:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-deep:#1e1f22;--bg-sidebar:#2b2d31;--bg-main:#313338;--bg-card:#2b2d31;--bg-hover:#35373c;--bg-active:#404249;--bg-input:#1e1f22;--text:#dbdee1;--text-muted:#949ba4;--text-bright:#f2f3f5;--accent:#5865f2;--accent-hover:#4752c4;--green:#23a55a;--red:#f23f43;--border:#232428;background:var(--bg-main);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:gg sans,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--bg-main);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;width:100%;min-width:0;overflow-x:hidden}body{background:var(--bg-main);width:100%;min-width:0;min-height:100vh;margin:0;overflow-x:hidden}#root{width:100%;min-width:0;min-height:100vh}button{font:inherit}input{border:1px solid var(--border);background:var(--bg-input);width:100%;min-width:0;height:38px;color:var(--text);font:inherit;border-radius:4px;padding:0 10px}input:focus{border-color:var(--accent);outline:none}@supports (-webkit-touch-callout:none){input:not([type=range]):not([type=checkbox]):not([type=radio]),select,textarea{font-size:16px}}h1,h2,h3{margin:0}.auth-shell{background:radial-gradient(circle at 50% -20%, #3a3d77, var(--bg-main) 60%);place-items:center;min-height:100vh;padding:20px;display:grid}.auth-card{border:1px solid var(--border);background:var(--bg-card);border-radius:8px;width:min(420px,100%);padding:24px;box-shadow:0 8px 24px #0006}.auth-brand{align-items:center;gap:12px;display:flex}.auth-brand h1{color:var(--text-bright);font-size:22px;line-height:1.1}.auth-brand p{color:var(--text-muted);margin:4px 0 0;font-size:13px}.brand-mark{background:var(--accent);color:#fff;border-radius:16px;place-items:center;width:44px;height:44px;font-size:20px;font-weight:800;display:grid}.auth-tabs{grid-template-columns:1fr 1fr;gap:8px;margin-top:20px;display:grid}.tab-button,.primary-button,.utility-button{color:var(--text-bright);background:var(--bg-active);cursor:pointer;border:none;border-radius:4px}.tab-button{justify-content:center;align-items:center;gap:8px;height:38px;font-size:13px;font-weight:700;display:flex}.tab-button.active{background:var(--accent);color:#fff}.tab-button.login.active{background:var(--green)}.tab-button.register.active{background:#3b82f6}.tab-button.login:hover{color:var(--text-bright);background:#23a55933}.tab-button.register:hover{color:var(--text-bright);background:#3b82f633}.tab-button.login.active:hover{background:#2eb96a}.tab-button.register.active:hover{background:#60a5fa}.auth-form{gap:14px;margin-top:20px;display:grid}.auth-note{border:1px solid var(--border);color:var(--text-muted);background:#232428b8;border-left-width:3px;border-radius:6px;gap:6px;padding:10px 12px;font-size:12px;line-height:1.45;display:grid}.auth-note p{margin:0}.auth-note.login{border-left-color:var(--green)}.auth-note.register{border-left-color:#3b82f6}.captcha-status{border:1px solid var(--border);color:var(--text-muted);background:#232428b8;border-radius:6px;align-items:center;gap:7px;padding:7px 10px;font-size:12px;line-height:1.35;display:flex}.captcha-status.passed{border-color:var(--green);color:var(--green);background:#23a55a1a}.captcha-status.failed,.captcha-status.blocked{border-color:var(--red);color:#ffb9bb;background:#f23f431a}.captcha-status.checking{color:#ffd98a;background:#f0b23214;border-color:#f0b232}.captcha-disclosure{color:var(--text-muted);margin:-4px 0 0;font-size:11px;line-height:1.4}.captcha-disclosure a{color:var(--text);text-underline-offset:2px;text-decoration:underline}.grecaptcha-badge{visibility:hidden!important}.auth-form label{color:var(--text-muted);text-transform:uppercase;gap:6px;font-size:12px;font-weight:700;display:grid}.password-input-row{grid-template-columns:minmax(0,1fr) 38px;align-items:stretch;min-width:0;display:grid}.password-input-row input{border-top-right-radius:0;border-bottom-right-radius:0}.password-reveal-button{border:1px solid var(--border);background:var(--bg-active);color:var(--text-muted);cursor:pointer;border-left:none;border-radius:0 4px 4px 0;place-items:center;display:grid}.password-reveal-button:hover,.password-reveal-button[aria-pressed=true]{color:var(--text-bright);background:#4e5058}.primary-button{background:var(--accent);color:#fff;justify-content:center;align-items:center;gap:8px;height:40px;font-size:14px;font-weight:700;display:flex}.primary-button.auth-submit.login{background:var(--green)}.primary-button.auth-submit.register{background:#3b82f6}.primary-button.auth-submit.login:hover{background:#2eb96a}.primary-button.auth-submit.register:hover{background:#60a5fa}.primary-button.compact{height:38px;padding:0 14px}.primary-button:hover,.tab-button:hover{background:var(--accent-hover)}.primary-button:disabled{cursor:wait;opacity:.7}.utility-button{background:var(--bg-active);justify-content:center;align-items:center;gap:8px;width:100%;height:36px;font-size:13px;font-weight:600;display:flex}.utility-button.compact{width:auto;height:32px;padding:0 10px}.utility-button:hover{background:#4e5058}.app-shell{background:var(--bg-main);grid-template-rows:minmax(0,1fr) auto;grid-template-columns:248px minmax(0,1fr) 240px;width:100%;min-width:0;height:100dvh;display:grid;overflow:hidden}.mobile-nav{display:none}.sidebar{background:var(--bg-sidebar);flex-direction:column;grid-area:1/1;min-width:0;min-height:0;display:flex}.server-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;height:52px;padding:0 14px;display:flex;box-shadow:0 1px #0003}.server-header .brand-mark{border-radius:10px;width:32px;height:32px;font-size:15px}.server-header h1{color:var(--text-bright);font-size:15px;font-weight:700}.server-header small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:11px;display:block;overflow:hidden}.sidebar-scroll{flex:1;min-height:0;padding:10px 8px;overflow-y:auto}.channel-list{flex-direction:column;gap:2px;display:flex}.channel-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;justify-content:space-between;align-items:center;padding:14px 8px 4px;font-size:11px;font-weight:700;display:flex}.category-add{color:var(--text-muted);cursor:pointer;background:0 0;border:none;place-items:center;padding:0;display:grid}.category-add:hover{color:var(--text-bright)}.channel-create{grid-template-columns:minmax(0,1fr) 32px;gap:4px;padding:2px 4px 6px;display:grid}.channel-create input{height:30px;font-size:13px}.channel-row{border-radius:4px;align-items:center;min-height:34px;display:flex}.channel-row:hover{background:var(--bg-hover)}.channel-row.active{background:var(--bg-active)}.channel-select{min-width:0;color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:6px;padding:6px;display:flex}.channel-row:hover .channel-select,.channel-row.active .channel-select{color:var(--text-bright)}.channel-name{text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:500;overflow:hidden}.channel-admin{gap:2px;padding-right:4px;display:none}.channel-row:hover .channel-admin{display:flex}.channel-rename{grid-template-columns:minmax(0,1fr) 28px 28px;gap:3px;width:100%;padding:3px 4px;display:grid}.channel-rename input{height:28px;font-size:13px}.channel-occupants{flex-direction:column;gap:1px;padding:2px 0 4px;display:flex}.occupant{cursor:default;border-radius:4px;align-items:center;gap:8px;padding:3px 6px;display:flex}.occupant:hover{background:var(--bg-hover)}.occupant-avatar{background:var(--bg-active);width:24px;height:24px;color:var(--text-bright);border:2px solid #0000;border-radius:50%;flex:none;place-items:center;font-size:10px;font-weight:700;display:grid}.occupant.speaking .occupant-avatar,.occupant-avatar.speaking{border-color:var(--green)}.occupant-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-muted);flex:1;font-size:14px;overflow:hidden}.occupant.speaking .occupant-name{color:var(--text-bright)}.occupant-icons{color:var(--text-muted);align-items:center;display:flex}.occupant-mic-on{opacity:.55}.icon-button{background:var(--bg-active);width:34px;height:34px;color:var(--text);cursor:pointer;border:none;border-radius:4px;flex:none;place-items:center;display:grid}.icon-button:hover{background:#4e5058}.icon-button.compact{width:28px;height:28px}.icon-button.ghost{color:var(--text-muted);background:0 0}.icon-button.ghost:hover{background:var(--bg-hover);color:var(--text-bright)}.icon-button.danger{color:var(--text-muted);background:0 0}.icon-button.danger:hover{background:var(--red);color:#fff}.icon-button.active-danger{color:var(--red)}.icon-button.active-success{color:var(--green)}.icon-button:disabled{opacity:.4;cursor:not-allowed}.control-tooltip{z-index:200;max-width:min(220px,100vw - 16px);color:var(--text-bright);text-align:center;white-space:nowrap;pointer-events:none;background:#111214f5;border:1px solid #ffffff14;border-radius:6px;padding:6px 8px;font-size:12px;font-weight:700;line-height:1.25;position:fixed;box-shadow:0 10px 28px #00000061}.control-tooltip:after{content:"";background:#111214f5;border-bottom:1px solid #ffffff14;border-right:1px solid #ffffff14;width:8px;height:8px;position:absolute;transform:rotate(45deg)}.control-tooltip.top:after{bottom:-5px;left:50%;transform:translate(-50%)rotate(45deg)}.control-tooltip.left:after{top:50%;right:-5px;transform:translateY(-50%)rotate(-45deg)}.control-tooltip.right:after{top:50%;left:-5px;transform:translateY(-50%)rotate(135deg)}.user-bar{border-top:1px solid var(--border);background:#232428;grid-area:2/1;min-width:0}.voice-status-panel{border-bottom:1px solid var(--border);padding:8px 10px}.voice-status-head{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.voice-status-meta{align-items:center;gap:8px;min-width:0;display:flex}.voice-status-signal{color:var(--green)}.voice-status-copy{outline:none;min-width:0;position:relative}.voice-status-meta strong{color:var(--green);font-size:13px;display:block}.voice-status-meta small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:12px;display:block;overflow:hidden}.voice-network-stats{z-index:5;border:1px solid var(--border);width:max-content;max-width:min(520px,100vw - 24px);color:var(--text-muted);opacity:0;pointer-events:none;visibility:hidden;background:#111214fa;border-radius:8px;grid-template-columns:auto repeat(3,max-content);align-items:stretch;gap:5px;padding:6px;font-size:10px;line-height:1;transition:opacity .12s,transform .12s,visibility .12s;display:grid;position:absolute;bottom:calc(100% + 7px);left:0;transform:translateY(2px);box-shadow:0 10px 24px #0000005c}.voice-status-copy:hover .voice-network-stats,.voice-status-copy:focus-within .voice-network-stats,.voice-status-copy:focus .voice-network-stats{opacity:1;visibility:visible;transform:translateY(0)}.voice-network-protocol{min-width:42px;color:var(--green);letter-spacing:0;background:#23a55a1f;border-radius:6px;place-items:center;padding:6px 8px;font-size:12px;font-weight:700;display:grid}.voice-network-chip{background:#ffffff09;border-radius:6px;gap:3px;min-width:0;padding:5px 7px;display:grid}.voice-network-chip span{color:var(--text-muted);text-transform:uppercase;font-size:9px}.voice-network-chip strong{color:var(--text);white-space:nowrap;font-size:11px;font-weight:600}.voice-status-controls{grid-template-columns:repeat(4,1fr);gap:4px;min-width:0;margin-top:8px;display:grid}.userbar-share-control{place-items:center;display:grid;position:relative}.screen-share-dialog{width:min(440px,100%)}.screen-share-dialog-body{text-align:center;color:var(--text-muted);justify-items:center;gap:10px;padding:16px 8px 22px;display:grid}.screen-share-dialog-body svg{color:var(--green)}.screen-share-dialog-body p{max-width:340px;margin:0;font-size:14px;line-height:1.45}.screen-share-quality-list{gap:6px;width:min(360px,100%);display:grid}.screen-share-quality{border:1px solid var(--border);background:var(--bg-card);width:100%;min-height:54px;color:var(--text);text-align:left;cursor:pointer;border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px 10px;display:grid}.screen-share-quality.active{border-color:var(--accent);background:var(--bg-active)}.screen-share-quality span:first-child{gap:2px;min-width:0;display:grid}.screen-share-quality strong,.screen-share-quality small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.screen-share-quality strong{font-size:13px}.screen-share-quality small{color:var(--text-muted);font-size:11px}.screen-share-dialog-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.account-bar{align-items:center;gap:6px;min-width:0;padding:8px;display:flex}.nickname-prompt{z-index:70;border:1px solid var(--border);background:var(--bg-card);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:10px;width:min(320px,100vw - 32px);padding:12px;display:grid;position:fixed;bottom:92px;right:16px;box-shadow:0 12px 32px #00000073}.nickname-prompt-copy{gap:3px;min-width:0;display:grid}.nickname-prompt-copy strong,.nickname-prompt-copy span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.nickname-prompt-copy strong{color:var(--text-bright);font-size:13px}.nickname-prompt-copy span{color:var(--text-muted);font-size:12px}.nickname-prompt-close{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;place-items:center;display:grid;position:absolute;top:6px;right:6px}.nickname-prompt-close:hover{background:var(--bg-active);color:var(--text-bright)}.account-identity{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.account-avatar{background:var(--accent);color:#fff;border:2px solid #0000;border-radius:50%;flex:none;place-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:grid}.account-avatar.speaking{border-color:var(--green)}.account-text{min-width:0}.account-text strong{color:var(--text-bright);text-overflow:ellipsis;white-space:nowrap;font-size:14px;display:block;overflow:hidden}.account-text small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;display:block;overflow:hidden}.account-text small.speaking{color:var(--green)}.account-controls{flex:none;gap:2px;display:flex}.stage-column{background:var(--bg-main);flex-direction:column;grid-area:1/2/3;min-width:0;display:flex}.voice-stage{flex-direction:column;flex:1;min-height:0;display:flex}.voice-stage.empty{justify-content:center;align-items:center}.stage-empty{text-align:center;color:var(--text-muted)}.stage-empty-icon{background:var(--bg-sidebar);width:84px;height:84px;color:var(--text-muted);border-radius:50%;place-items:center;margin:0 auto 16px;display:grid}.stage-empty h2{color:var(--text-bright);font-size:20px}.stage-empty p{margin-top:6px;font-size:14px}.stage-bar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;min-width:0;height:52px;padding:0 16px;display:flex;box-shadow:0 1px #0003}.stage-title{color:var(--text-muted);align-items:center;gap:10px;min-width:0;display:flex}.stage-title h2{color:var(--text-bright);text-overflow:ellipsis;white-space:nowrap;font-size:16px;overflow:hidden}.eyebrow{text-transform:uppercase;color:var(--text-muted);margin:0;font-size:10px;font-weight:700}.stage-controls{flex:none;align-items:center;gap:6px;display:flex}.stage-share-control{display:flex;position:relative}.icon-button.active{background:var(--bg-hover);color:var(--text-bright)}.stage-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));align-content:start;gap:14px;min-height:0;padding:18px;display:grid;overflow:auto}.screen-share-stage{flex:1;grid-template-rows:minmax(0,1fr) auto auto auto;gap:12px;min-height:0;padding:14px;display:grid;overflow:hidden}.screen-share-focus{place-items:center;min-height:0;display:grid}.screen-share-frame{border:1px solid var(--border);background:#111214;border-radius:8px;width:100%;height:100%;min-height:280px;position:relative;overflow:hidden}.screen-share-video{object-fit:contain;background:#050506;width:100%;height:100%;display:block}.screen-share-overlay{pointer-events:none;background:linear-gradient(#00000094,#0000);justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex;position:absolute;top:0;left:0;right:0}.screen-share-meta,.screen-share-actions{align-items:center;gap:8px;min-width:0;display:flex}.screen-share-meta{color:var(--text-bright);font-size:13px;font-weight:700}.screen-share-meta span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.screen-share-actions{pointer-events:auto;flex:none}.screen-share-corner-controls{z-index:2;background:#111214b8;border-radius:8px;align-items:flex-end;gap:6px;padding:6px;display:flex;position:absolute;bottom:12px;right:12px;box-shadow:0 8px 24px #00000057}.screen-share-corner-controls .icon-button{width:42px;height:42px;color:var(--text-bright);box-shadow:none;background:#2b2d31eb}.screen-share-corner-controls .icon-button:hover,.stream-audio-control:focus-within .stream-audio-button,.stream-audio-control:hover .stream-audio-button{background:#2b2d31f2}.stream-audio-control{place-items:end;display:grid;position:relative}.stream-audio-control:before{content:"";height:12px;position:absolute;bottom:100%;left:-8px;right:-8px}.stream-audio-button.muted{color:var(--text-muted)}.screen-share-corner-controls .stream-stop-sharing-button,.screen-share-corner-controls .stream-stop-watching-button{color:#fff;background:#da373c}.screen-share-corner-controls .stream-stop-sharing-button:hover,.screen-share-corner-controls .stream-stop-watching-button:hover{color:#fff;background:#a12828}.stream-volume-control{opacity:0;pointer-events:none;visibility:hidden;background:#111214eb;border-radius:6px;place-items:center;width:42px;height:148px;transition:opacity .12s,transform .12s,visibility .12s;display:grid;position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%,6px);box-shadow:0 8px 24px #0000006b}.stream-volume-control.open{opacity:1;pointer-events:auto;visibility:visible;transform:translate(-50%)}.stream-volume-track{background:#4e5058;border-radius:999px;width:6px;height:112px;position:relative}.stream-volume-fill{height:var(--stream-volume-percent);background:var(--accent);border-radius:999px;position:absolute;bottom:0;left:0;right:0}.stream-volume-thumb{left:50%;bottom:var(--stream-volume-percent);background:var(--accent);border-radius:50%;width:28px;height:28px;position:absolute;transform:translate(-50%,50%)}.stream-volume-control input{cursor:pointer;opacity:0;writing-mode:vertical-lr;direction:rtl;background:0 0;border:none;width:100%;height:calc(100% - 32px);padding:0;position:absolute;inset:16px 0}.screen-share-switcher{gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.stream-picker-stage{grid-template-rows:minmax(0,1fr) auto}.stream-picker{place-self:center;gap:12px;width:min(520px,100%);display:grid}.stream-picker-head{color:var(--text-bright);justify-content:center;align-items:center;gap:10px;display:flex}.stream-picker-head svg{color:var(--green)}.stream-picker-head h3{font-size:18px}.stream-offer-list{gap:8px;display:grid}.stream-offer{border:1px solid var(--border);background:var(--bg-deep);border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.stream-offer div{gap:2px;min-width:0;display:grid}.stream-offer strong,.stream-offer span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.stream-offer strong{color:var(--text-bright);font-size:14px}.stream-offer span{color:var(--text-muted);font-size:12px}.stream-watch-button{white-space:nowrap;flex:none}.share-chip{border:1px solid var(--border);background:var(--bg-deep);min-width:0;max-width:220px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:4px;align-items:center;gap:6px;padding:0 10px;display:flex}.share-chip.active,.share-chip:hover{border-color:var(--accent);color:var(--text-bright);background:var(--bg-active)}.share-chip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.participant-rail{grid-auto-columns:minmax(150px,190px);grid-auto-flow:column;gap:10px;min-height:112px;padding-bottom:2px;display:grid;overflow-x:auto}.stage-tile{aspect-ratio:16/10;background:var(--bg-deep);border:2px solid #0000;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex;position:relative}.stage-tile.compact{aspect-ratio:auto;border-width:1px;min-height:104px}.stage-tile.compact .tile-avatar{width:44px;height:44px;font-size:15px}.stage-tile.compact .tile-video-frame{width:min(100%,132px);height:74px}.stage-tile.compact .tile-badge{border-width:2px;width:18px;height:18px;font-size:9px}.stage-tile.speaking{border-color:var(--green)}.tile-avatar{background:var(--accent);color:#fff;border:3px solid #0000;border-radius:50%;place-items:center;width:72px;height:72px;font-size:24px;font-weight:700;display:grid;position:relative}.tile-avatar.speaking{border-color:var(--green);box-shadow:0 0 0 4px #23a55a40}.tile-video-frame{aspect-ratio:16/9;background:#050506;border:2px solid #0000;border-radius:8px;width:min(100%,220px);position:relative;overflow:hidden}.tile-video-frame.speaking{border-color:var(--green);box-shadow:0 0 0 4px #23a55a40}.tile-video{object-fit:cover;width:100%;height:100%;display:block}.tile-badge{background:var(--red);color:#fff;border:3px solid var(--bg-deep);border-radius:50%;place-items:center;width:22px;height:22px;font-size:11px;font-weight:800;display:grid;position:absolute;bottom:-2px;right:-2px}.tile-name{color:var(--text-bright);text-overflow:ellipsis;white-space:nowrap;max-width:90%;font-size:14px;font-weight:600;overflow:hidden}.error-strip{border:1px solid var(--red);color:#ffb9bb;background:#f23f431f;border-radius:4px;align-items:center;gap:8px;margin:10px 16px 0;padding:10px 12px;font-size:13px;display:flex}.offline-strip{color:#ffd98a;background:#f0b2321f;border:1px solid #f0b232;border-radius:4px;align-items:center;gap:8px;margin:10px 16px 0;padding:10px 12px;font-size:13px;display:flex}.error-strip.inline{margin:0}.error-note{color:#ffb9bb;border:1px solid var(--red);background:#f23f431a;border-radius:4px;margin-top:8px;padding:8px;font-size:12px}.compact-error{margin:6px 8px 0}.empty-state{min-height:40px;color:var(--text-muted);place-items:center;margin:8px;font-size:13px;display:grid}.member-list{background:var(--bg-sidebar);border-left:1px solid var(--border);grid-area:1/3/3;padding:16px 8px;overflow-y:auto}.member-group{margin-bottom:16px}.member-group-title{color:var(--text-muted);text-transform:uppercase;padding:6px 8px;font-size:11px;font-weight:700}.member-row{border-radius:4px;align-items:center;gap:10px;padding:5px 8px;display:flex}.member-row:hover{background:var(--bg-hover)}.member-row.offline{opacity:.5}.member-avatar{background:var(--bg-active);width:32px;height:32px;color:var(--text-bright);border-radius:50%;flex:none;place-items:center;font-size:12px;font-weight:700;display:grid;position:relative}.presence-dot{background:var(--text-muted);border:3px solid var(--bg-sidebar);border-radius:50%;width:12px;height:12px;position:absolute;bottom:-2px;right:-2px}.presence-dot.online{background:var(--green)}.member-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text);flex:1;font-size:14px;font-weight:500;overflow:hidden}.member-crown{color:#f0b232;flex:none}.member-kick{flex:none}.modal-overlay{z-index:50;background:#0009;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-main);border:1px solid var(--border);border-radius:8px;width:min(520px,100%);max-height:88vh;padding:20px;overflow-y:auto;box-shadow:0 12px 40px #00000080}.modal-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.modal-head h2{color:var(--text-bright);font-size:20px}.modal-section{border-top:1px solid var(--border);padding:16px 0}.modal-section:first-of-type{border-top:none}.modal-section h3{text-transform:uppercase;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;display:flex}.modal-row{grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-bottom:10px;display:grid}.modal-hint{color:var(--text-muted);margin:-4px 0 10px;font-size:12px}.modal-slider{gap:8px;margin-top:10px;display:grid}.modal-slider input[type=range]{width:100%}.nc-status{color:var(--text-muted);margin-top:10px;font-size:12px}.nc-status-line{align-items:center;gap:8px;display:flex}.nc-status .nc-status-dot{background:var(--text-muted);border-radius:50%;flex:none;width:8px;height:8px}.nc-status.active{color:var(--green)}.nc-status.active .nc-status-dot{background:var(--green)}.nc-status.failed{color:var(--red)}.nc-status.failed .nc-status-dot{background:var(--red)}.nc-status.loading{color:#f0b232}.nc-status.loading .nc-status-dot{background:#f0b232;animation:1s ease-in-out infinite nc-pulse}@keyframes nc-pulse{0%,to{opacity:.3}50%{opacity:1}}.nc-progress{background:var(--bg-active);border-radius:3px;width:100%;height:6px;margin-top:6px;overflow:hidden}.nc-progress-bar{background:#f0b232;border-radius:3px;width:0;height:100%;transition:width .15s ease-out}.nc-progress.indeterminate .nc-progress-bar{width:35%;animation:1.1s ease-in-out infinite nc-indeterminate}@keyframes nc-indeterminate{0%{transform:translate(-120%)}to{transform:translate(320%)}}.toggle-list{gap:8px;display:grid}.toggle-row{border:1px solid var(--border);background:var(--bg-card);color:var(--text);text-align:left;cursor:pointer;border-radius:4px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.toggle-row:hover{border-color:#4e5058}.toggle-row.active{border-color:var(--green)}.toggle-label{gap:2px;min-width:0;display:grid}.toggle-label strong{color:var(--text-bright);font-size:14px}.toggle-label small{color:var(--text-muted);font-size:12px}.toggle-state{color:var(--text-muted);flex:none;font-size:12px;font-weight:800}.toggle-row.active .toggle-state{color:var(--green)}.context-menu{z-index:60;background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;min-width:220px;padding:8px;position:fixed;box-shadow:0 8px 24px #00000080}.context-menu-title{color:var(--text-bright);border-bottom:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;margin-bottom:8px;padding:4px 6px 8px;font-size:13px;font-weight:700;overflow:hidden}.context-menu-volume{color:var(--text-muted);gap:6px;padding:4px 6px 8px;font-size:12px;display:grid}.context-menu-volume input{width:100%;accent-color:var(--accent);background:0 0;border:none;height:auto;padding:0}.context-menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px 6px;font-size:13px}.context-menu-item:hover{background:var(--accent);color:#fff}.pwa-banner{left:max(16px, env(safe-area-inset-left));right:max(16px, env(safe-area-inset-right));bottom:max(16px, env(safe-area-inset-bottom));z-index:70;border:1px solid var(--border);background:#111214;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;width:min(520px,100vw - 32px);margin:0 auto;padding:10px 12px;display:flex;position:fixed;box-shadow:0 12px 32px #00000061}.pwa-banner-copy{gap:2px;min-width:0;display:grid}.pwa-banner-copy strong{color:var(--text-bright);font-size:14px}.pwa-banner-copy small,.pwa-banner-copy p{color:var(--text-muted);margin:0;font-size:12px}.pwa-banner-copy p{color:var(--text);align-items:center;gap:4px;display:flex}.pwa-banner-actions{flex:none;align-items:center;gap:6px;display:flex}.soundboard-panel{z-index:60;border:1px solid var(--border);background:var(--bg-deep);border-radius:8px;flex-direction:column;gap:10px;width:300px;max-width:calc(100vw - 16px);padding:12px;display:flex;position:fixed;box-shadow:0 12px 32px #00000073}.soundboard-head{color:var(--text-muted);align-items:center;gap:8px;display:flex}.soundboard-head h3{min-width:0;color:var(--text-bright);flex:1;font-size:14px}.soundboard-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;max-height:280px;display:grid;overflow-y:auto}.soundboard-section{flex-direction:column;gap:6px;display:flex}.soundboard-section.queued{border-top:1px solid var(--border);padding-top:8px}.soundboard-section-title{text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:700}.soundboard-grid.queued-grid{max-height:160px}.soundboard-cell{min-width:0;position:relative}.soundboard-item{border:1px solid var(--border);background:var(--bg-card);width:100%;height:72px;color:var(--text);cursor:pointer;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:6px 4px;display:flex}.soundboard-item.queued{background:color-mix(in srgb, var(--bg-card) 86%, #faa61a);border-color:#faa61a73;height:86px}@media (hover:hover) and (pointer:fine){.soundboard-item:hover{border-color:var(--accent);background:var(--bg-active)}}.soundboard-item-emoji{font-size:22px;line-height:1}.soundboard-item-name{text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:11px;font-weight:600;overflow:hidden}.soundboard-delete-note{color:#faa61a;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:10px;font-weight:700;overflow:hidden}.soundboard-delete{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:50%;place-items:center;width:20px;height:20px;display:none;position:absolute;top:-6px;right:-6px}.soundboard-keep{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:50%;place-items:center;width:20px;height:20px;display:none;position:absolute;top:-6px;right:-6px}@media (hover:hover) and (pointer:fine){.soundboard-cell:hover .soundboard-delete,.soundboard-cell:hover .soundboard-keep{display:grid}}@media (hover:none),(pointer:coarse){.soundboard-delete,.soundboard-keep{display:grid}}.soundboard-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:10px;display:flex}.soundboard-protection{color:var(--text-muted);grid-template-columns:minmax(116px,auto) minmax(0,1fr) 34px;align-items:center;gap:8px;display:grid}.soundboard-protection-toggle{border:1px solid var(--border);background:var(--bg-card);min-width:0;height:30px;color:var(--text-muted);cursor:pointer;border-radius:6px;justify-content:flex-start;align-items:center;gap:6px;padding:0 8px;font-size:11px;font-weight:700;display:inline-flex}.soundboard-protection-toggle span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.soundboard-protection-toggle strong{color:var(--text)}.soundboard-protection.active .soundboard-protection-toggle{border-color:color-mix(in srgb, var(--green) 55%, var(--border));color:var(--green)}.soundboard-protection-control{align-items:center;min-width:0;height:20px;display:flex;position:relative}.soundboard-protection-track{background:#4e5058;border-radius:999px;width:100%;height:6px;position:relative}.soundboard-protection-fill{width:var(--sb-protection-percent);background:var(--green);border-radius:999px;position:absolute;top:0;bottom:0;left:0}.soundboard-protection-thumb{top:50%;left:var(--sb-protection-percent);background:var(--green);border-radius:50%;width:14px;height:14px;position:absolute;transform:translate(-50%,-50%)}.soundboard-protection-control input{cursor:pointer;opacity:0;background:0 0;border:none;width:100%;height:100%;margin:0;padding:0;position:absolute;inset:0}.soundboard-protection-control input:disabled{cursor:not-allowed}.soundboard-protection:not(.active) .soundboard-protection-track,.soundboard-protection:not(.active) .soundboard-protection-fill,.soundboard-protection:not(.active) .soundboard-protection-thumb{opacity:.45}.soundboard-protection-value{text-align:right;min-width:34px;font-size:11px;font-weight:700}.soundboard-volume{color:var(--text-muted);align-items:center;gap:8px;display:flex}.soundboard-volume-control{flex:1;align-items:center;height:20px;display:flex;position:relative}.soundboard-volume-track{background:#4e5058;border-radius:999px;width:100%;height:6px;position:relative}.soundboard-volume-fill{width:var(--sb-volume-percent);background:var(--accent);border-radius:999px;position:absolute;top:0;bottom:0;left:0}.soundboard-volume-thumb{top:50%;left:var(--sb-volume-percent);background:var(--accent);border-radius:50%;width:14px;height:14px;position:absolute;transform:translate(-50%,-50%)}.soundboard-volume-control input{cursor:pointer;opacity:0;background:0 0;border:none;width:100%;height:100%;margin:0;padding:0;position:absolute;inset:0}.soundboard-volume-value{text-align:right;min-width:34px;font-size:11px;font-weight:700}.soundboard-actions{align-items:center;gap:6px;display:flex}.soundboard-actions .utility-button{flex:1}.soundboard-upload-input{display:none}.soundboard-upload{border:1px solid var(--border);background:var(--bg-card);border-radius:6px;flex-direction:column;gap:8px;padding:10px;display:flex}.soundboard-file-button{justify-content:flex-start;overflow:hidden}.soundboard-upload-hint{color:var(--text-muted);font-size:11px}.soundboard-file-button span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.soundboard-emoji-label{text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:700}.soundboard-emoji-picker{grid-template-columns:repeat(8,1fr);gap:4px;max-height:96px;display:grid;overflow-y:auto}.soundboard-emoji{background:var(--bg-deep);cursor:pointer;border:1px solid #0000;border-radius:6px;place-items:center;height:30px;font-size:16px;display:grid}.soundboard-emoji:hover{background:var(--bg-active)}.soundboard-emoji.active{border-color:var(--accent);background:var(--bg-active)}.soundboard-upload-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.utility-button.compact.active{background:var(--accent);color:#fff}@media (width<=920px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.member-list{display:none}}@media (width<=640px){body{overflow:hidden}.app-shell{grid-template-rows:minmax(0,1fr) auto auto;grid-template-columns:1fr}.sidebar,.stage-column,.member-list{grid-area:1/1;min-height:0}.sidebar{max-height:none;display:none}.stage-column{display:none}.app-shell>.user-bar{grid-area:2/1;display:block}.member-list{border-left:none;padding:10px 8px;display:none}.app-shell[data-mobile-panel=channels] .sidebar,.app-shell[data-mobile-panel=voice] .stage-column{display:flex}.app-shell[data-mobile-panel=members] .member-list{display:block;overflow-y:auto}.nickname-prompt{display:none}.app-shell[data-mobile-panel=members] .nickname-prompt{left:8px;right:8px;bottom:calc(58px + env(safe-area-inset-bottom));width:auto;display:grid}.server-header,.stage-bar{height:50px;padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right))}.server-header small{max-width:min(210px,58vw)}.sidebar-scroll{padding:8px}.channel-row,.channel-select{min-height:42px}.channel-admin{display:flex}.user-bar{padding-bottom:env(safe-area-inset-bottom)}.voice-network-stats{grid-template-columns:auto repeat(2,minmax(0,max-content));max-width:calc(100vw - 16px)}.stage-empty{padding:0 22px}.stage-empty-icon{width:72px;height:72px}.stage-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:12px}.stage-tile{min-height:138px}.stage-controls{gap:4px}.screen-share-stage{padding:10px}.screen-share-frame{min-height:220px}.participant-rail{grid-auto-columns:minmax(132px,160px)}.modal-overlay{padding:12px;padding-bottom:max(12px, env(safe-area-inset-bottom));align-items:end}.modal{width:100%;max-height:min(88vh,680px)}.soundboard-panel{width:100%;max-width:none;padding-bottom:max(12px, env(safe-area-inset-bottom));border-radius:12px 12px 0 0;inset:auto 0 0!important}.soundboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));max-height:40vh}.mobile-nav{padding:6px max(8px, env(safe-area-inset-right)) max(6px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));border-top:1px solid var(--border);background:#232428;grid-area:3/1;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;display:grid}.mobile-nav-button{min-width:0;height:46px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;place-items:center;gap:2px;font-size:11px;font-weight:700;display:grid}.mobile-nav-button.active{background:var(--bg-active);color:var(--text-bright)}.pwa-banner{flex-direction:column;align-items:stretch}.pwa-banner-actions{justify-content:flex-end}}@media (width<=360px){.server-header,.stage-bar{padding-left:max(8px, env(safe-area-inset-left));padding-right:max(8px, env(safe-area-inset-right));gap:8px}.stage-title{gap:6px}.stage-controls{gap:2px}.voice-status-panel{padding:6px 8px}.account-bar{gap:4px;padding:6px}.account-avatar{width:28px;height:28px}.account-controls{gap:0}.icon-button{width:32px;height:32px}.mobile-nav{padding-left:max(4px, env(safe-area-inset-left));padding-right:max(4px, env(safe-area-inset-right));gap:2px}.mobile-nav-button{height:42px;font-size:10px}.stage-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));padding:8px}}
