/*
 * Operational layout layer for the Flux placeholder.
 * Theme, typography, and shared component styling live in nohmad-flux-theme.css.
 * This file keeps the dashboard grids, cards, dialogs, and wallboard structure reusable.
 */

.panel-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

.row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.row.tight {
  gap: var(--space-2);
}

.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-width: 220px;
}

.field--grow {
  flex: 1 1 auto;
}

.field--min-160 {
  min-width: 160px;
}

.field--min-180 {
  min-width: 180px;
}

.field--min-200 {
  min-width: 200px;
}

.field--min-240 {
  min-width: 240px;
}

.field--min-260 {
  min-width: 260px;
}

.field--min-320 {
  min-width: 320px;
}

.field--max-220 {
  max-width: 220px;
}

.field--max-240 {
  max-width: 240px;
}

.field--max-320 {
  max-width: 320px;
}

.field--max-760 {
  max-width: 760px;
}

.grid-span-full {
  grid-column: 1 / -1;
}

.m-0 {
  margin: 0;
}

.mt-1 {
  margin-top: var(--space-1);
}

.mt-2 {
  margin-top: var(--space-2);
}

.mt-3 {
  margin-top: var(--space-3);
}

.mt-4 {
  margin-top: var(--space-4);
}

.mb-1 {
  margin-bottom: var(--space-1);
}

.mb-2 {
  margin-bottom: var(--space-2);
}

.mb-3 {
  margin-bottom: var(--space-3);
}

.note-meta {
  margin: 2px 0 0;
}

.note-meta-spaced {
  margin: 2px 0 var(--space-3);
}

.note-inset {
  margin: var(--space-2) var(--space-3);
}

.justify-between {
  justify-content: space-between;
}

.justify-end {
  justify-content: flex-end;
}

.items-center {
  align-items: center;
}

.items-end {
  align-items: flex-end;
}

.inline-choice {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.inline-choice--padded {
  padding: 6px 10px;
}

.text-strong {
  font-weight: 700;
}

.popup-card {
  min-width: 220px;
  font-family: 'Space Grotesk', 'Segoe UI', sans-serif;
}

.popup-card__address {
  margin-top: 6px;
  font-size: 12px;
  opacity: 0.85;
}

.popup-card__actions {
  margin-top: 10px;
}

.sites-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.map-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
}

.map-canvas {
  width: 100%;
  height: 520px;
}

.map-canvas--dialog {
  height: 280px;
}

.desktop-table-wrap {
  border-radius: var(--radius-md);
  overflow: auto;
}

.status-stack,
.telemetry-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.action-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.action-row button {
  min-height: 32px;
  font-size: 12px;
  padding: 6px 10px;
}

.org-users-layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-5);
  align-items: start;
}

.picker-results {
  overflow: auto;
  max-height: 220px;
}

.picker-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 10px 12px;
}

.picker-item:first-child {
  border-top: 0;
}

.picker-item strong {
  display: block;
  font-size: 13px;
  letter-spacing: 0.2px;
}

.picker-item .tiny {
  margin: 0;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border-radius: 999px;
  padding: 6px 10px;
}

.chip button {
  min-height: 22px;
  padding: 2px 8px;
  font-size: 11px;
}

dialog.dialog {
  padding: 0;
  width: min(860px, calc(100vw - 36px));
}

dialog.dialog::backdrop {
  background: rgba(2, 10, 18, 0.72);
}

.dialog-surface {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
}

.dialog-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
}

.dialog-body {
  padding: var(--space-4) var(--space-5) var(--space-5);
}

.dialog-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-3);
}

.access-list {
  padding: var(--space-2);
  min-height: 80px;
}

.access-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: 6px 6px;
}

.dialog-add {
  margin-top: var(--space-4);
}

.latest-block {
  padding: var(--space-3);
}

.latest-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-2);
}

.latest-item {
  border-radius: 8px;
  padding: 8px;
}

.latest-item .k {
  margin: 0;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.latest-item .v {
  margin: 2px 0 0;
  font-size: 12px;
}

.site-cards {
  display: none;
}

.site-card {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.kv-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}

.kv {
  border-radius: 8px;
  padding: 8px;
}

.kv p {
  margin: 0;
}

.kv .k {
  font-size: 10px;
  text-transform: uppercase;
}

.kv .v {
  font-size: 12px;
  margin-top: 3px;
  overflow-wrap: anywhere;
}

.tab-tools {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.tab-tools .status-line {
  font-size: 12px;
}

.charger-details-row td {
  border-top: 0;
  padding: 0 10px 12px;
}

.charger-details-panel {
  padding: var(--space-3);
}

.charger-details-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.charger-details-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.charger-session-details {
  margin-top: var(--space-3);
}

.charger-session-details .charger-details-panel {
  border: 0;
  background: transparent;
  padding: 0;
}

.history-table-wrap {
  margin-top: var(--space-2);
  border-radius: var(--radius-sm);
  overflow: auto;
}

table.history-table {
  min-width: 0;
}

.history-table th,
.history-table td {
  padding: 9px 10px;
  font-size: 11px;
}

.history-table th {
  font-size: 10px;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-3);
}

.lms-tree {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.tree-depth-0 {
  margin-left: 0;
}

.tree-depth-1 {
  margin-left: 16px;
}

.tree-depth-2 {
  margin-left: 32px;
}

.tree-depth-3 {
  margin-left: 48px;
}

.tree-depth-4 {
  margin-left: 64px;
}

.tree-depth-5 {
  margin-left: 80px;
}

.tree-depth-6 {
  margin-left: 96px;
}

.tree-depth-7 {
  margin-left: 112px;
}

.tree-depth-8 {
  margin-left: 128px;
}

.tree-depth-9 {
  margin-left: 144px;
}

.tree-depth-10 {
  margin-left: 160px;
}

.tree-depth-11 {
  margin-left: 176px;
}

.tree-depth-12 {
  margin-left: 192px;
}

.lms-tree-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-2);
  align-items: baseline;
}

.lms-tree-phase-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.lms-tree-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
}

.lms-tree-charger {
  padding: 6px 10px;
  font-size: 12px;
}

.lms-tree-charger p {
  margin: 0;
}

.lms-tree-charger-id {
  margin-left: 6px;
}

.wallboard-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.wallboard-viewport {
  padding: var(--space-3);
  height: clamp(420px, 72vh, 780px);
  min-height: 420px;
  overflow: hidden;
}

.wallboard-grid {
  width: 100%;
  height: 100%;
  display: grid;
  gap: var(--space-2);
  grid-template-columns: repeat(1, minmax(0, 1fr));
  grid-auto-rows: minmax(120px, 1fr);
}

.wallboard-tile {
  text-align: left;
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: space-between;
  cursor: pointer;
  min-width: 0;
}

.wallboard-sub {
  margin: 0;
  font-size: clamp(0.65rem, 0.82vw, 0.82rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.wallboard-last {
  margin: 0;
  font-size: clamp(0.6rem, 0.72vw, 0.72rem);
}

body.wallboard-fullscreen .app {
  max-width: none;
  margin: 0;
  min-height: 100vh;
  padding: 0;
}

body.wallboard-fullscreen #topbar,
body.wallboard-fullscreen #initBanner,
body.wallboard-fullscreen #appFooter {
  display: none;
}

body.wallboard-fullscreen #mainGrid {
  gap: 0;
}

body.wallboard-fullscreen #wallboardCard {
  border-radius: 0;
  border: 0;
  box-shadow: none;
  min-height: 100vh;
  width: 100%;
}

body.wallboard-fullscreen #wallboardCard .wallboard-viewport {
  height: calc(100vh - 138px);
  min-height: 0;
  border-radius: 0;
}

@media (min-width: 980px) {
  .panel-grid {
    grid-template-columns: 1fr 1fr;
  }

  .span-full {
    grid-column: 1 / -1;
  }
}

@media (max-width: 1023px) {
  .desktop-table-wrap {
    display: none;
  }

  .org-table-wrap {
    display: block;
  }

  .org-users-layout {
    grid-template-columns: 1fr;
  }

  .site-cards {
    display: grid;
    gap: var(--space-3);
  }
}

@media (max-width: 620px) {
  .topbar {
    flex-direction: column;
  }

  .top-meta {
    justify-content: flex-start;
  }

  .auth-block {
    align-items: flex-start;
    width: 100%;
    margin-left: 0;
  }

  .auth-actions {
    justify-content: flex-start;
  }

  .auth-lines {
    text-align: left;
  }

  .account-menu-panel {
    left: 0;
    right: auto;
  }

  .field {
    min-width: 100%;
  }

  .kv-grid {
    grid-template-columns: 1fr;
  }

  .map-canvas {
    height: 360px;
  }

  .map-canvas--dialog {
    height: 240px;
  }

  .dialog-grid {
    grid-template-columns: 1fr;
  }

  .wallboard-viewport {
    height: 74vh;
    min-height: 320px;
  }
}
