@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#070709;--bg-secondary:#0c0c10;--bg-chat:#0e0e13;--bg-accent:#a255ff;--bg-accent-hover:#b833ff;--bg-danger:#f43f5e;--bg-danger-hover:#e11d48;--bg-success:#00e676;--bg-warning:#f59e0b;--text-normal:#dbdee1;--text-muted:#8e9297;--text-link:#d946ef;--text-white:#fff;--border-light:#a255ff14;--border-dark:#070709;--border-separator:#ffffff0d;--shadow-lg:0 10px 30px 0 #000000a6, 0 0 1px 1px #a255ff1a;--shadow-sm:0 4px 12px #0006;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:"Consolas", "Courier New", Courier, monospace;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-normal);width:100vw;height:100vh;overflow:hidden}#root{width:100%;height:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#1a1b1e;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#111214}@keyframes pulseGlow{0%{box-shadow:0 0 #5865f280}70%{box-shadow:0 0 0 10px #5865f200}to{box-shadow:0 0 #5865f200}}@keyframes voiceIndicator{0%{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}to{opacity:.3;transform:scale(1)}}@keyframes messageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.animate-pulse-glow{animation:2s infinite pulseGlow}@keyframes callPulse{0%{transform:scale(.95);box-shadow:0 0 #5865f2b3}70%{transform:scale(1);box-shadow:0 0 0 20px #5865f200}to{transform:scale(.95);box-shadow:0 0 #5865f200}}@keyframes callPulseSuccess{0%{transform:scale(.95);box-shadow:0 0 #23a55ab3}70%{transform:scale(1);box-shadow:0 0 0 20px #23a55a00}to{transform:scale(.95);box-shadow:0 0 #23a55a00}}.pulsing-ring{pointer-events:none;z-index:-1;border-radius:50%;width:100px;height:100px;animation:2s infinite callPulse;position:absolute;top:0;left:0}.pulsing-ring-success{pointer-events:none;z-index:-1;border-radius:50%;width:100px;height:100px;animation:2s infinite callPulseSuccess;position:absolute;top:0;left:0}.app-container{background-color:var(--bg-primary);width:100vw;height:100vh;display:flex;overflow:hidden}.auth-wrapper{background:linear-gradient(135deg,#111214 0%,#1e1f22 50%,#2b2d31 100%);justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.auth-wrapper:before{content:"";pointer-events:none;background:radial-gradient(circle,#5865f21f 0%,#0000 70%);width:60%;height:60%;position:absolute;top:-20%;left:-20%}.auth-wrapper:after{content:"";pointer-events:none;background:radial-gradient(circle,#23a55a14 0%,#0000 70%);width:60%;height:60%;position:absolute;bottom:-20%;right:-20%}.auth-card{-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-light);width:100%;max-width:480px;box-shadow:var(--shadow-lg);color:var(--text-normal);z-index:10;transition:transform var(--transition-normal);background:#2b2d31b3;border-radius:16px;padding:40px}.auth-header{text-align:center;margin-bottom:30px}.auth-logo{background:linear-gradient(90deg,#fff 0%,#a2a8ff 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;margin-bottom:8px;font-size:2.5rem;font-weight:800}.auth-subtitle{color:var(--text-muted);font-size:.95rem}.form-group{margin-bottom:20px}.form-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:8px;font-size:.75rem;font-weight:700;display:block}.form-input{width:100%;color:var(--text-white);transition:all var(--transition-fast);background-color:#1e1f22cc;border:1px solid #ffffff0d;border-radius:8px;padding:12px 16px;font-size:.95rem}.form-input:focus{border-color:var(--bg-accent);outline:none;box-shadow:0 0 0 2px #5865f233}.auth-btn{width:100%;color:var(--text-white);cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(90deg,#a255ff 0%,#b55fe6 100%);border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:10px;padding:14px;font-size:1rem;font-weight:600;display:flex;box-shadow:0 0 16px #a255ff40}.auth-btn:hover{background:linear-gradient(90deg,#b833ff 0%,#9026ff 100%);transform:translateY(-1px);box-shadow:0 0 24px #a255ff73}.auth-btn:active{transform:translateY(0)}.auth-btn:disabled{cursor:not-allowed;opacity:.6;background-color:#4f545c;transform:none}.auth-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:.9rem}.auth-link{color:var(--text-link);transition:text-decoration var(--transition-fast);margin-left:4px;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.otp-container{justify-content:space-between;gap:10px;margin:25px 0;display:flex}.otp-input{text-align:center;width:50px;height:56px;color:var(--text-white);transition:all var(--transition-fast);background-color:#1e1f22cc;border:1px solid #ffffff1a;border-radius:8px;font-size:1.5rem;font-weight:700}.otp-input:focus{border-color:var(--bg-accent);outline:none;box-shadow:0 0 0 2px #a255ff40}.app-layout{background-color:var(--bg-primary);flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.app-body{flex-direction:row;flex:1;display:flex;overflow:hidden}.app-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-separator);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;box-shadow:0 4px 20px #0000004d}.header-left{align-items:center;display:flex}.app-brand{align-items:center;gap:10px;display:flex}.brand-dot{background:var(--bg-accent);width:10px;height:10px;box-shadow:0 0 10px var(--bg-accent);border-radius:50%}.brand-title{letter-spacing:.5px;color:var(--text-white);background:linear-gradient(90deg,#fff 0%,#b833ff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}.header-center{flex:1;justify-content:center;max-width:60%;margin:0 20px;display:flex}.server-horizontal-list{background:#ffffff05;border:1px solid #ffffff0a;border-radius:30px;align-items:center;gap:12px;padding:6px 16px;display:flex}.server-nav-items{align-items:center;gap:8px;display:flex}.server-nav-separator{background-color:#ffffff1a;width:1px;height:20px;margin:0 4px}.server-nav-btn{width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background-color:#ffffff08;border:1px solid #ffffff0d;border-radius:50%;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;display:flex;position:relative;overflow:hidden}.server-nav-btn:hover{color:var(--text-white);background-color:#a255ff1a;border-color:#a255ff66;transform:translateY(-1px)}.server-nav-btn.active{border-color:var(--bg-accent);background-color:var(--bg-accent);color:var(--text-white);box-shadow:0 0 12px #a255ff66}.server-nav-btn.home-btn.active{background:linear-gradient(135deg,#a255ff 0%,#b55fe6 100%);border-color:#0000}.server-nav-btn.add-btn{color:var(--bg-success);border-color:#00e67633}.server-nav-btn.add-btn:hover{border-color:var(--bg-success);background-color:#00e6761a}.server-nav-img{object-fit:cover;width:100%;height:100%}.header-right{align-items:center;gap:8px;display:flex}.header-icon-btn{width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background-color:#0000;border:1px solid #ffffff0d;border-radius:8px;justify-content:center;align-items:center;display:flex}.header-icon-btn:hover{color:var(--text-white);background-color:#ffffff08;border-color:#ffffff1a}.header-icon-btn.logout:hover{color:var(--bg-danger);background-color:#f43f5e0d;border-color:#f43f5e33}.channels-sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-separator);flex-direction:column;flex-shrink:0;width:240px;height:100%;display:flex}.server-header{height:48px;color:var(--text-white);cursor:pointer;transition:background-color var(--transition-fast);border-bottom:1px solid #0003;justify-content:space-between;align-items:center;padding:0 16px;font-weight:700;display:flex;box-shadow:0 1px 2px #0000000d}.server-header:hover{background-color:#ffffff0a}.channels-list-container{flex:1;padding:12px 8px;overflow-y:auto}.channel-category{justify-content:space-between;align-items:center;margin-top:16px;margin-bottom:4px;padding:0 4px;display:flex}.category-title{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:.72rem;font-weight:700}.category-add-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.category-add-btn:hover{color:var(--text-white)}.channel-item{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;width:100%;margin-bottom:4px;padding:8px 12px;font-size:.9rem;font-weight:550;text-decoration:none;display:flex}.channel-item:hover{color:var(--text-white);background-color:#a255ff0a;border-color:#a255ff14}.channel-item.active{color:var(--text-white);background-color:#a255ff1a;border-color:#a255ff33}.channel-link-content{text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.channel-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.channel-delete-btn{opacity:0;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none}.channel-item:hover .channel-delete-btn{opacity:1}.channel-delete-btn:hover{color:var(--bg-danger)}.user-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-separator);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 8px;display:flex}.user-footer-info{cursor:pointer;min-width:0;transition:background-color var(--transition-fast);border-radius:4px;align-items:center;gap:8px;padding:4px;display:flex}.user-footer-info:hover{background-color:#ffffff0d}.user-avatar-wrapper{width:32px;height:32px;position:relative}.user-avatar{background-color:var(--bg-accent);width:32px;height:32px;color:var(--text-white);border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.status-badge{border:2px solid #232428;border-radius:50%;width:12px;height:12px;position:absolute;bottom:-2px;right:-2px}.status-badge.online{background-color:var(--bg-success)}.status-badge.idle{background-color:var(--bg-warning)}.status-badge.dnd{background-color:var(--bg-danger)}.status-badge.offline{background-color:var(--text-muted)}.user-footer-details{flex-direction:column;min-width:0;display:flex}.user-footer-name{color:var(--text-white);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:600;overflow:hidden}.user-footer-status-text{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.user-footer-controls{align-items:center;display:flex}.control-btn{width:32px;height:32px;color:var(--text-normal);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:flex}.control-btn:hover{color:var(--text-white);background-color:#ffffff0d}.control-btn.active{color:var(--bg-danger)}.main-chat-container{background-color:var(--bg-chat);flex-direction:column;flex:1;height:100%;display:flex;position:relative}.chat-header{z-index:10;border-bottom:1px solid #0003;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex;box-shadow:0 1px 2px #0000000d}.chat-header-left{color:var(--text-white);align-items:center;gap:8px;font-weight:600;display:flex}.chat-header-hash{color:var(--text-muted);font-size:1.25rem}.messages-scroller{flex-direction:column;flex:1;gap:16px;padding:20px 16px;display:flex;overflow-y:auto}.message-item{transition:all var(--transition-fast);background-color:#ffffff03;border:1px solid #ffffff04;border-radius:12px;gap:14px;padding:12px 16px;animation:.2s ease-out messageFadeIn;display:flex}.message-item:hover{background-color:#ffffff06;border-color:#a255ff14;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.message-avatar{background-color:var(--bg-accent);width:40px;height:40px;color:var(--text-white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.message-content-wrapper{flex-direction:column;min-width:0;display:flex}.message-header{align-items:baseline;gap:8px;margin-bottom:4px;display:flex}.message-author{color:var(--text-white);font-size:.95rem;font-weight:600}.message-timestamp{color:var(--text-muted);font-size:.72rem}.message-text{color:var(--text-normal);word-break:break-word;white-space:pre-wrap;font-size:.95rem;line-height:1.4}.chat-input-wrapper{flex-shrink:0;padding:0 16px 24px}.chat-input-container{width:100%;transition:all var(--transition-fast);background-color:#ffffff08;border:1px solid #ffffff0d;border-radius:8px;align-items:center;padding:0 16px;display:flex;position:relative}.chat-input-container:focus-within{border-color:#a255ff66;box-shadow:0 0 12px #a255ff26}.chat-input{color:var(--text-white);background:0 0;border:none;outline:none;flex:1;padding:14px 0;font-size:.95rem}.chat-input::placeholder{color:var(--text-muted)}.typing-indicator{color:var(--text-muted);font-size:.75rem;position:absolute;bottom:-18px;left:20px}.call-container{background-color:var(--bg-primary);flex-direction:column;flex:1;height:100%;display:flex;position:relative;overflow:hidden}.video-grid{flex:1;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));place-content:center;gap:16px;padding:24px;display:grid;overflow-y:auto}.video-card{aspect-ratio:16/10;background-color:var(--bg-secondary);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:2px solid #0000;border-radius:12px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.video-card.speaking{border-color:var(--bg-success);box-shadow:0 0 12px #23a55a66}.video-card.speaking-border-glow:before{content:"";border:3px solid var(--bg-success);pointer-events:none;z-index:10;border-radius:10px;animation:1.5s infinite voiceIndicator;position:absolute;inset:0}.video-stream{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.video-stream.screen-share{object-fit:contain;background-color:#000;transform:none}.video-placeholder{flex-direction:column;align-items:center;gap:12px;display:flex}.video-avatar{background-color:var(--bg-accent);width:96px;height:96px;color:var(--text-white);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;font-size:2.2rem;font-weight:700;display:flex}.video-user-name{color:var(--text-white);z-index:5;background-color:#0009;border-radius:4px;align-items:center;gap:6px;padding:4px 10px;font-size:.82rem;font-weight:600;display:flex;position:absolute;bottom:12px;left:12px}.video-card-status-icon{color:var(--bg-danger);justify-content:center;align-items:center;display:flex}.call-controls{background-color:var(--bg-secondary);border-top:1px solid var(--border-separator);z-index:20;justify-content:center;align-items:center;gap:16px;height:80px;display:flex}.call-btn{width:48px;height:48px;color:var(--text-white);cursor:pointer;transition:all var(--transition-fast);background-color:#2b2d31;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.call-btn:hover{background-color:#3f4248}.call-btn.active{background-color:var(--text-white);color:#111214}.call-btn.hangup{background-color:var(--bg-danger)}.call-btn.hangup:hover{background-color:var(--bg-danger-hover)}.members-sidebar{background-color:var(--bg-secondary);border-left:1px solid var(--border-separator);flex-direction:column;flex-shrink:0;width:240px;height:100%;padding:16px 8px;display:flex;overflow-y:auto}.member-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-left:8px;font-size:.72rem;font-weight:700}.member-card{cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);border-radius:4px;align-items:center;gap:8px;margin-bottom:2px;padding:6px 8px;display:flex}.member-card:hover{color:var(--text-normal);background-color:#ffffff0a}.member-username{text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:500;overflow:hidden}.member-card.online .member-username{color:var(--text-normal)}.member-card.offline{opacity:.45}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-light);width:100%;max-width:440px;box-shadow:var(--shadow-lg);color:var(--text-normal);border-radius:12px;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-separator);justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-title{color:var(--text-white);font-size:1.25rem;font-weight:700}.modal-close-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none}.modal-close-btn:hover{color:var(--text-white)}.modal-body{padding:20px}.modal-footer{background-color:#232428;justify-content:flex-end;gap:12px;padding:14px 20px;display:flex}.btn-secondary{color:var(--text-white);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:10px 16px;font-size:.95rem;font-weight:500}.btn-secondary:hover{text-decoration:underline}.btn-primary{color:var(--text-white);cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(90deg,#a255ff 0%,#b55fe6 100%);border:none;border-radius:6px;padding:10px 20px;font-size:.95rem;font-weight:600;box-shadow:0 0 12px #a255ff33}.btn-primary:hover{background:linear-gradient(90deg,#b833ff 0%,#9026ff 100%);transform:translateY(-1px);box-shadow:0 0 18px #a255ff59}.alert-banner{background-color:var(--bg-danger);color:var(--text-white);z-index:15;justify-content:space-between;align-items:center;padding:8px 16px;font-size:.88rem;font-weight:500;display:flex;position:absolute;top:0;left:0;right:0}.alert-banner-close{color:var(--text-white);cursor:pointer;background:0 0;border:none}.welcome-container{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.welcome-logo{background:linear-gradient(90deg,#5865f2 0%,#a2a8ff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:4rem;font-weight:800}.welcome-text{color:var(--text-muted);max-width:480px;font-size:1rem;line-height:1.5}.spoiler-text{color:#1e1f22;cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background-color:#1e1f22;border-radius:3px;padding:0 4px}.spoiler-text.revealed{color:inherit;background-color:#ffffff1a}.message-actions-hover{border:1px solid var(--border-light);box-shadow:var(--shadow-sm);z-index:10;background-color:#111214;border-radius:6px;display:none;position:absolute;top:-16px;right:16px;overflow:hidden}.message-item{position:relative}.message-item:hover .message-actions-hover{align-items:center;display:flex}.message-action-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:6px 10px;transition:all .2s;display:flex}.message-action-btn:hover{color:#fff;background-color:#ffffff0d}.message-action-btn.danger:hover{color:var(--bg-danger);background-color:#f43f5e26}.pins-drawer{border-left:1px solid var(--border-separator);background-color:var(--bg-secondary);z-index:30;flex-direction:column;flex-shrink:0;width:340px;height:100%;animation:.2s ease-out slideIn;display:flex}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.pins-drawer-header{border-bottom:1px solid var(--border-separator);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pins-drawer-body{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.pin-card{background-color:var(--bg-chat);border:1px solid var(--border-light);border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex;position:relative}.reactions-row{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.reaction-badge{color:var(--text-normal);cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#ffffff08;border:1px solid #ffffff0d;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:.75rem;transition:all .2s;display:flex}.reaction-badge:hover{background-color:#ffffff0f;border-color:#ffffff1a}.reaction-badge.active{border-color:var(--bg-accent);color:#fff;background-color:#a255ff26}.reply-preview-line{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:4px;margin-left:38px;font-size:.78rem;display:flex;position:relative}.reply-preview-line:before{content:"";border-top:2px solid #4e5058;border-left:2px solid #4e5058;border-top-left-radius:6px;width:16px;position:absolute;top:50%;bottom:-6px;left:-20px}.reply-preview-avatar{object-fit:cover;background-color:var(--bg-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.55rem;font-weight:700;display:flex}.reply-preview-author{color:#c4c7c5;font-weight:600}.reply-preview-text{text-overflow:ellipsis;white-space:nowrap;max-width:70%;overflow:hidden}.server-unread-badge{background-color:var(--bg-danger,#f23f43);color:#fff;border:2px solid var(--bg-primary,#111214);z-index:10;pointer-events:none;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.72rem;font-weight:700;animation:.2s cubic-bezier(.175,.885,.32,1.275) badgePop;display:flex;position:absolute;bottom:-4px;right:-4px;box-shadow:0 2px 4px #0006}.channel-unread-badge{background-color:var(--bg-danger,#f23f43);color:#fff;pointer-events:none;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:auto;padding:0 4px;font-size:.7rem;font-weight:700;display:inline-flex;box-shadow:0 1px 3px #0000004d}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}
