/* ── THEMES ── */ :root { --bg:#0e0e14;--bg2:#16161f;--bg3:#1e1e2a;--bg4:#252535; --border:#2a2a3d;--accent:#7c6af7;--accent2:#a855f7; --accent-glow:rgba(124,106,247,0.22);--text:#e8e8f0; --text2:#9090aa;--text3:#6a6a88;--red:#f04e5e; --green:#3ecf75;--yellow:#f5c842; --font-mono:'Space Mono',monospace;--font-sans:'DM Sans',sans-serif; --sidebar-w:260px; } [data-theme="light"]{--bg:#f0f0f8;--bg2:#e4e4ef;--bg3:#d8d8ea;--bg4:#cbcbdd;--border:#c0c0d0;--text:#1a1a2e;--text2:#4a4a6a;--text3:#7070a0;} [data-theme="pitch"]{--bg:#000;--bg2:#080808;--bg3:#101010;--bg4:#181818;--border:#202020;--text:#e0e0e0;--text2:#909090;--text3:#606060;} [data-theme="aurora"]{--bg:#050d1a;--bg2:#0a1525;--bg3:#0e1d30;--bg4:#12253c;--border:#1a3050;--accent:#00d4aa;--accent2:#00a8e8;--accent-glow:rgba(0,212,170,0.2);--text:#d0f0e8;--text2:#6ab8a0;--text3:#4a9880;} [data-theme="sunset"]{--bg:#1a0a10;--bg2:#240e16;--bg3:#2e121c;--bg4:#3a1624;--border:#4a2030;--accent:#ff6b6b;--accent2:#ff9f43;--accent-glow:rgba(255,107,107,0.2);--text:#ffe0d8;--text2:#c08080;--text3:#906060;} /* ── RESET ── */ *{box-sizing:border-box;margin:0;padding:0;} html,body{height:100%;} body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;transition:background .3s,color .3s;} ::-webkit-scrollbar{width:5px;} ::-webkit-scrollbar-track{background:transparent;} ::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;} ::-webkit-scrollbar-thumb:hover{background:var(--text3);} /* ── AUTH ── */ #auth-screen{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse at 30% 40%,var(--accent-glow) 0%,transparent 60%),radial-gradient(ellipse at 70% 60%,rgba(168,85,247,.1) 0%,transparent 50%);} .auth-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:390px;box-shadow:0 0 60px rgba(0,0,0,.5);} .auth-logo{font-family:var(--font-mono);font-size:26px;font-weight:700;color:var(--accent);letter-spacing:-1px;} .auth-logo span{color:var(--text2);font-size:13px;font-weight:400;display:block;margin-top:4px;} .auth-tabs{display:flex;gap:4px;margin:24px 0 20px;background:var(--bg3);border-radius:8px;padding:4px;} .auth-tab{flex:1;padding:9px;text-align:center;cursor:pointer;border-radius:6px;font-size:14px;font-weight:500;color:var(--text2);transition:all .2s;border:none;background:transparent;} .auth-tab.active{background:var(--accent);color:#fff;} .auth-input{width:100%;padding:11px 14px;margin-bottom:12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:15px;outline:none;transition:border-color .2s;} .auth-input:focus{border-color:var(--accent);} .auth-input::placeholder{color:var(--text3);} .auth-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-sans);} .auth-btn:hover{background:var(--accent2);transform:translateY(-1px);} .auth-error{color:var(--red);font-size:13px;margin-bottom:10px;min-height:18px;font-weight:500;} /* ── BAN SCREEN ── */ #ban-overlay{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.96);backdrop-filter:blur(10px);} #ban-overlay.show{display:flex;} .ban-box{text-align:center;padding:48px;max-width:480px;background:var(--bg2);border:1px solid var(--red);border-radius:16px;box-shadow:0 0 60px rgba(240,78,94,.25);} .ban-icon{font-size:56px;margin-bottom:16px;} .ban-title{font-family:var(--font-mono);font-size:22px;color:var(--red);margin-bottom:8px;} .ban-reason{color:var(--text2);font-size:15px;margin:12px 0;line-height:1.6;} .ban-duration{font-size:13px;color:var(--text3);} /* ── APP SHELL ── */ #app{display:none;height:100vh;} #app.show{display:flex;} #mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40;} #mobile-overlay.show{display:block;} /* ── SIDEBAR ── */ #sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:background .3s;z-index:45;} .sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--accent);letter-spacing:-.5px;display:flex;align-items:center;justify-content:space-between;} .sidebar-section-label{padding:12px 16px 5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);display:flex;align-items:center;justify-content:space-between;} .sidebar-section-label span{font-size:14px;cursor:pointer;color:var(--text2);transition:color .15s;} .sidebar-section-label span:hover{color:var(--accent);} .channel-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;cursor:pointer;margin:1px 8px;transition:background .15s;font-size:14px;color:var(--text2);font-weight:500;} .channel-item:hover{background:var(--bg3);color:var(--text);} .channel-item.active{background:var(--bg4);color:var(--text);} .channel-item .ch-icon{font-size:15px;} .online-list{overflow-y:auto;padding:4px 8px;max-height:220px;} .dm-list{overflow-y:auto;padding:4px 8px;flex:1;} .user-item{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;cursor:pointer;transition:background .15s;} .user-item:hover{background:var(--bg3);} .user-item.active{background:var(--bg4);} .user-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg4);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;position:relative;overflow:hidden;} .user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;} .status-dot{position:absolute;bottom:0;right:0;width:9px;height:9px;border-radius:50%;border:2px solid var(--bg2);} .status-dot.online{background:var(--green);} .status-dot.offline{background:var(--text3);} .status-dot.away{background:var(--yellow);} .user-meta{flex:1;min-width:0;} .user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .user-status-text{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .badge-owner{font-size:9px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;padding:1px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;margin-left:3px;} .badge-banned{font-size:9px;font-weight:700;background:var(--red);color:#fff;padding:1px 5px;border-radius:4px;text-transform:uppercase;margin-left:3px;} .dm-unread{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;} .sidebar-bottom{padding:10px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;} .my-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg4);flex-shrink:0;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;} .my-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;} .my-info{flex:1;min-width:0;cursor:pointer;} .my-name{font-size:13px;font-weight:600;} .my-status{font-size:11px;color:var(--text3);} .sidebar-icons{display:flex;gap:2px;} .icon-btn{width:29px;height:29px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:transparent;border:none;color:var(--text2);transition:all .15s;font-size:14px;} .icon-btn:hover{background:var(--bg3);color:var(--text);} #dev-btn{display:none !important;} #dev-btn.owner-visible{display:flex !important;color:var(--accent);} /* ── CHAT AREA ── */ #chat-area{flex:1;display:flex;flex-direction:column;min-width:0;position:relative;} .chat-header{padding:0 16px;height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--bg2);flex-shrink:0;} .hamburger{display:none;width:32px;height:32px;border-radius:6px;border:none;background:transparent;cursor:pointer;color:var(--text2);font-size:18px;align-items:center;justify-content:center;} .hamburger:hover{background:var(--bg3);color:var(--text);} .chat-header-icon{color:var(--accent);font-size:17px;font-weight:700;} .chat-header-name{font-weight:700;font-size:15px;} .chat-header-desc{font-size:12px;color:var(--text3);margin-left:4px;display:none;} .header-spacer{flex:1;} .header-btn{width:32px;height:32px;border-radius:7px;border:none;background:transparent;cursor:pointer;color:var(--text2);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .15s;} .header-btn:hover{background:var(--bg3);color:var(--text);} .header-btn.active{color:var(--accent);} .header-member-count{font-size:12px;color:var(--text3);padding:0 6px;} .pinned-bar{background:var(--bg3);border-bottom:1px solid var(--border);padding:8px 16px;font-size:13px;color:var(--text2);display:none;align-items:center;gap:8px;cursor:pointer;flex-shrink:0;} .pinned-bar:hover{background:var(--bg4);} .pinned-bar.show{display:flex;} .pinned-bar strong{color:var(--text);} /* ── LOAD MORE ── */ #load-more-wrap{padding:10px;text-align:center;flex-shrink:0;} .load-more-btn{padding:6px 18px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;color:var(--text2);font-size:12px;cursor:pointer;font-family:var(--font-sans);transition:all .2s;} .load-more-btn:hover{border-color:var(--accent);color:var(--accent);} /* ── MESSAGES ── */ #messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:0;scroll-behavior:smooth;} .msg-group{margin-top:4px;} .msg-group:first-child{margin-top:0;} /* ── COMPACT CHAT LINE STYLE ── */ .msg-line{display:flex;align-items:baseline;gap:0;padding:2px 0;position:relative;} .msg-line:hover{background:rgba(255,255,255,.025);border-radius:6px;margin:0 -8px;padding:2px 8px;} .msg-line:hover .msg-actions{opacity:1;pointer-events:all;} .msg-sender{font-weight:700;font-size:14px;cursor:pointer;margin-right:8px;white-space:nowrap;flex-shrink:0;} .msg-sender:hover{text-decoration:underline;} .msg-timestamp{font-size:11px;color:var(--text3);margin-right:8px;white-space:nowrap;flex-shrink:0;cursor:default;} .msg-content{font-size:14px;line-height:1.6;word-break:break-word;flex:1;min-width:0;} .msg-content.own .msg-sender{color:var(--accent);} .msg-edited{font-size:10px;color:var(--text3);font-style:italic;margin-left:4px;} /* Group header for first message in a group */ .msg-group-header{display:flex;align-items:baseline;gap:8px;margin-bottom:1px;margin-top:10px;} .msg-group-header .msg-sender{font-size:14px;font-weight:700;} .msg-group-header .msg-timestamp{font-size:11px;color:var(--text3);} /* Continued messages (same sender, within 5 min) — no name, just indent */ .msg-continued{display:flex;align-items:baseline;gap:0;padding:1px 0;padding-left:0;position:relative;} .msg-continued:hover{background:rgba(255,255,255,.025);border-radius:6px;margin:0 -8px;padding:1px 8px 1px calc(8px);} .msg-continued:hover .msg-actions{opacity:1;pointer-events:all;} .msg-continued .msg-content{font-size:14px;line-height:1.6;word-break:break-word;flex:1;min-width:0;} .msg-continued .msg-timestamp-hover{font-size:10px;color:var(--text3);margin-right:8px;white-space:nowrap;flex-shrink:0;opacity:0;width:52px;text-align:right;} .msg-continued:hover .msg-timestamp-hover{opacity:1;} .msg-actions{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:var(--bg2);border:1px solid var(--border);border-radius:8px;display:flex;gap:2px;padding:3px;opacity:0;pointer-events:none;transition:opacity .15s;z-index:10;box-shadow:0 4px 12px rgba(0,0,0,.35);} .msg-action-btn{width:27px;height:27px;border-radius:5px;border:none;background:transparent;cursor:pointer;color:var(--text2);font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;} .msg-action-btn:hover{background:var(--bg3);color:var(--text);} .reply-preview{border-left:3px solid var(--accent);padding:3px 8px;margin-bottom:3px;background:rgba(124,106,247,.07);border-radius:0 5px 5px 0;font-size:12px;color:var(--text2);cursor:pointer;display:inline-block;} .reply-preview:hover{background:rgba(124,106,247,.14);} .reply-preview strong{color:var(--accent);font-weight:600;} .msg-gif img{max-width:300px;border-radius:10px;display:block;margin-top:4px;} .reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;} .reaction{display:flex;align-items:center;gap:4px;background:var(--bg4);border:1px solid var(--border);border-radius:20px;padding:3px 9px;cursor:pointer;font-size:13px;transition:all .15s;} .reaction:hover{border-color:var(--accent);background:var(--accent-glow);} .reaction.mine{border-color:var(--accent);background:var(--accent-glow);} .reaction-count{font-size:12px;color:var(--text2);font-weight:600;} .pinned-badge{font-size:10px;background:rgba(124,106,247,.2);color:var(--accent);padding:2px 6px;border-radius:4px;margin-left:5px;} .sys-msg{align-self:center;text-align:center;font-size:12px;color:var(--text3);margin:6px 0;font-style:italic;padding:5px 14px;background:var(--bg3);border-radius:20px;} .date-divider{align-self:center;font-size:11px;color:var(--text3);margin:12px 0 4px;padding:3px 12px;background:var(--bg3);border-radius:20px;font-weight:600;} /* ── CONTENT FORMATTING ── */ .code-block{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin:6px 0;font-family:var(--font-mono);font-size:13px;overflow-x:auto;white-space:pre;line-height:1.5;color:#b0ffd8;} .code-inline{background:var(--bg4);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:var(--font-mono);font-size:13px;color:var(--accent);} .mention{background:var(--accent-glow);color:var(--accent);padding:1px 4px;border-radius:4px;cursor:pointer;font-weight:600;} .mention:hover{background:var(--accent);color:#fff;} .mention-me{background:rgba(124,106,247,.35);animation:mention-pulse 2s ease-out;} @keyframes mention-pulse{0%{background:rgba(124,106,247,.6);}100%{background:rgba(124,106,247,.35);}} .msg-link{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s;} .msg-link:hover{border-color:var(--accent);} .link-preview{margin-top:4px;} .inline-image{max-width:360px;max-height:280px;border-radius:10px;display:block;cursor:pointer;margin-top:4px;} .inline-image:hover{opacity:.9;} .yt-embed{position:relative;width:100%;max-width:400px;padding-top:56.25%;margin-top:4px;} .yt-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:10px;} .url-preview{display:inline-flex;gap:10px;background:var(--bg4);border:1px solid var(--border);border-radius:10px;padding:10px;max-width:400px;text-decoration:none;transition:border-color .15s;margin-top:4px;} .url-preview:hover{border-color:var(--accent);} .url-preview-icon{font-size:20px;flex-shrink:0;} .url-preview-text{min-width:0;} .url-preview-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .url-preview-domain{font-size:11px;color:var(--text3);} /* ── FILE MESSAGE ── */ .file-msg{display:inline-flex;align-items:center;gap:10px;background:var(--bg4);border:1px solid var(--border);border-radius:10px;padding:10px 14px;max-width:360px;margin-top:4px;} .file-icon{font-size:24px;flex-shrink:0;} .file-info{flex:1;min-width:0;} .file-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .file-size{font-size:11px;color:var(--text3);} .file-dl{color:var(--accent);text-decoration:none;font-size:12px;font-weight:600;flex-shrink:0;} .file-dl:hover{text-decoration:underline;} .upload-prog{height:3px;background:var(--bg3);border-radius:3px;margin-top:5px;overflow:hidden;} .upload-prog-bar{height:100%;background:var(--accent);border-radius:3px;transition:width .2s;} /* ── TYPING / MUTE ── */ #typing-indicator{padding:4px 20px 2px;min-height:22px;font-size:12px;color:var(--text3);font-style:italic;flex-shrink:0;} #mute-banner{display:none;padding:9px 16px;background:rgba(245,200,66,.1);border-top:1px solid rgba(245,200,66,.25);font-size:13px;color:var(--yellow);text-align:center;font-weight:500;flex-shrink:0;} #mute-banner.show{display:block;} /* ── INPUT ── */ .input-area{padding:12px 16px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0;} .reply-bar{display:none;align-items:center;justify-content:space-between;background:var(--bg3);border-radius:8px;padding:6px 11px;margin-bottom:9px;font-size:12px;color:var(--text2);border-left:3px solid var(--accent);} .reply-bar.show{display:flex;} .reply-bar-name{color:var(--accent);font-weight:600;} .reply-bar-close{cursor:pointer;color:var(--text3);font-size:15px;margin-left:8px;transition:color .15s;} .reply-bar-close:hover{color:var(--red);} .input-row{display:flex;align-items:flex-end;gap:7px;} #msg-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:10px 14px;color:var(--text);font-family:var(--font-sans);font-size:15px;resize:none;outline:none;max-height:150px;min-height:42px;transition:border-color .2s;overflow-y:auto;line-height:1.5;} #msg-input:focus{border-color:var(--accent);} #msg-input::placeholder{color:var(--text3);} #msg-input:disabled{opacity:.5;cursor:not-allowed;} .input-btn{width:42px;height:42px;border-radius:11px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;font-family:var(--font-mono);} .send-btn{background:var(--accent);color:#fff;font-size:17px;} .send-btn:hover{background:var(--accent2);transform:scale(1.05);} .send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;} .gif-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:11px;font-weight:700;} .gif-btn:hover{border-color:var(--accent);color:var(--accent);} .file-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:17px;} .file-btn:hover{border-color:var(--accent);color:var(--accent);} #file-input{display:none;} /* ── MENTION DROPDOWN ── */ #mention-dropdown{position:absolute;bottom:100%;left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:10px;margin:4px 8px;overflow:hidden;display:none;z-index:30;box-shadow:0 -6px 20px rgba(0,0,0,.4);} #mention-dropdown.show{display:block;} .mention-item{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;transition:background .1s;} .mention-item:hover,.mention-item.selected{background:var(--bg3);} .mention-avatar{width:26px;height:26px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;overflow:hidden;} .mention-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;} .mention-name{font-size:13px;font-weight:600;} .mention-handle{font-size:11px;color:var(--text3);} /* ── SCROLL TO BOTTOM ── */ #scroll-btn{position:absolute;bottom:80px;right:16px;width:38px;height:38px;background:var(--accent);border:none;border-radius:50%;cursor:pointer;color:#fff;font-size:16px;display:none;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.4);transition:all .2s;z-index:20;} #scroll-btn.show{display:flex;} #scroll-btn:hover{background:var(--accent2);transform:scale(1.1);} .scroll-unread{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:8px;min-width:16px;text-align:center;} /* ── GIF PICKER ── */ #gif-picker{position:absolute;bottom:70px;left:16px;width:340px;max-height:370px;background:var(--bg2);border:1px solid var(--border);border-radius:14px;z-index:50;display:none;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px rgba(0,0,0,.5);} #gif-picker.show{display:flex;} .gif-search{padding:9px;border-bottom:1px solid var(--border);} .gif-search input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:7px 12px;color:var(--text);font-family:var(--font-sans);font-size:13px;outline:none;} .gif-search input:focus{border-color:var(--accent);} .gif-search input::placeholder{color:var(--text3);} .gif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:6px;overflow-y:auto;flex:1;} .gif-item{border-radius:7px;overflow:hidden;cursor:pointer;aspect-ratio:1;} .gif-item img{width:100%;height:100%;object-fit:cover;display:block;} .gif-item:hover{opacity:.75;} /* ── EMOJI PICKER ── */ #emoji-picker{position:fixed;z-index:60;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:10px;display:none;flex-wrap:wrap;gap:4px;width:240px;box-shadow:0 8px 30px rgba(0,0,0,.45);} #emoji-picker.show{display:flex;} .emoji-opt{font-size:22px;cursor:pointer;padding:4px;border-radius:6px;transition:background .1s;} .emoji-opt:hover{background:var(--bg3);} /* ── CONTEXT MENU ── */ #ctx-menu{position:fixed;z-index:100;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:5px;display:none;flex-direction:column;gap:1px;min-width:170px;box-shadow:0 10px 30px rgba(0,0,0,.5);} #ctx-menu.show{display:flex;} .ctx-item{padding:8px 13px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px;transition:background .1s;user-select:none;} .ctx-item:hover{background:var(--bg3);} .ctx-item.danger{color:var(--red);} .ctx-item.danger:hover{background:rgba(240,78,94,.1);} .ctx-sep{height:1px;background:var(--border);margin:3px 0;} /* ── SEARCH OVERLAY ── */ #search-overlay{position:fixed;inset:0;z-index:80;display:none;align-items:flex-start;justify-content:center;padding-top:80px;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);} #search-overlay.show{display:flex;} .search-box{width:580px;max-width:92vw;background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);} .search-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);} .search-icon{color:var(--text3);font-size:16px;} #search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-family:var(--font-sans);font-size:16px;} #search-input::placeholder{color:var(--text3);} .search-close{cursor:pointer;color:var(--text3);font-size:18px;transition:color .15s;} .search-close:hover{color:var(--red);} .search-results{max-height:400px;overflow-y:auto;padding:8px;} .search-result{padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .1s;} .search-result:hover{background:var(--bg3);} .search-result-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;} .search-result-name{font-size:13px;font-weight:700;} .search-result-time{font-size:11px;color:var(--text3);} .search-result-text{font-size:13px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .search-result-text mark{background:rgba(124,106,247,.3);color:var(--text);border-radius:2px;padding:0 2px;} .search-empty{padding:24px;text-align:center;color:var(--text3);font-size:14px;} /* ── PROFILE MODAL ── */ #profile-modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);} #profile-modal.show{display:flex;} .profile-card{width:380px;background:var(--bg2);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);} .profile-banner{height:100px;background:linear-gradient(135deg,var(--accent),var(--accent2));position:relative;overflow:hidden;} .profile-banner img{width:100%;height:100%;object-fit:cover;} .profile-avatar-wrap{position:absolute;bottom:-20px;left:20px;width:64px;height:64px;} .profile-avatar-large{width:64px;height:64px;border-radius:50%;border:4px solid var(--bg2);background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;overflow:hidden;} .profile-avatar-large img{width:100%;height:100%;object-fit:cover;border-radius:50%;} .profile-info{padding:28px 20px 20px;} .profile-name{font-size:18px;font-weight:700;display:flex;align-items:center;gap:6px;flex-wrap:wrap;} .profile-handle{font-size:13px;color:var(--text3);font-family:var(--font-mono);margin-top:2px;} .profile-bio{font-size:14px;color:var(--text2);margin-top:12px;line-height:1.5;} .profile-status-row{margin-top:10px;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text3);} .profile-custom-status{margin-top:6px;font-size:13px;color:var(--text2);} .profile-actions{display:flex;gap:8px;margin-top:14px;} .profile-action-btn{flex:1;padding:8px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text2);font-size:13px;cursor:pointer;font-family:var(--font-sans);transition:all .15s;font-weight:500;} .profile-action-btn:hover{border-color:var(--accent);color:var(--accent);} /* ── SETTINGS ── */ #settings-panel{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);} #settings-panel.show{display:flex;} .settings-card{width:510px;max-height:88vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.5);} .settings-title{font-family:var(--font-mono);font-size:16px;font-weight:700;margin-bottom:24px;color:var(--accent);} .settings-section{margin-bottom:22px;} .settings-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:8px;} .settings-input{width:100%;padding:10px 13px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:14px;outline:none;transition:border-color .2s;} .settings-input:focus{border-color:var(--accent);} .settings-input::placeholder{color:var(--text3);} .settings-input.locked{opacity:.5;cursor:not-allowed;} .settings-hint{font-size:11px;color:var(--text3);margin-top:5px;} .theme-grid{display:flex;flex-wrap:wrap;gap:7px;} .theme-opt{padding:7px 14px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;border:2px solid var(--border);transition:all .2s;background:var(--bg3);color:var(--text2);} .theme-opt:hover{border-color:var(--text2);color:var(--text);} .theme-opt.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);} .status-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;} .status-preset{padding:5px 11px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:12px;color:var(--text2);transition:all .15s;} .status-preset:hover{border-color:var(--accent);color:var(--accent);} .settings-row{display:flex;justify-content:space-between;align-items:center;gap:12px;} .save-btn{padding:10px 22px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font-sans);transition:all .2s;} .save-btn:hover{background:var(--accent2);} /* ── DEV PANEL ── */ #dev-panel{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);} #dev-panel.show{display:flex;} .dev-card{width:720px;max-height:88vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.5);} .dev-title{font-family:var(--font-mono);font-size:16px;color:var(--accent);margin-bottom:4px;} .dev-subtitle{font-size:12px;color:var(--text3);margin-bottom:22px;} .dev-tabs{display:flex;gap:4px;margin-bottom:20px;} .dev-tab{padding:7px 14px;border-radius:7px;cursor:pointer;font-size:12px;font-weight:600;background:var(--bg3);border:none;color:var(--text2);transition:all .2s;} .dev-tab.active{background:var(--accent);color:#fff;} .dev-section{display:none;} .dev-section.show{display:block;} .user-row{display:flex;align-items:flex-start;gap:10px;padding:12px;border-radius:10px;border:1px solid var(--border);margin-bottom:8px;background:var(--bg3);} .user-row-info{flex:1;min-width:0;} .user-row-name{font-size:14px;font-weight:700;margin-bottom:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;} .user-row-handle{font-size:12px;color:var(--text3);font-family:var(--font-mono);} .user-row-meta{font-size:11px;color:var(--text3);margin-top:5px;line-height:1.7;} .user-row-meta strong{color:var(--text2);} .user-row-actions{display:flex;gap:5px;flex-wrap:wrap;flex-shrink:0;} .mod-btn{padding:5px 10px;border-radius:6px;border:none;cursor:pointer;font-size:11px;font-weight:700;font-family:var(--font-sans);transition:all .15s;} .mod-btn:hover{filter:brightness(1.2);} .mod-btn.ban{background:rgba(240,78,94,.15);color:var(--red);border:1px solid rgba(240,78,94,.3);} .mod-btn.unban{background:rgba(62,207,117,.15);color:var(--green);border:1px solid rgba(62,207,117,.3);} .mod-btn.mute{background:rgba(245,200,66,.15);color:var(--yellow);border:1px solid rgba(245,200,66,.3);} .mod-btn.unmute{background:rgba(62,207,117,.15);color:var(--green);border:1px solid rgba(62,207,117,.3);} .mod-btn.ip-ban{background:rgba(240,78,94,.1);color:var(--red);border:1px solid rgba(240,78,94,.2);} .log-item{padding:9px 13px;border-radius:8px;background:var(--bg3);margin-bottom:6px;font-size:12px;border-left:3px solid var(--accent);} .log-action{font-weight:700;color:var(--text);font-size:13px;} .log-meta{color:var(--text3);margin-top:2px;} .announce-input{width:100%;padding:10px 13px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:14px;outline:none;margin-bottom:10px;resize:vertical;min-height:80px;} .announce-input:focus{border-color:var(--accent);} .announce-input::placeholder{color:var(--text3);} .ip-ban-list{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:12px;} .ip-ban-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;} .ip-ban-item:last-child{border-bottom:none;} .ip-unban-btn{padding:3px 9px;background:rgba(62,207,117,.15);color:var(--green);border:1px solid rgba(62,207,117,.3);border-radius:5px;cursor:pointer;font-size:11px;font-weight:700;} /* ── GENERIC MODAL ── */ #modal-overlay{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);} #modal-overlay.show{display:flex;} .modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:28px;width:360px;box-shadow:0 20px 60px rgba(0,0,0,.5);} .modal-title{font-size:16px;font-weight:700;margin-bottom:14px;} .modal-body-text{color:var(--text2);font-size:14px;line-height:1.5;margin-bottom:12px;} .modal-input{width:100%;padding:9px 13px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:14px;outline:none;margin-bottom:10px;transition:border-color .2s;} .modal-input:focus{border-color:var(--accent);} .modal-input::placeholder{color:var(--text3);} .modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:6px;} .modal-cancel{padding:8px 16px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text2);cursor:pointer;font-size:13px;font-family:var(--font-sans);transition:all .15s;} .modal-cancel:hover{color:var(--text);} .modal-confirm{padding:8px 16px;background:var(--accent);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);transition:background .15s;} .modal-confirm:hover{background:var(--accent2);} .modal-confirm.danger{background:var(--red);} .modal-confirm.danger:hover{background:#c03040;} /* ── NOTIFICATIONS ── */ .notif{position:fixed;top:16px;right:16px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:13px 17px;z-index:999;font-size:13px;animation:slideIn .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.45);max-width:290px;line-height:1.4;} .notif.success{border-color:var(--green);color:var(--green);} .notif.error{border-color:var(--red);color:var(--red);} @keyframes slideIn{from{transform:translateX(20px);opacity:0;}to{transform:translateX(0);opacity:1;}} /* ── INLINE EDIT ── */ .edit-textarea{width:100%;background:var(--bg4);border:1px solid var(--accent);border-radius:8px;padding:8px 11px;color:var(--text);font-family:var(--font-sans);font-size:14px;resize:none;outline:none;min-height:60px;line-height:1.5;} .edit-actions{display:flex;gap:6px;margin-top:6px;} .edit-save{padding:5px 13px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;font-family:var(--font-sans);} .edit-save:hover{background:var(--accent2);} .edit-cancel{padding:5px 13px;background:var(--bg4);color:var(--text2);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:12px;font-family:var(--font-sans);} /* ── IMAGE LIGHTBOX ── */ #lightbox{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;cursor:zoom-out;} #lightbox.show{display:flex;} #lightbox img{max-width:90vw;max-height:90vh;border-radius:10px;object-fit:contain;} /* ── MOBILE ── */ @media(max-width:768px){ :root{--sidebar-w:260px;} #sidebar{position:fixed;left:calc(-1 * var(--sidebar-w));top:0;bottom:0;transition:left .28s cubic-bezier(.4,0,.2,1);box-shadow:none;} #sidebar.mobile-open{left:0;box-shadow:4px 0 24px rgba(0,0,0,.6);} .hamburger{display:flex;} #chat-area{width:100%;} .auth-box{width:calc(100vw - 32px);padding:28px 22px;} #gif-picker{width:calc(100vw - 32px);} .inline-image{max-width:100%;} .yt-embed{max-width:100%;} .search-box{width:calc(100vw - 24px);} .dev-card,.settings-card,.modal-box{width:calc(100vw - 24px);} } @media(min-width:769px){ .hamburger{display:none!important;} }
🔨
You are banned from Fraudcord
💬 the group
📌
Replying to
⚙ Settings
Display Name
Username — permanent
Usernames cannot be changed after signup.
Bio
Custom Status
🟢 Online
🌙 Sleeping
🎮 Gaming
💤 AFK
🎵 Listening
📵 DND
Profile Picture URL
Profile Banner URL
Theme
🌙 Dark
☀ Light
⬛ Pitch Black
🌊 Aurora
🔥 Sunset
🛠 Owner Panel
Moderation & administration — owner-only
Manually ban an IP address
Loading…
Send System Announcement