:root {
  --cyan: #00d9ff;
  --cyan-dim: #00d9ff66;
  --cyan-glow: #00d9ff33;
  --gold: #ffb84d;
  --red: #ff3860;
  --bg: #000814;
  --ok: #4ade80;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: radial-gradient(ellipse at center, #001428 0%, #000814 70%, #000 100%);
  color: var(--cyan);
  font-family: 'Consolas', 'Courier New', monospace;
  overflow: hidden;
  height: 100vh;
  width: 100vw;
  user-select: none;
}

.hidden { display: none !important; }

/* BOOT */
.boot {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 30px;
  background: #000;
}
.boot-text {
  font-size: 28px;
  letter-spacing: 8px;
  text-shadow: 0 0 20px var(--cyan);
  animation: flicker 2s infinite;
}
.boot-bar {
  width: 400px;
  height: 4px;
  background: #001428;
  border: 1px solid var(--cyan-dim);
}
.boot-bar-fill {
  height: 100%;
  width: 0;
  background: var(--cyan);
  box-shadow: 0 0 10px var(--cyan);
  animation: fill 3s ease-out forwards;
}
#start-btn {
  background: transparent;
  color: var(--cyan);
  border: 2px solid var(--cyan);
  padding: 14px 40px;
  font-family: inherit;
  font-size: 16px;
  letter-spacing: 6px;
  cursor: pointer;
  text-shadow: 0 0 10px var(--cyan);
  box-shadow: 0 0 20px var(--cyan-glow), inset 0 0 20px var(--cyan-glow);
  transition: all 0.3s;
  opacity: 0;
  animation: appear 1s 2.5s forwards;
}
#start-btn:hover {
  background: var(--cyan-glow);
  box-shadow: 0 0 40px var(--cyan), inset 0 0 30px var(--cyan-glow);
}

/* HUD */
.hud {
  position: fixed;
  inset: 0;
  animation: hudIn 1s ease-out;
}

#reactor {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 500px;
  height: 500px;
}

.reactor-logo-wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 180px;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 2;
}

.reactor-logo {
  width: 130px;
  height: 130px;
  object-fit: contain;
  pointer-events: none;
  mix-blend-mode: screen;
  filter:
    brightness(0.4)
    sepia(1)
    hue-rotate(160deg)
    saturate(8)
    brightness(1.4)
    drop-shadow(0 0 10px var(--cyan))
    drop-shadow(0 0 22px var(--cyan-glow));
  animation: logoPulse 4s ease-in-out infinite;
}

@keyframes logoPulse {
  0%, 100% {
    opacity: 0.85;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.04);
  }
}


.corner {
  position: absolute;
  width: 320px;
  padding: 20px;
}
.top-left    { top: 20px; left: 20px; }
.top-right   { top: 20px; right: 20px; }
.bottom-left { bottom: 20px; left: 20px; }
.bottom-right{ bottom: 20px; right: 20px; }

.panel {
  background: linear-gradient(135deg, rgba(0,217,255,0.05), rgba(0,217,255,0.02));
  border: 1px solid var(--cyan-dim);
  padding: 16px;
  position: relative;
  backdrop-filter: blur(4px);
  box-shadow: inset 0 0 30px rgba(0,217,255,0.05), 0 0 20px rgba(0,217,255,0.1);
}
.panel::before, .panel::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid var(--cyan);
}
.panel::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.panel::after  { bottom: -1px; right: -1px; border-left: none; border-top: none; }

.panel-title {
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--gold);
  margin-bottom: 12px;
  text-shadow: 0 0 8px var(--gold);
  border-bottom: 1px solid var(--cyan-dim);
  padding-bottom: 6px;
}

.row {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  padding: 4px 0;
  letter-spacing: 1px;
}
.row .ok { color: var(--ok); text-shadow: 0 0 6px var(--ok); }

.clock {
  font-size: 32px;
  text-align: center;
  letter-spacing: 4px;
  text-shadow: 0 0 12px var(--cyan);
  margin: 6px 0;
}
.date {
  font-size: 11px;
  text-align: center;
  letter-spacing: 3px;
  color: var(--cyan-dim);
  margin-bottom: 10px;
}

.bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  margin: 8px 0;
  letter-spacing: 1px;
}
.bar-row span { width: 60px; }
.bar {
  flex: 1;
  height: 6px;
  background: rgba(0,217,255,0.1);
  border: 1px solid var(--cyan-dim);
  overflow: hidden;
}
.bar-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--cyan), var(--gold));
  box-shadow: 0 0 8px var(--cyan);
  transition: width 2s ease-out;
}

.services-panel { margin-top: 12px; }
.services-list {
  font-size: 11px;
  letter-spacing: 1px;
  max-height: 200px;
  overflow-y: auto;
}
.svc-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 2px;
  border-bottom: 1px solid rgba(0,217,255,0.1);
}
.svc-name { color: #cce8ff; }
.svc-meta { font-size: 10px; color: var(--cyan-dim); }
.svc-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.svc-dot.up { background: var(--ok); box-shadow: 0 0 8px var(--ok); }
.svc-dot.down { background: var(--red); box-shadow: 0 0 8px var(--red); animation: pulse 1.5s infinite; }

.weather-panel { margin-top: 12px; }
.weather-loc {
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--cyan-dim);
  text-align: center;
  margin-bottom: 8px;
}
.weather-main {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin: 6px 0 10px;
  border-bottom: 1px solid var(--cyan-dim);
  padding-bottom: 8px;
}
.weather-temp {
  font-size: 28px;
  letter-spacing: 2px;
  color: var(--cyan);
  text-shadow: 0 0 12px var(--cyan);
}
.weather-cond {
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--gold);
  text-shadow: 0 0 6px var(--gold);
  text-align: right;
  max-width: 140px;
}
.weather-forecast {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-top: 10px;
  border-top: 1px solid var(--cyan-dim);
  padding-top: 8px;
}
.weather-fc-day {
  text-align: center;
  font-size: 10px;
  letter-spacing: 1px;
}
.weather-fc-day .fc-date { color: var(--gold); margin-bottom: 2px; }
.weather-fc-day .fc-temp { color: var(--cyan); font-size: 11px; }
.weather-fc-day .fc-cond { color: var(--cyan-dim); font-size: 9px; margin-top: 2px; }

.lxc-list {
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: 1px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}
/* bottom-left stretches up to fill gap under top-left stack — top set dynamically by JS */
.bottom-left {
  display: flex;
  flex-direction: column;
  bottom: 20px;
}
.bottom-left .panel { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.lxc-row {
  display: flex;
  justify-content: space-between;
  padding: 3px 4px;
  border-bottom: 1px solid rgba(0,217,255,0.1);
}
.lxc-row .name { color: #cce8ff; }
.lxc-row .vmid { color: var(--cyan-dim); margin-right: 6px; }
.lxc-row .stat-running { color: var(--ok); text-shadow: 0 0 6px var(--ok); }
.lxc-row .stat-stopped { color: var(--red); }
.lxc-row .meta { color: var(--cyan-dim); font-size: 10px; }

.chat-log {
  max-height: 180px;
  overflow-y: auto;
  font-size: 11px;
  letter-spacing: 0.5px;
  margin: 8px 0;
  padding: 6px;
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--cyan-dim);
}
.chat-msg { margin-bottom: 6px; line-height: 1.4; }
.chat-msg .who { color: var(--gold); font-size: 9px; letter-spacing: 2px; margin-right: 6px; }
.chat-msg.user .who { color: var(--cyan); }
.chat-msg .text { color: #cce8ff; }
.chat-msg.tool .text { color: var(--cyan-dim); font-style: italic; font-size: 10px; }

.transcript {
  font-size: 12px;
  min-height: 50px;
  padding: 10px;
  margin: 10px 0;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--cyan-dim);
  letter-spacing: 1px;
  color: #cce8ff;
}

.pending-banner {
  font-size: 11px;
  letter-spacing: 2px;
  padding: 8px 10px;
  margin-bottom: 8px;
  background: rgba(255,184,77,0.08);
  border: 1px solid var(--gold);
  color: var(--gold);
  text-shadow: 0 0 6px var(--gold);
  animation: pendingPulse 1.2s ease-in-out infinite;
}
.pending-banner .pending-action { color: var(--red); font-weight: bold; }
.pending-banner .pending-hint { font-size: 9px; color: var(--cyan-dim); letter-spacing: 1px; margin-top: 4px; }

@keyframes pendingPulse {
  0%, 100% { box-shadow: 0 0 6px rgba(255,184,77,0.4); }
  50% { box-shadow: 0 0 16px rgba(255,184,77,0.7); }
}

#mic-btn {
  width: 100%;
  background: transparent;
  color: var(--cyan);
  border: 1px solid var(--cyan);
  padding: 8px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 3px;
  cursor: pointer;
  margin-top: 6px;
}
#mic-btn:hover { background: var(--cyan-glow); }
#mic-btn.active { color: var(--red); border-color: var(--red); animation: pulse 1s infinite; }

.center-text {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-size: 14px;
  letter-spacing: 8px;
  color: var(--gold);
  text-shadow: 0 0 10px var(--gold);
}
.center-text.top { top: 40px; }
.center-text.bottom { bottom: 40px; font-size: 11px; letter-spacing: 4px; }

.scanline {
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0,217,255,0.03) 0px,
    rgba(0,217,255,0.03) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events: none;
  animation: scan 8s linear infinite;
}

/* LXC VIEW */
.view-toggle-bar {
  position: absolute;
  top: 8px;
  left: 40px;
  z-index: 10;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* global persistent top nav — visible on every view */
.global-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 6px 16px;
  background: linear-gradient(to bottom, rgba(0,15,25,0.95), rgba(0,10,18,0.85));
  border-bottom: 1px solid var(--cyan-dim);
  backdrop-filter: blur(4px);
  align-items: center;
  gap: 4px;
}
.global-nav-btn {
  background: transparent;
  box-shadow: none;
  border-color: transparent;
  color: var(--cyan-dim);
  text-shadow: none;
  padding: 4px 10px;
}
.global-nav-btn:hover {
  color: var(--cyan);
  border-color: var(--cyan-dim);
  text-shadow: 0 0 6px var(--cyan);
  box-shadow: none;
}
.global-nav-btn.active {
  color: var(--cyan);
  border-color: var(--cyan);
  background: var(--cyan-glow);
  text-shadow: 0 0 8px var(--cyan);
  box-shadow: 0 0 8px var(--cyan-glow);
}
.global-nav-sep { color: var(--cyan-dim); opacity: 0.5; padding: 0 2px; }
.global-nav-crumb {
  color: var(--gold);
  font: 10px 'Consolas', monospace;
  letter-spacing: 2px;
  margin-left: 12px;
  text-shadow: 0 0 4px var(--gold);
  opacity: 0.85;
}
.global-nav-crumb:empty { display: none; }
.nav-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  background: var(--red);
  color: #000;
  border-radius: 8px;
  font-weight: bold;
  font-size: 9px;
  letter-spacing: 1px;
  animation: pulse-badge 1.5s infinite;
}
@keyframes pulse-badge { 0%,100% { opacity: 1; } 50% { opacity: 0.6; } }

.jobs-tabs {
  display: flex;
  gap: 2px;
  padding: 8px 12px 0;
  max-width: 1600px;
  margin: 0 auto 16px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--cyan-dim);
}
/* push view content below global nav (views are position:fixed, body padding no help) */
body.has-global-nav .lxc-view,
body.has-global-nav #wg-view,
body.has-global-nav #clients-view,
body.has-global-nav #topology-view,
body.has-global-nav #docker-view,
body.has-global-nav #agents-view {
  top: 36px;
  padding-top: 20px;
}
body.has-global-nav .hud .top-left { top: 44px; }
body.has-global-nav .hud .top-right { top: 44px; }
.view-toggle {
  z-index: 10;
  background: linear-gradient(135deg, rgba(0,217,255,0.05), rgba(0,217,255,0.02));
  color: var(--gold);
  border: 1px solid var(--cyan-dim);
  padding: 4px 12px;
  font-family: inherit;
  font-size: 10px;
  letter-spacing: 3px;
  cursor: pointer;
  text-shadow: 0 0 6px var(--gold);
  box-shadow: inset 0 0 10px rgba(0,217,255,0.05);
  transition: all 0.2s;
}
.view-toggle:hover {
  color: var(--cyan);
  border-color: var(--cyan);
  text-shadow: 0 0 8px var(--cyan);
  box-shadow: inset 0 0 15px rgba(0,217,255,0.1), 0 0 10px var(--cyan-glow);
}


#wg-view { display: none; flex-direction: column; padding: 30px 40px; }
#wg-view:not(.hidden) { display: flex; }
.wg-config-block {
  background: #000;
  border: 1px solid var(--cyan-dim);
  padding: 12px;
  font: 11px 'Consolas', monospace;
  color: var(--cyan);
  white-space: pre;
  overflow: auto;
  max-height: 320px;
  margin: 10px 0;
}
.wg-modal-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 8px 0;
}
.wg-modal-row label { min-width: 110px; color: var(--cyan-dim); letter-spacing: 2px; font-size: 11px; }
.wg-modal-row input {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--cyan-dim);
  color: var(--cyan);
  font: 13px 'Consolas', monospace;
  padding: 4px 8px;
  outline: none;
}
.wg-qr {
  display: flex;
  justify-content: center;
  margin: 14px 0;
  padding: 12px;
  background: #fff;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
}
.wg-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 14px; }

#wg-modal .palette-window {
  display: flex;
  flex-direction: column;
  max-height: 85vh;
}
#wg-modal .view-toggle { position: static !important; }
#wg-body .view-toggle,
#wg-view .clients-body .view-toggle,
.clients-table .view-toggle { position: static !important; }
#wg-modal #wg-modal-body {
  flex: 1;
  overflow-y: auto;
  display: block;
}
#wg-modal .wg-modal-row { display: flex; align-items: center; }
#wg-modal .wg-actions { display: flex; }

.router-panel { margin-top: 12px; }
.router-panel .row span:last-child { color: var(--gold); }
.bandwidth-row {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  letter-spacing: 1px;
  margin-top: 4px;
  color: var(--cyan-dim);
}
.bandwidth-spark { margin-top: 4px; }

#clients-view { display: none; flex-direction: column; padding: 30px 40px; }
#clients-view:not(.hidden) { display: flex; }
#clients-view .lxc-header { position: relative; z-index: 50; }
#clients-view .topology-controls { position: relative; z-index: 50; pointer-events: auto; }
#clients-view .topology-controls button { position: relative; z-index: 51; pointer-events: auto; }
.clients-body {
  flex: 1;
  overflow-y: auto;
  border: 1px solid var(--cyan-dim);
  background: rgba(0,8,20,0.4);
}
.clients-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.clients-table th,
.clients-table td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid rgba(0,217,255,0.08);
}
.clients-table th {
  position: sticky;
  top: 0;
  background: #001428;
  color: var(--cyan);
  letter-spacing: 2px;
  font-size: 10px;
  border-bottom: 1px solid var(--cyan-dim);
  cursor: pointer;
  user-select: none;
}
.clients-table th:hover { color: var(--gold); }
.clients-table tr:hover td { background: rgba(0,217,255,0.06); }
.clients-table .col-mac { color: var(--cyan-dim); font-family: monospace; }
.clients-table .col-ip { color: var(--cyan); font-family: monospace; }
.clients-table .col-host { color: #cce8ff; }
.clients-table .col-signal { color: var(--gold); }
.clients-table .badge {
  display: inline-block;
  padding: 1px 6px;
  font-size: 9px;
  letter-spacing: 1px;
  border: 1px solid var(--cyan-dim);
  color: var(--cyan-dim);
}
.clients-table .badge.wifi { color: var(--gold); border-color: var(--gold); }
.clients-table .badge.dhcp { color: var(--ok); border-color: var(--ok); }
.container-chips { margin-top: 4px; display: flex; flex-wrap: wrap; gap: 4px; }
.container-chips .chip {
  display: inline-block;
  font-size: 9px;
  letter-spacing: 0.5px;
  padding: 1px 6px;
  border: 1px solid var(--gold);
  color: var(--gold);
  background: rgba(255,184,77,0.05);
}
.lxc-header .view-toggle { position: static; z-index: 20; }
.lxc-header .topology-controls { z-index: 20; position: relative; }
.lxc-header .topology-controls button { pointer-events: auto; }

.lxc-view {
  position: fixed;
  inset: 0;
  padding: 80px 40px 40px;
  background: radial-gradient(ellipse at center, #001428 0%, #000814 70%, #000 100%);
  overflow-y: auto;
  animation: hudIn 0.4s ease-out;
}
.lxc-header {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 30px;
  position: relative;
}
.lxc-title {
  font-size: 18px;
  letter-spacing: 8px;
  color: var(--gold);
  text-shadow: 0 0 12px var(--gold);
}
.lxc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 16px;
  max-width: 1600px;
  margin: 0 auto;
}
.lxc-card {
  background: linear-gradient(135deg, rgba(0,217,255,0.05), rgba(0,217,255,0.02));
  border: 1px solid var(--cyan-dim);
  padding: 16px;
  position: relative;
  backdrop-filter: blur(4px);
  box-shadow: inset 0 0 20px rgba(0,217,255,0.05);
}
.lxc-card::before, .lxc-card::after {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  border: 2px solid var(--cyan);
}
.lxc-card::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.lxc-card::after  { bottom: -1px; right: -1px; border-left: none; border-top: none; }

.lxc-card.stopped { border-color: rgba(255,56,96,0.4); }
.lxc-card.stopped::before, .lxc-card.stopped::after { border-color: var(--red); }

.lxc-card-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--cyan-dim);
  padding-bottom: 8px;
  margin-bottom: 10px;
}
.lxc-card-name {
  font-size: 14px;
  color: #cce8ff;
  letter-spacing: 2px;
}
.lxc-card-vmid {
  color: var(--gold);
  font-size: 11px;
  letter-spacing: 2px;
}
.lxc-card-status {
  font-size: 10px;
  letter-spacing: 3px;
  padding: 2px 6px;
  border: 1px solid currentColor;
}
.lxc-card-status.running { color: var(--ok); text-shadow: 0 0 6px var(--ok); }
.lxc-card-status.stopped { color: var(--red); }

.lxc-card-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 12px;
  font-size: 11px;
  letter-spacing: 1px;
  margin-bottom: 10px;
}
.lxc-card-stats .label { color: var(--cyan-dim); }
.lxc-card-stats .value { color: var(--cyan); text-align: right; }
.lxc-ip-link { color: var(--gold); text-decoration: none; text-shadow: 0 0 4px var(--gold); }
.lxc-ip-link:hover { text-decoration: underline; }
.docker-image, .docker-ports {
  font-size: 10px;
  word-break: break-all;
  overflow-wrap: anywhere;
}
.docker-net { color: var(--cyan-dim); margin-right: 2px; }

/* TOASTS */
.toast-stack {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.toast {
  min-width: 280px;
  max-width: 420px;
  padding: 10px 16px;
  background: rgba(0, 8, 20, 0.92);
  border: 1px solid var(--cyan);
  border-left-width: 4px;
  font-size: 12px;
  letter-spacing: 1px;
  color: #cce8ff;
  box-shadow: 0 0 20px var(--cyan-glow), inset 0 0 15px rgba(0,217,255,0.08);
  backdrop-filter: blur(6px);
  animation: toastIn 0.3s ease-out;
  pointer-events: auto;
}
.toast.warn { border-color: var(--gold); box-shadow: 0 0 20px rgba(255,184,77,0.3); }
.toast.error { border-color: var(--red); box-shadow: 0 0 20px rgba(255,56,96,0.3); }
.toast.ok { border-color: var(--ok); box-shadow: 0 0 20px rgba(74,222,128,0.3); }
.toast-head {
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--gold);
  margin-bottom: 4px;
}
.toast.warn .toast-head { color: var(--gold); }
.toast.error .toast-head { color: var(--red); }
.toast.ok .toast-head { color: var(--ok); }
.toast.fadeout { animation: toastOut 0.4s ease-in forwards; }

@keyframes toastIn {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes toastOut {
  to { opacity: 0; transform: translateY(-20px); }
}

/* SPARKLINES */
.spark {
  display: inline-block;
  vertical-align: middle;
  margin-left: 6px;
}
.spark-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
  padding: 2px 0;
}

/* HUD DIALOG (confirm/alert) */
.hud-dialog {
  position: fixed;
  inset: 0;
  background: rgba(0,8,20,0.7);
  backdrop-filter: blur(6px);
  z-index: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: hudIn 0.2s ease-out;
}
.hud-dialog-window {
  width: min(440px, 92vw);
  background: rgba(0,0,0,0.92);
  border: 1px solid var(--cyan);
  box-shadow: 0 0 30px var(--cyan-glow), inset 0 0 25px rgba(0,217,255,0.06);
  position: relative;
  padding: 20px 22px 18px;
}
.hud-dialog-window::before, .hud-dialog-window::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid var(--cyan);
}
.hud-dialog-window::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.hud-dialog-window::after  { bottom: -1px; right: -1px; border-left: none; border-top: none; }

.hud-dialog.danger .hud-dialog-window { border-color: var(--red); box-shadow: 0 0 30px rgba(255,56,96,0.4); }
.hud-dialog.danger .hud-dialog-window::before,
.hud-dialog.danger .hud-dialog-window::after { border-color: var(--red); }
.hud-dialog.warn .hud-dialog-window { border-color: var(--gold); box-shadow: 0 0 30px rgba(255,184,77,0.35); }
.hud-dialog.warn .hud-dialog-window::before,
.hud-dialog.warn .hud-dialog-window::after { border-color: var(--gold); }

.hud-dialog-head {
  font-size: 11px;
  letter-spacing: 5px;
  color: var(--gold);
  text-shadow: 0 0 8px var(--gold);
  border-bottom: 1px solid var(--cyan-dim);
  padding-bottom: 8px;
  margin-bottom: 14px;
}
.hud-dialog.danger .hud-dialog-head { color: var(--red); text-shadow: 0 0 8px var(--red); }
.hud-dialog.warn .hud-dialog-head { color: var(--gold); }

.hud-dialog-body {
  font-size: 13px;
  color: #cce8ff;
  letter-spacing: 1px;
  line-height: 1.5;
  margin-bottom: 18px;
  white-space: pre-wrap;
}

.hud-dialog-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.hud-dialog-btn {
  background: transparent;
  color: var(--cyan);
  border: 1px solid var(--cyan-dim);
  padding: 8px 18px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 3px;
  cursor: pointer;
  transition: all 0.15s;
}
.hud-dialog-btn:hover { background: var(--cyan-glow); border-color: var(--cyan); }
.hud-dialog-btn.primary { color: var(--gold); border-color: var(--gold); }
.hud-dialog-btn.primary:hover { background: rgba(255,184,77,0.12); }
.hud-dialog-btn.danger { color: var(--red); border-color: rgba(255,56,96,0.5); }
.hud-dialog-btn.danger:hover { background: rgba(255,56,96,0.15); border-color: var(--red); }

/* LOG MODAL */
.log-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,8,20,0.85);
  backdrop-filter: blur(6px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: hudIn 0.25s ease-out;
}
.log-window {
  width: min(900px, 90vw);
  height: min(600px, 80vh);
  background: rgba(0,0,0,0.92);
  border: 1px solid var(--cyan);
  box-shadow: 0 0 40px var(--cyan-glow), inset 0 0 30px rgba(0,217,255,0.05);
  display: flex;
  flex-direction: column;
  position: relative;
}
.log-window::before, .log-window::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid var(--cyan);
}
.log-window::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.log-window::after  { bottom: -1px; right: -1px; border-left: none; border-top: none; }

.log-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  border-bottom: 1px solid var(--cyan-dim);
}
.log-title {
  font-size: 12px;
  letter-spacing: 4px;
  color: var(--gold);
  text-shadow: 0 0 8px var(--gold);
}
.log-controls { display: flex; gap: 6px; }
.log-controls .view-toggle { position: static; }
.log-body {
  flex: 1;
  margin: 0;
  padding: 12px 16px;
  overflow: auto;
  font-family: 'Consolas', monospace;
  font-size: 11px;
  line-height: 1.5;
  color: #cce8ff;
  white-space: pre-wrap;
  word-break: break-word;
}
.log-body .err { color: var(--red); }
.log-body .warn { color: var(--gold); }
.log-body .ok { color: var(--ok); }

.ssh-auth-window { width: min(420px, 92vw); height: auto; min-height: 360px; }
.ssh-auth-form {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ssh-auth-form label {
  display: flex;
  flex-direction: column;
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--gold);
  gap: 4px;
}
.ssh-auth-form input[type="text"],
.ssh-auth-form input[type="password"],
.ssh-auth-form input[type="number"] {
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--cyan-dim);
  color: #cce8ff;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
  letter-spacing: 1px;
  outline: none;
}
.ssh-auth-form input:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 8px var(--cyan-glow);
}
.ssh-remember {
  flex-direction: row !important;
  align-items: center;
  gap: 8px !important;
  font-size: 9px;
  color: var(--cyan-dim) !important;
}
.ssh-connect-btn {
  margin-top: 8px;
  padding: 10px 14px !important;
  font-size: 12px !important;
}
.term-window { width: min(1100px, 95vw); height: min(700px, 85vh); }
.term-body {
  flex: 1;
  padding: 8px;
  background: #000;
  overflow: hidden;
}
.term-body .xterm { height: 100%; }
.term-body .xterm-viewport { background: transparent !important; }

.lxc-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 10px;
}
.lxc-tag {
  font-size: 9px;
  letter-spacing: 1px;
  padding: 1px 6px;
  background: rgba(0,217,255,0.1);
  border: 1px solid var(--cyan-dim);
  color: var(--cyan);
}

.lxc-card-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.lxc-action {
  flex: 1;
  min-width: 60px;
  background: transparent;
  color: var(--cyan);
  border: 1px solid var(--cyan-dim);
  padding: 6px;
  font-family: inherit;
  font-size: 10px;
  letter-spacing: 2px;
  cursor: pointer;
}
.lxc-action:hover:not(:disabled) { background: var(--cyan-glow); border-color: var(--cyan); }
.lxc-action:disabled { opacity: 0.3; cursor: not-allowed; }
.lxc-action.danger { color: var(--red); border-color: rgba(255,56,96,0.4); }
.lxc-action.danger:hover:not(:disabled) { background: rgba(255,56,96,0.15); border-color: var(--red); }
/* button intent variants — separate read/mutate/schedule visually */
.lxc-action.primary { background: var(--cyan-glow); border-color: var(--cyan); color: var(--cyan); font-weight: bold; }
.lxc-action.primary:hover:not(:disabled) { background: rgba(0,200,255,0.25); box-shadow: 0 0 8px var(--cyan-glow); }
.lxc-action.ghost { color: var(--cyan-dim); border-color: rgba(0,200,255,0.2); }
.lxc-action.ghost:hover:not(:disabled) { color: var(--cyan); border-color: var(--cyan-dim); background: rgba(0,200,255,0.05); }
.lxc-action.warn { color: var(--gold); border-color: rgba(255,200,80,0.4); }
.lxc-action.warn:hover:not(:disabled) { background: rgba(255,200,80,0.12); border-color: var(--gold); }

/* ANIMATIONS */
@keyframes flicker {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}
@keyframes fill { to { width: 100%; } }
@keyframes appear { to { opacity: 1; } }
@keyframes hudIn {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 5px var(--red); }
  50% { box-shadow: 0 0 20px var(--red); }
}
@keyframes scan {
  from { background-position-y: 0; }
  to   { background-position-y: 100px; }
}

/* SCROLLBARS */
* { scrollbar-width: thin; scrollbar-color: var(--cyan-dim) transparent; }
*::-webkit-scrollbar { width: 6px; height: 6px; }
*::-webkit-scrollbar-track {
  background: rgba(0,20,40,0.4);
  border-left: 1px solid var(--cyan-glow);
}
*::-webkit-scrollbar-thumb {
  background: var(--cyan-dim);
  border-radius: 0;
  box-shadow: 0 0 6px var(--cyan-glow);
}
*::-webkit-scrollbar-thumb:hover {
  background: var(--cyan);
  box-shadow: 0 0 10px var(--cyan);
}
*::-webkit-scrollbar-corner { background: transparent; }

/* ============ COMMAND PALETTE ============ */
.palette-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,8,20,0.85);
  z-index: 200;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 12vh;
  backdrop-filter: blur(4px);
}
.palette-window {
  width: min(720px, 92vw);
  background: #001428;
  border: 1px solid var(--cyan);
  box-shadow: 0 0 40px var(--cyan-glow), inset 0 0 20px rgba(0,217,255,0.05);
  position: relative;
}
.palette-window::before,
.palette-window::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid var(--cyan);
}
.palette-window::before { top: -2px; left: -2px; border-right: none; border-bottom: none; }
.palette-window::after { bottom: -2px; right: -2px; border-left: none; border-top: none; }
.palette-input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--cyan-dim);
  color: var(--cyan);
  font: 18px 'Consolas', monospace;
  padding: 16px 18px;
  outline: none;
  letter-spacing: 1px;
}
.palette-input::placeholder { color: var(--cyan-dim); }
.palette-list {
  max-height: 50vh;
  overflow-y: auto;
}
.palette-item {
  padding: 10px 18px;
  border-bottom: 1px solid rgba(0,217,255,0.08);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  color: #cce8ff;
}
.palette-item.active {
  background: rgba(0,217,255,0.12);
  border-left: 3px solid var(--cyan);
  padding-left: 15px;
}
.palette-item:hover { background: rgba(0,217,255,0.08); }
.palette-item-label { font-size: 14px; }
.palette-item-kind {
  font-size: 10px;
  color: var(--cyan-dim);
  letter-spacing: 2px;
  padding: 2px 8px;
  border: 1px solid var(--cyan-dim);
}
.palette-item.danger .palette-item-kind { border-color: var(--red); color: var(--red); }
.palette-hint {
  padding: 8px 18px;
  font-size: 10px;
  color: var(--cyan-dim);
  letter-spacing: 2px;
  border-top: 1px solid var(--cyan-dim);
}

/* ============ TERMINAL SNIPPETS ============ */
.term-snippet-select {
  background: #001428;
  color: var(--cyan);
  border: 1px solid var(--cyan-dim);
  font: 11px 'Consolas', monospace;
  padding: 4px 8px;
  letter-spacing: 1px;
  max-width: 180px;
}
.term-snippet-select:focus { outline: 1px solid var(--cyan); }

/* ============ NETWORK TOPOLOGY ============ */
#topology-view { display: none; flex-direction: column; padding: 30px 40px; }
#topology-view:not(.hidden) { display: flex; }
#topology-view .lxc-header { margin-bottom: 16px; }
.topology-controls {
  display: flex;
  gap: 10px;
  align-items: center;
}
.topology-status {
  font-size: 11px;
  color: var(--cyan-dim);
  letter-spacing: 2px;
}
.topology-body {
  flex: 1;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(rgba(0,217,255,0.04) 1px, transparent 1px) 0 0 / 40px 40px,
    linear-gradient(90deg, rgba(0,217,255,0.04) 1px, transparent 1px) 0 0 / 40px 40px;
}
.topology-svg {
  width: 100%;
  height: 100%;
  display: block;
}
.topology-svg .node-circle {
  fill: #001428;
  stroke: var(--cyan);
  stroke-width: 1.5;
  filter: drop-shadow(0 0 6px var(--cyan-glow));
}
.topology-svg .node-circle.down { stroke: var(--red); }
.topology-svg .node-label {
  fill: var(--cyan);
  font: 11px 'Consolas', monospace;
  text-anchor: middle;
  letter-spacing: 1px;
}
.topology-svg .node-ip {
  fill: var(--cyan-dim);
  font: 9px 'Consolas', monospace;
  text-anchor: middle;
}
.topology-svg .edge {
  stroke: rgba(0,217,255,0.15);
  stroke-width: 1;
  fill: none;
}
.topology-svg .edge.alive { stroke: var(--ok); stroke-width: 1.2; }
.topology-svg .edge.slow  { stroke: var(--gold); stroke-width: 1.2; }
.topology-svg .edge.dead  { stroke: var(--red); stroke-width: 1; stroke-dasharray: 4 3; opacity: 0.6; }
.topology-legend {
  position: absolute;
  bottom: 14px;
  left: 14px;
  background: rgba(0,8,20,0.8);
  border: 1px solid var(--cyan-dim);
  padding: 10px 14px;
  font-size: 11px;
  letter-spacing: 1px;
  display: flex;
  gap: 18px;
}
.topology-legend .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.topology-legend .dot.alive { background: var(--ok); box-shadow: 0 0 6px var(--ok); }
.topology-legend .dot.slow  { background: var(--gold); box-shadow: 0 0 6px var(--gold); }
.topology-legend .dot.dead  { background: var(--red); box-shadow: 0 0 6px var(--red); }

/* ---- agents view ---- */
/* AGENTS: reuse lxc-card theme. agent-detail spans full width of grid. */

/* agent groups — section per domain */
.agent-group { max-width: 1600px; margin: 0 auto 28px; }
.agent-group-head {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 0 2px 8px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--cyan-dim);
}
.agent-group-title {
  font-size: 13px;
  letter-spacing: 6px;
  color: var(--gold);
  text-shadow: 0 0 6px var(--gold);
}
.agent-group-desc {
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--cyan-dim);
  flex: 1;
}
.agent-group-count {
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--cyan);
  border: 1px solid var(--cyan-dim);
  padding: 2px 8px;
  background: var(--cyan-glow);
}
.agent-group-grid { margin: 0; }

/* tab strip under header — quick switch between agent panels */
.agents-tabs {
  display: flex;
  gap: 2px;
  padding: 8px 12px 0;
  max-width: 1600px;
  margin: 0 auto;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--cyan-dim);
}
.agents-tab {
  background: transparent;
  border: 1px solid var(--cyan-dim);
  border-bottom: none;
  color: var(--cyan-dim);
  padding: 6px 14px;
  font: 10px 'Consolas', monospace;
  letter-spacing: 2px;
  cursor: pointer;
  position: relative;
  bottom: -1px;
}
.agents-tab:hover { color: var(--cyan); border-color: var(--cyan-dim); background: rgba(0,200,255,0.05); }
.agents-tab.active {
  color: var(--cyan);
  border-color: var(--cyan);
  background: var(--cyan-glow);
  box-shadow: 0 0 8px var(--cyan-glow);
}
.agents-tab.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 2px;
  background: var(--cyan-glow);
}

/* form-group: input(s) + their action buttons grouped */
.agent-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: rgba(0,15,25,0.4);
  border-left: 2px solid var(--cyan-dim);
  padding: 8px 10px;
}
.agent-form-inputs { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.agent-form-inputs > .palette-input { flex: 1; min-width: 120px; }
.agent-form-inputs > input[type="number"].palette-input { flex: 0 0 90px; min-width: 60px; }
.agent-form-actions { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; margin-top: 4px; }
.agent-form-actions .lxc-action { flex: 0 0 auto; min-width: 80px; }

.agents-btn-row { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; margin-top: 6px; }
.agents-btn-row input[type="number"].palette-input { width: 80px; }

/* themed select (used inline in agent-section, not modal) */
select.palette-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #001428;
  border: 1px solid var(--cyan-dim);
  font: 11px 'Consolas', monospace;
  padding: 6px 26px 6px 10px;
  letter-spacing: 1px;
  width: auto;
  background-image: linear-gradient(45deg, transparent 50%, var(--cyan) 50%),
                    linear-gradient(135deg, var(--cyan) 50%, transparent 50%);
  background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  cursor: pointer;
}
select.palette-input:hover, select.palette-input:focus { border-color: var(--cyan); outline: none; }
select.palette-input option { background: #001428; color: var(--cyan); }

/* themed number input — hide native spinners, smaller font matching list rows */
.agent-section input[type="number"].palette-input,
.agents-btn-row input[type="number"].palette-input,
.agent-section input[type="text"].palette-input,
.agent-section input[type="url"].palette-input {
  background: #001428;
  border: 1px solid var(--cyan-dim);
  font: 11px 'Consolas', monospace;
  padding: 6px 10px;
  letter-spacing: 1px;
}
.agent-section input[type="number"].palette-input:hover,
.agent-section input[type="number"].palette-input:focus,
.agents-btn-row input[type="number"].palette-input:hover,
.agents-btn-row input[type="number"].palette-input:focus,
.agent-section input[type="text"].palette-input:focus,
.agent-section input[type="url"].palette-input:focus { border-color: var(--cyan); outline: none; }
.agent-section input[type="number"].palette-input::-webkit-outer-spin-button,
.agent-section input[type="number"].palette-input::-webkit-inner-spin-button,
.agents-btn-row input[type="number"].palette-input::-webkit-outer-spin-button,
.agents-btn-row input[type="number"].palette-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.agent-section input[type="number"].palette-input,
.agents-btn-row input[type="number"].palette-input { -moz-appearance: textfield; appearance: textfield; }
.agents-out {
  background: rgba(0, 10, 16, 0.5);
  border: 1px solid var(--cyan-dim);
  padding: 10px 12px;
  font-size: 11px;
  max-height: 320px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-all;
  color: var(--cyan);
  margin: 0;
}
.agent-detail { grid-column: 1 / -1; max-width: 900px; margin: 0 auto; width: 100%; }
.agent-section {
  border-top: 1px solid var(--cyan-dim);
  padding-top: 10px;
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.agent-section-title {
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--gold);
  text-shadow: 0 0 4px var(--gold);
}
.agent-tile { cursor: pointer; }
.agent-desc {
  font-size: 11px;
  color: var(--cyan-dim);
  letter-spacing: 1px;
  line-height: 1.5;
  margin-bottom: 10px;
}
.agents-nb-list { display: flex; flex-direction: column; gap: 6px; max-height: 360px; overflow-y: auto; margin-bottom: 10px; }
.agents-nb-item {
  padding: 8px 12px; cursor: pointer;
  border: 1px solid var(--cyan-dim); border-left-width: 3px;
  display: flex; justify-content: space-between; gap: 6px; font-size: 12px;
  color: var(--gold); transition: all 0.2s; letter-spacing: 2px;
}
.agents-nb-item:hover { background: rgba(0, 217, 255, 0.08); color: var(--cyan); }
.agents-nb-item.active { border-left-color: var(--cyan); background: rgba(0, 217, 255, 0.12); color: var(--cyan); text-shadow: 0 0 6px var(--cyan); }
.agents-nb-item .nb-meta { opacity: 0.5; font-size: 10px; }
.agents-newnb { display: flex; gap: 6px; }
.agents-newnb input { flex: 1; }
