/* ── Variables ─────────────────────────────────────────────────────────────── */

:root {
  --bg:              #0a0a0b;
  --surface:         #111114;
  --border:          #1e1e22;
  --border-sub:      #151518;
  --text:            #f0ede8;
  --muted:           #9896a4;
  --dim:             #7e7c8a;
  --dimmer:          #55535f;

  --blue:            #4d9cff;
  --blue-bg:         rgba(77, 156, 255, 0.08);
  --blue-border:     rgba(77, 156, 255, 0.22);
  --blue-border-top: rgba(77, 156, 255, 0.35);

  --green:           #22c55e;
  --amber:           #f59e0b;
  --red:             #ef4444;

  --font-display: 'Outfit', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  --radius-sm: 4px;
  --radius-md: 8px;

  --pad-x: clamp(20px, 5.5vw, 80px);
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */

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

html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-display);
  min-height: 100vh;
}

/* ── Shared Nav ────────────────────────────────────────────────────────────── */

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px var(--pad-x);
  border-bottom: 1px solid var(--border-sub);
}

.nav-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.nav-logo {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--dim);
  letter-spacing: 0.04em;
  text-decoration: none;
}

.nav-sep {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--dimmer);
}

.nav-page {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.nav-ts {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dimmer);
  letter-spacing: 0.04em;
}

.btn-login {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--blue);
  text-decoration: none;
  padding: 7px 16px;
  border: 1px solid rgba(77, 156, 255, 0.3);
  border-radius: var(--radius-sm);
  transition: background 0.15s;
  white-space: nowrap;
}

.btn-login:hover { background: var(--blue-bg); }

.btn-logout {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  text-decoration: none;
  padding: 5px 11px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  white-space: nowrap;
}

.btn-logout:hover {
  color: var(--red);
  border-color: rgba(239, 68, 68, 0.3);
  background: rgba(239, 68, 68, 0.05);
}

/* ── Nav links & dropdowns ───────────────────────────────────────────────── */

.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
}

.nav-link {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  text-decoration: none;
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  transition: color 0.15s, background 0.15s;
  white-space: nowrap;
  background: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.nav-link:hover { color: var(--text); background: rgba(255,255,255,0.04); }
.nav-link--active { color: var(--text); }

.nav-user {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.04em;
}

/* Dropdown */
.nav-dropdown { position: relative; }

.nav-dd-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 180px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 6px;
  z-index: 100;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.nav-dd--open .nav-dd-menu { display: flex; flex-direction: column; gap: 1px; }

.nav-dd-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 10px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.12s, background 0.12s;
}
.nav-dd-item:hover { color: var(--text); background: rgba(255,255,255,0.05); }
.nav-dd-item svg { color: var(--dimmer); flex-shrink: 0; }

/* Hamburger (mobile only) */
.nav-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  padding: 4px;
}

/* Mobile menu */
.nav-mobile-menu {
  display: none;
  flex-direction: column;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 12px 16px 16px;
  gap: 2px;
  z-index: 99;
}
.nav-mobile-menu--open { display: flex; }

.nav-mobile-link {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.12s, background 0.12s;
}
.nav-mobile-link:hover,
.nav-mobile-link.nav-link--active { color: var(--text); background: rgba(255,255,255,0.04); }
.nav-mobile-svc svg { color: var(--dimmer); flex-shrink: 0; }
.nav-mobile-logout { color: var(--dim); margin-top: 4px; }
.nav-mobile-logout:hover { color: var(--red); }

.nav-mobile-sep {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 10px 4px;
}

@media (max-width: 680px) {
  .nav-links,
  .nav-dropdown,
  .nav-user { display: none; }
  .nav-hamburger { display: flex; }
  .nav { position: relative; }
}

/* ── Service chips (nav) ───────────────────────────────────────────────────── */

.svc-links {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.svc-chip {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  text-decoration: none;
  padding: 5px 11px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  white-space: nowrap;
}

.svc-chip:hover {
  color: var(--text);
  border-color: var(--dimmer);
}

.svc-chip--accent {
  color: var(--blue);
  border-color: rgba(77, 156, 255, 0.3);
}

.svc-chip--accent:hover {
  background: var(--blue-bg);
  border-color: rgba(77, 156, 255, 0.5);
}

/* ── Section header link (↗) ───────────────────────────────────────────────── */

.section-link {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--dimmer);
  text-decoration: none;
  line-height: 1;
  transition: color 0.15s;
}

.section-link:hover { color: var(--blue); }

/* ── Services row (5-column grid) ─────────────────────────────────────────── */

.svc-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  align-items: stretch;
}

/* ── Landing: Page Shell ───────────────────────────────────────────────────── */

.landing {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ── Landing: Hero ─────────────────────────────────────────────────────────── */

.hero {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 60px var(--pad-x) 0;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--blue-bg);
  border: 1px solid var(--blue-border);
  border-radius: var(--radius-sm);
  width: fit-content;
}

.status-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--blue);
  flex-shrink: 0;
  animation: pulse-blue 2.4s ease-in-out infinite;
}
.status-badge-dot.dot--ok {
  background: var(--green);
  animation: pulse-green 2.4s ease-in-out infinite;
}
.status-badge-dot.dot--error {
  background: var(--red);
  animation: none;
}

.status-badge-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--blue);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.hero-headline {
  font-size: clamp(52px, 7.5vw, 104px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.04em;
  line-height: 0.92;
}

.hero-headline .muted { font-weight: 300; color: #35333b; }

.hero-subline {
  font-size: clamp(15px, 2vw, 18px);
  font-weight: 300;
  color: var(--dim);
  line-height: 1.6;
  max-width: 520px;
}

/* ── Landing: Location Cards ───────────────────────────────────────────────── */

.locations {
  display: flex;
  gap: 20px;
  padding: 48px var(--pad-x) 0;
}

.loc-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex: 1;
  padding: 24px 28px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: 2px solid var(--blue-border-top);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  min-height: 240px;
  transition: border-color 0.2s;
  gap: 20px;
}

.loc-card:hover { border-color: rgba(77, 156, 255, 0.55); }

.loc-card-icon { color: var(--blue); }

.loc-card-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.loc-card-name {
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
}

.loc-card-place {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.05em;
  margin-top: 3px;
}

.loc-online {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
}

.loc-online-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--dim);
  flex-shrink: 0;
  transition: background 0.3s;
}

.loc-online-dot.status--ok    { background: var(--green); }
.loc-online-dot.status--warn  { background: var(--amber); }
.loc-online-dot.status--error { background: var(--red); }

.loc-online-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.06em;
}

.loc-stats {
  display: flex;
  gap: 40px;
}

.loc-stat { display: flex; flex-direction: column; gap: 4px; }

.loc-stat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.loc-stat-value {
  font-size: clamp(32px, 3.5vw, 40px);
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1;
}

.loc-card-link {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dimmer);
  letter-spacing: 0.04em;
}

/* ── Landing: Services ─────────────────────────────────────────────────────── */

.services {
  padding: 48px var(--pad-x) 0;
}

.services-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.svc-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.18s, background 0.18s;
}

.svc-card:hover {
  border-color: rgba(77,156,255,0.4);
  background: rgba(77,156,255,0.03);
}

.svc-card-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Per-service icon accent colours */
.svc-icon--ha        { background: rgba(24,  188, 156, 0.12); color: #18bc9c; }
.svc-icon--grafana   { background: rgba(245, 158, 11,  0.12); color: var(--amber); }
.svc-icon--proxmox   { background: rgba(226, 85,  33,  0.12); color: #e25521; }
.svc-icon--cloud     { background: rgba(77,  156, 255, 0.12); color: var(--blue); }
.svc-icon--paperless { background: rgba(34,  197, 94,  0.12); color: var(--green); }
.svc-icon--omada     { background: rgba(168, 85,  247, 0.12); color: #a855f7; }

.svc-card-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

.svc-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.svc-card-host {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.svc-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #2a2a33;
  flex-shrink: 0;
  transition: background 0.4s;
}
.svc-status-dot.dot--ok    { background: var(--green); animation: pulse-green 2.4s ease-in-out infinite; }
.svc-status-dot.dot--error { background: var(--red); }

.svc-card-proto {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 3px;
  flex-shrink: 0;
}

.svc-proto--https {
  background: rgba(34, 197, 94, 0.1);
  color: var(--green);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.svc-proto--http {
  background: rgba(245, 158, 11, 0.1);
  color: var(--amber);
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.svc-badge--intern {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 3px;
  flex-shrink: 0;
  background: rgba(120, 118, 130, 0.1);
  color: var(--dim);
  border: 1px solid rgba(120, 118, 130, 0.2);
}

/* ── Landing: Footer ───────────────────────────────────────────────────────── */

/* ── Updates Section ────────────────────────────────────────────────────────── */

.updates {
  padding: 48px var(--pad-x) 0;
}

.updates-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.updates-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.updates-summary {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.updates-total {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--amber);
  letter-spacing: 0.04em;
}

.updates-total.ok { color: var(--green); }

.updates-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  letter-spacing: 0.04em;
}

.updates-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--border-sub);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.updates-loading {
  grid-column: 1 / -1;
  padding: 24px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dimmer);
}

.update-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 16px;
  background: var(--surface);
  transition: background 0.15s;
}

.update-row:hover { background: #16161a; }

.update-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--border);
}

.update-dot.has-updates { background: var(--amber); }
.update-dot.no-updates  { background: var(--green); opacity: 0.6; }

.update-host {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.update-count {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  flex-shrink: 0;
  min-width: 28px;
  text-align: right;
}

.update-count.zero { color: var(--dimmer); }

.update-age {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  flex-shrink: 0;
  min-width: 48px;
  text-align: right;
}

@media (max-width: 768px) {
  .updates-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .updates-grid { grid-template-columns: 1fr; }
}

/* ── Updates Page ────────────────────────────────────────────────────────────── */

.updates-page {
  padding: 60px var(--pad-x) 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
  flex: 1;
}

.updates-page-header {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.updates-page-kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dimmer);
  letter-spacing: 0.1em;
}

.updates-page-headline {
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.04em;
  line-height: 0.92;
}

.muted-h1 { font-weight: 300; color: #35333b; }

.updates-page-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.upd-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 11px;
  background: var(--blue-bg);
  border: 1px solid var(--blue-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--blue);
  letter-spacing: 0.06em;
}

.upd-badge--dim {
  background: transparent;
  border-color: var(--border);
  color: var(--dim);
}

.upd-badge--ok {
  background: rgba(34,197,94,0.07);
  border-color: rgba(34,197,94,0.22);
  color: var(--green);
}

.upd-badge--warn {
  background: rgba(245,158,11,0.07);
  border-color: rgba(245,158,11,0.22);
  color: var(--amber);
}

.upd-badge-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--blue);
  flex-shrink: 0;
  animation: pulse-blue 2.4s ease-in-out infinite;
}

.upd-badge-dot.ok   { background: var(--green); animation: pulse-green 2.4s ease-in-out infinite; }
.upd-badge-dot.warn { background: var(--amber); animation: none; }

.updates-page-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Summary row */

.upd-summary-row {
  display: flex;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.upd-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 22px;
  border-right: 1px solid var(--border-sub);
}

.upd-stat:last-child { border-right: none; }

.upd-stat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.upd-stat-value {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.upd-stat-green { color: var(--green); }
.upd-stat-mono  { font-family: var(--font-mono); font-size: 20px; font-weight: 500; color: var(--muted); }

/* Table */

.upd-table-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.upd-table-header {
  display: grid;
  grid-template-columns: 1fr 1fr 80px 72px 120px;
  gap: 0;
  padding: 9px 20px;
  border-bottom: 1px solid var(--border-sub);
  background: var(--bg);
}

.upd-table-header span {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--dimmer);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.upd-col-right { text-align: right; }

.upd-row {
  display: grid;
  grid-template-columns: 1fr 1fr 80px 72px 120px;
  align-items: center;
  padding: 11px 20px;
  border-bottom: 1px solid var(--border-sub);
  transition: background 0.15s;
}

.upd-row:last-child { border-bottom: none; }
.upd-row:hover { background: rgba(255,255,255,0.02); }

.upd-row-host {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text);
  min-width: 0;
}

.upd-row-host-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--amber);
}

.upd-row-host-dot.ok { background: var(--green); opacity: 0.55; }

.upd-row-os {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-right: 12px;
}

.upd-row-count {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--amber);
  text-align: right;
}

.upd-row-count.ok { color: var(--green); font-size: 11px; }

.upd-row-age {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dimmer);
  text-align: right;
}

.upd-empty {
  padding: 28px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dimmer);
}

/* Stale warning */
.upd-row--stale .upd-row-host { opacity: 0.6; }

.upd-reboot-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  padding: 2px 5px;
  border-radius: 4px;
  background: rgba(245,158,11,0.12);
  border: 1px solid rgba(245,158,11,0.3);
  color: var(--amber);
  margin-left: 7px;
  flex-shrink: 0;
}

.upd-stale-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  padding: 2px 5px;
  border-radius: 4px;
  background: rgba(239,68,68,0.12);
  border: 1px solid rgba(239,68,68,0.25);
  color: #ef4444;
  margin-left: 7px;
  flex-shrink: 0;
}

/* Package detail list */
.upd-pkg-list {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 8px 20px 12px 34px;
  border-top: 1px solid var(--border-sub);
}

.upd-pkg {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-sub);
  border-radius: 4px;
  padding: 2px 7px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.upd-pkg-ver {
  color: var(--dimmer);
  font-size: 9px;
}

.upd-row-host[style*="cursor:pointer"]:hover > span:first-child + span {
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 2px;
}

/* Action column */
.upd-row-action {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-end;
}

.upd-run-btn {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  padding: 4px 10px;
  border-radius: 5px;
  border: 1px solid rgba(245,158,11,0.35);
  background: rgba(245,158,11,0.08);
  color: var(--amber);
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap;
}
.upd-run-btn:hover:not(:disabled) {
  background: rgba(245,158,11,0.18);
}
.upd-run-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

.upd-run-all-btn {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  padding: 5px 14px;
  border-radius: 6px;
  border: 1px solid rgba(245,158,11,0.35);
  background: rgba(245,158,11,0.08);
  color: var(--amber);
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap;
  margin-left: 4px;
}
.upd-run-all-btn:hover:not(:disabled) {
  background: rgba(245,158,11,0.18);
}
.upd-run-all-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

.upd-job-status {
  font-family: var(--font-mono);
  font-size: 10px;
  white-space: nowrap;
}
.upd-job-status.job-queued  { color: var(--dimmer); }
.upd-job-status.job-running { color: var(--amber);  }
.upd-job-status.job-done    { color: var(--green);  }
.upd-job-status.job-error   { color: #ef4444;       }

@media (max-width: 640px) {
  .upd-summary-row { flex-wrap: wrap; }
  .upd-stat { flex: 1 1 calc(50% - 1px); border-bottom: 1px solid var(--border-sub); border-right: none; }
  .upd-stat:nth-child(odd)  { border-right: 1px solid var(--border-sub); }
  .upd-stat:last-child, .upd-stat:nth-last-child(2) { border-bottom: none; }
  .upd-table-header, .upd-row { grid-template-columns: 1fr 80px 64px auto; }
  .upd-table-header span:nth-child(2), .upd-row-os { display: none; }
}

/* ── Crew Easter Egg ────────────────────────────────────────────────────────── */

.crew {
  max-width: 960px;
  margin: 80px auto 56px;
  padding: 0 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.crew-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--dim);
}

.crew-row {
  display: flex;
  gap: 12px;
  width: 100%;
  justify-content: center;
}

.crew-card {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 18px;
  flex: 1;
  max-width: 300px;
  min-width: 0;
}

.crew-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.crew-avatar--jonny { background: rgba(77,156,255,0.1); border: 1.5px solid rgba(77,156,255,0.3); color: #4d9cff; }
.crew-avatar--biene { background: rgba(245,159,35,0.1); border: 1.5px solid rgba(245,159,35,0.3); color: #f59f23; }
.crew-avatar--merle { background: rgba(123,237,159,0.08); border: 1.5px solid rgba(123,237,159,0.25); color: #7bed9f; }

.crew-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}

.crew-name {
  font-family: 'Outfit', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.crew-role {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 500;
}
.crew-role--jonny { color: #4d9cff; }
.crew-role--biene { color: #f59f23; }
.crew-role--merle { color: #7bed9f; }

.crew-desc {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--dimmer);
  white-space: normal;
}

.crew-pid {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}

.crew-pid-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  color: var(--border);
}

.crew-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  opacity: 0.6;
}
.crew-dot--jonny { background: #4d9cff; }
.crew-dot--biene { background: #f59f23; }
.crew-dot--merle { background: #7bed9f; }

@media (max-width: 640px) {
  .crew-row { flex-direction: column; align-items: stretch; }
  .crew-card { max-width: 100%; }
  .crew-desc { white-space: normal; }
}

/* ── Footer */

.footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 28px var(--pad-x);
  margin-top: auto;
  border-top: 1px solid var(--border-sub);
}

.footer-text {
  font-family: var(--font-mono);
  font-size: 11px;
  color: #2e2d33;
  letter-spacing: 0.04em;
}

.footer-status {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.footer-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  opacity: 0.6;
}

.footer-status-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: #2e2d33;
  letter-spacing: 0.04em;
}

/* ── Status: Page Shell ────────────────────────────────────────────────────── */

.status-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ── Status: Header ────────────────────────────────────────────────────────── */

.status-header {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 36px var(--pad-x) 28px;
}

.status-op {
  display: flex;
  align-items: center;
  gap: 8px;
}

.status-op-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--dim);
  flex-shrink: 0;
  transition: background 0.3s;
}

.status-op-dot.is-ok    { background: var(--green); }
.status-op-dot.is-warn  { background: var(--amber); }
.status-op-dot.is-error { background: var(--red); }

.status-op-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.status-op-label.is-ok    { color: var(--green); }
.status-op-label.is-warn  { color: var(--amber); }
.status-op-label.is-error { color: var(--red); }

.page-heading {
  font-size: clamp(32px, 4.5vw, 52px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.03em;
  line-height: 1;
}

.page-heading .muted { font-weight: 300; color: #35333b; }

/* ── Status: Data Layout ───────────────────────────────────────────────────── */

.data-sections {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 0 var(--pad-x) 40px;
  flex: 1;
}

.data-row {
  display: flex;
  gap: 14px;
  align-items: stretch;
}

/* ── Status: Section Card ──────────────────────────────────────────────────── */

.section-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  flex: 1;
}

.section-card.wide { flex: 2; }
.section-card.mid  { flex: 1.4; }

.section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-sub);
  flex-shrink: 0;
  color: var(--blue);
}

.section-title {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ── Status: Big number stats ──────────────────────────────────────────────── */

.big-stats {
  display: flex;
  flex: 1;
}

.big-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  padding: 18px 20px;
  border-right: 1px solid var(--border-sub);
}

.big-stat:last-child { border-right: none; }

.big-stat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.big-stat-value {
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.big-stat-unit {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
}

/* ── Status: Row stats ─────────────────────────────────────────────────────── */

.row-stats {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.row-stat {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
  padding: 10px 20px;
  border-bottom: 1px solid var(--border-sub);
}

.row-stat:last-child { border-bottom: none; }

.row-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--dim);
  white-space: nowrap;
}

.row-value {
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  text-align: right;
}

.row-value .unit {
  font-size: 12px;
  font-weight: 400;
  color: var(--dim);
}

.row-value.mono {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
}

.row-value.ok    { color: var(--green); }
.row-value.muted { color: var(--dim); }

/* ── Animations ────────────────────────────────────────────────────────────── */

@keyframes pulse-blue {
  0%, 100% { box-shadow: 0 0 0 0 rgba(77, 156, 255, 0.5); }
  60%       { box-shadow: 0 0 0 5px rgba(77, 156, 255, 0); }
}
@keyframes pulse-green {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.6); }
  60%       { box-shadow: 0 0 0 5px rgba(34, 197, 94, 0); }
}

/* ── Responsive: Tablet ────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .nav-ts { display: none; }

  .hero { padding-top: 44px; }

  .locations { padding-top: 32px; flex-direction: column; }
  .loc-card  { min-height: auto; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }

  .data-row  { flex-direction: column; }
  .section-card.wide,
  .section-card.mid { flex: none; }
  .svc-row { grid-template-columns: repeat(3, 1fr); }
  .svc-links { display: none; }
}

/* ── Responsive: Mobile ────────────────────────────────────────────────────── */

@media (max-width: 480px) {
  .svc-row { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: 1fr; }
  .footer { flex-direction: column; align-items: flex-start; }

  /* Big stats wrap into 2-column grid on narrow screens */
  .big-stats { flex-wrap: wrap; }
  .big-stat {
    flex: 1 1 calc(50% - 1px);
    border-right: none;
    border-bottom: 1px solid var(--border-sub);
  }
  .big-stat:nth-child(odd)  { border-right: 1px solid var(--border-sub); }
  .big-stat:last-child      { border-bottom: none; }
  .big-stat:nth-last-child(2):nth-child(odd) { border-bottom: none; }
}

/* ── Power Flow Card ────────────────────────────────────────────────────────── */

.flow-card {
  margin: 0 var(--pad-x) 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.flow-card-hd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 18px 22px 4px;
}

.flow-card-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
}

.flow-card-sub {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--dim);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 3px;
}

.flow-live {
  display: flex;
  align-items: center;
  gap: 5px;
  padding-top: 2px;
}

.flow-live-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--green);
  animation: pulse-live 2.5s ease-in-out infinite;
}

.flow-live-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--green);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@keyframes pulse-live {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

.flow-wrap {
  padding: 4px 18px 10px;
  max-width: 460px;
  margin: 0 auto;
}

.flow-svg { width: 100%; height: auto; display: block; }

.flow-card-ft {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 22px;
  border-top: 1px solid var(--border-sub);
}

.flow-ft-stat {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.flow-ft-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--dim);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.flow-ft-val {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 500;
  color: var(--green);
}

/* Lines */
.fl {
  fill: none;
  stroke: #1e1e24;
  stroke-width: 3;
  stroke-dasharray: 8 5;
  stroke-linecap: round;
  transition: stroke 0.4s;
}
.fl.on       { animation: ff 0.7s linear infinite; }
.fl.on.rv    { animation: fr 0.7s linear infinite; }
.fl.c-sol    { stroke: var(--green); }
.fl.c-bat    { stroke: var(--blue); }
.fl.c-gIn    { stroke: var(--amber); }
.fl.c-gOut   { stroke: var(--green); }
.fl.c-ht     { stroke: #f97316; }

@keyframes ff { to { stroke-dashoffset: -13; } }
@keyframes fr { to { stroke-dashoffset:  13; } }

/* Nodes */
.nc {
  fill: var(--surface);
  stroke: var(--border);
  stroke-width: 1.5;
  transition: stroke 0.4s;
}
.nc.bdr-sol  { stroke: var(--green);  }
.nc.bdr-bat  { stroke: var(--blue);   }
.nc.bdr-gIn  { stroke: var(--amber);  }
.nc.bdr-gOut { stroke: var(--green);  }
.nc.bdr-ht   { stroke: #f97316;       }

/* ── Bartenbach: Top Row Layout ─────────────────────────────────────────────── */

.bt-top-row {
  display: flex;
  gap: 14px;
  padding: 0 var(--pad-x) 14px;
  align-items: stretch;
}

.flow-card-side {
  width: 380px;
  flex-shrink: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.bt-right-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

/* ── Battery Sub-Cards ──────────────────────────────────────────────────────── */

.bat-sub-cards {
  display: flex;
  flex: 1;
}

.bat-card {
  flex: 1;
  padding: 16px 20px;
  border-right: 1px solid var(--border-sub);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.bat-card:last-child { border-right: none; }

.bat-card-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.soc-num {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1;
}

.soc-bar-track {
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}

.soc-bar-fill {
  height: 100%;
  background: var(--blue);
  border-radius: 2px;
  width: 0%;
  transition: width 0.6s ease;
}

.bat-details {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 4px;
}

.bat-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}

.bat-detail-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--dim);
}

.bat-detail-val {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
}

/* ── Single Battery (Buchsweg) ──────────────────────────────────────────────── */

.bat-single-card {
  display: flex;
  flex: 1;
}

.bat-single-soc {
  display: flex;
  flex-direction: column;
  padding: 16px 20px;
  border-right: 1px solid var(--border-sub);
  width: 180px;
  flex-shrink: 0;
  gap: 8px;
}

.bat-single-details {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* ── Infra Bars ─────────────────────────────────────────────────────────────── */

.row-stat--bar { align-items: flex-start; }

.bar-col {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 5px;
}

.infra-bar-track {
  width: 80px;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}

.infra-bar-fill {
  height: 100%;
  background: var(--blue);
  border-radius: 2px;
  width: 0%;
  transition: width 0.6s ease;
}

.infra-bar-fill--green { background: var(--green); }

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

@media (max-width: 768px) {
  .bt-top-row     { flex-direction: column; padding-bottom: 0; }
  .flow-card-side { width: 100%; }
  .bat-sub-cards  { flex-direction: column; }
  .bat-card       { border-right: none; border-bottom: 1px solid var(--border-sub); }
  .bat-card:last-child { border-bottom: none; }
  .infra-bar-track { width: 60px; }
}

/* Node text */
.fn-lbl {
  font-size: 8px;
  fill: var(--dim);
  text-anchor: middle;
  font-family: var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.fn-val {
  font-size: 13px;
  fill: var(--text);
  text-anchor: middle;
  font-family: var(--font-mono);
  font-weight: 500;
}
.fn-sub {
  font-size: 9px;
  fill: var(--muted);
  text-anchor: middle;
  font-family: var(--font-mono);
}
