:root{--bg-base: #07071a;--bg-main: #0a0a20;--bg-panel: #0d0d28;--bg-raised: #12123a;--bg-input: #0f0f2e;--glass: rgba(14, 14, 40, .75);--glass-border: rgba(255, 255, 255, .07);--glass-hover: rgba(255, 255, 255, .05);--glass-active: rgba(255, 255, 255, .09);--blue: #60a5fa;--blue-bright: #3b82f6;--purple: #a78bfa;--purple-bright: #8b5cf6;--gradient: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-soft: linear-gradient(135deg, rgba(59,130,246,.18) 0%, rgba(139,92,246,.18) 100%);--gradient-glow: linear-gradient(135deg, rgba(59,130,246,.35) 0%, rgba(139,92,246,.35) 100%);--glow-blue: rgba(96, 165, 250, .28);--glow-purple: rgba(167, 139, 250, .28);--glow-mixed: rgba(110, 120, 250, .22);--text: #e2e8f0;--text-dim: #6b7280;--text-mute: #374151;--online: #34d399;--online-glow: rgba(52, 211, 153, .35);--idle: #fbbf24;--error: #f87171;--error-dim: rgba(248,113,113,.18);--r-xs: 8px;--r-sm: 12px;--r-md: 18px;--r-lg: 24px;--r-xl: 32px;--r-full: 9999px;--ease: cubic-bezier(.4, 0, .2, 1);--spring: cubic-bezier(.34, 1.56, .64, 1);--t: .18s;--font: -apple-system, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-display: -apple-system, "SF Pro Display", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "SF Mono", "JetBrains Mono", ui-monospace, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg-base);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;background:none;font-family:inherit}input{font-family:inherit}.boot{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-dim);font-size:14px;letter-spacing:.06em}.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);position:relative;overflow-x:hidden;overflow-y:auto;padding:20px}.login-glow{position:fixed;border-radius:50%;pointer-events:none;filter:blur(80px);z-index:0}.login-glow-a{width:480px;height:480px;top:-120px;left:-80px;background:radial-gradient(circle,rgba(59,130,246,.14) 0%,transparent 70%)}.login-glow-b{width:420px;height:420px;bottom:-100px;right:-60px;background:radial-gradient(circle,rgba(139,92,246,.13) 0%,transparent 70%)}.login-card{position:relative;z-index:1;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:36px 32px 32px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:20px;box-shadow:0 32px 80px #0000008c,0 0 0 1px #ffffff08 inset}.login-header{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.login-title{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.04em;background:linear-gradient(135deg,#60a5fa,#c084fc 45%,#818cf8 75%,#60a5fa);background-size:250% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 12px rgba(96,165,250,.4)) drop-shadow(0 0 24px rgba(167,139,250,.2));animation:outpost-shimmer 5s ease-in-out infinite}.login-sub{color:var(--text-dim);font-size:13px;line-height:1.5}.login-fields{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:11.5px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}.login-card input{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:10px 14px;font-size:14px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease);outline:none}.login-card input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.login-card input::placeholder{color:var(--text-dim);opacity:.5}.login-totp-input{letter-spacing:.3em;font-size:20px!important;text-align:center}.login-error{color:var(--error);font-size:12.5px;font-weight:500;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:var(--r-sm);padding:8px 12px}.login-success{color:var(--online);font-size:12.5px;font-weight:500;background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:var(--r-sm);padding:8px 12px;line-height:1.5}.login-btn{width:100%;padding:11px;font-size:14px;font-weight:700}.login-back{background:none;border:none;cursor:pointer;padding:0;text-align:center;font-size:12px;color:var(--text-dim);transition:color var(--t) var(--ease)}.login-back:hover{color:var(--blue)}.login-consent{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;color:var(--text-dim);cursor:pointer;line-height:1.45}.login-consent input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--blue)}.login-tab-switch{text-align:center;font-size:13px;color:var(--text-dim);border-top:1px solid var(--glass-border);padding-top:16px;margin-top:-4px}.login-tab-switch button{background:none;border:none;cursor:pointer;padding:0;font-size:13px;font-weight:600;color:var(--blue);transition:opacity var(--t) var(--ease)}.login-tab-switch button:hover{opacity:.8}.shell{display:grid;grid-template-columns:340px 1fr;height:100vh;height:100dvh;overflow:hidden;background:radial-gradient(ellipse at 0% 0%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 100% 100%,rgba(139,92,246,.08) 0%,transparent 50%),var(--bg-base)}.nav-panel{display:flex;flex-direction:row;height:100%;overflow:hidden}.rail{background:#07071ae6;border-right:1px solid var(--glass-border);display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:8px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.rail-home{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--text-dim);background:#ffffff0a;border:1px solid var(--glass-border);text-decoration:none;transition:background var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease)}.rail-home:hover{background:var(--gradient-soft);color:var(--blue);border-color:#60a5fa4d;transform:translateY(-2px);box-shadow:0 4px 16px var(--glow-blue)}.rail-wordmark{font-family:var(--font-mono);font-size:7.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);opacity:.75;-webkit-user-select:none;user-select:none;text-align:center;line-height:1;margin-bottom:2px}.rail-mark{width:40px;height:40px;border-radius:var(--r-sm);background:var(--gradient);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:800;color:#fff;letter-spacing:.04em;box-shadow:0 4px 20px var(--glow-mixed)}.rail-divider{width:30px;height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent);margin:4px 0}.rail-guild{border-radius:50%;overflow:hidden;transition:border-radius var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--spring);box-shadow:0 2px 8px #0006}.rail-guild:hover{border-radius:var(--r-sm);transform:translateY(-2px) scale(1.04);box-shadow:0 6px 20px #00000080}.rail-guild.active{border-radius:var(--r-sm);box-shadow:0 0 0 2.5px var(--blue),0 6px 24px var(--glow-blue)}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0;-webkit-user-select:none;user-select:none;letter-spacing:-.02em}.sidebar{flex:1;min-width:0;background:var(--glass);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;min-height:0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.sidebar-header{flex-shrink:0;padding:18px 16px 14px;border-bottom:1px solid var(--glass-border)}.sidebar-guild-name{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.03em}.sidebar-outpost-brand{background:linear-gradient(135deg,#60a5fa,#c084fc 45%,#818cf8 75%,#60a5fa);background-size:250% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 10px rgba(96,165,250,.45)) drop-shadow(0 0 20px rgba(167,139,250,.2));animation:outpost-shimmer 5s ease-in-out infinite}@keyframes outpost-shimmer{0%{background-position:100% 0;filter:drop-shadow(0 0 10px rgba(96,165,250,.45)) drop-shadow(0 0 20px rgba(167,139,250,.2))}50%{background-position:0% 0;filter:drop-shadow(0 0 14px rgba(167,139,250,.6)) drop-shadow(0 0 24px rgba(96,165,250,.25))}to{background-position:100% 0;filter:drop-shadow(0 0 10px rgba(96,165,250,.45)) drop-shadow(0 0 20px rgba(167,139,250,.2))}}.sidebar-guild-sub{display:flex;align-items:center;gap:6px;margin-top:4px}.sidebar-status-text{font-size:11px;color:var(--text-dim)}.sidebar-nav-btn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 12px;margin:4px 8px;width:calc(100% - 16px);border-radius:var(--r-sm);color:var(--text-dim);font-size:14px;font-weight:600;transition:background var(--t) var(--ease),color var(--t) var(--ease)}.sidebar-nav-btn:hover{background:var(--glass-hover);color:var(--text)}.sidebar-nav-btn.active{background:var(--gradient-soft);color:var(--blue);border-left:2px solid var(--blue-bright)}.sidebar-nav-badge{margin-left:auto;min-width:18px;height:18px;border-radius:var(--r-full);background:var(--blue-bright);color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;padding:0 5px}.sidebar-nav-badge.pending{background:var(--error)}.sidebar-divider{height:1px;background:var(--glass-border);margin:4px 12px 8px}.sidebar-scroll{flex:1;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}.sidebar-scroll::-webkit-scrollbar{width:4px}.sidebar-scroll::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.sidebar-footer{flex-shrink:0;display:flex;flex-direction:column;gap:8px;padding:10px 12px 14px;border-top:1px solid var(--glass-border)}.sidebar-group{display:flex;flex-direction:column}.section-header{display:flex;align-items:center;gap:4px;width:100%;padding:5px 8px 5px 12px;color:var(--text-dim);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;transition:color var(--t) var(--ease)}.section-header:hover{color:var(--text)}.section-chevron{font-size:13px;transition:transform var(--t) var(--ease);display:inline-block;transform:rotate(0)}.section-chevron.open{transform:rotate(90deg)}.section-label{flex:1}.section-count{font-size:10px;font-weight:500;opacity:.65}.section-badge{min-width:17px;height:17px;border-radius:var(--r-full);background:var(--error);color:#fff;font-size:10px;font-weight:700;line-height:17px;text-align:center;padding:0 4px}.channel-list{display:flex;flex-direction:column;gap:2px;padding:2px 8px 8px}.channel{display:flex;align-items:center;gap:6px;width:100%;text-align:left;padding:7px 10px;border-radius:var(--r-sm);color:var(--text-dim);font-size:13.5px;font-weight:500;transition:background var(--t) var(--ease),color var(--t) var(--ease),padding-left var(--t) var(--ease)}.channel-hash{font-size:15px;font-weight:600;opacity:.45;line-height:1}.channel:hover{background:var(--glass-hover);color:var(--text);padding-left:14px}.channel.active{background:var(--gradient-soft);color:var(--blue);padding-left:14px;border-left:2px solid var(--blue-bright);box-shadow:inset 0 0 20px #3b82f60d}.sidebar-entries{display:flex;flex-direction:column;gap:2px;padding:2px 8px 8px}.sidebar-empty{padding:4px 10px;font-size:12px;color:var(--text-dim);font-style:italic}.avatar-wrap{position:relative;flex-shrink:0}.presence-ring{position:absolute;bottom:0;right:0;width:9px;height:9px;border-radius:50%;border:2px solid var(--bg-panel);background:var(--text-mute)}.presence-ring.online{background:var(--online);box-shadow:0 0 4px var(--online-glow)}.presence-ring.idle{background:var(--idle)}.presence-ring.dnd{background:var(--error)}.sidebar-friend{display:flex;align-items:center;gap:9px;padding:5px 10px;border-radius:var(--r-sm);transition:background var(--t) var(--ease)}.sidebar-friend:hover{background:var(--glass-hover)}.sidebar-friend-name{font-size:13px;font-weight:500;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.sidebar-friend:hover .sidebar-friend-name{color:var(--text)}.sidebar-pending{display:flex;align-items:center;gap:9px;padding:5px 10px;border-radius:var(--r-sm)}.sidebar-pending-actions{display:flex;gap:5px;margin-left:auto;flex-shrink:0}.pill-btn{width:24px;height:24px;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:transform var(--t) var(--spring),filter var(--t) var(--ease)}.pill-btn:hover{transform:scale(1.18);filter:brightness(1.2)}.pill-btn.accept{background:var(--online);color:#052e16}.pill-btn.reject{background:var(--error-dim);color:var(--error)}.sidebar-pending-label{font-size:10px;color:var(--text-dim);font-style:italic;margin-left:auto}.voice-mini-panel{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:#34d3990f;border:1px solid rgba(52,211,153,.18);border-radius:var(--r-sm);margin-bottom:6px;animation:slide-down .2s var(--ease)}.voice-mini-info{display:flex;align-items:center;gap:8px;min-width:0}.voice-mini-dot{width:8px;height:8px;border-radius:50%;background:var(--online);flex-shrink:0;box-shadow:0 0 6px var(--online-glow);animation:voice-pulse 2s ease-in-out infinite}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.5}}.voice-mini-text{min-width:0}.voice-mini-label{font-size:10.5px;font-weight:600;color:var(--online);letter-spacing:.04em;text-transform:uppercase}.voice-mini-channel{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-mini-controls{display:flex;gap:4px;flex-shrink:0}.voice-mini-btn{width:28px;height:28px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease)}.voice-mini-btn:hover{background:var(--glass-hover);color:var(--text)}.voice-mini-btn.active{color:var(--blue)}.voice-mini-btn.danger{color:var(--error)}.voice-mini-btn.danger:hover{background:var(--error-dim)}.user-bar-wrap{position:relative}.user-bar{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-sm);background:var(--glass-hover);border:1px solid var(--glass-border);cursor:pointer;transition:background var(--t) var(--ease),border-color var(--t) var(--ease);-webkit-user-select:none;user-select:none}.user-bar:hover,.user-bar.active{background:var(--glass-active);border-color:#ffffff1f}.user-bar-name{flex:1;font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-bar-chevron{color:var(--text-dim);flex-shrink:0;transition:transform var(--t) var(--ease)}.user-bar.active .user-bar-chevron{transform:rotate(180deg)}.idle-moon{margin-left:5px;font-size:.8em;opacity:.85;vertical-align:middle}.idle-moon-sub{color:var(--idle);font-size:10.5px;font-weight:500}.user-bar-avatar-wrap{position:relative;flex-shrink:0}.user-bar-status-dot{position:absolute;bottom:-1px;right:-1px;width:11px;height:11px;border:2px solid var(--bg-panel);border-radius:50%}.user-bar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199}.user-bar-popout{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:8px;box-shadow:0 -8px 40px #0009,0 0 0 1px #ffffff0a;z-index:200;animation:popout-up .18s var(--spring)}@keyframes popout-up{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.user-bar-popout-header{display:flex;align-items:center;gap:10px;padding:8px 8px 10px}.user-bar-popout-info{flex:1;min-width:0}.user-bar-popout-name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-bar-popout-tag{font-size:11.5px;color:var(--text-dim);margin-top:1px}.user-bar-popout-label{font-size:10.5px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;padding:4px 10px 6px}.status-picker{display:flex;flex-direction:column;gap:2px;margin-bottom:4px}.status-picker-btn{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border-radius:var(--r-sm);font-size:13px;font-weight:500;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease)}.status-picker-btn:hover{background:var(--glass-hover);color:var(--text)}.status-picker-btn.active{color:var(--text);background:var(--glass-hover);font-weight:600}.user-bar-popout-divider{height:1px;background:var(--glass-border);margin:0 0 6px}.user-bar-popout-item{display:flex;align-items:center;gap:9px;width:100%;padding:9px 10px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:var(--text);transition:background var(--t) var(--ease),color var(--t) var(--ease)}.user-bar-popout-item:hover{background:var(--glass-hover)}.user-bar-popout-item.danger{color:var(--error)}.user-bar-popout-item.danger:hover{background:var(--error-dim)}.btn{background:var(--gradient);color:#fff;border-radius:var(--r-sm);padding:9px 18px;font-size:13px;font-weight:600;box-shadow:0 2px 12px var(--glow-mixed);transition:transform var(--t) var(--spring),box-shadow var(--t) var(--ease),filter var(--t) var(--ease)}.btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--glow-mixed);filter:brightness(1.1)}.btn:active{transform:translateY(0);box-shadow:0 2px 8px var(--glow-mixed)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;filter:none}.btn.ghost{background:transparent;color:var(--text-dim);border:1px solid var(--glass-border);box-shadow:none;transition:background var(--t) var(--ease),color var(--t) var(--ease),border-color var(--t) var(--ease),transform var(--t) var(--spring)}.btn.ghost:hover{background:var(--glass-hover);color:var(--text);border-color:#ffffff24;transform:translateY(-1px)}.dot{width:8px;height:8px;border-radius:50%;background:var(--text-mute);flex-shrink:0;transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease)}.dot[data-status=connected]{background:var(--online);box-shadow:0 0 6px var(--online-glow);animation:pulse-dot 2.5s ease-in-out infinite}.dot[data-status=connecting]{background:var(--blue);animation:pulse-dot 1s ease-in-out infinite}.dot[data-status=error]{background:var(--error)}.dot[data-status=online]{background:var(--online);box-shadow:0 0 5px var(--online-glow)}.dot[data-status=idle]{background:var(--idle)}.dot[data-status=dnd]{background:var(--error)}.dot[data-status=invisible],.dot[data-status=offline]{background:var(--text-dim)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.add-friend-topbar{position:relative}.add-friend-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:min(280px,calc(100vw - 20px));background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:12px;box-shadow:0 16px 48px #0009;z-index:100;display:flex;flex-direction:column;gap:8px;animation:slide-down .15s var(--ease)}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.add-friend-form{display:flex;gap:8px}.add-friend-form input{flex:1;background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:8px 10px;font-size:13px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.add-friend-form input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.add-friend-form input::placeholder{color:var(--text-dim)}.friend-status{font-size:12px;color:var(--text-dim);padding:0 2px}.friend-status.ok{color:var(--online)}.friend-status.err{color:var(--error)}.main{display:flex;flex-direction:row;min-width:0;flex:1;background:var(--bg-main);position:relative;overflow:hidden}.chat-area{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden;position:relative}.topbar{height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#0a0a20d9;border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-channel{display:flex;align-items:center;gap:6px}.topbar-hash{font-size:22px;font-weight:300;color:var(--text-dim);line-height:1}.topbar-name{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em}.topbar-right{display:flex;align-items:center;gap:14px}.member-stack{display:flex;align-items:center;padding-left:10px}.member-overflow{width:30px;height:30px;border-radius:50%;background:var(--bg-raised);border:2px solid var(--bg-main);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-dim);margin-left:-10px}.status-chip{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-full);background:#ffffff0a;border:1px solid var(--glass-border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);transition:background var(--t) var(--ease),border-color var(--t) var(--ease)}.status-chip.connected{background:#34d39914;border-color:#34d3994d;color:var(--online)}.status-chip-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.status-chip.connected .status-chip-dot{animation:pulse-dot 2s ease-in-out infinite}.messages{flex:1;overflow-y:auto;padding:20px 28px 12px;display:flex;flex-direction:column;gap:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-thumb{background:#ffffff12;border-radius:4px}.empty-state{margin:auto;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-dim);text-align:center}.empty-icon{font-size:36px;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.6}.empty-title{font-size:16px;font-weight:600;color:var(--text-dim)}.empty-sub{font-size:13px;color:var(--text-mute)}.welcome-screen{flex:1;display:flex;flex-direction:column;animation:welcome-fade .5s var(--ease)}.welcome-topbar{display:none;height:52px;align-items:center;padding:0 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0}.welcome-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:24px 20px}.welcome-open-sidebar{display:none;align-items:center;gap:8px;margin-top:8px;padding:11px 24px;background:var(--blue);color:#fff;border:none;border-radius:var(--r-md);font-size:14px;font-weight:600;cursor:pointer;transition:opacity var(--t) var(--ease)}.welcome-open-sidebar:hover{opacity:.85}@keyframes welcome-fade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-logo{width:72px;height:72px;border-radius:22px;box-shadow:0 0 32px #60a5fa40,0 0 64px #a78bfa1f;opacity:.92}.welcome-title{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.04em;background:linear-gradient(135deg,#60a5fa,#c084fc 45%,#818cf8 75%,#60a5fa);background-size:250% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 12px rgba(96,165,250,.4)) drop-shadow(0 0 24px rgba(167,139,250,.2));animation:outpost-shimmer 5s ease-in-out infinite}.welcome-sub{font-size:14px;color:var(--text-dim);max-width:260px;line-height:1.55}.friends-page{flex:1;overflow-y:auto;padding:28px 32px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}.friends-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-dim);margin-bottom:12px;display:flex;align-items:center;gap:8px}.friends-badge{min-width:18px;height:18px;border-radius:var(--r-full);background:var(--error);color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;padding:0 5px}.friends-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.friend-card{display:flex;align-items:center;gap:14px;padding:10px 14px;border-radius:var(--r-sm);transition:background var(--t) var(--ease)}.friend-card:hover{background:var(--glass-hover)}.friend-card-avatar{position:relative;flex-shrink:0}.friend-card-info{flex:1;min-width:0}.friend-card-name{font-size:15px;font-weight:600;color:var(--text)}.friend-card-status{font-size:12px;color:var(--text-dim);margin-top:1px;text-transform:capitalize}.friend-card-status.online{color:var(--online)}.friend-card-status.idle{color:var(--idle)}.friend-card-status.dnd{color:var(--error)}.presence-ring.large{width:14px;height:14px;bottom:-2px;right:-2px;border-width:2px}.friend-request-row{display:flex;align-items:center;gap:14px;padding:10px 14px;border-radius:var(--r-sm);background:#ffffff05;border:1px solid var(--glass-border);margin-bottom:6px}.friend-request-info{flex:1;min-width:0}.friend-request-actions{display:flex;gap:8px;flex-shrink:0}:root{--font-size-msg: 15px;--msg-padding: 2px 16px;--msg-gap: 16px}.msg-row{display:flex;gap:16px;padding:var(--msg-padding);border-radius:var(--r-xs);transition:background var(--t) var(--ease);position:relative}.msg-row:not(.grouped){margin-top:var(--msg-gap)}.msg-row:hover{background:#ffffff08}.msg-avatar-col{width:40px;flex-shrink:0;display:flex;align-items:flex-start;justify-content:center;padding-top:1px}.msg-hover-time{font-size:10px;color:transparent;white-space:nowrap;padding-top:4px;font-family:var(--font-mono)}.msg-row:hover .msg-hover-time{color:var(--text-dim)}.msg-body{flex:1;min-width:0}.msg-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.msg-author{font-size:15px;font-weight:700;letter-spacing:-.01em}.msg-row.mine .msg-author{color:var(--blue)!important}.msg-time{font-size:11px;color:var(--text-dim);font-family:var(--font-mono)}.msg-content{font-size:var(--font-size-msg);line-height:1.55;color:var(--text);white-space:pre-wrap;word-break:break-word}.msg-row.mine .msg-content{color:#c7d8ff}.topbar-topic{font-size:13px;color:var(--text-dim);padding-left:12px;margin-left:12px;border-left:1px solid var(--glass-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.composer-wrap{flex-shrink:0;padding:0 16px 20px}.composer{display:flex;align-items:center;gap:10px;padding:6px 6px 6px 16px;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--r-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 4px 24px #0000004d,0 0 0 1px #ffffff08 inset;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.composer:focus-within{border-color:#60a5fa59;box-shadow:0 4px 24px #0000004d,0 0 0 3px #60a5fa1a}.composer-attach{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-dim);background:#ffffff0f;transition:background var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--spring)}.composer-attach:hover{background:#ffffff1a;color:var(--text);transform:rotate(45deg)}.composer-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14.5px;line-height:1.5;caret-color:var(--blue);resize:none;overflow-y:auto;max-height:200px;padding:0;font-family:inherit;scrollbar-width:none}.composer-input::-webkit-scrollbar{display:none}.composer-input::placeholder{color:var(--text-dim)}.composer-input:disabled{cursor:not-allowed}.composer-send{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff0f;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease)}.composer-send.ready{background:var(--gradient);color:#fff;box-shadow:0 2px 12px var(--glow-mixed)}.composer-send.ready:hover{transform:scale(1.1);box-shadow:0 4px 20px var(--glow-mixed);filter:brightness(1.1)}.composer-send:disabled{opacity:.35;cursor:not-allowed}.settings-page{flex:1;overflow-y:auto;padding:32px 40px;display:flex;flex-direction:column;gap:28px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent;max-width:680px}.settings-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:8px}.settings-card{background:#ffffff08;border:1px solid var(--glass-border);border-radius:var(--r-md);overflow:hidden}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 20px}.settings-row-info{flex:1;min-width:0}.settings-row-label{font-size:14px;font-weight:600;color:var(--text)}.settings-row-sub{font-size:12px;color:var(--text-dim);margin-top:2px}.settings-row-value{display:flex;align-items:center;gap:10px;margin-top:6px}.settings-divider{height:1px;background:var(--glass-border);margin:0 20px}.settings-badge{font-size:11px;font-weight:700;color:var(--text-dim);background:#ffffff0f;border:1px solid var(--glass-border);border-radius:var(--r-full);padding:3px 10px;white-space:nowrap}.accent-swatches{display:flex;gap:8px}.swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;transition:transform var(--t) var(--spring),border-color var(--t) var(--ease);flex-shrink:0}.swatch:hover{transform:scale(1.15)}.swatch.active{border-color:#fff;box-shadow:0 0 0 2px #fff3;transform:scale(1.15)}.seg-control{display:flex;border:1px solid var(--glass-border);border-radius:var(--r-sm);overflow:hidden;flex-shrink:0}.seg-btn{padding:7px 14px;font-size:12px;font-weight:600;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease)}.seg-btn+.seg-btn{border-left:1px solid var(--glass-border)}.seg-btn:hover{background:var(--glass-hover);color:var(--text)}.seg-btn.active{background:var(--gradient);color:#fff}.toggle{width:44px;height:26px;border-radius:var(--r-full);background:#ffffff1a;border:1px solid var(--glass-border);position:relative;flex-shrink:0;transition:background var(--t) var(--ease),border-color var(--t) var(--ease)}.toggle.on{background:var(--gradient);border-color:transparent;box-shadow:0 0 10px var(--glow-mixed)}.toggle:disabled{opacity:.4;cursor:not-allowed}.toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#ffffff80;transition:left var(--t) var(--spring),background var(--t) var(--ease)}.toggle.on .toggle-thumb{left:21px;background:#fff}.slider-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0}.audio-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:130px;height:4px;border-radius:2px;background:#ffffff1f;outline:none;cursor:pointer}.audio-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--gradient);cursor:pointer;box-shadow:0 0 6px var(--glow-mixed);transition:transform var(--t) var(--spring)}.audio-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.audio-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;border:none;background:var(--blue-bright);cursor:pointer}.slider-label{font-size:12px;font-weight:600;color:var(--text-dim);width:34px;text-align:right;font-family:var(--font-mono)}.audio-select{background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text);font-size:13px;padding:7px 10px;border-radius:var(--r-sm);max-width:200px;cursor:pointer;transition:border-color var(--t) var(--ease),background var(--t) var(--ease)}.audio-select:hover{border-color:#ffffff2e;background:#ffffff14}.audio-select option{background:#1a1a3e;color:var(--text)}.test-sound-btn{font-size:11px;font-weight:600;color:var(--blue);padding:3px 10px;border-radius:var(--r-full);border:1px solid rgba(96,165,250,.3);background:#60a5fa14;transition:background var(--t) var(--ease),border-color var(--t) var(--ease);margin-top:4px}.test-sound-btn:hover{background:#60a5fa2e;border-color:#60a5fa80}.voice-channel-row{display:flex;align-items:center;justify-content:space-between;padding:0!important;background:none!important;border-left:none!important}.voice-channel-row.active .voice-channel-name{color:var(--blue)}.voice-channel-name{flex:1;display:flex;align-items:center;gap:7px;padding:7px 10px;border-radius:var(--r-sm);color:var(--text-dim);font-size:13.5px;font-weight:500;text-align:left;width:100%;transition:background var(--t) var(--ease),color var(--t) var(--ease)}.voice-channel-name:hover{background:var(--glass-hover);color:var(--text)}.voice-leave-mini{font-size:11px;color:var(--error);margin-right:8px;padding:2px 6px;border-radius:var(--r-xs);transition:background var(--t) var(--ease);flex-shrink:0}.voice-leave-mini:hover{background:var(--error-dim)}.voice-connecting-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:10px 24px;background:#34d39914;border-bottom:1px solid rgba(52,211,153,.2);font-size:13px;color:var(--online)}.voice-connecting-dot{width:8px;height:8px;border-radius:50%;background:var(--online);animation:pulse-dot 1s ease-in-out infinite}.voice-cancel-btn{margin-left:auto;font-size:12px;color:var(--text-dim);padding:3px 10px;border-radius:var(--r-full);border:1px solid var(--glass-border);transition:background var(--t) var(--ease)}.voice-cancel-btn:hover{background:var(--glass-hover)}.voice-room-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:var(--bg-main);display:flex;flex-direction:column}.voice-room{flex:1;display:flex;flex-direction:column;min-height:0;padding-bottom:8px}.voice-header{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:16px 24px;border-bottom:1px solid var(--glass-border);background:#0a0a20d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.voice-header-icon{font-size:20px}.voice-header-name{font-size:17px;font-weight:700;color:var(--text);flex:1}.voice-status{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);padding:4px 10px;border-radius:var(--r-full);border:1px solid var(--glass-border)}.voice-status.live{color:var(--online);border-color:#34d3994d;background:#34d39914}.voice-grid{flex:1;overflow:auto;display:grid;gap:12px;padding:20px;align-content:start;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.participant-tile{--speak-hue: 140;--speak-glow: 0px;--speak-opacity: 0;--speak-border: 0;background:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--r-md);overflow:hidden;position:relative;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}.participant-tile:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;border:2px solid hsla(var(--speak-hue),80%,55%,var(--speak-border));box-shadow:0 0 var(--speak-glow) hsla(var(--speak-hue),80%,55%,var(--speak-opacity)),inset 0 0 calc(var(--speak-glow) * .4) hsla(var(--speak-hue),80%,55%,calc(var(--speak-opacity) * .2));pointer-events:none;z-index:2}.participant-video{width:100%;height:100%;object-fit:cover}.participant-avatar-large{width:72px;height:72px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;box-shadow:0 4px 20px var(--glow-mixed)}.participant-info{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:linear-gradient(transparent,#000000a6);display:flex;align-items:center;gap:6px}.participant-name{font-size:13px;font-weight:600;color:#fff}.participant-muted{font-size:14px}.voice-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.voice-controls{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-top:1px solid var(--glass-border);background:#0a0a20e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.vc-ctrl-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;border-radius:10px;background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-dim);font-size:10px;font-weight:600;letter-spacing:.02em;min-width:64px;transition:background var(--t) var(--ease),color var(--t) var(--ease),border-color var(--t) var(--ease),transform var(--t) var(--spring)}.vc-ctrl-btn:hover{background:#ffffff17;color:var(--text);transform:translateY(-1px)}.vc-ctrl-btn.active{background:#60a5fa24;border-color:#60a5fa59;color:var(--blue)}.vc-ctrl-btn.active:hover{background:#60a5fa38}.vc-ctrl-btn.danger{background:#f871711a;border-color:#f8717147;color:var(--error)}.vc-ctrl-btn.danger:hover{background:#f8717138;border-color:#f8717180;transform:translateY(-1px)}.vc-ctrl-btn.leave{min-width:56px}.soundboard{flex-shrink:0;background:var(--bg-panel);border-top:1px solid var(--glass-border);padding:10px 14px 8px;max-height:180px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}.soundboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.soundboard-title{font-size:10px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.soundboard-upload-btn{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-full);background:#ffffff12;border:1px solid var(--glass-border);color:var(--text-dim);font-size:10.5px;font-weight:600;cursor:pointer;transition:background var(--t) var(--ease),color var(--t) var(--ease)}.soundboard-upload-btn:hover{background:#ffffff1c;color:var(--text)}.soundboard-upload-btn.loading{opacity:.5;pointer-events:none}.soundboard-err{font-size:11px;color:var(--error);margin-bottom:6px;padding:4px 8px;border-radius:var(--r-sm);background:#f8717112;border:1px solid rgba(248,113,113,.18)}.soundboard-empty{font-size:11.5px;color:var(--text-dim);text-align:center;padding:8px 0 4px}.soundboard-grid{display:flex;flex-wrap:wrap;gap:5px}.soundboard-clip{display:flex;align-items:center;border-radius:var(--r-full);background:linear-gradient(135deg,#60a5fa1f,#c084fc1f 45%,#818cf81f 75%,#60a5fa1f);background-size:250% 100%;border:1px solid rgba(96,165,250,.25);overflow:hidden;animation:outpost-shimmer 5s ease-in-out infinite}.soundboard-clip:hover{border-color:#a78bfa73;filter:brightness(1.15)}.soundboard-clip.playing{background:linear-gradient(135deg,#60a5fa38,#c084fc38 45%,#818cf838 75%,#60a5fa38);background-size:250% 100%;border-color:#60a5fa80;animation:outpost-shimmer 2.5s ease-in-out infinite}.soundboard-play-area{display:flex;align-items:center;gap:5px;padding:4px 6px 4px 9px;flex:1;min-width:0}.soundboard-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-dim);transition:color var(--t) var(--ease)}.soundboard-clip:hover .soundboard-icon,.soundboard-clip.playing .soundboard-icon{color:var(--blue)}.soundboard-name{font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.soundboard-delete{display:flex;align-items:center;justify-content:center;padding:4px 8px 4px 3px;flex-shrink:0;color:var(--text-dim);opacity:0;transition:opacity var(--t) var(--ease),color var(--t) var(--ease)}.soundboard-clip:hover .soundboard-delete{opacity:.55}.soundboard-delete:hover{opacity:1!important;color:var(--error)}.msg-row{position:relative}.msg-row:hover .msg-actions{opacity:1;pointer-events:auto}.msg-actions{position:absolute;top:-2px;right:12px;display:flex;align-items:center;gap:2px;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:2px;opacity:0;pointer-events:none;transition:opacity .12s var(--ease);z-index:10}.msg-act-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease)}.msg-act-btn:hover{background:var(--glass-hover);color:var(--text)}.msg-act-btn.danger:hover{background:var(--error-dim);color:var(--error)}.dm-call-btn:hover{color:#34d399}.dm-call-btn.active{color:var(--error)}.dm-call-btn.active:hover{background:var(--error-dim);color:var(--error)}.incoming-call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .15s var(--ease)}.incoming-call-card{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:24px;padding:36px 48px 32px;box-shadow:0 40px 100px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .2s var(--ease);min-width:240px}.incoming-call-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.incoming-call-avatar{position:relative;width:96px;height:96px;margin:8px 0}.incoming-call-avatar-img{width:96px;height:96px;border-radius:50%;object-fit:cover;display:block;position:relative;z-index:2}.incoming-call-avatar-fallback{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:800;color:#fff;position:relative;z-index:2}.incoming-call-ring-1,.incoming-call-ring-2{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid rgba(96,165,250,.35);animation:callRing 2s ease-out infinite;z-index:1}.incoming-call-ring-1{width:130px;height:130px;animation-delay:0s}.incoming-call-ring-2{width:164px;height:164px;animation-delay:.7s}@keyframes callRing{0%{transform:translate(-50%,-50%) scale(.85);opacity:.7}to{transform:translate(-50%,-50%) scale(1.1);opacity:0}}.incoming-call-name{font-size:20px;font-weight:800;color:var(--text)}.incoming-call-actions{display:flex;gap:24px;margin-top:8px}.incoming-call-btn{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .12s var(--ease),filter .12s var(--ease)}.incoming-call-btn:hover{transform:scale(1.1);filter:brightness(1.2)}.incoming-call-btn:active{transform:scale(.94)}.incoming-call-btn.decline{background:#ef4444;color:#fff}.incoming-call-btn.accept{background:#22c55e;color:#fff}.msg-edit-wrap{display:flex;flex-direction:column;gap:6px;margin-top:2px}.msg-edit-input{width:100%;min-height:60px;max-height:200px;background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-xs);color:var(--text);font:inherit;font-size:var(--font-size-msg, 15px);padding:8px 12px;resize:vertical;outline:none}.msg-edit-input:focus{border-color:var(--blue-bright);box-shadow:0 0 0 2px #3b82f626}.msg-edit-actions{display:flex;gap:6px;justify-content:flex-end}.msg-edited{font-size:11px;color:var(--text-dim);margin-left:4px}.msg-attachments{display:flex;flex-direction:column;gap:6px;margin-top:6px}.msg-attachment-img-wrap{display:inline-block;border-radius:var(--r-xs);overflow:hidden}.msg-attachment-img{display:block;border-radius:var(--r-xs);max-width:min(400px,calc(100vw - 80px));max-height:300px;object-fit:contain;background:var(--bg-raised)}.msg-attachment-file{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-xs);color:var(--text-dim);font-size:13px;text-decoration:none;transition:background var(--t) var(--ease)}.msg-attachment-file:hover{background:var(--glass-hover);color:var(--text)}.msg-attachment-size{font-size:11px;color:var(--text-mute);margin-left:4px}.msg-receipts{display:flex;align-items:center;gap:3px;margin-top:3px}.msg-receipts.dm-receipt{justify-content:flex-end;gap:5px}.msg-receipt-seen{font-size:11px;color:var(--text-mute);letter-spacing:.01em}.msg-receipts.group-receipt{justify-content:flex-end;gap:2px}.receipt-avatar-wrap{display:inline-flex;align-items:center;justify-content:center;animation:receiptDrop .22s var(--ease) both}.receipt-avatar-wrap .avatar{box-shadow:0 0 0 1.5px var(--bg-panel);border-radius:50%}@keyframes receiptDrop{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.msg-mention{background:#5865f22e;color:#a5b4fc;border-radius:3px;padding:0 2px}.msg-mention.me{background:#5865f259;color:#c7d0ff;font-weight:600}.mention-dropdown{position:relative;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-md);box-shadow:0 -8px 24px #00000080;overflow:hidden;max-height:240px;overflow-y:auto;margin:0 8px 4px;animation:slideUp .1s var(--ease)}.mention-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background var(--t)}.mention-item:hover,.mention-item.active{background:var(--glass-hover)}.mention-item-name{font-size:14px;font-weight:600;color:var(--text);flex-shrink:0}.mention-item-tag{font-size:12px;color:var(--text-dim);margin-left:auto}.conn-banner{position:fixed;top:0;left:0;right:0;z-index:2000;display:flex;align-items:center;justify-content:center;gap:8px;padding:7px 16px;background:var(--error);color:#fff;font-size:13px;font-weight:500;animation:slideDown .2s var(--ease)}.conn-banner.reconnecting{background:#b5841a}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.conn-banner-dot{width:7px;height:7px;border-radius:50%;background:#fff;opacity:.7;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}.quick-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;animation:fadeIn .1s var(--ease)}.quick-switcher{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);width:520px;max-width:94vw;box-shadow:0 24px 60px #000000b3;overflow:hidden;animation:slideUp .15s var(--ease)}.quick-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--glass-border)}.quick-search-icon{color:var(--text-mute);flex-shrink:0}.quick-input{flex:1;background:none;border:none;outline:none;font-size:16px;color:var(--text)}.quick-input::placeholder{color:var(--text-mute)}.quick-hint{font-size:11px;color:var(--text-mute);white-space:nowrap}.quick-list{max-height:360px;overflow-y:auto;padding:6px}.quick-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-sm);width:100%;text-align:left;transition:background var(--t)}.quick-item:hover,.quick-item.active{background:var(--glass-hover)}.quick-item-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-mute)}.quick-item-label{font-size:14px;color:var(--text);font-weight:500;flex:1}.quick-item-sub{font-size:11px;color:var(--text-mute)}.quick-empty{padding:24px;text-align:center;color:var(--text-mute);font-size:13px}.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.msg-reaction{display:inline-flex;align-items:center;gap:4px;padding:1px 8px;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-full);font-size:14px;color:var(--text-dim);transition:background var(--t) var(--ease),border-color var(--t) var(--ease)}.msg-reaction:hover{background:var(--glass-hover);border-color:#60a5fa4d;color:var(--text)}.msg-reaction.mine{background:#60a5fa1f;border-color:#60a5fa66;color:var(--blue)}.emoji-picker{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:6px;display:flex;flex-wrap:wrap;gap:2px;width:min(200px,calc(100vw - 24px));box-shadow:0 8px 24px #00000080;z-index:100}.emoji-opt{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:20px;transition:background var(--t) var(--ease)}.emoji-opt:hover{background:var(--glass-hover)}.emoji-opt.active{background:#60a5fa26}.typing-bar{display:flex;align-items:center;gap:8px;padding:2px 16px 6px;font-size:12px;color:var(--text-dim);min-height:20px}.typing-dots{display:flex;align-items:center;gap:3px}.typing-dots span{width:5px;height:5px;background:var(--text-dim);border-radius:50%;animation:typing-bounce 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.dm-channel{display:flex;align-items:center;gap:8px;font-size:13.5px}.dm-channel-avatar-wrap{position:relative;flex-shrink:0}.dm-presence{position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;border-radius:50%;border:1.5px solid var(--bg-panel)}.dm-presence.online{background:var(--online)}.dm-presence.idle{background:var(--idle)}.dm-presence.dnd{background:var(--error)}.friend-card-actions{margin-top:8px;display:flex;justify-content:center}.member-panel{width:240px;flex-shrink:0;background:#07071ae6;border-left:1px solid var(--glass-border);display:flex;flex-direction:column;overflow-y:auto;padding:8px 0}.member-panel-head{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);padding:10px 12px 4px}.member-section-label{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);padding:12px 12px 4px;opacity:.7}.member-row{display:flex;align-items:center;gap:8px;padding:3px 8px;border-radius:var(--r-xs);margin:0 4px;cursor:default;transition:background var(--t) var(--ease)}.member-row:hover{background:var(--glass-hover)}.member-row.offline{opacity:.4}.member-avatar-wrap{position:relative;flex-shrink:0}.member-presence{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;border:2px solid var(--bg-base)}.member-presence.online{background:var(--online)}.member-presence.idle{background:var(--idle)}.member-presence.dnd{background:var(--error)}.member-name{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-sep{display:flex;align-items:center;gap:8px;padding:12px 16px 4px}.date-sep-line{flex:1;height:1px;background:var(--glass-border)}.date-sep-label{font-size:11px;color:var(--text-dim);white-space:nowrap;font-weight:600}.msg-reply-ref{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-dim);margin-bottom:3px;cursor:pointer;overflow:hidden;white-space:nowrap}.msg-reply-author{font-weight:600;color:var(--blue);flex-shrink:0}.msg-reply-content{overflow:hidden;text-overflow:ellipsis;opacity:.75}.reply-banner{display:flex;align-items:center;gap:8px;padding:6px 16px;background:#60a5fa14;border-top:1px solid rgba(96,165,250,.2);font-size:13px;color:var(--text-dim)}.reply-banner svg{flex-shrink:0;opacity:.6}.reply-banner strong{color:var(--blue)}.reply-banner-preview{opacity:.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.reply-banner-close{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:11px;color:var(--text-dim);transition:background var(--t) var(--ease)}.reply-banner-close:hover{background:var(--glass-hover);color:var(--text)}.pending-files{display:flex;flex-wrap:wrap;gap:8px;padding:8px 16px 0}.pending-file{display:flex;align-items:center;gap:6px;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-xs);padding:4px 8px;font-size:12px;color:var(--text-dim);max-width:220px}.pending-file-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}.pending-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.pending-file-remove{flex-shrink:0;font-size:10px;opacity:.5;transition:opacity var(--t)}.pending-file-remove:hover{opacity:1}.load-more-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px}.load-more-dot{width:6px;height:6px;border-radius:50%;background:var(--text-dim);opacity:.4;animation:typing-bounce 1.2s ease-in-out infinite}.load-more-dot:nth-child(2){animation-delay:.2s}.load-more-dot:nth-child(3){animation-delay:.4s}.msg-code{font-family:var(--font-mono);font-size:.88em;background:#00000059;border:1px solid var(--glass-border);border-radius:4px;padding:1px 5px;color:var(--blue)}.msg-code-block{font-family:var(--font-mono);font-size:13px;background:#0006;border:1px solid var(--glass-border);border-radius:var(--r-xs);padding:10px 14px;margin:4px 0;overflow-x:auto;white-space:pre;color:var(--text)}.msg-code-lang{display:block;font-size:10px;color:var(--text-dim);margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}.msg-link{color:var(--blue);text-decoration:underline;text-underline-offset:2px}.msg-link:hover{color:var(--blue-bright)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 24px 24px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;animation:fadeIn .12s var(--ease)}.modal-backdrop>*{margin:auto}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}.modal-close-btn{width:30px;height:30px;border-radius:50%;background:#ffffff0f;display:flex;align-items:center;justify-content:center;color:var(--text);opacity:.7;flex-shrink:0;transition:opacity var(--t) var(--ease),background var(--t) var(--ease)}.modal-close-btn:hover{opacity:1;background:#ffffff1a}.profile-edit-modal{display:flex;flex-direction:row;width:780px;max-width:96vw;max-height:88vh;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .18s var(--ease)}.profile-edit-preview{width:260px;flex-shrink:0;background:var(--bg-base);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;padding:20px 16px;gap:12px;overflow-y:auto}.pep-label{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute)}.pep-card{background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-md);overflow:hidden}.pep-banner{height:90px;position:relative;overflow:hidden}.pep-banner-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:6px;background:#0000;transition:background var(--t)}.pep-banner:hover .pep-banner-actions{background:#00000080}.pep-media-btn{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#fff;background:#0009;border:1px solid rgba(255,255,255,.2);border-radius:var(--r-xs);padding:4px 9px;opacity:0;transition:opacity var(--t),background var(--t)}.pep-banner:hover .pep-media-btn{opacity:1}.pep-media-btn:hover{background:#000000d9}.pep-media-btn.danger{color:var(--error)}.pep-avatar-seam{display:flex;align-items:flex-end;gap:10px;padding:0 14px;margin-top:-36px}.pep-avatar-wrap{position:relative;flex-shrink:0}.pep-avatar-img,.pep-avatar-fallback{width:72px;height:72px;border-radius:50%;border:4px solid var(--bg-raised);object-fit:cover;display:block}.pep-avatar-fallback{display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:#fff}.pep-avatar-edit{position:absolute;bottom:2px;right:0;width:22px;height:22px;border-radius:50%;background:var(--bg-panel);border:2px solid var(--bg-raised);display:flex;align-items:center;justify-content:center;color:var(--text-dim);opacity:0;transition:opacity var(--t),background var(--t),color var(--t)}.pep-avatar-wrap:hover .pep-avatar-edit{opacity:1}.pep-avatar-edit:hover{background:var(--blue);color:#fff}.pep-remove-avatar{font-size:11px;color:var(--error);opacity:.7;align-self:flex-end;margin-bottom:4px;font-weight:500;transition:opacity var(--t)}.pep-remove-avatar:hover{opacity:1}.pep-info{padding:8px 12px 14px}.pep-display-name{font-size:15px;font-weight:700;color:var(--text)}.pep-tag{font-size:11.5px;color:var(--text-dim);margin-top:1px}.pep-pronouns{font-size:11.5px;color:var(--text-dim);margin-top:4px;font-style:italic}.pep-bio{font-size:12px;color:var(--text-dim);margin-top:8px;line-height:1.5;word-break:break-word}.profile-edit-form-panel{flex:1;display:flex;flex-direction:column;min-width:0}.profile-edit-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--glass-border);flex-shrink:0}.profile-edit-tabs{display:flex;gap:2px}.pe-tab{font-size:13.5px;font-weight:600;color:var(--text-dim);padding:6px 14px;border-radius:var(--r-sm);transition:background var(--t),color var(--t)}.pe-tab:hover{color:var(--text);background:var(--glass-hover)}.pe-tab.active{color:var(--text);background:var(--glass-active)}.profile-edit-body{overflow-y:auto;flex:1;padding:20px}.pe-form{display:flex;flex-direction:column;gap:14px}.pe-section-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);margin-bottom:2px}.pe-divider{height:1px;background:var(--glass-border);margin:6px 0}.pe-field{display:flex;flex-direction:column;gap:5px}.pe-label{font-size:12px;font-weight:600;color:var(--text-dim);display:flex;justify-content:space-between}.pe-required{font-size:11px;color:var(--error);font-weight:400;opacity:.8}.pe-hint{font-size:11px;color:var(--text-mute)}.pe-input{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:9px 12px;font-size:14px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.pe-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.pe-input::placeholder{color:var(--text-mute)}.pe-textarea{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:9px 12px;font-size:14px;resize:vertical;line-height:1.55;font-family:var(--font);transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.pe-textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.pe-textarea::placeholder{color:var(--text-mute)}.pe-username-row{display:flex;align-items:center;gap:6px}.pe-username-row .pe-input{flex:1}.pe-hash{color:var(--text-dim);font-size:16px}.pe-tag-input{width:72px;flex:none;text-align:center;letter-spacing:.1em}.pe-swatches{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pe-swatch{width:26px;height:26px;border-radius:50%;flex-shrink:0;border:2px solid transparent;transition:transform var(--t) var(--spring),border-color var(--t)}.pe-swatch:hover{transform:scale(1.15)}.pe-swatch.active{border-color:#fff;transform:scale(1.15)}.pe-color-input{width:26px;height:26px;border-radius:50%;border:2px solid var(--glass-border);overflow:hidden;cursor:pointer;padding:0;background:none}.pe-color-input::-webkit-color-swatch-wrapper{padding:0}.pe-color-input::-webkit-color-swatch{border:none;border-radius:50%}.pe-clear-color{font-size:11px;color:var(--text-dim);padding:4px 9px;border:1px solid var(--glass-border);border-radius:var(--r-xs);transition:color var(--t),border-color var(--t)}.pe-clear-color:hover{color:var(--error);border-color:var(--error-dim)}.profile-edit-footer{padding:12px 20px;border-top:1px solid var(--glass-border);display:flex;align-items:center;gap:10px;flex-shrink:0}.pe-footer-actions{display:flex;gap:8px;margin-left:auto}.pe-error{font-size:12px;color:var(--error)}.pe-success{font-size:12px;color:var(--online)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);display:flex;align-items:center;gap:6px}.form-hint-inline{font-weight:400;text-transform:none;letter-spacing:0}.form-hint{font-size:11px;color:var(--text-dim);opacity:.7}.form-input{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:9px 12px;font-size:14px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.form-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.form-textarea{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:9px 12px;font-size:14px;resize:vertical;line-height:1.5;font-family:var(--font);transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.form-textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.form-error{font-size:12px;color:var(--error)}.form-success{font-size:12px;color:var(--online)}img.avatar{border-radius:50%}.login-logo{width:120px;height:120px;object-fit:contain;border-radius:var(--r-md);display:block;margin:0 auto 4px}.rail-logo-btn{width:46px;height:46px;border-radius:var(--r-sm);overflow:hidden;padding:0;display:flex;align-items:center;justify-content:center;transition:transform var(--t) var(--spring),box-shadow var(--t) var(--ease);box-shadow:0 2px 10px #00000080}.rail-logo-btn:hover{transform:translateY(-2px) scale(1.06);box-shadow:0 6px 20px var(--glow-mixed)}.rail-logo-img{width:46px;height:46px;object-fit:cover;display:block}.outpost-pill{display:flex;align-items:center;gap:10px;width:100%;padding:7px 18px 7px 7px;border-radius:var(--r-full);background:#050512eb;border:1px solid rgba(96,165,250,.25);box-shadow:0 4px 22px #60a5fa26,0 0 0 1px #a78bfa1a inset}.outpost-pill-icon{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#0000004d}.outpost-pill-text{font-family:var(--font-display);font-size:36px;font-weight:800;letter-spacing:.18em;text-indent:.18em;white-space:nowrap;flex:1;text-align:center;background:linear-gradient(135deg,#60a5fa,#c084fc 45%,#818cf8 75%,#60a5fa);background-size:250% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:outpost-shimmer 5s ease-in-out infinite}.create-group-modal{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);width:440px;padding:32px 28px 28px;display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .15s var(--ease)}.create-group-icon-pick{width:80px;height:80px;border-radius:50%;background:var(--bg-raised);border:2px dashed var(--glass-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:border-color var(--t) var(--ease),background var(--t) var(--ease);overflow:hidden;flex-shrink:0}.create-group-icon-pick:hover{border-color:var(--blue);background:var(--gradient-soft)}.create-group-icon-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.create-group-title{font-size:20px;font-weight:700;color:var(--text);margin:4px 0 0}.create-group-sub{font-size:13px;color:var(--text-dim);text-align:center;margin-bottom:4px}.create-group-modal .form-group,.create-group-modal .form-input{width:100%}.rail-add-guild{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--online);background:#34d3991a;border:2px dashed rgba(52,211,153,.4);transition:border-radius var(--t) var(--ease),background var(--t) var(--ease),color var(--t) var(--ease),border-color var(--t) var(--ease),transform var(--t) var(--spring)}.rail-add-guild:hover{border-radius:var(--r-sm);background:#34d39933;border-color:var(--online);transform:translateY(-2px)}.vc-main-area{flex:1;display:flex;align-items:center;justify-content:center;background:#00000040;border-radius:var(--r-md);margin:0 16px;min-height:200px;overflow:hidden;position:relative}.vc-video-grid{display:grid;width:100%;height:100%;gap:4px;padding:4px}.vc-video-grid.grid-1{grid-template-columns:1fr}.vc-video-grid.grid-2{grid-template-columns:1fr 1fr}.vc-video-grid.grid-3{grid-template-columns:1fr 1fr 1fr}.vc-video-grid.grid-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.vc-video-tile{border-radius:8px;overflow:hidden;background:#000;position:relative}.vc-video{width:100%;height:100%;object-fit:cover;display:block}.vc-screen-grid{display:grid;width:100%;height:100%;gap:4px;padding:4px}.vc-screen-grid.grid-1{grid-template-columns:1fr}.vc-screen-grid.grid-2{grid-template-columns:1fr 1fr}.vc-screen-tile{position:relative;border-radius:8px;overflow:hidden;background:#000;box-shadow:0 0 0 1px #60a5fa33}.vc-screen-video{width:100%;height:100%;object-fit:contain;display:block}.vc-screen-label{position:absolute;bottom:8px;left:10px;display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#ffffffe6;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:3px 8px;border-radius:20px;pointer-events:none}.vc-pip-strip{position:absolute;bottom:0;right:0;display:flex;gap:4px;padding:6px;z-index:5}.vc-pip-strip .vc-video-tile{width:120px;height:90px;flex-shrink:0;border:1px solid rgba(255,255,255,.12)}.vc-no-video{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-dim)}.vc-no-video-label{font-size:13px;color:var(--text-dim)}.vc-participants-strip{display:flex;flex-direction:row;align-items:center;gap:16px;padding:14px 20px 4px;justify-content:center;flex-wrap:wrap}.vc-card{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;transition:transform var(--t) var(--spring)}.vc-card:hover{transform:translateY(-2px)}.vc-card-avatar{width:52px;height:52px;border-radius:50%;position:relative;box-shadow:0 0 0 3px transparent;transition:box-shadow .12s ease}.vc-card.vc-speaking .vc-card-avatar{box-shadow:0 0 0 3px #34d399,0 0 12px 2px #34d39980}.vc-card-img{width:52px;height:52px;border-radius:50%;object-fit:cover;display:block}.vc-card-initials{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}.vc-card-muted-badge{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:#ef4444;color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-panel)}.vc-card-name{font-size:11px;font-weight:500;color:var(--text-dim);text-align:center;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vc-card.vc-speaking .vc-card-name{color:#34d399}.settings-backdrop{align-items:center;z-index:450}.settings-modal{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);width:780px;max-width:96vw;max-height:88vh;display:flex;flex-direction:row;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .15s var(--ease);overflow:hidden}.settings-nav{width:200px;flex-shrink:0;background:var(--bg-base);border-right:1px solid var(--glass-border);padding:20px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.settings-nav-mobile-header{display:none;align-items:center;justify-content:space-between;padding:4px 6px 12px;margin-bottom:4px;border-bottom:1px solid var(--glass-border)}.settings-nav-mobile-title{font-size:17px;font-weight:700;color:var(--text)}.settings-nav-label{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute);padding:0 8px;margin-bottom:4px}.settings-nav-btn{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:var(--text-dim);transition:background var(--t) var(--ease),color var(--t) var(--ease);text-align:left;width:100%}.settings-nav-btn:hover{background:var(--glass-hover);color:var(--text)}.settings-nav-btn.active{background:var(--glass-active);color:var(--text);font-weight:600}.settings-nav-chevron{display:none;margin-left:auto;opacity:.35;flex-shrink:0}.settings-content{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.settings-content-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 16px;border-bottom:1px solid var(--glass-border);font-size:16px;font-weight:700;color:var(--text);flex-shrink:0}.settings-content-header-left{display:flex;align-items:center;gap:8px}.settings-back-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-sm);color:var(--text-dim);margin-left:-6px;transition:background var(--t),color var(--t)}.settings-back-btn:hover{background:var(--glass-hover);color:var(--text)}.settings-modal-body{overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:4px;flex:1;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.pending-users{padding:4px 0}.pending-msg{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:var(--r-sm);margin-bottom:16px;font-size:13px;font-weight:500}.pending-msg.ok{background:#34d3991a;border:1px solid rgba(52,211,153,.25);color:var(--online)}.pending-msg.err{background:#f871711a;border:1px solid rgba(248,113,113,.25);color:var(--error)}.pending-msg-dismiss{font-size:13px;opacity:.6;flex-shrink:0}.pending-msg-dismiss:hover{opacity:1}.pending-empty{color:var(--text-dim);font-size:14px;text-align:center;padding:40px 0}.pending-list{display:flex;flex-direction:column;gap:10px}.pending-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--r-md);background:var(--bg-raised);border:1px solid var(--glass-border)}.pending-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:var(--gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.pending-info{flex:1;min-width:0}.pending-name{font-size:14px;font-weight:700;color:var(--text)}.pending-tag{font-size:12px;font-weight:400;color:var(--text-dim);margin-left:3px}.pending-email{font-size:12px;color:var(--text-dim);margin-top:2px}.pending-meta{font-size:11px;color:var(--text-dim);opacity:.6;margin-top:3px;font-family:var(--font-mono)}.pending-actions{display:flex;gap:8px;flex-shrink:0}.pending-btn-approve{font-size:13px;padding:7px 16px}.pending-btn-deny{font-size:13px;padding:7px 16px;background:#f871711a;border:1px solid rgba(248,113,113,.25);color:var(--error)}.pending-btn-deny:hover{background:#f8717133;border-color:#f8717166}.admin-panel{display:flex;flex-direction:column;gap:0}.admin-section{display:flex;flex-direction:column;gap:14px;padding-top:4px}.admin-tab-bar{display:flex;gap:2px;margin-bottom:18px;background:var(--bg-raised);border-radius:var(--r-md);padding:4px;border:1px solid var(--glass-border)}.admin-tab{flex:1;padding:7px 10px;border-radius:calc(var(--r-md) - 2px);font-size:13px;font-weight:500;color:var(--text-dim);transition:all var(--t) var(--ease);cursor:pointer}.admin-tab:hover{color:var(--text)}.admin-tab.active{background:var(--glass);color:var(--text);font-weight:600}.admin-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);display:flex;align-items:center}.admin-overview-empty{display:flex;align-items:center;gap:10px;justify-content:center;color:var(--text-dim);font-size:13px;padding:20px 0}.admin-overview-actions{display:flex;flex-direction:column;gap:6px;margin-top:4px}.admin-overview-shortcut{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-md);background:var(--bg-raised);border:1px solid var(--glass-border);color:var(--text-dim);font-size:13px;font-weight:500;transition:all var(--t) var(--ease);cursor:pointer;text-align:left;width:100%}.admin-overview-shortcut:hover{color:var(--text);border-color:#60a5fa4d;background:var(--glass)}.admin-mode-list{display:flex;flex-direction:column;gap:6px}.admin-mode-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--r-md);background:var(--bg-raised);border:2px solid var(--glass-border);transition:all var(--t) var(--ease);cursor:pointer;text-align:left;width:100%}.admin-mode-row:hover{border-color:#60a5fa40}.admin-mode-row.selected{border-color:#60a5fa80;background:#60a5fa0f}.admin-mode-radio{width:16px;height:16px;border-radius:50%;flex-shrink:0;margin-top:2px;border:2px solid var(--glass-border);display:flex;align-items:center;justify-content:center;transition:border-color var(--t) var(--ease)}.admin-mode-row.selected .admin-mode-radio{border-color:var(--blue)}.admin-mode-radio-dot{width:8px;height:8px;border-radius:50%;background:var(--blue)}.admin-mode-info{flex:1}.admin-mode-label{font-size:13px;font-weight:600;color:var(--text)}.admin-mode-desc{font-size:12px;color:var(--text-dim);margin-top:2px}.admin-toast{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500;border:1px solid}.admin-toast.ok{background:#34d3991a;border-color:#34d39940;color:var(--online)}.admin-toast.err{background:#f871711a;border-color:#f8717140;color:var(--error)}.admin-toast-dismiss{background:none;border:none;cursor:pointer;color:inherit;font-size:14px;padding:0 2px;opacity:.7}.admin-toast-dismiss:hover{opacity:1}.admin-stats{display:flex;gap:0;background:var(--bg-raised);border-radius:var(--r-md);border:1px solid var(--glass-border);overflow:hidden}.admin-stat{flex:1;text-align:center;padding:14px 10px;display:flex;flex-direction:column;gap:3px}.admin-stat+.admin-stat{border-left:1px solid var(--glass-border)}.admin-stat-num{font-size:22px;font-weight:700;color:var(--text);line-height:1}.admin-stat-lbl{font-size:10.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.admin-toolbar{display:flex;gap:8px;align-items:center}.admin-search-wrap{flex:1;position:relative;display:flex;align-items:center}.admin-search-icon{position:absolute;left:10px;color:var(--text-dim);pointer-events:none;flex-shrink:0}.admin-search{width:100%;background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:8px 30px;color:var(--text);font-size:13px;outline:none;transition:border-color var(--t) var(--ease)}.admin-search:focus{border-color:#60a5fa66}.admin-search::placeholder{color:var(--text-dim)}.admin-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px;padding:4px;line-height:1}.admin-search-clear:hover{color:var(--text)}.admin-filter-tabs{display:flex;gap:4px;flex-shrink:0}.admin-filter-tab{padding:7px 13px;border-radius:var(--r-md);font-size:12px;font-weight:500;background:var(--bg-raised);border:1px solid var(--glass-border);color:var(--text-dim);cursor:pointer;transition:all var(--t) var(--ease);display:flex;align-items:center;gap:5px}.admin-filter-tab:hover{color:var(--text);background:var(--glass)}.admin-filter-tab.active{color:var(--text);background:var(--glass);border-color:#60a5fa4d}.admin-filter-badge{background:#f59e0b;color:#000;font-size:10px;font-weight:700;border-radius:999px;padding:1px 5px;min-width:16px;text-align:center;line-height:1.4}.admin-empty{text-align:center;color:var(--text-dim);padding:40px 0;font-size:14px}.admin-user-list{display:flex;flex-direction:column;gap:5px}.admin-user-row{display:flex;align-items:center;gap:11px;background:var(--bg-raised);border-radius:var(--r-md);padding:10px 12px;border:1px solid var(--glass-border);transition:border-color var(--t) var(--ease)}.admin-user-row.is-pending{border-left:3px solid #f59e0b}.admin-user-row.is-admin{border-left:3px solid rgba(96,165,250,.6)}.admin-user-avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#60a5fa,#c084fc);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;overflow:hidden}.admin-user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.admin-user-info{flex:1;min-width:0}.admin-user-name{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:5px;flex-wrap:wrap}.admin-user-tag{color:var(--text-dim);font-weight:400;font-size:12px}.admin-user-email{font-size:11.5px;color:var(--text-dim);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.admin-user-meta{font-size:11px;color:var(--text-dim);opacity:.65;margin-top:2px}.admin-badge{font-size:9px;font-weight:700;border-radius:999px;padding:2px 7px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.admin-badge-admin{background:#60a5fa1f;color:#60a5fa;border:1px solid rgba(96,165,250,.3)}.admin-badge-pending{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.admin-user-actions{display:flex;gap:5px;flex-shrink:0}.admin-btn-sm{padding:5px 11px!important;font-size:12px!important}.admin-btn-deny,.admin-btn-remove{background:#ef444414!important;border:1px solid rgba(239,68,68,.28)!important;color:#ef4444!important}.admin-btn-deny:hover,.admin-btn-remove:hover{background:#ef44442e!important;border-color:#ef444473!important}.settings-about-hero{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 20px 20px;text-align:center}.settings-about-logo{width:64px;height:64px;border-radius:18px;box-shadow:0 0 24px #60a5fa40,0 0 48px #a78bfa1a}.settings-about-name{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.04em;background:linear-gradient(135deg,#60a5fa,#c084fc 45%,#818cf8 75%,#60a5fa);background-size:250% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 10px rgba(96,165,250,.35));animation:outpost-shimmer 5s ease-in-out infinite}.settings-about-version{font-size:13px;color:var(--text-dim)}.settings-about-url{font-size:12px;color:var(--blue);text-decoration:none;opacity:.8;transition:opacity var(--t)}.settings-about-url:hover{opacity:1}.settings-shortcuts{display:flex;flex-direction:column;gap:0}.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;gap:12px}.shortcut-row+.shortcut-row{border-top:1px solid var(--glass-border)}.shortcut-desc{font-size:13px;color:var(--text-dim)}.shortcut-keys{display:flex;align-items:center;gap:4px;flex-shrink:0}.shortcut-plus{font-size:11px;color:var(--text-mute)}kbd{display:inline-flex;align-items:center;justify-content:center;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:6px;padding:2px 7px;font-size:11px;font-family:var(--font-mono);color:var(--text);box-shadow:0 2px #0006}.settings-tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:4px 0}.settings-tech-chip{background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:10px 12px}.settings-tech-name{font-size:13px;font-weight:600;color:var(--text)}.settings-tech-desc{font-size:11.5px;color:var(--text-dim);margin-top:2px}.crop-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}.crop-modal{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);display:flex;flex-direction:column;box-shadow:0 32px 80px #000c;animation:slideUp .18s var(--ease);overflow:hidden}.crop-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--glass-border);font-size:15px;font-weight:700;color:var(--text)}.crop-stage{position:relative;overflow:hidden;background:#000;flex-shrink:0;touch-action:none}.crop-footer{padding:14px 18px;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:10px}.crop-zoom-row{display:flex;align-items:center;gap:8px;color:var(--text-dim)}.crop-zoom-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--glass-border);outline:none;cursor:pointer}.crop-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 3px var(--glow-blue);cursor:grab}.crop-hint{font-size:11.5px;color:var(--text-mute);text-align:center}.crop-actions{display:flex;gap:8px;justify-content:flex-end}.user-profile-card{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);width:340px;max-width:96vw;overflow:hidden;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .15s var(--ease)}.user-profile-top{position:relative;padding-bottom:52px}.user-profile-banner{height:80px;background-size:cover;background-position:center;position:relative}.user-profile-banner .modal-close-btn{position:absolute;top:10px;right:10px}.user-profile-avatar-center{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:96px;height:96px;border-radius:50%;border:4px solid var(--bg-panel);overflow:hidden;background:var(--bg-raised);box-shadow:0 4px 20px #00000080}.user-profile-avatar-img{width:100%;height:100%;object-fit:cover;display:block}.user-profile-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:800;color:#fff}.user-profile-body{padding:4px 20px 20px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.user-profile-displayname{font-size:20px;font-weight:800;color:var(--text);line-height:1.2}.user-profile-tag{font-size:13px;color:var(--text-dim)}.profile-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.profile-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:20px;text-transform:uppercase}.profile-badge.admin{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;box-shadow:0 1px 6px #7c3aed59}.user-profile-pronouns{font-size:12px;color:var(--blue);font-weight:500}.user-profile-section{width:100%;margin-top:10px;background:var(--bg-raised);border-radius:var(--r-sm);padding:12px 14px;text-align:left}.user-profile-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:6px}.user-profile-bio{font-size:13px;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word}.user-profile-empty{font-size:13px;color:var(--text-dim);font-style:italic;padding:8px 0}.user-profile-loading{font-size:13px;color:var(--text-dim);padding:20px 0;text-align:center}.ctx-menu{position:fixed;z-index:300;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:4px;min-width:160px;max-width:calc(100vw - 24px);box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff0a inset;animation:fadeIn .08s var(--ease)}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.ctx-menu-item{display:flex;align-items:center;gap:9px;width:100%;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text);border-radius:8px;transition:background var(--t) var(--ease),color var(--t) var(--ease);text-align:left}.ctx-menu-item:hover{background:var(--glass-hover);color:var(--blue)}.ctx-menu-item svg{opacity:.6;flex-shrink:0}.ctx-menu-item:hover svg{opacity:1}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--text-dim);flex-shrink:0;transition:background var(--t) var(--ease),color var(--t) var(--ease)}.mobile-menu-btn:hover{background:var(--glass-hover);color:var(--text)}.mobile-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:399;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .18s var(--ease)}@media(max-width:768px){.mobile-menu-btn{display:flex}.mobile-backdrop{display:block}.welcome-topbar,.welcome-open-sidebar{display:flex}.welcome-title{font-size:22px}.welcome-sub{font-size:13px}.shell{grid-template-columns:1fr}.nav-panel{position:fixed;top:0;left:0;bottom:0;width:min(340px,88vw);z-index:400;transform:translate(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 32px #0009}.nav-panel.open{transform:translate(0)}.rail{width:60px;min-width:60px}.rail-logo-btn{width:40px;height:40px}.rail-guild,.rail-add-guild{width:44px;height:44px}.outpost-pill{padding:4px 10px 4px 5px;gap:6px}.outpost-pill-icon{width:24px;height:24px}.outpost-pill-text{font-size:13px}.sidebar{flex:1;width:0}.main{width:100%;min-width:0}.topbar{padding:0 12px;height:52px}.topbar-topic,.status-chip{display:none}.messages{padding:8px 8px 4px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.msg-row{gap:10px;padding:3px 6px}.msg-avatar-col{width:34px}.msg-content{font-size:15px}.msg-author{font-size:14px}.msg-time{font-size:10px}.msg-code-block{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:calc(100vw - 80px)}.msg-attachment-img{max-width:calc(100vw - 90px);max-height:240px}.msg-attachment-img-wrap{display:block}.msg-attachment-file{font-size:12px}.composer-wrap{padding:0 10px max(18px,env(safe-area-inset-bottom))}.composer{padding:7px 6px 7px 12px;gap:8px}.composer-attach{width:40px;height:40px}.composer-send{width:44px;height:44px;min-width:unset;min-height:unset}.pending-files{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:8px 10px 0;scrollbar-width:none}.pending-files::-webkit-scrollbar{display:none}.reply-banner{padding:5px 10px;font-size:12px}.reply-banner-close{width:32px;height:32px;border-radius:8px}.input-row{padding:8px 10px;padding-bottom:max(8px,env(safe-area-inset-bottom))}.input-box{font-size:16px}.voice-room-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;border-radius:0}.voice-room{border-radius:0;height:100%}.voice-controls{flex-wrap:wrap;gap:6px;padding:10px 8px;padding-bottom:max(10px,env(safe-area-inset-bottom))}.vc-ctrl-btn{min-width:56px;padding:9px 12px;min-height:44px}.soundboard{max-height:240px;padding:10px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom))}.soundboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.soundboard-clip{border-radius:var(--r-sm)}.soundboard-play-area{padding:11px 6px 11px 12px;gap:6px}.soundboard-name{font-size:12px;max-width:none;flex:1}.soundboard-delete{opacity:.45;padding:11px 10px 11px 4px}.soundboard-upload-btn{padding:6px 11px;font-size:11.5px}.vc-participants-strip{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding:10px 12px 4px}.modal-backdrop{padding:0;align-items:flex-end}.modal-backdrop>*{margin:0;border-radius:20px 20px 0 0;max-height:92dvh;width:100%!important;max-width:100%!important}.settings-backdrop{align-items:flex-end;padding:0}.settings-modal{flex-direction:column;width:100%;height:92vh;height:92dvh;max-height:92vh;max-height:92dvh;border-radius:20px 20px 0 0}.settings-nav{width:100%;border-right:none;border-bottom:1px solid var(--glass-border);padding:8px 8px 16px;flex-shrink:0;overflow-y:auto;flex:1}.settings-nav-mobile-header{display:flex;padding:8px 8px 14px;margin-bottom:4px}.settings-nav-btn{padding:13px 12px;font-size:15px;min-height:52px;border-radius:10px}.settings-nav-chevron{display:block}.settings-nav-label{padding:0 12px;font-size:11px}.settings-content{flex:1}.settings-content-header{padding:16px 18px 14px}.settings-modal-body{padding:16px 18px}.settings-back-btn{display:flex}.settings-mobile-nav .settings-content,.settings-mobile-content .settings-nav{display:none}.settings-mobile-content .settings-content{display:flex}.user-profile-card{width:100%;border-radius:20px 20px 0 0}.incoming-call-card{padding:28px 32px 24px}.friends-page{padding:16px 12px}.friend-row{gap:10px}.ctx-menu{font-size:14px}.member-stack{display:none}.login-card input,.add-friend-form input,.composer-input,.pe-input,.pe-textarea,.form-input,.form-textarea,.invite-modal-link-input{font-size:16px!important}.pill-btn{width:36px;height:36px}.voice-mini-btn{width:36px;height:36px;border-radius:var(--r-xs)}.modal-close-btn{width:40px;height:40px}.ctx-menu-item{padding:12px 14px;min-height:44px}.msg-act-btn{width:36px;height:36px}.emoji-opt{width:40px;height:40px}.pe-swatch,.pe-color-input{width:34px;height:34px}.msg-actions{display:none}.msg-row.selected .msg-actions{display:flex;position:absolute;top:-22px;right:6px;background:var(--bg-raised);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:4px;gap:2px;opacity:1;pointer-events:auto;z-index:20;box-shadow:0 6px 20px #00000080,0 0 0 1px #ffffff0a inset;animation:fadeIn .12s var(--ease)}.msg-row{overflow:visible}.pep-banner-actions{background:#00000059}.pep-media-btn,.pep-avatar-wrap .pep-avatar-edit{opacity:1}.sidebar-footer{padding-bottom:max(14px,env(safe-area-inset-bottom))}.topbar{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.login-screen{align-items:flex-start;padding:max(28px,env(safe-area-inset-top)) 16px max(24px,env(safe-area-inset-bottom))}.login-card{margin:auto;max-width:100%;padding:28px 20px 24px;gap:16px;border-radius:var(--r-md)}.login-logo{width:72px;height:72px}.login-title{font-size:22px}.login-sub{font-size:12px}.login-fields{gap:12px}.login-btn{padding:13px;font-size:15px;min-height:48px}.login-tab-switch{font-size:14px;padding-top:14px}.login-tab-switch button{font-size:14px;padding:4px 2px}.login-consent{font-size:13px}.login-consent input[type=checkbox]{width:18px;height:18px}.user-bar-popout{max-height:70dvh;overflow-y:auto}.member-panel{display:none}.profile-edit-modal{flex-direction:column;width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:92dvh}.profile-edit-preview{display:none}.profile-edit-form-panel{max-height:92dvh}.vc-card-name{max-width:80px;font-size:12px}.vc-ctrl-btn span{display:none}.vc-ctrl-btn{min-width:48px;padding:12px}.sidebar-ch-btn,.dm-row{min-height:40px}.sidebar-ch-btn{padding:8px 12px}.pill-btn{font-size:14px}.composer-attach-btn,.composer-send{min-width:44px;min-height:44px}.jump-to-bottom{bottom:calc(max(18px,env(safe-area-inset-bottom)) + 68px);padding:8px 14px;font-size:12px}.quick-backdrop{align-items:flex-end;padding:0}.quick-switcher{width:100%;border-radius:20px 20px 0 0;max-height:82dvh;animation:slideUp .2s var(--ease)}.quick-list{max-height:58dvh;padding:4px 6px max(8px,env(safe-area-inset-bottom))}.quick-hint{display:none}.quick-input-wrap{padding:16px 16px 12px}.quick-item{min-height:52px;padding:10px 12px}.quick-item-label{font-size:15px}.mention-dropdown{margin:0 4px 4px}.mention-item{padding:10px 12px;min-height:48px}}@media(min-width:769px)and (max-width:1024px){.shell{grid-template-columns:300px 1fr}.nav-panel{width:300px}.member-panel{width:200px}.settings-modal,.profile-edit-modal{width:min(780px,94vw)}.profile-edit-preview{width:210px}.voice-controls{flex-wrap:wrap;gap:6px;padding:10px 14px}.vc-ctrl-btn{min-width:60px;min-height:44px;padding:9px 14px}.voice-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;padding:14px}.soundboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.soundboard-clip{border-radius:var(--r-sm)}.soundboard-play-area{padding:10px 6px 10px 12px}.soundboard-name{max-width:none;flex:1}.soundboard-delete{opacity:.45}.pill-btn,.voice-mini-btn{width:32px;height:32px}.ctx-menu-item{min-height:40px}.emoji-opt{width:38px;height:38px}.login-card input,.add-friend-form input,.composer-input,.pe-input,.pe-textarea,.form-input,.form-textarea,.invite-modal-link-input{font-size:16px}}@media(max-width:380px){.nav-panel{width:92vw}.topbar-name{font-size:14px}.login-logo{width:56px;height:56px}.login-card{padding:20px 14px;gap:14px}.login-title{font-size:20px}.login-header{gap:8px}.voice-grid{grid-template-columns:1fr;gap:8px;padding:10px}.soundboard-grid{grid-template-columns:1fr}.vc-ctrl-btn{min-width:44px;padding:11px 8px;font-size:9px}.voice-controls{gap:4px;padding:8px 6px}.pe-swatches{gap:8px}.pe-swatch,.pe-color-input{width:36px;height:36px}}.invite-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:20px}.invite-card{position:relative;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:36px 32px 28px;width:100%;max-width:420px;text-align:center;box-shadow:0 24px 64px #00000080}.invite-card-brand{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:20px}.invite-loading,.invite-err{color:var(--text-dim);font-size:14px;padding:20px 0}.invite-err{color:var(--error)}.invite-guild-row{display:flex;align-items:center;gap:16px;margin-bottom:16px;text-align:left}.invite-guild-icon{width:60px;height:60px;border-radius:14px;overflow:hidden;flex-shrink:0}.invite-guild-icon img{width:100%;height:100%;object-fit:cover}.invite-guild-icon-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-raised);font-size:24px;font-weight:700;color:var(--text)}.invite-guild-name{font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}.invite-guild-counts{font-size:12px;color:var(--text-dim)}.invite-inviter{font-size:12px;color:var(--text-dim);margin-bottom:4px}.invite-channel{font-size:13px;color:var(--blue);margin-bottom:18px;font-weight:500}.invite-join-btn{width:100%;margin-top:8px;padding:10px;font-size:15px;font-weight:600}.invite-modal-card{position:relative;background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:28px 24px 22px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000080}.invite-modal-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--text);margin-bottom:18px;padding-right:24px}.invite-modal-link-row{display:flex;gap:8px;align-items:stretch}.invite-modal-link-input{flex:1;background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:8px 12px;color:var(--text);font-size:13px;font-family:var(--font-mono);outline:none;min-width:0}.invite-modal-copy{flex-shrink:0;padding:8px 16px;font-size:13px;transition:background var(--t) var(--ease)}.invite-modal-copy.copied{background:var(--online)}.invite-modal-hint{margin-top:10px;font-size:12px;color:var(--text-dim)}.jump-to-bottom{position:absolute;bottom:100px;left:50%;transform:translate(-50%);background:var(--bg-panel);border:1px solid var(--glass-border);color:var(--text);border-radius:20px;padding:8px 18px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #00000080;cursor:pointer;z-index:10;transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease)}.jump-to-bottom:hover{background:var(--bg-raised);box-shadow:0 6px 24px #0009}.jump-badge{background:var(--blue);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700;line-height:1.6}.messages.drag-over{outline:2px dashed var(--blue);outline-offset:-6px}.drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;z-index:20;pointer-events:none;border-radius:var(--r-md)}.drag-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--blue);font-size:16px;font-weight:600;background:var(--bg-panel);border:2px dashed var(--blue);border-radius:var(--r-lg);padding:32px 48px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#000000e0;display:flex;align-items:center;justify-content:center;cursor:zoom-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .15s ease}.lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--r-md);box-shadow:0 20px 60px #0009;cursor:default}.lightbox-close{position:fixed;top:16px;right:20px;background:#ffffff1f;border:none;color:#fff;border-radius:50%;width:36px;height:36px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t);z-index:9001}.lightbox-close:hover{background:#ffffff38}.lightbox-open{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#0009;color:#ffffffb3;font-size:12px;padding:6px 14px;border-radius:20px;text-decoration:none;z-index:9001;transition:color var(--t)}.lightbox-open:hover{color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.msg-spoiler{background:var(--bg-raised);color:transparent;border-radius:3px;padding:0 3px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--t),background var(--t)}.msg-spoiler:hover:not(.revealed){background:#ffffff26}.msg-spoiler.revealed{color:var(--text);background:#ffffff1a;cursor:text;-webkit-user-select:text;user-select:text}.msg-content.big-emoji{font-size:2.8em;line-height:1.2}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#0003;border-bottom:1px solid rgba(255,255,255,.06);margin:-8px -8px 8px}.code-copy-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:var(--text-dim);font-size:11px;border-radius:4px;padding:2px 8px;cursor:pointer;transition:background var(--t),color var(--t);font-family:var(--font-mono)}.code-copy-btn:hover{background:#ffffff26;color:var(--text)}
