/* ============================================================
   SafeChat v0.1.0 – Application Style
   ============================================================ */

*,*::before,*::after{box-sizing:border-box}
html{height:100%;height:-webkit-fill-available}
body{height:100%;height:-webkit-fill-available;margin:0;overflow:hidden;font-family:var(--font);background:var(--app-bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer}
::selection{background:rgb(var(--accent-rgb)/.45);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-thumb{background:rgb(var(--border-rgb)/.9);border-radius:999px}

@font-face{font-family:Arad;src:url('https://cdn.jsdelivr.net/gh/MohamadDarvishi/Arad@834162ef87f10ae853357b16ed626374ed93d56c/web%20usage/Dots1/font-files/Arad-Regular.woff2') format('woff2'),url('https://cdn.jsdelivr.net/gh/MohamadDarvishi/Arad@834162ef87f10ae853357b16ed626374ed93d56c/web%20usage/Dots1/font-files/Arad-Regular.woff') format('woff');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:Arad;src:url('https://cdn.jsdelivr.net/gh/MohamadDarvishi/Arad@834162ef87f10ae853357b16ed626374ed93d56c/web%20usage/Dots1/font-files/Arad-Bold.woff2') format('woff2'),url('https://cdn.jsdelivr.net/gh/MohamadDarvishi/Arad@834162ef87f10ae853357b16ed626374ed93d56c/web%20usage/Dots1/font-files/Arad-Bold.woff') format('woff');font-weight:700;font-style:normal;font-display:swap}

:root{
  color-scheme:light;
  --font:'Arad','Vazirmatn',Tahoma,sans-serif;
  --mono:'JetBrains Mono','Courier New',monospace;
  --dur:180ms;
  --dur2:260ms;
  --ease:cubic-bezier(.2,.8,.2,1);
  --r-sm:10px;
  --r-md:14px;
  --r-lg:20px;
  --r-pill:999px;
  --accent:#00a676;
  --accent2:#006a4e;
  --accent-rgb:0 166 118;
  --accent2-rgb:0 106 78;
  --warn-rgb:217 119 6;
  --danger-rgb:220 38 38;
  --text-rgb:15 26 23;
  --border-rgb:215 230 223;
  --accent-contrast:#ffffff;
  --app-bg:#f6f8f7;
  --surface:#ffffff;
  --surface2:#f1f6f3;
  --border:#d7e6df;
  --text:#0f1a17;
  --text2:#36534a;
  --muted:#6f8b82;
  --shadow-sm:0 1px 2px rgba(15,26,23,.06),0 1px 1px rgba(15,26,23,.04);
  --shadow-md:0 16px 44px rgba(15,26,23,.14),0 2px 10px rgba(15,26,23,.07);
  --ring:rgb(var(--accent-rgb)/.35);
  --overlay:rgba(1,18,12,.55);
  --toast-bg:rgb(15 26 23/.92);
  --err-bg:#fff1f1;
  --err-bd:#ffb8b8;
  --err-tx:#7a1515;
}

[data-theme="dark"]{
  color-scheme:dark;
  --accent:#18c37e;
  --accent2:#10a36a;
  --accent-rgb:24 195 126;
  --accent2-rgb:16 163 106;
  --text-rgb:231 244 239;
  --border-rgb:34 49 43;
  --accent-contrast:#06120e;
  --app-bg:#0b1110;
  --surface:#0f1916;
  --surface2:#0c1512;
  --border:#22312b;
  --text:#e7f4ef;
  --text2:#b7cec5;
  --muted:#8fa9a0;
  --shadow-sm:0 1px 2px rgba(0,0,0,.34);
  --shadow-md:0 18px 54px rgba(0,0,0,.52),0 2px 12px rgba(0,0,0,.28);
  --ring:rgb(var(--accent-rgb)/.45);
  --overlay:rgba(0,0,0,.6);
  --toast-bg:rgba(0,0,0,.72);
  --err-bg:#2a1414;
  --err-bd:#7a2a2a;
  --err-tx:#ff9b9b;
}

:focus-visible{outline:3px solid var(--ring);outline-offset:2px}

#app{display:flex;height:100%;height:-webkit-fill-available;overflow:hidden}
#overlay{display:none;position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(6px);z-index:30}
#overlay.on{display:block}

#landing{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;text-align:center;padding:24px;color:rgba(255,255,255,.94);background:radial-gradient(1100px 520px at 50% 0%,rgb(var(--accent-rgb)/.22),transparent 60%),linear-gradient(135deg,#003d2c,#004d38)}
[data-theme="dark"] #landing{color:#e7f4ef;background:radial-gradient(1100px 520px at 50% 0%,rgb(var(--accent-rgb)/.18),transparent 60%),linear-gradient(135deg,#05100c,#0b1110)}
#landing h1{font-size:32px;font-weight:800;margin:0 0 10px;letter-spacing:-.6px}
#landing .sub{font-size:15px;line-height:1.8;margin:0 0 26px;color:rgba(255,255,255,.84);max-width:380px}
#landing .chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 0 26px}
#landing .chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.92);border-radius:var(--r-pill);padding:6px 14px;font-size:12px;font-weight:650}
#landing .start-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);text-decoration:none;border-radius:16px;padding:14px 36px;font-size:16px;font-weight:800;box-shadow:0 10px 30px rgb(var(--accent-rgb)/.24);transition:transform var(--dur2) var(--ease),filter var(--dur2) var(--ease);border:none}
#landing .start-btn:hover{transform:translateY(-2px);filter:brightness(1.03)}

#sidebar{width:296px;min-width:296px;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border);overflow:hidden;z-index:20}
.sb-top{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:radial-gradient(900px 240px at 30% 0%,rgb(var(--accent-rgb)/.28),transparent 55%),linear-gradient(135deg,#003d2c,#004d38)}
[data-theme="dark"] .sb-top{background:radial-gradient(900px 240px at 30% 0%,rgb(var(--accent-rgb)/.2),transparent 55%),linear-gradient(135deg,#06120e,#0c1714)}
.sb-logo{display:flex;align-items:center;gap:10px}
.sb-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(145deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 10px 22px rgb(var(--accent-rgb)/.28);flex-shrink:0}
.sb-name{font-size:17px;font-weight:850;letter-spacing:-.3px;color:#f0f8f4}
#sb-close{display:none;width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:rgba(255,255,255,.92);font-size:15px;align-items:center;justify-content:center;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}
#sb-close:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.26)}

.id-card{margin:14px 14px 0;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-md)}
.id-label{font-size:10px;font-weight:800;color:var(--accent2);letter-spacing:.9px;text-transform:uppercase;margin-bottom:6px}
.id-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.id-val{font-family:var(--mono);font-size:20px;font-weight:600;letter-spacing:3px;color:var(--text)}
[data-theme="dark"] .id-val{color:var(--accent)}

.btn-copy{display:flex;align-items:center;gap:6px;background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);border:none;border-radius:10px;padding:7px 12px;font-size:12px;font-weight:750;white-space:nowrap;transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease)}
.btn-copy:hover{transform:translateY(-1px);filter:brightness(1.04)}
.btn-copy.ok{filter:saturate(.75) brightness(.92)}

.sb-connect{padding:12px 14px}
.sb-lbl{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.9px;margin-bottom:7px}
.crow{display:flex;gap:7px}
#inp-connect{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:11px;padding:9px 12px;font-family:var(--mono);font-size:13px;letter-spacing:2px;color:var(--text);outline:none;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
#inp-connect::placeholder{color:var(--muted);letter-spacing:0;font-size:12px;font-family:var(--font)}
#inp-connect:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgb(var(--accent-rgb)/.12)}

.btn-go{background:var(--text);color:var(--surface);border:none;border-radius:11px;padding:9px 14px;font-size:13px;font-weight:800;white-space:nowrap;transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease)}
.btn-go:hover{transform:translateY(-1px);filter:brightness(1.06)}
.btn-go.block{width:100%}
.btn-go.accent{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast)}

.sb-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}
.tab{flex:1;padding:11px 0;font-size:13px;font-weight:750;color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease),background var(--dur) var(--ease)}
.tab:hover{color:var(--text2);background:var(--surface2)}
.tab.on{color:var(--text);border-bottom-color:var(--accent)}

#conv-list{flex:1;overflow-y:auto;padding:4px 0}
.row{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;position:relative;transition:background var(--dur) var(--ease)}
.row:hover{background:var(--surface2)}
.row.on{background:rgb(var(--accent-rgb)/.08)}
.row.on::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--accent);border-radius:0 999px 999px 0}
.av{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;background:var(--surface2);border:1px solid var(--border);color:var(--accent2)}
.av.pub{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);font-size:19px;border:none}
.ri{flex:1;min-width:0}
.rn{font-size:14px;font-weight:750;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rs{font-size:12px;color:var(--muted);margin-top:1px}
.no-convs{padding:28px 16px;text-align:center;color:var(--muted);font-size:13px;line-height:1.8}

#chat{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--app-bg);min-width:0}
#welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:32px 24px;text-align:center;gap:14px}
.wic{font-size:64px;line-height:1;filter:drop-shadow(0 10px 22px rgba(0,77,56,.14))}
[data-theme="dark"] .wic{filter:drop-shadow(0 12px 26px rgba(0,0,0,.38))}
.wtitle{font-size:24px;font-weight:900;color:var(--text)}
.wdesc{font-size:14px;color:var(--text2);max-width:360px;line-height:1.75}
.chips{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:4px}
.chip{background:var(--surface);border:1px solid var(--border);color:var(--text2);border-radius:var(--r-pill);padding:6px 14px;font-size:12px;font-weight:700}

#chat-hdr{display:none;align-items:center;gap:11px;padding:11px 16px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);flex-shrink:0;z-index:2}
.menu-btn{display:none;width:40px;height:40px;border-radius:50%;border:1px solid transparent;background:none;font-size:19px;color:var(--text2);align-items:center;justify-content:center;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.menu-btn:hover{background:var(--surface2);border-color:var(--border)}
.hdr-av{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900}
.hdr-info{flex:1;min-width:0}
.hdr-name{font-size:15px;font-weight:850;color:var(--text)}
.hdr-sub{font-size:11px;color:var(--text2);margin-top:1px}
.hdr-actions{display:flex;align-items:center;gap:6px;position:relative}
.live{display:flex;align-items:center;gap:6px;background:rgb(var(--accent-rgb)/.10);border:1px solid rgb(var(--accent-rgb)/.22);border-radius:var(--r-pill);padding:5px 11px;font-size:11px;font-weight:800;color:var(--text);white-space:nowrap}
.ldot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.78)}}
.btn-add-member{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);border:none;border-radius:10px;padding:6px 14px;font-size:12px;font-weight:800;white-space:nowrap;box-shadow:0 10px 22px rgb(var(--accent-rgb)/.18);transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease)}
.btn-add-member:hover{transform:translateY(-1px);filter:brightness(1.04)}

#msgs{display:none;flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 14px 8px;flex-direction:column;gap:6px;min-height:0}
#empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--muted);padding:20px;text-align:center}
#empty span{font-size:48px;opacity:.35}
#empty p{font-size:13px;margin:0}

.bw{display:flex;flex-direction:column;max-width:75%;min-width:fit-content;animation:pop .18s var(--ease)}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.bw.mine{align-self:flex-start}
.bw.them{align-self:flex-end}
.bsender{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--accent2);margin-bottom:3px;padding:0 3px}
.bubble{padding:10px 14px;font-size:15px;line-height:1.65;border-radius:var(--r-lg);white-space:normal;overflow-wrap:anywhere;word-break:normal}
.bubble.deleted{background:transparent!important;color:var(--muted)!important;border:1.5px dashed var(--border)!important;font-style:italic;box-shadow:none!important}
.bw.mine .bubble{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);border-bottom-right-radius:6px;box-shadow:0 16px 34px rgb(var(--accent-rgb)/.16)}
.bw.them .bubble{background:var(--surface);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:6px;box-shadow:var(--shadow-sm)}
.btime{font-size:10px;color:var(--muted);margin-top:3px;padding:0 3px;display:flex;align-items:center;gap:4px}
.locked{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:var(--r-lg);border:1px dashed rgb(var(--accent-rgb)/.32);background:rgb(var(--accent-rgb)/.10);color:var(--text);cursor:pointer;font-size:13px;font-weight:750;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.locked:hover{background:rgb(var(--accent-rgb)/.14);border-color:rgb(var(--accent-rgb)/.42);transform:translateY(-1px)}
.locked .lic{font-size:16px;flex-shrink:0}
.bubble.edited::after{content:' (ویرایش شد)';font-size:10px;opacity:.65}

.message-actions{display:flex;gap:2px;margin-top:2px;opacity:0;transition:opacity var(--dur) var(--ease)}
.bw:hover .message-actions{opacity:1}
.message-actions button{background:none;border:none;font-size:11px;padding:3px 6px;color:var(--muted);border-radius:8px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.message-actions button:hover{background:var(--surface2);color:var(--accent2)}

.reply-preview{display:none;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:7px 12px;margin:0 12px 6px;font-size:12px;color:var(--text2)}
.reply-preview.on{display:flex}
.reply-preview .rptxt{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reply-preview button{background:none;border:none;font-size:14px;color:var(--muted);padding:2px 4px;border-radius:8px}
.reply-preview button:hover{background:var(--surface);color:var(--text)}

.edit-preview{background:rgb(var(--warn-rgb)/.14);border-color:rgb(var(--warn-rgb)/.35);color:var(--text)}
[data-theme="dark"] .edit-preview{background:rgb(var(--warn-rgb)/.18);border-color:rgb(var(--warn-rgb)/.40)}

.reply-to-badge{font-size:11px;color:var(--accent2);margin-bottom:4px;display:flex;align-items:center;gap:4px}
.seen-check{font-size:11px;color:var(--accent);margin-left:4px}

#input-bar{display:none;flex-shrink:0;padding:8px 12px;background:var(--surface);border-top:1px solid var(--border);padding-bottom:max(8px,env(safe-area-inset-bottom))}
#pass-row{display:none;align-items:center;gap:7px;padding:0 2px 8px}
#pass-row.on{display:flex}
.pass-lbl{font-size:11px;font-weight:850;color:var(--accent2);white-space:nowrap}
#inp-pass{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:9px 11px;font-size:14px;outline:none;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
#inp-pass:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgb(var(--accent-rgb)/.12)}
.irow{display:flex;align-items:flex-end;gap:10px}
.pill{flex:1;display:flex;align-items:flex-end;background:var(--surface2);border:1px solid var(--border);border-radius:28px;padding:7px 8px 7px 14px;gap:6px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.pill:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgb(var(--accent-rgb)/.10)}
#inp-msg{flex:1;background:none;border:none;outline:none;font-size:15px;color:var(--text);resize:none;max-height:120px;min-height:22px;line-height:1.5}
#inp-msg::placeholder{color:var(--muted)}
.pill-ac{display:flex;align-items:center;gap:2px}
#char-ct{font-size:10px;color:var(--muted);padding:0 4px;transition:color var(--dur) var(--ease)}
#char-ct.w{color:rgb(var(--warn-rgb))}
#char-ct.e{color:rgb(var(--danger-rgb))}
.btn-lock{width:34px;height:34px;border-radius:50%;border:1px solid transparent;background:none;font-size:17px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn-lock:hover{color:var(--accent2);background:rgb(var(--accent-rgb)/.09);border-color:rgb(var(--accent-rgb)/.18)}
.btn-lock.on{color:var(--accent2)}
.btn-send{width:46px;height:46px;border-radius:50%;border:none;background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 16px 34px rgb(var(--accent-rgb)/.18);transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease),opacity var(--dur) var(--ease)}
.btn-send svg{pointer-events:none}
.btn-send:hover{transform:scale(1.05);filter:brightness(1.04)}
.btn-send:disabled{opacity:.45;cursor:not-allowed;transform:none;filter:none}

#typing-indicator{font-size:11px;color:var(--muted);padding:4px 12px;display:none;font-style:italic}
#typing-indicator.on{display:block}

.search-bar{display:none;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface);position:relative}
.search-bar.on{display:flex}
.search-bar input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:9px 12px;font-size:13px;outline:none;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.search-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgb(var(--accent-rgb)/.12)}
.search-bar input::placeholder{color:var(--muted)}
.search-bar button{background:none;border:none;font-size:16px;color:var(--muted);padding:0 10px;border-radius:10px}
.search-bar button:hover{background:var(--surface2);color:var(--text)}
.search-bar.searching input{border-color:var(--accent)}
.search-bar.searching::after{content:'';display:block;position:absolute;bottom:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent));background-size:200% 100%;animation:searchPulse 1.2s ease infinite}
@keyframes searchPulse{0%{background-position:0% 0%}100%{background-position:200% 0%}}

.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(8px);align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-bg.on{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:100%;max-width:340px;padding:24px;box-shadow:var(--shadow-md);animation:mIn .22s var(--ease)}
@keyframes mIn{from{opacity:0;transform:scale(.95) translateY(14px)}to{opacity:1;transform:none}}
.modal-title{font-size:17px;font-weight:900;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.modal-err{display:none;background:var(--err-bg);border:1px solid var(--err-bd);color:var(--err-tx);border-radius:12px;padding:9px 13px;font-size:13px;font-weight:700;margin-bottom:13px}
.modal-err.on{display:block}
.modal input,.modal select{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:12px;font-size:15px;background:var(--surface2);outline:none;margin-bottom:18px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.modal input:focus,.modal select:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgb(var(--accent-rgb)/.10)}
.modal-btns{display:flex;gap:8px;justify-content:flex-start;flex-direction:row-reverse}
.btn-cancel{padding:9px 18px;background:none;border:1px solid var(--border);border-radius:12px;font-size:13px;font-weight:750;color:var(--text2);transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn-cancel:hover{background:var(--surface2);border-color:rgba(0,0,0,.18)}
[data-theme="dark"] .btn-cancel:hover{border-color:rgba(255,255,255,.18)}
.btn-ok{padding:9px 22px;background:linear-gradient(145deg,var(--accent),var(--accent2));border:none;border-radius:12px;font-size:13px;font-weight:850;color:var(--accent-contrast);transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease)}
.btn-ok:hover{transform:translateY(-1px);filter:brightness(1.04)}

.settings-panel{display:none;position:fixed;top:60px;left:16px;right:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;min-width:240px;max-width:min(280px,calc(100vw - 32px));box-shadow:var(--shadow-md);z-index:100;max-height:calc(100vh - 80px);overflow-y:auto}
@media (max-width:680px){.settings-panel{left:8px;right:8px;max-width:none}}
.settings-panel.on{display:block}
.settings-panel h4{font-size:13px;font-weight:900;color:var(--text);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.settings-panel label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2);cursor:pointer;padding:8px 6px;border-radius:10px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.settings-panel label:hover{color:var(--text);background:var(--surface2)}
.settings-panel input[type="checkbox"]{accent-color:var(--accent);width:15px;height:15px;flex-shrink:0;cursor:pointer}

#toast{position:fixed;bottom:max(88px,calc(80px + env(safe-area-inset-bottom)));left:50%;transform:translateX(-50%) translateY(12px);background:var(--toast-bg);color:#fff;border-radius:var(--r-pill);padding:9px 20px;font-size:13px;font-weight:650;opacity:0;pointer-events:none;max-width:calc(100vw - 40px);text-align:center;box-shadow:var(--shadow-md);transition:opacity var(--dur2) var(--ease),transform var(--dur2) var(--ease);z-index:200}
#toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

.admin-area{padding:10px 14px;border-top:1px solid var(--border)}
.admin-area .btn-reset{background:#b91c1c;color:#fff;border:none;border-radius:12px;padding:9px 12px;font-size:12px;font-weight:900;width:100%}
.admin-area .btn-reset:hover{filter:brightness(1.04)}

.group-row{cursor:pointer}
.group-row:hover{background:var(--surface2)}
.group-row.on{background:rgb(var(--accent-rgb)/.08)}

.connection-status{position:fixed;top:0;left:0;right:0;z-index:999;text-align:center;font-size:12px;font-weight:800;padding:6px 4px;transition:transform .3s var(--ease);transform:translateY(-100%)}
.connection-status.on{transform:translateY(0)}
.connection-status.ok{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast)}
.connection-status.err{background:rgb(var(--danger-rgb));color:#fff}

.block-banner{display:none;align-items:center;justify-content:space-between;gap:10px;padding:10px 16px;background:rgb(var(--warn-rgb)/.10);border-bottom:1px solid rgb(var(--warn-rgb)/.28);font-size:13px;color:var(--text);flex-shrink:0}
.block-banner button{background:#b91c1c;color:#fff;border:none;border-radius:10px;padding:6px 12px;font-size:12px;font-weight:800;white-space:nowrap}
.block-banner button:hover{filter:brightness(1.04)}

.blocked-list{max-height:300px;overflow-y:auto;margin-bottom:16px}
.blocked-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 8px;border-bottom:1px solid var(--border)}
.blocked-item:last-child{border-bottom:none}
.blocked-item .bi-id{font-family:var(--mono);font-size:14px;color:var(--text)}
.blocked-item .bi-name{font-size:11px;color:var(--muted);margin-top:2px}
.blocked-item button{background:#b91c1c;color:#fff;border:none;border-radius:10px;padding:6px 10px;font-size:11px;font-weight:800}
.blocked-item button:hover{filter:brightness(1.04)}
.blocked-empty{text-align:center;padding:20px;color:var(--muted);font-size:13px}
.modal-wide{max-width:400px}

.search-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:rgb(var(--accent-rgb)/.10);border:1px solid rgb(var(--accent-rgb)/.22);border-radius:12px;margin-bottom:8px;font-size:12px;color:var(--text)}
.search-banner button{background:linear-gradient(145deg,var(--accent),var(--accent2));color:var(--accent-contrast);border:none;border-radius:10px;padding:5px 10px;font-size:11px;font-weight:800;white-space:nowrap}
.search-banner button:hover{filter:brightness(1.04)}
.search-hit{border:2px solid var(--accent);border-radius:14px;padding:2px;margin-bottom:4px}
.search-empty{text-align:center;padding:20px;color:var(--muted);font-size:13px}

@media (max-width:680px){
  #sidebar{position:fixed;right:0;top:0;bottom:0;width:88%;max-width:320px;transform:translateX(110%);transition:transform .28s cubic-bezier(.32,.72,0,1);z-index:40}
  #sidebar.on{transform:none;box-shadow:-18px 0 50px rgba(0,0,0,.25)}
  #sb-close{display:flex}
  .menu-btn{display:flex}
  #chat{width:100%}
  .bw{max-width:88%;min-width:fit-content}
}

.fade-in{animation:fadeIn .2s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
@media (max-width:360px){.id-val{font-size:17px;letter-spacing:2px}}
