:root{--font-scale: 1;--font-base: 16px;--color-bg: #ffffff;--color-bg-elevated: #f2f3f5;--color-text: #2e3338;--color-text-muted: #5c6066;--color-accent: #5865f2;--color-accent-text: #ffffff;--color-border: #d7d9dc;--color-danger: #d83c3e;--color-status-ready: #23a55a;--color-status-connecting: #f0b232;--color-status-disconnected: #80848e;--radius: 8px;--space: 8px;--transition: .15s ease}:root[data-theme=dark]{--color-bg: #313338;--color-bg-elevated: #2b2d31;--color-text: #f2f3f5;--color-text-muted: #b5bac1;--color-accent: #5865f2;--color-accent-text: #ffffff;--color-border: #1e1f22;--color-danger: #f23f43}*{box-sizing:border-box}html{font-size:calc(var(--font-base) * var(--font-scale))}body{margin:0;font-family:gg sans,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text)}:root[data-density=compact]{--space: 4px}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}:root[data-reduced-motion=true] *{animation-duration:.01ms!important;transition-duration:.01ms!important}a{color:var(--color-accent)}button{font:inherit;cursor:pointer;border:1px solid transparent;border-radius:var(--radius);padding:calc(var(--space) * 1) calc(var(--space) * 2);background:var(--color-accent);color:var(--color-accent-text);transition:filter var(--transition)}button:hover:not(:disabled){filter:brightness(1.05)}button:disabled{opacity:.6;cursor:not-allowed}.link-button{background:none;color:var(--color-accent);border:none;padding:0;text-decoration:underline}.skip-link{position:absolute;left:-9999px;top:0;padding:var(--space);background:var(--color-accent);color:var(--color-accent-text);z-index:100}.skip-link:focus{left:0}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space) calc(var(--space) * 2);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.app-header-actions{display:flex;align-items:center;gap:var(--space)}.brand{font-weight:700}.app-main{flex:1;padding:calc(var(--space) * 2)}.theme-toggle{background:transparent;border-color:var(--color-border)}.connection-status{font-size:.85rem;color:var(--color-text-muted)}.connection-status[data-status=ready]{color:var(--color-status-ready)}.connection-status[data-status=connecting],.connection-status[data-status=reconnecting]{color:var(--color-status-connecting)}.connection-status[data-status=disconnected]{color:var(--color-status-disconnected)}.auth-card{max-width:420px;margin:calc(var(--space) * 6) auto;padding:calc(var(--space) * 3);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius)}.auth-card form{display:flex;flex-direction:column;gap:calc(var(--space) * 1.5)}.field{display:flex;flex-direction:column;gap:calc(var(--space) / 2)}.field input{padding:var(--space);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text)}.field input[aria-invalid=true]{border-color:var(--color-danger)}.field-error,.form-error{color:var(--color-danger);font-size:.85rem}.checkbox{display:flex;align-items:center;gap:calc(var(--space) / 2)}.route-loading{padding:calc(var(--space) * 3);text-align:center;color:var(--color-text-muted)}.app-main:has(.chat-page){padding:0}.chat-page{display:grid;grid-template-columns:72px 240px 1fr 240px;height:100%;min-height:0}.chat-page:not([data-members]){grid-template-columns:72px 240px 1fr}.icon-button{background:transparent;border:none;color:var(--color-text-muted);padding:calc(var(--space) / 2);border-radius:var(--radius);line-height:1}.icon-button:hover:not(:disabled){background:var(--color-bg);color:var(--color-text);filter:none}.icon-button-danger:hover:not(:disabled){color:var(--color-danger)}.server-rail{background:var(--color-border);padding:var(--space) 0;overflow-y:auto}.server-rail-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;align-items:center;gap:var(--space)}.server-rail-divider{width:32px;border:none;border-top:1px solid var(--color-bg);margin:0}.server-pill{width:48px;height:48px;border-radius:50%;background:var(--color-bg-elevated);color:var(--color-text);display:flex;align-items:center;justify-content:center;font-weight:600;text-decoration:none;border:none;transition:border-radius var(--transition),background var(--transition);overflow:hidden}.server-pill:hover,.server-pill[data-active]{border-radius:16px;background:var(--color-accent);color:var(--color-accent-text)}.server-pill-icon{width:100%;height:100%;object-fit:cover}.server-pill-add{color:var(--color-status-ready)}.channel-sidebar{background:var(--color-bg-elevated);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.channel-sidebar-header{padding:var(--space) calc(var(--space) * 1.5);border-bottom:1px solid var(--color-border);box-shadow:0 1px #0000001a}.channel-sidebar-title{font-size:1rem;margin:0}.channel-sidebar-status{padding:var(--space);color:var(--color-text-muted);font-size:.85rem}.channel-list{list-style:none;margin:0;padding:var(--space);overflow-y:auto}.channel-category{margin-top:var(--space)}.channel-category-header{width:100%;text-align:left;background:none;border:none;color:var(--color-text-muted);text-transform:uppercase;font-size:.72rem;font-weight:700;letter-spacing:.02em;padding:calc(var(--space) / 2)}.channel-category-items{list-style:none;margin:0;padding:0}.channel-link{display:flex;align-items:center;gap:calc(var(--space) / 1.5);padding:calc(var(--space) / 1.5) var(--space);border-radius:var(--radius);color:var(--color-text-muted);text-decoration:none;font-size:.95rem}.channel-link:hover,.channel-link[data-active]{background:var(--color-bg);color:var(--color-text)}.channel-link-icon{opacity:.7}.message-view{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--color-bg)}.message-view-empty,.empty-channel{align-items:center;justify-content:center;text-align:center;color:var(--color-text-muted)}.channel-header{display:flex;align-items:center;gap:var(--space);padding:var(--space) calc(var(--space) * 1.5);border-bottom:1px solid var(--color-border);min-height:48px}.channel-header-title{font-size:1rem;margin:0;display:flex;align-items:center;gap:calc(var(--space) / 2)}.channel-hash{color:var(--color-text-muted)}.channel-header-topic{margin:0;color:var(--color-text-muted);font-size:.85rem;border-left:1px solid var(--color-border);padding-left:var(--space);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-header-actions{margin-left:auto;display:flex;gap:calc(var(--space) / 2)}.message-list-wrapper{position:relative;flex:1;min-height:0}.message-list{height:100%;overflow-y:auto;padding:var(--space);display:flex;flex-direction:column}.message-list-status{color:var(--color-text-muted);padding:var(--space)}.jump-to-present{position:absolute;bottom:var(--space);right:var(--space);font-size:.8rem;padding:calc(var(--space) / 2) var(--space)}.message{display:grid;grid-template-columns:48px 1fr auto;gap:calc(var(--space) / 2);padding:calc(var(--space) / 2) var(--space);position:relative}.message:hover{background:var(--color-bg-elevated)}.message[data-grouped]{padding-top:0;padding-bottom:0}.message-gutter{display:flex;justify-content:center}.message-gutter-time{font-size:.65rem;color:var(--color-text-muted);opacity:0;align-items:center}.message:hover .message-gutter-time{opacity:1}.avatar{border-radius:50%;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.message-body{min-width:0}.message-header{display:flex;align-items:baseline;gap:var(--space)}.message-author{font-weight:600}.message-timestamp{font-size:.7rem;color:var(--color-text-muted)}.message-badge{font-size:.65rem;text-transform:uppercase;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);padding:0 4px}.message-content{overflow-wrap:anywhere;white-space:pre-wrap}.message-edited{font-size:.65rem;color:var(--color-text-muted)}.message[data-pending]{opacity:.6}.message-failed{background:none;color:var(--color-danger);border:none;padding:0;font-size:.8rem}.message-sending{font-size:.75rem;color:var(--color-text-muted)}.message-actions{position:absolute;top:-10px;right:var(--space);display:none;gap:2px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);padding:2px}.message:hover .message-actions{display:flex}.reply-reference{font-size:.8rem;color:var(--color-text-muted);display:flex;gap:calc(var(--space) / 2);align-items:center;margin-bottom:2px}.reply-reference-author{color:var(--color-accent)}.md-code{background:var(--color-bg-elevated);border-radius:4px;padding:0 4px;font-family:monospace;font-size:.85em}.md-codeblock{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space);overflow-x:auto;font-size:.85em}.md-spoiler[data-spoiler]{background:var(--color-text);color:transparent;border-radius:4px;cursor:pointer}.md-spoiler[data-spoiler]:hover{color:var(--color-bg)}.mention{background:color-mix(in srgb,var(--color-accent) 25%,transparent);color:var(--color-accent);border-radius:4px;padding:0 2px;font-weight:500}.mention-everyone{background:color-mix(in srgb,#f0b232 25%,transparent);color:inherit}.reactions{display:flex;flex-wrap:wrap;gap:calc(var(--space) / 2);margin-top:calc(var(--space) / 2)}.reaction-pill{display:inline-flex;align-items:center;gap:4px;background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text);border-radius:10px;padding:1px 8px;font-size:.85rem}.reaction-pill[data-me]{background:color-mix(in srgb,var(--color-accent) 25%,transparent);border-color:var(--color-accent)}.reaction-emoji{width:1.1em;height:1.1em;object-fit:contain;display:inline-block}.composer{margin:0 var(--space) var(--space);background:var(--color-bg-elevated);border-radius:var(--radius);padding:calc(var(--space) / 2) var(--space)}.composer-reply,.composer-slowmode{font-size:.8rem;color:var(--color-text-muted);display:flex;justify-content:space-between;align-items:center;padding:2px 0}.composer-attachments{list-style:none;margin:0;padding:var(--space) 0 0;display:flex;flex-wrap:wrap;gap:var(--space)}.composer-attachment{display:flex;align-items:center;gap:4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:4px 8px;font-size:.85rem}.composer-input-row{display:flex;align-items:flex-end;gap:calc(var(--space) / 2)}.composer-textarea-wrap{position:relative;flex:1}.composer-textarea{width:100%;resize:none;background:transparent;border:none;color:var(--color-text);font:inherit;padding:var(--space) 0;max-height:50vh}.composer-textarea:focus{outline:none}.composer-send{background:transparent;color:var(--color-accent)}.mention-autocomplete{position:absolute;bottom:calc(100% + 4px);left:0;right:0;list-style:none;margin:0;padding:4px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #0000004d;max-height:220px;overflow-y:auto;z-index:20}.mention-option{width:100%;display:flex;align-items:center;gap:var(--space);background:none;border:none;color:var(--color-text);text-align:left;padding:calc(var(--space) / 1.5) var(--space);border-radius:var(--radius)}.mention-option[data-active],.mention-option:hover{background:var(--color-accent);color:var(--color-accent-text)}.mention-option-detail{margin-left:auto;font-size:.8rem;color:var(--color-text-muted)}.mention-option[data-active] .mention-option-detail{color:var(--color-accent-text)}.emoji-picker{position:relative}.emoji-grid{position:absolute;bottom:calc(100% + 4px);right:0;display:grid;grid-template-columns:repeat(8,1fr);gap:2px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);padding:4px;box-shadow:0 4px 16px #0000004d;z-index:20}.emoji-grid-item{background:none;border:none;font-size:1.1rem;padding:4px;border-radius:4px}.emoji-grid-item:hover{background:var(--color-bg)}.typing-indicator{min-height:1.4rem;padding:0 calc(var(--space) * 2);font-size:.8rem;color:var(--color-text-muted)}.pins-panel{position:absolute;right:var(--space);top:48px;width:320px;max-height:60vh;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #0000004d;z-index:30}.pins-panel-header{display:flex;justify-content:space-between;padding:var(--space);border-bottom:1px solid var(--color-border)}.pins-panel-list{list-style:none;margin:0;padding:var(--space)}.pins-panel-item{padding:calc(var(--space) / 2) 0;border-bottom:1px solid var(--color-border)}.pins-panel-author{font-weight:600;font-size:.85rem}.member-list{background:var(--color-bg-elevated);border-left:1px solid var(--color-border);overflow-y:auto;padding:var(--space)}.member-list-header{font-size:.72rem;text-transform:uppercase;color:var(--color-text-muted);font-weight:700;padding:calc(var(--space) / 2)}.member-group-header{font-size:.72rem;text-transform:uppercase;color:var(--color-text-muted);margin:var(--space) 0 calc(var(--space) / 2)}.member-group-list{list-style:none;margin:0;padding:0}.member-row{display:flex;align-items:center;gap:var(--space);padding:calc(var(--space) / 2);border-radius:var(--radius)}.member-row:hover{background:var(--color-bg)}.member-row[data-status=offline]{opacity:.5}.member-avatar-wrap{position:relative;display:inline-flex}.presence-dot{position:absolute;right:-2px;bottom:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-bg-elevated);background:var(--color-status-disconnected)}.presence-dot[data-status=online]{background:var(--color-status-ready)}.presence-dot[data-status=idle]{background:var(--color-status-connecting)}.presence-dot[data-status=dnd]{background:var(--color-danger)}.member-name{font-size:.9rem}.server-settings{display:grid;grid-template-columns:220px 1fr;gap:calc(var(--space) * 2);height:100%;min-height:0}.server-settings-nav{border-right:1px solid var(--color-border);padding:calc(var(--space) * 2);overflow-y:auto}.server-settings-back{display:inline-block;margin-bottom:var(--space);font-size:.85rem}.server-settings-title{font-size:1rem;margin:0 0 var(--space)}.server-settings-sections{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.server-settings-link{display:block;padding:calc(var(--space) / 1.5) var(--space);border-radius:var(--radius);color:var(--color-text-muted);text-decoration:none;font-size:.95rem}.server-settings-link:hover,.server-settings-link[data-active]{background:var(--color-bg-elevated);color:var(--color-text)}.server-settings-content{padding:calc(var(--space) * 2);overflow-y:auto}.settings-panel{max-width:760px}.settings-panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space);margin-bottom:calc(var(--space) * 2)}.settings-panel-header h2{margin:0;font-size:1.2rem}.settings-form{display:flex;flex-direction:column;gap:calc(var(--space) * 1.5)}.settings-form select,.settings-textarea,.field select,.field textarea{padding:var(--space);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font:inherit}.settings-textarea{min-height:80px;resize:vertical}.settings-form-actions{display:flex;align-items:center;gap:var(--space)}.settings-saved{color:var(--color-status-ready);font-size:.85rem}.settings-empty{color:var(--color-text-muted)}.button-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.button-danger{background:var(--color-danger);color:#fff}.settings-badge{display:inline-block;font-size:.65rem;text-transform:uppercase;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);padding:0 4px;margin-left:calc(var(--space) / 2)}.settings-table{width:100%;border-collapse:collapse}.settings-table th,.settings-table td{text-align:left;padding:calc(var(--space) / 1.5) var(--space);border-bottom:1px solid var(--color-border)}.settings-table-name{font-weight:600}.settings-table-actions{display:flex;gap:calc(var(--space) / 2);justify-content:flex-end;align-items:center}.roles-layout{display:grid;grid-template-columns:240px 1fr;gap:calc(var(--space) * 2)}.roles-list{list-style:none;margin:0;padding:0}.roles-list-item{display:flex;align-items:center;justify-content:space-between;gap:calc(var(--space) / 2)}.roles-list-name{flex:1;display:flex;align-items:center;gap:calc(var(--space) / 2);background:none;border:none;color:var(--color-text);text-align:left;padding:calc(var(--space) / 1.5) var(--space);border-radius:var(--radius)}.roles-list-name[data-active],.roles-list-name:hover{background:var(--color-bg-elevated)}.roles-color-dot{width:12px;height:12px;border-radius:50%;border:1px solid var(--color-border)}.roles-list-controls{display:flex;gap:2px}.permission-matrix{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space)}.permission-group{margin-bottom:var(--space)}.permission-group-title{margin:var(--space) 0 calc(var(--space) / 2);font-size:.78rem;text-transform:uppercase;color:var(--color-text-muted)}.permission-row{display:flex;align-items:center;gap:calc(var(--space) / 2);padding:2px 0}.overwrite-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0}.overwrite-state{background:var(--color-bg-elevated);color:var(--color-text);border:1px solid var(--color-border);min-width:80px}.overwrite-state[data-state=allow]{border-color:var(--color-status-ready);color:var(--color-status-ready)}.overwrite-state[data-state=deny]{border-color:var(--color-danger);color:var(--color-danger)}.automod-rules{list-style:none;margin:0;padding:0}.automod-rule{display:flex;align-items:center;justify-content:space-between;padding:var(--space);border-bottom:1px solid var(--color-border)}.automod-rule-actions-summary{color:var(--color-text-muted);font-size:.8rem;margin-left:var(--space)}.automod-actions,.onboarding-channels{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space);display:flex;flex-direction:column;gap:calc(var(--space) / 2)}.audit-log,.reports-list{list-style:none;margin:0;padding:0}.audit-entry{display:flex;align-items:center;gap:var(--space);padding:calc(var(--space) / 1.5) 0;border-bottom:1px solid var(--color-border);font-size:.9rem}.audit-entry-time{margin-left:auto;color:var(--color-text-muted);font-size:.8rem}.report-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space) 0;border-bottom:1px solid var(--color-border)}.report-actions{display:flex;gap:calc(var(--space) / 2)}.settings-tabs{display:flex;gap:calc(var(--space) / 2);margin-bottom:var(--space)}.settings-tab{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.settings-tab[data-active]{background:var(--color-bg-elevated);color:var(--color-text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:calc(var(--space) * 2);max-width:420px;box-shadow:0 8px 32px #0006}.modal-message{margin:0 0 calc(var(--space) * 2)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space)}.app-header-link{text-decoration:none;color:var(--color-text-muted)}.app-header-link:hover{color:var(--color-text)}.dm-page{display:flex;height:100%}.dm-sidebar{display:flex;flex-direction:column;gap:calc(var(--space) / 2);padding:var(--space)}.dm-friends-link{display:block;padding:calc(var(--space) / 2) var(--space);border-radius:var(--radius);text-decoration:none;color:var(--color-text)}.dm-friends-link[data-active]{background:var(--color-accent);color:var(--color-accent-text)}.dm-list-label{font-size:.75rem;text-transform:uppercase;color:var(--color-text-muted);margin:var(--space) 0 0}.dm-list{list-style:none;margin:0;padding:0}.dm-row{display:flex;align-items:center;gap:var(--space);padding:calc(var(--space) / 2);border-radius:var(--radius);text-decoration:none;color:var(--color-text)}.dm-row:hover,.dm-row[data-active]{background:var(--color-bg-elevated)}.friends-view{flex:1;padding:var(--space);overflow-y:auto}.friends-tabs{display:flex;gap:var(--space);border-bottom:1px solid var(--color-border);padding-bottom:var(--space)}.friends-tabs button[data-active]{font-weight:600;color:var(--color-accent)}.add-friend{margin:var(--space) 0}.add-friend-row{display:flex;gap:var(--space)}.add-friend-row input{flex:1}.add-friend-success{color:var(--color-status-ready)}.relationship-list{list-style:none;margin:0;padding:0}.relationship-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space);padding:calc(var(--space) / 2);border-radius:var(--radius)}.relationship-row:hover{background:var(--color-bg-elevated)}.relationship-identity{display:flex;align-items:center;gap:var(--space);background:none;border:none;color:inherit;cursor:pointer}.relationship-actions{display:flex;gap:calc(var(--space) / 2)}.profile-panel{width:320px;border-left:1px solid var(--color-border);overflow-y:auto}.profile-card{display:flex;flex-direction:column;gap:var(--space);padding-bottom:var(--space)}.profile-banner{height:96px;background:var(--color-accent);background-size:cover;background-position:center}.profile-header{display:flex;gap:var(--space);padding:0 var(--space);margin-top:-36px}.profile-identity{display:flex;flex-direction:column;align-self:flex-end}.profile-name{margin:0}.profile-handle,.profile-pronouns{color:var(--color-text-muted);font-size:.85rem}.profile-bio,.profile-mutuals,.profile-actions{padding:0 var(--space)}.profile-mutual-list{list-style:none;margin:0;padding:0}.profile-mutual{display:flex;align-items:center;gap:calc(var(--space) / 2)}.profile-actions{display:flex;flex-wrap:wrap;gap:calc(var(--space) / 2)}.settings-page{display:flex;height:100%}.settings-nav{width:220px;border-right:1px solid var(--color-border);padding:var(--space)}.settings-nav ul{list-style:none;margin:0;padding:0}.settings-nav button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--color-text);padding:calc(var(--space) / 2) var(--space);border-radius:var(--radius);cursor:pointer}.settings-nav button[data-active]{background:var(--color-bg-elevated);font-weight:600}.settings-content{flex:1;padding:calc(var(--space) * 2);overflow-y:auto}.settings-panel{max-width:560px;display:flex;flex-direction:column;gap:var(--space)}.settings-saved{color:var(--color-status-ready)}.radio-row,.toggle-row{display:flex;align-items:center;gap:calc(var(--space) / 2)}.keyword-row{display:flex;gap:var(--space)}.keyword-list{list-style:none;display:flex;flex-wrap:wrap;gap:calc(var(--space) / 2);padding:0;margin:calc(var(--space) / 2) 0 0}.keyword-list li{display:inline-flex;align-items:center;gap:calc(var(--space) / 2);background:var(--color-bg-elevated);border-radius:var(--radius);padding:2px var(--space)}.session-list{list-style:none;margin:0;padding:0}.session-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space);padding:calc(var(--space) / 2) 0;border-bottom:1px solid var(--color-border)}.session-meta{display:block;font-size:.8rem;color:var(--color-text-muted)}.backup-codes{display:grid;grid-template-columns:repeat(2,1fr);gap:calc(var(--space) / 2);list-style:none;padding:0}button.danger{background:var(--color-danger);color:#fff}.image-upload{display:inline-flex;flex-direction:column;gap:calc(var(--space) / 2);cursor:pointer}.profile-images{display:flex;gap:calc(var(--space) * 2)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.voice-panel{display:flex;flex-direction:column;gap:var(--space);height:100%;min-height:0;padding:var(--space)}.voice-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space)}.voice-panel-header h2{margin:0;font-size:1rem}.voice-panel-count,.voice-panel-status{color:var(--color-text-muted);font-size:.8rem}.voice-panel-status[data-state=connected]{color:var(--color-status-ready)}.voice-panel-status[data-state=connecting],.voice-panel-status[data-state=reconnecting]{color:var(--color-status-connecting)}.voice-panel-status[data-state=disconnected]{color:var(--color-status-disconnected)}.voice-panel-body{flex:1;min-height:0;overflow:auto}.voice-join{align-self:flex-start;background:var(--color-accent);color:var(--color-accent-text);padding:calc(var(--space) * .75) calc(var(--space) * 2);border-radius:var(--radius);font-weight:600}.voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space)}.voice-grid-empty{color:var(--color-text-muted)}.voice-tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:calc(var(--space) * .5);padding:var(--space);background:var(--color-bg-elevated);border:2px solid transparent;border-radius:var(--radius);transition:border-color var(--transition)}.voice-tile[data-speaking]{border-color:var(--color-status-ready)}.voice-tile-media{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:16 / 9}.voice-tile-video{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);background:#000}.voice-tile-footer{display:flex;align-items:center;gap:calc(var(--space) * .5);max-width:100%}.voice-tile-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-tile-badges{display:inline-flex;gap:2px}.voice-tile-controls{display:flex;flex-direction:column;gap:calc(var(--space) * .5);width:100%}.voice-volume input[type=range]{width:100%}.voice-mod-actions,.stage-mod-actions{display:flex;gap:calc(var(--space) * .5)}.voice-inline-btn{font-size:.75rem}.voice-controls{display:flex;flex-wrap:wrap;align-items:center;gap:calc(var(--space) * .5);padding-top:var(--space);border-top:1px solid var(--color-border)}.voice-control-btn{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius);padding:calc(var(--space) * .5) var(--space)}.voice-control-btn[aria-pressed=true]{background:var(--color-accent);color:var(--color-accent-text)}.voice-control-disconnect{margin-left:auto;color:var(--color-danger)}.voice-ptt-indicator{font-size:.75rem;color:var(--color-text-muted)}.voice-ptt-indicator[data-active]{color:var(--color-status-ready);font-weight:600}.soundboard-panel,.device-settings,.stage-panel{margin-top:var(--space);padding:var(--space);background:var(--color-bg-elevated);border-radius:var(--radius)}.soundboard-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:calc(var(--space) * .5)}.soundboard-sound{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;padding:calc(var(--space) * .5);border:1px solid var(--color-border);border-radius:var(--radius)}.soundboard-emoji{font-size:1.4rem}.soundboard-empty,.voice-empty{color:var(--color-text-muted)}.stage-people{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:var(--space)}.stage-person{display:flex;flex-direction:column;align-items:center;gap:4px;padding:calc(var(--space) * .5);border-radius:var(--radius)}.stage-person[data-speaking]{background:color-mix(in srgb,var(--color-status-ready) 20%,transparent)}.stage-self-actions{margin-top:var(--space)}.device-field{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--space)}.device-level{height:8px;margin-top:calc(var(--space) * .5);background:var(--color-border);border-radius:999px;overflow:hidden}.device-level-fill{height:100%;background:var(--color-status-ready);transition:width 60ms linear}
