/* ── Vazirmatn Fonts ─────────────────────────────────────────────────── */
@font-face { font-family:'Vazirmatn'; font-weight:100; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-Thin.woff2') format('woff2'); }
@font-face { font-family:'Vazirmatn'; font-weight:300; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-Light.woff2') format('woff2'); }
@font-face { font-family:'Vazirmatn'; font-weight:400; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-Regular.woff2') format('woff2'); }
@font-face { font-family:'Vazirmatn'; font-weight:500; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-Medium.woff2') format('woff2'); }
@font-face { font-family:'Vazirmatn'; font-weight:600; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-SemiBold.woff2') format('woff2'); }
@font-face { font-family:'Vazirmatn'; font-weight:700; font-display:swap; src:url('../fonts/Vazirmatn/Vazirmatn-Bold.woff2') format('woff2'); }

/* ── Variables ───────────────────────────────────────────────────────── */
:root {
  --bg-root:      #0d1117;
  --bg-sidebar:   #13161e;
  --bg-card:      #1a1d2e;
  --bg-input:     #1e2235;
  --bg-hover:     #242840;
  --bg-modal:     #1a1d2e;
  --border:       #2d3250;
  --border-focus: #6366f1;
  --text:         #e8eaf0;
  --text-muted:   #7c85a8;
  --text-dim:     #4a5180;
  --accent:       #6366f1;
  --accent-hover: #4f52d6;
  --accent-light: rgba(99,102,241,0.12);
  --green:        #22c55e;
  --green-light:  rgba(34,197,94,0.12);
  --red:          #ef4444;
  --red-light:    rgba(239,68,68,0.12);
  --orange:       #f59e0b;
  --orange-light: rgba(245,158,11,0.12);
  --blue:         #3b82f6;
  --blue-light:   rgba(59,130,246,0.12);
  --purple:       #a855f7;
  --purple-light: rgba(168,85,247,0.12);
  --sidebar-w:    240px;
  --radius:       10px;
  --radius-sm:    6px;
  --shadow:       0 4px 24px rgba(0,0,0,.35);
  --transition:   .18s ease;
  --font:         'Vazirmatn', system-ui, sans-serif;
}

/* ── Reset ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:15px; }
body { font-family:var(--font); background:var(--bg-root); color:var(--text); line-height:1.6; direction:rtl; }
a { color:inherit; text-decoration:none; }
svg { fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
code { font-family:'Courier New',monospace; font-size:.85em; background:var(--bg-input); padding:2px 6px; border-radius:4px; color:#a5b4fc; }

/* ── Scrollbar ───────────────────────────────────────────────────────── */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

/* ── Layout ──────────────────────────────────────────────────────────── */
.app-layout { display:flex; min-height:100vh; }

.sidebar {
  width:var(--sidebar-w);
  background:var(--bg-sidebar);
  border-left:1px solid var(--border);
  display:flex;
  flex-direction:column;
  position:fixed;
  top:0; right:0;
  height:100vh;
  z-index:100;
  transition:transform var(--transition);
}
.sidebar.collapsed { transform:translateX(var(--sidebar-w)); }

.sidebar-brand {
  display:flex; align-items:center; gap:10px;
  padding:20px 16px;
  font-size:1rem; font-weight:700;
  border-bottom:1px solid var(--border);
  color:var(--text);
}
.sidebar-brand svg rect { rx:10; }

.sidebar-nav {
  flex:1;
  padding:12px 8px;
  display:flex;
  flex-direction:column;
  gap:2px;
  overflow-y:auto;
}

.nav-link {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius:var(--radius-sm);
  color:var(--text-muted);
  font-size:.9rem;
  font-weight:500;
  transition:background var(--transition), color var(--transition);
  cursor:pointer;
}
.nav-link svg { width:18px; height:18px; flex-shrink:0; }
.nav-link:hover { background:var(--bg-hover); color:var(--text); }
.nav-link.active { background:var(--accent-light); color:var(--accent); }

.sidebar-footer {
  padding:12px 14px;
  border-top:1px solid var(--border);
  display:flex; align-items:center; gap:10px;
}
.admin-avatar {
  width:32px; height:32px;
  border-radius:50%;
  background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:700;
  flex-shrink:0;
}
.admin-name { font-size:.85rem; font-weight:600; }
.admin-role { font-size:.75rem; color:var(--text-muted); }
.admin-info--link {
  flex:1; text-decoration:none; color:inherit;
  border-radius:var(--radius-sm);
  transition:background var(--transition);
}
.admin-info--link:hover { background:var(--bg-hover); }
.btn-logout {
  margin-right:auto;
  color:var(--text-muted);
  padding:6px;
  border-radius:var(--radius-sm);
  transition:color var(--transition), background var(--transition);
  display:flex; align-items:center;
}
.btn-logout:hover { color:var(--red); background:var(--red-light); }

.main-wrapper {
  flex:1;
  margin-right:var(--sidebar-w);
  display:flex;
  flex-direction:column;
  min-height:100vh;
  transition:margin var(--transition);
}
.sidebar.collapsed ~ .main-wrapper { margin-right:0; }

/* ── Topbar ──────────────────────────────────────────────────────────── */
.topbar {
  height:60px;
  background:var(--bg-sidebar);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:14px;
  padding:0 24px;
  position:sticky; top:0; z-index:50;
}
.sidebar-toggle {
  background:none; border:none; cursor:pointer;
  color:var(--text-muted); padding:4px;
  border-radius:var(--radius-sm);
  transition:color var(--transition);
  display:none;
}
.sidebar-toggle:hover { color:var(--text); }
.page-title { font-size:1rem; font-weight:600; flex:1; }
.topbar-actions { display:flex; gap:8px; }

/* ── Page content ────────────────────────────────────────────────────── */
.page-content { padding:24px; flex:1; }

/* ── Cards ───────────────────────────────────────────────────────────── */
.card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
}
.card--accounts {
  overflow:visible;
}
.card--accounts .table-wrap {
  overflow:visible;
}
.card--accounts .table th:last-child,
.card--accounts .table td:last-child {
  position:relative;
  overflow:visible;
  white-space:nowrap;
}
.card-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid var(--border);
}
.card-title { font-size:.95rem; font-weight:600; }
.mt-4 { margin-top:16px; }

/* ── Stats grid ──────────────────────────────────────────────────────── */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:16px;
  margin-bottom:24px;
}
.stat-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 16px;
  display:flex; align-items:center; gap:14px;
  position:relative;
}
.stat-icon {
  width:44px; height:44px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.stat-icon svg { width:22px; height:22px; }
.stat-icon--blue   { background:var(--blue-light);   color:var(--blue); }
.stat-icon--purple { background:var(--purple-light); color:var(--purple); }
.stat-icon--green  { background:var(--green-light);  color:var(--green); }
.stat-icon--orange { background:var(--orange-light); color:var(--orange); }
.stat-body { flex:1; }
.stat-value { font-size:1.6rem; font-weight:700; line-height:1.2; }
.stat-label { font-size:.8rem; color:var(--text-muted); margin-top:2px; }
.stat-badge {
  position:absolute;
  top:12px; left:12px;
  font-size:.7rem; font-weight:600;
  padding:2px 8px;
  border-radius:20px;
}
.stat-badge--green { background:var(--green-light); color:var(--green); }
.stat-badge--blue  { background:var(--blue-light);  color:var(--blue); }

/* ── Server list (dashboard) ─────────────────────────────────────────── */
.server-list { padding:8px 0; }
.server-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 20px;
  gap:16px;
  border-bottom:1px solid var(--border);
}
.server-row:last-child { border-bottom:none; }
.server-info { display:flex; align-items:center; gap:10px; min-width:200px; }
.server-indicator {
  width:8px; height:8px;
  border-radius:50%;
  flex-shrink:0;
}
.server-indicator--online  { background:var(--green); box-shadow:0 0 6px var(--green); }
.server-indicator--offline { background:var(--text-dim); }
.server-name { font-weight:600; font-size:.9rem; }
.server-meta { font-size:.78rem; color:var(--text-muted); font-family:monospace; }
.server-progress-wrap { display:flex; align-items:center; gap:10px; flex:1; }
.server-progress { flex:1; height:6px; background:var(--bg-input); border-radius:3px; overflow:hidden; }
.server-progress-bar { height:100%; border-radius:3px; transition:width .4s ease; }
.server-progress-bar--success { background:var(--green); }
.server-progress-bar--warning { background:var(--orange); }
.server-progress-bar--danger  { background:var(--red); }
.server-count { font-size:.8rem; color:var(--text-muted); white-space:nowrap; }

/* ── Progress mini ───────────────────────────────────────────────────── */
.progress-mini { height:5px; background:var(--bg-input); border-radius:3px; overflow:hidden; flex:1; }
.progress-mini-bar { height:100%; background:var(--green); border-radius:3px; transition:width .3s; }
.progress-mini-bar.warning { background:var(--orange); }
.progress-mini-bar.danger  { background:var(--red); }

/* ── Tables ──────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; }
.table { width:100%; border-collapse:collapse; font-size:.875rem; }
.table th {
  padding:11px 16px;
  text-align:right;
  font-size:.78rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.05em;
  color:var(--text-muted);
  background:var(--bg-input);
  border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.table td {
  padding:11px 16px;
  border-bottom:1px solid var(--border);
  vertical-align:middle;
}
.table tbody tr:last-child td { border-bottom:none; }
.table tbody tr:hover { background:rgba(255,255,255,.02); }
.table-footer {
  padding:10px 16px;
  font-size:.8rem;
  color:var(--text-muted);
  border-top:1px solid var(--border);
  text-align:left;
}

/* ── Pagination ──────────────────────────────────────────────────────── */
.pagination {
  display:flex; flex-wrap:wrap; gap:4px;
  padding:12px 16px;
  border-top:1px solid var(--border);
}
.page-btn {
  min-width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:.82rem;
  color:var(--text-muted);
  transition:all var(--transition);
}
.page-btn:hover { border-color:var(--accent); color:var(--accent); }
.page-btn.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.page-btn--nav { font-size:1.1rem; font-weight:700; padding:0 10px; }
.page-btn--dots { border:none; cursor:default; min-width:24px; }
.page-btn--dots:hover { border:none; color:var(--text-muted); }

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px;
  border-radius:var(--radius-sm);
  font-family:var(--font);
  font-size:.875rem; font-weight:500;
  border:1px solid transparent;
  cursor:pointer;
  transition:all var(--transition);
  white-space:nowrap;
  line-height:1.4;
}
.btn:disabled { opacity:.5; cursor:not-allowed; }

.btn-primary   { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover:not(:disabled) { background:var(--accent-hover); }

.btn-ghost     { background:transparent; color:var(--text-muted); border-color:var(--border); }
.btn-ghost:hover:not(:disabled) { background:var(--bg-hover); color:var(--text); }

.btn-outline   { background:transparent; color:var(--accent); border-color:var(--accent); }
.btn-outline:hover:not(:disabled) { background:var(--accent-light); }

.btn-danger-ghost { background:transparent; color:var(--text-muted); border-color:transparent; }
.btn-danger-ghost:hover:not(:disabled) { color:var(--red); background:var(--red-light); }

.btn-sm { padding:5px 10px; font-size:.8rem; }
.btn-full { width:100%; justify-content:center; }

/* ── Forms ───────────────────────────────────────────────────────────── */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-group.span-2 { grid-column:span 2; }
.form-label { font-size:.82rem; font-weight:600; color:var(--text-muted); }
.req { color:var(--red); margin-right:2px; }
.form-input {
  background:var(--bg-input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);
  font-family:var(--font);
  font-size:.875rem;
  padding:9px 12px;
  transition:border-color var(--transition);
  width:100%;
  outline:none;
}
.form-input:focus { border-color:var(--border-focus); box-shadow:0 0 0 3px rgba(99,102,241,.12); }
.form-input::placeholder { color:var(--text-dim); }
.form-input option { background:var(--bg-card); }
.form-hint { font-size:.75rem; color:var(--text-dim); }
.font-mono { font-family:'Courier New',monospace !important; letter-spacing:.02em; }

.input-with-icon { position:relative; }
.input-with-icon .form-input { padding-left:38px; }
.input-icon-btn {
  position:absolute; left:10px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer;
  color:var(--text-muted); padding:2px;
  display:flex; align-items:center;
}
.input-icon-btn:hover { color:var(--text); }
.input-icon-btn--static { pointer-events:none; cursor:default; }
.input-icon-btn--static:hover { color:var(--text-muted); }

/* ── Alerts ──────────────────────────────────────────────────────────── */
.alert {
  padding:10px 14px;
  border-radius:var(--radius-sm);
  font-size:.875rem;
  border:1px solid transparent;
}
.alert-danger  { background:var(--red-light);   border-color:rgba(239,68,68,.3);   color:#fca5a5; }
.alert-success { background:var(--green-light);  border-color:rgba(34,197,94,.3);   color:#86efac; }
.alert-info    { background:var(--blue-light);   border-color:rgba(59,130,246,.3);  color:#93c5fd; }

/* ── Badges ──────────────────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center;
  padding:2px 9px;
  border-radius:20px;
  font-size:.75rem; font-weight:600;
  white-space:nowrap;
}
.badge--green  { background:var(--green-light);  color:var(--green); }
.badge--red    { background:var(--red-light);    color:var(--red); }
.badge--blue   { background:var(--blue-light);   color:var(--blue); }
.badge--gray   { background:rgba(255,255,255,.06); color:var(--text-muted); }
.badge--orange { background:var(--orange-light); color:var(--orange); }

/* ── Action buttons ──────────────────────────────────────────────────── */
.action-btns {
  display:inline-flex; gap:5px; align-items:center; flex-wrap:nowrap;
  padding:5px 6px;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.015) 100%);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.btn-icon {
  position:relative;
  width:34px; height:34px; padding:0; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:10px;
  border:1px solid transparent;
  background:transparent;
  color:var(--text-muted);
  cursor:pointer;
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
}
.btn-icon::before {
  content:'';
  position:absolute; inset:0;
  border-radius:inherit;
  opacity:0;
  transition:opacity .18s ease;
  pointer-events:none;
}
.btn-icon .icon {
  position:relative; z-index:1;
  display:block;
  transition:transform .18s ease;
}
.btn-icon:hover {
  transform:translateY(-1px);
  color:var(--text);
}
.btn-icon:hover .icon { transform:scale(1.08); }
.btn-icon:active {
  transform:translateY(0) scale(.94);
}
.btn-icon:active .icon { transform:scale(1); }

/* tinted variants */
.btn-icon--copy {
  color:#38bdf8;
  background:rgba(56,189,248,.1);
  border-color:rgba(56,189,248,.22);
  box-shadow:0 2px 8px rgba(56,189,248,.08);
}
.btn-icon--copy::before { background:radial-gradient(circle at 50% 0%, rgba(56,189,248,.18), transparent 70%); }
.btn-icon--copy:hover {
  color:#7dd3fc;
  background:rgba(56,189,248,.18);
  border-color:rgba(56,189,248,.4);
  box-shadow:0 4px 14px rgba(56,189,248,.22);
}
.btn-icon--copy:hover::before { opacity:1; }

.btn-icon--info {
  color:#a78bfa;
  background:rgba(167,139,250,.1);
  border-color:rgba(167,139,250,.22);
  box-shadow:0 2px 8px rgba(167,139,250,.08);
}
.btn-icon--info::before { background:radial-gradient(circle at 50% 0%, rgba(167,139,250,.18), transparent 70%); }
.btn-icon--info:hover {
  color:#c4b5fd;
  background:rgba(167,139,250,.18);
  border-color:rgba(167,139,250,.4);
  box-shadow:0 4px 14px rgba(167,139,250,.22);
}
.btn-icon--info:hover::before { opacity:1; }

.btn-icon--menu {
  color:var(--accent);
  background:var(--accent-light);
  border-color:rgba(99,102,241,.28);
  box-shadow:0 2px 8px rgba(99,102,241,.1);
}
.btn-icon--menu::before { background:radial-gradient(circle at 50% 0%, rgba(99,102,241,.2), transparent 70%); }
.btn-icon--menu:hover {
  color:#a5b4fc;
  background:rgba(99,102,241,.2);
  border-color:rgba(99,102,241,.45);
  box-shadow:0 4px 14px rgba(99,102,241,.25);
}
.btn-icon--menu:hover::before { opacity:1; }

.btn-icon--danger {
  color:var(--red);
  background:var(--red-light);
  border-color:rgba(239,68,68,.24);
  box-shadow:0 2px 8px rgba(239,68,68,.1);
}
.btn-icon--danger::before { background:radial-gradient(circle at 50% 0%, rgba(239,68,68,.18), transparent 70%); }
.btn-icon--danger:hover {
  color:#fca5a5;
  background:rgba(239,68,68,.18);
  border-color:rgba(239,68,68,.42);
  box-shadow:0 4px 14px rgba(239,68,68,.24);
}
.btn-icon--danger:hover::before { opacity:1; }

.action-menu-wrap { position:relative; }
.action-menu {
  position:absolute; right:0; top:calc(100% + 4px); z-index:200;
  min-width:188px; padding:4px;
  background:var(--bg-modal); border:1px solid var(--border);
  border-radius:var(--radius-sm); box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.action-menu--fixed {
  position:fixed;
  top:auto; right:auto;
}
.action-menu-item,
.action-menu button,
.action-menu a {
  display:flex; align-items:center; gap:10px;
  width:100%; text-align:right;
  padding:9px 12px; border:none; background:transparent;
  color:var(--text); font-family:var(--font); font-size:.8125rem;
  border-radius:var(--radius-sm); cursor:pointer;
  text-decoration:none;
}
.action-menu-item .icon,
.action-menu button .icon,
.action-menu a .icon { flex-shrink:0; opacity:.88; }
.action-menu-item span { flex:1; }
.action-menu-item:hover,
.action-menu button:hover,
.action-menu a:hover { background:rgba(255,255,255,.06); }
.action-menu-item.danger,
.action-menu button.danger { color:var(--red); }
.action-menu hr { margin:4px 0; border:none; border-top:1px solid var(--border); }

/* ── Reset account modal ─────────────────────────────────────────────── */
.reset-modal-intro {
  font-size:.875rem; color:var(--text-muted);
  margin-bottom:16px; line-height:1.6;
}
.reset-modal-intro strong { color:var(--text); word-break:break-all; }
.reset-options { display:flex; flex-direction:column; gap:10px; }
.reset-option {
  display:flex; align-items:center; gap:14px;
  width:100%; padding:14px 16px;
  border:1px solid var(--border); border-radius:12px;
  background:var(--bg-input);
  color:var(--text);
  cursor:pointer; text-align:right;
  font-family:var(--font);
  appearance:none;
  transition:border-color .15s, background .15s, transform .1s, color .15s;
}
.reset-option:hover {
  border-color:rgba(99,102,241,.45);
  background:rgba(99,102,241,.08);
  color:var(--text);
}
.reset-option:active { transform:scale(.98); }
.reset-option-icon {
  width:42px; height:42px; flex-shrink:0;
  border-radius:11px;
  display:flex; align-items:center; justify-content:center;
}
.reset-option-icon--traffic { background:var(--blue-light); color:var(--blue); }
.reset-option-icon--expiry  { background:var(--orange-light); color:var(--orange); }
.reset-option-icon--both    { background:var(--purple-light); color:var(--purple); }
.reset-option-body { flex:1; min-width:0; color:inherit; }
.reset-option-body strong {
  display:block;
  font-size:.875rem;
  font-weight:600;
  margin-bottom:4px;
  color:var(--text);
}
.reset-option-body small {
  display:block;
  font-size:.75rem;
  color:#a8b0cc;
  line-height:1.45;
}
.reset-option:hover .reset-option-body small { color:var(--text-muted); }
.form-check { display:flex; align-items:center; gap:8px; }
.form-check input { width:16px; height:16px; accent-color:var(--primary); }
.readonly-field {
  padding:10px 12px; background:rgba(255,255,255,.04);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  font-family:var(--font-mono); font-size:.875rem;
}

/* ── Bulk actions bar ─────────────────────────────────────────────────── */
.bulk-bar {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding:12px 16px;
  background:var(--accent-light);
  border-bottom:1px solid var(--border);
}
.bulk-bar-count { font-size:.875rem; }
.bulk-bar-actions { display:flex; flex-wrap:wrap; gap:6px; }
.bulk-edit-intro { font-size:.875rem; color:var(--text-muted); margin-bottom:12px; }
.col-check { width:36px; text-align:center; padding-left:8px !important; padding-right:8px !important; }
.col-check input { width:15px; height:15px; accent-color:var(--accent); cursor:pointer; }
.table tbody tr.row-selected { background:rgba(99,102,241,.08); }

/* ── Settings page ───────────────────────────────────────────────────── */
.settings-grid { max-width:720px; }
.api-docs-page.settings-grid,
.page-content:has(.api-docs-page) .settings-grid { max-width:none; }
.mt-4 { margin-top:16px; }
.settings-card-body { padding:20px; }
.settings-desc { font-size:.875rem; color:var(--text-muted); margin-bottom:20px; }
.settings-form { display:flex; flex-direction:column; gap:14px; }
.settings-form .btn { align-self:flex-start; margin-top:4px; }

.card-header--split {
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
}

.api-docs-links {
  display:flex; flex-wrap:wrap; gap:8px;
  margin-bottom:16px;
}

.api-keys-table-wrap { overflow-x:auto; }
.api-keys-table { font-size:.8125rem; margin-top:8px; }
.api-keys-actions { display:flex; gap:6px; justify-content:flex-end; white-space:nowrap; }

.api-key-reveal-box {
  display:flex; align-items:center; gap:10px;
  padding:14px 16px;
  background:var(--bg-input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  margin-top:12px;
}
.api-key-reveal-box code {
  flex:1; word-break:break-all;
  font-size:.8rem; color:#a5b4fc;
  background:transparent; padding:0;
}

/* ── API docs (Swagger) ──────────────────────────────────────────────── */
.api-docs-page { max-width:100%; }
.api-docs-toolbar { margin-bottom:16px; }
.api-docs-toolbar-inner {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  flex-wrap:wrap; padding:16px 20px;
}
.api-docs-actions { display:flex; flex-wrap:wrap; gap:8px; }
.swagger-wrap {
  background:#fff;
  border-radius:var(--radius);
  border:1px solid var(--border);
  overflow:hidden;
  min-height:480px;
}
.swagger-wrap .swagger-ui { font-family:var(--font); }

/* ── Stats sync bar ──────────────────────────────────────────────────── */
.stats-sync-bar {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
  padding:10px 14px; margin-bottom:12px;
  background:rgba(99,102,241,.08);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:.8125rem;
}
.stats-sync-text { color:var(--text-muted); }
.d-block { display:block; }

/* ── Search bar ──────────────────────────────────────────────────────── */
.search-bar { max-width:400px; }
.mb-4 { margin-bottom:16px; }

/* ── Empty state ─────────────────────────────────────────────────────── */
.empty-state {
  padding:60px 24px;
  text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  color:var(--text-muted);
}
.empty-state h3 { font-size:1.1rem; color:var(--text); }
.empty-state p  { font-size:.875rem; }

/* ── Modal ───────────────────────────────────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0; z-index:200;
  background:rgba(0,0,0,.65);
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(4px);
  opacity:0; visibility:hidden;
  transition:opacity var(--transition), visibility var(--transition);
  padding:16px;
}
.modal-overlay.open { opacity:1; visibility:visible; }
.modal-box {
  background:var(--bg-modal);
  border:1px solid var(--border);
  border-radius:var(--radius);
  width:100%; max-width:600px;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:var(--shadow);
  transform:translateY(-12px);
  transition:transform var(--transition);
}
.modal-overlay.open .modal-box { transform:translateY(0); }
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid var(--border);
  position:sticky; top:0; background:var(--bg-modal); z-index:1;
}
.modal-header h3 { font-size:.95rem; font-weight:600; }
.modal-close {
  background:none; border:none; cursor:pointer;
  color:var(--text-muted); padding:4px;
  border-radius:var(--radius-sm);
  display:flex; align-items:center;
  transition:color var(--transition), background var(--transition);
}
.modal-close:hover { color:var(--text); background:var(--bg-hover); }
.modal-body { padding:20px; }
.modal-footer {
  display:flex; justify-content:flex-end; gap:8px;
  margin-top:20px; padding-top:16px;
  border-top:1px solid var(--border);
}

/* ── Toast ───────────────────────────────────────────────────────────── */
.toast-container {
  position:fixed; bottom:24px; left:24px;
  display:flex; flex-direction:column; gap:8px;
  z-index:999; max-width:360px;
}
.toast {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px;
  border-radius:var(--radius-sm);
  font-size:.875rem;
  box-shadow:var(--shadow);
  animation:slideUp .2s ease;
  backdrop-filter:blur(8px);
  border:1px solid transparent;
}
@keyframes slideUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.toast--success { background:#16261e; border-color:rgba(34,197,94,.3); color:#86efac; }
.toast--danger  { background:#261616; border-color:rgba(239,68,68,.3);  color:#fca5a5; }
.toast--info    { background:#162036; border-color:rgba(59,130,246,.3); color:#93c5fd; }
.toast--warning { background:#261e10; border-color:rgba(245,158,11,.3); color:#fcd34d; }
.toast svg { flex-shrink:0; }
.toast-close { margin-right:auto; background:none; border:none; cursor:pointer; color:inherit; opacity:.7; }

/* ── Login page ──────────────────────────────────────────────────────── */
.login-body {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: #0c0f1a;
  overflow: hidden;
}

.login-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 90% 60% at 50% -15%, rgba(99,102,241,.32), transparent 55%),
    radial-gradient(ellipse 55% 45% at 100% 100%, rgba(59,130,246,.14), transparent 50%),
    radial-gradient(ellipse 40% 35% at 0% 80%, rgba(168,85,247,.1), transparent 45%),
    #0c0f1a;
}

.login-wrapper {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 420px;
  padding: 20px 16px;
}

.login-card {
  background: linear-gradient(165deg, rgba(26,29,46,.95) 0%, rgba(20,23,38,.98) 100%);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 36px 32px 32px;
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(12px);
}

.login-card--locked {
  border-color: rgba(239,68,68,.25);
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 0 1px rgba(239,68,68,.08),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.login-header {
  text-align: center;
  margin-bottom: 28px;
}

.login-logo-ring {
  width: 64px;
  height: 64px;
  margin: 0 auto 18px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, rgba(99,102,241,.35), rgba(79,70,229,.15));
  border: 1px solid rgba(129,140,248,.3);
  box-shadow: 0 8px 28px rgba(99,102,241,.22);
}

.login-card--locked .login-logo-ring {
  background: linear-gradient(145deg, rgba(239,68,68,.25), rgba(185,28,28,.12));
  border-color: rgba(248,113,113,.3);
  box-shadow: 0 8px 28px rgba(239,68,68,.15);
}

.login-logo-icon {
  width: 28px;
  height: 28px;
  color: #c7d2fe;
}

.login-card--locked .login-logo-icon {
  color: #fca5a5;
}

.login-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: -.01em;
}

.login-subtitle {
  font-size: .875rem;
  color: var(--text-muted);
  margin: 0;
}

.login-lock-timer {
  font-size: .9375rem;
  font-weight: 600;
  color: #fca5a5;
  margin: 0;
}

.login-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 12px;
  font-size: .8125rem;
  line-height: 1.55;
  margin-bottom: 20px;
}

.login-alert svg {
  flex-shrink: 0;
  margin-top: 1px;
}

.login-alert--danger {
  background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.28);
  color: #fecaca;
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.login-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.login-label {
  font-size: .8125rem;
  font-weight: 600;
  color: var(--text-muted);
}

.login-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.login-input-icon {
  position: absolute;
  right: 14px;
  display: flex;
  color: var(--text-dim);
  pointer-events: none;
}

.login-input-icon svg {
  width: 17px;
  height: 17px;
}

.login-input {
  width: 100%;
  padding: 13px 44px 13px 44px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  background: rgba(15,18,30,.7);
  color: var(--text);
  font-family: var(--font);
  font-size: .9375rem;
  outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
}

.login-input::placeholder {
  color: var(--text-dim);
}

.login-input:focus {
  border-color: rgba(99,102,241,.55);
  background: rgba(15,18,30,.95);
  box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}

.login-toggle-pwd {
  position: absolute;
  left: 10px;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: color .15s, background .15s;
}

.login-toggle-pwd:hover {
  color: var(--text);
  background: rgba(255,255,255,.06);
}

.login-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 4px;
  padding: 14px 20px;
  border: none;
  border-radius: 12px;
  background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
  color: #fff;
  font-family: var(--font);
  font-size: .9375rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(99,102,241,.35);
  transition: transform .15s, box-shadow .15s, opacity .15s;
}

.login-submit:hover {
  box-shadow: 0 10px 28px rgba(99,102,241,.45);
}

.login-submit:active {
  transform: scale(.98);
}

.login-submit svg {
  transform: scaleX(-1);
}

@media (max-width: 400px) {
  .login-card { padding: 28px 22px 24px; }
}

/* ── RR Info box ─────────────────────────────────────────────────────── */
.rr-info-box {
  display:flex; align-items:flex-start; gap:10px;
  background:var(--blue-light);
  border:1px solid rgba(59,130,246,.3);
  border-radius:var(--radius-sm);
  padding:10px 14px;
  font-size:.82rem; color:#93c5fd;
  margin-bottom:16px;
}
.rr-info-box svg { flex-shrink:0; margin-top:2px; }
.rr-info-box ul {
  margin:0; padding:0 16px 0 0;
  list-style:disc;
  line-height:1.55;
}
.rr-info-box li { margin:0; }
.rr-info-box li + li { margin-top:2px; }

/* ── Servers preview ─────────────────────────────────────────────────── */
.servers-preview { border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; }
.servers-preview-title {
  font-size:.78rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; color:var(--text-muted);
  padding:8px 12px; background:var(--bg-input);
  border-bottom:1px solid var(--border);
}
.srv-preview-row {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px;
  font-size:.82rem;
  border-bottom:1px solid var(--border);
}
.srv-preview-row:last-child { border-bottom:none; }
.srv-preview-row > span:first-child { flex:1; font-weight:500; }
.srv-full { opacity:.55; }
.srv-candidate { background:rgba(99,102,241,.08); }

/* ── Detail grid ─────────────────────────────────────────────────────── */
.detail-grid { display:flex; flex-direction:column; gap:10px; }
.detail-item { display:flex; flex-direction:column; gap:3px; }
.detail-label { font-size:.75rem; color:var(--text-muted); font-weight:600; text-transform:uppercase; }
.detail-item code { word-break:break-all; }

/* ── Link item ───────────────────────────────────────────────────────── */
.link-item {
  display:flex; align-items:flex-start; gap:8px;
  background:var(--bg-input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:8px 10px; margin-top:6px;
}
.link-item code { flex:1; word-break:break-all; font-size:.78rem; }
.link-item button {
  background:var(--accent-light); border:none; color:var(--accent);
  border-radius:4px; padding:3px 8px; font-size:.75rem;
  font-family:var(--font); cursor:pointer; white-space:nowrap;
  flex-shrink:0;
}

/* ── Spinner ─────────────────────────────────────────────────────────── */
.spinner {
  display:inline-block;
  width:12px; height:12px;
  border:2px solid currentColor;
  border-top-color:transparent;
  border-radius:50%;
  animation:spin .6s linear infinite;
  vertical-align:middle;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Inbound multi-select ─────────────────────────────────────────────── */
.inbound-label-row {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:6px;
}
.inbound-check-list {
  display:flex; flex-direction:column; gap:6px;
  max-height:200px; overflow-y:auto;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:8px;
  background:var(--bg-input);
}
.inbound-check-item {
  display:flex; align-items:center; gap:10px;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  cursor:pointer;
  transition:background var(--transition), border-color var(--transition);
  user-select:none;
}
.inbound-check-item:hover { background:var(--bg-hover); }
.inbound-check-item.checked { border-color:var(--accent); background:var(--accent-light); }
.inbound-check-item input[type=checkbox] { accent-color:var(--accent); width:15px; height:15px; cursor:pointer; }
.inbound-check-info { display:flex; align-items:center; gap:8px; flex:1; }
.inbound-check-badge {
  font-size:.7rem; font-weight:700; text-transform:uppercase;
  padding:1px 6px; border-radius:4px;
  background:var(--blue-light); color:var(--blue);
}
.inbound-check-name { font-size:.85rem; font-weight:500; }
.inbound-check-port { font-size:.78rem; color:var(--text-muted); font-family:monospace; }
.inbound-check-id   { font-size:.75rem; color:var(--text-dim); margin-right:auto; }

/* ── Account result modal ─────────────────────────────────────────────── */
.result-header {
  display:flex; align-items:flex-start; gap:14px;
  padding:4px 0 18px;
  border-bottom:1px solid var(--border);
  margin-bottom:18px;
}
.result-success-icon {
  width:36px; height:36px; border-radius:50%;
  background:var(--green-light); color:var(--green);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; font-weight:700; flex-shrink:0;
}
.result-title { font-size:1rem; font-weight:700; margin-bottom:6px; }
.result-meta  { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }

.link-result-section-title {
  display:flex; align-items:center; gap:7px;
  font-size:.78rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; color:var(--text-muted);
  margin-bottom:10px;
}

.link-result-list { display:flex; flex-direction:column; gap:10px; }

.link-result-card {
  display:flex; gap:14px; align-items:flex-start;
  background:var(--bg-input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:12px;
  transition:border-color var(--transition);
}
.link-result-card:hover { border-color:var(--border-focus); }
.link-result-card--sub {
  border-color:rgba(99,102,241,.4);
  background:var(--accent-light);
  margin-bottom:20px;
}

.link-result-qr {
  flex-shrink:0;
  width:220px; min-height:220px;
  background:#ffffff;
  border-radius:4px;
  padding:10px;
  display:flex; align-items:center; justify-content:center;
  /* NEVER clip QR — corner finders must stay intact for scanning */
  overflow:visible;
  box-sizing:border-box;
}
.qr-img {
  display:block;
  width:200px;
  height:200px;
  image-rendering:pixelated;
  image-rendering:crisp-edges;
  /* no border-radius on the QR image itself */
}
.qr-error { font-size:.7rem; color:var(--text-dim); text-align:center; padding:4px; }

.link-result-body { flex:1; min-width:0; display:flex; flex-direction:column; gap:8px; }

.link-proto-badge {
  display:inline-flex; align-items:center;
  padding:2px 10px; border-radius:20px;
  font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  width:fit-content;
}
.link-proto-badge--sub     { background:var(--accent-light); color:var(--accent); }
.link-proto-badge--vless   { background:var(--blue-light);   color:var(--blue); }
.link-proto-badge--vmess   { background:var(--purple-light); color:var(--purple); }
.link-proto-badge--trojan  { background:var(--orange-light); color:var(--orange); }
.link-proto-badge--ss      { background:var(--green-light);  color:var(--green); }
.link-proto-badge--hy2,
.link-proto-badge--hy      { background:rgba(251,146,60,.12); color:#fb923c; }
.link-proto-badge--other   { background:rgba(255,255,255,.08); color:var(--text-muted); }

.link-url-text {
  font-family:'Courier New',monospace;
  font-size:.75rem;
  color:var(--text-muted);
  word-break:break-all;
  line-height:1.5;
}
.link-url-truncate {
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.link-actions { display:flex; gap:6px; flex-wrap:wrap; margin-top:2px; }
/* ── Account detail modal ───────────────────────────────────────────── */
.acc-detail-info {
  display:flex; flex-direction:column;
  background:var(--bg-input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  overflow:hidden;
  margin-bottom:4px;
}
.acc-detail-row {
  display:flex; align-items:center;
  padding:9px 14px;
  gap:14px;
  border-bottom:1px solid var(--border);
}
.acc-detail-row:last-child { border-bottom:none; }
.acc-detail-label {
  font-size:.75rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.04em;
  color:var(--text-muted);
  min-width:70px; flex-shrink:0;
}
.code-copyable {
  font-family:'Courier New',monospace;
  font-size:.8rem;
  background:var(--bg-card);
  padding:2px 8px; border-radius:4px;
  color:#a5b4fc;
  cursor:pointer;
  word-break:break-all;
  transition:background var(--transition);
  border:1px solid transparent;
}
.code-copyable:hover { background:var(--accent-light); border-color:var(--accent); }
.section-divider { height:1px; background:var(--border); margin:16px 0; }
.loading-row { display:flex; align-items:center; gap:10px; padding:14px 0; color:var(--text-muted); font-size:.875rem; }
.qr-fallback {
  width:200px; height:200px;
  background:var(--bg-input);
  border:1px dashed var(--border);
  border-radius:8px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; cursor:pointer;
  color:var(--text-muted); font-size:.72rem; text-align:center; padding:8px;
  transition:background var(--transition), border-color var(--transition);
}
.qr-fallback:hover { background:var(--bg-hover); border-color:var(--accent); color:var(--accent); }
.qr-fallback-hint  { font-size:.68rem; color:var(--text-dim); }

.stat-cell { min-width:115px; vertical-align:middle; }
.stat-loading { display:flex; align-items:center; }
.stat-loading .spinner { width:14px; height:14px; border-width:2px; }
.stat-value { font-size:.84rem; font-weight:600; line-height:1.4; }
.stat-value.badge { display:inline-block; font-weight:600; padding:3px 8px; }
.stat-progress { margin-top:6px; max-width:130px; }

.conn-badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.82rem; font-weight:600;
}
.conn-dot {
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
}
.conn-badge--online .conn-dot {
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.25);
  animation:conn-pulse 2s ease-in-out infinite;
}
.conn-badge--online { color:#4ade80; }
.conn-badge--offline .conn-dot { background:#6b7280; }
.conn-badge--offline { color:var(--text-muted); }
.conn-badge--disabled .conn-dot { background:#ef4444; }
.conn-badge--disabled { color:#f87171; }
@keyframes conn-pulse {
  0%, 100% { box-shadow:0 0 0 3px rgba(34,197,94,.25); }
  50%       { box-shadow:0 0 0 6px rgba(34,197,94,.1); }
}

.d-flex      { display:flex; }
.align-center { align-items:center; }
.gap-2       { gap:8px; }
.text-muted  { color:var(--text-muted); }
.text-mono   { font-family:'Courier New',monospace; font-size:.82rem; }
.fw-600      { font-weight:600; }
.mt-3        { margin-top:12px; }
.mt-2        { margin-top:8px; }
.d-none      { display:none; }

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  :root { --sidebar-w: 220px; }
  .sidebar { transform:translateX(var(--sidebar-w)); }
  .sidebar.open { transform:translateX(0); }
  .main-wrapper { margin-right:0 !important; }
  .sidebar-toggle { display:flex; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .form-grid { grid-template-columns:1fr; }
  .form-group.span-2 { grid-column:span 1; }
  .page-content { padding:16px; }
  .topbar { padding:0 16px; }
  .modal-box { max-width:100%; }
}
@media (max-width: 480px) {
  .stats-grid { grid-template-columns:1fr; }
}
