/* ===========================================================
   Daan Display Dashboard — terminal-style monochrome theme
   =========================================================== */

:root {
  --bg: #0a0a0c;
  --panel: #111114;
  --panel-soft: #15151a;
  --border: #1f1f25;
  --text: #e6e3da;
  --muted: #7a7a82;
  --muted-2: #50505a;
  --green: #4ade80;
  --green-soft: #1f3324;
  --orange: #f59e0b;
  --orange-soft: #3a2710;
  --red: #ef4444;
  --red-soft: #3a1414;
  --blue: #38bdf8;
  --blue-soft: #0e2a3a;

  --font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular,
    Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --gap: 18px;
  --pad: 14px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.45;
  letter-spacing: 0.2px;
  min-height: 100vh;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ----- Layout ------------------------------------------------ */
.app {
  padding: 22px 28px 90px;
  max-width: 100%;
}

header.top {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 24px;
  margin-bottom: 26px;
}

.brand {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}

.brand-logo {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.brand-logo .name {
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 800;
  font-size: 30px;
  letter-spacing: -0.02em;
}
.brand-logo .name::after {
  content: ".";
  color: var(--green);
}
.brand-logo .name .reg {
  font-size: 0.55em;
  vertical-align: super;
  margin-left: 2px;
  color: var(--muted);
}
.brand-logo .sub {
  font-size: 9px;
  color: var(--muted);
  letter-spacing: 0.18em;
  margin-top: 6px;
  text-transform: uppercase;
}

.brand-title {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 6px;
}
.brand-title .label {
  font-size: 12px;
  letter-spacing: 0.4em;
  color: var(--muted);
}
.brand-title .live {
  font-size: 11px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.brand-title .live::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
}

.clock-block {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}
.clock-block .clock {
  font-size: 56px;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1;
}
.clock-block .meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--muted);
}
.clock-block .weather {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text);
}

/* ----- KPI cards -------------------------------------------- */
.kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
  margin-bottom: 22px;
}

.kpi {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 18px 16px;
}
.kpi .label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.28em;
  text-transform: uppercase;
}
.kpi .value {
  font-size: 56px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 4px;
  line-height: 1;
}
.kpi.online .value { color: var(--green); }
.kpi.warning .value { color: var(--orange); }
.kpi.offline .value { color: var(--red); }

.kpi .deltas {
  display: flex;
  gap: 14px;
  margin-top: 14px;
  font-size: 11px;
  color: var(--muted);
}
.kpi .deltas .d-up { color: var(--green); }
.kpi .deltas .d-down { color: var(--red); }
.kpi .deltas .d-flat { color: var(--muted); }

/* ----- Columns ---------------------------------------------- */
.grid {
  display: grid;
  grid-template-columns: 1.1fr 1.1fr 1.1fr 1.2fr;
  gap: var(--gap);
}

.column {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.column-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 6px;
  border-bottom: 1px solid transparent;
  margin-bottom: 4px;
}
.column-header .title {
  font-size: 13px;
  letter-spacing: 0.3em;
  color: var(--muted);
  text-transform: uppercase;
}
.column-header .refreshed {
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--muted-2);
}

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: var(--pad);
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
}

.card.tone-offline { box-shadow: inset 3px 0 0 var(--red); background: linear-gradient(90deg, rgba(239,68,68,0.06), transparent 30%); }
.card.tone-warning { box-shadow: inset 3px 0 0 var(--orange); background: linear-gradient(90deg, rgba(245,158,11,0.05), transparent 30%); }
.card.tone-online { box-shadow: inset 3px 0 0 transparent; }

.card .row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

/* ----- Website card ----------------------------------------- */
.site-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--text);
}
.site-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 11px;
  color: var(--muted);
}
.site-meta .ms { color: var(--muted); }
.site-meta .code-warning { color: var(--orange); }
.site-meta .code-bad { color: var(--red); }

.tags {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.ip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 11px;
  color: var(--muted);
}
.ip.cf::after {
  content: "";
  width: 10px;
  height: 10px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23f59e0b'><path d='M11.4 11.6h-7c-.7 0-1.3-.5-1.4-1.2-.1-.7.3-1.4 1-1.6.1 0 .2-.1.2-.2C4.3 7.4 5.4 6.5 6.7 6.5c.9 0 1.7.4 2.3 1.1.2.2.5.3.7.2.6-.1 1.2.2 1.4.7l.4-.7c.3-.5.9-.7 1.4-.5.5.2.8.7.7 1.2l-.6 2.6c-.1.4-.5.8-1 .8z'/></svg>") center/contain no-repeat;
  opacity: .8;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid var(--border);
  color: var(--muted);
  background: var(--panel-soft);
  font-weight: 600;
}
.badge.green { color: var(--green); border-color: rgba(74,222,128,0.25); background: rgba(74,222,128,0.05); }
.badge.orange { color: var(--orange); border-color: rgba(245,158,11,0.25); background: rgba(245,158,11,0.05); }
.badge.red { color: var(--red); border-color: rgba(239,68,68,0.25); background: rgba(239,68,68,0.05); }
.badge.blue { color: var(--blue); border-color: rgba(56,189,248,0.25); background: rgba(56,189,248,0.05); }
.badge.solid-red { background: rgba(239,68,68,0.18); color: #ffb6b6; border-color: rgba(239,68,68,0.4); }
.badge.solid-orange { background: rgba(245,158,11,0.18); color: #ffd996; border-color: rgba(245,158,11,0.4); }
.badge.solid-green { background: rgba(74,222,128,0.18); color: #b6f7c8; border-color: rgba(74,222,128,0.4); }

.records {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}
.records .label {
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--muted-2);
  text-transform: uppercase;
  margin-right: 4px;
}

/* ----- Network device / console ----------------------------- */
.device-name { font-weight: 600; font-size: 13px; }
.device-sub { font-size: 11px; color: var(--muted); }
.device-sub .model {
  display: inline-block;
  padding: 1px 6px;
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-left: 6px;
  color: var(--muted);
  font-size: 10px;
}

.timing {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
}

/* ----- Backups ---------------------------------------------- */
.backup-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 4px;
  padding: 8px 10px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.backup-summary .last-24h { color: var(--muted); font-size: 11px; margin-left: auto; }
.backup-summary .sizes { color: var(--muted); font-size: 11px; }

.tenant {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.tenant.tone-warning { box-shadow: inset 3px 0 0 var(--orange); background: linear-gradient(90deg, rgba(245,158,11,0.05), transparent 30%); }
.tenant.tone-offline { box-shadow: inset 3px 0 0 var(--red); }
.tenant .head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.tenant .name { font-weight: 600; }
.tenant .last { font-size: 11px; color: var(--muted); }
.tenant .item {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 8px;
  font-size: 11px;
  align-items: center;
}
.tenant .item .label {
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--muted-2);
  text-transform: uppercase;
}
.tenant .item .name-col { color: var(--text); }
.tenant .item .msg { color: var(--muted); font-size: 10px; grid-column: 1 / -1; padding-left: 78px; line-height: 1.4; }
.tenant .item .count { color: var(--muted); font-size: 10px; }

.console-summary {
  font-size: 11px;
  color: var(--green);
  margin-top: 10px;
}

.recovered {
  margin-top: 18px;
  font-size: 11px;
  color: var(--muted);
}
.recovered .header {
  letter-spacing: 0.2em;
  color: var(--muted-2);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.recovered .row {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  padding: 2px 0;
}
.recovered .row .when { color: var(--muted); }

/* ----- Footer summary -------------------------------------- */
.footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  font-size: 10px;
  letter-spacing: 0.1em;
  background: linear-gradient(0deg, rgba(10,10,12,0.95), rgba(10,10,12,0.0));
  padding: 18px 28px 14px;
  pointer-events: none;
  text-transform: lowercase;
}
.footer .col { color: var(--muted); }
.footer .col .ok { color: var(--green); }
.footer .col .warn { color: var(--orange); }
.footer .col .bad { color: var(--red); }

/* ----- Misc -------------------------------------------------- */
.spacer { height: 8px; }
.dim { color: var(--muted); }
.right { margin-left: auto; }

/* HTMX swap fade */
.htmx-swapping { opacity: .4; transition: opacity .2s ease; }
.htmx-settling { opacity: 1; }

.empty-ok {
  text-align: center;
  color: var(--green);
  font-size: 12px;
  padding: 24px 12px;
  border: 1px dashed rgba(74,222,128,0.25);
  border-radius: 10px;
  letter-spacing: 0.1em;
}

/* Scan progress bar (websites kolom) */
.scan-progress {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 4px;
}
.scan-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
}
.scan-label {
  font-size: 9px;
  letter-spacing: 0.22em;
  color: var(--muted);
  text-transform: uppercase;
}
.scan-counter {
  color: var(--text);
}
.scan-pct {
  margin-left: auto;
  color: var(--green);
  font-weight: 600;
}
.scan-bar {
  height: 4px;
  background: var(--panel-soft);
  border-radius: 2px;
  overflow: hidden;
}
.scan-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--green), #22d39a);
  border-radius: 2px;
  transition: width 0.4s ease;
}
