/* ── Variables ────────────────────────────────────────────────────────────── */
:root {
  --sidebar-w:  220px;
  --topbar-h:   56px;
  --bg:         #12151a;
  --bg-card:    #1a1e26;
  --bg-card2:   #1e2330;
  --border:     #2a3040;
  --border2:    #333d50;
  --cyan:       #00c9b0;
  --cyan-dim:   rgba(0,201,176,0.10);
  --green:      #28d980;
  --green-dim:  rgba(40,217,128,0.10);
  --amber:      #f0a020;
  --amber-dim:  rgba(240,160,32,0.10);
  --red:        #e05060;
  --red-dim:    rgba(224,80,96,0.10);
  --blue:       #4a9ef0;
  --blue-dim:   rgba(74,158,240,0.10);
  --purple:     #9a78f0;
  --purple-dim: rgba(154,120,240,0.10);
  --text:       #c0ccd8;
  --text-dim:   #566070;
  --text-bright:#e8edf2;
  --mono:       'SF Mono','Fira Code','Consolas',monospace;
}

/* ── Reset ────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  height: 100%;
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 14px;
}

/* ── Global form elements ──────────────────────────────────────────────── */
input, select, textarea {
  background: var(--bg-card2);
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--text-bright);
  font-size: 13px;
  padding: 7px 10px;
  outline: none;
  font-family: inherit;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 0 2px var(--cyan-dim);
}
input::placeholder, textarea::placeholder { color: var(--text-dim); }


/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-w);
  background: var(--bg-card);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  z-index: 100;
}

.sidebar-brand {
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  padding: 0 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.sidebar-brand img { height: 28px; width: auto; }

.sidebar-nav { padding: 16px 0; overflow-y: auto; }

.sidebar-nav ul,
.sidebar-nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-section-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-dim);
  padding: 8px 20px 4px;
}

.nav-section-title + .nav-section-title,
.sidebar-nav > *:not(:first-child) .nav-section-title { margin-top: 8px; }

.sidebar-nav .nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 20px;
  color: var(--text-dim);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.15s;
}

.sidebar-nav .nav-link:hover {
  color: var(--text-bright);
  background: rgba(255,255,255,0.04);
}

.sidebar-nav .nav-link.active {
  color: var(--cyan);
  background: var(--cyan-dim);
  border-left: 2px solid var(--cyan);
  padding-left: 18px;
}

.sidebar-nav .nav-link i { font-size: 15px; }

.sidebar-footer {
  margin-top: auto;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-dim);
  padding: 0 4px;
}

.sidebar-user i { font-size: 15px; }

.sidebar-logout {
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  padding: 7px 10px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-dim);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}

.sidebar-logout:hover {
  background: rgba(248,81,73,0.08);
  border-color: rgba(248,81,73,0.3);
  color: #f85149;
}

/* ── Topbar ───────────────────────────────────────────────────────────────── */
.topbar {
  position: fixed;
  top: 0;
  left: var(--sidebar-w);
  right: 0;
  height: var(--topbar-h);
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  z-index: 99;
}

.topbar-left  { flex: 1; display: flex; align-items: center; gap: 12px; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.topbar-title { font-size: 13px; font-weight: 600; color: var(--text-bright); }

/* ── Env badge ────────────────────────────────────────────────────────────── */
.env-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 20px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.env-badge.sandbox    { background: var(--amber-dim); border: 1px solid rgba(240,160,32,0.3); color: var(--amber); }
.env-badge.production { background: var(--green-dim); border: 1px solid rgba(40,217,128,0.3); color: var(--green); }

/* ── Live dot ─────────────────────────────────────────────────────────────── */
.live-dot   { width: 7px; height: 7px; border-radius: 50%; background: var(--green); animation: blink 1.4s infinite; flex-shrink: 0; }
.live-label { font-size: 11px; font-weight: 600; color: var(--green); display: flex; align-items: center; gap: 5px; }

/* ── Main content ─────────────────────────────────────────────────────────── */
.main-content { margin-left: var(--sidebar-w); padding-top: var(--topbar-h); min-height: 100vh; }
.content-inner { padding: 24px; }

/* ── Page header ──────────────────────────────────────────────────────────── */
.page-header   { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; }
.page-title    { font-size: 22px; font-weight: 700; color: var(--text-bright); margin: 0 0 4px; }
.page-subtitle { font-size: 13px; color: var(--text-dim); margin: 0 0 24px; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.tool-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 20px;
  overflow: hidden;
}

/* Accent stripe on left + space-between so right-side actions slot in naturally */
.card-header-bar {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  font-weight: 700;
  color: var(--text-bright);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
}

.card-header-bar::before {
  content: '';
  width: 3px;
  height: 14px;
  background: var(--cyan);
  border-radius: 2px;
  flex-shrink: 0;
}

.card-body-pad { padding: 20px; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn-primary-sm {
  padding: 8px 16px;
  background: linear-gradient(135deg, var(--cyan), var(--blue));
  border: none;
  border-radius: 6px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}
.btn-primary-sm:hover    { opacity: 0.85; }
.btn-primary-sm:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-outline {
  padding: 7px 14px;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--text);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn-outline:hover    { border-color: var(--cyan); color: var(--cyan); background: var(--cyan-dim); }
.btn-outline:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-danger-sm {
  padding: 7px 14px;
  background: var(--red-dim);
  border: 1px solid rgba(224,80,96,0.3);
  border-radius: 6px;
  color: var(--red);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn-danger-sm:hover    { background: rgba(224,80,96,0.18); }
.btn-danger-sm:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Notice box ───────────────────────────────────────────────────────────── */
.notice {
  padding: 12px 14px;
  background: var(--amber-dim);
  border: 1px solid rgba(240,160,32,0.25);
  border-radius: 6px;
  color: var(--amber);
  font-size: 12px;
  display: flex;
  align-items: flex-start;
  gap: 9px;
  margin-bottom: 20px;
}
.notice i { margin-top: 1px; flex-shrink: 0; }

/* ── Toast ────────────────────────────────────────────────────────────────── */
.toast-wrap {
  position: fixed;
  bottom: 20px; right: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.toast-item {
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  animation: slide-in 0.2s ease;
}
.toast-item.ok  { background: var(--bg-card); border: 1px solid var(--green); color: var(--green); }
.toast-item.err { background: var(--bg-card); border: 1px solid var(--red);   color: var(--red); }
.toast-item.inf { background: var(--bg-card); border: 1px solid var(--cyan);  color: var(--cyan); }

/* ── Utilities ────────────────────────────────────────────────────────────── */
.mono { font-family: var(--mono); }

/* ── Animations ───────────────────────────────────────────────────────────── */
@keyframes blink    { 0%,100%{opacity:1} 50%{opacity:0.25} }
@keyframes pulse    { 0%,100%{opacity:1} 50%{opacity:0.55} }
@keyframes slide-in { from{transform:translateX(12px);opacity:0} to{transform:translateX(0);opacity:1} }

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

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .sidebar        { display: none; }
  .main-content   { margin-left: 0; }
  .topbar         { left: 0; }
  .dash-footer    { margin-left: 0; }
}

/* ── Login page ───────────────────────────────────────────────────────────── */
.login-body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.login-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 40px;
  width: 100%;
  max-width: 400px;
}

.login-brand {
  display: flex;
  justify-content: center;
  margin-bottom: 32px;
}

.login-brand img {
  height: 36px;
  width: auto;
}

.login-field { margin-bottom: 16px; }

.login-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  margin-bottom: 6px;
}

.login-field input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 10px 14px;
  color: var(--text);
  font-size: 14px;
  outline: none;
  transition: border-color 0.15s;
}

.login-field input:focus { border-color: var(--cyan); }

.login-field input.totp-input {
  font-family: var(--mono);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 8px;
  text-align: center;
}

.login-btn {
  width: 100%;
  padding: 11px;
  background: var(--cyan);
  border: none;
  border-radius: 7px;
  color: #0d1117;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 8px;
  transition: opacity 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.login-btn:hover { opacity: 0.88; }
.login-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.login-error {
  background: rgba(248,81,73,0.1);
  border: 1px solid rgba(248,81,73,0.3);
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--red);
  margin-bottom: 16px;
  display: none;
}

.login-back {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--text-dim);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  margin-bottom: 20px;
}

.login-back:hover { color: var(--cyan); }

.login-totp-hint {
  font-size: 11px;
  color: var(--text-dim);
  text-align: center;
  margin-top: 12px;
  line-height: 1.5;
}

.login-setup-notice {
  display: none;
  align-items: flex-start;
  gap: 12px;
  background: rgba(251,191,36,0.08);
  border: 1px solid rgba(251,191,36,0.25);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 20px;
  font-size: 12px;
  line-height: 1.6;
  color: rgba(255,255,255,0.8);
}

.login-setup-notice i {
  color: #fbbf24;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

.login-step { display: none; }
.login-step.active { display: block; }

/* ── Swap Monitor (index.html) ───────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:12px; margin-bottom:20px; }
.stat-card  { background:var(--bg-card); border:1px solid var(--border); border-radius:8px; padding:16px 16px 14px; }
.stat-card-label { font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-dim); margin-bottom:8px; }
.stat-card-value { font-size:24px; font-weight:700; color:var(--text-bright); line-height:1; }
.stat-card-sub   { font-size:11px; color:var(--text-dim); margin-top:4px; }
.v-danger { color:var(--red); } .v-info { color:var(--cyan); } .v-amber { color:var(--amber); }
.flow-strip { display:flex; align-items:flex-start; gap:0; padding:16px 20px; overflow-x:auto; }
.flow-node  { display:flex; flex-direction:column; align-items:center; gap:5px; flex-shrink:0; min-width:82px; }
.flow-node-icon { width:40px; height:40px; border-radius:6px; border:1px solid var(--border2); background:var(--bg); display:flex; align-items:center; justify-content:center; font-size:15px; transition:all 0.25s; }
.flow-node-cnt  { font-size:13px; font-weight:700; color:var(--text-bright); line-height:1; }
.flow-node-lbl  { font-size:9px; font-weight:700; letter-spacing:0.8px; text-transform:uppercase; color:var(--text-dim); text-align:center; }
.flow-node.active .flow-node-icon { border-color:var(--cyan);  background:var(--cyan-dim); }
.flow-node.active .flow-node-lbl  { color:var(--cyan); }
.flow-node.done   .flow-node-icon { border-color:var(--green); background:var(--green-dim); }
.flow-node.done   .flow-node-lbl  { color:var(--green); }
.flow-node.error  .flow-node-icon { border-color:var(--red);   background:var(--red-dim); }
.flow-node.error  .flow-node-lbl  { color:var(--red); }
.flow-arrow      { flex:1; min-width:16px; height:1px; background:var(--border); align-self:flex-start; margin-top:20px; }
.flow-arrow.live { background:linear-gradient(90deg,var(--green),var(--cyan)); }
.table-card { background:var(--bg-card); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.table-wrap { overflow-x:auto; max-height:460px; overflow-y:auto; }
.table-wrap table       { width:100%; border-collapse:collapse; }
.table-wrap thead th    { position:sticky; top:0; background:var(--bg-card2); padding:10px 14px; text-align:left; font-size:10px; font-weight:700; letter-spacing:0.8px; text-transform:uppercase; color:var(--text-dim); border-bottom:1px solid var(--border); white-space:nowrap; }
.table-wrap tbody tr    { border-bottom:1px solid rgba(42,48,64,0.6); cursor:pointer; transition:background 0.1s; }
.table-wrap tbody tr:hover { background:rgba(255,255,255,0.025); }
.table-wrap tbody tr.sel   { background:rgba(0,201,176,0.04); border-left:2px solid var(--cyan); }
.table-wrap td { padding:11px 14px; font-size:12px; color:var(--text); white-space:nowrap; }
.td-hash { color:var(--blue); font-family:var(--mono); font-size:11px; max-width:130px; overflow:hidden; text-overflow:ellipsis; }
.td-amt  { color:var(--cyan);  font-weight:600; font-family:var(--mono); }
.td-out  { color:var(--green); font-weight:600; font-family:var(--mono); }
.td-fee  { color:var(--amber); font-weight:600; font-family:var(--mono); }
.td-time { font-size:11px; color:var(--text-dim); }
.td-route{ font-size:11px; color:var(--purple); font-weight:600; }
.badge-custom { display:inline-flex; align-items:center; gap:5px; padding:3px 8px; border-radius:20px; font-size:10px; font-weight:700; letter-spacing:0.3px; white-space:nowrap; }
.badge-custom::before { content:''; width:5px; height:5px; border-radius:50%; flex-shrink:0; }
.b-received  { background:var(--blue-dim);   border:1px solid rgba(74,158,240,0.25);  color:var(--blue);   } .b-received::before   { background:var(--blue); }
.b-forwarded { background:var(--purple-dim); border:1px solid rgba(154,120,240,0.25); color:var(--purple); } .b-forwarded::before  { background:var(--purple); }
.b-credited  { background:var(--cyan-dim);   border:1px solid rgba(0,201,176,0.25);   color:var(--cyan);   } .b-credited::before   { background:var(--cyan); }
.b-manual-fx { background:rgba(251,191,36,0.12); border:1px solid rgba(251,191,36,0.3); color:#fbbf24; }     .b-manual-fx::before  { background:#fbbf24; }
.b-swapped   { background:var(--amber-dim);  border:1px solid rgba(240,160,32,0.25);  color:var(--amber);  } .b-swapped::before    { background:var(--amber); }
.b-crossover { background:var(--amber-dim);  border:1px solid rgba(240,160,32,0.25);  color:var(--amber);  animation:pulse 1.5s infinite; } .b-crossover::before { background:var(--amber); }
.b-complete  { background:var(--green-dim);  border:1px solid rgba(40,217,128,0.25);  color:var(--green);  } .b-complete::before   { background:var(--green); }
.b-failed    { background:var(--red-dim);    border:1px solid rgba(224,80,96,0.25);   color:var(--red);    } .b-failed::before     { background:var(--red); }
.filters { display:flex; gap:5px; }
.f-btn { padding:4px 12px; background:transparent; border:1px solid var(--border); border-radius:20px; color:var(--text-dim); font-size:10px; font-weight:700; letter-spacing:0.5px; cursor:pointer; transition:all 0.15s; text-transform:uppercase; }
.f-btn:hover, .f-btn.active { border-color:var(--cyan); color:var(--cyan); background:var(--cyan-dim); }
.f-btn.failed-btn:hover, .f-btn.active.failed-btn { border-color:var(--red); color:var(--red); background:var(--red-dim); }
.main-grid { display:grid; grid-template-columns:1fr 300px; gap:16px; }
.left-col  { display:flex; flex-direction:column; gap:16px; min-width:0; }
.detail-panel { background:var(--bg-card); border:1px solid var(--border); border-radius:8px; position:sticky; top:calc(var(--topbar-h) + 24px); max-height:calc(100vh - var(--topbar-h) - 48px); overflow-y:auto; display:flex; flex-direction:column; }
.detail-body  { padding:14px; flex:1; display:flex; flex-direction:column; gap:10px; }
.empty-state  { display:flex; flex-direction:column; align-items:center; justify-content:center; height:200px; gap:8px; opacity:0.3; }
.empty-icon   { font-size:28px; }
.empty-text   { font-size:10px; font-weight:700; color:var(--text-dim); letter-spacing:1.5px; text-transform:uppercase; }
.detail-row { display:flex; justify-content:space-between; align-items:flex-start; padding:9px 0; border-bottom:1px solid rgba(42,48,64,0.5); gap:12px; }
.detail-row:last-child { border-bottom:none; }
.detail-label { font-size:12px; color:var(--text-dim); flex-shrink:0; }
.detail-value { font-size:12px; font-weight:600; color:var(--text-bright); text-align:right; word-break:break-all; }
.detail-value.mono  { font-family:var(--mono); font-size:10px; }
.detail-value.cyan  { color:var(--cyan); }
.detail-value.green { color:var(--green); }
.detail-value.amber { color:var(--amber); }
.d-hr { height:1px; background:var(--border); margin:2px 0; }
.d-section-title { font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-dim); margin-bottom:4px; }
.route-box  { background:var(--bg); border:1px solid var(--border2); border-radius:6px; padding:10px 14px; display:flex; align-items:center; justify-content:space-between; }
.route-side { display:flex; flex-direction:column; align-items:center; gap:2px; }
.route-chain { font-size:12px; font-weight:700; color:var(--text-bright); }
.route-asset { font-size:10px; font-weight:600; color:var(--text-dim); }
.route-arrow { color:var(--cyan); font-size:18px; }
.mini-pipe { display:flex; flex-direction:column; gap:3px; }
.mini-step { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:5px; border:1px solid transparent; font-size:11px; font-weight:600; }
.ms-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.mini-step.done   { background:var(--green-dim); border-color:rgba(40,217,128,0.15); color:var(--green); } .mini-step.done .ms-dot   { background:var(--green); }
.mini-step.active { background:var(--cyan-dim);  border-color:rgba(0,201,176,0.15);  color:var(--cyan);  animation:pulse 1.5s infinite; } .mini-step.active .ms-dot { background:var(--cyan); box-shadow:0 0 6px var(--cyan); }
.mini-step.failed { background:var(--red-dim);   border-color:rgba(224,80,96,0.15);  color:var(--red);   } .mini-step.failed .ms-dot  { background:var(--red); }
.mini-step.pending { color:var(--text-dim); } .mini-step.pending .ms-dot { background:var(--border2); }
.replay-btn { width:100%; padding:10px; background:var(--red-dim); border:1px solid rgba(224,80,96,0.35); border-radius:6px; color:var(--red); font-size:11px; font-weight:700; letter-spacing:0.5px; cursor:pointer; text-transform:uppercase; transition:all 0.2s; display:flex; align-items:center; justify-content:center; gap:7px; }
.replay-btn:hover { background:rgba(224,80,96,0.18); }
.resume-fx-btn { width:100%; padding:10px; background:rgba(251,191,36,0.12); border:1px solid rgba(251,191,36,0.35); border-radius:6px; color:#fbbf24; font-size:11px; font-weight:700; letter-spacing:0.5px; cursor:pointer; text-transform:uppercase; transition:all 0.2s; display:flex; align-items:center; justify-content:center; gap:7px; margin-top:8px; }
.resume-fx-btn:hover { background:rgba(251,191,36,0.2); }
.manual-fx-banner { display:flex; gap:12px; padding:14px; background:rgba(251,191,36,0.07); border:1px solid rgba(251,191,36,0.25); border-radius:8px; margin-bottom:4px; }
.mfx-icon { font-size:20px; line-height:1; flex-shrink:0; }
.mfx-title { font-size:12px; font-weight:700; color:#fbbf24; margin-bottom:5px; }
.mfx-text  { font-size:11px; color:rgba(255,255,255,0.7); line-height:1.6; }
.mfx-link  { font-size:11px; color:var(--cyan); text-decoration:none; display:inline-flex; align-items:center; gap:4px; margin-top:6px; }
.mfx-link:hover { text-decoration:underline; }
.dash-footer { margin-left:var(--sidebar-w); text-align:center; padding:16px; font-size:11px; color:var(--text-dim); border-top:1px solid var(--border); background:var(--bg-card); }
@media (max-width:1200px) { .stats-grid { grid-template-columns:repeat(4,1fr); } }
@media (max-width:1024px) { .main-grid { grid-template-columns:1fr; } .detail-panel { position:static; max-height:none; } .stats-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:768px)  { .stats-grid { grid-template-columns:repeat(2,1fr); } .dash-footer { margin-left:0; } }

/* ── Circle Account (circle.html) ────────────────────────────────────────── */
.balances-row { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:4px; }
.balance-pill { background:var(--bg); border:1px solid var(--border2); border-radius:8px; padding:14px 20px; min-width:140px; }
.bp-currency { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-dim); margin-bottom:4px; }
.bp-amount   { font-size:26px; font-weight:700; font-family:var(--mono); color:var(--text-bright); }
.bp-eur .bp-amount { color:var(--cyan); }
.bp-usd .bp-amount { color:var(--blue); }
.addr-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:12px; }
.addr-card { background:var(--bg); border:1px solid var(--border2); border-radius:8px; padding:14px; }
.addr-chain  { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-dim); margin-bottom:6px; display:flex; align-items:center; justify-content:space-between; }
.addr-address{ font-family:var(--mono); font-size:11px; color:var(--blue); word-break:break-all; margin-bottom:4px; }
.addr-id     { font-size:10px; color:var(--text-dim); margin-bottom:6px; }
.addr-label  { font-size:10px; font-weight:700; padding:2px 7px; border-radius:3px; display:inline-block; }
.addr-label.configured { background:var(--cyan-dim); color:var(--cyan); border:1px solid rgba(0,201,176,0.2); }
.addr-label.other      { background:var(--bg-card2); color:var(--text-dim); border:1px solid var(--border2); }
.status-dot { width:7px; height:7px; border-radius:50%; }
.status-dot.active { background:var(--green); }
.status-dot.pending{ background:var(--amber); }
.status-dot.other  { background:var(--text-dim); }
.xfers-table { width:100%; border-collapse:collapse; }
.xfers-table th { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-dim); padding:8px 12px; border-bottom:1px solid var(--border); text-align:left; }
.xfers-table td { padding:10px 12px; border-bottom:1px solid var(--border); font-size:12px; vertical-align:middle; }
.xfers-table tr:last-child td { border-bottom:none; }
.xfer-status { display:inline-flex; align-items:center; gap:5px; font-size:10px; font-weight:700; padding:3px 8px; border-radius:20px; text-transform:uppercase; }
.xfer-status.complete { background:var(--green-dim); color:var(--green); }
.xfer-status.pending  { background:var(--amber-dim); color:var(--amber); }
.xfer-status.failed   { background:var(--red-dim);   color:var(--red); }
.xfer-dir { font-size:10px; font-weight:700; padding:2px 7px; border-radius:3px; text-transform:uppercase; }
.xfer-dir.inbound  { background:var(--cyan-dim); color:var(--cyan); }
.xfer-dir.outbound { background:var(--blue-dim); color:var(--blue); }
.da-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.da-card { background:var(--bg); border:1px solid var(--border2); border-radius:8px; padding:16px; }
.da-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-dim); margin-bottom:12px; display:flex; align-items:center; gap:7px; }
.da-row { display:flex; gap:8px; align-items:center; }
.da-select { background:var(--bg-card2); border:1px solid var(--border2); border-radius:5px; color:var(--text-bright); font-size:12px; padding:6px 10px; outline:none; cursor:pointer; }
.da-select:focus { border-color:var(--cyan); }
.da-btn { padding:6px 14px; background:var(--cyan-dim); border:1px solid rgba(0,201,176,0.25); border-radius:5px; color:var(--cyan); font-size:11px; font-weight:700; cursor:pointer; transition:all 0.15s; white-space:nowrap; }
.da-btn:hover { background:rgba(0,201,176,0.18); }
.da-btn:disabled { opacity:0.45; cursor:not-allowed; }
.da-result { margin-top:12px; background:var(--bg-card2); border:1px solid var(--border); border-radius:6px; padding:10px 12px; display:none; }
.da-result-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-dim); margin-bottom:6px; }
.da-result-addr { font-family:var(--mono); font-size:11px; color:var(--cyan); word-break:break-all; margin-bottom:8px; }
.da-copy { padding:4px 10px; background:transparent; border:1px solid var(--border2); border-radius:4px; color:var(--text-dim); font-size:10px; font-weight:700; cursor:pointer; transition:all 0.15s; }
.da-copy:hover { border-color:var(--cyan); color:var(--cyan); }
.da-notice { font-size:11px; color:var(--amber); margin-top:8px; line-height:1.5; display:flex; gap:6px; }
@media(max-width:600px){ .da-grid{ grid-template-columns:1fr; } }

/* ── Test Swaps (test.html) ──────────────────────────────────────────────── */
/* content-inner is full-width on all pages */
.route-display { display:flex; align-items:flex-start; gap:12px; padding:16px; background:var(--bg); border:1px solid var(--border2); border-radius:8px; margin-bottom:20px; }
.route-arrow-mid { color:var(--cyan); font-size:22px; flex-shrink:0; padding-top:22px; }
.amount-row { display:flex; align-items:flex-end; gap:10px; margin-bottom:20px; flex-wrap:wrap; }
.amount-row > div:first-child { flex:1; min-width:120px; }
.quick-btns { display:flex; gap:6px; flex-wrap:wrap; padding-bottom:1px; }
.q-btn { padding:8px 14px; background:var(--bg); border:1px solid var(--border2); border-radius:5px; color:var(--text-dim); font-size:12px; font-weight:700; cursor:pointer; transition:all 0.15s; }
.q-btn:hover { border-color:var(--cyan); color:var(--cyan); background:var(--cyan-dim); }
.btn-trigger { width:100%; padding:14px; background:linear-gradient(135deg,var(--cyan),var(--blue)); border:none; border-radius:8px; color:#fff; font-size:15px; font-weight:700; cursor:pointer; transition:opacity 0.15s; display:flex; align-items:center; justify-content:center; gap:10px; }
.btn-trigger:hover { opacity:0.88; }
.btn-trigger:disabled { opacity:0.4; cursor:not-allowed; }
.btn-clear { padding:10px 20px; background:var(--red-dim); border:1px solid rgba(224,80,96,0.3); border-radius:6px; color:var(--red); font-size:12px; font-weight:700; cursor:pointer; transition:all 0.15s; display:flex; align-items:center; gap:7px; }
.btn-clear:hover { background:rgba(224,80,96,0.18); }
.tracker { background:var(--bg); border:1px solid var(--border2); border-radius:8px; padding:14px; margin-top:16px; display:none; }
.tracker.visible { display:block; }
.tracker-title { font-size:11px; font-weight:700; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.8px; margin-bottom:12px; display:flex; align-items:center; gap:7px; }
.pipe-steps { display:flex; flex-direction:column; gap:4px; }
.pipe-step  { display:flex; align-items:center; gap:10px; padding:7px 10px; border-radius:5px; border:1px solid transparent; font-size:12px; font-weight:600; }
.ps-icon { width:22px; text-align:center; font-size:13px; flex-shrink:0; }
.ps-label { flex:1; }
.ps-badge { font-size:10px; opacity:0.7; }
.pipe-step.done   { background:var(--green-dim); border-color:rgba(40,217,128,0.15); color:var(--green); }
.pipe-step.active { background:var(--cyan-dim);  border-color:rgba(0,201,176,0.2);   color:var(--cyan); animation:pulse 1.5s infinite; }
.pipe-step.pending { color:var(--text-dim); }
.pipe-step.failed { background:var(--red-dim); border-color:rgba(224,80,96,0.2); color:var(--red); }
.tracker-hash { font-family:var(--mono); font-size:10px; color:var(--blue); margin-top:10px; word-break:break-all; }
.tracker-done-banner { margin-top:12px; padding:10px 14px; background:var(--green-dim); border:1px solid rgba(40,217,128,0.25); border-radius:6px; color:var(--green); font-size:12px; font-weight:700; display:flex; align-items:center; gap:8px; }
.tracker-fail-banner { margin-top:12px; padding:10px 14px; background:var(--red-dim);   border:1px solid rgba(224,80,96,0.25);   border-radius:6px; color:var(--red);   font-size:12px; font-weight:700; display:flex; align-items:center; gap:8px; }

/* ── Trustlines (trustlines.html) ────────────────────────────────────────── */
.wallet-row { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border); gap:12px; flex-wrap:wrap; }
.wallet-row:last-child { border-bottom:none; }
.wallet-label { font-size:13px; font-weight:600; color:var(--text-bright); }
.wallet-addr  { font-family:var(--mono); font-size:10px; color:var(--text-dim); margin-top:2px; }
.chips { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.chip { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; border-radius:20px; font-size:11px; font-weight:700; }
.chip-ok      { background:var(--green-dim); color:var(--green); border:1px solid rgba(40,217,128,0.25); }
.chip-missing { background:var(--red-dim);   color:var(--red);   border:1px solid rgba(224,80,96,0.25); }
.chip-skip    { background:var(--bg-card2);  color:var(--text-dim); border:1px solid var(--border2); }
.bal-tag { font-family:var(--mono); font-size:11px; color:var(--text-dim); }
.result-box { margin-top:16px; background:var(--bg); border:1px solid var(--border2); border-radius:6px; padding:14px; display:none; }
.result-box.visible { display:block; }
.result-row { display:flex; align-items:flex-start; gap:10px; padding:7px 0; border-bottom:1px solid var(--border); font-size:12px; }
.result-row:last-child { border-bottom:none; }
.result-wallet { font-weight:700; color:var(--text-bright); flex:1; }
.result-msg    { color:var(--text-dim); }

/* ── Webhook (webhook.html) ──────────────────────────────────────────────── */
.sub-row { display:flex; align-items:stretch; gap:10px; padding:12px; background:var(--bg); border:1px solid var(--border2); border-radius:6px; margin-bottom:8px; }
.sub-row:last-child { margin-bottom:0; }
.sub-accent { width:4px; flex-shrink:0; border-radius:2px; }
.sub-accent.active  { background:var(--green); }
.sub-accent.pending { background:var(--amber); }
.sub-accent.other   { background:var(--text-dim); }
.sub-endpoint { font-family:var(--mono); font-size:11px; color:var(--blue); word-break:break-all; }
.sub-id { font-size:10px; color:var(--text-dim); margin-top:3px; }
.sub-badge { display:inline-block; font-size:10px; font-weight:700; padding:2px 7px; border-radius:3px; text-transform:uppercase; margin-top:5px; }
.sub-badge.active  { background:var(--green-dim); color:var(--green); }
.sub-badge.pending { background:var(--amber-dim); color:var(--amber); }
.result-success { color:var(--green); font-size:12px; font-weight:700; display:flex; align-items:center; gap:7px; }
.result-endpoint { font-family:var(--mono); font-size:11px; color:var(--blue); margin-top:6px; word-break:break-all; }

/* ── Users (users.html) ──────────────────────────────────────────────────── */
.user-row { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border); gap:12px; flex-wrap:wrap; }
.user-row:last-child { border-bottom:none; }
.user-email { font-size:13px; font-weight:600; color:var(--text-bright); display:flex; align-items:center; gap:8px; }
.user-meta  { font-size:11px; color:var(--text-dim); margin-top:2px; }
.user-you   { font-size:10px; font-weight:700; padding:2px 7px; border-radius:3px; background:var(--cyan-dim); color:var(--cyan); border:1px solid rgba(0,201,176,0.2); }
.user-delete-btn { padding:6px 12px; background:var(--red-dim); border:1px solid rgba(224,80,96,0.3); border-radius:5px; color:var(--red); font-size:11px; font-weight:700; cursor:pointer; transition:all 0.15s; display:flex; align-items:center; gap:6px; }
.user-delete-btn:hover { background:rgba(224,80,96,0.18); }
.user-delete-btn:disabled { opacity:0.4; cursor:not-allowed; }
.add-user-form { display:flex; flex-direction:column; gap:14px; }
.form-row { display:flex; gap:10px; flex-wrap:wrap; }
.form-row > div { flex:1; min-width:180px; }

