*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button,a,[role=button]{-webkit-touch-callout:none;touch-action:manipulation}html,body{height:100%;width:100%;overflow:hidden;background-color:var(--bg);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);line-height:var(--line-height);overscroll-behavior:none;-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{touch-action:pan-x pan-y}::selection{background-color:var(--accent-primary);color:var(--bg)}::-webkit-scrollbar{width:var(--scrollbar-width);height:var(--scrollbar-width)}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}#app{display:flex;height:100vh;height:100dvh;width:100vw;width:100dvw;overflow:hidden}.quark-layout{display:grid;grid-template-columns:var(--space-strip-width) var(--room-list-width) 1fr;grid-template-rows:1fr;height:100%;width:100%;overflow:hidden}.quark-layout--thread-open{grid-template-columns:var(--space-strip-width) var(--room-list-width) 1fr var(--thread-view-width)}.quark-layout--member-list-open{grid-template-columns:var(--space-strip-width) var(--room-list-width) 1fr var(--member-list-width)}.quark-layout--thread-open.quark-layout--member-list-open{grid-template-columns:var(--space-strip-width) var(--room-list-width) 1fr var(--thread-view-width) var(--member-list-width)}.quark-layout--home{grid-template-columns:var(--space-strip-width) 1fr}.quark-layout--home .room-list,.quark-layout--home .content-area,.quark-layout--home .thread-view,.quark-layout--home .member-list{display:none}.space-strip{grid-column:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:4px 0 var(--status-bar-height);overflow-y:auto;overflow-x:hidden;background-color:var(--bg);border-right:var(--border-width) solid var(--border-color);isolation:isolate}.space-strip__item{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:2px;cursor:pointer;font-size:14px;color:var(--roomlist-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;outline:none;transition:color var(--transition-speed),background-color var(--transition-speed),box-shadow var(--transition-speed)}.space-strip__item:hover{color:var(--fg);background-color:var(--roomlist-active-bg)}.space-strip__item:focus{box-shadow:0 0 0 var(--focus-width) var(--focus-color);outline:none}.space-strip__item--active{color:var(--accent-primary);background-color:var(--roomlist-active-bg);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.space-strip__item--active:before{content:"";position:absolute;left:0;width:2px;height:36px;background-color:var(--accent-primary)}.space-strip__icon{width:36px;height:36px;object-fit:contain;border-radius:var(--icon-radius)}.space-strip__divider{width:20px;height:var(--border-width);background-color:var(--border-color);margin:2px 0;flex-shrink:0}.space-strip__spacer{flex:1}.space-strip__settings-btn{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:2px;cursor:pointer;font-size:18px;color:var(--roomlist-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;outline:none;transition:color var(--transition-speed),background-color var(--transition-speed);margin-bottom:4px}.space-strip__settings-btn:hover{color:var(--accent-primary);background-color:var(--roomlist-active-bg)}.space-strip__settings-btn:focus{box-shadow:0 0 0 var(--focus-width) var(--focus-color);outline:none}.space-strip__profile-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;margin:2px auto 12px;border-radius:var(--icon-radius);cursor:pointer;flex-shrink:0;outline:none;overflow:hidden;font-size:16px;font-weight:700;color:var(--fg);background-color:var(--surface-hover-active);transition:box-shadow var(--transition-speed),opacity var(--transition-speed)}.space-strip__profile-btn:hover{opacity:.85}.space-strip__profile-btn:focus{box-shadow:0 0 0 var(--focus-width) var(--focus-color);outline:none}.space-strip__profile-btn--fallback{color:var(--accent-primary);background-color:color-mix(in srgb,var(--accent-primary) 18%,transparent)}.space-strip__profile-img{width:100%;height:100%;object-fit:cover}.room-list{grid-column:2;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg);border-right:var(--border-width) solid var(--border-color);position:relative;isolation:isolate}.room-list__header{padding:4px 8px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);text-transform:uppercase;letter-spacing:.05em;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.room-list__scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:var(--status-bar-height)}.room-list__section-label{padding:4px 8px 2px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;-webkit-user-select:none;user-select:none}.room-list__item{display:flex;align-items:center;justify-content:space-between;padding:2px 8px;color:var(--fg);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;outline:none;transition:color var(--transition-speed),background-color var(--transition-speed),text-shadow var(--transition-speed)}.room-list__item:hover{background-color:var(--roomlist-active-bg)}.room-list__item:focus{box-shadow:inset 0 0 0 var(--focus-width) var(--focus-color);outline:none}.room-list__item--active{background-color:var(--roomlist-active-bg);color:var(--roomlist-active-fg);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.room-list__item--unread{color:var(--roomlist-unread);text-shadow:0 0 4px color-mix(in srgb,var(--roomlist-unread) 15%,transparent);animation:unread-pulse 2s ease-in-out infinite}.room-list__item--muted{color:var(--roomlist-muted)}@keyframes unread-pulse{0%,to{opacity:1}50%{opacity:.7}}.room-list__item-name{flex:1;overflow:hidden;text-overflow:ellipsis}.room-list__item-badge{margin-left:6px;font-size:calc(var(--font-size) - 3px);color:var(--roomlist-mention-badge);flex-shrink:0}.room-list__presence{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-right:5px}.room-list__presence--online{background-color:var(--presence-online, #4caf50);box-shadow:0 0 4px var(--presence-online, #4caf50)}.room-list__presence--unavailable{background-color:var(--presence-unavailable, #ff9800)}.room-list__presence--offline{background-color:var(--presence-offline, #555)}.thread-view{grid-column:4;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg);border-left:var(--border-width) solid var(--msg-thread-indicator);min-width:0;position:relative}.quark-layout:not(.quark-layout--thread-open) .thread-view{width:0;overflow:hidden;border:none}.thread-view__header{display:flex;align-items:center;gap:4px;padding:6px 8px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.thread-view__title{flex:1;color:var(--msg-thread-indicator);font-size:calc(var(--font-size) - 1px);font-weight:700;text-transform:uppercase;letter-spacing:.08em}.thread-view__close{background:none;border:none;color:var(--roomlist-muted);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);cursor:pointer;padding:0;line-height:1;transition:color var(--transition-speed)}.thread-view__close:hover,.thread-view__close:focus{color:var(--accent-error);outline:none}.thread-view__root{flex-shrink:0;padding:8px 10px;background-color:color-mix(in srgb,var(--msg-thread-indicator) 6%,transparent);border-bottom:var(--border-width) solid var(--border-color);border-left:3px solid var(--msg-thread-indicator);font-family:var(--font-family-messages)}.thread-view__root-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.thread-view__root-sender{color:var(--msg-thread-indicator);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);font-weight:700;flex-shrink:0}.thread-view__root-timestamp{color:var(--msg-timestamp);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);flex-shrink:0;margin-left:auto}.thread-view__root-body{color:var(--fg);font-size:calc(var(--font-size) - 1px);word-break:break-word;white-space:pre-wrap;line-height:var(--line-height);opacity:.85}.thread-view__divider{text-align:center;color:var(--roomlist-muted);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);letter-spacing:.1em;padding:4px 0;flex-shrink:0;-webkit-user-select:none;user-select:none}.thread-view__timeline{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0;display:flex;flex-direction:column;gap:0;min-height:0}.thread-view__message{display:flex;flex-direction:column;gap:2px;padding:5px 10px 7px;outline:none;transition:background-color var(--transition-speed);font-family:var(--font-family-messages)}.thread-view__message+.thread-view__message{border-top:1px dashed color-mix(in srgb,var(--border-color) 60%,transparent)}.thread-view__message:hover{background-color:var(--surface-dim)}.thread-view__message:focus{background-color:var(--roomlist-active-bg);box-shadow:inset 3px 0 0 var(--focus-color)}.thread-view__message-header{display:flex;align-items:baseline;gap:8px}.thread-view__message-sender{color:var(--msg-other);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);font-weight:700;flex-shrink:0}.thread-view__message-sender--own{color:var(--msg-own);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.thread-view__message-timestamp{color:var(--msg-timestamp);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);flex-shrink:0;margin-left:auto}.thread-view__message-body{color:var(--fg);font-size:calc(var(--font-size) - 1px);word-break:break-word;white-space:pre-wrap;line-height:var(--line-height)}.thread-view__message--own{background-color:color-mix(in srgb,var(--msg-own) 3%,transparent)}.thread-view__message-image,.thread-view__message-sticker{max-width:100%;max-height:160px;object-fit:contain;display:block;border-radius:4px;margin-top:4px}.thread-view__input-bar{display:flex;align-items:center;gap:0;flex-shrink:0;padding:8px;border-top:var(--border-width) solid var(--border-color);background-color:var(--bg)}.thread-view__prompt{color:var(--msg-thread-indicator);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);font-weight:700;padding:6px 6px 6px 4px;flex-shrink:0;-webkit-user-select:none;user-select:none}.thread-view__input{flex:1;background:transparent;border:var(--border-width) solid color-mix(in srgb,var(--border-color) 70%,var(--msg-thread-indicator) 30%);border-radius:6px;color:var(--fg);font-family:var(--font-family-messages);font-size:calc(var(--font-size) - 1px);line-height:var(--line-height);padding:5px 10px;outline:none;caret-color:var(--cursor);transition:border-color var(--transition-speed),box-shadow var(--transition-speed)}.thread-view__input::placeholder{color:var(--roomlist-muted)}.thread-view__input:focus{border-color:color-mix(in srgb,var(--msg-thread-indicator) 60%,var(--border-color));box-shadow:0 0 0 1px color-mix(in srgb,var(--msg-thread-indicator) 15%,transparent)}.thread-inline{display:grid;grid-template-rows:0fr;transition:grid-template-rows .22s cubic-bezier(.25,.46,.45,.94);margin-left:40px;border-left:2px solid var(--msg-thread-indicator);border-radius:0 0 0 3px;background-color:color-mix(in srgb,var(--msg-thread-indicator) 4%,var(--bg));margin-right:0;margin-bottom:0}.thread-inline--open{grid-template-rows:1fr;margin-bottom:12px}.thread-inline__inner{overflow:hidden;min-height:0;display:flex;flex-direction:column;max-height:360px}.thread-inline__header{display:flex;align-items:center;gap:6px;padding:4px 10px;border-bottom:1px solid color-mix(in srgb,var(--border-color) 60%,transparent);flex-shrink:0}.thread-inline__title{color:var(--msg-thread-indicator);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);font-weight:700;letter-spacing:.06em;flex-shrink:0}.thread-inline__count{color:var(--roomlist-muted);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);flex:1}.thread-inline__close{background:none;border:none;color:var(--roomlist-muted);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);cursor:pointer;padding:0;line-height:1;transition:color var(--transition-speed)}.thread-inline__close:hover,.thread-inline__close:focus{color:var(--accent-error);outline:none}.thread-inline__timeline{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0;display:flex;flex-direction:column;min-height:0}.thread-inline__message{display:flex;flex-direction:column;gap:1px;padding:4px 10px 6px;font-family:var(--font-family-messages);transition:background-color var(--transition-speed)}.thread-inline__message+.thread-inline__message{border-top:1px dashed color-mix(in srgb,var(--border-color) 55%,transparent)}.thread-inline__message:hover{background-color:var(--surface-dim)}.thread-inline__message--own{background-color:color-mix(in srgb,var(--msg-own) 3%,transparent)}.thread-inline__message--selected{background-color:var(--roomlist-active-bg);box-shadow:inset 3px 0 0 var(--msg-thread-indicator)}.thread-inline__message-header{display:flex;align-items:baseline;gap:8px}.thread-inline__message-sender{color:var(--msg-other);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);font-weight:700;flex-shrink:0}.thread-inline__message-sender--own{color:var(--msg-own);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.thread-inline__message-timestamp{color:var(--msg-timestamp);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);flex-shrink:0;margin-left:auto}.thread-inline__message-body{color:var(--fg);font-size:calc(var(--font-size) - 1px);word-break:break-word;white-space:pre-wrap;line-height:var(--line-height)}.thread-inline__message-image,.thread-inline__message-sticker{max-width:100%;max-height:120px;object-fit:contain;display:block;border-radius:3px;margin-top:3px}.member-list{grid-column:4;position:relative;border-left:var(--border-width) solid var(--border-color)}.quark-layout--thread-open .member-list{grid-column:5;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg);border-left:var(--border-width) solid var(--border-color);min-width:0}.quark-layout:not(.quark-layout--member-list-open) .member-list{width:0;overflow:hidden;border:none}.member-list__header{display:flex;align-items:center;gap:4px;padding:4px 8px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.member-list__header-title{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);text-transform:uppercase;letter-spacing:.05em}.member-list__count{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px)}.member-list__scroll{flex:1;overflow-y:auto;overflow-x:hidden}.member-list__section-header{display:flex;align-items:center;gap:4px;padding:4px 8px 2px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;-webkit-user-select:none;user-select:none}.member-list__section-header:hover{color:var(--fg)}.member-list__section-arrow{font-size:calc(var(--font-size) - 3px)}.member-list__item{display:flex;align-items:center;gap:6px;padding:2px 8px 2px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden;outline:none;transition:background-color var(--transition-speed)}.member-list__item:hover{background-color:var(--roomlist-active-bg)}.member-list__item:focus{box-shadow:inset 0 0 0 var(--focus-width) var(--focus-color)}.member-list__item--active{background-color:var(--roomlist-active-bg);color:var(--roomlist-active-fg)}.member-list__avatar{width:24px;height:24px;border-radius:var(--icon-radius);flex-shrink:0;object-fit:cover;display:block}.member-list__avatar--fallback{display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--font-mono);line-height:1;opacity:.85}.member-list__presence{font-size:8px;flex-shrink:0}.member-list__presence--online{color:var(--accent-success)}.member-list__presence--unavailable{color:var(--accent-warning)}.member-list__presence--offline{color:var(--roomlist-muted)}.member-list__name{flex:1;overflow:hidden;text-overflow:ellipsis;font-size:calc(var(--font-size) - 1px)}.member-list__badge{font-size:calc(var(--font-size) - 3px);flex-shrink:0}.member-list__badge--admin{color:var(--accent-error)}.member-list__badge--mod{color:var(--accent-warning)}.main-panel{grid-column:3;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg)}.main-panel__header{padding:4px 12px;border-bottom:var(--border-width) solid var(--border-color);color:var(--fg);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resize-handle{position:absolute;top:0;width:5px;height:100%;cursor:ew-resize;z-index:10;opacity:0;background:var(--accent-primary);transition:opacity .15s}.resize-handle:hover,.resize-handle--dragging{opacity:.3}.room-header{display:flex;align-items:center;gap:10px;padding:6px 12px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;min-height:44px;background-color:var(--bg);font-family:var(--font-family)}.room-header__avatar,.room-header__avatar-fallback{width:32px;height:32px;border-radius:var(--icon-radius);flex-shrink:0}.room-header__avatar{object-fit:cover;display:block}.room-header__avatar-fallback{display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;line-height:1;border:1px solid currentColor;opacity:.85}.room-header__left{display:flex;align-items:baseline;gap:0;flex:1;min-width:0;overflow:hidden}.room-header__name{color:var(--accent-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1}.room-header__sep{color:color-mix(in srgb,var(--fg) 35%,transparent);flex-shrink:0;margin:4px}.room-header__topic{color:color-mix(in srgb,var(--fg) 55%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:2;font-size:calc(var(--font-size) - 1px)}.room-header__meta{display:flex;align-items:center;gap:0;flex-shrink:0;color:color-mix(in srgb,var(--fg) 65%,transparent);font-size:calc(var(--font-size) - 1px);white-space:nowrap}.room-header__members{color:color-mix(in srgb,var(--fg) 65%,transparent);padding:0 4px}.room-header__members--clickable{cursor:pointer}.room-header__members--clickable:hover{color:var(--fg)}.room-header__encryption--on{color:var(--accent-success);padding:0 4px}.room-header__encryption--off{color:var(--roomlist-muted);padding:0 4px}.room-header__pinned-btn{background:none;border:none;color:color-mix(in srgb,var(--fg) 45%,transparent);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:0 4px;border-radius:2px;flex-shrink:0;transition:color .12s}.room-header__pinned-btn:hover{color:var(--accent-primary)}.room-header__search-btn{background:none;border:none;color:color-mix(in srgb,var(--fg) 45%,transparent);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:0 4px;border-radius:2px;flex-shrink:0;transition:color .12s}.room-header__search-btn:hover{color:var(--accent-primary)}.content-area{grid-column:3;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg);min-height:0;position:relative}.timeline-wrap{flex:1;min-height:0;display:flex;flex-direction:column;position:relative;overflow:hidden}.timeline{flex:1;overflow-y:auto;overflow-x:hidden;overflow-anchor:none;overscroll-behavior-y:none;scrollbar-gutter:stable;padding:10px 12px;display:flex;flex-direction:column-reverse;min-height:0}.timeline__loading-more{position:absolute;top:0;left:0;right:0;text-align:center;color:var(--msg-system);font-size:calc(var(--font-size) - 2px);padding:4px 12px;background:var(--bg);z-index:1}.timeline__jump-to-latest{position:absolute;bottom:12px;right:16px;background:var(--bg-secondary, var(--bg));color:var(--accent);border:var(--border-width) solid var(--border-color);border-radius:4px;padding:4px 10px;font-size:calc(var(--font-size) - 1px);font-family:var(--font-family, monospace);cursor:pointer;z-index:10;opacity:.9;margin-right:4px}.timeline__jump-to-latest:hover{opacity:1;color:var(--accent-primary)}.message-group{border:var(--border-width) solid var(--border-color);border-radius:8px;position:relative;padding-top:calc(var(--font-size) * var(--line-height) * .25);transition:border-color var(--transition-speed),box-shadow var(--transition-speed)}.message-group:hover{border-color:color-mix(in srgb,var(--border-color) 70%,var(--accent-primary))}.message-group--selected{border-color:var(--accent-primary);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 30%,transparent),inset 0 0 12px color-mix(in srgb,var(--accent-primary) 5%,transparent)}.message-group--selected .message-group__sender{color:var(--accent-primary);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.message-group__header{position:absolute;top:-1px;transform:translateY(-50%);left:1.5ch;right:1.5ch;display:flex;align-items:center;gap:6px;padding:0 .6ch;white-space:nowrap;z-index:1;pointer-events:none;font-family:var(--font-family)}.message-group-wrapper{display:flex;align-items:stretch;gap:8px;font-family:var(--font-family-messages);margin-top:calc(var(--font-size) * .5 + 8px);margin-bottom:calc(var(--font-size) * 1.75)}.message-group-wrapper .message-group{flex:1;min-width:0}.message-group__avatar-col{width:32px;flex-shrink:0}.message-group__avatar,.message-group__avatar-fallback{width:32px;height:32px;border-radius:var(--icon-radius);cursor:pointer;position:sticky;top:0;margin-top:5px;margin-bottom:4px}.message-group__avatar{object-fit:cover;display:block}.message-group__avatar-fallback{display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1}.message-group__sender{color:var(--msg-other);flex-shrink:0;background-color:var(--bg);padding:0 .4ch}.message-group__sender--own{color:var(--msg-own);text-shadow:0 0 var(--glow-radius) var(--glow-color)}.message-group__timestamp{color:var(--msg-timestamp);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);flex-shrink:0;margin-left:auto;background-color:var(--bg);padding:0 .4ch}.message{display:flex;flex-direction:column;gap:2px;padding:4px 10px;outline:none;position:relative;transition:background-color var(--transition-speed)}.message-group .message+.message{border-top:1px dashed color-mix(in srgb,var(--border-color) 60%,transparent)}.message-group .message{padding-top:4px;padding-bottom:8px}.message:hover{background-color:var(--surface-dim)}.message__actions{position:absolute;right:4px;top:0;transform:translateY(-50%);display:none;gap:2px;align-items:center;background:var(--bg);border:1px solid var(--border-color);padding:1px 4px;border-radius:2px;z-index:10}.message:hover .message__actions{display:flex}.message__action-btn{background:none;border:none;padding:0 3px;height:20px;line-height:20px;font-size:13px;cursor:pointer;color:var(--fg);border-radius:2px;transition:background-color var(--transition-speed),color var(--transition-speed)}.message__action-btn:hover{background-color:color-mix(in srgb,var(--accent-primary) 20%,transparent);color:var(--accent-primary)}.message:focus{background-color:var(--roomlist-active-bg);box-shadow:inset 3px 0 0 var(--focus-color);outline:none}.message--selected{background-color:color-mix(in srgb,var(--accent-primary) 6%,transparent);box-shadow:inset 2px 0 0 var(--accent-primary)}.message--ungrouped{border:var(--border-width) solid var(--border-color);border-radius:8px;padding:4px 10px}.message--ungrouped:hover{border-color:color-mix(in srgb,var(--border-color) 70%,var(--accent-primary))}.message__header{display:flex;align-items:baseline;gap:8px}.message__sender{color:var(--msg-other);font-weight:400;flex-shrink:0}.message__sender--own{color:var(--msg-own)}.message__timestamp{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);flex-shrink:0}.message__body{color:var(--fg);word-break:break-word;white-space:pre-wrap}.message__body ul,.message__body ol,.thread-view__root-body ul,.thread-view__root-body ol,.thread-view__message-body ul,.thread-view__message-body ol,.thread-inline__message-body ul,.thread-inline__message-body ol{padding-left:2em}.message__body--text-select{outline:1px dashed color-mix(in srgb,var(--cursor) 60%,transparent);outline-offset:2px;border-radius:2px;caret-color:var(--cursor);-webkit-user-select:text;user-select:text}.message__body--text-select:focus{outline-color:var(--cursor)}.message__body--text-select-block,.input-bar__field--text-select-block{caret-color:transparent}.message__body--text-select-block::selection,.message__body--text-select-block *::selection{background-color:var(--cursor);color:var(--bg)}.input-bar__field--text-select-block::selection{background-color:var(--cursor);color:var(--bg)}.message__body--text-select-visual::selection,.message__body--text-select-visual *::selection{background-color:var(--accent-secondary);color:var(--bg)}.input-bar__field--text-select-visual::selection{background-color:var(--accent-secondary);color:var(--bg)}.message--system .message__body{color:var(--msg-system);font-style:italic}.message--mention{background-color:var(--msg-mention-bg);color:var(--msg-mention-fg)}.reply-preview-bar{display:flex;align-items:center;gap:6px;margin:0 20px 4px 44px;padding:4px 10px;border-left:2px solid var(--accent-secondary);border-radius:0 3px 3px 0;background-color:color-mix(in srgb,var(--accent-secondary) 6%,transparent);font-size:calc(var(--font-size) - 1px);overflow:hidden;white-space:nowrap;-webkit-user-select:none;user-select:none}.reply-preview-bar__indicator{color:var(--accent-secondary);flex-shrink:0;opacity:.85}.reply-preview-bar__content{flex:1;display:flex;gap:6px;align-items:baseline;overflow:hidden;min-width:0}.reply-preview-bar__sender{color:var(--accent-secondary);font-weight:700;flex-shrink:0}.reply-preview-bar__snippet{color:color-mix(in srgb,var(--fg) 70%,transparent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-preview-bar__close{background:none;border:none;color:var(--msg-system);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);cursor:pointer;padding:0 0 0 8px;flex-shrink:0;transition:color var(--transition-speed)}.reply-preview-bar__close:hover,.reply-preview-bar__close:focus{color:var(--accent-error);outline:none}.reply-preview-bar--thread{border-left-color:var(--msg-thread-indicator);background-color:color-mix(in srgb,var(--msg-thread-indicator) 6%,transparent)}.reply-preview-bar--thread .reply-preview-bar__indicator,.reply-preview-bar--thread .reply-preview-bar__sender{color:var(--msg-thread-indicator)}.reply-preview-bar--edit{border-left-color:var(--accent-warn, #c8a000);background-color:color-mix(in srgb,var(--accent-warn, #c8a000) 6%,transparent)}.reply-preview-bar--edit .reply-preview-bar__indicator,.reply-preview-bar--edit .reply-preview-bar__sender{color:var(--accent-warn, #c8a000)}.reply-preview{display:flex;align-items:baseline;gap:6px;padding:3px 8px;border-left:2px solid var(--accent-secondary);background-color:color-mix(in srgb,var(--accent-secondary) 6%,transparent);color:var(--fg);font-size:calc(var(--font-size) - 1px);margin-bottom:4px;overflow:hidden;white-space:nowrap;cursor:pointer;border-radius:0 3px 3px 0;transition:background-color var(--transition-speed),border-color var(--transition-speed);outline:none;-webkit-user-select:none;user-select:none}.reply-preview:hover,.reply-preview:focus{background-color:color-mix(in srgb,var(--accent-secondary) 14%,transparent);border-color:var(--accent-secondary)}.reply-preview__icon{color:var(--accent-secondary);flex-shrink:0;font-size:calc(var(--font-size) - 2px);opacity:.85}.reply-preview__sender{color:var(--accent-secondary);font-weight:700;flex-shrink:0}.reply-preview__body{color:color-mix(in srgb,var(--fg) 70%,transparent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes message-highlight-flash{0%{background-color:color-mix(in srgb,var(--accent-secondary) 18%,transparent)}60%{background-color:color-mix(in srgb,var(--accent-secondary) 18%,transparent)}to{background-color:transparent}}.message--highlight{animation:message-highlight-flash 1.4s ease forwards}.message--image{padding-left:8px}.message__image{display:block;max-width:600px;max-height:400px;width:auto;height:auto;object-fit:contain;object-position:left;margin-top:4px;cursor:zoom-in}.message__image--unsized{min-height:200px}.message__image-caption{margin-top:4px}.message--video{padding-left:8px}.message__video-affordance{display:inline-flex;align-items:center;gap:6px;margin-top:4px;padding:4px 10px;border:1px solid var(--border-color);border-radius:2px;cursor:pointer;-webkit-user-select:none;user-select:none;max-width:400px;color:var(--fg);background:var(--surface-subtle);font-family:inherit;font-size:inherit}.message__video-affordance:hover,.message__video-affordance:focus-visible{border-color:var(--accent-primary);color:var(--accent-primary);outline:none}.message__video-affordance--loading{position:relative;overflow:hidden;pointer-events:none;border-color:var(--accent-primary);color:var(--accent-primary)}.message__video-affordance--loading:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--accent-primary) 50%,transparent 100%);opacity:.15;animation:video-load-sweep 1.2s linear infinite;transform:translate(-100%)}@keyframes video-load-sweep{0%{transform:translate(-100%)}to{transform:translate(200%)}}.message__video-affordance-icon{font-size:.9em;opacity:.8}.message__video-affordance-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.message__video-affordance-thumb{position:relative;width:160px;height:90px;flex-shrink:0;background:var(--bg);border-radius:1px;overflow:hidden}.message__video-affordance-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.message__video-affordance-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.4em;color:var(--media-icon-fg);text-shadow:0 0 6px var(--shadow-color);pointer-events:none}.message__file-affordance{display:inline-flex;align-items:center;gap:6px;margin-top:4px;padding:4px 10px;border:1px solid var(--border-color);border-radius:2px;cursor:pointer;-webkit-user-select:none;user-select:none;max-width:400px;color:var(--fg);background:var(--surface-subtle);font-family:inherit;font-size:inherit}.message__file-affordance:hover,.message__file-affordance:focus-visible{border-color:var(--accent-primary);color:var(--accent-primary);outline:none}.message__file-affordance-icon{font-size:.9em;opacity:.8}.message__file-affordance-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}.message__file-affordance-type{font-size:calc(var(--font-size) - 3px);opacity:.6;flex-shrink:0}.message__video{display:block;max-width:600px;max-height:400px;width:auto;height:auto;margin-top:4px;background:var(--media-bg);border-radius:2px}.message__url-preview{display:flex;align-items:flex-start;gap:8px;margin-top:6px;padding:6px 8px;border-left:2px solid var(--accent-primary);background:var(--surface-subtle);max-width:480px;border-radius:0 2px 2px 0}.message__url-preview-img-wrap{flex-shrink:0;width:56px;height:56px;overflow:hidden;border-radius:2px;background:var(--bg)}.message__url-preview-img{width:100%;height:100%;object-fit:cover;display:block}.message__url-preview-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.message__url-preview-site{font-size:calc(var(--font-size) - 2px);color:var(--accent-primary);opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message__url-preview-title{font-size:var(--font-size);color:var(--fg);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message__url-preview-desc{font-size:calc(var(--font-size) - 1px);color:var(--reaction-count);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.message__sticker{display:block;max-width:var(--sticker-max-size);max-height:var(--sticker-max-size);width:auto;height:auto;object-fit:contain;object-position:left;margin-top:4px}.message__sticker--unsized{min-height:var(--sticker-max-size)}img[data-mx-emoticon]{height:1em;width:auto;vertical-align:-.15em;display:inline}.message__spoiler{filter:blur(6px);background:var(--fg);border-radius:2px;color:transparent;cursor:pointer;-webkit-user-select:none;user-select:none;transition:filter .12s ease,color .12s ease,background .12s ease}.message__spoiler img[data-mx-emoticon]{visibility:hidden}.message__spoiler--revealed{filter:none;background:transparent;color:inherit;cursor:text;-webkit-user-select:text;user-select:text}.message__spoiler--revealed img[data-mx-emoticon]{visibility:visible}.reaction-bar{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.message-group .message:not(:last-of-type) .reaction-bar{position:absolute;bottom:0;right:10px;transform:translateY(50%);z-index:2;margin-top:0}.message-group .message:not(:last-of-type):has(.reaction-bar){padding-bottom:14px}.message-group .message:not(:last-of-type):has(.reaction-bar)+.message{padding-top:16px}.message-group .message:last-of-type .reaction-bar{position:absolute;bottom:0;right:1.5ch;transform:translateY(50%);z-index:1}.message-group .message:last-of-type:has(.reaction-bar){padding-right:6rem}.read-receipts{position:absolute;right:8px;bottom:3px;display:flex;flex-direction:row;align-items:center;z-index:3;pointer-events:auto;cursor:default}.read-receipts-tooltip{position:fixed;z-index:10000;background:var(--bg);border:var(--border-width) solid color-mix(in srgb,var(--border-color) 70%,var(--accent-primary));box-shadow:0 4px 16px #0006;padding:6px 8px;max-width:280px;color:var(--fg);font-size:calc(var(--font-size) - 1px);pointer-events:none}.read-receipts-tooltip__title{color:var(--msg-own);font-size:calc(var(--font-size) - 2px);letter-spacing:.05em;text-transform:uppercase;margin-bottom:5px}.read-receipts-tooltip__row{display:flex;align-items:center;gap:7px;padding:2px 0}.read-receipts-tooltip__name{color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.read-receipts-tooltip__time{margin-left:auto;padding-left:12px;flex-shrink:0;color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);white-space:nowrap}.message:has(.reaction-bar) .read-receipts{bottom:22px}.read-receipt{width:14px;height:14px;margin-left:-5px;border-radius:var(--icon-radius);border:1px solid var(--bg);overflow:hidden;background:var(--bg);box-sizing:border-box;flex-shrink:0}.read-receipt:first-child{margin-left:0}.read-receipt__avatar{width:100%;height:100%;object-fit:cover;display:block}.read-receipt__fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1;color:var(--bg)}.read-receipts__overflow{width:14px;height:14px;margin-left:-5px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-size:11px;line-height:1;padding-bottom:3px;border-radius:var(--icon-radius);border:1px solid var(--bg);background:var(--surface-bright, var(--surface-dim));color:var(--fg)}.reaction{display:inline-flex;align-items:center;justify-content:center;gap:4px;margin:0 2px;padding:2px 8px;background-color:var(--bg);border:var(--border-width) solid var(--reaction-border);border-radius:6px;color:var(--fg);font-size:calc(var(--font-size) - 1px);line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;transition:border-color var(--transition-speed),background-color var(--transition-speed),transform var(--transition-speed)}.reaction:hover{border-color:var(--fg);transform:translateY(-1px)}.message-group .reaction:hover{transform:none}.reaction:focus{box-shadow:0 0 0 var(--focus-width) var(--focus-color);outline:none}.reaction--own{background-color:var(--reaction-own-bg);border-color:var(--accent-primary)}img.reaction__emoji{height:calc(var(--reaction-size) + 4px);padding:2px;width:auto;vertical-align:middle}span.reaction__emoji{font-size:calc(var(--font-size));line-height:1;margin-top:4px;margin-bottom:4px;margin-right:2px}.reaction__count{color:var(--reaction-count);font-size:calc(var(--font-size) - 2px);line-height:1}.message__thread-indicator{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;background:none;border:1px solid color-mix(in srgb,var(--msg-thread-indicator) 40%,transparent);border-radius:10px;color:var(--msg-thread-indicator);font-family:var(--font-family);font-size:calc(var(--font-size) - 3px);font-weight:700;letter-spacing:.03em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-speed),border-color var(--transition-speed)}.message__thread-indicator:hover{background-color:color-mix(in srgb,var(--msg-thread-indicator) 12%,transparent);border-color:var(--msg-thread-indicator)}.message__thread-indicator:focus{outline:none;box-shadow:0 0 0 var(--focus-width) var(--msg-thread-indicator)}.quick-react-picker{position:fixed;flex-direction:column;gap:0;background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 20px var(--shadow-color),0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent);z-index:300;width:300px;animation:quick-react-in 80ms ease}@keyframes quick-react-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.quick-react-picker__input-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-bottom:var(--border-width) solid var(--border-color)}.quick-react-picker__prompt{color:var(--accent-primary);flex-shrink:0;-webkit-user-select:none;user-select:none;opacity:.7}.quick-react-picker__input{flex:1;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);caret-color:var(--cursor);min-width:0}.quick-react-picker__input::placeholder{color:var(--roomlist-muted);opacity:.7}.quick-react-picker__cats{display:flex;flex-direction:row;flex-wrap:nowrap;gap:1px;padding:3px 6px;overflow-x:auto;border-bottom:var(--border-width) solid var(--border-color);scrollbar-width:none}.quick-react-picker__cats::-webkit-scrollbar{display:none}.quick-react-picker__cat-btn{flex-shrink:0;width:22px;height:22px;padding:0;font-size:14px;line-height:1;background:transparent;border:var(--border-width) solid transparent;border-radius:3px;cursor:pointer;opacity:.6;transition:opacity var(--transition-speed),border-color var(--transition-speed),background-color var(--transition-speed);outline:none}.quick-react-picker__cat-btn:hover,.quick-react-picker__cat-btn--active{opacity:1;border-color:var(--accent-primary);background-color:var(--selection-bg)}.quick-react-picker__grid{display:flex;flex-wrap:wrap;gap:2px;padding:6px;max-height:160px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.quick-react-picker__custom-img{width:20px;height:20px;object-fit:contain;vertical-align:middle}.quick-react-picker__btn{background:transparent;border:var(--border-width) solid transparent;padding:4px 5px;font-size:18px;cursor:pointer;border-radius:3px;line-height:1;outline:none;transition:border-color var(--transition-speed),background-color var(--transition-speed)}.quick-react-picker__btn:hover,.quick-react-picker__btn--focused,.quick-react-picker__btn:focus{border-color:var(--accent-primary);background-color:var(--selection-bg)}.quick-react-picker__hint{padding:3px 8px 5px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);border-top:var(--border-width) solid var(--border-color);letter-spacing:.03em}.emoji-picker{position:fixed;bottom:80px;right:16px;width:340px;height:min(420px,calc(100vh - 100px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 24px var(--shadow-color);z-index:250;display:flex;flex-direction:column;overflow:hidden;animation:picker-in 80ms ease}.emoji-picker__tabs{display:flex;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.emoji-picker__section{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.emoji-picker__categories{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:2px;padding:4px 6px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;scrollbar-width:none}.emoji-picker__categories::-webkit-scrollbar{display:none}.emoji-picker__category-btn{background:transparent;border:var(--border-width) solid transparent;border-radius:4px;cursor:pointer;font-size:16px;line-height:1;outline:none;padding:3px 5px;flex-shrink:0;opacity:.5;transition:opacity .1s,border-color .1s}.emoji-picker__category-btn:hover{opacity:1;border-color:var(--border-color)}.emoji-picker__category-btn--active{opacity:1;border-color:var(--accent-primary);background-color:var(--surface-hover)}.emoji-picker__category-img{width:16px;height:16px;object-fit:contain;vertical-align:middle}.emoji-picker__tab{background:transparent;border:none;border-right:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);letter-spacing:.06em;padding:4px 14px;text-transform:uppercase;outline:none}.emoji-picker__tab:hover{color:var(--fg);background-color:var(--surface-hover)}.emoji-picker__tab--active{color:var(--accent-primary);background-color:var(--surface-subtle)}.emoji-picker__search{background:transparent;border:none;border-bottom:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);outline:none;padding:6px 10px;flex-shrink:0}.emoji-picker__grid{display:grid;grid-template-columns:repeat(auto-fill,34px);justify-content:center;column-gap:10px;row-gap:12px;padding:10px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.emoji-picker__cell{width:34px;height:34px;background:transparent;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;outline:none;overflow:hidden;padding:3px;min-width:0}.emoji-picker__cell:hover,.emoji-picker__cell:focus{background-color:var(--surface-hover-active)}.emoji-picker__img{width:24px;height:24px;object-fit:contain}.sticker-picker{position:fixed;bottom:80px;right:16px;width:340px;height:min(420px,calc(100vh - 100px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 24px var(--shadow-color);z-index:250;display:flex;flex-direction:column;overflow:hidden;animation:picker-in 80ms ease}.sticker-picker__pack-label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.06em;padding:4px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;text-transform:uppercase}.sticker-picker__pack-header{grid-column:1 / -1;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.06em;padding:6px 4px 2px;text-transform:uppercase}.sticker-picker__search{background:transparent;border:none;border-bottom:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);outline:none;padding:6px 10px;flex-shrink:0}.sticker-picker__grid{display:grid;grid-template-columns:repeat(4,76px);grid-auto-rows:76px;justify-content:center;gap:4px;padding:6px;overflow-y:auto;flex:1;min-height:0}.sticker-picker__cell{width:76px;height:76px;background:transparent;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;outline:none;padding:4px;overflow:hidden}.sticker-picker__cell:hover,.sticker-picker__cell--focused,.sticker-picker__cell:focus{background-color:var(--surface-hover-active)}.sticker-picker__img{width:100%;height:100%;object-fit:contain;border-radius:2px}.sticker-picker__cell-label{display:none}.input-bar{display:flex;align-items:stretch;flex-shrink:0;background-color:var(--bg);margin-top:auto;padding:0 12px 0 8px}.input-bar__mode{width:40px;padding:10px 4px 12px;margin:8px 0 8px 4px;color:var(--bg);background-color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);letter-spacing:.05em;font-weight:700;min-width:0;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:center;align-items:flex-end;justify-content:center;border-right:var(--border-width) solid var(--border-color);transition:background-color var(--transition-speed),color var(--transition-speed);border-radius:8px 0 0 8px}.input-bar__mode--insert{background-color:var(--accent-secondary);color:var(--bg)}.input-bar__mode--command{background-color:var(--accent-warning);color:var(--bg)}.input-bar__mode--visual{background-color:var(--accent-primary);color:var(--bg)}.input-bar__compose-box{flex:1;display:flex;align-items:flex-start;border:var(--border-width) solid color-mix(in srgb,var(--border-color) 70%,var(--accent-primary) 30%);border-radius:0 8px 8px 0;min-width:0;margin:8px 0;padding-top:calc(var(--font-size) * var(--line-height) * .25);transition:border-color var(--transition-speed),box-shadow var(--transition-speed),border-radius var(--transition-speed)}.input-bar--no-vim .input-bar__compose-box{border-radius:8px}.input-bar__compose-box:focus-within{border-color:color-mix(in srgb,var(--accent-primary) 55%,var(--border-color));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 12%,transparent)}.input-bar__field{flex:1;background:transparent;border:none;color:var(--fg);font-family:var(--font-family-messages);font-size:var(--font-size);line-height:var(--line-height);padding:4px 10px 8px;outline:none;caret-color:var(--cursor);resize:none;box-sizing:border-box;overflow-y:auto;max-height:calc(var(--font-size) * var(--line-height) * 6 + 12px)}.input-bar__field::placeholder{color:var(--roomlist-muted)}.input-bar__actions{display:flex;align-items:center;flex-shrink:0;padding:0 4px 0 0;gap:2px}.input-bar__action-btn{background:transparent;border:var(--border-width) solid transparent;padding:3px 5px;font-size:16px;cursor:pointer;border-radius:4px;line-height:1;outline:none;opacity:.5;transition:opacity var(--transition-speed),border-color var(--transition-speed),background-color var(--transition-speed);tabindex:-1}.input-bar__action-btn:hover{opacity:1;border-color:var(--border-color);background-color:var(--selection-bg)}.input-bar__action-btn--gif{font-size:10px;font-weight:700;letter-spacing:.5px;opacity:1;color:var(--accent-secondary);border-color:var(--border-color);padding:2px 5px}.input-bar__action-btn--gif:hover{color:var(--bg);background-color:var(--accent-secondary);border-color:var(--accent-secondary)}@keyframes composeBoxMerge{0%{border-color:color-mix(in srgb,var(--border-color) 70%,var(--accent-primary) 30%);box-shadow:none}20%{border-color:transparent;box-shadow:none}to{border-color:color-mix(in srgb,var(--border-color) 70%,var(--accent-primary) 30%);box-shadow:none}}.input-bar__compose-box--merge{animation:composeBoxMerge .38s ease forwards}@keyframes composeBoxSent{0%{opacity:0;border-color:color-mix(in srgb,var(--accent-primary) 70%,transparent);box-shadow:0 0 8px color-mix(in srgb,var(--accent-primary) 25%,transparent)}60%{opacity:1}to{border-color:color-mix(in srgb,var(--border-color) 70%,var(--accent-primary) 30%);box-shadow:none}}.input-bar__compose-box--sent{animation:composeBoxSent .35s ease forwards}.input-bar-wrap{display:flex;flex-direction:column;flex-shrink:0}.typing-indicator{display:flex;align-items:center;gap:6px;padding:0 20px 6px 60px;font-size:calc(var(--font-size) - 2px);color:color-mix(in srgb,var(--fg) 50%,transparent);flex-shrink:0;height:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;visibility:hidden}.typing-indicator--active{visibility:visible}.typing-indicator__dots{display:inline-flex;gap:3px;align-items:center}.typing-indicator__dots span{width:3px;height:3px;border-radius:50%;background-color:currentColor;animation:typingDot 1.4s infinite ease-in-out}.typing-indicator__dots span:nth-child(2){animation-delay:.2s}.typing-indicator__dots span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{opacity:.3;transform:scale(1)}30%{opacity:1;transform:scale(1.3)}}.paste-preview{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 52px;background:color-mix(in srgb,var(--bg-secondary) 80%,transparent);border-top:var(--border-width) solid var(--border-color);flex-shrink:0}.paste-preview__img{max-width:120px;max-height:80px;object-fit:contain;border-radius:3px}.paste-preview__label{flex:1;font-size:calc(var(--font-size) - 1px);color:color-mix(in srgb,var(--fg) 70%,transparent)}.paste-preview__btn{background:none;border:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);padding:2px 8px;cursor:pointer;border-radius:2px}.paste-preview__btn:hover{background:color-mix(in srgb,var(--accent-primary) 20%,transparent);border-color:var(--accent-primary)}.paste-preview__btn--send{border-color:var(--accent-success);color:var(--accent-success)}.paste-preview__btn--cancel{border-color:color-mix(in srgb,var(--fg) 30%,transparent)}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg-dark);display:none;align-items:center;justify-content:center;z-index:9000;flex-direction:column}.image-lightbox--open{display:flex}.image-lightbox__img-wrap{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;width:100%;touch-action:none}.image-lightbox__img{max-width:90vw;max-height:85vh;object-fit:contain;transition:transform .15s ease;-webkit-user-select:none;user-select:none}.image-lightbox__toolbar{display:flex;gap:8px;padding:10px 16px;align-items:center;flex-shrink:0}.image-lightbox__btn{background:none;border:var(--border-width) solid color-mix(in srgb,var(--fg) 40%,transparent);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);padding:4px 12px;cursor:pointer;border-radius:2px}.image-lightbox__btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.image-lightbox__close{margin-left:auto;border-color:color-mix(in srgb,var(--fg) 30%,transparent)}.image-lightbox__zoom-label{color:color-mix(in srgb,var(--fg) 50%,transparent);font-size:calc(var(--font-size) - 1px);min-width:4ch;text-align:center}@keyframes msgHeaderReveal{0%{opacity:0}to{opacity:1}}.msg-header--reveal{animation:msgHeaderReveal .25s ease both}@keyframes msgMergeReveal{0%{opacity:0}to{opacity:1}}.message--entering{animation:msgMergeReveal .16s ease forwards}[tabindex]:focus-visible{outline:var(--focus-width) solid var(--focus-color);outline-offset:-1px}a{color:var(--accent-link);text-decoration:none;transition:text-shadow var(--transition-speed)}a:hover{text-decoration:underline;text-shadow:0 0 4px color-mix(in srgb,var(--accent-link) 40%,transparent)}.status-bar{display:flex;align-items:center;position:fixed;bottom:0;left:0;width:calc(var(--space-strip-width) + var(--room-list-width));min-height:var(--status-bar-height);z-index:100;background-color:var(--bg);border-top:var(--border-width) solid var(--border-color);border-right:var(--border-width) solid var(--border-color);font-size:calc(var(--font-size) - 2px);-webkit-user-select:none;user-select:none;pointer-events:auto}.status-bar__sep{color:var(--border-color)}.status-bar__room{padding:2px 8px;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-bar__spacer{flex:1}.status-bar__encryption{padding:2px 4px}.status-bar__encryption--on{filter:drop-shadow(0 0 3px var(--accent-success))}.status-bar__connection{padding:2px 8px;color:var(--roomlist-muted);transition:color var(--transition-speed)}.status-bar__connection--online{color:var(--accent-success);text-shadow:0 0 4px var(--glow-color)}.status-bar__connection--offline{color:var(--accent-error)}.status-bar__status{padding:2px 6px;color:var(--accent-secondary);cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color var(--transition-speed)}.status-bar__status:hover{color:var(--fg)}.status-bar__status--placeholder{color:var(--roomlist-muted);font-style:italic}.status-bar__status-input{background:transparent;border:none;border-bottom:1px solid var(--accent-secondary);color:var(--fg);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);padding:0 4px;width:120px;outline:none}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;background-color:var(--bg);gap:8px;padding:max(24px,env(safe-area-inset-top)) max(24px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));overflow-y:auto}.login-screen__banner{color:var(--accent-primary);text-align:left;text-shadow:0 0 var(--glow-radius) var(--glow-color),0 0 calc(var(--glow-radius) * 3) var(--glow-color);animation:banner-flicker 4s ease-in-out infinite;font-size:min(var(--font-size),calc((100vw - 48px) / 28));line-height:1.1;white-space:pre;max-width:100%}@keyframes banner-flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.8}94%{opacity:1}96%{opacity:.9}97%{opacity:1}}.login-screen__tagline{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px);letter-spacing:.1em}.login-screen__divider{color:var(--border-color);margin:4px 0;white-space:nowrap;overflow:hidden;max-width:100%;font-size:min(var(--font-size),calc((100vw - 48px) / 42))}.login-screen__form{display:flex;flex-direction:column;gap:8px;width:100%;max-width:420px}.login-screen__field{display:flex;align-items:center;gap:8px;border-bottom:var(--border-width) solid var(--border-color);padding:4px 0;transition:border-color var(--transition-speed)}.login-screen__field--focused{border-bottom-color:var(--accent-primary);box-shadow:0 1px 0 0 var(--glow-color)}.login-screen__field-prompt{color:var(--accent-primary);flex-shrink:0}.login-screen__field-label{color:var(--roomlist-muted);flex-shrink:0;min-width:11ch;text-transform:lowercase}.login-screen__field-input{flex:1;background:transparent;border:none;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);outline:none;caret-color:var(--cursor)}.login-screen__field-input::placeholder{color:var(--roomlist-muted)}.login-screen__submit{margin-top:8px;background:transparent;border:var(--border-width) solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-family);font-size:var(--font-size);padding:6px 16px;cursor:pointer;letter-spacing:.1em;transition:background-color var(--transition-speed),color var(--transition-speed),box-shadow var(--transition-speed)}.login-screen__submit:hover{background-color:var(--accent-primary);color:var(--bg);box-shadow:0 0 var(--glow-radius) var(--glow-color)}.login-screen__submit:disabled{opacity:.5;cursor:not-allowed}.login-screen__status{min-height:1.5em;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.login-screen__status--error{color:var(--accent-error)}.login-screen__status--success{color:var(--accent-success);text-shadow:0 0 4px var(--glow-color)}.login-screen__hints{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.05em;margin-top:12px}.command-bar{display:flex;align-items:center;border-top:var(--border-width) solid var(--border-color);background-color:var(--bg);flex-shrink:0}.command-bar__prompt{padding:4px 6px;color:var(--accent-warning);text-shadow:0 0 4px var(--glow-color);flex-shrink:0;-webkit-user-select:none;user-select:none}.command-bar__input{flex:1;background:transparent;border:none;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);line-height:var(--line-height);padding:4px 8px 4px 0;outline:none;caret-color:var(--cursor)}.command-bar__input::placeholder{color:var(--roomlist-muted)}.command-bar__completion{padding:4px 8px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}.shortcode-preview{max-height:200px;overflow-y:auto;background-color:var(--bg);border:var(--border-width) solid var(--border-color);border-bottom:none;z-index:50;flex-shrink:0}.shortcode-preview__list{list-style:none;margin:0;padding:0}.shortcode-preview__item{display:flex;align-items:center;gap:8px;padding:4px 10px;cursor:pointer;transition:background-color var(--transition-speed)}.shortcode-preview__item:hover{background-color:var(--surface-hover)}.shortcode-preview__item--active{background-color:var(--selection-bg);color:var(--selection-fg)}.shortcode-preview__emoji-glyph{font-size:calc(var(--font-size) + 2px);width:1.5em;text-align:center;flex-shrink:0;overflow:hidden}.shortcode-preview__emoji-img{flex-shrink:0;object-fit:contain}.shortcode-preview__label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.shortcode-preview__item--active .shortcode-preview__label{color:var(--selection-fg)}.shortcode-preview__empty{padding:8px 10px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.gif-picker{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}@keyframes gif-picker-fade-in{0%{opacity:0}to{opacity:1}}.gif-picker__panel{display:flex;flex-direction:column;width:min(600px,calc(100vw - 40px));max-height:min(540px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden}.gif-picker__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.gif-picker__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.gif-picker__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.gif-picker__search-wrap{display:flex;align-items:center;gap:6px;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.gif-picker__search-prompt{color:var(--accent-primary);font-family:var(--font-family);font-size:var(--font-size);opacity:.7;flex-shrink:0;-webkit-user-select:none;user-select:none}.gif-picker__search{flex:1;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);caret-color:var(--cursor);padding:0}.gif-picker__search::placeholder{color:var(--roomlist-muted);opacity:.6}.gif-picker__powered-by{font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);color:var(--roomlist-muted);opacity:.6;flex-shrink:0;white-space:nowrap;-webkit-user-select:none;user-select:none}.gif-picker__grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:110px;gap:3px;padding:6px;overflow-y:auto;min-height:0;align-content:start}.gif-picker__empty{grid-column:1 / -1;padding:32px 0;text-align:center;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.gif-picker__cell{position:relative;display:block;overflow:hidden;background-color:var(--surface-hover);border:var(--border-width) solid transparent;cursor:pointer;padding:0;transition:border-color var(--transition-speed)}.gif-picker__cell:hover,.gif-picker__cell:focus{border-color:var(--accent-primary);outline:none}.gif-picker__cell:focus{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.gif-picker__thumbnail{width:100%;height:100%;object-fit:cover;display:block}.gif-picker__cell-label{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background-color:var(--overlay-bg);color:var(--fg);font-size:calc(var(--font-size) - 3px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;transition:opacity var(--transition-speed);pointer-events:none}.gif-picker__cell:hover .gif-picker__cell-label,.gif-picker__cell:focus .gif-picker__cell-label{opacity:1}.gif-picker__status{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background-color:var(--surface-dim)}.help-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.help-dialog__panel{display:flex;flex-direction:column;width:min(680px,calc(100vw - 40px));max-height:min(520px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden}.help-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.help-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.help-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.help-dialog__tabs{display:flex;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.help-dialog__tab{background:transparent;border:none;border-right:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);letter-spacing:.06em;padding:4px 14px;text-transform:uppercase;outline:none}.help-dialog__tab:hover{color:var(--fg);background-color:var(--surface-hover)}.help-dialog__tab--active{color:var(--accent-primary);background-color:var(--surface-subtle)}.help-dialog__content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.help-dialog__headings{display:grid;gap:0 12px;padding:4px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.06em}.help-dialog__headings--bindings{grid-template-columns:12ch 10ch 1fr}.help-dialog__headings--commands{grid-template-columns:14ch 20ch 1fr}.help-dialog__table{flex:1;overflow-y:auto;min-height:0;padding:4px 0}.help-dialog__row{display:grid;gap:0 12px;padding:3px 10px;cursor:default;outline:none}.help-dialog__row--bindings{grid-template-columns:12ch 10ch 1fr}.help-dialog__row--commands{grid-template-columns:14ch 20ch 1fr}.help-dialog__row:focus,.help-dialog__row:hover{background-color:var(--surface-hover-strong)}.help-dialog__row:focus .help-dialog__cmd-name,.help-dialog__row:focus .help-dialog__key{color:var(--accent-primary)}.help-dialog__key{color:var(--fg);font-weight:700;white-space:nowrap}.help-dialog__mode{color:var(--roomlist-muted);white-space:nowrap}.help-dialog__cmd-name{color:var(--fg);font-weight:700;white-space:nowrap}.help-dialog__cmd-args{color:var(--accent-secondary, var(--roomlist-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.help-dialog__cmd-desc{color:var(--msg-body, var(--fg));opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.help-dialog__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}.profile-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);flex-direction:column;gap:0;background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 20px var(--shadow-color),0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent);z-index:300;width:auto;animation:profile-dialog-in 80ms ease}@keyframes profile-dialog-in{0%{opacity:0;transform:translate(-50%,calc(-50% - 4px))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes picker-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.profile-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 6px;border-bottom:var(--border-width) solid var(--border-color)}.profile-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);letter-spacing:.05em;-webkit-user-select:none;user-select:none}.profile-dialog__close{background:transparent;border:none;color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size);padding:0 2px;outline:none}.profile-dialog__close:hover{color:var(--fg)}.profile-dialog__avatar{width:64px;height:64px;margin:16px auto 8px;border-radius:var(--icon-radius);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.profile-dialog__avatar--fallback{background-color:color-mix(in srgb,var(--accent-primary) 15%,transparent);color:var(--accent-primary);border:var(--border-width) solid color-mix(in srgb,var(--accent-primary) 40%,transparent)}.profile-dialog__avatar-img{width:100%;height:100%;object-fit:cover}.profile-dialog__info{padding:8px 16px 12px;display:flex;flex-direction:column;gap:6px}.profile-dialog__row{display:flex;gap:12px;align-items:baseline}.profile-dialog__label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.05em;min-width:100px;flex-shrink:0}.profile-dialog__value{color:var(--fg)}.profile-dialog__value--muted{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.profile-dialog__value--status{min-width:0;flex:1 1 auto;overflow-wrap:break-word;word-break:normal}.profile-dialog__copy-btn{background:transparent;border:none;color:var(--roomlist-muted);font-family:var(--font-mono);font-size:smaller;cursor:pointer;padding:0;outline:none}.profile-dialog__copy-btn:hover{color:var(--accent-primary)}.profile-dialog__actions{padding:4px 16px 8px;display:flex;gap:8px}.profile-dialog__dm-btn{background:transparent;border:var(--border-width) solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:2px 8px;outline:none;letter-spacing:.04em}.profile-dialog__dm-btn:hover{background:color-mix(in srgb,var(--accent-primary) 15%,transparent)}.profile-dialog__hint{padding:3px 10px 5px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);border-top:var(--border-width) solid var(--border-color);letter-spacing:.03em}.profile-edit-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:320}.profile-edit-dialog__panel{background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 20px var(--shadow-color),0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent);width:min(440px,calc(100vw - 24px));display:flex;flex-direction:column;gap:4px;padding-bottom:8px;outline:none;animation:profile-edit-dialog-in 80ms ease}@keyframes profile-edit-dialog-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.profile-edit-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:var(--border-width) solid var(--border-color)}.profile-edit-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);letter-spacing:.05em}.profile-edit-dialog__close{background:transparent;border:none;color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size)}.profile-edit-dialog__close:hover{color:var(--fg)}.profile-edit-dialog__row{display:flex;flex-direction:column;gap:4px;padding:6px 14px}.profile-edit-dialog__row--readonly{flex-direction:row;align-items:baseline;gap:12px;padding-top:10px;padding-bottom:4px}.profile-edit-dialog__label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.05em}.profile-edit-dialog__value{color:var(--fg);word-break:break-all}.profile-edit-dialog__input{width:100%;background-color:var(--input-bg, var(--bg));color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);border:var(--border-width) solid var(--border-color);padding:6px 8px;outline:none;transition:border-color var(--transition-speed),box-shadow var(--transition-speed)}.profile-edit-dialog__input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 30%,transparent)}.profile-edit-dialog__status{min-height:1.2em;padding:0 14px;font-size:calc(var(--font-size) - 2px)}.profile-edit-dialog__status--neutral{color:var(--roomlist-muted)}.profile-edit-dialog__status--success{color:var(--accent-primary)}.profile-edit-dialog__status--error{color:var(--error-color, #ff6363)}.profile-edit-dialog__footer{display:flex;justify-content:flex-end;gap:8px;padding:6px 14px 4px}.profile-edit-dialog__btn{background:transparent;border:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-mono);font-size:var(--font-size);padding:6px 12px;cursor:pointer}.profile-edit-dialog__btn:hover{border-color:var(--accent-primary)}.profile-edit-dialog__btn--primary{color:var(--accent-primary);border-color:var(--accent-primary)}.profile-edit-dialog__btn--primary:hover{background-color:color-mix(in srgb,var(--accent-primary) 15%,transparent)}.profile-edit-dialog__btn:disabled{opacity:.5;cursor:progress}body.quark-mobile .profile-edit-dialog__panel{width:calc(100vw - 16px);width:calc(100dvw - 16px);max-height:calc(100dvh - 32px);overflow-y:auto}.verification-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.verification-dialog__panel{display:flex;flex-direction:column;width:min(480px,calc(100vw - 40px));max-height:min(520px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden}.verification-dialog__panel--verified{border-color:var(--accent-success, var(--accent-primary))}.verification-dialog__panel--failed,.verification-dialog__panel--cancelled{border-color:var(--accent-error, #ff3333)}.verification-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.verification-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.verification-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.verification-dialog__body{display:flex;flex-direction:column;gap:16px;padding:20px;flex:1;overflow-y:auto}.verification-dialog__status{color:var(--fg);font-size:var(--font-size);text-align:center}.verification-dialog__incoming-subtitle{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px);text-align:center;word-break:break-all}.verification-dialog__emoji-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.verification-dialog__emoji-cell{display:flex;flex-direction:column;align-items:center;gap:4px;width:56px}.verification-dialog__emoji-glyph{font-size:28px;line-height:1}.verification-dialog__emoji-desc{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);text-align:center;word-break:break-word}.verification-dialog__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.verification-dialog__btn{background:transparent;border:var(--border-width) solid var(--border-color);color:var(--fg);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size);padding:5px 14px;outline:none;transition:border-color 80ms,color 80ms}.verification-dialog__btn:hover,.verification-dialog__btn--focused{border-color:var(--accent-primary);color:var(--accent-primary)}.verification-dialog__btn--confirm:hover,.verification-dialog__btn--confirm.verification-dialog__btn--focused{border-color:var(--accent-success, var(--accent-primary));color:var(--accent-success, var(--accent-primary))}.verification-dialog__btn--deny:hover,.verification-dialog__btn--deny.verification-dialog__btn--focused{border-color:var(--accent-error, #ff3333);color:var(--accent-error, #ff3333)}.verification-dialog__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim);text-align:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.message__link{color:var(--accent-link, var(--accent-secondary, #00aaff));text-decoration:underline;text-underline-offset:2px;cursor:pointer}.message__link:hover{opacity:.8}.unread-separator{display:flex;align-items:center;gap:8px;margin:12px 16px;color:var(--accent-primary, #00ff41);font-size:calc(var(--font-size) - 2px);white-space:nowrap;-webkit-user-select:none;user-select:none}.unread-separator:before,.unread-separator:after{content:"";flex:1;border-top:1px solid var(--accent-primary, #00ff41);opacity:.5}.time-separator{display:flex;align-items:center;gap:8px;margin:12px 16px;color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);white-space:nowrap;-webkit-user-select:none;user-select:none}.time-separator:before,.time-separator:after{content:"";flex:1;border-top:1px solid var(--border-color);opacity:.5}.settings-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.settings-dialog__panel{display:flex;flex-direction:column;width:min(600px,calc(100vw - 40px));max-height:min(520px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden;outline:none}.settings-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.settings-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.settings-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.settings-dialog__tabs{display:flex;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.settings-dialog__tab{background:transparent;border:none;border-right:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);letter-spacing:.06em;padding:4px 14px;text-transform:uppercase;outline:none}.settings-dialog__tab:hover{color:var(--fg);background-color:var(--surface-hover)}.settings-dialog__tab--active{color:var(--accent-primary);background-color:var(--surface-subtle)}.settings-dialog__content{flex:1;overflow-y:auto;min-height:0;padding:0}.settings-dialog__section{padding:10px 14px;border-bottom:var(--border-width) solid var(--border-color)}.settings-dialog__section:last-child{border-bottom:none}.settings-dialog__section-title{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.settings-dialog__row{display:flex;align-items:center;gap:10px;padding:3px 0}.settings-dialog__row--quiet-hours{gap:6px}.settings-dialog__row--theme{justify-content:space-between;padding:4px 0}.settings-dialog__label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px);min-width:100px;flex-shrink:0}.settings-dialog__value{color:var(--fg)}.settings-dialog__hint{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);margin:4px 0}.settings-dialog__checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--fg);font-size:var(--font-size)}.settings-dialog__checkbox-label input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;flex-shrink:0;border:var(--border-width) solid var(--border-color);background:var(--bg);cursor:pointer;position:relative;vertical-align:middle}.settings-dialog__checkbox-label input[type=checkbox]:checked{background:var(--accent-primary);border-color:var(--accent-primary)}.settings-dialog__checkbox-label input[type=checkbox]:checked:after{content:"";position:absolute;left:2px;top:-1px;width:5px;height:9px;border:2px solid var(--bg);border-top:none;border-left:none;transform:rotate(45deg)}.settings-dialog__checkbox-label input[type=checkbox]:focus-visible{outline:1px solid var(--accent-primary);outline-offset:2px}.settings-dialog__time-input,.settings-dialog__number-input,.settings-dialog__select,.settings-dialog__text-input{background:var(--bg);border:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);padding:2px 6px;outline:none}.settings-dialog__time-input:focus,.settings-dialog__number-input:focus,.settings-dialog__select:focus,.settings-dialog__text-input:focus{border-color:var(--accent-primary)}.settings-dialog__number-input{width:70px}.settings-dialog__select{cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:22px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3e%3cpath fill='%23888888' d='M0 0l5 6 5-6z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 6px center;background-size:8px 5px}.settings-dialog__select option{background:var(--bg);color:var(--fg)}.settings-dialog__text-input{flex:1;min-width:0}.settings-dialog__actions{display:flex;gap:8px;padding:8px 14px}.settings-dialog__btn{background:transparent;border:var(--border-width) solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:2px 8px;outline:none;letter-spacing:.04em}.settings-dialog__btn:hover{background:color-mix(in srgb,var(--accent-primary) 15%,transparent)}.settings-dialog__btn--danger{border-color:var(--accent-error);color:var(--accent-error)}.settings-dialog__btn--danger:hover{background:color-mix(in srgb,var(--accent-error) 15%,transparent)}.settings-dialog__theme-btn{background:transparent;border:none;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);cursor:pointer;padding:0;text-align:left;outline:none;letter-spacing:.03em}.settings-dialog__theme-btn:hover{color:var(--accent-primary)}.settings-dialog__current{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);margin-left:auto}.settings-dialog__footer{display:flex;justify-content:space-between;padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}.settings-dialog__footer-version{opacity:.6}.room-info-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);flex-direction:column;gap:0;background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 4px 20px var(--shadow-color),0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent);z-index:300;width:360px;animation:profile-dialog-in 80ms ease;outline:none}.room-info-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 6px;border-bottom:var(--border-width) solid var(--border-color)}.room-info-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);letter-spacing:.05em;-webkit-user-select:none;user-select:none}.room-info-dialog__close{background:transparent;border:none;color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size);padding:0 2px;outline:none}.room-info-dialog__close:hover{color:var(--fg)}.room-info-dialog__body{padding:8px 16px 12px;display:flex;flex-direction:column;gap:6px}.room-info-dialog__row{display:flex;gap:12px;align-items:baseline}.room-info-dialog__label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);letter-spacing:.05em;min-width:70px;flex-shrink:0;text-transform:uppercase}.room-info-dialog__value{color:var(--fg);word-break:break-all}.room-info-dialog__value--muted{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px)}.room-info-dialog__actions{padding:4px 16px 8px;display:flex;gap:8px;flex-wrap:wrap;border-top:var(--border-width) solid var(--border-color)}.room-info-dialog__btn{background:transparent;border:var(--border-width) solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:2px 8px;outline:none;letter-spacing:.04em}.room-info-dialog__btn:hover{background:color-mix(in srgb,var(--accent-primary) 15%,transparent)}.room-info-dialog__btn--danger{border-color:var(--accent-error);color:var(--accent-error)}.room-info-dialog__btn--danger:hover{background:color-mix(in srgb,var(--accent-error) 15%,transparent)}.room-info-dialog__btn--muted{border-color:var(--roomlist-muted);color:var(--roomlist-muted)}.room-info-dialog__hint{padding:3px 10px 5px;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);border-top:var(--border-width) solid var(--border-color);letter-spacing:.03em}.pinned-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.pinned-dialog__panel{display:flex;flex-direction:column;width:min(600px,calc(100vw - 40px));max-height:min(480px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden;outline:none}.pinned-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.pinned-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.pinned-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.pinned-dialog__list{flex:1;overflow-y:auto;min-height:0;padding:4px 0}.pinned-dialog__item{padding:8px 12px;border-bottom:var(--border-width) solid var(--border-color);display:flex;flex-direction:column;gap:4px}.pinned-dialog__item:last-child{border-bottom:none}.pinned-dialog__item:hover{background-color:var(--surface-hover);cursor:pointer}.pinned-dialog__item:focus{box-shadow:inset 0 0 0 var(--focus-width) var(--focus-color);outline:none}.pinned-dialog__jump-hint{font-size:calc(var(--font-size) - 3px);color:color-mix(in srgb,var(--accent-primary) 60%,transparent);letter-spacing:.03em}.pinned-dialog__item--empty{color:var(--roomlist-muted);font-style:italic;padding:16px 12px}.pinned-dialog__sender{color:var(--accent-primary);font-weight:700;font-size:calc(var(--font-size) - 1px)}.pinned-dialog__ts{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 3px);margin-left:auto}.pinned-dialog__item>div:first-of-type{display:flex;align-items:baseline;gap:8px}.pinned-dialog__body{color:var(--fg);opacity:.85;font-size:var(--font-size);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.pinned-dialog__body--utd{font-style:italic;opacity:.5}.pinned-dialog__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}.search-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.search-dialog__panel{display:flex;flex-direction:column;width:min(640px,calc(100vw - 40px));max-height:min(560px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden;outline:none}.search-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.search-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.search-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.search-dialog__query{margin:8px 10px 6px;padding:4px 8px;background:var(--surface-dim);border:var(--border-width) solid var(--border-color);border-radius:2px;color:var(--fg);font-family:var(--font-family);font-size:var(--font-size)}.search-dialog__query:focus{outline:none;border-color:var(--accent-primary)}.search-dialog__scope{display:flex;border-top:var(--border-width) solid var(--border-color);border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0}.search-dialog__scope-btn{background:transparent;border:none;border-right:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);cursor:pointer;font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);letter-spacing:.06em;padding:4px 14px;text-transform:uppercase;outline:none}.search-dialog__scope-btn:hover{color:var(--fg);background-color:var(--surface-hover)}.search-dialog__scope-btn--active{color:var(--accent-primary);background-color:var(--surface-subtle)}.search-dialog__sort{margin:0 6px 0 auto;align-self:center;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M2 3.5L5 6.5L8 3.5' fill='none' stroke='%23888888' stroke-width='1.4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:8px;border:var(--border-width) solid var(--border-color);border-radius:2px;color:var(--fg);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);padding:1px 18px 1px 6px;cursor:pointer;outline:none}.search-dialog__sort:hover,.search-dialog__sort:focus{border-color:var(--accent-primary)}.search-dialog__sort option{background-color:var(--bg);color:var(--fg)}.search-dialog__date-row{display:flex;align-items:center;gap:8px;padding:6px 10px;flex-shrink:0;position:relative}.search-dialog__date-label{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px)}.date-picker__trigger{background:var(--surface-dim);border:var(--border-width) solid var(--border-color);border-radius:2px;color:var(--roomlist-muted);font-family:var(--font-family);font-size:calc(var(--font-size) - 1px);padding:1px 8px;cursor:pointer}.date-picker__trigger--set{color:var(--fg)}.date-picker__trigger:hover{border-color:var(--accent-primary)}.date-picker__calendar{position:fixed;z-index:300;background:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 6px 20px var(--shadow-color);padding:6px;width:max-content}.date-picker__header{display:flex;align-items:center;gap:4px;margin-bottom:4px}.date-picker__title{flex:1;text-align:center;color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);white-space:nowrap}.date-picker__nav{background:transparent;border:var(--border-width) solid var(--border-color);border-radius:2px;color:var(--fg);font-family:var(--font-family);cursor:pointer;padding:0 6px;line-height:1.4}.date-picker__nav:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.date-picker__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker__weekday{text-align:center;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);padding:2px 0}.date-picker__day{background:transparent;border:var(--border-width) solid transparent;border-radius:2px;color:var(--fg);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);width:26px;height:24px;cursor:pointer;text-align:center}.date-picker__day:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.date-picker__day--selected{background-color:var(--accent-primary);color:var(--bg)}.search-dialog__list{flex:1;overflow-y:auto;min-height:0;padding:4px 0}.search-dialog__item{padding:8px 12px;border-bottom:var(--border-width) solid var(--border-color);display:flex;flex-direction:column;gap:4px}.search-dialog__item:last-child{border-bottom:none}.search-dialog__item:hover{background-color:var(--surface-hover);cursor:pointer}.search-dialog__item:focus{box-shadow:inset 0 0 0 var(--focus-width) var(--focus-color);outline:none}.search-dialog__item--empty{color:var(--roomlist-muted);font-style:italic;padding:16px 12px}.search-dialog__sender{color:var(--accent-primary);font-weight:700;font-size:calc(var(--font-size) - 1px)}.search-dialog__ts{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 3px);margin-left:8px}.search-dialog__body{color:var(--fg);opacity:.85;font-size:var(--font-size);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.search-dialog__match{background-color:color-mix(in srgb,var(--accent-primary) 35%,transparent);color:var(--fg);border-radius:2px}.search-dialog__progress{position:relative;height:3px;flex-shrink:0;overflow:hidden;background-color:var(--surface-dim);border-top:var(--border-width) solid var(--border-color)}.search-dialog__progress-fill{height:100%;width:0;background-color:var(--accent-primary);transition:width .2s ease}.search-dialog__progress--indeterminate .search-dialog__progress-fill{width:35%;transition:none;animation:search-progress-sweep 1.1s ease-in-out infinite}@keyframes search-progress-sweep{0%{transform:translate(-100%)}to{transform:translate(285%)}}.search-dialog__footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}.search-dialog__cancel{background:var(--surface-dim);border:var(--border-width) solid var(--border-color);border-radius:2px;color:var(--accent-primary);font-family:var(--font-family);font-size:calc(var(--font-size) - 2px);padding:1px 8px;cursor:pointer}.search-dialog__cancel:hover{border-color:var(--accent-primary)}.room-dir-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.room-dir-dialog__panel{display:flex;flex-direction:column;width:min(640px,calc(100vw - 40px));max-height:min(560px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden}.room-dir-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.room-dir-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.room-dir-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.room-dir-dialog__search{background:transparent;border:none;border-bottom:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);padding:8px 12px;outline:none;width:100%;box-sizing:border-box;flex-shrink:0}.room-dir-dialog__search::placeholder{color:var(--roomlist-muted);opacity:.6}.room-dir-dialog__search:focus{border-bottom-color:var(--accent-primary)}.room-dir-dialog__list{flex:1;overflow-y:auto;min-height:0}.room-dir-dialog__status{padding:12px;color:var(--roomlist-muted);font-style:italic}.room-dir-dialog__item{display:flex;flex-direction:column;gap:2px;padding:8px 12px;border-bottom:var(--border-width) solid var(--border-color);cursor:pointer;position:relative}.room-dir-dialog__item:last-child{border-bottom:none}.room-dir-dialog__item:hover{background-color:var(--surface-hover)}.room-dir-dialog__item--focused{background-color:var(--surface-hover-strong)}.room-dir-dialog__name{color:var(--fg);font-weight:700;font-size:var(--font-size)}.room-dir-dialog__item--focused .room-dir-dialog__name{color:var(--accent-primary)}.room-dir-dialog__topic{color:var(--msg-body, var(--fg));opacity:.7;font-size:calc(var(--font-size) - 1px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-dir-dialog__meta{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px)}.room-dir-dialog__join-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:var(--border-width) solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:2px 6px;outline:none;opacity:0;transition:opacity .1s}.room-dir-dialog__item:hover .room-dir-dialog__join-btn,.room-dir-dialog__item--focused .room-dir-dialog__join-btn{opacity:1}.room-dir-dialog__join-btn:hover{background:color-mix(in srgb,var(--accent-primary) 15%,transparent)}.room-dir-dialog__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}.quick-nav-palette{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;background-color:var(--overlay-bg);z-index:300;animation:gif-picker-fade-in .1s ease}.quick-nav-palette__panel{display:flex;flex-direction:column;width:min(520px,calc(100vw - 40px));max-height:min(400px,calc(100vh - 140px));background-color:var(--bg);border:var(--border-width) solid var(--border-color);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden}.quick-nav-palette__search{background:transparent;border:none;border-bottom:var(--border-width) solid var(--border-color);color:var(--fg);font-family:var(--font-family);font-size:var(--font-size);padding:10px 12px;outline:none;flex-shrink:0}.quick-nav-palette__search::placeholder{color:var(--roomlist-muted);opacity:.6}.quick-nav-palette__search:focus{border-bottom-color:var(--accent-primary)}.quick-nav-palette__list{flex:1;overflow-y:auto;min-height:0}.quick-nav-palette__empty{padding:12px;color:var(--roomlist-muted);font-style:italic}.quick-nav-palette__item{display:flex;align-items:baseline;gap:8px;padding:7px 12px;border-bottom:var(--border-width) solid var(--border-color);cursor:pointer}.quick-nav-palette__item:last-child{border-bottom:none}.quick-nav-palette__item:hover{background-color:var(--surface-hover)}.quick-nav-palette__item--focused{background-color:var(--surface-hover-strong)}.quick-nav-palette__name{color:var(--fg);font-size:var(--font-size);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.quick-nav-palette__item--focused .quick-nav-palette__name{color:var(--accent-primary)}.quick-nav-palette__alias{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 1px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.quick-nav-palette__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0;background-color:var(--surface-dim)}#startup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background-color:var(--bg, #0a0a0a);display:flex;align-items:center;justify-content:center;transition:opacity .6s cubic-bezier(.4,0,.2,1)}#startup-overlay.startup-overlay--out{opacity:0;pointer-events:none}.startup-overlay__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:20px}.startup-overlay__logo{font-family:var(--font-family, "JetBrains Mono", monospace);font-size:52px;font-weight:700;letter-spacing:.25em;color:var(--accent-primary, #00ff41);text-shadow:0 0 10px var(--accent-primary, #00ff41),0 0 30px color-mix(in srgb,var(--accent-primary, #00ff41) 40%,transparent),0 0 60px color-mix(in srgb,var(--accent-primary, #00ff41) 20%,transparent);animation:startup-logo-in .6s cubic-bezier(.16,1,.3,1) both,startup-flicker 6s ease-in-out 1.2s infinite}@keyframes startup-logo-in{0%{opacity:0;transform:translateY(6px);letter-spacing:.4em}to{opacity:1;transform:translateY(0);letter-spacing:.25em}}@keyframes startup-flicker{0%,88%,90%,92%,to{opacity:1}89%{opacity:.78}91%{opacity:.92}}.startup-overlay__sub{font-family:var(--font-family, monospace);font-size:10px;letter-spacing:.5em;color:var(--roomlist-muted, #444444);text-transform:uppercase;animation:startup-sub-in .5s ease .2s both}@keyframes startup-sub-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.startup-overlay__progress{width:180px;height:1px;background-color:var(--border-color, #333333);position:relative;overflow:hidden;animation:startup-sub-in .4s ease .3s both}.startup-overlay__bar{position:absolute;top:0;left:0;height:100%;width:40%;background-color:var(--accent-primary, #00ff41);box-shadow:0 0 8px var(--accent-primary, #00ff41);animation:startup-bar-sweep 1.3s ease-in-out .3s infinite}@keyframes startup-bar-sweep{0%{transform:translate(-110%)}to{transform:translate(355%)}}.startup-overlay__scanlines{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,transparent 0px,transparent 1px,var(--scanline-color) 1px,var(--scanline-color) 2px);opacity:.5}:root.theme-tweening,:root.theme-tweening *,:root.theme-tweening *:before,:root.theme-tweening *:after{transition:background-color .45s ease,color .45s ease,border-color .45s ease,box-shadow .45s ease,fill .45s ease,stroke .45s ease!important}.skeleton-overlay{position:fixed;z-index:150;background-color:var(--bg);display:flex;flex-direction:column;gap:22px;padding:16px 14px;overflow:hidden;transition:opacity .38s ease}.skeleton-overlay--out{opacity:0;pointer-events:none}.skeleton-group{display:flex;gap:12px;align-items:flex-start;opacity:0;animation:skeleton-fade-in .28s ease forwards}@keyframes skeleton-fade-in{to{opacity:1}}.skeleton-group__avatar{width:32px;height:32px;border-radius:var(--icon-radius, 50%);flex-shrink:0}.skeleton-group__content{flex:1;display:flex;flex-direction:column;gap:7px;padding-top:2px}.skeleton-group__name{height:9px;border-radius:2px;max-width:160px}.skeleton-group__line{height:9px;border-radius:2px}.skeleton-group__avatar,.skeleton-group__name,.skeleton-group__line{background-color:var(--border-color);background-image:linear-gradient(90deg,var(--border-color) 0%,color-mix(in srgb,var(--accent-primary) 9%,var(--border-color)) 50%,var(--border-color) 100%);background-size:300% 100%;animation:skeleton-fade-in .28s ease forwards,skeleton-shimmer 2.6s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:100% 50%}to{background-position:-100% 50%}}.room-settings-dialog__wide-input{flex:1;min-width:0;max-width:340px}.room-settings-dialog__user-row{gap:6px}.room-settings-dialog__user-id{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-viewer{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:300;animation:gif-picker-fade-in .1s ease}.debug-viewer__panel{display:flex;flex-direction:column;width:min(820px,calc(100vw - 40px));max-height:min(640px,calc(100vh - 60px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden;outline:none}.debug-viewer__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.debug-viewer__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-viewer__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5;flex-shrink:0;margin-left:8px}.debug-viewer__toolbar{display:flex;gap:6px;padding:4px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-dim)}.debug-viewer__toolbar-btn{background:transparent;border:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-family:var(--font-mono);font-size:calc(var(--font-size) - 2px);cursor:pointer;padding:1px 6px;outline:none;letter-spacing:.04em}.debug-viewer__toolbar-btn:hover{color:var(--fg);border-color:var(--fg)}.debug-viewer__body{flex:1;overflow:auto;padding:10px 14px;margin:0;font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);line-height:1.5;color:var(--fg);white-space:pre;-moz-tab-size:2;tab-size:2}.debug-viewer__body{color:var(--fg)}.message__edited-marker{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);cursor:pointer;opacity:.7;-webkit-user-select:none;user-select:none}.message__edited-marker:hover{opacity:1;text-decoration:underline;color:var(--accent-primary)}.revision-dialog{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--overlay-bg);z-index:200;animation:gif-picker-fade-in .1s ease}.revision-dialog__panel{display:flex;flex-direction:column;width:min(560px,calc(100vw - 40px));max-height:min(480px,calc(100vh - 80px));background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);overflow:hidden;outline:none}.revision-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;background-color:var(--surface-subtle)}.revision-dialog__title{color:var(--accent-primary);font-size:calc(var(--font-size) - 1px);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.revision-dialog__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.5}.revision-dialog__list{flex:1;overflow-y:auto;min-height:0;padding:4px 0}.revision-dialog__item{padding:10px 14px;border-bottom:var(--border-width) solid var(--border-color);display:flex;flex-direction:column;gap:4px}.revision-dialog__item:last-child{border-bottom:none}.revision-dialog__meta{display:flex;align-items:baseline;gap:8px}.revision-dialog__version{color:var(--accent-primary);font-size:calc(var(--font-size) - 2px);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.revision-dialog__timestamp{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 3px)}.revision-dialog__body{color:var(--fg);opacity:.85;font-size:var(--font-size);white-space:pre-wrap;word-break:break-word}.revision-dialog__error{padding:12px 14px;color:var(--error);font-size:calc(var(--font-size) - 1px)}.revision-dialog__footer{padding:4px 10px;border-top:var(--border-width) solid var(--border-color);color:var(--roomlist-muted);font-size:calc(var(--font-size) - 3px);flex-shrink:0;background-color:var(--surface-subtle)}.context-menu{position:fixed;z-index:10000;background:var(--bg);border:var(--border-width) solid var(--border-color);min-width:180px;padding:3px 0;outline:none;box-shadow:0 4px 16px #0006}.context-menu__item{display:flex;align-items:center;justify-content:space-between;padding:5px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;gap:24px;color:var(--fg);font-size:var(--font-size)}.context-menu__item--active,.context-menu__item:focus{background:var(--accent);color:var(--surface)}.context-menu__item-hint{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);flex-shrink:0}.context-menu__item--active .context-menu__item-hint,.context-menu__item:focus .context-menu__item-hint{color:var(--surface);opacity:.7}.context-menu__separator{height:var(--border-width);background:var(--border-color);margin:3px 0}.mobile-top-bar,.mobile-backdrop{display:none}body.quark-mobile .mobile-top-bar{display:flex;align-items:center;gap:8px;height:44px;padding:0 12px;padding-top:env(safe-area-inset-top);padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));box-sizing:content-box;background-color:var(--bg);border-bottom:var(--border-width) solid var(--border-color);flex-shrink:0;z-index:5}.mobile-top-bar__btn{background:none;border:none;color:var(--fg);font-family:var(--font-family);font-size:22px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px}.mobile-top-bar__btn:active{background-color:var(--surface-hover-active)}.mobile-top-bar__title{flex:1;font-size:var(--font-size);color:var(--accent-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-top-bar__avatar{width:32px;height:32px;flex-shrink:0;border:none;padding:0;border-radius:var(--icon-radius);overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:pointer;background-color:transparent;color:var(--fg);font-family:var(--font-family);font-size:16px;font-weight:700;outline:none}.mobile-top-bar__avatar-img{width:100%;height:100%;object-fit:cover}.mobile-top-bar__avatar:active{opacity:.6}.mobile-top-bar__members{font-size:18px;color:var(--accent-primary)}.mobile-top-bar__members--hidden{visibility:hidden;pointer-events:none}body.quark-mobile .room-header{display:none}.dialog-close-btn{background:transparent;border:none;font-family:var(--font-family);cursor:pointer;padding:2px 4px;letter-spacing:.02em}.dialog-close-btn:hover{opacity:1}body.quark-mobile .dialog-close-btn{padding:8px 12px;font-size:var(--font-size);opacity:1;margin:-4px 0}.device-picker__header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 8px 2px}.device-picker__close-hint{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.6}.device-picker{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;width:max-content;max-width:calc(100vw - 40px);max-height:calc(100vh - 80px);background-color:var(--bg);border:var(--border-width) solid var(--accent-primary);box-shadow:0 8px 32px var(--shadow-color),0 0 0 1px var(--border-color);z-index:200;overflow:hidden;animation:gif-picker-fade-in .1s ease}.device-picker__title{font-weight:700;color:var(--fg)}.device-picker__hint{padding:0 8px 4px;color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.7}.device-picker__list{list-style:none;margin:0;padding:4px 0;overflow-y:auto}.device-picker__item{display:grid;grid-template-columns:var(--device-name-col, max-content) var(--device-id-col, max-content) var(--device-status-col, max-content);column-gap:2ch;align-items:baseline;padding:3px 12px;cursor:pointer}.device-picker__item:hover{background-color:var(--surface-hover)}.device-picker__item--selected{background-color:var(--surface-hover-strong)}.device-picker__name{color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-picker__item--selected .device-picker__name{color:var(--accent-primary)}.device-picker__name--unnamed{color:var(--msg-timestamp);opacity:.6;font-style:italic}.device-picker__device-id{color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-picker__trust{text-align:right;color:var(--msg-timestamp);font-size:calc(var(--font-size) - 2px);opacity:.85}body.quark-mobile .quark-layout,body.quark-mobile .quark-layout--thread-open,body.quark-mobile .quark-layout--member-list-open,body.quark-mobile .quark-layout--thread-open.quark-layout--member-list-open{grid-template-columns:1fr;position:relative}body.quark-mobile .space-strip,body.quark-mobile .room-list{position:fixed;top:0;height:100%;z-index:20;transform:translate(-100%);transition:transform .22s ease;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}body.quark-mobile-drawer-open .space-strip,body.quark-mobile-drawer-open .room-list,body.quark-mobile.quark-drawer-dragging .space-strip,body.quark-mobile.quark-drawer-dragging .room-list{box-shadow:0 0 24px var(--shadow-color)}body.quark-mobile .space-strip{left:0;width:var(--space-strip-width);border-right:var(--border-width) solid var(--border-color)}body.quark-mobile .room-list{left:var(--space-strip-width);width:calc(100vw - var(--space-strip-width));width:calc(100dvw - var(--space-strip-width));transform:translate(calc(-100% - var(--space-strip-width)))}body.quark-mobile .room-list__scroll{padding-bottom:env(safe-area-inset-bottom)}body.quark-mobile-drawer-open .space-strip,body.quark-mobile-drawer-open .room-list{transform:translate(0)}body.quark-mobile.quark-drawer-dragging .space-strip,body.quark-mobile.quark-drawer-dragging .room-list{transition:none}body.quark-mobile.quark-drawer-dragging .space-strip{transform:translate(calc(-100% * var(--drawer-shut, 1)))}body.quark-mobile.quark-drawer-dragging .room-list{transform:translate(calc((-100% - var(--space-strip-width)) * var(--drawer-shut, 1)))}body.quark-mobile-drawer-open .content-area{overflow:hidden;touch-action:none;pointer-events:none}body.quark-mobile .mobile-backdrop{display:none}body.quark-mobile .room-list__header{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:var(--font-size);letter-spacing:.08em;color:var(--accent-primary);cursor:pointer;min-height:44px;-webkit-user-select:none;user-select:none}body.quark-mobile .room-list__header:before{content:"◀";font-size:calc(var(--font-size) - 1px);color:var(--accent-primary)}body.quark-mobile .room-list__header:active{background-color:var(--surface-hover-active)}body.quark-mobile .member-list__header{cursor:pointer;min-height:44px;padding:12px 16px}body.quark-mobile .member-list__header:before{content:"◀";font-size:calc(var(--font-size) - 1px);color:var(--accent-primary);margin-right:6px}body.quark-mobile .member-list__header:active{background-color:var(--surface-hover-active)}body.quark-mobile .content-area{grid-column:1 / -1;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:var(--keyboard-offset, 0px);transition:padding-bottom .12s ease}body.quark-mobile .input-bar-wrap{padding-bottom:max(0px,env(safe-area-inset-bottom) - var(--keyboard-offset, 0px))}body.quark-mobile .room-list__item{padding:12px;min-height:44px;font-size:calc(var(--font-size) + 1px)}body.quark-mobile .input-bar__field,body.quark-mobile .login-screen__field-input,body.quark-mobile .thread-view__input,body.quark-mobile input[type=text],body.quark-mobile input[type=url],body.quark-mobile input[type=email],body.quark-mobile input[type=search],body.quark-mobile input[type=password],body.quark-mobile textarea{font-size:max(16px,var(--font-size))}body.quark-mobile .space-strip__item,body.quark-mobile .space-strip__settings-btn{width:56px;height:56px}body.quark-mobile .quark-layout--member-list-open .member-list,body.quark-mobile .quark-layout--thread-open .thread-view{position:fixed;top:0;right:0;bottom:0;left:0;width:100%!important;z-index:12;background-color:var(--bg);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}body.quark-mobile .status-bar,body.quark-mobile .message:hover .message__actions,body.quark-mobile .image-lightbox__zoom-ctl{display:none}body.quark-mobile .profile-dialog{width:calc(100vw - 24px);width:calc(100dvw - 24px);max-width:420px;max-height:calc(100dvh - 60px);overflow-y:auto}body.quark-mobile .profile-dialog__avatar{width:96px;height:96px;font-size:40px}body.quark-mobile .profile-dialog__row{flex-direction:column;align-items:stretch;gap:2px}body.quark-mobile .profile-dialog__label{min-width:0;font-size:calc(var(--font-size) - 3px)}body.quark-mobile .profile-dialog__value{word-break:break-all}body.quark-mobile .profile-dialog__copy-btn{align-self:flex-start;padding:4px 0}body.quark-mobile .profile-dialog__dm-btn{padding:8px 14px;font-size:var(--font-size)}body.quark-mobile .settings-dialog__panel{width:100vw;width:100dvw;max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;border:none;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}body.quark-mobile .settings-dialog__tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}body.quark-mobile .settings-dialog__tabs::-webkit-scrollbar{display:none}body.quark-mobile .settings-dialog__tab{flex-shrink:0;padding:10px 14px}.quick-react-picker--mobile{left:0!important;right:0!important;bottom:0!important;top:auto!important;width:100%!important;transform:none!important;max-height:60vh;padding-bottom:env(safe-area-inset-bottom);border-bottom:none;border-left:none;border-right:none;border-top:var(--border-width) solid var(--accent-primary);animation:quick-react-sheet-in .14s ease}.quick-react-picker--mobile .quick-react-picker__grid{max-height:40vh;font-size:calc(var(--font-size) + 4px)}.quick-react-picker--mobile .quick-react-picker__btn{padding:8px 9px;font-size:24px}@keyframes quick-react-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}body.quark-mobile .message__link{padding:4px 0;-webkit-touch-callout:default}.context-menu--mobile{position:fixed!important;left:0!important;right:0!important;bottom:0!important;top:auto!important;width:100%!important;max-width:100%!important;border-radius:0!important;border-left:none!important;border-right:none!important;border-bottom:none!important;border-top:var(--border-width) solid var(--accent-primary)!important;padding:4px 0!important;padding-bottom:max(4px,env(safe-area-inset-bottom))!important;animation:context-menu-sheet-in .14s ease}.context-menu--mobile .context-menu__item{padding:14px 18px;font-size:calc(var(--font-size) + 1px);min-height:44px}.context-menu--mobile .context-menu__item-hint{display:none}.context-menu--mobile .context-menu__separator{margin:4px 0}@keyframes context-menu-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.home-view{grid-column:2;display:flex;height:100%;min-width:0;overflow:hidden;background:var(--bg)}.home-view__profile{flex:0 0 260px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 18px;border-right:1px solid var(--border-color)}.home-view__profile-avatar{width:96px;height:96px;border-radius:var(--icon-radius, 50%);border:1px solid var(--border-color);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary, rgba(255, 255, 255, .04))}.home-view__profile-avatar img{width:100%;height:100%;object-fit:cover}.home-view__avatar-initial{color:var(--accent-primary);font-size:calc(var(--font-size) * 2)}.home-view__profile-name{color:var(--fg);font-weight:700;text-align:center;overflow-wrap:break-word;max-width:100%}.home-view__profile-mxid{color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px);text-align:center;overflow-wrap:anywhere;max-width:100%}.home-view__profile-status-label{display:flex;flex-direction:column;gap:4px;width:100%;color:var(--roomlist-muted);font-size:calc(var(--font-size) - 2px)}.home-view__profile-status{width:100%;background:transparent;border:1px solid var(--border-color);color:var(--fg);font-family:inherit;font-size:calc(var(--font-size) - 1px);padding:5px 8px}.home-view__profile-status:focus{outline:none;border-color:var(--accent-primary)}.home-view__profile-btn{background:transparent;border:none;color:var(--accent-secondary);font-family:inherit;font-size:calc(var(--font-size) - 1px);cursor:pointer;padding:4px}.home-view__profile-btn:hover{color:var(--accent-primary)}.home-view__canvas{position:relative;flex:1;min-width:0;overflow:hidden}.home-view__float{position:absolute;left:var(--x);top:var(--y);display:flex;flex-direction:column;align-items:center;gap:6px;max-width:230px;cursor:pointer;transform:translate(-50%,-50%);animation:home-drift var(--drift-dur, 24s) ease-in-out var(--drift-delay, 0s) infinite}.home-view__float:hover,.home-view__float:focus-visible{animation-play-state:paused;z-index:2}.home-view__float:focus-visible{outline:none}.home-view__float:focus-visible .home-view__bubble{border-color:var(--accent-primary);box-shadow:0 0 8px color-mix(in srgb,var(--accent-primary) 40%,transparent)}.home-view__float-avatar-wrap{position:relative}.home-view__float-avatar{width:56px;height:56px;border-radius:var(--icon-radius, 50%);border:1px solid var(--border-color);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary, rgba(255, 255, 255, .04))}.home-view__float-avatar img{width:100%;height:100%;object-fit:cover}.home-view__presence{position:absolute;right:0;bottom:2px;width:11px;height:11px;border-radius:50%;border:2px solid var(--bg)}.home-view__presence--online{background:var(--presence-online, #4caf50);box-shadow:0 0 4px var(--presence-online, #4caf50)}.home-view__presence--unavailable{background:var(--presence-unavailable, #ff9800)}.home-view__presence--offline{background:var(--presence-offline, #555)}.home-view__float-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--roomlist-mention-badge, var(--accent-error));color:var(--bg);font-size:10px;line-height:16px;text-align:center}.home-view__bubble{border:1px solid var(--border-color);background:var(--bg);padding:5px 9px;max-width:230px;min-width:90px}.home-view__bubble-header{display:flex;justify-content:space-between;gap:8px;font-size:calc(var(--font-size) - 3px);margin-bottom:2px}.home-view__bubble-name{color:var(--accent-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-view__bubble-age{color:var(--roomlist-muted);flex-shrink:0}.home-view__bubble-text{color:var(--fg);font-size:calc(var(--font-size) - 2px);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}.home-view__bubble-text--status{color:var(--roomlist-muted);font-style:italic}.home-view__empty{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);white-space:pre;color:var(--roomlist-muted);text-align:left}@keyframes home-drift{0%{transform:translate(-50%,-50%) translate(0)}25%{transform:translate(-50%,-50%) translate(var(--drift-rx, 12px),calc(var(--drift-ry, 9px) * -.6))}50%{transform:translate(-50%,-50%) translate(calc(var(--drift-rx, 12px) * .2),var(--drift-ry, 9px))}75%{transform:translate(-50%,-50%) translate(calc(var(--drift-rx, 12px) * -1),calc(var(--drift-ry, 9px) * .4))}to{transform:translate(-50%,-50%) translate(0)}}@media(prefers-reduced-motion:reduce){.home-view__float{animation:none}}:root{--bg: #0a0a0a;--fg: #b0b0b0;--cursor: #00ff41;--selection-bg: #1a3a1a;--selection-fg: #00ff41;--border: #333333;--accent-primary: #00ff41;--accent-secondary: #00aaff;--accent-error: #ff3333;--accent-warning: #ffaa00;--accent-success: #00ff41;--accent-link: #00aaff;--msg-own: #00ff41;--msg-other: #b0b0b0;--msg-system: #555555;--msg-timestamp: #444444;--msg-mention-bg: #1a1a00;--msg-mention-fg: #ffaa00;--msg-reply-border: #555555;--msg-thread-indicator: #00aaff;--roomlist-active-bg: #2a2a2a;--roomlist-active-fg: #00ff41;--roomlist-unread: #ffffff;--roomlist-mention-badge: #ff3333;--roomlist-muted: #444444;--reaction-bg: #1a1a1a;--reaction-border: #333333;--reaction-own-bg: #1a3a1a;--reaction-count: #888888;--font-emoji: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", "Twemoji Mozilla", "EmojiOne Color", emoji;--font-family: "JetBrains Mono", "Fira Code", "Roboto Mono", monospace, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", "Twemoji Mozilla", "EmojiOne Color", emoji;--font-family-messages: "Roboto", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", "Twemoji Mozilla", "EmojiOne Color", emoji;--font-size: 14px;--line-height: 1.5;--message-spacing: 4px;--border-style: rounded;--border-h: "─";--border-v: "│";--border-tl: "╭";--border-tr: "╮";--border-bl: "╰";--border-br: "╯";--border-color: #333333;--border-width: 2px;--space-strip-width: 64px;--room-list-width: 220px;--thread-view-width: 300px;--member-list-width: 200px;--status-bar-height: 24px;--emoji-size: 32px;--sticker-max-size: 256px;--reaction-size: 14px;--prompt-symbol: ":>";--mode-normal: "NOR";--mode-insert: "INS";--mode-command: "CMD";--mode-visual: "VIS";--icon-radius: 50%;--scrollbar-width: 6px;--scrollbar-thumb: #333333;--scrollbar-track: transparent;--focus-color: var(--accent-primary);--focus-width: 1px;--overlay-bg: rgba(0, 0, 0, .65);--overlay-bg-dark: rgba(0, 0, 0, .88);--shadow-color: rgba(0, 0, 0, .6);--surface-dim: rgba(255, 255, 255, .02);--surface-subtle: rgba(255, 255, 255, .03);--surface-hover: rgba(255, 255, 255, .04);--surface-hover-strong: rgba(255, 255, 255, .06);--surface-hover-active: rgba(255, 255, 255, .1);--media-bg: #000;--media-icon-fg: #fff;--scanline-color: rgba(0, 0, 0, .22);--glow-color: color-mix(in srgb, var(--accent-primary) 50%, transparent);--glow-radius: 6px;--transition-speed: .15s}
