:root{--bg:#0b0e12;--panel:#121722;--line:#222b3a;--ink:#e7edf6;--mut:#7e8aa0;--accent:#46e3ff}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.vh{display:flex;align-items:center;gap:8px;padding:14px 16px;font-weight:700;letter-spacing:2px;
  font-size:14px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);
  padding-top:max(14px,env(safe-area-inset-top))}
.vh .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.vstat{margin-left:auto;font-weight:400;letter-spacing:1px;color:var(--mut);font-size:12px}
.vmain{max-width:560px;margin:0 auto;padding:16px}
.vcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px}
.vcard h2{margin:0 0 6px;font-size:20px}.vcard h3{margin:16px 0 6px;font-size:13px;letter-spacing:1px;color:var(--accent);text-transform:uppercase}
.vmut{color:var(--mut);font-size:13px;margin:6px 0}
.vin{width:100%;background:#0a0e14;border:1px solid var(--line);color:var(--ink);border-radius:8px;
  padding:12px;font-size:16px;outline:none}
.vin:focus{border-color:var(--accent)}
.vta{width:100%;min-height:84px;background:#0a0e14;border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:12px;font:14px/1.5 ui-monospace,Menlo,Consolas,monospace;outline:none;resize:vertical;word-break:break-all}
.vbtn{margin-top:10px;width:100%;background:var(--accent);color:#04121a;border:0;border-radius:8px;
  padding:12px;font-size:15px;font-weight:700;cursor:pointer}
.vbtn.ghost{background:transparent;color:var(--accent);border:1px solid var(--line);width:auto;padding:9px 14px;margin-top:0}
.vrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--ink)}
.vrow b{color:var(--accent)}
.vrow2{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.vlink{margin-left:auto;background:none;border:0;color:var(--mut);text-decoration:underline;cursor:pointer;font-size:12px}
.vinstall{border-style:dashed}

/* the interrupt — incoming call on the personal phone */
.gm-scrim{position:fixed;inset:0;background:rgba(2,4,7,.84);display:flex;align-items:center;justify-content:center;z-index:200;animation:gmIn .3s}
@keyframes gmIn{from{opacity:0}to{opacity:1}}
.gm-call{width:340px;max-width:90vw;background:#0e1116;border:1px solid #232c3a;border-radius:18px;padding:22px}
.gm-id{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.gm-av{width:54px;height:54px;border-radius:50%;background:#2a2f3a;color:#cdd4e0;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;animation:gmPulse 1.1s infinite}
@keyframes gmPulse{0%,100%{box-shadow:0 0 0 0 rgba(70,227,255,.4)}50%{box-shadow:0 0 0 12px rgba(70,227,255,0)}}
.gm-name{font-size:18px;font-weight:600}.gm-num{font-size:12px;color:var(--mut)}
.gm-sub{max-height:230px;overflow:auto;margin:4px 0}
.gm-line{color:var(--ink);font-size:14px;line-height:1.6;padding:5px 0;animation:gmIn .3s}
.gm-lost{color:#ff6b6b;letter-spacing:2px;font-size:12px;margin-top:12px}
.gm-mut{color:var(--mut);font-size:12px;margin-top:2px}
.gm-actions{display:flex;gap:12px;margin-top:16px}
.gm-btn{flex:1;border:0;border-radius:24px;padding:13px;font-size:14px;font-weight:600;cursor:pointer}
.gm-btn.answer{background:#2ec16b;color:#04140a}
.gm-btn.decline{background:#3a2330;color:#ff8a8a}
