@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* ═══════════════════════════════════════════════════════════════════
   THEME DEFINITIONS  — 5 themes via data-theme on <html>
   ═══════════════════════════════════════════════════════════════════ */

/* 1. NEBULA (default) — Deep Blue + Electric Purple */
:root, [data-theme="nebula"] {
  --bg0:#04060f;--bg1:#080c1a;--bg2:#0c1228;--bg3:#111932;--bg4:#1a2444;
  --glass:rgba(12,18,40,.72);--glass2:rgba(20,30,60,.55);
  --glass-border:rgba(120,80,255,.18);--glass-border2:rgba(80,120,255,.12);
  --glass-shine:rgba(255,255,255,.04);
  --accent:#7c3aed;--accent2:#5b21b6;--accent3:#a855f7;
  --blue:#3b82f6;--blue2:#60a5fa;--cyan:#22d3ee;
  --g:#10b981;--g2:#059669;--g-glow:rgba(16,185,129,.15);--g-glow2:rgba(16,185,129,.07);
  --yellow:#f59e0b;--red:#f43f5e;--orange:#fb923c;--purple:#a855f7;
  --t0:#f1f5ff;--t1:#c4cdea;--t2:#7b8db8;--t3:#374570;
  --border:rgba(100,80,200,.14);--border2:rgba(120,100,220,.22);
  --glow-accent:0 0 40px rgba(124,58,237,.35);
  --glow-blue:0 0 30px rgba(59,130,246,.3);
  --glow-green:0 0 25px rgba(16,185,129,.3);
  --glow-card:0 8px 32px rgba(0,0,20,.6),0 0 0 1px var(--glass-border);
  --grad-accent:linear-gradient(135deg,#7c3aed,#3b82f6);
  --grad-bg:radial-gradient(ellipse at 20% 20%,rgba(124,58,237,.12) 0%,transparent 60%),
            radial-gradient(ellipse at 80% 80%,rgba(59,130,246,.08) 0%,transparent 60%);
  --r:12px;--r-lg:18px;--sidebar:230px;--top:54px;--trans:.18s ease;
  --mono:'JetBrains Mono',monospace;--sans:'Inter','DM Sans',sans-serif;
}

/* 2. AURORA — Teal + Amber */
[data-theme="aurora"] {
  --bg0:#020d0d;--bg1:#061515;--bg2:#0a1e1e;--bg3:#0f2828;--bg4:#163535;
  --glass:rgba(6,21,21,.75);--glass2:rgba(15,40,40,.55);
  --glass-border:rgba(20,184,166,.2);--glass-border2:rgba(20,184,166,.1);
  --glass-shine:rgba(255,255,255,.04);
  --accent:#14b8a6;--accent2:#0d9488;--accent3:#2dd4bf;
  --blue:#f59e0b;--blue2:#fbbf24;--cyan:#34d399;
  --g:#14b8a6;--g2:#0d9488;--g-glow:rgba(20,184,166,.15);--g-glow2:rgba(20,184,166,.07);
  --yellow:#f59e0b;--red:#f43f5e;--orange:#fb923c;--purple:#a78bfa;
  --t0:#ecfdf5;--t1:#b2d8d0;--t2:#5f9e94;--t3:#2e5a55;
  --border:rgba(20,184,166,.14);--border2:rgba(20,184,166,.24);
  --glow-accent:0 0 40px rgba(20,184,166,.35);
  --glow-blue:0 0 30px rgba(245,158,11,.3);
  --glow-green:0 0 25px rgba(20,184,166,.3);
  --glow-card:0 8px 32px rgba(0,10,10,.65),0 0 0 1px var(--glass-border);
  --grad-accent:linear-gradient(135deg,#14b8a6,#f59e0b);
  --grad-bg:radial-gradient(ellipse at 20% 20%,rgba(20,184,166,.12) 0%,transparent 60%),
            radial-gradient(ellipse at 80% 80%,rgba(245,158,11,.08) 0%,transparent 60%);
}

/* 3. CRIMSON — Dark Noir + Red */
[data-theme="crimson"] {
  --bg0:#0c0203;--bg1:#160406;--bg2:#1f060a;--bg3:#2a080e;--bg4:#380b14;
  --glass:rgba(22,4,6,.78);--glass2:rgba(42,8,14,.55);
  --glass-border:rgba(244,63,94,.2);--glass-border2:rgba(244,63,94,.1);
  --glass-shine:rgba(255,255,255,.03);
  --accent:#f43f5e;--accent2:#e11d48;--accent3:#fb7185;
  --blue:#fb923c;--blue2:#fdba74;--cyan:#f59e0b;
  --g:#10b981;--g2:#059669;--g-glow:rgba(16,185,129,.12);--g-glow2:rgba(16,185,129,.06);
  --yellow:#fbbf24;--red:#f43f5e;--orange:#fb923c;--purple:#e879f9;
  --t0:#fff1f2;--t1:#e8c0c6;--t2:#9e6b73;--t3:#5a2d35;
  --border:rgba(244,63,94,.14);--border2:rgba(244,63,94,.24);
  --glow-accent:0 0 40px rgba(244,63,94,.4);
  --glow-blue:0 0 30px rgba(251,146,60,.3);
  --glow-green:0 0 25px rgba(16,185,129,.25);
  --glow-card:0 8px 32px rgba(10,0,2,.7),0 0 0 1px var(--glass-border);
  --grad-accent:linear-gradient(135deg,#f43f5e,#fb923c);
  --grad-bg:radial-gradient(ellipse at 20% 20%,rgba(244,63,94,.14) 0%,transparent 60%),
            radial-gradient(ellipse at 80% 80%,rgba(251,146,60,.08) 0%,transparent 60%);
}

/* 4. CYBERPUNK — Black + Neon Green/Magenta */
[data-theme="cyberpunk"] {
  --bg0:#030303;--bg1:#080808;--bg2:#0d0d0d;--bg3:#111;--bg4:#161616;
  --glass:rgba(8,8,8,.85);--glass2:rgba(20,20,20,.6);
  --glass-border:rgba(0,255,65,.2);--glass-border2:rgba(0,255,65,.1);
  --glass-shine:rgba(0,255,65,.03);
  --accent:#00ff41;--accent2:#00cc33;--accent3:#39ff14;
  --blue:#ff00ff;--blue2:#ff66ff;--cyan:#00ffff;
  --g:#00ff41;--g2:#00cc33;--g-glow:rgba(0,255,65,.15);--g-glow2:rgba(0,255,65,.06);
  --yellow:#ffff00;--red:#ff0040;--orange:#ff6600;--purple:#ff00ff;
  --t0:#e0ffe8;--t1:#a0c8a8;--t2:#4a7a52;--t3:#1a3a1e;
  --border:rgba(0,255,65,.12);--border2:rgba(0,255,65,.22);
  --glow-accent:0 0 40px rgba(0,255,65,.5);
  --glow-blue:0 0 30px rgba(255,0,255,.4);
  --glow-green:0 0 30px rgba(0,255,65,.5);
  --glow-card:0 8px 32px rgba(0,0,0,.8),0 0 0 1px var(--glass-border);
  --grad-accent:linear-gradient(135deg,#00ff41,#ff00ff);
  --grad-bg:radial-gradient(ellipse at 15% 85%,rgba(0,255,65,.1) 0%,transparent 50%),
            radial-gradient(ellipse at 85% 15%,rgba(255,0,255,.08) 0%,transparent 50%);
}

/* 5. ARCTIC — Light Mode */
[data-theme="arctic"] {
  --bg0:#f0f4ff;--bg1:#ffffff;--bg2:#f8faff;--bg3:#eef2ff;--bg4:#e0e7ff;
  --glass:rgba(255,255,255,.75);--glass2:rgba(240,244,255,.65);
  --glass-border:rgba(99,102,241,.18);--glass-border2:rgba(99,102,241,.1);
  --glass-shine:rgba(255,255,255,.9);
  --accent:#6366f1;--accent2:#4f46e5;--accent3:#818cf8;
  --blue:#3b82f6;--blue2:#60a5fa;--cyan:#06b6d4;
  --g:#10b981;--g2:#059669;--g-glow:rgba(16,185,129,.12);--g-glow2:rgba(16,185,129,.06);
  --yellow:#d97706;--red:#e11d48;--orange:#ea580c;--purple:#7c3aed;
  --t0:#0f172a;--t1:#334155;--t2:#64748b;--t3:#94a3b8;
  --border:rgba(99,102,241,.14);--border2:rgba(99,102,241,.25);
  --glow-accent:0 0 30px rgba(99,102,241,.2);
  --glow-blue:0 0 20px rgba(59,130,246,.2);
  --glow-green:0 0 20px rgba(16,185,129,.2);
  --glow-card:0 4px 24px rgba(99,102,241,.1),0 0 0 1px var(--glass-border);
  --grad-accent:linear-gradient(135deg,#6366f1,#3b82f6);
  --grad-bg:radial-gradient(ellipse at 20% 20%,rgba(99,102,241,.06) 0%,transparent 60%),
            radial-gradient(ellipse at 80% 80%,rgba(59,130,246,.04) 0%,transparent 60%);
}

/* ═══ RESET ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg0);color:var(--t1);font-family:var(--sans);font-size:13.5px;overflow:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:var(--sans)}
body::before{content:'';position:fixed;inset:0;background:var(--grad-bg);pointer-events:none;z-index:0}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ═══ GLASS MIXIN ═════════════════════════════════════ */
.card,.modal,.login-box,#topbar,#sidebar,.chat-shell,.contact-panel,.chat-header,.chat-input-bar,#feed,#qr-box{backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}

/* ═══ LOGIN ═══════════════════════════════════════════ */
#login-screen{position:fixed;inset:0;background:var(--bg0);display:flex;align-items:center;justify-content:center;z-index:1000;transition:opacity .5s;overflow:hidden}
#login-screen::before,#login-screen::after{content:'';position:absolute;border-radius:50%;filter:blur(80px);animation:floatOrb 8s ease-in-out infinite alternate}
#login-screen::before{width:400px;height:400px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);top:-100px;left:-100px;opacity:.3}
#login-screen::after{width:300px;height:300px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);bottom:-80px;right:-80px;opacity:.2;animation-delay:-4s}
@keyframes floatOrb{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,20px) scale(1.1)}}
#login-screen.hide{opacity:0;pointer-events:none}
.login-box{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:44px 40px;width:380px;box-shadow:var(--glow-card),var(--glow-accent);position:relative;z-index:1}
.login-box::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--accent3),transparent);border-radius:1px}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:36px}
.login-logo-icon{width:40px;height:40px;background:var(--g-glow);border:1px solid var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:var(--glow-accent)}
.login-logo-icon svg{width:20px;height:20px;color:var(--accent3)}
.login-logo-text{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--t0);letter-spacing:.06em}
.login-logo-sub{font-size:11px;color:var(--t3);margin-top:2px}
.login-title{font-size:22px;font-weight:700;color:var(--t0);margin-bottom:4px}
.login-sub{font-size:12px;color:var(--t3);margin-bottom:28px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:11px;color:var(--t2);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:7px}
.login-field input{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--border2);border-radius:8px;padding:11px 14px;color:var(--t0);font-family:var(--mono);font-size:12.5px;outline:none;transition:border-color var(--trans),box-shadow var(--trans)}
.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,.15)}
[data-theme="arctic"] .login-field input{background:rgba(255,255,255,.7)}
.login-btn{width:100%;padding:12px;margin-top:8px;background:var(--grad-accent);color:#fff;font-weight:700;font-size:13.5px;border:none;border-radius:8px;cursor:pointer;transition:all var(--trans);letter-spacing:.03em;box-shadow:var(--glow-accent)}
.login-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}
.login-btn:active{transform:none;filter:brightness(.95)}
.login-err{font-size:12px;color:var(--red);margin-top:10px;text-align:center;min-height:18px}

/* ═══ APP SHELL ═══════════════════════════════════════ */
#app{display:none;grid-template-columns:var(--sidebar) 1fr;grid-template-rows:var(--top) 1fr;height:100vh;position:relative;z-index:1}
#app.show{display:grid}

/* ═══ TOPBAR ══════════════════════════════════════════ */
#topbar{grid-column:1/-1;background:var(--glass);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:12px;padding:0 20px;z-index:100;position:relative}
#topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--accent) 40%,var(--blue) 60%,transparent 100%);opacity:.4}
.topbar-logo{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent3);letter-spacing:.08em;display:flex;align-items:center;gap:8px}
.topbar-logo svg{color:var(--accent);filter:drop-shadow(0 0 6px var(--accent))}
.topbar-logo span{color:var(--t3);font-weight:400}
.tb-sep{width:1px;height:22px;background:var(--border2);margin:0 2px}
#bot-dot{width:8px;height:8px;border-radius:50%;background:var(--t3);transition:all .4s;flex-shrink:0}
#bot-dot.qr{background:var(--yellow);box-shadow:0 0 10px var(--yellow)}
#bot-dot.connecting{background:var(--orange);box-shadow:0 0 10px var(--orange);animation:pulse 1s infinite}
#bot-dot.ready{background:var(--g);box-shadow:0 0 10px var(--g)}
#bot-dot.disconnected{background:var(--red);box-shadow:0 0 10px var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
#bot-label{font-size:11px;color:var(--t2);font-family:var(--mono)}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.tb-version{font-size:10px;font-family:var(--mono);color:var(--t3);background:var(--glass2);border:1px solid var(--border);padding:3px 9px;border-radius:20px}
.theme-switcher{display:flex;align-items:center;gap:6px;background:var(--glass2);border:1px solid var(--border);padding:5px 9px;border-radius:20px}
.theme-dot{width:12px;height:12px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all var(--trans)}
.theme-dot:hover{transform:scale(1.25)}
.theme-dot.active{border-color:var(--t0);transform:scale(1.2)}
.theme-dot[data-theme="nebula"]{background:linear-gradient(135deg,#7c3aed,#3b82f6)}
.theme-dot[data-theme="aurora"]{background:linear-gradient(135deg,#14b8a6,#f59e0b)}
.theme-dot[data-theme="crimson"]{background:linear-gradient(135deg,#f43f5e,#fb923c)}
.theme-dot[data-theme="cyberpunk"]{background:linear-gradient(135deg,#00ff41,#ff00ff)}
.theme-dot[data-theme="arctic"]{background:linear-gradient(135deg,#6366f1,#3b82f6)}
#logout-btn{font-size:11px;color:var(--t2);cursor:pointer;padding:5px 12px;border-radius:8px;border:1px solid var(--border);background:var(--glass2);font-family:var(--sans);transition:all var(--trans)}
#logout-btn:hover{border-color:var(--red);color:var(--red);background:rgba(244,63,94,.08)}

/* ═══ SIDEBAR ═════════════════════════════════════════ */
#sidebar{background:var(--glass);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;padding:12px 0;overflow-y:auto;z-index:50;position:relative}
.nav-sect{padding:14px 16px 5px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--t3)}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--t2);border-left:2px solid transparent;margin:1px 8px;border-radius:0 8px 8px 0;transition:all var(--trans);position:relative}
.nav-item:hover{color:var(--t0);background:var(--glass2);border-left-color:var(--border2)}
.nav-item.active{color:var(--accent3);border-left-color:var(--accent);background:var(--g-glow2)}
.nav-item.active svg{filter:drop-shadow(0 0 4px var(--accent))}
.nav-item svg{width:14px;height:14px;flex-shrink:0;opacity:.8}
.nav-item.active svg{opacity:1}
.nav-badge{margin-left:auto;font-size:9px;background:var(--red);color:#fff;padding:1px 6px;border-radius:10px;font-family:var(--mono);box-shadow:0 0 8px rgba(244,63,94,.4)}

/* ═══ MAIN ════════════════════════════════════════════ */
#main{overflow-y:auto;background:transparent}
.page{display:none;padding:24px;animation:fadeUp .22s ease}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}
.ph-title{font-size:18px;font-weight:700;color:var(--t0);letter-spacing:-.01em}
.ph-sub{font-size:11px;color:var(--t3);font-family:var(--mono);margin-top:3px}

/* ═══ STAT CARDS ══════════════════════════════════════ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);padding:18px 20px;box-shadow:var(--glow-card);position:relative;overflow:hidden;transition:transform var(--trans),box-shadow var(--trans)}
.stat:hover{transform:translateY(-2px);box-shadow:var(--glow-card),var(--glow-accent)}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent3),transparent);opacity:.5}
.stat::after{content:'';position:absolute;top:-40px;right:-40px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.08}
.stat.g::after{background:radial-gradient(circle,var(--g) 0%,transparent 70%)}
.stat.c::after{background:radial-gradient(circle,var(--cyan) 0%,transparent 70%)}
.stat.y::after{background:radial-gradient(circle,var(--yellow) 0%,transparent 70%)}
.stat.p::after{background:radial-gradient(circle,var(--purple) 0%,transparent 70%)}
.stat-label{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-weight:600}
.stat-val{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--t0);line-height:1}
.stat-sub{font-size:10px;color:var(--t3);margin-top:4px}
.stat.g .stat-val{color:var(--g);text-shadow:0 0 20px var(--g)}
.stat.c .stat-val{color:var(--cyan);text-shadow:0 0 20px var(--cyan)}
.stat.y .stat-val{color:var(--yellow);text-shadow:0 0 20px var(--yellow)}
.stat.p .stat-val{color:var(--purple);text-shadow:0 0 20px var(--purple)}

/* ═══ CARDS ═══════════════════════════════════════════ */
.card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);margin-bottom:16px;box-shadow:var(--glow-card);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 10%,var(--glass-border2) 50%,transparent 90%)}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--glass-border)}
.card-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t2);display:flex;align-items:center;gap:8px}
.card-title svg{width:12px;height:12px;color:var(--accent3)}
.card-body{padding:18px}

/* ═══ LIVE GRID / FEED ════════════════════════════════ */
.live-grid{display:grid;grid-template-columns:1fr 300px;gap:16px}
#feed{height:460px;display:flex;flex-direction:column;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);box-shadow:var(--glow-card);overflow:hidden}
.feed-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0}
.feed-title-row{display:flex;align-items:center;gap:8px}
.feed-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t2)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--red);animation:pulse 1.2s infinite;box-shadow:0 0 8px var(--red)}
.feed-actions{display:flex;gap:6px}
.feed-scroll{flex:1;overflow-y:auto;padding:10px 12px}
.msg{margin-bottom:10px;animation:msgIn .22s ease}
@keyframes msgIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:none}}
.msg.out{animation-name:msgOut}
@keyframes msgOut{from{opacity:0;transform:translateX(6px)}to{opacity:1;transform:none}}
.msg-meta{font-size:10px;color:var(--t3);font-family:var(--mono);margin-bottom:3px;display:flex;align-items:center;gap:5px}
.msg-from{color:var(--cyan)}
.msg.out .msg-from{color:var(--g)}
.msg-body{display:inline-block;max-width:90%;padding:8px 12px;background:var(--glass2);border:1px solid var(--glass-border);border-radius:4px 12px 12px 12px;font-size:12px;line-height:1.55;white-space:pre-wrap;word-break:break-word;color:var(--t1)}
.msg.out .msg-body{background:var(--g-glow);border-color:rgba(16,185,129,.2);border-radius:12px 4px 12px 12px}
.msg-dir{font-size:9px;padding:1px 5px;border-radius:4px;font-family:var(--mono)}
.dir-in{background:rgba(34,211,238,.1);color:var(--cyan)}
.dir-out{background:var(--g-glow);color:var(--g)}

/* ═══ QR ══════════════════════════════════════════════ */
#qr-box{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);height:460px;display:flex;flex-direction:column;box-shadow:var(--glow-card)}
.qr-head{padding:12px 16px;border-bottom:1px solid var(--glass-border);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t2)}
.qr-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:16px}
#qr-img-wrap{width:220px;height:220px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:var(--glow-accent)}
#qr-img-wrap img{width:220px;height:220px;display:block;object-fit:contain}
.qr-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--t3)}
.qr-placeholder svg{width:48px;height:48px;opacity:.3}
.qr-hint{font-size:11px;color:var(--t3);text-align:center;line-height:1.6;max-width:220px}
#qr-state-label{font-size:11px;font-family:var(--mono);padding:4px 12px;border-radius:20px;background:var(--glass2);border:1px solid var(--border)}

/* ═══ TABLE ═══════════════════════════════════════════ */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--t3);padding:9px 14px;text-align:left;border-bottom:1px solid var(--glass-border);white-space:nowrap;background:var(--glass2)}
tbody td{padding:10px 14px;border-bottom:1px solid var(--glass-border);font-size:12px;color:var(--t1);vertical-align:top}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--glass-shine)}

/* ═══ FORMS ═══════════════════════════════════════════ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg.full{grid-column:1/-1}
.fg label{font-size:10px;color:var(--t2);font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.fg input,.fg select,.fg textarea{background:rgba(0,0,0,.25);border:1px solid var(--border2);border-radius:8px;padding:9px 12px;color:var(--t0);font-family:var(--mono);font-size:12px;outline:none;transition:border-color var(--trans),box-shadow var(--trans)}
[data-theme="arctic"] .fg input,[data-theme="arctic"] .fg select,[data-theme="arctic"] .fg textarea{background:rgba(255,255,255,.7)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
.fg select option{background:var(--bg2);color:var(--t0)}
.fg textarea{resize:vertical;min-height:72px;line-height:1.55}
.form-hint{font-size:10.5px;color:var(--t3);margin-top:2px}
.form-sep{grid-column:1/-1;height:1px;background:var(--glass-border);margin:4px 0}
.form-footer{display:flex;align-items:center;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--glass-border)}
.form-msg{font-size:11px;margin-left:auto}
.form-msg.ok{color:var(--g)}
.form-msg.err{color:var(--red)}

/* ═══ BUTTONS ═════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:8px;font-size:12px;font-family:var(--sans);font-weight:600;cursor:pointer;border:1px solid transparent;transition:all var(--trans);outline:none;white-space:nowrap;letter-spacing:.01em}
.btn svg{width:13px;height:13px}
.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:var(--glow-accent)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn-ghost{background:var(--glass2);color:var(--t2);border-color:var(--border)}
.btn-ghost:hover{color:var(--t0);border-color:var(--accent);background:var(--glass)}
.btn-danger{background:transparent;color:var(--red);border-color:rgba(244,63,94,.25)}
.btn-danger:hover{background:rgba(244,63,94,.08);border-color:var(--red)}
.btn-sm{padding:5px 11px;font-size:11px;border-radius:6px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;filter:none!important}

/* ═══ TOGGLE ══════════════════════════════════════════ */
.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:8px}
.toggle input{position:absolute;opacity:0;width:0;height:0}
.toggle-track{width:36px;height:20px;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;transition:all var(--trans);flex-shrink:0}
.toggle-thumb{position:absolute;left:4px;top:50%;transform:translateY(-50%);width:12px;height:12px;background:var(--t3);border-radius:50%;transition:all var(--trans)}
.toggle input:checked~.toggle-track{background:var(--g-glow);border-color:var(--g);box-shadow:0 0 8px var(--g)}
.toggle input:checked~.toggle-track .toggle-thumb{left:20px;background:var(--g)}
.toggle-label{font-size:12px;color:var(--t2)}

/* ═══ BADGES ══════════════════════════════════════════ */
.badge{display:inline-block;font-size:10px;font-family:var(--mono);padding:2px 8px;border-radius:20px;font-weight:600}
.badge-green{background:var(--g-glow);color:var(--g);border:1px solid rgba(16,185,129,.25)}
.badge-red{background:rgba(244,63,94,.1);color:var(--red);border:1px solid rgba(244,63,94,.25)}
.badge-yellow{background:rgba(245,158,11,.1);color:var(--yellow);border:1px solid rgba(245,158,11,.25)}
.badge-blue{background:rgba(59,130,246,.1);color:var(--blue2);border:1px solid rgba(59,130,246,.25)}
.badge-gray{background:var(--glass2);color:var(--t2);border:1px solid var(--border)}
.badge-purple{background:rgba(168,85,247,.1);color:var(--purple);border:1px solid rgba(168,85,247,.25)}

/* ═══ TAG INPUT ═══════════════════════════════════════ */
.tag-input-wrap{display:flex;flex-wrap:wrap;gap:5px;background:rgba(0,0,0,.2);border:1px solid var(--border2);border-radius:8px;padding:7px 10px;min-height:40px;cursor:text;transition:border-color var(--trans)}
.tag-input-wrap:focus-within{border-color:var(--accent)}
.tag{display:inline-flex;align-items:center;gap:4px;background:var(--g-glow);border:1px solid rgba(16,185,129,.25);color:var(--g);border-radius:6px;font-size:11px;font-family:var(--mono);padding:2px 8px}
.tag-x{cursor:pointer;color:var(--g);font-size:14px;line-height:1;padding:0 2px}
.tag-x:hover{color:var(--red)}
.tag-new-input{border:none;background:transparent;color:var(--t0);font-family:var(--mono);font-size:12px;outline:none;flex:1;min-width:80px;padding:2px}

/* ═══ CHANGELOG ═══════════════════════════════════════ */
.cl-item{border-left:2px solid var(--border2);padding:0 0 22px 18px;position:relative}
.cl-item:last-child{padding-bottom:0;border-left-color:transparent}
.cl-item::before{content:'';position:absolute;left:-5px;top:4px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--bg1);box-shadow:0 0 8px var(--accent)}
.cl-ver{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--t0)}
.cl-date{font-size:11px;color:var(--t3);font-family:var(--mono);margin:4px 0 9px}
.cl-changes{list-style:none;display:flex;flex-direction:column;gap:5px}
.cl-changes li{font-size:12px;color:var(--t2);display:flex;align-items:baseline;gap:7px}
.cl-changes li::before{content:'→';color:var(--accent3);font-family:var(--mono);font-size:10px;flex-shrink:0}
.cl-current .cl-ver::after{content:' CURRENT';font-size:8px;background:var(--grad-accent);color:#fff;padding:2px 7px;border-radius:10px;margin-left:8px;vertical-align:middle}

/* ═══ CMD CARDS ═══════════════════════════════════════ */
.cmd-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);padding:16px;margin-bottom:10px;transition:border-color var(--trans),box-shadow var(--trans)}
.cmd-card:hover{border-color:var(--accent);box-shadow:var(--glow-accent)}
.cmd-card.disabled{opacity:.45}
.cmd-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.cmd-name{font-size:13px;font-weight:600;color:var(--t0);flex:1}
.cmd-keywords{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.cmd-kw{font-size:10.5px;font-family:var(--mono);background:var(--glass2);border:1px solid var(--border2);color:var(--cyan);padding:2px 8px;border-radius:6px}
.cmd-desc{font-size:11.5px;color:var(--t3)}
.cmd-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--glass-border)}

/* ═══ MODAL ═══════════════════════════════════════════ */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);z-index:500;display:none;align-items:center;justify-content:center}
.modal-bg.show{display:flex}
.modal{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:26px;width:520px;max-width:95vw;max-height:88vh;overflow-y:auto;animation:modalIn .22s ease;box-shadow:var(--glow-card),0 0 60px rgba(0,0,0,.6);position:relative}
.modal::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--accent3),transparent);opacity:.5}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}
.modal-title{font-size:16px;font-weight:700;color:var(--t0);margin-bottom:18px}

/* ═══ TICKET PRIOS ════════════════════════════════════ */
.prio-high{color:var(--orange)}
.prio-critical{color:var(--red);text-shadow:0 0 8px var(--red)}
.prio-medium{color:var(--yellow)}
.prio-low{color:var(--g)}

/* ═══ CHAT SHELL ══════════════════════════════════════ */
.chat-shell{display:grid;grid-template-columns:280px 1fr;height:calc(100vh - var(--top) - 90px);background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--glow-card)}
.contact-panel{border-right:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden;background:var(--glass2)}
.contact-search-wrap{padding:12px;border-bottom:1px solid var(--glass-border);flex-shrink:0}
.contact-search{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--border2);border-radius:8px;padding:8px 12px;color:var(--t0);font-family:var(--sans);font-size:12px;outline:none;transition:border-color var(--trans)}
.contact-search:focus{border-color:var(--accent)}
[data-theme="arctic"] .contact-search{background:rgba(255,255,255,.5)}
#contact-list{flex:1;overflow-y:auto}
.contact-empty{color:var(--t3);font-size:12px;text-align:center;padding:30px 10px}
.contact-item{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;border-left:2px solid transparent;transition:all var(--trans);position:relative}
.contact-item:hover{background:var(--glass-shine)}
.contact-item.active{background:var(--g-glow2);border-left-color:var(--accent)}
.contact-avatar{width:38px;height:38px;border-radius:50%;background:var(--glass2);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--accent3);flex-shrink:0;font-family:var(--mono);text-transform:uppercase;box-shadow:0 0 10px rgba(124,58,237,.15)}
.contact-info{flex:1;min-width:0}
.contact-name-row{display:flex;align-items:baseline;justify-content:space-between;gap:6px;min-width:0}
.contact-name-text{font-size:12.5px;font-weight:600;color:var(--t0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.contact-username-text{font-size:10px;color:var(--cyan);font-family:var(--mono);white-space:nowrap;flex-shrink:0;opacity:.75;border-radius:4px;padding:1px 4px;transition:all var(--trans)}
.contact-username-text:hover{opacity:1;background:rgba(34,211,238,.1)}
.contact-name{font-size:12.5px;font-weight:600;color:var(--t0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contact-preview{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.contact-time{font-size:9.5px;color:var(--t3);font-family:var(--mono);flex-shrink:0}
.contact-unread{position:absolute;top:8px;right:10px;background:var(--accent);color:#fff;width:17px;height:17px;border-radius:50%;font-size:9px;font-weight:700;font-family:var(--mono);display:flex;align-items:center;justify-content:center;box-shadow:0 0 8px var(--accent)}
.chat-area{display:flex;flex-direction:column;overflow:hidden;position:relative}
.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--t3);font-size:13px}
.chat-header{display:flex;align-items:center;gap:11px;padding:11px 16px;border-bottom:1px solid var(--glass-border);background:var(--glass2);flex-shrink:0}
.chat-header-avatar{width:36px;height:36px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--accent3);font-family:var(--mono);text-transform:uppercase;box-shadow:0 0 10px rgba(124,58,237,.2)}
.chat-header-name{font-size:13.5px;font-weight:700;color:var(--t0)}
.chat-header-number{font-size:10.5px;color:var(--t3);font-family:var(--mono)}
.chat-header-actions{margin-left:auto}
.chat-thread{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px;background:transparent}
.thread-date-sep{text-align:center;font-size:10px;color:var(--t3);font-family:var(--mono);margin:8px 0;display:flex;align-items:center;gap:8px}
.thread-date-sep::before,.thread-date-sep::after{content:'';flex:1;height:1px;background:var(--glass-border)}
.thread-msg{display:flex;flex-direction:column;max-width:74%}
.thread-msg.out{align-self:flex-end;align-items:flex-end}
.thread-msg.in{align-self:flex-start;align-items:flex-start}
.thread-bubble{padding:9px 14px;border-radius:6px 16px 16px 16px;font-size:13px;line-height:1.55;white-space:pre-wrap;word-break:break-word;position:relative}
.thread-msg.in .thread-bubble{background:var(--glass);border:1px solid var(--glass-border);color:var(--t1)}
.thread-msg.out .thread-bubble{background:var(--g-glow);border:1px solid rgba(16,185,129,.25);color:var(--t0);border-radius:16px 6px 16px 16px}
.thread-msg.out .thread-bubble.manual{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.25)}
.thread-meta{font-size:10px;color:var(--t3);display:flex;align-items:center;gap:6px;margin-top:4px;padding:0 4px}
.thread-img{max-width:220px;border-radius:10px;cursor:pointer;display:block}
.thread-file{display:flex;align-items:center;gap:8px;background:var(--glass2);border:1px solid var(--glass-border);border-radius:10px;padding:8px 12px;font-size:12px;color:var(--t1)}
.thread-file-link{color:var(--accent3);text-decoration:none;display:flex;align-items:center;gap:6px}
.thread-file-link:hover{text-decoration:underline}
.del-msg-btn{background:none;border:none;cursor:pointer;color:var(--t3);font-size:12px;padding:0 2px;opacity:0;transition:opacity .15s,color .15s;line-height:1;flex-shrink:0}
.thread-msg:hover .del-msg-btn{opacity:.45}
.del-msg-btn:hover{opacity:1!important;color:var(--red)!important}
.chat-input-bar{border-top:1px solid var(--glass-border);background:var(--glass2);padding:10px 14px;flex-shrink:0}
.chat-input-row{display:flex;align-items:flex-end;gap:7px}
.chat-tool-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--border2);background:var(--glass2);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--trans)}
.chat-tool-btn svg{width:16px;height:16px}
.chat-tool-btn:hover{color:var(--accent3);border-color:var(--accent);background:var(--g-glow2)}
.chat-tool-btn.active{color:var(--accent3);border-color:var(--accent);background:var(--g-glow2)}
.chat-input-wrap{flex:1}
.chat-textarea{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--border2);border-radius:10px;padding:9px 14px;color:var(--t0);font-family:var(--sans);font-size:13px;outline:none;resize:none;line-height:1.5;max-height:120px;overflow-y:auto;transition:border-color var(--trans),box-shadow var(--trans)}
.chat-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
[data-theme="arctic"] .chat-textarea{background:rgba(255,255,255,.6)}
.chat-send-btn{width:38px;height:38px;border-radius:10px;background:var(--grad-accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--trans);box-shadow:var(--glow-accent)}
.chat-send-btn svg{width:16px;height:16px}
.chat-send-btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.attach-preview{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;margin-bottom:8px;font-size:12px;color:var(--t1)}
.attach-remove{margin-left:auto;background:none;border:none;color:var(--t3);cursor:pointer;font-size:15px;padding:0 4px;transition:color var(--trans)}
.attach-remove:hover{color:var(--red)}
.emoji-picker{position:absolute;bottom:74px;left:14px;width:300px;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;padding:12px;z-index:100;box-shadow:var(--glow-card);backdrop-filter:blur(24px)}
.emoji-picker-search{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--border2);border-radius:8px;padding:7px 10px;color:var(--t0);font-size:12px;outline:none;margin-bottom:9px;transition:border-color var(--trans)}
.emoji-picker-search:focus{border-color:var(--accent)}
.emoji-categories{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap}
.emoji-cat-btn{font-size:14px;padding:3px 6px;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all var(--trans)}
.emoji-cat-btn:hover,.emoji-cat-btn.active{background:var(--glass2);border-color:var(--border2)}
.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;max-height:180px;overflow-y:auto}
.emoji-btn{font-size:18px;padding:4px;background:transparent;border:none;border-radius:6px;cursor:pointer;text-align:center;transition:background var(--trans)}
.emoji-btn:hover{background:var(--glass2)}

/* ═══ CONTACTS PAGE ═══════════════════════════════════ */
.tbl-search{background:rgba(0,0,0,.2);border:1px solid var(--border2);border-radius:8px;padding:7px 12px;color:var(--t0);font-family:var(--sans);font-size:12px;outline:none;width:220px;transition:border-color var(--trans)}
.tbl-search:focus{border-color:var(--accent)}
[data-theme="arctic"] .tbl-search{background:rgba(255,255,255,.6)}
.info-banner{display:flex;align-items:center;gap:10px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);border-radius:10px;padding:10px 16px;margin-bottom:16px;font-size:12px;color:var(--yellow)}
.info-banner svg{flex-shrink:0}
.server-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.server-detail-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--t3);margin-bottom:9px}
.server-detail-row{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--t2);padding:4px 0;border-bottom:1px solid var(--glass-border)}
.server-detail-row:last-child{border-bottom:none}
.server-detail-row code{font-family:var(--mono);font-size:11px;color:var(--cyan);background:var(--glass2);padding:1px 6px;border-radius:4px}

/* ═══ ACTION EDITOR ═══════════════════════════════════ */
.action-tab{padding:5px 16px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid var(--border2);background:transparent;color:var(--t2);cursor:pointer;font-family:var(--sans);transition:all var(--trans)}
.action-tab:hover{color:var(--t0);border-color:var(--border2);background:var(--glass2)}
.action-tab.active{background:var(--g-glow2);border-color:var(--accent);color:var(--accent3);box-shadow:0 0 10px var(--g-glow2)}
.action-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r);margin-bottom:10px;overflow:hidden;transition:border-color var(--trans),box-shadow var(--trans)}
.action-card:hover{border-color:var(--border2)}
.action-card.builtin-edited{border-color:rgba(168,139,250,.3)}
.action-card.custom{border-color:rgba(16,185,129,.25)}
.action-header{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none}
.action-header:hover{background:var(--glass-shine)}
.action-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.action-icon.mikrotik{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.2)}
.action-icon.olt{background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.2)}
.action-icon.helpdesk{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.2)}
.action-icon.system{background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.2)}
.action-icon.custom{background:rgba(251,146,60,.12);border:1px solid rgba(251,146,60,.2)}
.action-info{flex:1;min-width:0}
.action-name{font-size:13px;font-weight:600;color:var(--t0)}
.action-desc{font-size:11px;color:var(--t3);margin-top:2px}
.action-badges{display:flex;gap:5px;align-items:center;flex-shrink:0}
.action-chevron{color:var(--t3);transition:transform .2s;flex-shrink:0}
.action-card.open .action-chevron{transform:rotate(90deg)}
.action-body{display:none;border-top:1px solid var(--glass-border)}
.action-card.open .action-body{display:block}
.code-editor-wrap{position:relative}
.code-editor{width:100%;min-height:160px;max-height:420px;background:rgba(0,0,0,.4);color:#e2e8f0;font-family:var(--mono);font-size:12px;line-height:1.7;padding:14px 16px;border:none;outline:none;resize:vertical;tab-size:2;border-bottom:1px solid var(--glass-border)}
.code-editor:focus{box-shadow:inset 0 0 0 2px rgba(124,58,237,.2)}
.code-toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--glass2);border-top:1px solid var(--glass-border);flex-wrap:wrap}
.code-status{font-size:11px;font-family:var(--mono);flex:1}
.code-status.ok{color:var(--g)}
.code-status.err{color:var(--red)}
.action-meta{padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.test-result{margin:0 16px 14px;padding:11px 14px;background:rgba(0,0,0,.3);border:1px solid var(--glass-border);border-radius:8px;font-family:var(--mono);font-size:11.5px;color:var(--t1);white-space:pre-wrap;max-height:200px;overflow-y:auto;display:none}

/* ═══ SYSLOG ══════════════════════════════════════════ */
#syslog-terminal{background:rgba(0,0,0,.4);border:1px solid var(--glass-border);border-radius:10px;height:calc(100vh - 260px);overflow-y:auto;font-family:var(--mono);font-size:12px;padding:10px 12px}


/* ═══ TOPBAR CLOCK ════════════════════════════════════ */
.tb-clock {
  display: flex; flex-direction: column; align-items: flex-end;
  line-height: 1.2; flex-shrink: 0;
}
#tb-date {
  font-size: 9px; color: var(--t3); font-family: var(--mono);
  text-transform: uppercase; letter-spacing: .05em;
}
#tb-time {
  font-size: 13px; font-weight: 700; color: var(--accent3);
  font-family: var(--mono); letter-spacing: .04em;
  text-shadow: 0 0 12px var(--accent);
}




/* ═══ LOCATION CARD ══════════════════════════════════ */
.location-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--glass2); border: 1px solid var(--glass-border);
  border-radius: 12px; padding: 12px 14px;
  text-decoration: none; color: var(--t1);
  transition: all var(--trans); max-width: 280px;
}
.location-card:hover {
  border-color: var(--accent); background: var(--glass);
  box-shadow: var(--glow-accent);
}
.location-map-thumb {
  width: 48px; height: 48px; border-radius: 10px;
  background: var(--g-glow2); border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.location-info { min-width: 0; }
.location-label  { font-size: 12px; font-weight: 600; color: var(--t0); }
.location-coords { font-size: 10px; color: var(--t3); font-family: var(--mono); margin-top: 2px; }
.location-desc   { font-size: 11px; color: var(--t2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.location-open   { font-size: 10px; color: var(--accent3); margin-top: 4px; }

/* ═══ SETTINGS PAGE ══════════════════════════════════ */
.settings-tabs {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.settings-tab {
  padding: 8px 18px; border-radius: 10px; font-size: 12.5px; font-weight: 600;
  border: 1px solid var(--border2); background: var(--glass2);
  color: var(--t2); cursor: pointer; font-family: var(--sans);
  transition: all var(--trans);
}
.settings-tab:hover  { color: var(--t0); border-color: var(--border2); background: var(--glass); }
.settings-tab.active { background: var(--g-glow2); border-color: var(--accent); color: var(--accent3);
  box-shadow: 0 0 12px var(--g-glow2); }

.settings-panel { display: none; }
.settings-panel.active { display: block; animation: fadeUp .2s ease; }

/* Theme cards in settings */
.theme-card {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 14px 18px; border-radius: var(--r);
  border: 2px solid var(--border2); background: var(--glass2);
  cursor: pointer; font-family: var(--sans); transition: all var(--trans);
  min-width: 130px;
}
.theme-card:hover  { border-color: var(--border2); background: var(--glass); transform: translateY(-2px); }
.theme-card.active { border-color: var(--accent); box-shadow: 0 0 16px var(--g-glow); }
.theme-card-swatch { width: 48px; height: 48px; border-radius: 50%; box-shadow: 0 4px 12px rgba(0,0,0,.3); }
.theme-card-name   { font-size: 13px; font-weight: 700; color: var(--t0); }
.theme-card-desc   { font-size: 10px; color: var(--t3); text-align: center; }

/* ═══ CONTACTS TABLE — fixed layout, all columns always visible ══ */
#contacts-table { table-layout: fixed; width: 100%; }
#contacts-table thead th,
#contacts-table tbody td {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Sortable header hover */
#contacts-table th.sortable:hover { color: var(--accent3); background: var(--glass-shine); }
.sort-icon { font-size: 9px; opacity: .5; margin-left: 3px; }
th.sortable:hover .sort-icon { opacity: 1; }





/* Clickable contact row */
.contact-row { cursor: pointer; transition: background var(--trans); }
.contact-row:hover td { background: var(--glass2) !important; }

/* ═══ DISPLAY PREFERENCES (toggled via JS on <html>) ═ */
.hide-avatar  .contact-avatar  { display: none !important; }
.hide-carrier .carrier-badge   { display: none !important; }

/* ═══ VOICE MESSAGE ══════════════════════════════════ */
#mic-btn { touch-action: none; user-select: none; -webkit-user-select: none; }
#mic-btn:active { color: var(--red) !important; background: rgba(244,63,94,.15) !important; }
#voice-audio-preview { accent-color: var(--accent); }
/* Hide browser default audio controls overflow */
#voice-audio-preview::-webkit-media-controls-panel { background: var(--glass2); }

/* ═══ ATTACH SHEET (WhatsApp-style) ══════════════════ */
.attach-sheet-btn {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer;
  color: var(--t2); font-size: 11px; font-family: var(--sans);
  padding: 6px 12px; border-radius: 10px; transition: all var(--trans);
  flex: 1;
}
.attach-sheet-btn:hover { color: var(--accent3); background: var(--glass2); }
.attach-sheet-icon {
  font-size: 24px; width: 46px; height: 46px;
  background: var(--glass2); border: 1px solid var(--glass-border);
  border-radius: 14px; display: flex; align-items: center; justify-content: center;
}

/* ═══ RESPONSIVE TABLET (≤900px) ═════════════════════ */
@media(max-width:900px){
  :root{--sidebar:54px}
  .nav-sect{display:none}
  .nav-item{padding:11px;justify-content:center;margin:2px 5px;border-radius:10px;border-left:none;border-bottom:2px solid transparent}
  .nav-item.active{border-left:none;border-bottom-color:var(--accent)}
  .nav-item svg{width:18px;height:18px}
  .nav-item>*:not(svg):not(.nav-badge){display:none}
  .nav-badge{position:absolute;top:3px;right:3px;font-size:8px;padding:1px 3px}
  .nav-item{position:relative}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .modal{width:95vw!important}
  .form-grid{grid-template-columns:1fr}
  .fg.full{grid-column:1}
  .live-grid{grid-template-columns:1fr}
}

/* ═══ RESPONSIVE PHONE (≤640px) ══════════════════════ */
@media(max-width:640px){
  :root{--sidebar:0px;--top:48px}
  html,body{overflow:hidden;font-size:13px}
  #app.show{grid-template-columns:1fr;grid-template-rows:var(--top) 1fr}
  #topbar{padding:0 12px;gap:8px}
  #hamburger-btn{display:flex!important}
  .topbar-logo span,.tb-sep,.tb-version,.theme-switcher{display:none}
  #tb-user-role,#bot-label,.tb-clock{display:none}
  #sidebar{position:fixed;left:-260px;top:0;bottom:0;width:240px;z-index:200;transition:left .26s cubic-bezier(.4,0,.2,1);padding-top:var(--top);overflow-y:auto}
  #sidebar.mobile-open{left:0;box-shadow:4px 0 40px rgba(0,0,0,.5)}
  .nav-sect{display:block}
  .nav-item{padding:10px 14px;justify-content:flex-start;border-radius:0 8px 8px 0;border-left:2px solid transparent;border-bottom:none}
  .nav-item.active{border-left-color:var(--accent);border-bottom:none}
  .nav-item svg{width:14px;height:14px}
  .nav-item>*:not(svg):not(.nav-badge){display:inline}
  .nav-badge{position:static;font-size:9.5px;padding:1px 5px}
  #main{grid-column:1;overflow-y:auto}
  .page{padding:14px}
  .ph{flex-direction:column;gap:10px;align-items:flex-start}
  .ph>div:last-child{display:flex;flex-wrap:wrap;gap:6px;width:100%}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat{padding:12px 14px}
  .stat-val{font-size:22px}
  .live-grid{grid-template-columns:1fr}
  #feed{height:260px}
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:480px}
  .chat-shell{grid-template-columns:100%;height:calc(100vh - var(--top));border-radius:0;border-left:none;border-right:none;position:relative;overflow:hidden}
  .contact-panel{width:100%;border-right:none;position:absolute;inset:0;transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:1}
  .chat-area{position:absolute;inset:0;transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:2}
  .chat-shell.mobile-chat-open .contact-panel{transform:translateX(-100%)}
  .chat-shell.mobile-chat-open .chat-area{transform:translateX(0)}
  #chat-back-btn{display:flex!important}
  .chat-thread{padding:10px}
  .chat-input-bar{padding:8px}
  .chat-tool-btn{width:32px;height:32px}
  .modal{width:100vw!important;max-width:100vw!important;max-height:92vh;border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;margin:0;animation:slideUp .22s cubic-bezier(.4,0,.2,1)}
  .modal-bg.show{align-items:flex-end}
  @keyframes slideUp{from{transform:translateY(50px);opacity:0}to{transform:none;opacity:1}}
  .form-grid{grid-template-columns:1fr}
  .fg.full{grid-column:1}
  .server-detail-grid{grid-template-columns:1fr}
  .emoji-picker{width:calc(100vw - 24px);left:12px;bottom:68px}
  .action-meta{grid-template-columns:1fr}
  #syslog-terminal{height:calc(100vh - 220px);font-size:11px}
  /* Bigger textarea on mobile for comfortable typing */
  .chat-textarea {
    min-height: 46px; max-height: 160px;
    font-size: 15px; padding: 12px 42px 12px 14px; line-height: 1.6;
  }
  /* Input bar: safe padding + bottom clearance (prevent cut-off) */
  .chat-input-bar {
    padding: 8px 10px;
    padding-bottom: max(10px, env(safe-area-inset-bottom, 10px));
  }
  /* Send button bigger on mobile */
  .chat-send-btn { width: 46px; height: 46px; border-radius: 12px; }
  /* Chat area must not overflow into nav bar */
  .chat-shell { height: calc(100vh - var(--top)); }
  .chat-thread { padding-bottom: 8px; }

}


/* ═══ PWA / SAFE AREA (iPhone notch + home bar) ══════ */
#app.show {
  padding-top: env(safe-area-inset-top, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
/* Topbar height accounts for notch on iPhone */
#topbar {
  padding-left: max(20px, env(safe-area-inset-left, 20px));
  padding-right: max(20px, env(safe-area-inset-right, 20px));
}
/* Input bar clears home bar */
.chat-input-bar {
  padding-bottom: max(10px, env(safe-area-inset-bottom, 10px));
}

/* ═══ LOCATION MESSAGE CARD ══════════════════════════ */
.location-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--glass2); border: 1px solid var(--glass-border);
  border-radius: 12px; padding: 12px 14px;
  text-decoration: none; transition: all var(--trans);
  min-width: 220px; max-width: 280px;
}
.location-card:hover { border-color: var(--accent); background: var(--glass); }
.location-map-thumb {
  width: 44px; height: 44px; border-radius: 10px;
  background: var(--g-glow2); border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.location-info { flex: 1; min-width: 0; }
.location-label { font-size: 12.5px; font-weight: 600; color: var(--t0); }
.location-coords { font-family: var(--mono); font-size: 10px; color: var(--t3); margin-top: 2px; }
.location-desc  { font-size: 11px; color: var(--t2); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.location-open  { font-size: 10.5px; color: var(--accent3); margin-top: 5px; font-weight: 600; }
