body.dashboard-body {
  margin: 0;
  font-family: Arial, sans-serif;
  background-color: #111821; /* dark */
  color: #f5f5f5;
}

/* Top bar */

.top-bar {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  align-items: center;
  padding: 8px 16px;
  background-color: #18212c;
  border-bottom: 1px solid #2b3a4b;
}

.logo-placeholder {
  color: #cdd9e5;
  font-weight: bold;
}

.top-center,
.top-right {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.top-label {
  font-size: 0.85rem;
  color: #9fb3c8;
}

.top-select,
.top-input {
  background-color: #111821;
  border: 1px solid #2b3a4b;
  color: #f5f5f5;
  padding: 4px 8px;
  border-radius: 4px;
}

.top-button {
  background-color: #2f4858; /* KB/Earthline blue */
  border: none;
  color: #f5f5f5;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
}

.top-button:hover {
  background-color: #3d5f73;
}

/* Dashboard grid */

.dashboard-main {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 56px); /* full height minus header */
}

.nc-dashboard {
  display: grid;
  grid-template-columns: 300px 1fr;
  grid-template-rows: 1fr 200px;
  gap: 8px;
  padding: 8px;
  height: 100%;
}

.left-panel,
.map-panel,
.bottom-panel {
  background-color: #18212c;
  border: 1px solid #2b3a4b;
  padding: 8px;
}

.left-panel {
  grid-row: 1 / 3; /* tall left column */
}

.map-panel {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}

.bottom-panel {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
}