.agora-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-md);font-family:inherit;font-weight:var(--font-medium);letter-spacing:-.01em;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.agora-btn:disabled{opacity:.5;cursor:not-allowed}.agora-btn--sm{height:30px;padding:0 12px;font-size:var(--text-xs);border-radius:var(--radius-sm)}.agora-btn--md{height:36px;padding:0 16px;font-size:var(--text-sm)}.agora-btn--lg{height:44px;padding:0 24px;font-size:var(--text-md)}.agora-btn--icon-only.agora-btn--sm{width:28px;padding:0}.agora-btn--icon-only.agora-btn--md{width:36px;padding:0}.agora-btn--icon-only.agora-btn--lg{width:44px;padding:0}.agora-btn--primary{background:var(--accent);color:#fff}.agora-btn--primary:hover:not(:disabled){background:var(--accent-hover)}.agora-btn--primary:active:not(:disabled){background:var(--accent-active)}.agora-btn--secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-subtle)}.agora-btn--secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border)}.agora-btn--danger{background:var(--danger);color:#fff}.agora-btn--danger:hover:not(:disabled){opacity:.9}.agora-btn--ghost{background:transparent;color:var(--text-muted)}.agora-btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.agora-btn__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.agora-btn--sm .agora-btn__icon{font-size:var(--text-md)}.agora-btn--md .agora-btn__icon{font-size:1rem}.agora-btn--lg .agora-btn__icon{font-size:var(--text-lg)}.agora-input{display:flex;flex-direction:column;gap:4px;position:relative}.agora-input__icon{position:absolute;left:10px;top:10px;display:flex;align-items:center;color:var(--text-muted);font-size:1rem;pointer-events:none;z-index:1}.agora-input__field{width:100%;padding:10px 14px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);font-family:inherit;font-size:var(--text-md);transition:border-color var(--transition-fast);outline:none}.agora-input--has-icon .agora-input__field{padding-left:34px}.agora-input__field:focus{border-color:var(--accent);box-shadow:none}.agora-input__field::placeholder{color:var(--text-muted)}.agora-input--error .agora-input__field{border-color:var(--danger)}.agora-input__error{font-size:var(--text-2xs);color:var(--danger)}.agora-modal{border:none;border-radius:var(--radius-lg);background-color:var(--bg-secondary);color:var(--text-primary);padding:0;max-width:var(--modal-width, 520px);width:90%;max-height:80vh;box-shadow:var(--shadow-lg);overflow:hidden;margin-top:12vh;animation:agora-modal-in .2s ease-out}.agora-modal::backdrop{background-color:var(--bg-overlay);animation:agora-modal-backdrop-in .2s ease}@keyframes agora-modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes agora-modal-backdrop-in{0%{opacity:0}to{opacity:1}}.agora-modal__content{display:flex;flex-direction:column;max-height:80vh}.agora-modal__header{padding:24px 32px 0;flex-shrink:0}.agora-modal__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.02em;margin:0}.agora-modal__body{overflow-y:auto;padding:20px 32px 32px;flex:1}.agora-select{position:relative;display:inline-flex;flex-direction:column;gap:4px}.agora-select__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.agora-select__trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:160px;height:36px;padding:0 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);font-family:inherit;font-size:var(--text-md);cursor:pointer;transition:border-color var(--transition-fast);outline:none;text-align:left}.agora-select__trigger:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}.agora-select__trigger:hover:not(:disabled){border-color:var(--border)}.agora-select--disabled .agora-select__trigger{opacity:.5;cursor:not-allowed}.agora-select__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agora-select__value--placeholder{color:var(--text-muted)}.agora-select__chevron{flex-shrink:0;font-size:10px;color:var(--text-muted);transition:transform var(--transition-fast)}.agora-select--open .agora-select__chevron{transform:rotate(180deg)}.agora-select__dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);box-shadow:var(--shadow-md);z-index:50;overflow:hidden;animation:agora-select-in .12s ease}@keyframes agora-select-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.agora-select__search{padding:6px;border-bottom:1px solid var(--border)}.agora-select__search-input{width:100%;padding:6px 8px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-family:inherit;font-size:var(--text-sm);outline:none}.agora-select__search-input:focus{border-color:var(--accent)}.agora-select__search-input::placeholder{color:var(--text-muted)}.agora-select__listbox{list-style:none;margin:0;padding:4px 0;max-height:200px;overflow-y:auto;outline:none}.agora-select__option{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;font-size:var(--text-md);cursor:pointer;transition:background-color 80ms}.agora-select__option--highlighted{background:var(--bg-hover)}.agora-select__option--selected{color:var(--accent);font-weight:var(--font-semibold)}.agora-select__option--disabled{color:var(--text-muted);cursor:not-allowed;opacity:.5}.agora-select__check{flex-shrink:0;font-size:12px;margin-left:8px}.agora-select__no-results{padding:8px 12px;color:var(--text-muted);font-size:var(--text-sm);text-align:center}.agora-popover{position:absolute;z-index:100;outline:none;animation:agora-popover-in .12s ease}@keyframes agora-popover-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.agora-popover__content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;min-width:120px}.agora-popover__arrow{position:absolute;width:16px;height:16px;background:var(--bg-secondary);border:1px solid var(--border);transform:rotate(45deg);z-index:-1}.agora-popover--bottom .agora-popover__arrow{top:-5px;left:calc(50% - 8px);border-right:none;border-bottom:none}.agora-popover--top .agora-popover__arrow{bottom:-5px;left:calc(50% - 8px);border-left:none;border-top:none}.agora-popover--right .agora-popover__arrow{left:-5px;top:calc(50% - 8px);border-right:none;border-top:none}.agora-popover--left .agora-popover__arrow{right:-5px;top:calc(50% - 8px);border-left:none;border-bottom:none}.agora-tabs{display:flex;flex-direction:column}.agora-tabs__tablist{display:flex;gap:0;border-bottom:1px solid var(--border)}.agora-tabs__tab{position:relative;padding:10px 16px;border:none;background:transparent;color:var(--text-muted);font-family:inherit;font-size:var(--text-sm);font-weight:var(--font-medium);letter-spacing:-.005em;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);outline:none;border-bottom:1px solid transparent;margin-bottom:-1px}.agora-tabs__tab:hover:not(:disabled):not(.agora-tabs__tab--disabled){color:var(--text-primary)}.agora-tabs__tab:focus-visible{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.agora-tabs__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.agora-tabs__tab--disabled{color:var(--text-muted);opacity:.5;cursor:not-allowed}.agora-tabs__panel{padding:16px 0;outline:none}.agora-toggle{display:inline-flex;align-items:center;gap:8px}.agora-toggle__switch{position:relative;width:40px;height:22px;border:none;border-radius:11px;background:var(--border);cursor:pointer;padding:0;outline:none;transition:background-color .2s ease;flex-shrink:0}.agora-toggle__switch:focus-visible{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent)}.agora-toggle--on .agora-toggle__switch{background:var(--accent)}.agora-toggle__thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.agora-toggle--on .agora-toggle__thumb{transform:translate(18px)}.agora-toggle--disabled .agora-toggle__switch{opacity:.5;cursor:not-allowed}.agora-toggle__label{font-size:var(--text-md);color:var(--text-primary);-webkit-user-select:none;user-select:none}.agora-toggle--disabled .agora-toggle__label{opacity:.5}.agora-chip{display:inline-flex;align-items:center;gap:4px;border:none;border-radius:999px;font-family:inherit;font-weight:var(--font-semibold);white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.agora-chip--sm{height:22px;padding:0 8px;font-size:var(--text-2xs)}.agora-chip--md{height:28px;padding:0 10px;font-size:var(--text-sm)}.agora-chip--default{background:var(--bg-hover);color:var(--text-primary)}.agora-chip--primary{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.agora-chip--success{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.agora-chip--warning{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.agora-chip--danger{background:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger)}.agora-chip--clickable{cursor:pointer}.agora-chip--clickable:hover{opacity:.8}.agora-chip--disabled{opacity:.5;cursor:default}.agora-chip__label{line-height:1}.agora-chip__remove{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:inherit;cursor:pointer;padding:0;margin-left:2px;font-size:14px;line-height:1;opacity:.7;transition:opacity var(--transition-fast)}.agora-chip__remove:hover{opacity:1}.agora-color-picker{display:inline-block;position:relative}.agora-color-picker--disabled{opacity:.5;pointer-events:none}.agora-color-picker__trigger{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:3px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-input);cursor:pointer;transition:border-color var(--transition-fast)}.agora-color-picker__trigger:hover:not(:disabled){border-color:var(--border)}.agora-color-picker__trigger:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}.agora-color-picker__swatch{display:block;width:100%;height:100%;border-radius:2px}.agora-color-picker__swatch--none{background:repeating-conic-gradient(#ccc 0% 25%,#fff 0% 50%) 50% / 8px 8px}.agora-color-picker__panel{display:flex;flex-direction:column;gap:8px;width:220px}.agora-color-picker__no-color{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-family:inherit;font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-fast)}.agora-color-picker__no-color:hover{background:var(--bg-hover)}.agora-color-picker__no-color--active{border-color:var(--accent);color:var(--accent)}.agora-color-picker__no-color-icon{width:16px;height:16px;border-radius:2px;background:repeating-conic-gradient(#ccc 0% 25%,#fff 0% 50%) 50% / 6px 6px;position:relative}.agora-color-picker__no-color-icon:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 45%,var(--danger) 45%,var(--danger) 55%,transparent 55%);border-radius:2px}.agora-color-picker__presets{display:grid;grid-template-columns:repeat(8,1fr);gap:3px}.agora-color-picker__preset{width:22px;height:22px;border:1px solid rgba(0,0,0,.1);border-radius:3px;padding:0;cursor:pointer;transition:transform 80ms}.agora-color-picker__preset:hover{transform:scale(1.1);z-index:1}.agora-color-picker__preset--selected{outline:2px solid var(--accent);outline-offset:1px}.agora-color-picker__hex-row{display:flex;align-items:center;gap:4px}.agora-color-picker__hex-hash{color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-semibold)}.agora-color-picker__hex-input{flex:1;padding:4px 8px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-family:monospace;font-size:var(--text-sm);outline:none}.agora-color-picker__hex-input:focus{border-color:var(--accent)}.agora-color-picker__slider-row{display:flex;align-items:center;gap:6px}.agora-color-picker__slider-label{font-size:var(--text-2xs);color:var(--text-muted);min-width:42px}.agora-color-picker__slider{flex:1;height:4px;accent-color:var(--accent)}.agora-color-picker__slider-value{font-size:var(--text-2xs);color:var(--text-muted);min-width:32px;text-align:right}.agora-color-picker__advanced{border-top:1px solid var(--border-subtle);padding-top:6px}.agora-color-picker__advanced-toggle{font-size:var(--text-2xs);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:4px}.agora-color-picker__section-label{font-size:var(--text-2xs);color:var(--text-muted);display:block;margin-bottom:4px}.agora-color-picker__recent{border-top:1px solid var(--border-subtle);padding-top:6px}.agora-color-picker__recent-grid{display:flex;gap:3px;flex-wrap:wrap}.agora-toolbar{display:flex;align-items:center;gap:0;flex-wrap:nowrap;overflow:hidden;position:relative}.agora-toolbar__group{display:flex;align-items:center;gap:2px;flex-shrink:0}.agora-toolbar__separator{width:1px;height:20px;background:var(--border);margin:0 6px;flex-shrink:0}.agora-toolbar__btn-wrap{position:relative;display:inline-flex}.agora-toolbar__btn{display:inline-flex;align-items:center;gap:4px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-family:inherit;font-size:var(--text-sm);padding:4px 8px;cursor:pointer;transition:background-color var(--transition-fast);white-space:nowrap}.agora-toolbar__btn:hover:not(:disabled){background:var(--bg-hover)}.agora-toolbar__btn--active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.agora-toolbar__btn--icon-only{padding:4px 6px}.agora-toolbar__btn:disabled{opacity:.4;cursor:not-allowed}.agora-toolbar__btn-icon{display:flex;align-items:center;font-size:1rem}.agora-toolbar__btn-label{font-weight:var(--font-semibold)}.agora-toolbar__btn-chevron{font-size:10px;color:var(--text-muted);margin-left:2px}.agora-toolbar__dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:50;min-width:120px;padding:4px}.agora-toolbar__overflow{position:relative;flex-shrink:0;margin-left:auto}.agora-toolbar__overflow-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:var(--text-lg);cursor:pointer;transition:background-color var(--transition-fast)}.agora-toolbar__overflow-btn:hover{background:var(--bg-hover)}.agora-toolbar__overflow-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:50;padding:8px;display:flex;flex-direction:column;gap:4px}.agora-slider{display:flex;flex-direction:column;gap:4px;width:100%;-webkit-user-select:none;user-select:none}.agora-slider--disabled{opacity:.5;pointer-events:none}.agora-slider__labels{display:flex;justify-content:space-between;font-size:var(--text-2xs);color:var(--text-muted)}.agora-slider__track{position:relative;height:6px;background:var(--border);border-radius:3px;cursor:pointer}.agora-slider__fill{position:absolute;top:0;height:100%;background:var(--accent);border-radius:3px;pointer-events:none}.agora-slider__thumb{position:absolute;top:50%;width:16px;height:16px;margin-left:-8px;margin-top:-8px;border-radius:50%;background:#fff;border:2px solid var(--accent);cursor:grab;outline:none;transition:box-shadow .12s;touch-action:none}.agora-slider__thumb:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 30%,transparent)}.agora-slider__thumb--active{cursor:grabbing;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 30%,transparent)}.agora-slider__tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:2px 6px;background:var(--bg-elevated, #333);color:#fff;font-size:var(--text-2xs);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none}.agora-ctx-menu{z-index:2000;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:4px 0;min-width:180px;outline:none;animation:agora-ctx-menu-in .15s ease-out;transform-origin:top left}@keyframes agora-ctx-menu-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.agora-ctx-menu__item{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:background-color 60ms;-webkit-user-select:none;user-select:none}.agora-ctx-menu__item--highlighted{background:var(--bg-hover)}.agora-ctx-menu__item--disabled{opacity:.4;cursor:not-allowed}.agora-ctx-menu__item--danger{color:var(--danger)}.agora-ctx-menu__item--danger.agora-ctx-menu__item--highlighted{background:color-mix(in srgb,var(--danger) 10%,transparent)}.agora-ctx-menu__check{width:16px;text-align:center;font-size:12px;flex-shrink:0}.agora-ctx-menu__icon{display:flex;align-items:center;width:16px;font-size:1rem;flex-shrink:0}.agora-ctx-menu__label{flex:1}.agora-ctx-menu__shortcut{margin-left:auto;padding-left:24px;font-size:var(--text-2xs);color:var(--text-muted)}.agora-ctx-menu__submenu-arrow{margin-left:auto;color:var(--text-muted);font-size:14px}.agora-ctx-menu__separator{height:1px;background:var(--border);margin:4px 0}.agora-cmd-palette__overlay{position:fixed;inset:0;z-index:3000;display:flex;justify-content:center;padding-top:15vh;background:var(--bg-overlay, rgba(0, 0, 0, .4));animation:agora-cmd-fade-in .12s ease}@keyframes agora-cmd-fade-in{0%{opacity:0}to{opacity:1}}.agora-cmd-palette{width:560px;max-width:90vw;max-height:60vh;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:agora-cmd-scale-in .15s ease-out;transform-origin:center top;align-self:flex-start}@keyframes agora-cmd-scale-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.agora-cmd-palette__search{padding:16px 20px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.agora-cmd-palette__input{width:100%;padding:4px 0;border:none;background:transparent;color:var(--text-primary);font-family:inherit;font-size:var(--text-lg);outline:none;letter-spacing:-.01em}.agora-cmd-palette__input::placeholder{color:var(--text-muted)}.agora-cmd-palette__results{overflow-y:auto;padding:4px 0;flex:1}.agora-cmd-palette__group-label{padding:6px 16px 4px;font-size:var(--text-2xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.agora-cmd-palette__item{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;transition:background-color 60ms}.agora-cmd-palette__item--highlighted{background:var(--bg-hover)}.agora-cmd-palette__item-icon{display:flex;align-items:center;width:20px;font-size:1rem;color:var(--text-muted);flex-shrink:0}.agora-cmd-palette__item-label{font-size:var(--text-md);color:var(--text-primary)}.agora-cmd-palette__item-desc{font-size:var(--text-sm);color:var(--text-muted);margin-left:4px}.agora-cmd-palette__item-shortcut{margin-left:auto;display:inline-flex;align-items:center;gap:2px}.agora-cmd-palette__kbd{font-size:var(--text-2xs);color:var(--text-muted);padding:1px 5px;background:var(--bg-hover);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;line-height:1.4;min-width:20px;text-align:center;box-shadow:0 1px 0 var(--border-subtle)}.agora-cmd-palette__empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:var(--text-md)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #111113;--bg-secondary: #18191c;--bg-tertiary: #202124;--bg-input: #1e1f22;--bg-hover: #232528;--bg-active: #2b2d31;--bg-overlay: rgba(0, 0, 0, .64);--text-primary: #e4e4e8;--text-secondary: #9a9aa4;--text-muted: #5c5c68;--text-link: #8892e4;--accent: #636de0;--accent-hover: #565fcc;--accent-active: #4a52b5;--success: #3d9960;--warning: #c09a3e;--danger: #c24c50;--border: #262830;--border-subtle: #1e2028;--sidebar-width: 240px;--header-height: 52px;--rail-width: 52px;--top-bar-height: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", "Courier New", monospace;--transition-fast: .15s ease-out;--transition-normal: .2s ease-out;--bg-surface: var(--bg-secondary);--bg-muted: var(--bg-tertiary);--border-color: var(--border);--border-light: var(--border-subtle);--accent-color: var(--accent);--accent-bg: color-mix(in srgb, var(--accent) 10%, transparent);--hover-bg: var(--bg-hover);--active-bg: var(--bg-active);--text-tertiary: var(--text-muted);--error-color: var(--danger);--error-bg: color-mix(in srgb, var(--danger) 10%, transparent);--warning-color: var(--warning);--bg-inverted: #2a2a2e;--text-inverted: #f0f0f2;--text-inverted-secondary: #a0a0a6;--accent-light: #7880e8;--bg-tooltip: #1a1a1e;--text-tooltip: #e8e8ec;--text-2xs: .6875rem;--text-xs: .75rem;--text-sm: .8125rem;--text-md: .875rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 1.75;--z-sticky: 10;--z-float: 50;--z-dropdown: 100;--z-overlay: 999;--z-modal: 1000;--z-toast: 9998;--z-tooltip: 10000;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .24);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .28);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .32);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;font-family:var(--font-sans);font-size:1rem;line-height:var(--leading-relaxed);font-weight:var(--font-normal);letter-spacing:-.011em;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--bg-primary: #111113;--bg-secondary: #18191c;--bg-tertiary: #202124;--bg-input: #1e1f22;--bg-hover: #232528;--bg-active: #2b2d31;--bg-overlay: rgba(0, 0, 0, .64);--text-primary: #e4e4e8;--text-secondary: #9a9aa4;--text-muted: #5c5c68;--text-link: #8892e4;--accent: #636de0;--accent-hover: #565fcc;--accent-active: #4a52b5;--success: #3d9960;--warning: #c09a3e;--danger: #c24c50;--border: #262830;--border-subtle: #1e2028;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .24);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .28);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .32);--bg-surface: var(--bg-secondary);--bg-muted: var(--bg-tertiary);--border-color: var(--border);--border-light: var(--border-subtle);--accent-color: var(--accent);--accent-bg: color-mix(in srgb, var(--accent) 10%, transparent);--hover-bg: var(--bg-hover);--active-bg: var(--bg-active);--text-tertiary: var(--text-muted);--error-color: var(--danger);--error-bg: color-mix(in srgb, var(--danger) 10%, transparent);--warning-color: var(--warning);--bg-inverted: #2a2a2e;--text-inverted: #f0f0f2;--text-inverted-secondary: #a0a0a6;--accent-light: #7880e8;--bg-tooltip: #1a1a1e;--text-tooltip: #e8e8ec}[data-theme=light]{--bg-primary: #faf9f7;--bg-secondary: #f2f1ee;--bg-tertiary: #e8e7e3;--bg-input: #eae9e5;--bg-hover: #edece8;--bg-active: #e0dfda;--bg-overlay: rgba(0, 0, 0, .36);--text-primary: #1a1a1e;--text-secondary: #58585e;--text-muted: #8a8a92;--text-link: #4a55c4;--accent: #4a55c4;--accent-hover: #3f49b0;--accent-active: #36409c;--success: #2d8049;--warning: #a88530;--danger: #b5423e;--border: #dddbd6;--border-subtle: #e8e7e3;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .1);--bg-surface: var(--bg-secondary);--bg-muted: var(--bg-tertiary);--border-color: var(--border);--border-light: var(--border-subtle);--accent-color: var(--accent);--accent-bg: color-mix(in srgb, var(--accent) 8%, transparent);--hover-bg: var(--bg-hover);--active-bg: var(--bg-active);--text-tertiary: var(--text-muted);--error-color: var(--danger);--error-bg: color-mix(in srgb, var(--danger) 8%, transparent);--warning-color: var(--warning);--bg-inverted: #2a2a2e;--text-inverted: #f0f0f2;--text-inverted-secondary: #a0a0a6;--accent-light: #7880e8;--bg-tooltip: #1a1a1e;--text-tooltip: #e8e8ec}@media(prefers-color-scheme:light){:root:not([data-theme]){--bg-primary: #faf9f7;--bg-secondary: #f2f1ee;--bg-tertiary: #e8e7e3;--bg-input: #eae9e5;--bg-hover: #edece8;--bg-active: #e0dfda;--bg-overlay: rgba(0, 0, 0, .36);--text-primary: #1a1a1e;--text-secondary: #58585e;--text-muted: #8a8a92;--text-link: #4a55c4;--accent: #4a55c4;--accent-hover: #3f49b0;--accent-active: #36409c;--success: #2d8049;--warning: #a88530;--danger: #b5423e;--border: #dddbd6;--border-subtle: #e8e7e3;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .1);--bg-surface: var(--bg-secondary);--bg-muted: var(--bg-tertiary);--border-color: var(--border);--border-light: var(--border-subtle);--accent-color: var(--accent);--accent-bg: color-mix(in srgb, var(--accent) 8%, transparent);--hover-bg: var(--bg-hover);--active-bg: var(--bg-active);--text-tertiary: var(--text-muted);--error-color: var(--danger);--error-bg: color-mix(in srgb, var(--danger) 8%, transparent);--warning-color: var(--warning);--bg-inverted: #2a2a2e;--text-inverted: #f0f0f2;--text-inverted-secondary: #a0a0a6;--accent-light: #7880e8;--bg-tooltip: #1a1a1e;--text-tooltip: #e8e8ec}}html,body,#root{height:100%;width:100%;overflow:hidden}a{color:var(--text-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit;letter-spacing:inherit}input,textarea{font-family:inherit;font-size:inherit;letter-spacing:inherit;color:var(--text-primary);background-color:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 12px;outline:none;transition:border-color var(--transition-fast)}input:focus,textarea:focus{border-color:var(--border)}input::placeholder,textarea::placeholder{color:var(--text-muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}*{scrollbar-width:thin;scrollbar-color:var(--bg-active) transparent}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--bg-active);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}@keyframes shimmer{0%{opacity:.5}50%{opacity:.8}to{opacity:.5}}.user-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:#fff;font-weight:var(--font-semibold);line-height:var(--leading-none);flex-shrink:0;-webkit-user-select:none;user-select:none;overflow:hidden}.user-avatar__img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.user-avatar--xs{width:20px;height:20px;font-size:.625rem}.user-avatar--sm{width:24px;height:24px;font-size:var(--text-xs)}.user-avatar--md{width:32px;height:32px;font-size:var(--text-sm)}.user-avatar--lg{width:36px;height:36px;font-size:var(--text-md)}.user-avatar--xl{width:48px;height:48px;font-size:var(--text-lg)}.tooltip-trigger{display:inline-flex}.tooltip{position:fixed;z-index:var(--z-tooltip);max-width:240px;padding:5px 10px;border-radius:var(--radius-md);background-color:var(--bg-tooltip);color:var(--text-tooltip);font-size:var(--text-2xs);font-weight:var(--font-medium);line-height:var(--leading-normal);white-space:nowrap;pointer-events:none;animation:tooltip-fade-in .15s ease-out}@keyframes tooltip-fade-in{0%{opacity:0}to{opacity:1}}.tooltip:after{content:"";position:absolute;border:4px solid transparent}.tooltip--top:after{top:100%;left:50%;transform:translate(-50%);border-top-color:var(--bg-tooltip)}.tooltip--bottom:after{bottom:100%;left:50%;transform:translate(-50%);border-bottom-color:var(--bg-tooltip)}.tooltip--left:after{left:100%;top:50%;transform:translateY(-50%);border-left-color:var(--bg-tooltip)}.tooltip--right:after{right:100%;top:50%;transform:translateY(-50%);border-right-color:var(--bg-tooltip)}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:130;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;box-shadow:var(--shadow-md);font-size:var(--text-md);pointer-events:auto;animation:toast-slide-up .25s ease-out;min-width:280px;max-width:480px}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.toast--info{background:var(--bg-primary);color:#fff}.toast--success{background:#16a34a;color:#fff}.toast--error{background:#dc2626;color:#fff}.toast__message{flex:1}.toast__action{background:none;border:none;color:inherit;cursor:pointer;font-weight:600;font-size:var(--text-sm);text-decoration:underline;padding:2px 4px;white-space:nowrap}.toast__action:hover{opacity:.8}.toast__close{background:none;border:none;color:inherit;cursor:pointer;opacity:.7;padding:2px;display:flex;align-items:center}.toast__close:hover{opacity:1}.poll-card{background-color:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 16px;max-width:420px;margin-top:4px}.poll-card--error{color:var(--text-muted);font-style:italic;font-size:var(--text-sm)}.poll-card__header{display:flex;align-items:flex-start;gap:8px;margin-bottom:12px}.poll-card__icon{font-size:var(--text-lg);flex-shrink:0;line-height:var(--leading-none);margin-top:2px}.poll-card__question{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);line-height:var(--leading-snug)}.poll-card__options{display:flex;flex-direction:column;gap:6px}.poll-card__option{position:relative;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s ease,background-color .15s ease;font-family:inherit;font-size:var(--text-md);color:var(--text-primary);text-align:left;overflow:hidden}.poll-card__option:hover:not(:disabled){border-color:var(--accent);background-color:var(--bg-hover)}.poll-card__option--voted{cursor:pointer}.poll-card__option--voted:disabled{cursor:default}.poll-card__option--mine{border-color:var(--accent);border-width:2px;padding:7px 11px}.poll-card__bar{position:absolute;top:0;left:0;bottom:0;background-color:var(--accent);opacity:.15;border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:width .3s ease}.poll-card__option-text{position:relative;z-index:1;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poll-card__option-pct{position:relative;z-index:1;flex-shrink:0;font-size:var(--text-2xs);font-weight:var(--font-semibold);color:var(--text-muted);min-width:32px;text-align:right}.poll-card__option-radio{width:16px;height:16px;border:2px solid var(--text-muted);border-radius:50%;flex-shrink:0;transition:border-color .15s ease}.poll-card__option:hover:not(:disabled) .poll-card__option-radio{border-color:var(--accent)}.poll-card__footer{margin-top:8px;display:flex;align-items:center}.poll-card__total{font-size:var(--text-2xs);color:var(--text-muted)}.poll-card__option-group{display:flex;flex-direction:column;gap:2px}.poll-card__voter-names{font-size:var(--text-2xs);color:var(--text-muted);padding-left:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poll-card__close-btn{margin-left:auto;font-size:var(--text-2xs);font-weight:var(--font-semibold);color:var(--text-muted);background:none;border:none;cursor:pointer;padding:2px 8px;border-radius:var(--radius-sm);transition:color .15s ease,background-color .15s ease}.poll-card__close-btn:hover:not(:disabled){color:var(--danger);background-color:#da373c1a}.poll-card__close-btn:disabled{opacity:.6;cursor:not-allowed}.poll-card--closed{opacity:.85}.poll-card__closed-badge{flex-shrink:0;font-size:var(--text-2xs);font-weight:var(--font-semibold);color:var(--text-muted);background-color:var(--bg-hover);padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.04em}.gif-message{max-width:300px}.gif-message__container{position:relative;border-radius:var(--radius-md);overflow:hidden;background-color:var(--bg-hover);min-height:80px}.gif-message__container--loaded{min-height:unset}.gif-message__img{display:block;width:100%;height:auto;border-radius:var(--radius-md)}.gif-message__img--paused{animation-play-state:paused}.gif-message__badge{position:absolute;top:8px;left:8px;padding:2px 6px;font-size:.625rem;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.04em;color:#fff;background-color:var(--bg-overlay);border-radius:var(--radius-sm);pointer-events:none}.gif-message__play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#00000059;border:none;cursor:pointer;border-radius:var(--radius-md);transition:background-color .15s ease}.gif-message__play-overlay:hover{background-color:var(--bg-overlay)}.gif-message__play-icon{font-size:2rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.gif-message__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--text-sm)}.gif-message__fallback{color:var(--accent);font-size:var(--text-md);word-break:break-all}.quoted-block{display:flex;align-items:stretch;gap:0;max-width:460px;margin-bottom:4px;padding:0;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;border-radius:var(--radius-sm);overflow:hidden;transition:background-color var(--transition-fast)}.quoted-block:hover{background-color:var(--bg-hover)}.quoted-block__bar{width:3px;flex-shrink:0;background-color:var(--accent);border-radius:3px}.quoted-block__body{display:flex;flex-direction:column;gap:1px;padding:4px 10px;min-width:0}.quoted-block__author{font-size:var(--text-xs, 11px);font-weight:var(--font-semibold, 600);color:var(--accent);line-height:1.2}.quoted-block__text{font-size:var(--text-2xs, 12px);color:var(--text-muted);line-height:var(--leading-snug, 1.3);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.message-bubble--own .quoted-block{margin-left:auto}.reminder-picker{position:fixed;z-index:var(--z-modal);width:280px;background-color:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:reminder-picker-in .15s ease;overflow:hidden}@keyframes reminder-picker-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.reminder-picker__header{display:flex;align-items:center;gap:8px;padding:12px 16px 8px;font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-primary)}.reminder-picker__options{display:flex;flex-direction:column}.reminder-picker__option{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background-color var(--transition-fast)}.reminder-picker__option:hover{background-color:var(--bg-hover)}.reminder-picker__option-label{font-size:var(--text-sm);color:var(--text-primary)}.reminder-picker__option-desc{font-size:var(--text-2xs);color:var(--text-muted)}.reminder-picker__divider{height:1px;background-color:var(--border-subtle);margin:4px 0}.reminder-picker__custom-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 16px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:var(--text-sm);color:var(--accent);transition:background-color var(--transition-fast)}.reminder-picker__custom-toggle:hover{background-color:var(--bg-hover)}.reminder-picker__custom{padding:8px 16px 12px;display:flex;flex-direction:column;gap:8px}.reminder-picker__custom-row{display:flex;align-items:center;gap:8px}.reminder-picker__custom-label{font-size:var(--text-2xs);font-weight:var(--font-semibold);color:var(--text-muted);width:36px;flex-shrink:0}.reminder-picker__custom-input{flex:1;padding:6px 8px;font-size:var(--text-sm);font-family:inherit;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background-color:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.reminder-picker__custom-input:focus{border-color:var(--accent)}.reminder-picker__remind-btn{margin-top:4px;padding:8px 12px;font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:inherit;background-color:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.reminder-picker__remind-btn:hover:not(:disabled){background-color:var(--accent-hover)}.reminder-picker__remind-btn:disabled{opacity:.5;cursor:not-allowed}.message-bubble{display:flex;gap:12px;padding:6px 24px;position:relative;transition:background-color var(--transition-fast)}.message-bubble:hover{background-color:var(--bg-hover)}.message-bubble__avatar-btn{all:unset;cursor:pointer;border-radius:var(--radius-full);flex-shrink:0}.message-bubble__avatar-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.message-bubble__avatar{margin-top:2px}.message-bubble--grouped{padding-top:2px;padding-bottom:2px}.message-bubble__gutter{width:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.message-bubble__hover-timestamp{font-size:var(--text-2xs);color:var(--text-muted);opacity:0;transition:opacity var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.message-bubble:hover .message-bubble__hover-timestamp{opacity:1}.message-bubble__body{flex:0 1 auto;min-width:0;position:relative}.message-bubble__header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-bubble__author{all:unset;font-size:var(--text-md);font-weight:var(--font-medium);cursor:pointer}.message-bubble__author:hover{text-decoration:underline}.message-bubble__timestamp{font-size:var(--text-2xs);color:var(--text-muted)}.message-bubble__edited{font-size:var(--text-2xs);color:var(--text-muted);font-style:italic}.message-bubble__content{font-size:var(--text-base);color:var(--text-primary);line-height:var(--leading-normal);white-space:pre-wrap;word-break:break-word}.message-bubble__meta{display:flex;justify-content:flex-end;align-items:center;gap:4px;margin-top:2px;font-size:var(--text-2xs);color:var(--text-muted);line-height:1}.message-bubble__meta-icon{flex-shrink:0;color:var(--text-muted)}.message-bubble__meta-icon--read{color:var(--accent)}.message-bubble__meta-icon--sending{animation:meta-status-pulse 1.4s ease-in-out infinite}@keyframes meta-status-pulse{0%,to{opacity:1}50%{opacity:.35}}.message-bubble__actions{position:absolute;top:0;right:0;transform:translateY(-100%);gap:2px;background-color:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:2px;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);display:flex}.message-bubble:hover .message-bubble__actions,.message-bubble:focus-within .message-bubble__actions{opacity:1;pointer-events:auto}.message-bubble__action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:var(--text-md);color:var(--text-muted);transition:background-color var(--transition-fast),color var(--transition-fast);cursor:pointer}.message-bubble__action-btn:hover{background-color:var(--bg-hover);color:var(--text-secondary)}.message-bubble__action-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.message-bubble__action-btn--active{color:var(--accent)}.message-bubble__action-btn--delete:hover{color:var(--danger)}.message-bubble__action-picker-wrapper,.message-bubble__overflow-wrapper{position:relative}.message-bubble__overflow-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:140px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;box-shadow:var(--shadow-md);z-index:var(--z-float);display:flex;flex-direction:column}.message-bubble__overflow-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.message-bubble__overflow-item:hover,.message-bubble__overflow-item:focus-visible{background-color:var(--bg-hover);color:var(--text-primary)}.message-bubble__overflow-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.message-bubble__overflow-item--active{color:var(--accent)}.message-bubble__overflow-item--danger:hover{color:var(--danger)}.message-bubble__edit-form{margin-top:8px}.message-bubble__edit-input{width:100%;padding:10px 14px;font-size:var(--text-base);line-height:var(--leading-normal);resize:vertical;background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.message-bubble__edit-actions{display:flex;gap:8px;margin-top:8px}.message-bubble__edit-btn{font-size:var(--text-xs);font-weight:var(--font-medium);padding:4px 12px;border-radius:var(--radius-sm);cursor:pointer}.message-bubble__edit-btn--cancel{color:var(--text-muted)}.message-bubble__edit-btn--cancel:hover{color:var(--text-secondary)}.message-bubble__edit-btn--save{color:#fff;background-color:var(--accent)}.message-bubble__edit-btn--save:hover{background-color:var(--accent-hover)}.message-bubble__delete-confirm{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:var(--text-sm);color:var(--text-secondary)}.message-bubble__delete-btn{font-size:var(--text-xs);font-weight:var(--font-medium);padding:4px 12px;border-radius:var(--radius-sm);cursor:pointer}.message-bubble__delete-btn--yes{color:#fff;background-color:var(--danger)}.message-bubble__delete-btn--yes:hover{opacity:.9}.message-bubble__delete-btn--no{color:var(--text-muted)}.message-bubble__delete-btn--no:hover{color:var(--text-secondary)}.message-bubble__error{font-size:var(--text-2xs);color:var(--danger);margin-top:4px}.message-bubble--highlighted{animation:message-highlight-flash 2s ease-out}@keyframes message-highlight-flash{0%{background-color:color-mix(in srgb,var(--warning) 16%,transparent)}to{background-color:transparent}}.message-bubble--own{flex-direction:row-reverse}.message-bubble--own .message-bubble__body{text-align:right}.message-bubble--own .message-bubble__header{justify-content:flex-end}.message-bubble--own .message-bubble__content{background-color:var(--accent-bg);padding:8px 12px;border-radius:var(--radius-md);display:inline-block;text-align:left}.message-bubble--own .message-bubble__actions{right:auto;left:0}.message-bubble--entering{animation:message-enter .2s ease-out}@keyframes message-enter{0%{opacity:0}to{opacity:1}}.user-profile-card{position:fixed;z-index:var(--z-modal);width:280px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px;animation:user-profile-card-fade-in .15s ease-out}@keyframes user-profile-card-fade-in{0%{opacity:0}to{opacity:1}}.user-profile-card__loading,.user-profile-card__error{font-size:var(--text-sm);color:var(--text-muted);margin:0;text-align:center;padding:8px 0}.user-profile-card__header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.user-profile-card__names{display:flex;flex-direction:column;min-width:0}.user-profile-card__display-name{font-size:var(--text-base);font-weight:var(--font-semibold);letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-profile-card__username{font-size:var(--text-2xs);color:var(--text-muted)}.user-profile-card__pronouns{font-size:var(--text-xs);color:var(--text-secondary);margin-top:1px}.user-profile-card__presence{display:flex;align-items:center;gap:6px;margin-bottom:8px}.user-profile-card__presence-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium, 500)}.user-profile-card__status{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 8px;padding:6px 8px;background:var(--bg-hover);border-radius:var(--radius-sm)}.user-profile-card__bio{font-size:var(--text-sm);color:var(--text-primary);margin:0 0 12px;line-height:var(--leading-normal)}.user-profile-card__actions{display:flex;gap:8px;border-top:1px solid var(--border-subtle);padding-top:12px}.user-profile-card__action-btn{flex:1;padding:7px 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);font-family:inherit;cursor:pointer;text-align:center;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.user-profile-card__action-btn:hover{background:var(--bg-hover)}.user-profile-card__action-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.user-profile-card__action-btn--primary:hover{background:var(--accent-hover, var(--accent));border-color:var(--accent-hover, var(--accent))}.global-top-bar{grid-area:topbar;display:flex;align-items:center;gap:16px;padding:0 16px;height:var(--top-bar-height, 48px);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0;z-index:var(--z-sticky)}.global-top-bar__brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.global-top-bar__logo{display:block}.global-top-bar__brand-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.02em}.global-top-bar__search{display:flex;align-items:center;gap:8px;flex:1;max-width:480px;margin:0 auto;height:32px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background-color:transparent;color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.global-top-bar__search:hover{border-color:var(--border);color:var(--text-secondary)}.global-top-bar__search:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.global-top-bar__search-text{flex:1;text-align:left;pointer-events:none}.global-top-bar__search-kbd{font-family:inherit;font-size:var(--text-2xs);color:var(--text-muted);background-color:var(--bg-tertiary);padding:1px 5px;border-radius:3px;border:1px solid var(--border-subtle);line-height:var(--leading-normal);pointer-events:none}.global-top-bar__actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.global-top-bar__btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);font-size:var(--text-lg);line-height:var(--leading-none);transition:background-color var(--transition-fast),color var(--transition-fast)}.global-top-bar__btn:hover{background-color:var(--bg-hover);color:var(--text-secondary)}.global-top-bar__btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.global-top-bar__badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--danger);color:#fff;font-size:var(--text-2xs);font-weight:var(--font-semibold);line-height:16px;text-align:center;pointer-events:none}.global-top-bar__avatar-btn{display:flex;align-items:center;justify-content:center;padding:0;margin-left:4px;cursor:pointer;border-radius:var(--radius-full);transition:opacity var(--transition-fast)}.global-top-bar__avatar-btn:hover{opacity:.85}.global-top-bar__avatar-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-rail{grid-area:rail;display:flex;flex-direction:column;width:var(--rail-width, 52px);background-color:var(--bg-primary);border-right:1px solid var(--border-subtle);overflow:hidden;flex-shrink:0}.app-rail__main{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;overflow-y:auto}.app-rail__bottom{display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;border-top:1px solid var(--border-subtle)}.app-rail__item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);transition:background-color var(--transition-fast),color var(--transition-fast)}.app-rail__item:hover{background-color:var(--bg-hover);color:var(--text-secondary)}.app-rail__item--active{background-color:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.app-rail__item--active:hover{background-color:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.app-rail__item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.app-rail__item--active:focus-visible{outline-color:var(--accent)}.app-rail__icon{display:flex;align-items:center;justify-content:center;line-height:0}.app-rail__icon svg{stroke-width:1.5;transition:color var(--transition-fast)}.app-rail__label{font-size:.5625rem;font-weight:var(--font-medium);line-height:var(--leading-none);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:44px;text-align:center}.app-rail__badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background-color:var(--danger);color:#fff;font-size:.625rem;font-weight:var(--font-semibold);line-height:16px;text-align:center;pointer-events:none;animation:app-rail-badge-in .2s ease-out}@keyframes app-rail-badge-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.app-sidebar{grid-area:sidebar;position:relative;display:flex;flex-direction:column;background-color:var(--bg-secondary);border-right:1px solid var(--border-subtle);overflow:hidden;flex-shrink:0;transition:width .2s ease-out,border-color .2s ease-out}.app-sidebar--resizing{transition:none}.app-sidebar--collapsed{border-color:transparent}.app-sidebar__content{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.app-sidebar__loading{flex:1}.app-sidebar__resize-handle{position:absolute;top:0;right:-2px;width:4px;height:100%;cursor:col-resize;z-index:var(--z-sticky);transition:background-color var(--transition-fast)}.app-sidebar__resize-handle:hover,.app-sidebar__resize-handle:active{background-color:var(--accent)}.app-sidebar__resize-handle:focus-visible{background-color:var(--accent);outline:none}.app-layout{display:grid;grid-template-rows:var(--top-bar-height, 48px) 1fr;grid-template-columns:var(--rail-width, 52px) auto 1fr;grid-template-areas:"topbar  topbar   topbar" "rail    sidebar  content";height:100%;width:100%;overflow:hidden}.skip-to-content{position:absolute;left:-9999px;z-index:var(--z-overlay);padding:8px 16px;background:var(--accent);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-md);border-radius:var(--radius-md);text-decoration:none}.skip-to-content:focus{left:8px;top:8px}.app-layout__content-area{grid-area:content;display:flex;min-width:0;min-height:0;overflow:hidden}.app-layout__content{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;background-color:var(--bg-tertiary);animation:content-fade-in .18s ease-out}@keyframes content-fade-in{0%{opacity:0}to{opacity:1}}.login-page{display:flex;align-items:center;justify-content:center;height:100%;width:100%;background-color:var(--bg-primary)}.login-card{width:100%;max-width:400px;padding:48px 40px;background-color:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.login-card__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);text-align:center;letter-spacing:-.025em;margin-bottom:8px}.login-card__subtitle{font-size:var(--text-sm);color:var(--text-muted);text-align:center;line-height:var(--leading-relaxed);margin-bottom:32px}.login-card__form{display:flex;flex-direction:column;gap:20px}.login-card__field{display:flex;flex-direction:column;gap:8px}.login-card__label{font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.login-card__label--error{color:var(--danger)}.login-card__input{width:100%;padding:12px 14px;font-size:var(--text-md)}.login-card__error{font-size:var(--text-sm);color:var(--danger);text-align:center;padding:10px 16px;background-color:color-mix(in srgb,var(--danger) 8%,transparent);border-radius:var(--radius-md)}.login-card__submit{width:100%;padding:12px;margin-top:4px;font-size:var(--text-md);font-weight:var(--font-medium);letter-spacing:-.01em;color:#fff;background-color:var(--accent);border-radius:var(--radius-md);transition:background-color var(--transition-fast),opacity var(--transition-fast)}.login-card__submit:hover{background-color:var(--accent-hover)}.login-card__submit:active{background-color:var(--accent-active)}.login-card__submit:disabled{opacity:.5;cursor:not-allowed}.login-card__footer{margin-top:24px;font-size:var(--text-sm);color:var(--text-muted);text-align:center}.login-card__footer a{color:var(--text-link);font-size:var(--text-sm)}.login-card__success{font-size:var(--text-sm);color:var(--success);text-align:center;padding:10px 16px;background-color:color-mix(in srgb,var(--success) 8%,transparent);border-radius:var(--radius-md)}.login-card__spinner{display:inline-block;width:14px;height:14px;border:1.5px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:login-spinner .7s linear infinite;vertical-align:middle;margin-right:8px}@keyframes login-spinner{to{transform:rotate(360deg)}}.register-page{display:flex;align-items:center;justify-content:center;height:100%;width:100%;background-color:var(--bg-primary)}.register-card{width:100%;max-width:420px;padding:32px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.register-card__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);text-align:center;margin-bottom:24px}.register-card__form{display:flex;flex-direction:column;gap:16px}.register-card__field{display:flex;flex-direction:column;gap:6px}.register-card__label{font-size:var(--text-2xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.register-card__input{width:100%;padding:10px 12px;font-size:var(--text-base)}.register-card__error{font-size:var(--text-sm);color:var(--danger);text-align:center;padding:8px;background-color:#da373c1a;border-radius:var(--radius-sm)}.register-card__submit{width:100%;padding:12px;font-size:var(--text-base);font-weight:var(--font-semibold);color:#fff;background-color:var(--accent);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.register-card__submit:hover{background-color:var(--accent-hover)}.register-card__submit:active{background-color:var(--accent-active)}.register-card__submit:disabled{opacity:.6;cursor:not-allowed}.register-card__footer{margin-top:12px;font-size:var(--text-sm);color:var(--text-muted)}.register-card__footer a{color:var(--text-link);font-size:var(--text-sm)}.register-card__spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:register-spinner .6s linear infinite;vertical-align:middle;margin-right:8px}@keyframes register-spinner{to{transform:rotate(360deg)}}.set-password-page{display:flex;align-items:center;justify-content:center;height:100%;width:100%;background-color:var(--bg-primary)}.set-password-card{width:100%;max-width:420px;padding:32px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.set-password-card__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);text-align:center;margin-bottom:8px}.set-password-card__subtitle{font-size:var(--text-md);color:var(--text-secondary);text-align:center;margin-bottom:24px}.set-password-card__form{display:flex;flex-direction:column;gap:16px}.set-password-card__field{display:flex;flex-direction:column;gap:6px}.set-password-card__label{font-size:var(--text-2xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.set-password-card__input{width:100%;padding:10px 12px;font-size:var(--text-base)}.set-password-card__error{font-size:var(--text-sm);color:var(--danger);text-align:center;padding:8px;background-color:#da373c1a;border-radius:var(--radius-sm)}.set-password-card__success{font-size:var(--text-sm);color:var(--success);text-align:center;padding:8px;background-color:#23a55a1a;border-radius:var(--radius-sm)}.set-password-card__submit{width:100%;padding:12px;font-size:var(--text-base);font-weight:var(--font-semibold);color:#fff;background-color:var(--accent);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.set-password-card__submit:hover{background-color:var(--accent-hover)}.set-password-card__submit:active{background-color:var(--accent-active)}.set-password-card__submit:disabled{opacity:.6;cursor:not-allowed}.set-password-card__footer{margin-top:12px;font-size:var(--text-sm);color:var(--text-muted)}.set-password-card__footer a{color:var(--text-link);font-size:var(--text-sm)}.set-password-card__spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:set-password-spinner .6s linear infinite;vertical-align:middle;margin-right:8px}@keyframes set-password-spinner{to{transform:rotate(360deg)}}.set-password-card__loading{display:flex;justify-content:center;padding:24px 0}.set-password-card__loading .set-password-card__spinner{width:24px;height:24px;border-color:var(--border-subtle);border-top-color:var(--accent)}.set-password-card__strength{display:flex;align-items:center;gap:8px;margin-top:4px}.set-password-card__strength-bar{flex:1;height:4px;border-radius:2px;background-color:var(--border-subtle);position:relative;overflow:hidden}.set-password-card__strength-bar:after{content:"";position:absolute;left:0;top:0;height:100%;border-radius:2px;transition:width .2s ease,background-color .2s ease}.set-password-card__strength-bar--0:after{width:15%;background-color:var(--danger)}.set-password-card__strength-bar--1:after{width:33%;background-color:var(--danger)}.set-password-card__strength-bar--2:after{width:66%;background-color:var(--warning, #f59e0b)}.set-password-card__strength-bar--3:after{width:100%;background-color:var(--success)}.set-password-card__strength-label{font-size:var(--text-xs);color:var(--text-muted);min-width:60px}.search-modal{border:none;border-radius:var(--radius-lg);background-color:var(--bg-secondary);color:var(--text-primary);padding:0;max-width:560px;width:90%;max-height:70vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);overflow:hidden;margin:0 auto;top:var(--top-bar-height, 48px)}.search-modal::backdrop{background-color:transparent}.search-modal__content{display:flex;flex-direction:column;max-height:70vh}.search-modal__header{padding:16px 20px 0;flex-shrink:0}.search-modal__input-wrapper{display:flex;align-items:center;gap:8px;background-color:var(--bg-input);border-radius:var(--radius-md);padding:0 12px}.search-modal__back-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color var(--transition-fast),background-color var(--transition-fast)}.search-modal__back-btn:hover{color:var(--text-primary);background-color:var(--bg-hover)}.search-modal__input{flex:1;padding:10px 0;font-size:var(--text-base);background:none;color:var(--text-primary);border:none;border-radius:0;outline:none}.search-modal__input:focus{box-shadow:none}.search-modal__input::placeholder{color:var(--text-muted)}.search-modal__clear-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:var(--text-2xs);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color var(--transition-fast),background-color var(--transition-fast)}.search-modal__clear-btn:hover{color:var(--text-primary);background-color:var(--bg-hover)}.search-modal__filter-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);cursor:not-allowed;flex-shrink:0;opacity:.4}.search-modal__tabs{display:flex;gap:4px;padding:12px 0 0;border-bottom:1px solid var(--border-subtle);position:sticky;top:0;background-color:var(--bg-secondary);z-index:1}.search-modal__tab{padding:8px 12px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-muted);cursor:pointer;border-bottom:1px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast);border-radius:0;background:none}.search-modal__tab:hover{color:var(--text-primary)}.search-modal__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.search-modal__body{overflow-y:auto;padding:8px 0 16px;flex:1}.search-modal__error{font-size:var(--text-sm);color:var(--danger);text-align:center;padding:12px 16px}.search-modal__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;color:var(--text-muted);font-size:var(--text-md);text-align:center;gap:8px}.search-modal__empty-icon{font-size:2rem;opacity:.5}.search-modal__results{display:flex;flex-direction:column}.search-modal__result{display:flex;gap:10px;padding:10px 16px;cursor:pointer;transition:background-color var(--transition-fast)}.search-modal__result:hover{background-color:var(--bg-hover)}.search-modal__result:focus-visible{background-color:var(--bg-hover);outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius-sm)}.search-modal__result-avatar{width:32px;height:32px;border-radius:var(--radius-full);background-color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-semibold);color:#fff;flex-shrink:0;margin-top:2px}.search-modal__result-body{flex:1;min-width:0}.search-modal__result-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px;flex-wrap:wrap}.search-modal__result-channel{font-size:var(--text-2xs);font-weight:var(--font-medium);color:var(--accent);background-color:var(--accent-bg);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0}.search-modal__result-sender{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.search-modal__result-time{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto;flex-shrink:0}.search-modal__result-content{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.search-modal__result-snippet{word-break:break-word}.search-modal__highlight{background-color:color-mix(in srgb,var(--warning) 20%,transparent);color:var(--text-primary);border-radius:2px;padding:0 2px}.search-modal__email-subject{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.search-modal__file-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;margin-top:2px}.search-modal__file-meta{font-size:var(--text-xs);color:var(--text-muted)}.search-modal__load-more{display:flex;justify-content:center;padding:12px 16px 4px}.search-modal__load-more-btn{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-link);cursor:pointer;padding:6px 16px;border-radius:var(--radius-md);background:none;transition:background-color var(--transition-fast)}.search-modal__load-more-btn:hover:not(:disabled){background-color:var(--bg-hover)}.search-modal__load-more-btn:disabled{opacity:.6;cursor:not-allowed}.search-modal__cap-note{font-size:var(--text-xs);color:var(--text-muted);text-align:center;padding:8px 16px}.search-modal__group{margin-bottom:8px}.search-modal__group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 4px;font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.search-modal__view-all{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-link);cursor:pointer;background:none;text-transform:none;letter-spacing:normal;transition:color var(--transition-fast)}.search-modal__view-all:hover{color:var(--accent)}.search-modal__loading{display:flex;flex-direction:column;padding:8px 0}.search-modal__skeleton{display:flex;gap:10px;padding:10px 16px}.search-modal__skeleton-avatar{width:32px;height:32px;border-radius:var(--radius-full);background-color:var(--bg-active);flex-shrink:0;animation:shimmer 1.5s ease-in-out infinite}.search-modal__skeleton-body{flex:1;display:flex;flex-direction:column;gap:8px;padding-top:4px}.search-modal__skeleton-line{height:12px;border-radius:var(--radius-sm);background-color:var(--bg-active);animation:shimmer 1.5s ease-in-out infinite}.search-modal__skeleton-line--short{width:40%}.search-modal__skeleton-line--long{width:80%}
