: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{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 20%,rgba(59,130,246,.12) 0%,transparent 55%),radial-gradient(ellipse at 70% 80%,rgba(139,92,246,.12) 0%,transparent 55%),var(--bg-base)}.login-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:40px 36px;width:360px;display:flex;flex-direction:column;gap:14px;box-shadow:0 32px 80px #0009,0 0 0 1px #ffffff0a inset,0 0 60px var(--glow-mixed);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.login-mark{font-family:var(--font-display);background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;font-size:14px;letter-spacing:.2em}.login-sub{color:var(--text-dim);font-size:13px;line-height:1.55}.login-card label{font-size:11px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.login-card input{background:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text);padding:11px 14px;font-size:14px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.login-card input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-blue)}.login-error{color:var(--error);font-size:12px}.login-card .btn{margin-top:4px}.login-back{display:block;text-align:center;font-size:12px;color:var(--text-dim);text-decoration:none;transition:color var(--t) var(--ease)}.login-back:hover{color:var(--text)}.shell{display:grid;grid-template-columns:68px 240px 1fr;height:100vh;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)}.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{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:15px;font-weight:700;color:var(--text);letter-spacing:-.02em}.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}.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)}.user-bar-name{flex:1;font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-bar-logout{font-size:16px;color:var(--text-dim);padding:2px 4px;border-radius:var(--r-xs);transition:color var(--t) var(--ease),background var(--t) var(--ease)}.user-bar-logout:hover{color:var(--error);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)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.add-friend-form{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:var(--r-sm);background:#ffffff08;border:1px solid var(--glass-border);animation:slide-down .15s var(--ease)}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.add-friend-form input{background:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--r-xs);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:11.5px;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;background:var(--bg-main);position:relative;overflow:hidden}.chat-area{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.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}.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)}.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.4;caret-color:var(--blue)}.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}.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:12px;padding:16px 24px;border-top:1px solid var(--glass-border);background:#0a0a20d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.voice-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 20px;border-radius:var(--r-md);background:#ffffff0f;border:1px solid var(--glass-border);color:var(--text);font-size:11px;font-weight:600;transition:background var(--t) var(--ease),border-color var(--t) var(--ease),transform var(--t) var(--spring);min-width:72px}.voice-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.voice-btn.off{background:#f871711f;border-color:#f871714d;color:var(--error)}.voice-btn.mute{background:#f871711a;border-color:#f8717140;color:var(--error)}.voice-btn.mute:hover{background:#f8717138;border-color:#f8717180}.voice-btn.unmute{background:#34d3991f;border-color:#34d39959;color:var(--online);box-shadow:0 0 16px #34d39926}.voice-btn.unmute:hover{background:#34d39938;border-color:#34d39999}.voice-btn.leave{background:#f871711f;border-color:#f871714d;color:var(--error)}.voice-btn.leave:hover{background:#f871713d}.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)}.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:400px;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-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:200px;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:center;justify-content:center;padding:24px;animation:fadeIn .12s var(--ease)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.profile-modal{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--r-lg);width:480px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a inset;animation:slideUp .15s var(--ease)}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}.profile-modal-banner{height:120px;flex-shrink:0;position:relative;background-size:cover;background-position:center;border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-close-btn{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;color:var(--text);opacity:.7;transition:opacity var(--t) var(--ease),background var(--t) var(--ease)}.modal-close-btn:hover{opacity:1;background:#000000bf}.banner-controls{position:absolute;bottom:10px;right:12px;display:flex;gap:6px}.banner-edit-btn{font-size:11px;font-weight:600;background:#0000008c;color:var(--text);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-xs);padding:4px 10px;transition:background var(--t) var(--ease)}.banner-edit-btn:hover{background:#000c}.banner-edit-btn.danger{color:var(--error)}.profile-modal-avatar-row{padding:0 20px;display:flex;align-items:flex-end;gap:12px;margin-top:-36px;position:relative}.profile-modal-avatar-wrap{position:relative;flex-shrink:0}.profile-modal-avatar-img,.profile-modal-avatar-fallback{width:80px;height:80px;border-radius:50%;border:4px solid var(--bg-panel);object-fit:cover}.profile-modal-avatar-fallback{display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff}.avatar-edit-btn{position:absolute;bottom:4px;right:0;width:26px;height:26px;border-radius:50%;background:var(--bg-raised);border:2px solid var(--bg-panel);display:flex;align-items:center;justify-content:center;color:var(--text);transition:background var(--t) var(--ease)}.avatar-edit-btn:hover{background:var(--blue)}.remove-avatar-btn{font-size:11px;color:var(--error);opacity:.7;transition:opacity var(--t);align-self:flex-end;margin-bottom:6px}.remove-avatar-btn:hover{opacity:1}.profile-modal-names{align-self:flex-end;padding-bottom:6px}.profile-modal-displayname{font-size:18px;font-weight:700;color:var(--text)}.profile-modal-tag{font-size:12px;color:var(--text-dim)}.profile-tabs{display:flex;gap:0;padding:16px 20px 0;border-bottom:1px solid var(--glass-border);flex-shrink:0}.profile-tab{font-size:13px;font-weight:600;color:var(--text-dim);padding:8px 14px;border-bottom:2px solid transparent;transition:color var(--t) var(--ease),border-color var(--t) var(--ease);margin-bottom:-1px}.profile-tab.active{color:var(--text);border-color:var(--blue)}.profile-tab:hover:not(.active){color:var(--text)}.profile-modal-body{overflow-y:auto;flex:1;padding:20px}.profile-form{display:flex;flex-direction:column;gap:18px}.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:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--r-xs);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:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--r-xs);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)}.username-tag-row{display:flex;align-items:center;gap:6px}.username-tag-row .form-input{flex:1}.tag-hash{color:var(--text-dim);font-size:16px}.tag-input{width:72px!important;flex:none!important;text-align:center;letter-spacing:.1em}.color-custom-input{width:28px;height:28px;border-radius:50%;border:2px solid var(--glass-border);overflow:hidden;cursor:pointer;padding:0;background:none}.color-custom-input::-webkit-color-swatch-wrapper{padding:0}.color-custom-input::-webkit-color-swatch{border:none;border-radius:50%}.clear-color-btn{font-size:11px;color:var(--text-dim);padding:4px 8px;border:1px solid var(--glass-border);border-radius:var(--r-xs);transition:color var(--t),border-color var(--t)}.clear-color-btn:hover{color:var(--error);border-color:var(--error)}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}.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)}
