/* Dream Dashboard - integrated multi-page design system
   Palette pulled from DreamServer's extensions/services/dashboard/src/index.css */

/* ── Theme tokens ─────────────────────────────────────── */

:root, :root[data-theme="dream"] {
  --theme-bg:           rgb(15 15 19);
  --theme-card:         rgb(24 24 27);
  --theme-card-2:       rgb(28 28 32);
  --theme-border:       rgb(39 39 42);
  --theme-text:         rgb(228 228 231);
  --theme-text-2:       rgb(161 161 170);
  --theme-text-muted:   rgb(113 113 122);

  --accent:        rgb(157 0 255);
  --accent-hover:  rgb(137 0 223);
  --accent-light:  rgb(215 164 255);
  --accent-soft:   rgba(157, 0, 255, 0.11);
  --accent-glow:   rgba(157, 0, 255, 0.20);

  --up:        #10b981;  --up-soft:        rgba(16, 185, 129, 0.12);
  --degraded:  #f59e0b;  --degraded-soft:  rgba(245, 158, 11, 0.12);
  --down:      #ef4444;  --down-soft:      rgba(239, 68, 68, 0.12);

  --shell-base:        #050507;
  --shell-grid:        rgba(255, 255, 255, 0.028);
  --shell-accent:      rgba(157, 0, 255, 0.11);
  --shell-accent-soft: rgba(215, 164, 255, 0.08);

  --sidebar-bg:     linear-gradient(180deg, #1a1722 0%, #17131f 58%, #110f17 100%);
  --sidebar-bg-glow:radial-gradient(circle at top left, rgba(157, 0, 255, 0.20), transparent 28%);
  --sidebar-border: rgba(157, 0, 255, 0.16);
  --sidebar-text:   rgba(226, 223, 255, 0.82);
  --sidebar-text-2: rgba(226, 223, 255, 0.62);
}

:root[data-theme="lemonade"] {
  --theme-bg:           rgb(240 232 207);
  --theme-card:         rgb(253 251 243);
  --theme-card-2:       rgb(248 240 220);
  --theme-border:       rgb(228 218 187);
  --theme-text:         rgb(38 38 38);
  --theme-text-2:       rgb(107 102 92);
  --theme-text-muted:   rgb(138 132 120);
  --accent:        rgb(245 197 24);
  --accent-hover:  rgb(226 178 15);
  --accent-light:  rgb(242 222 136);
  --accent-soft:   rgba(245, 197, 24, 0.15);
  --accent-glow:   rgba(245, 197, 24, 0.30);
  --shell-base: #f5edd0;
  --shell-grid: rgba(0, 0, 0, 0.025);
  --shell-accent: rgba(245, 197, 24, 0.12);
  --shell-accent-soft: rgba(242, 222, 136, 0.10);
  --sidebar-bg:     linear-gradient(180deg, #f6efd9 0%, #f0e6c2 100%);
  --sidebar-bg-glow:radial-gradient(circle at top left, rgba(245, 197, 24, 0.18), transparent 28%);
  --sidebar-border: rgba(245, 197, 24, 0.30);
  --sidebar-text:   rgb(60 50 30);
  --sidebar-text-2: rgb(120 110 90);
}

:root[data-theme="light"] {
  --theme-bg:           rgb(248 250 252);
  --theme-card:         rgb(255 255 255);
  --theme-card-2:       rgb(241 245 249);
  --theme-border:       rgb(226 232 240);
  --theme-text:         rgb(15 23 42);
  --theme-text-2:       rgb(71 85 105);
  --theme-text-muted:   rgb(148 163 184);
  --shell-base: #f1f5f9;
  --shell-grid: rgba(0, 0, 0, 0.025);
  --sidebar-bg:     #ffffff;
  --sidebar-bg-glow:radial-gradient(circle at top left, rgba(157, 0, 255, 0.06), transparent 28%);
  --sidebar-border: rgb(226 232 240);
  --sidebar-text:   rgb(30 41 59);
  --sidebar-text-2: rgb(100 116 139);
}

/* ── Base ─────────────────────────────────────────────── */

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--shell-base);
  color: var(--theme-text);
  font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, sans-serif;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(circle at 0% 0%, var(--shell-accent), transparent 35%),
    radial-gradient(circle at 100% 100%, var(--shell-accent-soft), transparent 40%),
    radial-gradient(var(--shell-grid) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 24px 24px;
}

a { color: var(--accent-light); text-decoration: none; }
a:hover { color: var(--accent); }
code { background: var(--theme-card-2); padding: 1px 6px; border-radius: 5px; font-size: 12px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: var(--accent-light); }
label { color: var(--theme-text-muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.7px; font-weight: 600; }
value { color: var(--theme-text); font-weight: 600; }

/* ── Layout ───────────────────────────────────────────── */

.app { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; position: relative; z-index: 1; }

/* ── Sidebar ──────────────────────────────────────────── */

.sidebar {
  background: var(--sidebar-bg-glow), var(--sidebar-bg);
  border-right: 1px solid var(--sidebar-border);
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.04);
  position: sticky; top: 0; height: 100vh;
  display: flex; flex-direction: column;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  padding: 20px 18px;
  border-bottom: 1px solid var(--sidebar-border);
}
.brand-logo {
  width: 38px; height: 38px; border-radius: 10px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
  display: grid; place-items: center;
  font: bold 14px/1 ui-monospace, monospace; color: #fff;
  box-shadow: 0 4px 14px var(--accent-glow), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.brand-text { flex: 1; min-width: 0; }
.brand-text h1 { margin: 0; font-size: 15px; font-weight: 700; color: var(--theme-text); letter-spacing: -0.01em; }
.brand-text p { margin: 1px 0 0; font-size: 11px; color: var(--sidebar-text-2); font-family: ui-monospace, monospace; }

.nav { padding: 14px 10px; display: flex; flex-direction: column; gap: 2px; flex: 1; overflow-y: auto; }
.nav-label {
  text-transform: uppercase; letter-spacing: 1px;
  font-size: 10px; font-weight: 600; color: rgba(220, 204, 255, 0.5);
  padding: 12px 10px 6px;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 8px;
  color: var(--sidebar-text);
  font-size: 13px; font-weight: 500; cursor: pointer;
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
}
.nav-item:hover { background: rgba(255, 255, 255, 0.04); color: var(--theme-text); text-decoration: none; }
.nav-item.active {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
  color: #fff;
  box-shadow: 0 6px 18px rgba(126, 34, 206, 0.30), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.nav-item .ni-icon { font-size: 16px; width: 18px; text-align: center; }
.nav-item .ni-arrow { margin-left: auto; opacity: 0.5; }
.nav-item.ext { color: var(--sidebar-text-2); }

.sidebar-foot {
  padding: 14px 18px; border-top: 1px solid var(--sidebar-border);
  font-size: 11px; color: var(--sidebar-text-2);
}
.foot-actions { display: flex; gap: 8px; align-items: center; }
.theme-toggle, .link-btn {
  background: rgba(255, 255, 255, 0.04); color: var(--sidebar-text);
  border: 1px solid var(--sidebar-border); border-radius: 6px;
  padding: 6px 10px; font-size: 12px; cursor: pointer;
  text-decoration: none; display: inline-flex; align-items: center; gap: 4px;
}
.theme-toggle:hover, .link-btn:hover { background: rgba(255, 255, 255, 0.08); color: var(--theme-text); }

/* ── Main + page-head ─────────────────────────────────── */

.main { padding: 28px 32px 40px; min-width: 0; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 24px; gap: 24px; flex-wrap: wrap; }
.page-title h2 { margin: 0; font-size: 24px; font-weight: 700; color: var(--theme-text); letter-spacing: -0.02em; }
.page-title p { margin: 4px 0 0; color: var(--theme-text-2); font-size: 13px; }
.live-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--up); margin-right: 6px; box-shadow: 0 0 8px var(--up); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

.head-stats { display: flex; gap: 10px; flex-wrap: wrap; }
.stat-pill {
  background: var(--theme-card); border: 1px solid var(--theme-border);
  border-radius: 10px; padding: 10px 14px; min-width: 88px; text-align: left;
}
.stat-pill label { display: block; }
.stat-pill value { display: block; margin-top: 2px; font-size: 15px; font-weight: 700; font-family: ui-monospace, monospace; }
.stat-pill.up       { border-color: rgba(16, 185, 129, 0.35); background: var(--up-soft); }       .stat-pill.up value       { color: var(--up); }
.stat-pill.down     { border-color: rgba(239, 68, 68, 0.35); background: var(--down-soft); }      .stat-pill.down value     { color: var(--down); }
.stat-pill.degraded { border-color: rgba(245, 158, 11, 0.35); background: var(--degraded-soft); } .stat-pill.degraded value { color: var(--degraded); }

.section-search { display: flex; gap: 12px; margin-bottom: 20px; align-items: center; flex-wrap: wrap; }
.search-box, .select {
  background: var(--theme-card); border: 1px solid var(--theme-border);
  border-radius: 9px; padding: 8px 12px; color: var(--theme-text); font-size: 13px;
  font-family: inherit;
}
.search-box { padding-left: 36px; min-width: 260px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>");
  background-repeat: no-repeat; background-position: 12px center;
}
.search-box:focus, .select:focus { outline: 2px solid var(--accent); outline-offset: 1px; }
.refresh-info {
  margin-left: auto; font-size: 11px; color: var(--theme-text-muted);
  display: flex; align-items: center; gap: 6px;
}
.refresh-info::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent-light); box-shadow: 0 0 6px var(--accent-light); animation: pulse 2s ease-in-out infinite; }

/* ── Groups + cards (services page) ───────────────────── */

.group { margin-bottom: 24px; }
.group-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; padding: 0 4px; }
.group-icon { width: 30px; height: 30px; border-radius: 8px; background: var(--accent-soft); border: 1px solid rgba(157, 0, 255, 0.20); display: grid; place-items: center; font-size: 15px; }
.group-head h3 { margin: 0; font-size: 15px; font-weight: 600; color: var(--theme-text); }
.g-counts { margin-left: auto; display: flex; gap: 6px; }
.g-counts span { font-size: 11px; padding: 2px 8px; border-radius: 999px; font-family: ui-monospace, monospace; }
.g-up { background: var(--up-soft); color: var(--up); }
.g-down { background: var(--down-soft); color: var(--down); }
.g-degraded { background: var(--degraded-soft); color: var(--degraded); }

.cards { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }
.card {
  background: var(--theme-card); border: 1px solid var(--theme-border);
  border-radius: 12px; padding: 14px 16px; position: relative; overflow: hidden;
  transition: border-color 0.2s, transform 0.15s, box-shadow 0.2s;
  display: flex; flex-direction: column; gap: 8px;
}
.card::before {
  content: ""; position: absolute; left: 0; top: 12%; bottom: 12%;
  width: 2px; border-radius: 2px; background: var(--theme-border);
  transition: background 0.2s, box-shadow 0.2s;
}
.card:hover { border-color: rgba(157, 0, 255, 0.40); transform: translateY(-1px); box-shadow: 0 10px 30px rgba(0,0,0,0.30), 0 0 0 1px rgba(157, 0, 255, 0.15); }
.card:hover::before { background: var(--accent); box-shadow: 0 0 12px var(--accent-glow); }
.card-top { display: flex; align-items: center; gap: 10px; }
.svc-status-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--theme-text-muted); flex-shrink: 0; box-shadow: 0 0 0 3px rgba(255,255,255,0.04); }
.svc-name { flex: 1; font-size: 14px; font-weight: 600; letter-spacing: -0.01em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.svc-port { font-size: 11px; color: var(--accent-light); font-family: ui-monospace, monospace; background: var(--accent-soft); padding: 2px 7px; border-radius: 5px; }
.svc-desc { font-size: 12px; color: var(--theme-text-2); line-height: 1.4; min-height: 32px; }
.svc-meta { display: flex; align-items: center; gap: 10px; font-size: 11px; color: var(--theme-text-muted); font-family: ui-monospace, monospace; padding-top: 6px; border-top: 1px solid var(--theme-border); }
.svc-kind { text-transform: uppercase; letter-spacing: 1px; font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 4px; background: rgba(255,255,255,0.04); }
.svc-detail { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.svc-actions { display: flex; gap: 6px; margin-top: 4px; flex-wrap: wrap; }

.btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px; font-size: 11px; font-weight: 600; border-radius: 6px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
  color: #fff; border: none; cursor: pointer; text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.15), 0 2px 6px rgba(126,34,206,0.25);
  transition: transform 0.1s, box-shadow 0.2s;
}
.btn:hover { transform: translateY(-1px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.15), 0 4px 12px rgba(126,34,206,0.40); color: #fff; text-decoration: none; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.btn-ghost { background: transparent; color: var(--theme-text-2); border: 1px solid var(--theme-border); box-shadow: none; }
.btn-ghost:hover { background: rgba(255,255,255,0.04); color: var(--theme-text); border-color: var(--theme-text-2); box-shadow: none; }

.card.status-up .svc-status-dot { background: var(--up); box-shadow: 0 0 0 3px var(--up-soft); animation: dot-pulse 2s ease-in-out infinite; }
.card.status-up::before { background: linear-gradient(180deg, var(--up), transparent); }
.card.status-degraded .svc-status-dot { background: var(--degraded); box-shadow: 0 0 0 3px var(--degraded-soft); }
.card.status-degraded { border-color: rgba(245,158,11,0.30); }
.card.status-down .svc-status-dot, .card.status-missing .svc-status-dot { background: var(--down); box-shadow: 0 0 0 3px var(--down-soft); }
.card.status-down, .card.status-missing { border-color: rgba(239,68,68,0.35); }
.card.status-down::before, .card.status-missing::before { background: var(--down); }
@keyframes dot-pulse { 0%, 100% { box-shadow: 0 0 0 3px var(--up-soft); } 50% { box-shadow: 0 0 0 5px rgba(16,185,129,0.06); } }
.card[data-hidden="true"] { display: none; }
.group[data-empty="true"] { display: none; }

/* ── Logins table (services page) ─────────────────────── */

.logins-section { margin-top: 36px; background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 20px; }
.logins-section h2 { margin: 0 0 16px; font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.logins-section table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.logins-section th { text-align: left; padding: 10px 12px; color: var(--theme-text-muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--theme-border); }
.logins-section td { padding: 10px 12px; border-bottom: 1px solid var(--theme-border); color: var(--theme-text-2); }
.logins-section tr:last-child td { border-bottom: none; }
.logins-section td strong { color: var(--theme-text); font-weight: 600; }

footer { margin-top: 40px; padding: 20px 0; color: var(--theme-text-muted); font-size: 11px; text-align: center; border-top: 1px solid var(--theme-border); }

/* ── Overview page ────────────────────────────────────── */

.kpi-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); margin-bottom: 28px; }
.kpi-card { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 16px; }
.kpi-card header { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.kpi-card header h3 { margin: 0; font-size: 14px; font-weight: 700; flex: 1; }
.kc-icon { font-size: 18px; }
.kc-link { color: var(--theme-text-muted); padding: 4px 8px; border-radius: 5px; background: var(--theme-card-2); font-size: 12px; }
.kc-link:hover { color: var(--accent); }
.kpi-rows { display: grid; gap: 6px; }
.kpi-rows > div { display: flex; justify-content: space-between; align-items: center; gap: 8px; font-size: 12px; }
.kpi-rows label { font-size: 11px; }
.kpi-rows value { font-size: 12px; font-family: ui-monospace, monospace; }
.kpi-empty { color: var(--down); padding: 12px; background: var(--down-soft); border-radius: 6px; font-size: 12px; }
.mem-bar { margin-top: 10px; height: 6px; border-radius: 3px; background: rgba(255,255,255,0.05); overflow: hidden; }
.mem-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent) 0%, var(--accent-light) 100%); box-shadow: 0 0 10px var(--accent-glow); transition: width 0.4s ease; }

.quick-actions { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 20px; }
.quick-actions h3 { margin: 0 0 12px; font-size: 15px; }
.quick-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.quick-link { display: block; padding: 12px 14px; background: var(--theme-card-2); border: 1px solid var(--theme-border); border-radius: 8px; color: var(--theme-text); font-weight: 500; transition: all 0.15s; }
.quick-link:hover { border-color: var(--accent); background: var(--accent-soft); color: var(--theme-text); text-decoration: none; transform: translateY(-1px); }

/* ── Logs page ────────────────────────────────────────── */

.logs-toolbar { display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; align-items: center; }
.logs-toolbar .search-box { min-width: 180px; }
.log-pane {
  background: #0a0a0d; border: 1px solid var(--theme-border); border-radius: 10px;
  padding: 14px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px; height: calc(100vh - 240px); overflow: auto; white-space: pre-wrap; word-break: break-all;
}
.log-line { padding: 1px 0; }
.log-err { color: #fca5a5; }
.log-warn { color: #fcd34d; }
.log-info { color: #93c5fd; }

/* ── Metrics page ─────────────────────────────────────── */

.charts-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(420px, 1fr)); margin-bottom: 28px; }
.chart-card { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 14px; }
.chart-card h3 { margin: 0 0 10px; font-size: 13px; font-weight: 600; color: var(--theme-text-2); }
.chart-card canvas { width: 100% !important; height: 200px !important; }
.sparklines { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 18px; }
.sparklines h3 { margin: 0 0 14px; font-size: 14px; }
.spark-grid { display: grid; gap: 8px; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.spark-card { background: var(--theme-card-2); border: 1px solid var(--theme-border); border-radius: 6px; padding: 8px; }
.spark-label { font-size: 11px; color: var(--theme-text-2); margin-bottom: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.spark-card canvas { width: 100% !important; height: 32px !important; }

/* ── Databases page ───────────────────────────────────── */

.db-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); }
.db-card { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 18px; }
.db-card header { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.db-card header h3 { margin: 0; flex: 1; font-size: 15px; }
.db-size { font-family: ui-monospace, monospace; font-size: 12px; color: var(--accent-light); background: var(--accent-soft); padding: 3px 8px; border-radius: 6px; }
.db-meta { display: flex; gap: 14px; margin-bottom: 12px; font-size: 12px; color: var(--theme-text-2); }
.db-tables { width: 100%; border-collapse: collapse; font-size: 12px; }
.db-tables th { text-align: left; padding: 6px 8px; color: var(--theme-text-muted); font-size: 10px; text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--theme-border); }
.db-tables td { padding: 6px 8px; border-bottom: 1px solid var(--theme-border); }
.db-tables td:nth-child(2) { font-family: ui-monospace, monospace; color: var(--accent-light); text-align: right; }
.db-tables td:nth-child(3) { font-family: ui-monospace, monospace; color: var(--theme-text-2); text-align: right; }

/* ── Security page ────────────────────────────────────── */

.sec-grid { display: grid; gap: 18px; grid-template-columns: repeat(2, 1fr); }
.sec-grid .sec-wide { grid-column: 1 / -1; }
.sec-card { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 18px; }
.sec-card header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.sec-card header h3 { margin: 0; font-size: 14px; }
.sec-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.sec-table th { text-align: left; padding: 8px; color: var(--theme-text-muted); font-size: 11px; text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--theme-border); }
.sec-table td { padding: 8px; border-bottom: 1px solid var(--theme-border); }
.sec-table tr:hover td { background: rgba(255,255,255,0.02); }
.sec-table .dim { color: var(--theme-text-muted); }
.cert-badge { padding: 2px 8px; border-radius: 999px; font-family: ui-monospace, monospace; font-size: 11px; }
.cert-ok       .cert-badge, .cert-badge.cert-ok       { background: var(--up-soft); color: var(--up); }
.cert-warn     .cert-badge, .cert-badge.cert-warn     { background: var(--degraded-soft); color: var(--degraded); }
.cert-critical .cert-badge, .cert-badge.cert-critical { background: var(--down-soft); color: var(--down); }
.f2b-jail { padding: 10px 0; border-bottom: 1px solid var(--theme-border); }
.f2b-jail:last-child { border-bottom: none; }
.f2b-stats { display: flex; gap: 18px; margin-top: 6px; font-size: 12px; }
.f2b-stats label { font-size: 10px; }
.f2b-ips { margin-top: 6px; font-size: 11px; }
.f2b-ips code { margin-right: 4px; }

@media (max-width: 900px) {
  .sec-grid { grid-template-columns: 1fr; }
  .sec-grid .sec-wide { grid-column: auto; }
}

/* ── Topology page ────────────────────────────────────── */

.topology-wrap { display: grid; grid-template-columns: 1fr 280px; gap: 16px; }
#topology { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; height: 75vh; width: 100%; }
.topo-node { cursor: grab; }
.topo-node:active { cursor: grabbing; }
.topo-node text { font-family: -apple-system, sans-serif; pointer-events: none; }
.topo-side { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; padding: 16px; font-size: 13px; }
.topo-side h3 { margin: 0 0 8px; font-size: 14px; }
.topo-side h4 { margin: 12px 0 4px; font-size: 12px; color: var(--theme-text-muted); text-transform: uppercase; letter-spacing: 1px; }
.topo-side ul { margin: 0; padding-left: 18px; font-size: 12px; color: var(--theme-text-2); }
.topo-side p { margin: 4px 0; color: var(--theme-text-2); }
.topo-status.status-up { color: var(--up); }
.topo-status.status-down { color: var(--down); }
.topo-status.status-degraded { color: var(--degraded); }
.topo-hint { color: var(--theme-text-muted); }

@media (max-width: 900px) {
  .topology-wrap { grid-template-columns: 1fr; }
  #topology { height: 50vh; }
}

/* ── Assistant page ───────────────────────────────────── */

.chat-wrap { display: flex; flex-direction: column; gap: 14px; height: calc(100vh - 200px); }
.chat-log { flex: 1; overflow-y: auto; padding: 14px; background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 12px; }
.msg { padding: 12px 16px; border-radius: 10px; margin-bottom: 10px; max-width: 85%; }
.msg.user { background: var(--accent-soft); border: 1px solid rgba(157,0,255,0.30); margin-left: auto; }
.msg.assistant { background: var(--theme-card-2); border: 1px solid var(--theme-border); }
.msg-role { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--theme-text-muted); margin-bottom: 4px; }
.msg-body { font-size: 13.5px; line-height: 1.55; white-space: pre-wrap; word-break: break-word; }
.msg-body em { color: var(--accent-light); }
.msg-body ul { margin: 4px 0; padding-left: 18px; }
.chat-input { display: flex; gap: 10px; }
.chat-input textarea {
  flex: 1; background: var(--theme-card); border: 1px solid var(--theme-border);
  border-radius: 9px; padding: 12px 14px; color: var(--theme-text);
  font: 13px inherit; resize: vertical; min-height: 60px;
}
.chat-input textarea:focus { outline: 2px solid var(--accent); outline-offset: 1px; }

/* ── Login page ───────────────────────────────────────── */

.login-wrap { display: grid; place-items: center; min-height: 60vh; }
.login-card { background: var(--theme-card); border: 1px solid var(--theme-border); border-radius: 14px; padding: 32px; min-width: 320px; max-width: 420px; }
.login-card h2 { margin: 0 0 14px; }
.login-form { display: flex; gap: 8px; margin-top: 16px; }
.login-form .search-box { flex: 1; }

/* ── Responsive ───────────────────────────────────────── */

@media (max-width: 920px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .nav { flex-direction: row; overflow-x: auto; padding: 10px; }
  .nav-label { display: none; }
  .nav-item .ni-badge, .nav-item.ext .ni-arrow { display: none; }
  .sidebar-foot { display: none; }
  .page-head { flex-direction: column; align-items: stretch; }
  .head-stats { flex-wrap: wrap; }
  .main { padding: 18px; }
  .search-box { width: 100%; min-width: 0; }
  .kpi-grid, .charts-grid, .db-grid { grid-template-columns: 1fr; }
}
