*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-family:Outfit,system-ui,sans-serif}button,input,textarea{font-family:inherit}:root{--bg:#14131f;--bg-deep:#0d0c15;--on-accent:#0d0c15;--panel:#1c1a29;--panel-2:#232032;--card:#272336;--line:#ffffff12;--line-soft:#ffffff0a;--text:#ece9f1;--text-dim:#9b96ad;--text-faint:#635e73;--coral:#ff6b5b;--coral-soft:#ff6b5b24;--amber:#ffb454;--read:#4fb8ff;--online:#4ade80;--glass:blur(16px) saturate(140%);--shadow-lg:0 24px 48px -12px #0000008c;--shadow-sm:0 4px 16px -4px #0006;--display:"Bricolage Grotesque", system-ui, sans-serif;--body:"Outfit", system-ui, sans-serif;--r-lg:20px;--r-md:14px;--r-sm:10px}body{background:var(--bg);color:var(--text);font-family:var(--body);height:100vh;overflow:hidden}body:before{content:"";z-index:-1;background:radial-gradient(60vw 60vw at 12% 0%, #ff6b5b1a, transparent 60%), radial-gradient(50vw 50vw at 100% 100%, #ffb45412, transparent 55%), var(--bg);position:fixed;inset:0}.auth-page{place-items:center;height:100vh;padding:24px;display:grid}.auth-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:44px 36px;animation:.5s cubic-bezier(.16,1,.3,1) rise;position:relative;overflow:hidden}.auth-card:before{content:"";background:linear-gradient(90deg, var(--coral), var(--amber));height:3px;position:absolute;top:0;left:0;right:0}.logo-mark{width:56px;height:56px;font-family:var(--display);color:var(--on-accent);background:linear-gradient(135deg, var(--coral), var(--amber));border-radius:16px;place-items:center;margin:0 auto 18px;font-size:28px;font-weight:800;display:grid;box-shadow:0 8px 24px -6px #ff6b5b80}.auth-card h1{font-family:var(--display);letter-spacing:-.5px;margin:0 0 28px;font-size:30px;font-weight:700}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-form input{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);color:var(--text);outline:none;padding:13px 15px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.auth-form input::placeholder{color:var(--text-faint)}.auth-form input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.auth-form button{background:linear-gradient(135deg, var(--coral), #ff8366);border-radius:var(--r-md);color:#fff;cursor:pointer;border:none;margin-top:4px;padding:13px;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .2s}.auth-form button:hover{transform:translateY(-1px);box-shadow:0 8px 20px -6px #ff6b5b80}.auth-form button:active{transform:translateY(0)}.link-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;margin-top:18px;font-size:.85rem;transition:color .2s}.link-btn:hover{color:var(--coral)}.app-shell{grid-template-columns:320px minmax(0,1fr);height:100vh;display:grid}.sidebar{background:var(--panel);border-right:1px solid var(--line);flex-direction:column;min-height:0;display:flex}.brand-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:22px 22px 18px;display:flex}.brand-row h2{font-family:var(--display);letter-spacing:-.5px;background:linear-gradient(135deg, var(--coral), var(--amber));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.45rem;font-weight:700}.ghost-btn{border:1px solid var(--line);color:var(--text-dim);border-radius:var(--r-sm);cursor:pointer;background:0 0;padding:7px 13px;font-size:.82rem;transition:all .18s}.ghost-btn:hover{border-color:var(--coral);color:var(--coral)}.user-list{flex-direction:column;flex:1;gap:2px;padding:10px;display:flex;overflow-y:auto}.user-row{width:100%;color:var(--text);border-radius:var(--r-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:11px 12px;transition:background .18s;display:flex}.user-row:hover{background:var(--panel-2)}.user-row.active{background:var(--coral-soft);box-shadow:inset 2px 0 0 var(--coral)}.user-row strong{font-size:.95rem;font-weight:500}.avatar{width:40px;height:40px;font-family:var(--display);color:var(--on-accent);background:linear-gradient(135deg, var(--amber), var(--coral));border-radius:12px;flex-shrink:0;place-items:center;font-size:1rem;font-weight:700;display:grid}.chat{flex-direction:column;min-width:0;min-height:0;display:flex;position:relative}.chat-header{border-bottom:1px solid var(--line);height:68px;-webkit-backdrop-filter:var(--glass);backdrop-filter:var(--glass);background:#14131fb3;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.chat-header h3{font-family:var(--display);margin:0;font-size:1.1rem;font-weight:600}.status-pill{color:var(--text-dim);border:1px solid var(--line);border-radius:999px;align-items:center;gap:6px;padding:5px 11px;font-size:.75rem;display:flex}.status-pill:before{content:"";background:var(--online);width:6px;height:6px;box-shadow:0 0 8px var(--online);border-radius:50%}.messages{flex-direction:column;flex:1;gap:10px;min-width:0;padding:24px;display:flex;overflow-y:auto}.bubble-wrap{width:100%;display:flex}.bubble-wrap.mine{justify-content:flex-end}.bubble{border-radius:18px;max-width:68%;padding:11px 15px;font-size:.94rem;line-height:1.45;animation:.28s cubic-bezier(.16,1,.3,1) rise;position:relative}.bubble p{overflow-wrap:anywhere;word-break:break-word;margin:0}.mine .bubble{background:linear-gradient(135deg, var(--coral), #ff8467);color:#fff;border-bottom-right-radius:5px}.theirs .bubble{background:var(--card);border:1px solid var(--line);color:var(--text);border-bottom-left-radius:5px}.msg-footer{justify-content:flex-end;align-items:center;gap:5px;margin-top:5px;display:flex}.msg-footer span{font-size:.68rem}.mine .msg-footer span{color:#ffffffbf}.theirs .msg-footer span{color:var(--text-faint)}.receipt{letter-spacing:-1px;font-weight:700;transition:color .3s}.receipt.read{color:var(--read);text-shadow:0 0 8px #4fb8ff80}.empty-chat{text-align:center;flex:1;place-items:center;padding:40px;display:grid}.empty-chat h1{font-family:var(--display);color:var(--text-dim);max-width:320px;font-size:1.6rem;font-weight:600;line-height:1.3}.composer{background:var(--panel);border-top:1px solid var(--line);flex-shrink:0;gap:10px;padding:16px 20px;display:flex}.composer input{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);color:var(--text);outline:none;flex:1;padding:12px 15px;font-size:.94rem;transition:border-color .2s,box-shadow .2s}.composer input::placeholder{color:var(--text-faint)}.composer input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.composer button{background:linear-gradient(135deg, var(--coral), #ff8366);border-radius:var(--r-md);color:#fff;cursor:pointer;border:none;padding:0 22px;font-size:.9rem;font-weight:600;transition:transform .15s,box-shadow .2s}.composer button:hover{transform:translateY(-1px);box-shadow:0 8px 20px -6px #ff6b5b80}.composer button:active{transform:translateY(0)}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:7px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}@media (width<=720px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:20;width:280px;box-shadow:var(--shadow-lg);position:absolute;inset:0 auto 0 0}.bubble{max-width:82%}}.brand-actions{align-items:center;gap:8px;display:flex}.icon-btn{border:1px solid var(--line);color:var(--text-dim);border-radius:var(--r-sm);cursor:pointer;background:0 0;place-items:center;width:34px;height:34px;transition:all .18s;display:grid;position:relative}.icon-btn:hover{border-color:var(--coral);color:var(--coral)}.notif-dot{color:#fff;background:var(--coral);border:2px solid var(--panel);border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.66rem;font-weight:700;display:grid;position:absolute;top:-6px;right:-6px}.notif-wrap{position:relative}.notif-panel{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);width:min(320px,100vw - 28px);max-height:440px;box-shadow:var(--shadow-lg);z-index:50;flex-direction:column;animation:.18s ease-out rise;display:flex;position:absolute;top:44px;left:0;right:auto;overflow:hidden}.notif-panel-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:13px 15px;display:flex}.notif-panel-head strong{font-family:var(--display);font-size:.95rem;font-weight:600}.link-btn-sm{color:var(--coral);cursor:pointer;background:0 0;border:none;font-size:.76rem}.link-btn-sm:hover{text-decoration:underline}.notif-list{overflow-y:auto}.notif-empty{text-align:center;color:var(--text-faint);padding:28px 16px;font-size:.85rem}.notif-item{border-bottom:1px solid var(--line-soft);border-left:2px solid #0000;padding:11px 15px}.notif-item.unread{background:var(--coral-soft);border-left-color:var(--coral)}.notif-item-top{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.notif-item-top strong{font-size:.88rem;font-weight:600}.notif-item-top span{color:var(--text-faint);flex-shrink:0;font-size:.7rem}.notif-item p{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;margin:3px 0 0;font-size:.8rem;overflow:hidden}.user-row{position:relative}.user-badge{color:#fff;background:var(--coral);border-radius:999px;place-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:.72rem;font-weight:700;display:grid}.receipt{white-space:nowrap;font-size:.68rem}.receipt.read{letter-spacing:0}.bubble-image{border:1px solid var(--line);padding:4px;background:var(--card)!important}.mine .bubble-image{background:var(--card)!important}.msg-image{border-radius:13px;width:100%;max-width:240px;height:auto;display:block}.bubble-image .msg-footer{padding:2px 6px 4px}.bubble-image .msg-footer span,.mine .bubble-image .msg-footer span{color:var(--text-faint)}.composer-icon{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);width:42px;color:var(--text-dim);cursor:pointer;flex-shrink:0;place-items:center;transition:all .18s;display:grid}.composer-icon:hover{border-color:var(--coral);color:var(--coral)}.composer-icon.active{background:var(--coral-soft);border-color:var(--coral);color:var(--coral)}.giphy-panel{border-top:1px solid var(--line);background:var(--panel);flex-direction:column;flex-shrink:0;max-height:320px;animation:.2s ease-out rise;display:flex}.giphy-search{border-bottom:1px solid var(--line-soft);color:var(--text-faint);align-items:center;gap:8px;padding:12px 16px;display:flex}.giphy-search input{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);outline:none;flex:1;padding:9px 12px;font-size:.88rem}.giphy-search input:focus{border-color:var(--coral)}.giphy-search button{background:var(--coral);border-radius:var(--r-sm);color:#fff;cursor:pointer;border:none;padding:9px 14px;font-size:.82rem;font-weight:600}.giphy-grid{column-count:4;column-gap:8px;padding:12px 16px;overflow-y:auto}.giphy-status{text-align:center;color:var(--text-faint);padding:28px 0;font-size:.85rem}.giphy-thumb{border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;background:var(--bg-deep);break-inside:avoid;width:100%;margin:0 0 8px;padding:0;transition:border-color .15s,transform .15s;display:block;overflow:hidden}.giphy-thumb:hover{border-color:var(--coral);transform:scale(1.03)}.giphy-thumb img{width:100%;height:auto;display:block}@media (width<=720px){.giphy-grid{column-count:2}.msg-image{max-width:180px}}.notif-tabs{border-bottom:1px solid var(--line);display:flex}.notif-tabs button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:11px 8px;font-size:.82rem;font-weight:600;transition:color .15s,border-color .15s;display:inline-flex}.notif-tabs button:hover{color:var(--text)}.notif-tabs button.active{color:var(--coral);border-bottom-color:var(--coral)}.tab-count{color:#fff;background:var(--coral);border-radius:999px;place-items:center;min-width:17px;height:17px;padding:0 4px;font-size:.62rem;font-weight:700;display:grid}.req-item{border-bottom:1px solid var(--line-soft);align-items:center;gap:10px;padding:10px 14px;display:flex}.req-name{flex-direction:column;flex:1;min-width:0;display:flex}.req-name strong{font-size:.88rem;font-weight:600}.req-name span{color:var(--text-faint);font-size:.68rem}.req-actions{flex-shrink:0;gap:6px;display:flex}.req-accept,.req-decline{border-radius:var(--r-sm);border:1px solid var(--line);cursor:pointer;background:0 0;place-items:center;width:30px;height:30px;transition:all .15s;display:grid}.req-accept{color:#34d399}.req-accept:hover{color:#04110b;background:#34d399;border-color:#34d399}.req-decline{color:var(--text-faint)}.req-decline:hover{background:var(--line);color:var(--text)}.add-search{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);color:var(--text-faint);align-items:center;gap:8px;margin:12px 12px 0;padding:8px 12px;display:flex}.add-search input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:.88rem}.add-search input::placeholder{color:var(--text-faint)}.search-results{border:1px solid var(--line);border-radius:var(--r-md);margin:8px 12px 0;overflow:hidden}.search-status{text-align:center;color:var(--text-faint);padding:14px;font-size:.82rem}.search-row{border-bottom:1px solid var(--line-soft);align-items:center;gap:10px;padding:9px 12px;display:flex}.search-row:last-child{border-bottom:none}.search-row strong{flex:1;min-width:0;font-size:.9rem;font-weight:500}.add-btn{background:var(--coral);color:#fff;border-radius:var(--r-sm);cursor:pointer;border:none;flex-shrink:0;align-items:center;gap:5px;padding:6px 11px;font-size:.78rem;font-weight:600;transition:filter .15s;display:inline-flex}.add-btn:hover{filter:brightness(1.08)}.tag-friend,.tag-pending{border-radius:999px;flex-shrink:0;padding:4px 9px;font-size:.72rem;font-weight:600}.tag-friend{color:#34d399;background:#34d3991f}.tag-pending{color:var(--text-faint);background:var(--panel-2)}.avatar.sm{width:32px;height:32px;font-size:.82rem}.friends-empty{text-align:center;color:var(--text-faint);padding:28px 18px;font-size:.85rem;line-height:1.5}.report-btn{color:var(--text-faint);cursor:pointer;opacity:.5;background:0 0;border:none;padding:0;transition:opacity .15s,color .15s;display:inline-flex}.report-btn:hover{opacity:1;color:var(--coral)}.admin-shell{background:var(--bg);flex-direction:column;height:100vh;display:flex}.admin-top{border-bottom:1px solid var(--line);align-items:center;gap:16px;padding:16px 22px;display:flex}.admin-back{border:1px solid var(--line);color:var(--text-dim);border-radius:var(--r-sm);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:7px 13px;font-size:.82rem;display:inline-flex}.admin-back:hover{border-color:var(--coral);color:var(--coral)}.admin-title{font-family:var(--display);align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:inline-flex}.admin-me{color:var(--text-faint);margin-left:auto;font-size:.85rem}.admin-tabs{border-bottom:1px solid var(--line);gap:4px;padding:10px 18px 0;display:flex}.admin-tabs button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;padding:9px 13px;font-size:.86rem;font-weight:600;display:inline-flex}.admin-tabs button:hover{color:var(--text)}.admin-tabs button.active{color:var(--coral);border-bottom-color:var(--coral)}.admin-pill{color:#fff;background:var(--coral);border-radius:999px;place-items:center;min-width:17px;height:17px;padding:0 4px;font-size:.62rem;font-weight:700;display:grid}.admin-body{flex:1;width:100%;max-width:880px;margin:0 auto;padding:22px;overflow-y:auto}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);flex-direction:column;gap:4px;padding:20px;display:flex}.stat-card.alert{border-color:var(--coral)}.stat-num{font-family:var(--display);font-size:2rem;font-weight:700}.stat-label{color:var(--text-dim);font-size:.8rem}.admin-search{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);color:var(--text-faint);align-items:center;gap:9px;margin-bottom:14px;padding:9px 13px;display:flex}.admin-search input,.admin-search select{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.admin-search select option{background:var(--panel);color:var(--text)}.admin-table{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.admin-empty{text-align:center;color:var(--text-faint);padding:30px;font-size:.9rem}.admin-row{border-bottom:1px solid var(--line-soft);align-items:center;gap:13px;padding:12px 15px;display:flex}.admin-row:last-child{border-bottom:none}.admin-row.is-banned{opacity:.55}.admin-avatar{background:var(--coral-soft);width:38px;height:38px;color:var(--coral);border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.admin-row-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.admin-row-main strong{align-items:center;gap:7px;font-size:.92rem;display:flex}.admin-row-main span{color:var(--text-faint);font-size:.74rem}.role-tag{text-transform:uppercase;letter-spacing:.04em;background:var(--coral-soft);color:var(--coral);border-radius:4px;padding:2px 6px;font-size:.62rem;font-weight:700}.role-tag.ban{color:#ef4444;background:#ef444426}.admin-row-actions{flex-shrink:0;gap:7px;display:flex}.admin-row-actions button{border:1px solid var(--line);border-radius:var(--r-sm);width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;place-items:center;transition:all .15s;display:grid}.admin-row-actions button:hover{border-color:var(--coral);color:var(--coral)}.admin-row-actions .ban:hover{color:#ef4444;border-color:#ef4444}.admin-row-actions .unban{color:#34d399;border-color:#34d399}.flag-row{border-bottom:1px solid var(--line-soft);gap:12px;padding:14px 15px;display:flex}.flag-row:last-child{border-bottom:none}.flag-row.done{opacity:.5}.flag-main{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.flag-meta{color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:5px;font-size:.78rem;display:flex}.flag-reason{color:var(--text-dim);font-size:.82rem;font-style:italic}.flag-content{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);word-break:break-word;padding:9px 12px;font-size:.9rem}.flag-actions{flex-shrink:0;align-items:flex-start;gap:7px;display:flex}.flag-actions button,.viewer-row .danger{border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;background:0 0;place-items:center;width:32px;height:32px;transition:all .15s;display:grid}.flag-actions .resolve{color:#34d399}.flag-actions .resolve:hover{color:#04110b;background:#34d399;border-color:#34d399}.flag-actions .danger,.viewer-row .danger{color:#ef4444}.flag-actions .danger:hover,.viewer-row .danger:hover{color:#fff;background:#ef4444;border-color:#ef4444}.viewer-row{border-bottom:1px solid var(--line-soft);align-items:center;gap:12px;padding:11px 15px;display:flex}.viewer-row:last-child{border-bottom:none}.viewer-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.viewer-dir{color:var(--text-faint);font-size:.72rem}.viewer-text{word-break:break-word;font-size:.9rem}.viewer-time{color:var(--text-faint);font-size:.68rem}.mod-actions{align-items:center;gap:6px;display:inline-flex}.strike-btn{color:#f59e0b;border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b;align-items:center;gap:4px;padding:5px 9px;font-size:.74rem;font-weight:600;transition:all .15s;display:inline-flex}.strike-btn:hover{color:#1a1305;background:#f59e0b}.ban-select{background:var(--panel-2);color:#ef4444;border-radius:var(--r-sm);cursor:pointer;border:1px solid #ef4444;padding:5px 7px;font-size:.74rem;font-weight:600}.ban-select option{background:var(--panel);color:var(--text)}.lift-btn{color:#34d399;border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #34d399;padding:5px 9px;font-size:.74rem;font-weight:600;transition:all .15s}.lift-btn:hover{color:#04110b;background:#34d399}.role-tag.strike{color:#f59e0b;background:#f59e0b26}.flag-mod{border-top:1px dashed var(--line);margin-top:8px;padding-top:8px}.strike-warning{border-radius:var(--r-md);color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b;flex-direction:column;gap:4px;margin:12px 12px 0;padding:11px 13px;font-size:.82rem;line-height:1.45;display:flex}.strike-reason{color:var(--text-dim);font-size:.76rem;font-style:italic}.chat-header-right{align-items:center;gap:10px;display:flex}.report-user-btn{border:1px solid var(--line);color:var(--text-faint);border-radius:var(--r-sm);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:5px 10px;font-size:.78rem;font-weight:600;transition:all .15s;display:inline-flex}.report-user-btn:hover{border-color:var(--coral);color:var(--coral)}.flag-type{letter-spacing:.05em;color:#ef4444;background:#ef444426;border-radius:4px;padding:2px 6px;font-size:.62rem;font-weight:800}.flag-type.msg{background:var(--coral-soft);color:var(--coral)}.va-btn{border:1px solid var(--line);color:var(--text-dim);border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:4px;padding:5px 9px;font-size:.74rem;font-weight:600;transition:all .15s;display:inline-flex}.va-btn:hover{border-color:var(--coral);color:var(--coral)}.viewas-banner{color:#fbbf24;background:#f59e0b1f;border-bottom:1px solid #f59e0b;align-items:center;gap:8px;padding:11px 22px;font-size:.85rem;display:flex}.viewas-body{flex:1;grid-template-columns:240px minmax(0,1fr);min-height:0;display:grid}.viewas-friends{border-right:1px solid var(--line);flex-direction:column;gap:2px;padding:10px;display:flex;overflow-y:auto}.viewas-friends-head{text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);padding:8px 10px;font-size:.72rem}.viewas-friend{color:var(--text);border-radius:var(--r-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:9px 10px;font-size:.9rem;transition:background .15s;display:flex}.viewas-friend:hover{background:var(--panel-2)}.viewas-friend.active{background:var(--coral-soft);box-shadow:inset 2px 0 0 var(--coral)}.admin-avatar.sm{width:30px;height:30px;font-size:.78rem}.viewas-thread{flex-direction:column;gap:10px;padding:22px;display:flex;overflow-y:auto}.va-bubble-wrap{display:flex}.va-bubble-wrap.mine{justify-content:flex-end}.va-bubble-wrap.theirs{justify-content:flex-start}.va-bubble{background:var(--panel);border:1px solid var(--line);border-radius:16px;max-width:70%;padding:9px 13px;font-size:.9rem}.va-bubble-wrap.mine .va-bubble{background:var(--coral);color:#fff;border-color:#0000}.va-bubble p{word-break:break-word;margin:0}.va-time{opacity:.6;margin-top:4px;font-size:.66rem;display:block}.va-bubble .msg-image{border-radius:10px;max-width:220px}.unstrike-btn{color:#34d399;border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #34d399;align-items:center;gap:4px;padding:5px 9px;font-size:.74rem;font-weight:600;transition:all .15s;display:inline-flex}.unstrike-btn:hover{color:#04110b;background:#34d399}.avatar{overflow:hidden}.avatar-img{object-fit:cover;width:100%;height:100%;display:block}.me-strip{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);align-items:center;gap:11px;margin:12px 12px 0;padding:11px 13px;display:flex}.me-avatar{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;line-height:0;position:relative}.me-cam{background:var(--coral);color:#fff;border:2px solid var(--panel-2);border-radius:50%;place-items:center;width:18px;height:18px;display:grid;position:absolute;bottom:-3px;right:-3px}.me-name{flex-direction:column;min-width:0;display:flex}.me-name strong{font-size:.92rem}.me-name span{color:var(--text-faint);font-size:.72rem}.chat-header-left{align-items:center;gap:11px;display:flex}.chat-header-left h3{margin:0}.bubble-wrap{flex-direction:column}.bubble-wrap.mine{align-items:flex-end}.bubble-wrap.theirs{align-items:flex-start}.bubble{position:relative}.react-overlay{z-index:40;position:fixed;inset:0}.react-picker{background:var(--panel-2);border:1px solid var(--line);box-shadow:var(--shadow-lg);z-index:50;border-radius:999px;gap:2px;margin-bottom:7px;padding:5px 8px;display:flex;position:absolute;bottom:100%;left:0}.bubble-wrap.mine .react-picker{left:auto;right:0}.react-picker button{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:3px 4px;font-size:1.2rem;line-height:1;transition:transform .1s,background .1s}.react-picker button:hover{background:var(--panel);transform:scale(1.3)}.react-chips{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.react-chip{background:var(--panel-2);border:1px solid var(--line);cursor:pointer;border-radius:999px;align-items:center;gap:3px;padding:1px 7px;font-size:.74rem;line-height:1.5;transition:all .12s;display:inline-flex}.react-chip:hover{border-color:var(--coral)}.react-chip.mine{background:var(--coral-soft);border-color:var(--coral)}[data-theme=midnight]{--bg:#0e1124;--bg-deep:#080a18;--on-accent:#080a18;--panel:#151a33;--panel-2:#1d2440;--card:#222a4a;--coral:#6c7cff;--coral-soft:#6c7cff29;--amber:#9d7bff;--read:#4fb8ff;--online:#4ade80}[data-theme=ocean]{--bg:#0c1a1e;--bg-deep:#071215;--on-accent:#071215;--panel:#11262b;--panel-2:#173238;--card:#1b3a41;--coral:#2dd4bf;--coral-soft:#2dd4bf26;--amber:#38bdf8;--read:#38bdf8;--online:#4ade80}[data-theme=forest]{--bg:#101a12;--bg-deep:#0a120c;--on-accent:#0a120c;--panel:#16241a;--panel-2:#1d2f22;--card:#22392a;--coral:#4ade80;--coral-soft:#4ade8026;--amber:#a3e635;--read:#4fb8ff;--online:#34d399}[data-theme=grape]{--bg:#171025;--bg-deep:#0f0a18;--on-accent:#0f0a18;--panel:#22182f;--panel-2:#2c2040;--card:#33274a;--coral:#c084fc;--coral-soft:#c084fc29;--amber:#f0abfc;--read:#4fb8ff;--online:#4ade80}[data-theme=rose]{--bg:#1e1018;--bg-deep:#150a11;--on-accent:#150a11;--panel:#2a1722;--panel-2:#361d2c;--card:#412334;--coral:#fb7185;--coral-soft:#fb718529;--amber:#fda4af;--read:#4fb8ff;--online:#4ade80}[data-theme=daylight]{--bg:#f4f1f7;--bg-deep:#fff;--on-accent:#1b0f0c;--panel:#fff;--panel-2:#f3f0f8;--card:#fbfafd;--line:#140f1e1a;--line-soft:#140f1e0d;--text:#221e2e;--text-dim:#6b6680;--text-faint:#9a95a8;--coral:#f0533f;--coral-soft:#f0533f1f;--amber:#f59e0b;--read:#2a93e0;--online:#1fa463;--shadow-lg:0 24px 48px -12px #3c285a2e;--shadow-sm:0 4px 16px -4px #3c285a1f}.theme-menu-wrap{position:relative}.theme-dropdown{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);width:230px;box-shadow:var(--shadow-lg);z-index:60;padding:8px;position:absolute;top:calc(100% + 8px);right:0}.theme-dropdown-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);padding:4px 6px 8px;font-size:.7rem}.theme-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.theme-option{background:var(--panel);border:1.5px solid var(--line);border-radius:var(--r-sm);cursor:pointer;color:var(--text-dim);align-items:center;gap:8px;padding:8px 9px;font-size:.82rem;font-weight:600;transition:all .14s;display:flex}.theme-option:hover{color:var(--text);border-color:var(--text-faint)}.theme-option.active{border-color:var(--coral);color:var(--text)}.theme-swatch{border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;width:18px;height:18px}.me-strip{text-align:left;width:auto;font:inherit;color:inherit;cursor:pointer;transition:border-color .14s,background .14s}.me-strip:hover{border-color:var(--text-faint)}.me-strip .me-name span{color:var(--text-faint)}.me-gear{color:var(--text-faint);flex-shrink:0;margin-left:auto}.me-strip:hover .me-gear{color:var(--coral)}.settings-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.settings-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);width:100%;max-width:440px;max-height:88vh;box-shadow:var(--shadow-lg);overflow-y:auto}.settings-head{border-bottom:1px solid var(--line);background:var(--panel);z-index:1;justify-content:space-between;align-items:center;padding:18px 20px;display:flex;position:sticky;top:0}.settings-head h3{font-family:var(--display);margin:0}.settings-body{padding:8px 20px 20px}.settings-section{border-bottom:1px solid var(--line-soft);padding:16px 0}.settings-section:last-child{border-bottom:none}.settings-section h4{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);margin:0 0 12px;font-size:.74rem}.settings-pfp-row{align-items:center;gap:14px;margin-bottom:16px;display:flex}.settings-pfp-actions{flex-direction:column;gap:6px;display:flex}.settings-label{color:var(--text-dim);margin-bottom:6px;font-size:.8rem;display:block}.settings-name-row{gap:8px;display:flex}.settings-input{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);font:inherit;flex:1;padding:9px 12px;font-size:.9rem}.settings-input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft);outline:none}.settings-msg{margin:8px 0 0;font-size:.8rem}.settings-msg.ok{color:var(--online)}.settings-msg.err{color:var(--coral)}.mini-btn{background:var(--coral-soft);color:var(--coral);border-radius:var(--r-sm);font:inherit;cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 13px;font-size:.82rem;font-weight:600;transition:all .14s;display:inline-flex}.mini-btn:hover:not(:disabled){background:var(--coral);color:var(--on-accent)}.mini-btn:disabled{opacity:.5;cursor:default}.mini-btn.ghost{color:var(--text-dim);border-color:var(--line);background:0 0}.mini-btn.ghost:hover{color:var(--text);border-color:var(--text-faint);background:0 0}.settings-toggle{width:100%;color:var(--text);font:inherit;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:4px 0;font-size:.9rem;display:flex}.switch{background:var(--panel-2);border:1px solid var(--line);border-radius:999px;flex-shrink:0;width:42px;height:24px;transition:background .16s;position:relative}.switch .knob{background:var(--text-dim);border-radius:50%;width:18px;height:18px;transition:transform .16s,background .16s;position:absolute;top:2px;left:2px}.switch.on{background:var(--coral);border-color:var(--coral)}.switch.on .knob{background:#fff;transform:translate(18px)}.settings-hint{color:var(--text-faint);margin:8px 0 0;font-size:.76rem}.settings-info{justify-content:space-between;padding:7px 0;font-size:.86rem;display:flex}.settings-info span{color:var(--text-dim)}.settings-signout{border:1px solid var(--line);border-radius:var(--r-sm);width:100%;color:var(--coral);font:inherit;cursor:pointer;background:0 0;margin-top:14px;padding:10px;font-weight:600;transition:all .14s}.settings-signout:hover{background:var(--coral-soft);border-color:var(--coral)}.auth-tagline{text-align:center;color:var(--text-dim);margin:-6px 0 6px;font-size:.9rem}.auth-row{gap:8px;display:flex}.auth-row input{flex:1;min-width:0}.auth-divider{color:var(--text-faint);text-transform:uppercase;letter-spacing:.07em;align-items:center;gap:10px;margin:6px 0 2px;font-size:.7rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--line);flex:1;height:1px}.auth-form input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.auth-form input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.auth-form input[type=number]{-moz-appearance:textfield}.admin-row-personal{color:var(--text-dim);margin-top:1px;font-size:.78rem}.admin-row-personal a{color:var(--coral);text-decoration:none}.admin-row-personal a:hover{text-decoration:underline}.acct-list{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.acct-row{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);align-items:center;gap:10px;padding:8px 10px;display:flex}.acct-row.active{border-color:var(--coral);background:var(--coral-soft)}.acct-info{flex-direction:column;flex:1;min-width:0;display:flex}.acct-info strong{font-size:.9rem}.acct-info span{color:var(--text-faint);font-size:.72rem}.acct-active-dot{background:var(--online);border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-right:4px}.acct-remove{width:26px;height:26px;color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:7px;flex-shrink:0;place-items:center;display:grid}.acct-remove:hover{background:var(--panel-2);color:var(--text)}.avatar-presence{line-height:0;display:inline-block;position:relative}.avatar-presence.online:after{content:"";background:var(--online);border:2px solid var(--panel);border-radius:50%;width:11px;height:11px;position:absolute;bottom:-1px;right:-1px}.chat-header-name{flex-direction:column;gap:1px;display:flex}.chat-header-name h3{margin:0;line-height:1.1}.presence-line{color:var(--text-dim);font-size:.72rem}.chat-search{border-bottom:1px solid var(--line);color:var(--text-faint);background:var(--panel);align-items:center;gap:8px;padding:8px 14px;display:flex}.chat-search input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.chat-search button{color:var(--text-faint);cursor:pointer;background:0 0;border:none;place-items:center;display:grid}.msg-menu{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-lg);z-index:50;min-width:168px;margin-bottom:7px;position:absolute;bottom:100%;left:0;overflow:hidden}.bubble-wrap.mine .msg-menu{left:auto;right:0}.msg-menu-emojis{border-bottom:1px solid var(--line);gap:2px;padding:6px 8px;display:flex}.msg-menu-emojis button{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:3px 4px;font-size:1.2rem;line-height:1;transition:transform .1s,background .1s}.msg-menu-emojis button:hover{background:var(--panel);transform:scale(1.3)}.msg-menu-actions{flex-direction:column;padding:4px;display:flex}.msg-menu-actions button{text-align:left;color:var(--text);border-radius:var(--r-sm);cursor:pointer;background:0 0;border:none;padding:8px 10px;font-size:.85rem;font-weight:600}.msg-menu-actions button:hover{background:var(--panel)}.msg-menu-actions button.danger{color:var(--coral)}.reply-quote{border-left:3px solid var(--coral);background:var(--panel-2);border-radius:8px 8px 0 0;flex-direction:column;gap:1px;max-width:78%;margin-bottom:-2px;padding:4px 10px;font-size:.76rem;display:flex}.reply-quote-name{color:var(--coral);font-weight:700}.reply-quote-text{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:240px;overflow:hidden}.bubble.deleted{opacity:.7}.msg-deleted{color:var(--text-faint);margin:0;font-style:italic}.typing-bubble{align-items:center;gap:4px;display:inline-flex;padding:12px 14px!important}.typing-dot{background:var(--text-faint);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-bounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.reply-bar{border-top:1px solid var(--line);background:var(--panel-2);align-items:center;gap:10px;padding:8px 14px;display:flex}.reply-bar.editing{border-left:3px solid var(--amber)}.reply-bar-text{flex-direction:column;flex:1;min-width:0;display:flex}.reply-bar-text strong{color:var(--coral);font-size:.8rem}.reply-bar.editing .reply-bar-text strong{color:var(--amber)}.reply-bar-text span{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.reply-bar>button{color:var(--text-faint);cursor:pointer;background:0 0;border:none;flex-shrink:0;place-items:center;display:grid}.emoji-panel{border-top:1px solid var(--line);background:var(--panel-2);grid-template-columns:repeat(8,1fr);gap:2px;max-height:160px;padding:8px 12px;display:grid;overflow-y:auto}.emoji-panel button{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:5px;font-size:1.35rem;line-height:1;transition:transform .1s,background .1s}.emoji-panel button:hover{background:var(--panel);transform:scale(1.25)}.user-row-text{text-align:left;flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.user-status{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.74rem;overflow:hidden}.chat-header-name h3{align-items:center;gap:6px;display:inline-flex}.nickname-btn{color:var(--text-faint);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;place-items:center;padding:2px;transition:opacity .12s,color .12s;display:grid}.nickname-btn:hover{opacity:1;color:var(--coral)}.announce-banner{z-index:200;background:linear-gradient(135deg, var(--coral), var(--amber));color:var(--on-accent);box-shadow:var(--shadow-sm);align-items:center;gap:10px;padding:10px 16px;font-size:.9rem;font-weight:600;display:flex;position:fixed;top:0;left:0;right:0}.announce-banner-text{flex:1;min-width:0}.announce-banner button{color:inherit;cursor:pointer;background:#0000001f;border:none;border-radius:50%;flex-shrink:0;place-items:center;width:26px;height:26px;display:grid}.announce-tab{flex-direction:column;gap:16px;display:flex}.announce-compose{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);padding:16px}.announce-compose h3{margin:0 0 4px}.announce-hint{color:var(--text-dim);margin:0 0 10px;font-size:.82rem}.announce-compose textarea{background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-sm);width:100%;color:var(--text);font:inherit;resize:vertical;box-sizing:border-box;padding:10px 12px}.announce-post{background:linear-gradient(135deg, var(--coral), var(--amber));color:var(--on-accent);border-radius:var(--r-sm);cursor:pointer;border:none;align-items:center;gap:7px;margin-top:10px;padding:9px 16px;font-weight:700;display:inline-flex}.announce-post:disabled{opacity:.5;cursor:default}.announce-row{border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:11px 13px;display:flex}.announce-row-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.announce-body{font-size:.9rem}.announce-time{color:var(--text-faint);font-size:.74rem}.audit-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:10px 13px;font-size:.85rem;display:flex}.audit-action{text-transform:capitalize;text-align:center;background:var(--panel-2);min-width:104px;color:var(--text-dim);border:1px solid var(--line);border-radius:999px;flex-shrink:0;padding:3px 9px;font-size:.74rem;font-weight:700}.audit-action.act-ban,.audit-action.act-strike,.audit-action.act-delete_message{background:var(--coral-soft);color:var(--coral);border-color:var(--coral)}.audit-action.act-unban,.audit-action.act-remove_strike{color:var(--online);border-color:var(--online);background:#4ade801f}.audit-main{flex:1;min-width:0}.audit-detail{color:var(--text-dim);margin-left:6px;font-style:italic}.audit-time{color:var(--text-faint);flex-shrink:0;font-size:.74rem}.file-chip{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);align-items:center;gap:10px;max-width:260px;padding:10px 12px;text-decoration:none;transition:border-color .12s;display:flex}.file-chip:hover{border-color:var(--coral)}.file-chip-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.85rem;font-weight:600;overflow:hidden}.file-chip svg:last-child{color:var(--text-faint);flex-shrink:0}.bubble.mine .file-chip{background:#0000001f;border-color:#00000026}.groups-head,.friends-head{justify-content:space-between;align-items:center;margin-top:8px;padding:4px 14px;display:flex}.groups-head h4,.friends-head h4{text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint);margin:0;font-size:.7rem}.new-group-btn{background:var(--coral-soft);color:var(--coral);border:1px solid var(--coral);cursor:pointer;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:.74rem;font-weight:700;display:inline-flex}.group-list{flex-direction:column;display:flex}.group-avatar{background:linear-gradient(135deg, var(--coral), var(--amber));width:40px;height:40px;color:var(--on-accent);border-radius:14px;flex-shrink:0;place-items:center;display:grid}.chat-header-left .group-avatar{border-radius:11px;width:34px;height:34px}.group-sender{color:var(--coral);margin:0 0 1px 2px;font-size:.72rem;font-weight:700}.group-member-avatars{display:flex}.group-member-avatars .avatar{border:2px solid var(--panel);margin-left:-8px}.group-member-avatars .avatar:first-child{margin-left:0}.modal-overlay{z-index:100;background:#0000008c;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.new-group-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);flex-direction:column;gap:12px;max-height:80vh;padding:20px;display:flex}.new-group-head{justify-content:space-between;align-items:center;display:flex}.new-group-head h3{margin:0}.new-group-head button{color:var(--text-faint);cursor:pointer;background:0 0;border:none;place-items:center;display:grid}.new-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);margin:2px 0 0;font-size:.74rem}.new-group-friends{flex-direction:column;gap:4px;max-height:40vh;display:flex;overflow-y:auto}.new-group-empty{color:var(--text-dim);font-size:.86rem}.ng-friend{background:var(--panel-2);border:1.5px solid var(--line);border-radius:var(--r-sm);cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:8px 10px;font-size:.9rem;font-weight:600;display:flex}.ng-friend span{text-align:left;flex:1}.ng-friend.checked{border-color:var(--coral);color:var(--coral)}.ng-create{background:linear-gradient(135deg, var(--coral), var(--amber));color:var(--on-accent);border-radius:var(--r-sm);cursor:pointer;border:none;margin-top:4px;padding:11px;font-size:.95rem;font-weight:700}.ng-create:disabled{opacity:.5;cursor:default}.banned-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:12px 14px;display:flex}.banned-row-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.banned-until{color:var(--coral);font-size:.78rem}.unban-btn{color:var(--online);border:1px solid var(--online);border-radius:var(--r-sm);cursor:pointer;background:#4ade801f;flex-shrink:0;align-items:center;gap:6px;padding:7px 13px;font-size:.84rem;font-weight:700;display:inline-flex}.unban-btn:hover{background:#4ade8033}.auth-field-label{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;margin:2px 0 -4px 4px;font-size:.74rem}.auth-date{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=daylight] .auth-date{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}
