:root{
  color-scheme:dark;
  --bg:#0b0d0f;
  --surface:#101316;
  --panel:#12171b;
  --panel-2:#161d22;
  --line:#2a343c;
  --line-soft:#1e272e;
  --text:#e9f1fb;
  --muted:#8b98a3;
  --accent:#4fc38b;
  --accent-2:#68a8e8;
  --good:#52d49f;
  --warn:#e5b75b;
  --bad:#ff6b7a;
  --shadow:none;
}
*{box-sizing:border-box}
html{scrollbar-color:#314154 #0b0d0f}
body{
  margin:0;
  min-height:100vh;
  background:var(--bg);
  color:var(--text);
  font:13px/1.38 Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
header{
  height:38px;
  padding:0 max(8px,calc((100% - 1440px)/2));
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--line);
  background:#101316f2;
  backdrop-filter:blur(8px);
  position:sticky;
  top:0;
  z-index:5;
}
header>div{display:flex;align-items:center;gap:8px;min-width:0}
header strong{font-size:15px;letter-spacing:0}
.version-badge{padding:1px 6px;border:1px solid var(--line);border-radius:7px;background:#0c0f12;color:var(--muted);font-size:11px;font-weight:750;line-height:1.5}
main{max-width:1440px;margin:8px auto 18px;padding:0 8px}
.muted{color:var(--muted)}
.good{color:var(--good)}
.error,.bad{color:var(--bad)}

.page-tabs{
  display:flex;
  gap:3px;
  margin-bottom:8px;
  padding:3px;
  border:1px solid var(--line);
  border-radius:7px;
  background:#101316;
  overflow:auto;
}
.page-tab{
  min-width:112px;
  min-height:32px;
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid transparent;
  border-radius:5px;
  background:transparent;
  color:var(--text);
  box-shadow:none;
  padding:4px 8px;
  font-size:13px;
}
.page-tab small{max-width:68px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-weight:600}
.page-tab.active{border-color:#3e6b56;background:#16221c;box-shadow:none}
.page{display:none}
.page.active{display:block}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px}
.stats article,.panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:6px;
  box-shadow:var(--shadow);
}
.stats article{padding:8px 10px;min-height:52px}
.stats span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.stats strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:750;line-height:1.2}
.panel{padding:10px;margin-bottom:8px}
.panel h2{margin:0;font-size:14px;font-weight:750}
.actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.panel>.actions{
  padding-bottom:8px;
  border-bottom:1px solid var(--line-soft);
}
.panel>.actions+*{margin-top:0}
.actions>div:first-child{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.actions h2,.actions p{margin:0}
.actions h2{line-height:1.15}
.actions p{
  max-width:760px;
  color:var(--muted);
  font-size:11px;
  line-height:1.3;
}
.toolbar{align-items:center}

.subscription-layout{
  display:grid;
  gap:8px;
}
.subscription-links{display:flex;flex-direction:column}
.modal-card.subscription-links{width:min(1180px,100%)}
.subscription-links summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin:-2px 0 7px;
  cursor:pointer;
  list-style:none;
  user-select:none;
}
.subscription-links summary::-webkit-details-marker{display:none}
.subscription-links summary span{display:flex;align-items:center;gap:7px;min-width:0;white-space:nowrap}
.subscription-links summary strong{display:flex;align-items:center;gap:4px;white-space:nowrap;font-size:14px}
.subscription-links summary small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:10px}
.subscription-links summary b::before{content:"Свернуть";color:var(--muted);font-size:10px;font-weight:750}
.subscription-links:not([open]) summary{margin-bottom:0}
.subscription-links:not([open]) summary b::before{content:"Развернуть"}
.subscription-links .table-wrap{overflow:auto;max-height:52vh}
.modal-card.subscription-links .table-wrap{max-height:min(620px,72vh)}
.link-tools{margin-bottom:6px}
.link-tools input{min-width:0}
.upstream-list{display:grid;gap:6px;margin-top:8px}
.upstream-card{
  border:1px solid var(--line-soft);
  border-radius:5px;
  padding:0;
  background:#0d1114;
  overflow:hidden;
}
.upstream-card-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  cursor:pointer;
  list-style:none;
  min-height:38px;
  padding:8px 10px;
}
.upstream-card[open] .upstream-card-head{border-bottom:1px solid var(--line-soft);background:#10161a}
.upstream-card-head::-webkit-details-marker{display:none}
.upstream-card-head strong{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.upstream-card-title{display:grid;grid-template-columns:220px minmax(0,1fr);align-items:center;gap:14px;min-width:0}
.upstream-inline-stats{display:grid;grid-template-columns:1.25fr .7fr .7fr .95fr;align-items:center;gap:8px;min-width:0;overflow:hidden}
.upstream-inline-stats span{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-width:0;
  padding:0;
  color:var(--text);
}
.upstream-inline-stats b{color:var(--muted);font-size:10px;font-weight:750;text-transform:none;letter-spacing:0;white-space:nowrap}
.upstream-inline-stats em{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:normal;font-size:11px;font-weight:750}
.upstream-card-head .button-row{margin-left:auto}
.upstream-card-head button{min-height:26px;padding:4px 7px;font-size:11px}
.upstream-toggle{
  width:10px;
  height:10px;
  margin-left:8px;
  margin-right:3px;
  border-right:2px solid var(--muted);
  border-bottom:2px solid var(--muted);
  transform:rotate(45deg);
  transition:transform .15s,border-color .15s;
  opacity:.9;
}
.upstream-card[open] .upstream-toggle{transform:rotate(225deg);border-color:var(--accent)}
.upstream-card .grid{grid-template-columns:repeat(4,1fr)}
.upstream-settings{
  margin:0;
  padding:10px 8px 8px;
  background:#0b0f12;
  border-top:1px solid #111b20;
}
.upstream-settings .grid{padding-top:0}
.modal-source-group{
  display:grid;
  gap:4px;
  border:1px solid var(--line-soft);
  border-radius:5px;
  background:#0d1114;
  padding:5px;
}
.modal-source-group summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  cursor:pointer;
  color:var(--text);
  list-style:none;
  padding:2px 3px 5px;
}
.modal-source-group summary::-webkit-details-marker{display:none}
.modal-source-group summary span{color:var(--muted);font-size:11px;font-weight:750}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.form-grid{margin-top:6px}
.wide{grid-column:1/-1}
label{display:flex;flex-direction:column;gap:3px;color:var(--muted);font-size:12px}
input,textarea,select{
  width:100%;
  border:1px solid var(--line);
  border-radius:5px;
  background:#0b0f12;
  color:var(--text);
  padding:6px 8px;
  min-height:30px;
  font:inherit;
  outline:none;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #4fc38b24;background:#10161a}
textarea{resize:vertical;margin-top:4px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace}
.check{flex-direction:row;align-items:center;color:var(--text);gap:8px}
.check input{width:auto;min-height:auto}
.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:8px}

button{
  border:1px solid #4fc38b66;
  border-radius:5px;
  padding:6px 10px;
  min-height:30px;
  background:#2f9f6c;
  color:#07120d;
  font:inherit;
  font-weight:750;
  cursor:pointer;
  white-space:nowrap;
  transition:filter .15s,transform .08s,border-color .15s;
}
button:hover{filter:brightness(1.08)}
button:active{transform:translateY(1px)}
button:disabled{opacity:.55;cursor:wait;transform:none}
.quiet{border-color:#34414a;background:#171d22;color:var(--text)}
.danger{border-color:#74404a;background:#4b202c;color:#ffdce1}
.button-row{display:flex;gap:5px;align-items:center}
.button-row input{min-width:190px}
.button-row select{min-width:116px}

.table-wrap{
  overflow:auto;
  border:1px solid var(--line-soft);
  border-radius:5px;
  background:#0d1114;
}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
tbody tr:hover{background:#151c21}
tbody tr:last-child td{border-bottom:0}
th{color:var(--muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#11171b;position:sticky;top:0;z-index:1}
td{font-size:12px}
.link-cell{max-width:680px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:10px;color:#b9c8da}
.ping{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;color:var(--good)}
.ping-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:58px;
  padding:2px 6px;
  border:1px solid #3a4852;
  border-radius:4px;
  background:#172027;
  color:#c6d4e3;
  font:750 10px/1.35 ui-monospace,SFMono-Regular,Consolas,monospace;
}
.ping-fast{border-color:#4fc38b55;background:#11241b;color:#79e5ae}
.ping-ok{border-color:#68a8e855;background:#111f2d;color:#99cbff}
.ping-slow{border-color:#f0a04b66;background:#2b1d10;color:#ffbd70}
.ping-bad{border-color:#ff6b7a55;background:#2b171b;color:#ff9aa5}
.ping-pending{border-color:#8b98a355;background:#191f24;color:#aab6c1}
.ping-unknown{border-color:#3a4852;background:#172027;color:#9aa8b5}
.type-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:52px;
  padding:2px 6px;
  border:1px solid #3a4852;
  border-radius:4px;
  background:#172027;
  color:#c6d4e3;
  font:750 10px/1.35 ui-monospace,SFMono-Regular,Consolas,monospace;
  letter-spacing:0;
  text-transform:uppercase;
}
.type-vless{border-color:#b58cff55;background:#211a2d;color:#c9a8ff}
.type-vmess{border-color:#68a8e855;background:#111f2d;color:#94caff}
.type-trojan{border-color:#e5b75b55;background:#292212;color:#f3cf76}
.type-ss,.type-ssr,.type-shadowsocks{border-color:#b58cff55;background:#211a2d;color:#c9a8ff}
.type-hysteria,.type-hysteria2,.type-hy2{border-color:#ff6b7a55;background:#2b171b;color:#ff9aa5}
.type-tuic{border-color:#5fd8d055;background:#112525;color:#8deae4}
.type-wireguard,.type-wg{border-color:#d7df6a55;background:#242713;color:#e7ef86}
.copy-button{min-width:82px;padding:5px 8px;min-height:26px;font-size:11px}
.copy-button.copied{border-color:#58d9a655;background:var(--good);color:#061d15}
.copy-button.copy-error{border-color:#ff6b7a55;background:var(--bad);color:#25070a}

.raw{
  max-height:170px;
  overflow:auto;
  white-space:pre-wrap;
  color:#b8c6d7;
  background:#0b0f12;
  border:1px solid var(--line-soft);
  border-radius:5px;
  padding:7px;
  font:11px/1.35 ui-monospace,SFMono-Regular,Consolas,monospace;
}

.clients-table input{min-width:120px;padding:5px 7px;min-height:28px}
.clients-table td:first-child{width:38px;text-align:center}
.clients-table td:last-child{width:96px}
.clients-table td:last-child button{width:100%}
.clients-table td:first-child input{
  width:14px;
  height:14px;
  min-width:0;
  min-height:0;
  padding:0;
}
[data-page="clients"]{gap:8px}
.unknown-clients-panel{margin-top:0}
.unknown-client-list{display:grid;gap:6px}
.unknown-client-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:7px;
  align-items:center;
  border:1px solid #e5b75b3d;
  border-left:3px solid var(--warn);
  border-radius:5px;
  padding:7px;
  background:#211b10;
}
.unknown-client-card:hover{border-color:#e5b75b70;background:#272013}
.unknown-client-meta{display:flex;flex-wrap:wrap;gap:5px 10px;color:var(--muted);font-size:11px}
.unknown-client-meta b{color:var(--text);font-weight:600}
.unknown-client-title{display:flex;gap:7px;align-items:center;margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid var(--line-soft)}
.unknown-client-title strong{font-size:12px}
.route-card{
  border:1px solid var(--line-soft);
  border-radius:5px;
  padding:7px;
  margin-top:6px;
  background:#0d1114;
}
.route-profile{display:grid;grid-template-columns:1fr auto;gap:7px;align-items:center}
.route-profile-main{display:grid;grid-template-columns:minmax(170px,260px) 1fr;gap:7px;align-items:end}
.route-readonly{border-color:#4fc38b40;background:#101914}
.route-all{border-left:3px solid var(--accent)}
.route-readonly-title{display:flex;flex-direction:column;gap:3px;padding:6px 8px;border:1px solid var(--line-soft);border-radius:5px;background:#0b0f12}
.route-readonly-title strong{font-size:13px;color:var(--text);font-family:ui-monospace,SFMono-Regular,Consolas,monospace}
.route-summary{display:flex;flex-direction:column;gap:3px;color:var(--muted);padding-left:8px;border-left:2px solid var(--line-soft)}
.route-summary strong{color:var(--text);font-size:12px}
.route-actions{justify-content:flex-end}
.route-url-text{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#9fc7e8;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:10px}
.route-empty{margin:8px 0 0}
.route-status-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}
.status-badge{display:inline-flex;align-items:center;width:max-content;border:1px solid var(--line);border-radius:4px;padding:1px 5px;font-size:10px;font-weight:750;line-height:1.4}
.status-new{border-color:#4fc38b66;background:#13251b;color:#85e8b4}
.status-stale{border-color:#e5b75b66;background:#2a2110;color:#f0c86c}
.modal{
  position:fixed;
  inset:0;
  display:grid;
  place-items:center;
  padding:10px;
  background:#020405cc;
  backdrop-filter:blur(5px);
  z-index:20;
}
.modal[hidden]{display:none}
.modal-card{
  width:min(900px,100%);
  max-height:min(760px,94vh);
  display:flex;
  flex-direction:column;
  gap:7px;
  background:#11171b;
  border:1px solid var(--line);
  border-radius:7px;
  padding:9px;
  box-shadow:none;
}
.modal-link-list{display:grid;gap:4px;overflow:auto;padding-right:2px}
.modal-link{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  gap:7px;
  align-items:center;
  color:var(--text);
  background:#0d1114;
  border:1px solid var(--line-soft);
  border-radius:5px;
  padding:5px 7px;
}
.modal-link:hover{border-color:#3e6b56;background:#121a16}
.modal-link-stale{border-color:#e5b75b55;background:#211b10}
.modal-link input{width:auto;min-height:auto}
.modal-link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-link code:not(.type-badge){color:var(--muted);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:11px}

.log-list{display:grid;gap:6px;max-height:72vh;overflow:auto}
.log-item{
  display:grid;
  grid-template-columns:76px 58px 86px 1fr;
  gap:6px;
  padding:5px 7px;
  border-left:2px solid var(--line);
  border:1px solid var(--line-soft);
  background:#0d1114;
  border-radius:4px;
  font-size:11px;
}
.log-item span,.log-item em{color:var(--muted);font-style:normal}
.log-time{display:flex;flex-direction:column;gap:1px;line-height:1.1}
.log-time small{font-size:10px;color:var(--muted)}
.log-time b{color:#c4d0dd;font-size:11px}
.log-item code{white-space:pre-wrap;color:#c8d5e5}
.level-error{border-color:#ff6b7a55;border-left-color:var(--bad);background:#2a1218}
.level-warning{border-color:#e5b75b4d;border-left-color:var(--warn);background:#271f10}
.level-info{border-color:#4fc38b45;border-left-color:var(--accent);background:#102119}

.login-body{min-height:100vh;display:grid;place-items:center;padding:16px}
.login-card{
  width:min(320px,100%);
  margin:0;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:7px;
  padding:18px;
  box-shadow:none;
}
.login-card h1{margin:12px 0 4px;font-size:20px}
.login-card p{margin:0;color:var(--muted)}
.login-card form{display:grid;gap:10px;margin-top:20px}
.login-card form button{margin-top:14px}
.login-hint{margin-top:12px!important;color:var(--muted);font-size:11px}
.login-logo{display:grid;justify-items:center;gap:3px;margin:0 0 12px;text-align:center}
.login-product{font-size:26px;font-weight:700;line-height:1;color:#eef3f8;letter-spacing:0}
.login-logo-text{font-size:14px;font-weight:500;line-height:1;color:#eef3f8;letter-spacing:0}
.login-logo-text strong{color:#2688df}

@media(max-width:820px){
  main{margin-top:6px;padding:0 6px}
  header{padding:0 6px}
  .stats article,
  .panel,
  .subscription-layout,
  .subscription-layout>*{min-width:0;max-width:100%;width:100%}
  .page-tabs{overflow:visible}
  .page-tab small{display:none}
  .page-tab{min-width:0;flex:1 1 0;padding:4px 5px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .subscription-links .table-wrap{max-height:60vh}
  .subscription-links summary{min-width:0}
  .subscription-links summary span{flex-wrap:wrap;white-space:normal}
  .subscription-links summary strong{white-space:normal}
  .subscription-links summary small{width:100%}
  .grid{grid-template-columns:1fr}
  .upstream-card-head{display:flex;align-items:stretch;flex-direction:column}
  .upstream-card-head .button-row{margin-left:0;width:100%}
  .upstream-card-title{display:flex;align-items:flex-start;flex-direction:column;gap:5px}
  .upstream-inline-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;width:100%;overflow:visible}
  .upstream-inline-stats span{max-width:none;padding:3px 5px;border:1px solid var(--line-soft);border-radius:4px;background:#0b0f12}
  .upstream-card .grid{grid-template-columns:1fr}
  .wide{grid-column:auto}
  .actions{align-items:flex-start;flex-direction:column}
  .actions>div:first-child,
  .actions label,
  .actions button,
  .form-actions,
  .form-actions button,
  label,
  input,
  textarea,
  select{width:100%;min-width:0}
  .toolbar,.button-row{align-items:stretch}
  .button-row{width:100%;flex-wrap:wrap}
  .button-row input,
  .button-row select,
  .button-row button{min-width:0;flex:1 1 150px}
  .link-tools{display:grid;grid-template-columns:1fr 1fr;gap:5px}
  .link-tools input{grid-column:1/-1}
  .table-wrap{max-width:100%}
  .subscription-links table{min-width:0}
  .subscription-links th:nth-child(5),
  .subscription-links td:nth-child(5){display:none}
  .clients-table{min-width:0;table-layout:fixed}
  .clients-table thead{display:none}
  .clients-table tbody{display:block}
  .clients-table tr{
    display:grid;
    grid-template-columns:24px minmax(58px,1fr) minmax(64px,1fr) minmax(72px,1.2fr) minmax(58px,.8fr) 56px;
    gap:4px;
    align-items:center;
    padding:7px;
    border-bottom:1px solid var(--line-soft);
  }
  .clients-table td{
    padding:0;
    border-bottom:0;
    min-width:0;
  }
  .clients-table td:first-child{
    width:auto;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .clients-table td:last-child{width:100%}
  .clients-table td:last-child button{width:100%}
  .clients-table input{
    width:100%;
    min-width:0;
    padding:4px 5px;
    min-height:26px;
    font-size:11px;
  }
  .clients-table td:first-child input{width:13px;height:13px}
  .clients-table button{padding:4px 5px;min-height:26px;font-size:11px}
  .route-profile,.route-profile-main{grid-template-columns:1fr}
  .route-actions{justify-content:stretch}
  .unknown-client-card{grid-template-columns:1fr}
  .unknown-client-card .button-row{display:grid;grid-template-columns:1fr 1fr}
  .clients-table input{min-width:0}
  .modal-link{grid-template-columns:auto 1fr auto}
  .modal-link code{grid-column:2/-1}
  .log-item{grid-template-columns:64px 1fr}
  .log-item code{grid-column:1/-1}
}
@media(max-width:520px){
  body{font-size:12px}
  .stats{grid-template-columns:1fr}
  .page-tab{min-width:0}
  .panel{padding:7px}
  .form-actions{align-items:stretch;flex-direction:column}
  .form-actions button{width:100%}
  .link-tools,
  .unknown-client-card .button-row{grid-template-columns:1fr}
  .upstream-inline-stats{grid-template-columns:1fr}
  .modal-card{padding:7px}
}
