:root{
  --bg: var(--tg-theme-bg-color, #f4f5f9);
  --card: var(--tg-theme-secondary-bg-color, #ffffff);
  --text: var(--tg-theme-text-color, #14151a);
  --hint: var(--tg-theme-hint-color, #8a8f9a);
  /* бренд Safe VPN — фиксированный зелёный (под логотип), не из темы Telegram */
  --accent: #2f9e44;
  --accent-text: #ffffff;
  --link: #2f9e44;
  --ok: #2bbf6a; --okbg: rgba(43,191,106,.14);
  --cold: #ff5c5c; --coldbg: rgba(255,92,92,.13);
  --grad1:#379a46; --grad2:#7ed957;
  --line: rgba(140,143,154,.18);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;background:var(--bg);color:var(--text);
  font:15px/1.4 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  padding-bottom:78px}
#view{max-width:560px;margin:0 auto;padding:10px 14px 20px}

/* шапка */
#appbar{position:sticky;top:0;z-index:5;background:var(--bg);
  border-bottom:1px solid var(--line);padding:12px 14px;display:flex;align-items:center;gap:11px}
#appbar .logo{width:42px;height:42px;border-radius:13px;flex:none;display:flex;
  align-items:center;justify-content:center;font-size:21px;object-fit:cover;
  background:linear-gradient(135deg,var(--grad1),var(--grad2));color:#fff;
  box-shadow:0 4px 12px rgba(55,154,70,.35)}
#appbar .ttl{font-weight:700;font-size:17px;line-height:1.1}
#appbar .sub{color:var(--hint);font-size:12px}
#appbar .spacer{flex:1}
#appbar .iconbtn{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  font-size:17px;cursor:pointer}

.hello{display:flex;align-items:flex-start;justify-content:space-between;margin:14px 2px 12px}
.hello .h1{font-size:13px;color:var(--hint)}
.hello .h2{font-size:22px;font-weight:800;margin-top:2px}
.refresh{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);
  background:var(--card);font-size:17px;cursor:pointer}

/* герой */
.hero{border-radius:22px;padding:20px;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--grad1),var(--grad2));
  box-shadow:0 12px 30px rgba(55,154,70,.32)}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:170px;height:170px;
  border-radius:50%;background:rgba(255,255,255,.12)}
.hero .cap{font-size:13px;opacity:.85}
.hero .big{font-size:30px;font-weight:800;margin:4px 0 2px}
.hero .pill{display:inline-block;font-size:12px;padding:3px 10px;border-radius:9px;
  background:rgba(255,255,255,.22)}
.hero .row{display:flex;gap:10px;margin-top:16px;position:relative;z-index:1}
.hero .hbtn{flex:1;text-align:center;padding:12px;border-radius:13px;font-weight:600;
  font-size:14px;background:rgba(255,255,255,.18);color:#fff;cursor:pointer;border:0}
.hero .hbtn.solid{background:#fff;color:var(--grad1)}

/* статы */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.stat{background:var(--card);border-radius:16px;padding:12px;border:1px solid var(--line)}
.stat .ic{font-size:15px}
.stat .lbl{color:var(--hint);font-size:12px;margin:6px 0 3px;line-height:1.2}
.stat .val{font-size:21px;font-weight:800}
.stat .val.sm{font-size:16px}

.section{display:flex;align-items:center;justify-content:space-between;margin:20px 2px 8px}
.section .t{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--hint);text-transform:uppercase}
.section .a{font-size:13px;color:var(--link);cursor:pointer}

/* карточки ключей/строк */
.card{background:var(--card);border-radius:16px;padding:14px;margin:8px 0;border:1px solid var(--line)}
.center{text-align:center}.muted{color:var(--hint)}.small{font-size:13px}
.row{display:flex;align-items:center;gap:12px;cursor:pointer}
.row .ib{width:44px;height:44px;border-radius:12px;flex:none;display:flex;align-items:center;
  justify-content:center;font-size:20px;background:rgba(55,154,70,.12)}
.row .gr{flex:1;min-width:0}
.row .nm{font-weight:700}
.row .ds{color:var(--hint);font-size:13px;margin-top:1px}
.chev{color:var(--hint);font-size:18px}
.badge{font-size:12px;padding:4px 10px;border-radius:9px;white-space:nowrap;font-weight:600}
.badge.ok{background:var(--okbg);color:var(--ok)}
.badge.cold{background:var(--coldbg);color:var(--cold)}

.btn{display:block;width:100%;border:0;border-radius:14px;padding:14px;margin:9px 0;
  font-size:15px;font-weight:700;background:var(--accent);color:var(--accent-text);cursor:pointer}
.btn:disabled{opacity:.55}
.btn.sec{background:var(--card);color:var(--text);border:1px solid var(--line)}
.btn.ghost{background:transparent;color:var(--link)}
.btn.danger{background:transparent;color:var(--cold)}
.qr{display:block;width:210px;height:210px;margin:6px auto;background:#fff;border-radius:14px;padding:9px}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;word-break:break-all;margin-top:4px}
.input{width:100%;border:0;background:transparent;color:var(--text);font-size:16px;padding:6px 2px;outline:none;text-transform:uppercase}
.guide{margin:0;padding-left:18px}.guide li{margin:7px 0}
.device{display:flex;align-items:center;gap:10px}

/* нижнее меню */
#tabbar{position:fixed;left:0;right:0;bottom:0;z-index:6;display:flex;
  background:var(--card);border-top:1px solid var(--line);
  padding:7px 6px calc(7px + env(safe-area-inset-bottom))}
#tabbar .tab{flex:1;text-align:center;color:var(--hint);font-size:11px;cursor:pointer;
  padding:3px 0;display:flex;flex-direction:column;align-items:center;gap:3px}
#tabbar .tab .ti{font-size:19px}
#tabbar .tab.active{color:var(--accent)}
