:root,:root[data-theme=dark]{--bg: #1a1d21;--bg-2: #222529;--bg-3: #2b2e33;--sidebar: #19171d;--sidebar-2: #27242c;--text: #e8e8e8;--text-dim: #9a9ba0;--accent: #4f8cff;--accent-2: #3a6fd8;--danger: #e0524f;--green: #2bac76;--border: #34373c;color-scheme:dark}:root[data-theme=light]{--bg: #ffffff;--bg-2: #f6f7f9;--bg-3: #eceef2;--sidebar: #f1f2f5;--sidebar-2: #e3e5ea;--text: #1b1d21;--text-dim: #6a6e76;--accent: #2f6bff;--accent-2: #1f57e0;--danger: #d83b38;--green: #1f9d63;--border: #d9dce1;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],input[type=url],input[type=tel],input[type=time],select,textarea{width:100%;box-sizing:border-box;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:14px;outline:none;transition:border-color .12s ease}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=search]:focus,input[type=number]:focus,input[type=url]:focus,input[type=tel]:focus,input[type=time]:focus,select:focus,textarea:focus{border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text-dim)}input[type=file]{color:var(--text-dim);font-size:13px}input[type=file]::file-selector-button{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:7px 12px;margin-right:10px;color:var(--text);cursor:pointer;font:inherit}input[type=file]::file-selector-button:hover{border-color:var(--accent)}.boot{display:grid;place-items:center;height:100%;color:var(--text-dim)}.auth-wrap{display:grid;place-items:center;height:100%;background:radial-gradient(circle at 30% 20%,#232a37,var(--bg))}.auth-card{width:320px;background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:28px 26px;display:flex;flex-direction:column;gap:10px;box-shadow:0 20px 60px #0006}.auth-logo{margin:0;font-size:28px;background:linear-gradient(90deg,#6ea8ff,#b18cff);-webkit-background-clip:text;background-clip:text;color:transparent}.auth-sub{margin:0 0 8px;color:var(--text-dim)}.auth-card input{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);outline:none}.auth-card input:focus{border-color:var(--accent)}.auth-card button[type=submit]{margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px;font-weight:600}.auth-card button[type=submit]:hover{background:var(--accent-2)}.auth-error{background:#e0524f26;color:#ff9b99;border-radius:6px;padding:8px 10px;font-size:13px}.auth-switch{text-align:center;color:var(--text-dim);margin-top:4px}.auth-switch a{color:var(--accent);cursor:pointer}.layout{display:grid;grid-template-columns:var(--left-w, 250px) 1fr var(--right-w, 250px);height:100vh}.layout.admin-mode{grid-template-columns:var(--left-w, 250px) 1fr}.layout{overflow:hidden;position:relative}.resizer{position:absolute;top:0;bottom:0;width:8px;z-index:30;cursor:col-resize;background:linear-gradient(var(--accent, #5b9dd9),var(--accent, #5b9dd9)) center / 1px 100% no-repeat;opacity:0;transition:opacity .12s ease}.resizer:hover,body.resizing .resizer{opacity:.5}.resizer-left{left:calc(var(--left-w, 250px) - 4px)}.resizer-right{right:calc(var(--right-w, 250px) - 4px)}.layout.dock-open{grid-template-columns:var(--left-w, 250px) 1fr var(--dock-w, 340px) var(--right-w, 250px)}.resizer-dock{right:calc(var(--right-w, 250px) + var(--dock-w, 340px) - 4px)}@media (min-width: 861px){.layout.people-collapsed{grid-template-columns:var(--left-w, 250px) 1fr 60px}.layout.people-collapsed.dock-open{grid-template-columns:var(--left-w, 250px) 1fr var(--dock-w, 340px) 60px}.layout.people-collapsed .resizer-dock{right:calc(60px + var(--dock-w, 340px) - 4px)}.people.rail .people-head{justify-content:center;padding:10px 0}.people.rail .people-search,.people.rail .filter-input,.people.rail .folder-head,.people.rail .person-meta,.people.rail .chan-folder-btn,.people.rail .person .badge{display:none}.people.rail .people-list,.people.rail .folder-body{padding:4px 0}.people.rail .person-row{justify-content:center}.people.rail .person{justify-content:center;padding:5px 0;border-left:none!important;width:100%}.people.rail .avatar-sm{width:36px;height:36px}}@media (max-width: 860px){.people-collapse-btn{display:none}}body.resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.sidebar{background:var(--sidebar);color:var(--text);display:flex;flex-direction:column;overflow:hidden;border-right:1px solid #000}.sidebar-scroll{flex:1;overflow-y:auto;min-height:0}.recent-section{flex:none;border-top:1px solid #2a272f;max-height:30%;overflow-y:auto}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #2a272f}.brand{font-weight:700;font-size:16px}.me-row{display:flex;align-items:center;gap:8px;padding:10px 16px;color:var(--text-dim);flex:none;border-top:1px solid #2a272f;background:var(--sidebar)}.me-name{font-weight:600;color:var(--text)}.section{padding:8px 8px 12px}.section-head{display:flex;align-items:center;justify-content:space-between;color:var(--text-dim);text-transform:uppercase;font-size:11px;letter-spacing:.5px;padding:6px 8px}.chan-item{width:100%;display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-dim);padding:6px 8px;border-radius:6px;text-align:left}.chan-item:hover{background:var(--sidebar-2);color:var(--text)}.chan-item.active{background:var(--accent);color:#fff}.chan-hash{width:16px;text-align:center;opacity:.8}.chan-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chan-name.unread{font-weight:700;color:var(--text)}.folder-name.unread{color:var(--text)}.badge{background:var(--danger);color:#fff;border-radius:10px;padding:0 7px;font-size:11px;font-weight:700}.chan-name.muted,.person-name.muted{color:var(--text-dim);font-weight:400}.badge.muted{background:var(--bg-3, #2a2f37);color:var(--text-dim)}.chan-muted-icon{flex:0 0 auto;margin-left:4px;font-size:12px;color:var(--text-dim);opacity:.7}.chan-hash.muted{position:relative;display:inline-flex;align-items:center;justify-content:center}.chan-hash.muted:after{content:"";position:absolute;left:-3px;right:-3px;top:50%;height:1.5px;background:currentColor;opacity:.85;transform:rotate(-20deg);pointer-events:none}.ctx-item.checked{color:var(--accent)}.ctx-item.checked:after{content:"✓";margin-left:auto;font-weight:700}.empty-hint{color:var(--text-dim);padding:6px 8px;font-style:italic;font-size:13px}.filter-input{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:6px 8px;color:var(--text);margin-bottom:6px;outline:none}.icon-btn{background:transparent;border:none;color:var(--text-dim);font-size:16px;padding:2px 6px;border-radius:6px}.icon-btn:hover{background:var(--sidebar-2);color:var(--text)}.icon-btn.danger:hover{color:var(--danger, #e06c6c)}.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:none}.dot.online{background:var(--green)}.dot.offline{background:#5c5f66}.chat{display:flex;flex-direction:column;background:var(--bg);min-width:0;min-height:0;overflow:hidden;position:relative}.load-older{text-align:center;color:var(--text-dim);font-size:12px;padding:6px}.jump-bottom{position:absolute;right:22px;bottom:96px;z-index:20;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-2);color:var(--text);font-size:18px;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 18px #00000059}.jump-bottom:hover{background:var(--bg-3)}.no-channel{display:grid;place-items:center;background:var(--bg);color:var(--text-dim);text-align:center}.chat-head{display:flex;flex-direction:column;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border)}.chat-head-main{display:flex;align-items:center;gap:8px;min-height:30px}.chat-head-actions{margin-left:auto;display:flex;align-items:center;gap:2px}.chat-title{font-weight:700;font-size:16px;display:flex;align-items:center;gap:6px;flex:none}.chat-title-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}.chat-title-name .chat-handle{font-weight:600;color:var(--text-dim)}.chat-title-name .chat-handle .at{color:var(--accent)}.chat-topic{color:var(--text-dim);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:1px solid var(--border);padding-left:10px;flex:1;min-width:0}.chat-notify-status{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:1px 8px;border-radius:10px;background:var(--bg-3);color:var(--text-dim);font-size:11px;font-weight:600;white-space:nowrap;flex:0 0 auto}.chat-notify-status svg{font-size:12px}.chan-inline{display:inline-flex;align-items:center;gap:5px}.person.active{background:var(--accent);color:#fff}.person.active .person-sub{color:#fffc}.search-box{display:flex;align-items:center;gap:4px}.search-box input{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);outline:none;width:220px}.search-box input:focus{border-color:var(--accent)}.chat-head-search{width:100%}.chat-head-search input{flex:1;width:auto}.messages,.results{flex:1;min-height:0;overflow-y:auto;padding:0 18px 14px}.results-head{color:var(--text-dim);margin-bottom:8px}.msg{display:flex;gap:10px;padding:6px;border-radius:8px;position:relative;margin-top:16px;scroll-margin-top:14px}.msg:hover{background:var(--bg-2)}.msg.grouped{padding-top:1px;padding-bottom:1px;margin-top:0}.avatar-wrap.spacer{height:auto;display:flex;justify-content:center;align-items:flex-start}.msg-time-hover{font-size:10px;line-height:1.6;color:var(--text-dim);opacity:0;-webkit-user-select:none;user-select:none;transition:opacity .1s}.msg.grouped:hover .msg-time-hover{opacity:1}.avatar{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#4f8cff,#9a6bff);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}.msg-body{min-width:0;flex:1}.msg-head{display:flex;align-items:baseline;gap:8px;margin-bottom:3px}.msg-author{font-weight:700}.msg-time,.msg-edited{color:var(--text-dim);font-size:12px}.msg-content{white-space:pre-wrap;word-break:break-word;line-height:1.45}.attachments{margin-top:4px;display:flex;flex-wrap:wrap;gap:6px}.attachment{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--accent);text-decoration:none;font-size:13px}.reactions{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}.reaction{background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:1px 8px;color:var(--text);font-size:12px}.reaction.mine{border-color:var(--accent);background:#4f8cff2e}.msg-actions{position:absolute;top:-10px;right:10px;display:none;gap:2px;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:2px}.msg:hover .msg-actions{display:flex}.msg-actions button{background:transparent;border:none;font-size:14px;padding:3px 5px;border-radius:6px}.msg-actions button:hover{background:var(--bg)}.edit-row textarea{width:100%;background:var(--bg-3);border:1px solid var(--accent);border-radius:6px;color:var(--text);padding:6px;min-height:54px}.edit-row button{margin:6px 6px 0 0;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:4px 10px}.typing{color:var(--text-dim);font-size:12px;font-style:italic;padding:2px 18px;height:18px}.late-banner{margin:0 14px 6px;padding:7px 12px;border-radius:8px;background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);color:var(--text);font-size:13px}.composer{padding:10px 18px 16px;flex:none}.attach-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}.pill{background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:3px 10px;font-size:12px}.pill a{color:var(--danger);margin-left:6px;cursor:pointer}.composer-row{display:flex;align-items:flex-end;gap:8px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:8px}.composer-row textarea{flex:1;resize:none;background:transparent;border:none;color:var(--text);outline:none;max-height:260px;min-height:22px;line-height:1.4;overflow-y:auto}.send-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:600}.send-btn:hover{background:var(--accent-2)}.send-btn:disabled{opacity:.5}button svg{display:block;width:1.05em;height:1.05em}.icon-btn{display:inline-flex;align-items:center;justify-content:center}.people{background:var(--sidebar);border-left:1px solid #000;display:flex;flex-direction:column;overflow:hidden}.dock{background:var(--bg-2, var(--sidebar));border-left:1px solid var(--border, #2a272f);display:flex;flex-direction:column;overflow:hidden;min-width:0}.dock-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border, #2a272f);font-weight:700}.dock-head h3{margin:0;font-size:15px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dock-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.dock-tabs{display:flex;gap:2px;padding:8px;flex-wrap:wrap;border-bottom:1px solid var(--border)}.dock-tabs button{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border:none;border-radius:8px;background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer}.dock-tabs button:hover{background:var(--bg-3);color:var(--text)}.dock-tabs button.active{background:var(--accent);color:#fff}.dock-pane{flex:1;min-height:0;overflow-y:auto;padding:10px 12px 16px}.pin-author{display:inline-flex;align-items:center;gap:6px;min-width:0}.pin-author .avatar-sm{width:22px;height:22px;font-size:9px;flex:none}.user-info{overflow-y:auto;padding:16px;gap:18px}.user-info-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.user-info-avatar{width:84px;height:84px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:#fff;position:relative;overflow:visible}.user-info-avatar .avatar-img{width:100%;height:100%;border-radius:18px;object-fit:cover}.user-info-avatar .presence{position:absolute;right:-2px;bottom:-2px;width:16px;height:16px;border-radius:50%;border:3px solid var(--bg-2, var(--sidebar))}.user-info-avatar .presence.online{background:var(--green, #3ba55d)}.user-info-avatar .presence.offline{background:#6b6b6b}.user-info-name{font-size:18px;font-weight:700}.user-info-handle{display:inline-flex;align-items:center;gap:3px;color:var(--text-dim);font-size:13px}.user-info-handle svg{width:13px;height:13px}.user-info-status{font-size:12px;font-weight:600}.user-info-status.online{color:var(--green, #3ba55d)}.user-info-status.offline{color:var(--text-dim)}.user-info-fields{display:flex;flex-direction:column;gap:8px}.user-info-field{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:var(--bg-3);color:var(--text);text-decoration:none}a.user-info-field:hover{background:var(--bg-1, var(--bg-3));outline:1px solid var(--accent)}.user-info-icon{flex:none;width:18px;height:18px;color:var(--text-dim)}.user-info-field-meta{display:flex;flex-direction:column;min-width:0}.user-info-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim)}.user-info-value{font-size:14px;overflow-wrap:anywhere}.user-info-dm{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border:none;border-radius:10px;background:var(--accent);color:#fff;font-weight:600;font-size:14px;cursor:pointer}.user-info-dm:hover{filter:brightness(1.08)}.avatar-wrap.as-btn{border:none;background:transparent;padding:0;cursor:pointer}.msg-author.as-link{cursor:pointer}.msg-author.as-link:hover{text-decoration:underline}.invite-row.as-btn{cursor:pointer}.invite-row.as-btn:hover{background:var(--bg-3);border-radius:8px}.msg-forwarded{display:inline-flex;align-items:center;gap:5px;margin:2px 0 4px;padding:2px 8px;border:none;border-radius:8px;background:var(--bg-3);color:var(--text-dim);font-size:12px;cursor:pointer}.msg-forwarded:hover:not(:disabled){color:var(--accent)}.msg-forwarded:disabled{cursor:default}.msg-forwarded svg{width:12px;height:12px}.msg-forward-block{border-left:2px solid var(--accent);padding-left:10px;margin-top:2px}.msg-forward-author{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:2px}.avatar-xs{width:18px;height:18px;border-radius:5px;display:inline-grid;place-items:center;font-size:8px;font-weight:700;color:#fff;overflow:hidden;flex:none}.avatar-xs .avatar-img{width:100%;height:100%;object-fit:cover}.avatar-xs.anon{background:var(--bg-1, #555);color:var(--text-dim)}.avatar-xs.anon svg{width:11px;height:11px}.msg.selecting{cursor:pointer}.msg.selecting:hover{background:var(--bg-3)}.msg.selected{background:color-mix(in srgb,var(--accent) 14%,transparent)}.msg-select{position:absolute;left:6px;top:8px;width:20px;height:20px;border-radius:50%;border:2px solid var(--border);background:var(--bg-2, var(--bg-3));display:grid;place-items:center;color:#fff;z-index:3}.msg-select.on{background:var(--accent);border-color:var(--accent)}.msg.selecting{padding-left:30px;position:relative}.select-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 14px;border-top:1px solid var(--border);background:var(--bg-2, var(--sidebar))}.select-bar-actions{display:inline-flex;gap:8px}.forward-modal{width:min(440px,94vw);display:flex;flex-direction:column;max-height:80vh}.forward-search{position:relative;padding:10px 14px}.forward-search-icon{position:absolute;left:24px;top:50%;transform:translateY(-50%);color:var(--text-dim)}.forward-search input{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:8px 10px 8px 32px;color:var(--text);outline:none}.forward-list{overflow-y:auto;padding:4px 8px 12px}.forward-section{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim);padding:8px 8px 4px}.forward-row{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--text);border-radius:8px;cursor:pointer;text-align:left}.forward-row:hover{background:var(--bg-3)}.forward-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-fwd-bar{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.row-check{flex:none;width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:grid;place-items:center;color:#fff}.row-check.on{background:var(--accent);border-color:var(--accent)}.att-file.selected,.att-audio.selected{outline:2px solid var(--accent);outline-offset:-2px;border-radius:10px}.gal-cell.selectable{cursor:pointer}.gal-cell.selected{outline:3px solid var(--accent);outline-offset:-3px}.gal-check{position:absolute;top:6px;left:6px;width:22px;height:22px;border-radius:50%;border:2px solid #fff;background:#0006;display:grid;place-items:center;color:#fff;z-index:2}.gal-check.on{background:var(--accent);border-color:var(--accent)}.export-channels{border:1px solid var(--border);border-radius:8px;overflow:hidden}.export-channels-head{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border);font-size:13px}.export-channels-list{max-height:200px;overflow-y:auto;padding:4px 0}.export-channel-row{display:flex;align-items:center;gap:8px;padding:5px 10px;cursor:pointer}.export-channel-row:hover{background:var(--bg-3)}.link-btn{border:none;background:transparent;color:var(--accent);cursor:pointer;font-size:12px;padding:0}.dm-blocked{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:24px;color:var(--text-dim)}.dm-blocked-icon{font-size:40px;opacity:.7}.dm-blocked-title{font-size:16px;font-weight:700;color:var(--text)}.dm-blocked-text{max-width:340px}.global-media{padding:12px 16px}.global-media .panel-media-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.global-media-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 0;color:var(--text-dim)}.global-media-loading svg{font-size:30px}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.day-divider{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:4;background:var(--bg);margin:0;padding:8px 10px;color:var(--text-dim);font-size:12px;font-weight:600}.day-divider:before,.day-divider:after{content:"";flex:1;height:1px;background:var(--border)}.day-divider span{white-space:nowrap}.todo-panel{display:flex;flex-direction:column;gap:8px}.todo-new-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:1px dashed var(--border);border-radius:10px;background:transparent;color:var(--text);font-weight:600;cursor:pointer}.todo-new-btn:hover{border-color:var(--accent);color:var(--accent)}.todo-new-input{display:flex;align-items:center;gap:6px}.todo-new-input input{flex:1;min-width:0;background:var(--bg-3);border:1px solid var(--accent);border-radius:8px;padding:7px 10px;color:var(--text);outline:none}.todo-card{border:1px solid var(--border);border-radius:10px;background:var(--bg-2, var(--bg-3));overflow:hidden}.todo-card-head{display:flex;align-items:center;gap:6px;padding:8px 8px 8px 4px}.todo-card-toggle{border:none;background:transparent;color:var(--text-dim);cursor:pointer;display:inline-flex;padding:2px}.todo-card-name{flex:1;min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-card-name.struck{text-decoration:line-through;color:var(--text-dim)}.todo-card-name-input{flex:1;min-width:0;background:var(--bg-3);border:1px solid var(--accent);border-radius:6px;padding:4px 8px;color:var(--text);font-weight:600;outline:none}.todo-card-bar{margin:2px 0 8px}@keyframes todoFlash{0%{box-shadow:0 0 0 2px var(--accent)}65%{box-shadow:0 0 0 2px var(--accent)}to{box-shadow:0 0 #0000}}.todo-card.flash{animation:todoFlash 1.6s ease-out}.todo-card-actions,.todo-row-actions{display:inline-flex;align-items:center;gap:2px}.todo-card-body{padding:2px 10px 10px;border-top:1px solid var(--border)}.todo-pct{flex:none;min-width:30px;height:20px;padding:0 5px;border-radius:10px;background:var(--bg-1, #0003);color:var(--text-dim);font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.todo-check{flex:none;width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border);background:transparent;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.todo-check svg{width:16px;height:16px}.todo-check.done{background:var(--green, #3ba55d);border-color:var(--green, #3ba55d)}.todo-check.done.parent{cursor:default}.todo-tree{display:flex;flex-direction:column;gap:1px;padding-top:4px}.todo-row{display:flex;align-items:center;gap:6px;padding:3px 2px;border-radius:6px}.todo-row:hover{background:var(--bg-3)}.todo-row[draggable=true]{cursor:grab}.todo-row.drag-over{box-shadow:inset 0 2px 0 var(--accent);background:var(--bg-3)}.todo-toggle-collapse{border:none;background:transparent;color:var(--text-dim);cursor:pointer;display:inline-flex;padding:0}.todo-collapse-spacer{width:14px;flex:none}.todo-main{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;column-gap:6px;row-gap:0}.todo-text{overflow-wrap:break-word}.todo-row.done .todo-text{color:var(--text-dim)}.todo-done-by{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--text-dim);font-style:italic;text-decoration:none}.todo-row-actions{opacity:0;transition:opacity .1s ease}.todo-row:hover .todo-row-actions{opacity:1}.todo-mini{border:none;background:transparent;color:var(--text-dim);cursor:pointer;padding:3px;border-radius:5px;display:inline-flex}.todo-mini:hover{background:var(--bg-1, #0004);color:var(--text)}.todo-mini.danger:hover{color:var(--danger, #e06c6c)}.todo-edit-input,.todo-add input{flex:1;min-width:0;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--text);outline:none;font-size:13px}.todo-edit-input:focus,.todo-add input:focus{border-color:var(--accent)}.todo-add{display:flex;align-items:center;gap:6px;padding:3px 2px 3px 20px}.todo-add-icon{color:var(--text-dim);flex:none}.todo-add-wrap{display:flex;align-items:center;gap:4px}.todo-children{display:flex;flex-direction:column;gap:1px}.todo-archive{margin-top:4px;border-top:1px solid var(--border);padding-top:8px;display:flex;flex-direction:column;gap:8px}.todo-archive-head{display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;color:var(--text-dim);cursor:pointer;font-weight:600;font-size:13px}.todo-modal{width:min(560px,94vw);display:flex;flex-direction:column;max-height:86vh}.todo-modal-body{padding:14px 16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.todo-name-input{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-size:16px;font-weight:600;outline:none}.todo-name-input:focus{border-color:var(--accent)}.todo-progress{display:flex;align-items:center;gap:10px}.todo-progress-bar{flex:1;height:8px;border-radius:4px;background:var(--bg-3);overflow:hidden}.todo-progress-bar span{display:block;height:100%;background:var(--accent);transition:width .2s ease}.todo-progress-bar span.done{background:var(--green, #3ba55d)}.todo-progress-label{font-size:12px;color:var(--text-dim);display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.todo-modal-foot{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text);cursor:pointer;font-size:13px}.btn-ghost:hover{border-color:var(--accent)}.btn-ghost.danger:hover{border-color:var(--danger, #e06c6c);color:var(--danger, #e06c6c)}.todo-chip{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border);border-radius:14px;background:var(--bg-3);color:var(--text);cursor:pointer;font-size:13px;font-weight:600}.todo-chip:hover{border-color:var(--accent);color:var(--accent)}.todo-chip.filled{border-color:transparent;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.todo-chip.filled:before{content:"";position:absolute;top:-1px;bottom:-1px;left:-1px;width:calc(var(--todo-pct) + 1px);background:var(--todo-fill);transition:width .3s ease,background .3s ease}.todo-chip.filled>*{position:relative;z-index:1}.todo-chip.filled:hover{color:#fff;border-color:#ffffff8c}.todo-chip.complete .todo-chip-name{text-decoration:line-through;opacity:.85}.todo-chip.archived{opacity:.7;background:var(--bg-3);border-color:var(--border);border-style:solid;color:var(--text-dim)}.todo-chip-archived{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim)}.todo-chip-name{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-chip-prog{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;margin-left:2px}.todo-chip-pct{font-weight:800}.todo-chip-frac{opacity:.85;font-weight:600}.people-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #2a272f;font-weight:700}.people-count{color:var(--green);font-size:12px;font-weight:600}.people-search{position:relative;padding:10px 12px}.people-search .people-search-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:var(--text-dim)}.people-search input{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:7px 10px 7px 30px;color:var(--text);outline:none}.people-search input:focus{border-color:var(--accent)}.people-list{flex:1;min-height:0;overflow-y:auto;padding:4px 8px 12px}.online-toggle{display:inline-flex;align-items:center;gap:5px;background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:3px 9px;color:var(--text-dim);font-size:12px;font-weight:600;cursor:pointer}.online-toggle .online-dot-icon{width:9px;height:9px;fill:var(--green);color:var(--green)}.online-toggle.active{background:#2bac7629;border-color:var(--green);color:var(--green)}.person{width:100%;display:flex;align-items:center;gap:10px;background:transparent;border:none;color:var(--text);padding:7px 8px;border-radius:8px;text-align:left}.person:hover{background:var(--sidebar-2)}.person:hover .person-dm{opacity:1}.avatar-sm{position:relative;width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#4f8cff,#9a6bff);color:#fff;display:grid;place-items:center;font-weight:700;font-size:11px;flex:none}.presence{position:absolute;right:-2px;bottom:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--sidebar)}.presence.online{background:var(--green)}.presence.offline{background:#5c5f66}.person-meta{display:flex;flex-direction:column;min-width:0;flex:1}.person-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-sub{color:var(--text-dim);font-size:12px}.person-seen{opacity:.75;font-size:11px}.muted-sm{font-size:11px;opacity:.85}.person-dm{color:var(--text-dim);opacity:0;transition:opacity .12s}.md p{margin:0;line-height:1.45;white-space:pre-wrap;word-break:break-word;font-size:13.5px}.md p,.md li{font-size:13.5px;color:color-mix(in srgb,var(--text) 80%,var(--text-dim))}.md p+p{margin-top:6px}.md strong{font-weight:700}.md del{opacity:.7}.md code{background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px}.codeblock code{background:transparent!important;border:none!important;padding:0;border-radius:0}.md pre{background:transparent;border:none;padding:0;margin:6px 0;overflow-x:auto}.md pre>code{display:block;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;overflow-x:auto}.md blockquote{margin:4px 0;padding:2px 12px;border-left:3px solid var(--accent);color:var(--text-dim)}.md ul,.md ol{margin:4px 0;padding-left:22px}.md a{color:var(--accent)}.md-img{max-width:100%;max-height:320px;border-radius:8px;display:block;margin:4px 0}.att-pdf-card .att-pdf-open{display:flex;align-items:center;gap:8px;flex:1;min-width:0;background:none;border:none;text-align:left;color:inherit;cursor:pointer;padding:0}.quote{display:flex;flex-direction:column;gap:1px;background:var(--bg-3);border:none;border-left:3px solid var(--accent);border-radius:0 6px 6px 0;padding:4px 10px;margin-bottom:4px;max-width:520px;text-align:left;cursor:pointer}.quote:hover{background:#313640}.quote-icon{color:var(--accent);flex:none;width:.9em;height:.9em}.quote-author{display:flex;align-items:center;gap:4px;font-weight:700;font-size:12px;color:var(--accent)}.quote-text{color:var(--text-dim);font-size:11.5px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}@keyframes flashbg{0%{background:#4f8cff59}to{background:transparent}}.msg.flash{animation:flashbg 1.6s ease-out}.reply-banner{display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:6px 10px;margin-bottom:6px;color:var(--text-dim)}.reply-banner-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-snippet{color:var(--text)}.toolbar{display:flex;gap:2px;margin-bottom:6px}.toolbar button{background:var(--bg-2);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:5px 8px;display:inline-flex}.toolbar button:hover{color:var(--text);border-color:var(--accent)}.search-box{position:relative}.search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.search-box input{padding-left:28px}.emoji-anchor{position:relative;display:inline-flex}.emoji-pop{position:absolute;bottom:120%;left:0;z-index:50}.emoji-pop.right{right:0;left:auto}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:grid;place-items:center;z-index:100}.modal{width:420px;max-width:calc(100vw - 32px);background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:14px;box-shadow:0 24px 70px #00000073}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0}.field{display:flex;flex-direction:column;gap:6px}.field>span{color:var(--text-dim);font-size:13px}.field input,.field select{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);outline:none}.field input:focus{border-color:var(--accent)}.type-choice{display:flex;gap:10px}.type-opt{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text)}.type-opt small{color:var(--text-dim)}.type-opt.active{border-color:var(--accent);background:#4f8cff24}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-weight:600;cursor:pointer}.btn-ghost{white-space:nowrap}.btn-primary:hover{background:var(--accent-2)}.btn-primary:disabled{opacity:.6}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border);border-radius:8px;padding:9px 16px}.btn-ghost:hover{color:var(--text)}.mobile-only,.backdrop{display:none}.no-channel-menu{position:absolute;top:12px;left:12px}@media (max-width: 860px){html,body,#root{height:auto}.layout,.layout.dock-open{grid-template-columns:1fr;height:auto;min-height:100dvh;overflow:visible}.resizer{display:none}.dock{position:fixed;top:0;bottom:0;right:0;width:320px;max-width:90vw;z-index:85;box-shadow:0 0 40px #00000080}.chat{min-height:100dvh;overflow:visible}.messages,.results{overflow:visible}.mobile-only{display:inline-flex}.sidebar,.people{position:fixed;top:0;bottom:0;width:280px;max-width:85vw;z-index:80;transition:transform .22s ease}.sidebar{left:0;transform:translate(-105%)}.people{right:0;transform:translate(105%)}.sidebar.open,.people.open{transform:translate(0);box-shadow:0 0 40px #00000080}.layout.drawer-open .backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:70}.chat-head{gap:8px}.search-box input{width:130px}}.head-actions{display:flex;gap:2px}.me-row{width:100%;text-align:left;cursor:pointer;border-left:none;border-right:none;border-bottom:none}.me-row:hover{background:var(--sidebar-2)}.me-avatar{width:24px;height:24px;border-radius:6px;object-fit:cover;display:inline-grid;place-items:center;font-size:10px;font-weight:700;flex:none}.me-avatar.fallback{background:linear-gradient(135deg,var(--accent),#9a6bff);color:#fff}img.avatar{object-fit:cover;padding:0}.avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:8px}.avatar-lg{width:72px;height:72px;border-radius:14px;object-fit:cover;flex:none}.avatar-lg.fallback{display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),#9a6bff);color:#fff;font-size:24px;font-weight:700}.settings-modal{width:640px;max-width:calc(100vw - 24px)}.settings-body{display:grid;grid-template-columns:160px 1fr;gap:16px;min-height:360px}.settings-nav{display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border);padding-right:8px}.settings-nav button{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-dim);padding:9px 10px;border-radius:8px;text-align:left}.settings-nav button:hover{background:var(--bg-3);color:var(--text)}.settings-nav button.active{background:var(--accent);color:#fff}.settings-pane{overflow-y:auto;max-height:60vh}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section h4{margin:0}.settings-hr{border:none;border-top:1px solid var(--border);margin:6px 0}.settings-msg{color:var(--green);font-size:13px}.settings-hint{color:var(--text-dim);font-size:13px;margin:0}.notif-test-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.settings-h4{margin:6px 0 0;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.sound-row{display:flex;gap:8px;align-items:center}.sound-row select{flex:1;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);outline:none}.toggle-row{display:flex;align-items:center;gap:10px;cursor:pointer}.toggle-row input{width:16px;height:16px;accent-color:var(--accent)}.dnd-times{display:flex;gap:12px}.dnd-times .field{flex:1}.bypass-block{display:flex;flex-direction:column;gap:6px}.bypass-title{font-weight:600;font-size:13px}.bypass-list{display:flex;flex-direction:column;gap:4px;max-height:150px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:8px;background:var(--bg-3)}.bypass-item{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.bypass-item input{accent-color:var(--accent)}.avatar-row{display:flex;align-items:center;gap:16px}.avatar-actions{display:flex;flex-direction:column;gap:8px}.avatar-actions .btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;min-width:150px}.file-btn{display:inline-flex;align-items:center;gap:6px;cursor:pointer}.accent-row{display:flex;gap:10px}.accent-dot{width:28px;height:28px;border-radius:50%;border:2px solid transparent;display:grid;place-items:center;color:#fff}.accent-dot.active{border-color:var(--text)}.qr-wrap{background:#fff;padding:12px;border-radius:10px;width:fit-content}.totp-secret{display:inline-block;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:6px 10px;letter-spacing:1px;font-size:13px;word-break:break-all}.twofa-status.enabled{display:inline-flex;align-items:center;gap:6px;color:var(--green);font-weight:600}@media (max-width: 600px){.settings-body{grid-template-columns:1fr}.settings-nav{flex-direction:row;border-right:none;border-bottom:1px solid var(--border);padding:0 0 8px;overflow-x:auto}}.nav-section{padding:4px 8px}.nav-item{width:100%;display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-dim);padding:7px 8px;border-radius:6px;text-align:left}.nav-item:hover{background:var(--sidebar-2);color:var(--text)}.nav-item.active{background:var(--accent);color:#fff}.section-head-actions{display:flex;gap:2px}.chan-row{position:relative;display:flex;align-items:center}.chan-row .chan-item{flex:1}.chan-folder-btn{background:transparent;border:none;color:var(--text-dim);padding:4px 6px;border-radius:6px;opacity:0}.chan-row:hover .chan-folder-btn{opacity:1}.chan-folder-btn:hover{background:var(--sidebar-2);color:var(--text)}.folder-menu{position:absolute;right:0;top:100%;z-index:40;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:160px;box-shadow:0 10px 30px #0006}.folder-menu-title{color:var(--text-dim);font-size:11px;padding:4px 8px}.folder-menu button{width:100%;text-align:left;background:transparent;border:none;color:var(--text);padding:6px 8px;border-radius:6px}.folder-menu button:hover{background:var(--bg-3)}.folder-menu-empty{color:var(--text-dim);font-size:12px;padding:6px 8px}.folder-head{display:flex;align-items:center;position:relative;padding-left:6px}.ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.ctx-menu{position:fixed;z-index:91;min-width:180px;max-height:70vh;overflow-y:auto;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:4px;box-shadow:0 12px 36px #00000073}.ctx-title{color:var(--text-dim);font-size:11px;text-transform:uppercase;letter-spacing:.4px;padding:6px 8px 2px}.ctx-item{width:100%;display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text);padding:7px 8px;border-radius:6px;text-align:left;cursor:pointer}.ctx-item:hover{background:var(--bg-3)}.ctx-item.danger{color:var(--danger)}.ungrouped{min-height:6px}.chan-row[draggable=true]{cursor:default}.logout-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px}.color-dots{display:flex;flex-wrap:wrap;gap:6px;padding:4px 6px 8px}.color-dot{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer}.color-dot.active{border-color:var(--text)}.color-dot.none{background:var(--bg-3);position:relative}.color-dot.none:after{content:"✕";position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:10px;color:var(--text-dim)}.folder-toggle{flex:1;display:flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text-dim);padding:6px 8px;border-radius:6px;text-transform:uppercase;font-size:11px;letter-spacing:.4px}.folder-toggle:hover{color:var(--text)}.folder-name{flex:1;text-align:left;font-weight:700}.folder-count{color:var(--text-dim)}.folder-body{padding-left:8px}.folder .icon-btn{opacity:0}.folder:hover .icon-btn{opacity:1}.group-card{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}.group-card-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.group-card-actions{margin-left:auto;display:flex;gap:2px}.group-name-input{flex:1;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:7px 9px}.perm-list{display:flex;flex-direction:column;gap:8px}.perm-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer}.perm-row input{margin-top:3px}.perm-text{display:flex;flex-direction:column}.perm-label{font-weight:600}.perm-desc{color:var(--text-dim);font-size:12px}.toolbar-sep{width:1px;align-self:stretch;background:var(--border);margin:0 4px}.toolbar-wide{display:inline-flex;align-items:center;gap:5px;background:var(--bg-2);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:5px 9px;font-size:12px}.toolbar-wide:hover{color:var(--text);border-color:var(--accent)}.toolbar-wide.active{background:var(--accent);color:#fff;border-color:var(--accent)}.composer-preview{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:6px;max-height:260px;overflow-y:auto}.msg-pinned{display:inline-flex;align-items:center;gap:3px;color:var(--accent);font-size:11px}.avatar-wrap{position:relative;flex:none;width:36px;height:36px}.avatar-wrap .avatar{width:36px;height:36px}.avatar-presence{position:absolute;right:-2px;bottom:-2px;width:11px;height:11px;border-radius:50%;border:2px solid var(--bg)}.avatar-presence.online{background:var(--green)}.avatar-presence.offline{background:#6b6f78}.msg:hover .avatar-presence{border-color:var(--bg-2)}.mention-pop{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:4px;margin-bottom:6px;max-height:240px;overflow-y:auto;box-shadow:0 10px 30px #00000059}.mention-item{width:100%;display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text);padding:7px 9px;border-radius:7px;text-align:left}.mention-item.active{background:var(--accent);color:#fff}.mention-kind{font-weight:700;opacity:.8;width:14px;text-align:center}.mention-label{font-weight:600}.mention-sub{color:var(--text-dim);font-size:12px;margin-left:auto}.mention-item.active .mention-sub{color:#fffc}.attachments{display:flex;flex-direction:column;gap:6px;margin-top:6px;align-items:flex-start}.att-media-link{display:inline-block;line-height:0}.att-image{max-width:380px;max-height:300px;border-radius:10px;border:1px solid var(--border);object-fit:cover}.att-video{max-width:420px;max-height:320px;border-radius:10px;border:1px solid var(--border);background:#000}.att-audio{width:320px}.att-file{display:flex;align-items:center;gap:10px;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:8px 12px;min-width:240px;max-width:380px}.att-file-icon{font-size:22px;color:var(--accent);flex:none}.att-file-meta{display:flex;flex-direction:column;min-width:0;flex:1}.att-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-file-size{color:var(--text-dim);font-size:12px}.att-file-dl{color:var(--text-dim);flex:none;display:inline-flex;padding:6px;border-radius:6px;border:none;background:transparent;cursor:pointer}.att-file-dl:hover{background:var(--bg);color:var(--text)}.att-audio{display:flex;flex-direction:column;gap:8px;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:8px 12px;min-width:280px;max-width:420px}.att-audio-head{display:flex;align-items:center;gap:10px}.att-audio-player{width:100%;height:34px}.custom-emoji{height:1.4em;width:auto;vertical-align:-.3em;display:inline-block}.mention-kind .custom-emoji{height:20px}.custom-emoji-grid{display:flex;flex-wrap:wrap;gap:12px}.custom-emoji-item{display:flex;flex-direction:column;align-items:center;gap:2px;width:64px}.custom-emoji-item img{width:32px;height:32px;object-fit:contain}.custom-emoji-item small{color:var(--text-dim);font-size:10px;overflow:hidden;text-overflow:ellipsis;max-width:100%;white-space:nowrap}.md-clamp{max-height:220px;overflow:hidden;-webkit-mask-image:linear-gradient(180deg,#000 70%,transparent);mask-image:linear-gradient(180deg,#000 70%,transparent)}.show-all{margin-top:4px;background:transparent;border:none;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer;padding:0}.edit-textarea{min-height:60px;resize:none;overflow-y:auto}.gallery{display:grid;gap:4px;max-width:340px}.gallery.g1{grid-template-columns:1fr}.gallery.g2{grid-template-columns:1fr 1fr}.gallery.g3,.gallery.g4{grid-template-columns:repeat(3,1fr)}.gal-cell{position:relative;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg-3);padding:0;aspect-ratio:1 / 1;cursor:zoom-in}.gallery.g1 .gal-cell{aspect-ratio:auto;height:240px}.gal-cell img,.gal-cell video{width:100%;height:100%;object-fit:cover;display:block}.gallery.g1 .gal-cell img,.gallery.g1 .gal-cell video{max-height:240px;object-fit:contain;background:#000}.gal-play{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff;font-size:26px;background:#00000040;pointer-events:none}.gal-more{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0000008c;color:#fff;font-size:22px;font-weight:700}.gal-dl{position:absolute;top:6px;right:6px;width:28px;height:28px;border:none;border-radius:6px;background:#0000008c;color:#fff;display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .12s;z-index:2}.gal-actions{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .12s;z-index:2}.gal-cell:hover .gal-actions{opacity:1}.gal-act{width:28px;height:28px;border:none;border-radius:6px;background:#0000008c;color:#fff;display:grid;place-items:center;cursor:pointer}.gal-act:hover{background:#000000c7}.gal-cell:hover .gal-dl,.att-pdf-frame:hover .gal-dl{opacity:1}.gal-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 8px 5px;font-size:10px;line-height:1.3;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.9);background:linear-gradient(to top,#000000d9,#0000008c 45%,#0000);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;z-index:1}.codeblock{position:relative;max-width:100%}.codeblock div::-webkit-scrollbar{height:8px}.codeblock div::-webkit-scrollbar-thumb{background:#3a3f4b;border-radius:6px}.code-actions{position:absolute;top:12px;right:12px;z-index:2;display:flex;gap:4px;opacity:0;transition:opacity .12s}.codeblock:hover .code-actions{opacity:1}.code-btn{background:#80808047;border:none;color:var(--text);border-radius:6px;padding:5px;display:inline-flex;cursor:pointer}.code-btn:hover{background:#80808073}.code-btn.ok{color:var(--green)}.att-pdf{display:block;text-align:left;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;overflow:hidden;padding:0;max-width:320px;cursor:pointer}.att-pdf-frame{position:relative;height:180px;background:#fff}.att-pdf-frame iframe{width:100%;height:100%;border:0;pointer-events:none}.att-pdf-overlay{position:absolute;top:0;right:0;bottom:0;left:0}.att-pdf .att-file-meta{padding:8px 10px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000d9;display:grid;grid-template-rows:1fr auto;place-items:center}.lb-stage{display:grid;place-items:center;max-width:92vw;max-height:82vh;overflow:auto}.lb-stage img,.lb-stage video{max-width:92vw;max-height:80vh;border-radius:8px}.lb-pdf{width:86vw;height:80vh;border:0;background:#fff;border-radius:8px}.lb-close{position:fixed;top:16px;right:18px;background:#ffffff1f;border:none;color:#fff;border-radius:8px;padding:8px;font-size:18px;cursor:pointer}.lb-nav{position:fixed;top:50%;transform:translateY(-50%);background:#ffffff1f;border:none;color:#fff;border-radius:50%;width:44px;height:44px;font-size:22px;display:grid;place-items:center;cursor:pointer}.lb-nav.prev{left:16px}.lb-nav.next{right:16px}.lb-meta{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;color:#eee;background:#0006}.lb-meta-text{display:flex;flex-direction:column;min-width:0}.lb-name{font-weight:600}.lb-sub{color:#aab;font-size:12px}.lb-dl{display:inline-flex;align-items:center;gap:6px;color:#fff;background:var(--accent);border-radius:8px;padding:8px 14px;text-decoration:none;flex:none}.link-preview{display:flex;gap:10px;margin-top:6px;max-width:460px;background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:8px 10px;text-decoration:none;color:var(--text)}.lp-img{width:64px;height:64px;object-fit:cover;border-radius:6px;flex:none}.lp-body{display:flex;flex-direction:column;min-width:0;gap:2px}.lp-site{color:var(--text-dim);font-size:11px;text-transform:uppercase}.lp-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lp-desc{color:var(--text-dim);font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.panel-date{position:sticky;top:0;background:var(--bg-2);color:var(--text-dim);font-size:12px;font-weight:600;padding:6px 2px;margin:6px 0 4px;z-index:1}.panel-media-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.panel-media-grid .gal-cell{aspect-ratio:1 / 1}.link-list-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 6px;border:none;border-bottom:1px solid var(--border);background:none;color:var(--accent);text-decoration:none;text-align:left;word-break:break-all;cursor:pointer}.link-list-item:hover{background:var(--bg-2)}.link-list-url{overflow:hidden;text-overflow:ellipsis}.panel-pin{border-bottom:1px solid var(--border);padding:8px 6px;border-radius:6px;cursor:pointer}.panel-pin:hover{background:var(--bg-2)}.quick-emoji-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.quick-emoji-chip{display:inline-flex;align-items:center;gap:4px;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:16px;cursor:pointer}.quick-emoji-chip svg{width:12px;height:12px;color:var(--text-dim)}.settings-emoji-pop{margin-top:8px}.settings-emoji-pop .EmojiPickerReact{--epr-emoji-size: 22px;width:100%!important}.invite-list{max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.invite-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 4px;border-bottom:1px solid var(--border)}.invite-row .btn-primary,.invite-row .btn-ghost{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;font-size:13px}.raw-md{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:8px 10px;margin:2px 0;white-space:pre-wrap;word-break:break-word;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px;color:var(--text-dim)}.msg-actions button.active{background:var(--accent);color:#fff;border-radius:6px}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.app-icon-row{display:flex;gap:16px;flex-wrap:wrap;padding:6px 8px}.app-icon-swatch{position:relative;border:none;background:transparent;padding:0;cursor:pointer}.app-icon-img{width:46px;height:46px;border-radius:13px;display:block;object-fit:cover;box-shadow:inset 0 0 0 1px #ffffff2e}.app-icon-swatch.active .app-icon-img{outline:2px solid var(--accent);outline-offset:2px}.app-icon-swatch>svg{position:absolute;right:-5px;bottom:-5px;background:var(--accent);color:#fff;border-radius:50%;padding:2px;font-size:13px;box-shadow:0 0 0 2px var(--bg-2, var(--bg-3))}.theme-card{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:8px;text-align:left;color:var(--text)}.theme-card.active{border-color:var(--accent)}.theme-swatch{height:44px;border-radius:6px;border:1px solid;display:flex;align-items:center;gap:5px;padding:0 8px;margin-bottom:6px}.theme-swatch span{width:16px;height:16px;border-radius:50%}.theme-name{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{text-align:left;padding:7px 8px;border-bottom:1px solid var(--border)}.admin-table th{color:var(--text-dim);font-weight:600}.admin-table .muted,.muted{color:var(--text-dim);font-size:12px}.admin-table select,.grant-row select,.field select{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:5px 8px}.row-actions{display:flex;gap:2px}.tag{background:var(--accent);color:#fff;border-radius:8px;padding:0 6px;font-size:10px;font-weight:700}.new-group-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.new-group-row input[type=text],.new-group-row>input:first-child{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:7px 9px}.new-group-row label{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--text-dim)}.admin-channel{border:1px solid var(--border);border-radius:8px;padding:10px}.admin-channel-head{display:flex;align-items:center;justify-content:space-between}.grant-row{display:flex;gap:8px;margin-top:8px}.person:disabled{opacity:.6;cursor:not-allowed}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-thumb{background:#3a3d42;border-radius:6px}.chan-search-box{position:relative;margin-bottom:6px}.chan-search-box .chan-search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.chan-search{margin-bottom:0;padding-left:28px}.panel-modal{width:860px;max-width:calc(100vw - 24px)}.admin-modal{width:1100px;max-width:calc(100vw - 32px)}.admin-modal .settings-body{min-height:70vh}.admin-modal .settings-pane{max-height:78vh;overflow-y:auto}.panel-modal .settings-body{min-height:60vh}.panel-modal .settings-pane{max-height:70vh;overflow-y:auto}.pin-jump{cursor:pointer}.drop-overlay{position:absolute;top:8px;right:8px;bottom:8px;left:8px;z-index:50;background:#4f8cff1a;border:2px dashed var(--accent);border-radius:12px;display:grid;place-items:center;pointer-events:none}.drop-overlay-box{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--accent);border-radius:12px;padding:14px 22px;font-weight:600;color:var(--text);font-size:16px}.mymsg-chan{display:inline-flex;align-items:center;gap:4px;font-weight:700;color:var(--accent);font-size:13px}.sys-msg{text-align:center;margin:10px 0;color:var(--text-dim);font-size:12px}.sys-msg>span{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:2px 12px}.sys-msg-time{margin-left:8px;opacity:.6;font-size:11px}.admin-users-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.group-chips{display:flex;flex-wrap:wrap;gap:6px}.group-chip{background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:3px 10px;font-size:12px;color:var(--text-dim);cursor:pointer}.group-chip.on{background:#4f8cff2e;border-color:var(--accent);color:var(--text)}.new-user-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.new-user-grid input{width:100%}.row-disabled td{opacity:.5}.btn-ghost.danger{color:var(--danger);border-color:var(--danger)}.people-head-actions{display:flex;align-items:center;gap:4px}.person-row{display:flex;align-items:center}.person-row .person{flex:1;min-width:0}.person-row:hover .chan-folder-btn{opacity:1}.people-list .filter-input{margin:6px 0}.ctx-item.muted{color:var(--text-dim);cursor:default}.admin-sidebar .nav-section.admin-nav{padding:8px 8px 0;display:flex;flex-direction:column;gap:2px}.admin-view{grid-column:2;display:flex;flex-direction:column;height:100vh;min-width:0;overflow:hidden;background:var(--bg)}.admin-view-head{padding:14px 20px;border-bottom:1px solid var(--border);flex:0 0 auto}.admin-view-head h2{margin:0;font-size:18px}.admin-view-body{flex:1;overflow-y:auto;padding:16px 20px 40px}.admin-view-body .settings-section{max-width:920px}.admin-search{display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:6px 10px;flex:1;min-width:0}.admin-search input{border:none;background:transparent;color:var(--text);outline:none;flex:1;min-width:0}.admin-channel-actions{display:flex;align-items:center;gap:14px}.member-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.member-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg-3);border-radius:14px;padding:3px 6px 3px 10px;font-size:13px}.member-owner{font-size:10px;text-transform:uppercase;color:var(--text-dim);letter-spacing:.03em}.member-x{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-dim);cursor:pointer;border-radius:50%;width:18px;height:18px}.member-x:hover{background:var(--danger);color:#fff}.modal.admin-dialog{width:min(560px,94vw);max-height:88vh;display:flex;flex-direction:column}.admin-dialog-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.admin-dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.member-pick-list{display:flex;flex-direction:column;gap:2px;max-height:48vh;overflow-y:auto}.member-pick-row{display:flex;align-items:center;gap:10px;padding:7px 8px;background:transparent;border:none;border-radius:8px;color:var(--text);text-align:left;cursor:pointer;width:100%}.member-pick-row:hover{background:var(--bg-3)}.toast-stack{position:fixed;bottom:20px;right:20px;z-index:2000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.toast{pointer-events:auto;display:inline-flex;align-items:center;gap:9px;min-width:190px;max-width:380px;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-2);color:var(--text);box-shadow:0 10px 28px #00000061;font-size:14px;text-align:left;cursor:pointer;animation:toast-in .18s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-icon{display:inline-flex;flex:0 0 auto;font-size:17px}.toast-msg{flex:1;min-width:0}.toast-success .toast-icon{color:var(--green, #34c759)}.toast-error{border-color:var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-info .toast-icon{color:var(--accent)}@media (max-width: 560px){.toast-stack{left:12px;right:12px;bottom:12px}.toast{max-width:none}}.toolbar-right{margin-left:auto;display:inline-flex;align-items:center;gap:2px}.toolbar-right .emoji-pop{left:auto;right:0}.call-card{display:inline-flex;align-items:center;gap:12px;margin-top:6px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg-2);color:var(--text);text-decoration:none;max-width:320px}.call-card:hover{border-color:var(--accent)}.call-card-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--green, #34c759);color:#fff;font-size:21px;flex:0 0 auto}.call-card-text{display:flex;flex-direction:column;min-width:0}.call-card-title{font-weight:600}.call-card-host{color:var(--text-dim);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.confirm-body{color:var(--text-dim);line-height:1.5}.btn-danger{background:var(--danger)}.btn-danger:hover{filter:brightness(1.08)}.type-choice-3 .type-opt{flex:1 1 30%;min-width:0}.composer.composer-locked{display:flex;align-items:center;gap:8px;padding:14px 18px;color:var(--text-dim);border-top:1px solid var(--border);font-size:13px}.composer.composer-locked svg{flex-shrink:0;color:var(--accent)}.grant-toggles{display:inline-flex;gap:4px;margin-left:auto}.grant-toggles .grant{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-dim);cursor:pointer}.grant-toggles .grant.on{background:var(--accent);border-color:var(--accent);color:#fff}.seg-tabs{display:flex;gap:6px;margin-bottom:14px}.seg-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-dim);cursor:pointer}.seg-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-inline-form{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.admin-inline-form input{flex:1 1 160px}.webhook-row{display:flex;gap:6px;margin:8px 0}.webhook-row input{flex:1;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;color:var(--text-dim)}.admin-channel.is-disabled{opacity:.55}.bot-avatar-btn{position:relative;width:26px;height:26px;border-radius:6px;overflow:hidden;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#fff;flex:none}.bot-avatar-btn .avatar-img{width:100%;height:100%;object-fit:cover}.btn-xs{padding:3px 8px;font-size:12px}.cmd-url{font-family:SF Mono,Menlo,Consolas,monospace;word-break:break-all}.field-row{display:flex;gap:10px}.checkbox-row{display:flex;align-items:center;gap:8px;margin:8px 0;cursor:pointer}.integration-help{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin:4px 0 16px;font-size:13px}.integration-help p{margin:0 0 8px}.integration-help pre{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;overflow-x:auto;font-size:12px;line-height:1.5;white-space:pre}.bot-create-avatar{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:14px}.bot-avatar-btn.lg{width:72px;height:72px;border-radius:16px;font-size:24px}.avatar-presets{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:4px}.avatar-preset{width:52px;height:52px;border-radius:12px;overflow:hidden;border:2px solid var(--border);background:var(--bg-3);padding:0;cursor:pointer;transition:border-color .12s ease}.avatar-preset img{width:100%;height:100%;object-fit:cover;display:block}.avatar-preset:hover{border-color:var(--text-dim)}.avatar-preset.active{border-color:var(--accent)}
