*{box-sizing:border-box}body{margin:0;background:#101218;color:#f4f4f5;font-family:Inter,Arial,sans-serif}button,input{font:inherit}button{-webkit-user-select:none;user-select:none}.app{height:100vh;display:grid;grid-template-columns:72px 240px 1fr 220px;background:#101218}.servers{background:#090b10;padding:12px;display:flex;flex-direction:column;gap:12px}.server{width:48px;height:48px;border:0;padding:0;color:#fff;border-radius:16px;background:#1b1f2a;display:grid;place-items:center;font-weight:800;cursor:pointer;transition:.12s ease}.server:hover,.server.active{border-radius:14px;background:#5865f2}.server-divider{height:1px;background:#252a37;margin:0 6px}.channels{background:#151922;padding:18px 14px;border-right:1px solid #252a37;overflow-y:auto}.channels h2{margin:0 0 20px;font-size:20px}.section-row{margin:18px 0 8px;display:flex;align-items:center;justify-content:space-between}.section-title{margin:18px 0 8px;color:#8f96a8;font-size:12px;text-transform:uppercase;font-weight:700}.section-row .section-title{margin:0}.add-channel-btn{width:24px;height:24px;border:0;border-radius:8px;background:#252a37;color:#c9cedd;cursor:pointer;font-weight:800}.add-channel-btn:hover{background:#5865f2;color:#fff}.channel-row{display:flex;align-items:center;gap:6px;border-radius:10px}.channel-row:hover{background:#252a3780}.channel{flex:1;min-width:0;border:0;background:transparent;color:#c9cedd;text-align:left;padding:9px 10px;border-radius:10px;cursor:pointer}.channel:hover,.channel.active{background:#252a37;color:#fff}.dm-add-button{background:#252a37;color:#fff;margin-bottom:8px}.dm-add-button:hover{background:#5865f2}.channel-actions{display:flex;gap:4px;padding-right:4px;opacity:0;transition:.12s ease}.channel-row:hover .channel-actions{opacity:1}.channel-action{width:24px;height:24px;border:0;border-radius:8px;background:transparent;color:#8f96a8;cursor:pointer;display:grid;place-items:center;line-height:1}.channel-action:hover{background:#5865f229;color:#aab2ff}.channel-action.danger:hover{background:#ff4d4d24;color:#f77}.friend-row{width:100%;border:0;background:transparent;color:#c9cedd;border-radius:12px;padding:9px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left}.friend-row:hover,.friend-row.active{background:#252a37;color:#fff}.friend-row-main{min-width:0;display:flex;flex-direction:column}.friend-row-main strong,.friend-row-main small{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.friend-row-main small{color:#737b91;font-size:12px}.sidebar-empty{color:#737b91;background:#101218;border:1px solid #252a37;border-radius:14px;padding:12px;font-size:13px;line-height:1.35}.friend-request-row{display:flex;align-items:center;gap:8px;background:#101218;border:1px solid #252a37;border-radius:14px;padding:10px;margin-bottom:8px}.friend-request-main{min-width:0;flex:1;display:flex;align-items:center;gap:10px}.friend-request-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.friend-request-accept,.friend-request-decline{width:28px;height:28px;border:0;border-radius:10px;cursor:pointer;display:grid;place-items:center;font-weight:900;line-height:1}.friend-request-accept{background:#3ddc8424;color:#5ff0a0}.friend-request-accept:hover{background:#3ddc84;color:#07110b}.friend-request-decline{background:#ff4d4d24;color:#f77}.friend-request-decline:hover{background:#ff4d4d;color:#fff}.friend-request-status{flex-shrink:0;color:#8f96a8;background:#252a37;border-radius:999px;padding:4px 8px;font-size:11px;text-transform:uppercase}.chat{min-width:0;display:grid;grid-template-rows:56px 1fr 72px}.chat-header{border-bottom:1px solid #252a37;padding:0 20px;display:flex;align-items:center;gap:12px}.chat-header span{color:#8f96a8;font-size:14px}.messages{padding:22px;overflow-y:auto}.message{display:flex;gap:12px;margin-bottom:18px}.avatar{width:38px;height:38px;border-radius:14px;background:#2f3546;display:grid;place-items:center;font-weight:700;flex-shrink:0}.message-content{min-width:0;flex:1}.message-top{display:flex;gap:10px;align-items:baseline}.message-top span{color:#8f96a8;font-size:12px}.message p{margin:5px 0 0;color:#d8dbea;word-break:break-word}.edited-label{color:#737b91;font-size:12px}.message-edit,.message-delete{width:22px;height:22px;border:0;border-radius:8px;background:transparent;color:#737b91;cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center}.message-edit:hover{background:#5865f224;color:#9ca6ff}.message-delete{font-size:18px}.message-delete:hover{background:#ff4d4d24;color:#f77}.message-edit-form{margin-top:8px;display:grid;gap:8px}.message-edit-form input{width:100%;border:0;outline:0;background:#252a37;color:#fff;border-radius:12px;padding:10px 12px}.message-edit-actions{display:flex;gap:8px}.message-edit-actions button{border:0;border-radius:10px;background:#252a37;color:#c9cedd;padding:7px 10px;cursor:pointer}.message-edit-actions button:first-child{background:#5865f2;color:#fff}.message-edit-actions button:hover{filter:brightness(1.1)}.input-bar{border-top:1px solid #252a37;padding:14px 20px;display:flex;gap:12px}.input-bar input{flex:1;border:0;outline:0;background:#252a37;color:#fff;border-radius:14px;padding:0 16px}.input-bar input:disabled{opacity:.5}.input-bar button{border:0;border-radius:14px;background:#5865f2;color:#fff;padding:0 18px;cursor:pointer}.input-bar button:disabled{opacity:.5;cursor:not-allowed}.members{background:#151922;border-left:1px solid #252a37;padding:18px 14px;overflow-y:auto}.members h3{margin:0 0 16px;color:#c9cedd;font-size:14px}.member{padding:8px 0;color:#d8dbea}.offline-title{margin-top:28px!important}.offline{color:#737b91}.empty{height:100%;display:grid;place-content:center;text-align:center;color:#c9cedd;padding:24px}.empty h3{margin:0 0 8px;color:#fff}.empty p{margin:0;color:#8f96a8}.auth-page{min-height:100vh;background:radial-gradient(circle at top,#20263a,#090b10 55%);display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:380px;background:#151922;border:1px solid #252a37;border-radius:24px;padding:28px;box-shadow:0 20px 80px #00000059}.auth-logo{width:58px;height:58px;border-radius:18px;background:#5865f2;display:grid;place-items:center;font-weight:900;font-size:24px;margin-bottom:18px}.auth-card h1{margin:0 0 8px;font-size:28px}.auth-card p{margin:0 0 22px;color:#8f96a8}.auth-card label{display:block;margin-bottom:14px}.auth-card label span{display:block;color:#c9cedd;font-size:13px;font-weight:700;margin-bottom:7px}.auth-card input{width:100%;height:48px;border:0;outline:0;background:#252a37;color:#fff;border-radius:14px;padding:0 16px;margin-bottom:14px}.auth-card button{width:100%;height:48px;border:0;border-radius:14px;background:#5865f2;color:#fff;cursor:pointer;font-weight:700}.auth-card button:disabled{opacity:.6;cursor:not-allowed}.auth-error{background:#ff4d4d1f;border:1px solid rgba(255,77,77,.35);color:#ff9b9b;border-radius:14px;padding:10px 12px;margin-bottom:14px;font-size:14px}.auth-secondary{margin-top:10px;background:transparent!important;border:1px solid #252a37!important;color:#c9cedd!important}.auth-secondary:hover{background:#252a37!important;color:#fff!important}.auth-hint{margin-top:16px;color:#737b91;font-size:12px;text-align:center;line-height:1.4}.profile-card{display:flex;align-items:center;gap:10px;background:#101218;border:1px solid #252a37;border-radius:16px;padding:10px;margin-bottom:22px}.profile-avatar{width:36px;height:36px;border-radius:12px;background:#5865f2;display:grid;place-items:center;font-weight:800;flex-shrink:0}.profile-info{min-width:0;flex:1;display:flex;flex-direction:column}.profile-info strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-info span{color:#3ddc84;font-size:12px}.logout-btn{width:28px;height:28px;border:0;border-radius:10px;background:#252a37;color:#c9cedd;cursor:pointer;font-size:20px;line-height:1}.logout-btn:hover{background:#ff4d4d;color:#fff}.member-row{display:flex;align-items:center;gap:10px;padding:9px 0;min-width:0}.status-dot{width:10px;height:10px;border-radius:999px;background:#737b91;flex-shrink:0}.status-dot.online{background:#3ddc84}.member-main{min-width:0;flex:1;display:flex;flex-direction:column}.member-main strong{color:#d8dbea;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-main span{color:#737b91;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-badge{color:#8f96a8;background:#252a37;border-radius:999px;padding:3px 7px;font-size:10px;text-transform:uppercase;flex-shrink:0}.modal-backdrop{position:fixed;inset:0;z-index:1000;background:#05060ab8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:24px;animation:modalFadeIn .12s ease}.modal-card{width:100%;max-width:440px;background:#1b1f2a;border:1px solid #30364a;border-radius:22px;box-shadow:0 24px 90px #0000008c;padding:22px;animation:modalPopIn .14s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:10px}.modal-header h2{margin:0;font-size:22px;color:#fff}.modal-close{width:34px;height:34px;border:0;border-radius:12px;background:#252a37;color:#c9cedd;cursor:pointer;font-size:22px;line-height:1}.modal-close:hover{background:#30364a;color:#fff}.modal-description{margin:0 0 18px;color:#9aa2b8;line-height:1.45;font-size:14px}.modal-label{display:grid;gap:8px;margin-bottom:14px}.modal-label span{color:#c9cedd;font-size:13px;font-weight:800;text-transform:uppercase}.modal-label input{width:100%;height:46px;border:1px solid #30364a;outline:0;background:#101218;color:#fff;border-radius:14px;padding:0 14px}.modal-label input:focus{border-color:#5865f2;box-shadow:0 0 0 3px #5865f22e}.modal-error{margin:12px 0 0;background:#ff4d4d1f;border:1px solid rgba(255,77,77,.35);color:#ff9b9b;border-radius:14px;padding:10px 12px;font-size:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.modal-primary,.modal-secondary,.modal-danger{min-width:110px;height:42px;border:0;border-radius:14px;padding:0 16px;cursor:pointer;font-weight:800}.modal-primary{background:#5865f2;color:#fff}.modal-primary:hover{background:#6b76ff}.modal-secondary{background:#252a37;color:#c9cedd}.modal-secondary:hover{background:#30364a;color:#fff}.modal-danger{background:#e5484d;color:#fff}.modal-danger:hover{background:#ff5c61}.modal-primary:disabled,.modal-secondary:disabled,.modal-danger:disabled{opacity:.6;cursor:not-allowed}.invite-code-box{background:#101218;border:1px solid #30364a;border-radius:16px;padding:16px;text-align:center;margin-top:14px}.invite-code-box code{color:#fff;font-size:28px;letter-spacing:4px;font-weight:900}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPopIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.notify-btn{width:28px;height:28px;border:0;border-radius:10px;background:#252a37;color:#c9cedd;cursor:pointer;font-size:14px;line-height:1;display:grid;place-items:center}.notify-btn:hover,.notify-btn.active{background:#5865f2;color:#fff}.file-input{display:none}.attach-btn{width:44px;min-width:44px;height:44px;border:0;border-radius:14px;background:#252a37;color:#c9cedd;cursor:pointer;display:grid;place-items:center}.attach-btn:hover{background:#30364a;color:#fff}.attach-btn:disabled{opacity:.5;cursor:not-allowed}.message-input-stack{position:relative;flex:1;display:grid;gap:8px}.message-input-stack input{width:100%;height:44px}.selected-attachments{display:flex;gap:8px;flex-wrap:wrap}.selected-attachment{display:flex;align-items:center;gap:8px;max-width:210px;background:#1b1f2a;border:1px solid #30364a;color:#c9cedd;border-radius:999px;padding:6px 8px 6px 10px;font-size:12px}.selected-attachment span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-attachment button{width:18px;height:18px;border:0;border-radius:999px;background:#30364a;color:#c9cedd;cursor:pointer;display:grid;place-items:center;line-height:1}.selected-attachment button:hover{background:#ff4d4d;color:#fff}.attachments{margin-top:8px;display:grid;gap:8px;max-width:420px}.attachment-card{text-decoration:none;color:inherit;background:#1b1f2a;border:1px solid #30364a;border-radius:16px;overflow:hidden;display:flex;align-items:center;gap:12px;max-width:420px}.attachment-card:hover{border-color:#5865f2}.attachment-card.image{display:block}.attachment-card.image img{display:block;width:100%;max-height:320px;object-fit:cover;background:#101218}.attachment-file-icon{width:54px;height:54px;background:#252a37;display:grid;place-items:center;font-size:22px;flex-shrink:0}.attachment-info{min-width:0;padding:10px 12px;display:grid;gap:3px}.attachment-card.image .attachment-info{border-top:1px solid #30364a}.attachment-info strong{color:#fff;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-info span{color:#8f96a8;font-size:12px}.voice-room{min-height:100%;display:grid;place-items:center;padding:24px}.voice-room-card{width:100%;max-width:520px;background:#151922;border:1px solid #252a37;border-radius:24px;padding:28px;text-align:center;box-shadow:0 20px 70px #0000003d}.voice-icon{width:72px;height:72px;margin:0 auto 16px;border-radius:24px;background:#252a37;display:grid;place-items:center;font-size:30px}.voice-room-card h3{margin:0 0 8px;font-size:24px}.voice-room-card p{margin:0 auto 18px;color:#8f96a8;max-width:420px;line-height:1.5}.voice-actions{margin-bottom:22px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.voice-status-line{background:#101218;border:1px solid #252a37;border-radius:16px;padding:10px 12px;margin:0 auto 16px;display:grid;gap:4px;max-width:420px}.voice-status-line span{color:#c9cedd;font-size:13px}.voice-status-line strong{color:#3ddc84;font-size:12px}.voice-join,.voice-mute,.voice-leave{height:44px;border:0;border-radius:14px;color:#fff;padding:0 18px;cursor:pointer;font-weight:800}.voice-join{background:#23a559}.voice-join:hover{background:#2fc46d}.voice-mute{background:#5865f2}.voice-mute:hover{background:#6b76ff}.voice-leave{background:#e5484d}.voice-leave:hover{background:#ff5c61}.voice-join:disabled,.voice-mute:disabled,.voice-leave:disabled{opacity:.65;cursor:not-allowed}.voice-participants{text-align:left;background:#101218;border:1px solid #252a37;border-radius:18px;padding:14px}.voice-participants h4{margin:0 0 10px;color:#c9cedd;font-size:13px;text-transform:uppercase}.voice-empty{color:#737b91;font-size:14px;padding:8px 0}.voice-participant{display:flex;align-items:center;gap:10px;padding:8px 0}.remote-audio-stack{position:fixed;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.toast{position:fixed;right:24px;bottom:24px;z-index:1200;width:min(360px,calc(100vw - 48px));background:#1b1f2a;border:1px solid #30364a;border-radius:18px;padding:14px 16px;box-shadow:0 18px 60px #0006;display:grid;gap:4px;animation:modalPopIn .14s ease}.toast strong{color:#fff;font-size:14px}.toast span{color:#c9cedd;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-diagnostics{background:#101218;border:1px solid #252a37;border-radius:18px;padding:14px;margin:0 auto 18px;max-width:460px;text-align:left}.voice-diag-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}.voice-diag-grid div{background:#151922;border:1px solid #252a37;border-radius:12px;padding:8px;min-width:0}.voice-diag-grid span{display:block;color:#737b91;font-size:11px;text-transform:uppercase;font-weight:800;margin-bottom:4px}.voice-diag-grid strong{color:#d8dbea;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.mic-meter{height:9px;background:#252a37;border-radius:999px;overflow:hidden;margin-bottom:12px}.mic-meter div{height:100%;background:#3ddc84;border-radius:999px;transition:width 80ms linear}.voice-peer-list{display:grid;gap:8px;margin-bottom:12px}.voice-peer-item{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:5px 8px;background:#151922;border:1px solid #252a37;border-radius:12px;padding:9px}.voice-peer-item strong{grid-column:1 / -1;color:#fff;font-size:13px}.voice-peer-item span{color:#9aa2b8;font-size:11px;white-space:nowrap}.voice-debug-log{display:grid;gap:5px;color:#8f96a8;font-size:11px;line-height:1.35;max-height:96px;overflow-y:auto;border-top:1px solid #252a37;padding-top:10px}@media(max-width:900px){.voice-diag-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.voice-peer-item{grid-template-columns:1fr}}.server,.friend-row,.channel-row{position:relative}.server-badge{position:absolute;right:-4px;bottom:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#e5484d;color:#fff;border:3px solid #090b10;display:grid;place-items:center;font-size:11px;font-weight:900;line-height:1}.server-badge.mention{background:#5865f2}.sidebar-badge,.channel-unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#e5484d;color:#fff;display:grid;place-items:center;font-size:11px;font-weight:900;line-height:1;flex-shrink:0}.channel-unread-badge{margin-right:4px}.sidebar-badge{margin-left:auto}.channel-unread-badge.mention{background:#5865f2}.chat-header{justify-content:space-between}.chat-header-main{min-width:0;display:flex;align-items:center;gap:12px}.chat-header-main strong{white-space:nowrap}.chat-header-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mark-read-btn{border:0;border-radius:12px;background:#252a37;color:#c9cedd;padding:8px 12px;cursor:pointer;font-size:13px;font-weight:800;flex-shrink:0}.mark-read-btn:hover{background:#30364a;color:#fff}.message-group{display:contents}.new-messages-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:#ff6b6b;font-size:12px;font-weight:900;text-transform:uppercase}.new-messages-divider:before,.new-messages-divider:after{content:"";height:1px;background:#ff6b6b73;flex:1}.new-messages-divider span{background:#ff6b6b1f;border:1px solid rgba(255,107,107,.28);padding:5px 10px;border-radius:999px}.mention-menu{position:absolute;left:0;right:0;bottom:54px;z-index:40;background:#1b1f2a;border:1px solid #30364a;border-radius:16px;padding:8px;box-shadow:0 18px 60px #00000073;display:grid;gap:4px;max-height:280px;overflow-y:auto}.mention-option{width:100%;min-height:50px;border:0;border-radius:12px;background:transparent;color:#d8dbea;padding:8px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left}.mention-option:hover,.mention-option.active{background:#252a37;color:#fff}.mention-avatar{width:34px;height:34px;border-radius:12px;background:#5865f2;color:#fff;display:grid;place-items:center;font-weight:900;flex-shrink:0}.mention-avatar.everyone{background:#3a4156}.mention-main{min-width:0;flex:1;display:flex;flex-direction:column}.mention-main strong{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mention-main small{color:#8f96a8;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mention-status{width:10px;height:10px;border-radius:999px;background:#737b91;flex-shrink:0}.mention-status.online{background:#3ddc84}.mention-empty{color:#8f96a8;padding:12px;text-align:center;font-size:14px}.server-delete-button{width:100%;border:0;background:#e5484d1a;color:#ff9b9b;text-align:left;padding:9px 10px;border-radius:10px;cursor:pointer;margin:6px 0 2px}.server-delete-button:hover{background:#e5484d2e;color:#fff}
