/* databyte VPN Portal — clean dark/light CSS
   All classes prefixed vp- to avoid collisions.
   CSS variables for theme: dark=default, light via body[data-theme=light] */

/* ─── Tokens ──────────────────────────────────────────── */
:root {
  --vp-bg:      #0E1117;
  --vp-surface: #161B22;
  --vp-s2:      #1C2330;
  --vp-border:  #2D3748;
  --vp-border2: #1E2A3A;

  --vp-cyan:    #00C9FF;
  --vp-cyan-d: #0A3A4A;
  --vp-amber:   #F59E0B;
  --vp-amber-d: #2D2008;
  --vp-red:    #EF4444;
  --vp-red-d:  #2D1010;
  --vp-green:  #22C55E;
  --vp-green-d:#0A2D1A;
  --vp-dim:    #374151;

  --vp-text:    #E2E8F0;
  --vp-text2:   #8B95A3;
  --vp-text3:   #4A5568;

  --green: #22C55E; --red: #EF4444; --amber: #F59E0B; --cyan: #00C9FF;
}

body[data-theme="light"] {
  --vp-bg:      #F7FAFC;
  --vp-surface: #FFFFFF;
  --vp-s2:      #EDF2F7;
  --vp-border:  #CBD5E0;
  --vp-border2: #E2E8F0;

  --vp-cyan:    #0077B3;
  --vp-cyan-d: #BEE3F8;
  --vp-amber:   #B45309;
  --vp-amber-d: #FEF3C7;
  --vp-red:    #C53030;
  --vp-red-d:  #FED7D7;
  --vp-green:  #276749;
  --vp-green-d:#C6F6D5;
  --vp-dim:    #E2E8F0;

  --vp-text:   #1A202C;
  --vp-text2:  #4A5568;
  --vp-text3:  #A0AEC0;

  --green: #276749; --red: #C53030; --amber: #B45309; --cyan: #0077B3;
}

/* ─── Base ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background: var(--vp-bg);
  color: var(--vp-text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.5;
}
#app { height: 100%; }

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--vp-surface); }
::-webkit-scrollbar-thumb { background: var(--vp-border); border-radius: 3px; }

/* ─── Banner (top error/ok notice) ─────────────────────── */
.vp-banner {
  position: fixed; top: 12px; left: 50%; transform: translateX(-50%);
  z-index: 500; padding: 10px 18px; border-radius: 8px;
  font-size: 13px; font-weight: 500; max-width: 80vw;
  border: 1px solid; box-shadow: 0 4px 16px rgba(0,0,0,0.35);
  display: none; pointer-events: none;
}
.vp-banner-err { background: var(--vp-red-d); color: var(--red); border-color: var(--red); }
.vp-banner-ok  { background: var(--vp-green-d); color: var(--green); border-color: var(--green); }

/* ─── Layout ───────────────────────────────────────────── */
.vp-app  { display: flex; flex-direction: column; min-height: 100vh; }
.vp-main { flex: 1; padding: 24px; max-width: 1200px; margin: 0 auto; width: 100%; }
.vp-page { /* nothing extra needed */ }
.vp-page-head { margin-bottom: 20px; }
.vp-page-title { font-size: 18px; font-weight: 600; }
.vp-page-sub   { font-size: 13px; color: var(--vp-text2); margin-top: 3px; }

/* ─── Nav ──────────────────────────────────────────────── */
.vp-nav {
  display: flex; align-items: center; gap: 8px;
  padding: 0 20px; height: 50px;
  background: var(--vp-surface); border-bottom: 1px solid var(--vp-border);
  position: sticky; top: 0; z-index: 100;
}
.vp-nav-logo {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 13px; font-weight: 600; color: var(--cyan);
  letter-spacing: 0.06em; margin-right: 4px;
}
.vp-nav-sep { width: 1px; height: 18px; background: var(--vp-border); margin: 0 4px; }
.vp-nav-tab {
  font-size: 13px; color: var(--vp-text2);
  background: none; border: none; cursor: pointer;
  padding: 4px 10px; border-radius: 6px;
  font-family: inherit; transition: color .15s, background .15s;
}
.vp-nav-tab:hover { background: var(--vp-s2); color: var(--vp-text); }
.vp-nav-tab-on    { color: var(--cyan) !important; background: var(--vp-cyan-d) !important; }
.vp-nav-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.vp-nav-user  { font-family: ui-monospace, monospace; font-size: 12px; color: var(--vp-text2); }

/* ─── Buttons ─────────────────────────────────────────── */
.vp-btn {
  font-size: 13px; font-weight: 500; padding: 6px 14px;
  border-radius: 6px; border: 1px solid; cursor: pointer;
  font-family: inherit; transition: opacity .15s;
  display: inline-flex; align-items: center; gap: 6px;
}
.vp-btn:hover { opacity: 0.85; }
.vp-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.vp-btn-sm  { font-size: 12px; padding: 4px 10px; }
.vp-btn-primary { background: var(--vp-cyan-d); border-color: var(--cyan); color: var(--cyan); }
.vp-btn-ghost   { background: none; border-color: var(--vp-border); color: var(--vp-text2); }
.vp-btn-ghost:hover { background: var(--vp-s2); color: var(--vp-text); opacity: 1; }
.vp-btn-ok   { background: var(--vp-green-d); border-color: var(--green); color: var(--green); }
.vp-btn-warn { background: var(--vp-amber-d); border-color: var(--amber); color: var(--amber); }
.vp-btn-danger { background: var(--vp-red-d, rgba(248,81,73,0.12)); border-color: var(--red); color: var(--red); }
.vp-btn-danger:hover { background: var(--red); color: #fff; }
.vp-btn-row  { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }

/* v1.2.12 — toolbar (search + filter pills) */
.vp-toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 14px; padding: 10px; background: var(--vp-s1); border: 1px solid var(--vp-border); border-radius: 8px; }
.vp-search { background: var(--vp-s2); border: 1px solid var(--vp-border); color: var(--vp-text); padding: 7px 12px; border-radius: 6px; min-width: 220px; flex: 0 1 280px; font-size: 13px; }
.vp-search:focus { outline: none; border-color: var(--vp-accent); }
.vp-pills { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; }
.vp-pill { background: transparent; border: 1px solid var(--vp-border); color: var(--vp-dim); padding: 5px 12px; border-radius: 999px; cursor: pointer; font-size: 12px; font-weight: 500; transition: all 0.15s; }
.vp-pill:hover { border-color: var(--vp-accent); color: var(--vp-text); }
.vp-pill-active { background: var(--vp-accent); border-color: var(--vp-accent); color: #fff; }
.vp-pill-active:hover { background: var(--vp-accent); color: #fff; }
.vp-toolbar-meta { color: var(--vp-dim); font-size: 12px; margin-left: auto; }

/* v1.2.12 — archived row treatment */
.vp-tr-archived { opacity: 0.55; font-style: italic; }
.vp-tr-archived:hover { opacity: 0.8; }

/* v1.2.12 — toast */
.vp-toast { position: fixed; top: 24px; right: 24px; z-index: 9999; padding: 12px 18px; border-radius: 8px; background: var(--vp-s2); border: 1px solid var(--vp-border); color: var(--vp-text); box-shadow: 0 4px 16px rgba(0,0,0,0.4); font-size: 13px; opacity: 0; transform: translateX(20px); transition: opacity 0.2s, transform 0.2s; max-width: 360px; }
.vp-toast-ok { border-color: var(--green); }
.vp-toast-err { border-color: var(--red); }
.vp-toast-show { opacity: 1; transform: translateX(0); }

/* v1.2.13 — bulk action UI */
.vp-th-check, .vp-td-check { width: 32px; text-align: center; padding: 6px 4px; }
.vp-check { cursor: pointer; accent-color: var(--vp-accent, #4f8cff); width: 16px; height: 16px; margin: 0; }
.vp-check-disabled { color: var(--vp-dim); opacity: 0.4; font-size: 12px; }
.vp-tr-bulk { background: rgba(79, 140, 255, 0.06); }
.vp-tr-bulk:hover { background: rgba(79, 140, 255, 0.12); }
.vp-tr-sel.vp-tr-bulk { background: rgba(79, 140, 255, 0.14); }
.vp-bulk-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 14px; margin-bottom: 14px; background: var(--vp-s1); border: 1px solid var(--vp-accent, #4f8cff); border-radius: 8px; box-shadow: 0 0 0 1px rgba(79, 140, 255, 0.15); }
.vp-bulk-bar-l { display: flex; align-items: center; gap: 14px; }
.vp-bulk-bar-r { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.vp-bulk-count { font-weight: 600; color: var(--vp-accent, #4f8cff); font-size: 13px; }
.vp-bulk-tier-wrap { display: inline-flex; }
.vp-btn-link { background: none; border: none; color: var(--vp-dim); cursor: pointer; padding: 4px 8px; font-size: 12px; text-decoration: underline; }
.vp-btn-link:hover { color: var(--vp-text); }

/* v1.2.14 — sortable column headers + active-session dot */
.vp-th-sort { cursor: pointer; user-select: none; transition: color 0.12s; }
.vp-th-sort:hover { color: var(--vp-accent, #4f8cff); }
.vp-th-sort-on { color: var(--vp-accent, #4f8cff); }
.vp-td-active { text-align: center; width: 60px; }
.vp-active-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 20px;
  padding: 0 6px;
  border-radius: 10px;
  background: rgba(46, 160, 67, 0.18);
  color: var(--green, #2ea043);
  font-weight: 600;
  font-size: 11px;
  font-family: var(--vp-mono, 'JetBrains Mono', monospace);
}
.vp-active-dot::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green, #2ea043);
  margin-right: 4px;
  box-shadow: 0 0 4px var(--green, #2ea043);
}
.vp-active-dot-off { color: var(--vp-dim); opacity: 0.4; font-size: 14px; }


/* Theme toggle */
.vp-theme-btn {
  background: var(--vp-s2); border: 1px solid var(--vp-border);
  color: var(--vp-text2); width: 30px; height: 30px;
  border-radius: 6px; cursor: pointer; font-size: 15px;
  display: flex; align-items: center; justify-content: center;
}
.vp-theme-btn:hover { color: var(--vp-text); }

/* ─── Cards + grid ─────────────────────────────────────── */
.vp-card    { background: var(--vp-surface); border: 1px solid var(--vp-border); border-radius: 10px; padding: 18px 20px; margin-bottom: 14px; }
.vp-card-sm { padding: 14px 16px; }
.vp-card-title {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--vp-text2); margin-bottom: 10px;
}
.vp-row      { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; margin-bottom: 14px; }
.vp-row-2    { display: grid; grid-template-columns: 380px 1fr; gap: 18px; align-items: start; }
.vp-left-col, .vp-right-col { min-width: 0; }
.vp-metric   { font-family: ui-monospace, monospace; font-size: 26px; font-weight: 500; line-height: 1.1; color: var(--metric-color, var(--vp-text)); }
.vp-metric-label { font-size: 12px; color: var(--vp-text2); margin-top: 3px; }
.vp-metric-sub   { font-size: 11px; color: var(--vp-text3); margin-top: 2px; }
.vp-big-num  { font-family: ui-monospace, monospace; font-size: 30px; font-weight: 500; color: var(--cyan); margin: 6px 0 4px; }
.vp-note     { font-size: 12px; color: var(--vp-text2); margin-top: 10px; }
.vp-muted    { color: var(--vp-text3); font-size: 13px; }
.vp-mono     { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 12px; }

/* ─── v1.4.0 — strict-CSP utility classes ────────────────
   Inline style attributes (`el(..., {style: '...'})` or
   `el.style.x = '...'`) violate strict `style-src 'self'` CSP.
   These classes replace every prior inline-style use case.
   For dynamic values (bar width, dynamic color), CSS custom
   properties are set via the CSSOM API `el.style.setProperty()`
   which is NOT blocked by strict CSP per W3C CSP3. */
.vp-hidden   { display: none !important; }
.vp-mt-14    { margin-top: 14px; }
.vp-mt-18    { margin-top: 18px; }
.vp-mt-20    { margin-top: 20px; }
.vp-mt-12    { margin-top: 12px; }
.vp-justify-end { justify-content: flex-end; }
.vp-gap-8    { gap: 8px; }
.vp-fs-12    { font-size: 12px; }
.vp-no-pad   { padding: 0; }
.vp-link-cyan { color: var(--cyan); text-decoration: none; }
.vp-link-cyan:hover { text-decoration: underline; }

/* v1.4.0 — red error box (replaces inline `style='border-color:var(--red); color:var(--red)'` on .vp-empty) */
.vp-empty.vp-empty-err {
  border-color: var(--red);
  color: var(--red);
  margin-bottom: 14px;
}

/* v1.4.0 — offscreen textarea (clipboard fallback). Used to be inline
   `ta.style.position = 'fixed'; ta.style.opacity = '0'` which violates strict CSP. */
.vp-offscreen {
  position: fixed;
  top: 0; left: 0;
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}

/* ─── Badges ──────────────────────────────────────────── */
.vp-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 20px;
}
.vp-badge-green  { background: var(--vp-green-d); color: var(--green); }
.vp-badge-red    { background: var(--vp-red-d);   color: var(--red); }
.vp-badge-amber  { background: var(--vp-amber-d); color: var(--amber); }
.vp-badge-cyan   { background: var(--vp-cyan-d);  color: var(--cyan); }
.vp-badge-dim    { background: var(--vp-s2);      color: var(--vp-text2); }

/* ─── Progress bar ────────────────────────────────────── */
/* v1.4.0 — width is set via `--pct` CSS custom property (CSP-safe via CSSOM).
   Element gets `style="--pct: 50"` (set by `el.style.setProperty('--pct', 50)` in JS). */
.vp-bar-wrap   { background: var(--vp-s2); border-radius: 4px; height: 6px; overflow: hidden; margin: 10px 0 14px; }
.vp-bar-fill   { height: 100%; border-radius: 4px; width: var(--pct, 0%); transition: width .4s; }
.vp-bar-green   { background: var(--green); }
.vp-bar-amber   { background: var(--amber); }
.vp-bar-red     { background: var(--red); }

/* ─── Table ─────────────────────────────────────────────── */
.vp-tbl-wrap { border: 1px solid var(--vp-border); border-radius: 8px; overflow: hidden; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th {
  background: var(--vp-s2); font-weight: 500; color: var(--vp-text2);
  text-align: left; padding: 8px 13px; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
  border-bottom: 1px solid var(--vp-border);
}
td { padding: 9px 13px; border-bottom: 1px solid var(--vp-border2); vertical-align: middle; }
tr:last-child td { border-bottom: none; }
.vp-tr { cursor: pointer; }
.vp-tr:hover td { background: var(--vp-s2); }
.vp-tr-sel td   { background: var(--vp-cyan-d) !important; }

/* ─── Forms ─────────────────────────────────────────────── */
.vp-inp {
  background: var(--vp-s2); border: 1px solid var(--vp-border);
  border-radius: 6px; padding: 7px 10px;
  color: var(--vp-text); font-size: 13px; font-family: inherit;
  width: 100%; outline: none;
}
.vp-inp:focus { border-color: var(--cyan); }
.vp-inp-mono  { font-family: ui-monospace, monospace; font-size: 12px; }
.vp-field     { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.vp-label      { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--vp-text2); }
.vp-inline-form { display: flex; gap: 8px; align-items: flex-end; flex-wrap: wrap; }
.vp-inline-form .vp-inp { flex: 1; min-width: 160px; }

/* ─── kv list ──────────────────────────────────────────── */
.vp-kv { display: grid; grid-template-columns: 130px 1fr; gap: 6px 16px; font-size: 13px; }
.vp-kv dt { color: var(--vp-text2); }
.vp-kv dd { color: var(--vp-text); }

/* ─── Raw / pre ────────────────────────────────────────── */
.vp-raw {
  background: var(--vp-s2); font-family: ui-monospace, monospace;
  font-size: 12px; padding: 12px; border-radius: 6px;
  overflow-x: auto; white-space: pre-wrap; word-break: break-all;
  border: 1px solid var(--vp-border); min-height: 60px; max-height: 300px; overflow-y: auto;
  margin-top: 8px;
}

/* ─── Login ─────────────────────────────────────────────── */
.vp-login-wrap {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: var(--vp-bg); padding: 24px;
}
.vp-login-card {
  width: 340px; padding: 30px 28px;
  background: var(--vp-surface); border: 1px solid var(--vp-border);
  border-radius: 10px; box-shadow: 0 6px 32px rgba(0,0,0,0.3);
}
.vp-login-logo {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 16px; font-weight: 600; color: var(--cyan);
  letter-spacing: 0.06em; margin-bottom: 2px;
}
.vp-login-sub { font-size: 12px; color: var(--vp-text2); margin-bottom: 22px; font-family: ui-monospace, monospace; }
.vp-login-err {
  background: var(--vp-red-d); color: var(--red); border: 1px solid var(--red);
  border-radius: 6px; padding: 9px 11px; font-size: 12px;
  margin-bottom: 14px; word-break: break-word;
}

/* ─── Placeholder ─────────────────────────────────────── */
.vp-ph {
  text-align: center; color: var(--vp-text3);
  padding: 48px 24px; font-size: 13px;
}

/* ─── Skeleton (loading shimmer) ──────────────────────── */
@keyframes vp-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.vp-skel {
  display: inline-block;
  background: linear-gradient(
    90deg,
    var(--vp-s2) 0%,
    var(--vp-border2) 40%,
    var(--vp-s2) 80%
  );
  background-size: 200% 100%;
  animation: vp-shimmer 1.4s ease-in-out infinite;
  border-radius: 4px;
  color: transparent;
  user-select: none;
  /* v1.4.0 — dynamic width/height via CSS custom properties (set via CSSOM, CSP-safe).
     JS calls skel(cls, w, h) → el.style.setProperty('--skelW', w) / '--skelH', h. */
  width: var(--skelW, 100%);
  height: var(--skelH, 12px);
}
.vp-skel-line   { /* defaults already set above */ }
.vp-skel-line-sm { height: 10px; width: 60%; }
.vp-skel-num    { height: 28px; width: 70%; border-radius: 6px; }
.vp-skel-block  { height: 80px; width: 100%; border-radius: 8px; }

/* ─── Empty state ─────────────────────────────────────── */
.vp-empty {
  text-align: center; padding: 48px 24px;
  border: 1px dashed var(--vp-border);
  border-radius: 10px;
  color: var(--vp-text2);
  background: var(--vp-s2);
}
.vp-empty-icon  { font-size: 32px; opacity: 0.4; margin-bottom: 8px; }
.vp-empty-title { font-size: 14px; font-weight: 600; color: var(--vp-text); margin-bottom: 4px; }
.vp-empty-sub   { font-size: 12px; color: var(--vp-text3); }

/* ─── Inline reload spinner ──────────────────────────── */
.vp-spin {
  display: inline-block; width: 12px; height: 12px;
  border: 2px solid var(--vp-border);
  border-top-color: var(--cyan);
  border-radius: 50%;
  animation: vp-spin 0.7s linear infinite;
  vertical-align: middle;
}
@keyframes vp-spin { to { transform: rotate(360deg); } }
.vp-spinner-row {
  display: flex; align-items: center; gap: 8px;
  color: var(--vp-text3); font-size: 12px;
  padding: 10px 0;
}

/* ─── Error dump (last resort) ─────────────────────────── */
.vp-errdump {
  background: var(--vp-red-d); color: var(--red);
  font-family: ui-monospace, monospace; font-size: 12px;
  padding: 16px; white-space: pre-wrap; margin: 16px; border-radius: 8px;
}

/* ─── Responsive ───────────────────────────────────────── */
@media (max-width: 900px) { .vp-row-2 { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .vp-row { grid-template-columns: 1fr 1fr; } .vp-main { padding: 16px; } }

/* ─── Usage bar (leases table) ─────────────────────────── */
.vp-usage {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 140px; max-width: 220px;
}
.vp-usage-track {
  height: 6px; width: 100%; background: var(--vp-s2);
  border-radius: 3px; overflow: hidden;
}
/* v1.4.0 — same CSS-custom-property pattern as vp-bar-fill above.
   Width via `--pct`, color via `--bar-color` (both CSSOM-set, CSP-safe). */
.vp-usage-fill {
  height: 100%; border-radius: 3px;
  width: var(--pct, 0%);
  background: var(--bar-color, var(--green));
  transition: width 0.4s ease-out;
}
.vp-usage-text { font-size: 11px; color: var(--bar-color, var(--vp-text2)); white-space: nowrap; }
/* v1.2.7.3 — 'no cap' / 'no quota' tag next to operator usage number */
.vp-usage-tag {
  display: inline-block;
  padding: 1px 6px; border-radius: 3px;
  background: rgba(120, 140, 160, 0.18);
  color: var(--vp-text2);
  font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.04em;
}
/* v1.2.7.3 — neutral bar color for operators (no progress to show) */
.vp-bar-dim { background: var(--vp-s2); }

/* ─── Responsive: leases table on mobile ───────────────── */
@media (max-width: 600px) {
  /* Hide Identity column on phones — customer+device already in row */
  .vp-tbl-lease-hide-sm { display: none; }
}

/* ─── Comprehensive mobile-friendly pass ───────────────── */
@media (max-width: 900px) {
  .vp-row-2 { grid-template-columns: 1fr; }
  .vp-nav { padding: 8px 12px; }
  .vp-nav-logo { font-size: 14px; }
  .vp-nav-user { display: none; }  /* save space on tablets */
  .vp-page-head { flex-wrap: wrap; }
  .vp-page-title { font-size: 18px; }
}
@media (max-width: 600px) {
  .vp-row { grid-template-columns: 1fr 1fr; }
  .vp-main { padding: 12px; }
  .vp-card { padding: 14px; }
  /* Metric cards: 1 col on very narrow phones */
  .vp-row-metrics { grid-template-columns: 1fr 1fr; }
}

/* ─── Horizontal scroll for nav on phones ─────────────── */
@media (max-width: 480px) {
  .vp-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 6px 8px;
    gap: 6px;
  }
  .vp-nav-logo { display: none; }
  .vp-nav-sep { display: none; }
  .vp-nav-right { margin-left: auto; flex-shrink: 0; }
  .vp-nav-tab {
    flex-shrink: 0;
    padding: 8px 12px;
    font-size: 12px;
    white-space: nowrap;
  }
  /* Fade-out edge on the nav to hint at scrollability */
  .vp-nav-wrap {
    position: relative;
  }
  .vp-nav-wrap::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 24px;
    background: linear-gradient(to right, transparent, var(--vp-bg));
    pointer-events: none;
  }
  .vp-nav-user { display: none; }
  /* Stack form fields on narrow phones */
  .vp-inline-form {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .vp-inline-form .vp-inp { width: 100%; min-width: 0; }
  .vp-inline-form .vp-btn { width: 100%; }
  /* Make buttons touch-target sized (Apple HIG 44pt) */
  .vp-btn, .vp-btn-sm { min-height: 38px; }
  .vp-theme-btn { min-width: 38px; }
}

/* ─── Card-style tables on mobile (using data-label) ───── */
@media (max-width: 600px) {
  .vp-tbl-wrap {
    background: transparent;
    border: none;
  }
  .vp-tbl-wrap table,
  .vp-tbl-wrap thead,
  .vp-tbl-wrap tbody,
  .vp-tbl-wrap tr,
  .vp-tbl-wrap td { display: block; width: 100%; }
  .vp-tbl-wrap thead { display: none; }
  .vp-tbl-wrap tr {
    background: var(--vp-s1);
    border: 1px solid var(--vp-border);
    border-radius: 8px;
    padding: 10px 12px;
    margin-bottom: 10px;
  }
  .vp-tbl-wrap tr:last-child { margin-bottom: 0; }
  .vp-tbl-wrap td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
    border-bottom: 1px solid var(--vp-border);
    text-align: right;
  }
  .vp-tbl-wrap td:last-child { border-bottom: none; padding-bottom: 0; }
  .vp-tbl-wrap td:first-child { padding-top: 0; }
  /* Show the data-label as a small caption on the left */
  .vp-tbl-wrap td[data-label]::before {
    content: attr(data-label);
    color: var(--vp-text3);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-right: 12px;
    text-align: left;
    flex-shrink: 0;
  }
  /* Keep monospace cells intact */
  .vp-tbl-wrap td.vp-mono[data-label]::before {
    color: var(--vp-text3);
  }
  /* Make cell content wrap nicely when not monospace */
  .vp-tbl-wrap td[data-label] > * { max-width: 60%; text-align: right; }
  .vp-tbl-wrap td.vp-mono { font-size: 12px; }
}

/* ─── <pre> blocks must wrap on mobile ─────────────────── */
@media (max-width: 600px) {
  .vp-raw {
    font-size: 11px;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 200px;
  }
}

/* ─── Banner (top-of-page error) mobile padding ───────── */
@media (max-width: 600px) {
  .vp-banner { padding: 10px 12px; font-size: 12px; }
}

/* ─── Buttons in btn-row should wrap on narrow phones ─── */
@media (max-width: 480px) {
  .vp-btn-row { flex-direction: column; align-items: stretch; }
  .vp-btn-row .vp-btn { width: 100%; }
}

/* ─── LIVE badge (auto-refresh indicator) ──────────────── */
.vp-live-badge {
  display: inline-block;
  margin-left: 10px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--green);
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.3);
  border-radius: 10px;
  animation: vp-live-pulse 2s ease-in-out infinite;
}
@keyframes vp-live-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.55; }
}

/* ─── Per-row icon buttons (customer list actions) ──────── */
.vp-row-actions {
  width: 1%;
  white-space: nowrap;
  text-align: right;
}
.vp-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  padding: 0;
  font-size: 16px;
  font-weight: 700;
  background: transparent;
  border: 1px solid var(--vp-border);
  border-radius: 6px;
  color: var(--vp-text2);
  cursor: pointer;
  transition: all 0.15s ease;
}
.vp-btn-icon:hover {
  background: var(--vp-s2);
  color: var(--amber);
  border-color: var(--amber);
}
.vp-btn-icon.vp-btn-warn:hover { color: var(--amber); border-color: var(--amber); }

/* Make the actions column compact on mobile cards */
@media (max-width: 600px) {
  .vp-row-actions { text-align: right; }
  .vp-row-actions .vp-btn-icon { width: 36px; height: 36px; }
}

/* ─── Modal (device editor) ─── */
.vp-modal-bg {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  padding: 20px;
}
.vp-modal {
  background: var(--vp-s1);
  border: 1px solid var(--vp-border);
  border-radius: 10px;
  padding: 24px;
  width: 100%;
  max-width: 480px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.vp-modal-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 16px;
  color: var(--vp-text);
}
.vp-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}
.vp-field > span {
  font-size: 12px;
  color: var(--vp-text2);
  font-weight: 600;
}
.vp-field input,
.vp-field textarea {
  background: var(--vp-s2);
  border: 1px solid var(--vp-border);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: var(--vp-font);
  font-size: 13px;
  color: var(--vp-text);
}
.vp-field input:focus,
.vp-field textarea:focus {
  outline: none;
  border-color: var(--cyan);
}

/* ---------- v1.2.7 — Operator client onboarding ---------- */

.vp-page-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.vp-page-head-l { flex: 1 1 auto; }
.vp-page-head-r { flex: 0 0 auto; display: flex; gap: 8px; }
.vp-btn-primary {
  background: var(--cyan, #1f7a8c);
  color: #fff;
  border: 1px solid var(--cyan, #1f7a8c);
}
.vp-btn-primary:hover { filter: brightness(1.1); }
.vp-btn-primary:disabled { opacity: 0.5; cursor: wait; }

/* New-client modal: form */
.vp-modal-lg { max-width: 720px; width: 95vw; max-height: 92vh; overflow: auto; }
.vp-modal-x {
  background: transparent;
  border: 0;
  color: var(--vp-text2);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
}
.vp-modal-x:hover { color: var(--vp-text); }
.vp-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 14px;
  margin-top: 8px;
}
.vp-form-grid .vp-field { display: flex; flex-direction: column; gap: 4px; }
.vp-optional { font-weight: 400; color: var(--vp-text2); font-size: 11px; }
.vp-hint { font-size: 11px; color: var(--vp-text2); }
/* v1.2.7.2 — live collision warning under device name field */
.vp-field-warn {
  font-size: 11px; color: var(--red, #d04848);
  background: rgba(208, 72, 72, 0.10);
  border: 1px solid rgba(208, 72, 72, 0.35);
  border-radius: 4px; padding: 6px 8px; margin-top: 4px;
}
.vp-inp-bad { border-color: var(--red, #d04848) !important; box-shadow: 0 0 0 1px rgba(208,72,72,0.35); }
.vp-form-err {
  margin-top: 12px; padding: 8px 10px;
  background: rgba(255, 80, 80, 0.12);
  border: 1px solid var(--red, #d04848);
  border-radius: 6px; color: var(--red, #d04848);
  font-size: 12px; font-family: var(--vp-font);
}
.vp-custom-preview {
  margin-top: 10px; padding: 8px 12px;
  background: rgba(31, 122, 140, 0.10);
  border: 1px dashed var(--cyan, #1f7a8c);
  border-radius: 6px;
  font-size: 12px; color: var(--vp-text);
}

/* One-shot password panel */
.vp-oneshot-warn {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: rgba(208, 72, 72, 0.12);
  border: 1px solid var(--red, #d04848);
  border-left: 4px solid var(--red, #d04848);
  border-radius: 6px;
  margin-bottom: 14px;
  font-size: 13px;
  color: var(--red, #d04848);
}
.vp-oneshot-warn-icon { font-size: 18px; }
.vp-oneshot-summary {
  background: var(--vp-s2);
  border: 1px solid var(--vp-border);
  border-radius: 6px;
  padding: 10px 14px;
  margin-bottom: 14px;
  font-size: 12px;
}
.vp-oneshot-summary > div { margin: 2px 0; }
.vp-os-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
}
.vp-os-card {
  background: var(--vp-s2);
  border: 1px solid var(--vp-border);
  border-radius: 8px;
  overflow: hidden;
}
.vp-os-card-h {
  padding: 8px 14px;
  background: var(--vp-s1, rgba(0,0,0,0.06));
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--vp-text2);
  border-bottom: 1px solid var(--vp-border);
}
.vp-os-card-b { padding: 10px 14px; font-size: 12px; }
.vp-os-card-core { grid-column: 1 / -1; }
.vp-os-fields { display: flex; flex-direction: column; gap: 4px; }
.vp-os-field {
  display: grid;
  grid-template-columns: 200px 1fr 32px;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  border-bottom: 1px dashed var(--vp-border);
}
.vp-os-field:last-child { border-bottom: 0; }
.vp-os-field-l {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--vp-text2);
}
.vp-os-field-r { font-size: 12px; word-break: break-all; }
.vp-pw-shown { color: var(--cyan, #1f7a8c); font-weight: 600; }
.vp-setup-steps { padding-left: 18px; margin: 0; line-height: 1.7; font-size: 12px; }
.vp-setup-steps li { margin: 1px 0; }
.vp-btn-icon {
  background: transparent;
  border: 1px solid var(--vp-border);
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 14px;
  cursor: pointer;
  color: var(--vp-text2);
}
.vp-btn-icon:hover { color: var(--cyan, #1f7a8c); border-color: var(--cyan, #1f7a8c); }

/* Current session block (in customer detail) */
.vp-current-session {
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--vp-s2);
  border: 1px solid var(--vp-border);
  border-radius: 8px;
}
.vp-cs-empty {
  display: flex; align-items: center; gap: 8px;
  color: var(--vp-text2); font-size: 12px;
}
.vp-cs-on { }
.vp-cs-head {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--vp-text2); font-weight: 700;
  margin-bottom: 8px;
}
.vp-cs-dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.vp-cs-dot-off { background: var(--vp-text2); }
.vp-cs-dot-on  { background: #4ade80; box-shadow: 0 0 6px #4ade80; }
.vp-cs-label { }
.vp-cs-grid {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 4px 12px;
  font-size: 12px;
  margin: 0;
}
.vp-cs-grid dt {
  color: var(--vp-text2);
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: 0.5px;
  align-self: center;
}
.vp-cs-grid dd { margin: 0; word-break: break-all; }

@media (max-width: 700px) {
  .vp-form-grid { grid-template-columns: 1fr; }
  .vp-os-grid   { grid-template-columns: 1fr; }
  .vp-os-field  { grid-template-columns: 1fr; }
  .vp-cs-grid   { grid-template-columns: 1fr; }
}
