:root {
  --bg: #07110c;
  --bg-secondary: #0a1811;
  --panel: rgba(12, 24, 18, 0.92);
  --panel-strong: rgba(16, 31, 23, 0.98);
  --panel-soft: rgba(13, 27, 19, 0.82);
  --border: rgba(77, 148, 103, 0.2);
  --border-strong: rgba(101, 255, 148, 0.34);
  --text: #edf8ef;
  --muted: #8ba292;
  --accent: #00c805;
  --accent-soft: rgba(0, 200, 5, 0.14);
  --accent-strong: #7cff98;
  --sidebar: linear-gradient(180deg, rgba(7, 18, 12, 0.98) 0%, rgba(5, 11, 8, 0.98) 100%);
  --sidebar-text: #ebf5ed;
  --sidebar-muted: #7f9986;
  --good: #7cff98;
  --warn: #f6c45a;
  --bad: #ff6b6b;
  --info: #57d6ff;
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(31, 107, 57, 0.18), transparent 26%),
    radial-gradient(circle at 80% 10%, rgba(0, 200, 5, 0.08), transparent 22%),
    linear-gradient(180deg, #08120d 0%, #050b08 100%);
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(124, 255, 152, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124, 255, 152, 0.025) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: 0.35;
}

.welcome-gate {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(0, 0, 0, 0.74);
  backdrop-filter: blur(8px);
}

.welcome-card {
  width: min(720px, 100%);
  max-height: min(820px, calc(100vh - 36px));
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.20);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(10, 21, 16, 0.98), rgba(3, 8, 6, 0.98));
  box-shadow: 0 28px 96px rgba(0, 0, 0, 0.62);
  padding: 24px;
}

.welcome-card h2 {
  margin: 4px 0 8px;
  font-size: 1.7rem;
}

.welcome-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 0;
}

.welcome-option {
  min-height: 116px;
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 15px;
  border: 1px solid rgba(124, 255, 152, 0.14);
  border-radius: 12px;
  background: rgba(4, 10, 7, 0.58);
  color: var(--text);
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.welcome-option:hover,
.welcome-option:focus-visible {
  border-color: rgba(124, 255, 152, 0.36);
  background: rgba(124, 255, 152, 0.08);
}

.welcome-option.primary {
  border-color: rgba(0, 200, 5, 0.42);
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.18), rgba(4, 10, 7, 0.72));
}

.welcome-option strong {
  font-size: 1rem;
}

.welcome-option span {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.welcome-auth-form {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(124, 255, 152, 0.10);
}

.welcome-auth-tabs {
  display: inline-flex;
  width: max-content;
  padding: 3px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 10px;
  background: rgba(2, 6, 4, 0.48);
}

.welcome-auth-tabs button {
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  padding: 7px 12px;
  font-weight: 800;
  cursor: pointer;
}

.welcome-auth-tabs button.active {
  background: rgba(0, 200, 5, 0.18);
  color: var(--text);
}

.welcome-auth-form label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.welcome-auth-form input {
  width: 100%;
  min-height: 39px;
  border: 1px solid rgba(124, 255, 152, 0.14);
  border-radius: 10px;
  background: rgba(2, 6, 4, 0.72);
  color: var(--text);
  padding: 8px 10px;
}

@media (max-width: 720px) {
  .welcome-options {
    grid-template-columns: 1fr;
  }

  .welcome-option {
    min-height: 84px;
  }
}

.chart-hover-tooltip {
  position: fixed;
  z-index: 9999;
  min-width: 180px;
  max-width: 280px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(124, 255, 152, 0.18);
  background: linear-gradient(180deg, rgba(10, 21, 16, 0.98), rgba(6, 12, 9, 0.98));
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.42);
  color: var(--text);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 100ms ease, transform 100ms ease;
}

.chart-hover-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

.chart-hover-tooltip .eyebrow {
  margin-bottom: 6px;
}

.chart-hover-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  margin-bottom: 6px;
}

.chart-hover-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
  flex: 0 0 auto;
}

.chart-hover-tooltip .subtle {
  color: var(--muted);
  margin: 0;
  font-size: 0.84rem;
}

.app-shell {
  height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 190px;
  overflow: hidden;
}

.mobile-topbar,
.mobile-page-dropdown,
.mobile-backdrop {
  display: none;
}

.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 130;
  height: 62px;
  width: min(32vw, 430px);
  padding: 8px 12px;
  background: var(--sidebar);
  color: var(--sidebar-text);
  display: block;
  align-items: center;
  gap: 8px;
  border-right: 1px solid rgba(124, 255, 152, 0.08);
  border-bottom: 1px solid rgba(124, 255, 152, 0.08);
  border-bottom-right-radius: 14px;
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.28);
  overflow: hidden;
}

.sidebar .brand,
.sidebar .status-card {
  display: none;
}

.brand,
.status-card,
.panel,
.flow-strip {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 22px;
  box-shadow: var(--shadow);
}

.brand {
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(15, 34, 23, 0.96) 0%, rgba(10, 21, 15, 0.95) 100%);
}

.brand h1,
.hero h2,
.panel h3,
.status-card h2 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.68rem;
  color: var(--accent-strong);
}

.subtle {
  color: var(--muted);
  line-height: 1.5;
}

#station-subtitle:empty {
  display: none;
}

.sidebar .subtle {
  color: var(--sidebar-muted);
}

.station-nav {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  padding-bottom: 2px;
}

.sidebar-map-button {
  border: 1px solid rgba(87, 214, 255, 0.18);
  background: linear-gradient(180deg, rgba(9, 23, 25, 0.96), rgba(7, 16, 18, 0.96));
  color: var(--text);
  border-radius: 10px;
  padding: 9px 11px;
  cursor: pointer;
  font: inherit;
  font-weight: 700;
  text-align: left;
  white-space: nowrap;
  font-size: 0.78rem;
}

.sidebar-map-button:hover {
  border-color: rgba(87, 214, 255, 0.34);
}

.station-button {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background:
    linear-gradient(180deg, rgba(16, 30, 23, 0.88) 0%, rgba(10, 18, 14, 0.9) 100%);
  color: inherit;
  text-align: left;
  border-radius: 10px;
  padding: 8px 10px;
  cursor: pointer;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
  min-width: 84px;
  flex: 0 0 auto;
}

.station-button:hover {
  transform: translateY(-1px);
  border-color: rgba(124, 255, 152, 0.22);
}

.station-button.active {
  border-color: var(--border-strong);
  background:
    linear-gradient(180deg, rgba(16, 37, 25, 0.98) 0%, rgba(10, 24, 16, 0.96) 100%);
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.08), 0 12px 28px rgba(0, 0, 0, 0.35);
}

.station-button-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.station-button .station-button-head {
  gap: 5px;
}

.station-button strong {
  font-size: 0.86rem;
}

.station-button .station-badge,
.sidebar .station-button > span,
.sidebar .station-mini-grid,
.station-button .station-subtle,
.station-button small {
  display: none;
}

.station-badge {
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: rgba(124, 255, 152, 0.1);
  color: var(--accent-strong);
}

.station-button strong,
.station-button span,
.station-button label {
  display: block;
}

.station-button > span {
  margin-top: 5px;
  color: var(--sidebar-muted);
  font-size: 0.92rem;
}

.station-mini-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.station-mini-grid div {
  padding: 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(124, 255, 152, 0.06);
}

.station-mini-grid div.ibkr-stale {
  background: rgba(255, 178, 71, 0.1);
  border-color: rgba(255, 178, 71, 0.45);
  box-shadow: inset 0 0 16px rgba(255, 178, 71, 0.05);
}

.station-mini-grid div.ibkr-down {
  background: rgba(255, 86, 86, 0.12);
  border-color: rgba(255, 86, 86, 0.55);
  box-shadow: inset 0 0 18px rgba(255, 86, 86, 0.08);
}

.station-mini-grid label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--sidebar-muted);
  margin-bottom: 4px;
}

.station-mini-grid strong {
  font-size: 1rem;
  color: var(--text);
}

.station-mini-grid small {
  display: block;
  margin-top: 3px;
  color: var(--sidebar-muted);
  font-size: 0.66rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.market-warning-triangle {
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 5px;
  transform: translateY(1px);
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 9px solid #ffb247;
  filter: drop-shadow(0 0 6px rgba(255, 178, 71, 0.6));
}

.station-button.ibkr-stale {
  border-color: rgba(255, 178, 71, 0.3);
}

.station-button.ibkr-down {
  border-color: rgba(255, 86, 86, 0.32);
}

.status-card {
  padding: 16px;
  background: linear-gradient(180deg, rgba(11, 23, 17, 0.94) 0%, rgba(8, 17, 12, 0.95) 100%);
}

.status-row {
  padding: 12px 0;
  border-top: 1px solid rgba(124, 255, 152, 0.08);
}

.status-row:first-child {
  border-top: 0;
}

.status-row strong {
  color: var(--accent-strong);
}

.status-row strong,
.status-row span {
  display: block;
}

.main-panel {
  padding: 132px 26px 26px;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
}

.panel-rail {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 20px 10px;
  border-left: 1px solid rgba(124, 255, 152, 0.08);
  background: linear-gradient(180deg, rgba(6, 16, 11, 0.98), rgba(4, 10, 7, 0.98));
  overflow-y: auto;
}

.panel-rail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.panel-rail-head .eyebrow {
  margin: 0;
}

.panel-rail-reset {
  border: 1px solid rgba(124, 255, 152, 0.14);
  background: rgba(11, 23, 17, 0.86);
  color: var(--muted);
  border-radius: 999px;
  padding: 6px 9px;
  cursor: pointer;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 700;
}

.panel-rail-reset:hover {
  color: var(--text);
  border-color: rgba(124, 255, 152, 0.34);
}

.panel-rail-note {
  margin: 10px 0 12px;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.35;
}

.panel-rail-list {
  display: grid;
  gap: 7px;
}

.panel-rail-empty {
  padding: 10px;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
  border: 1px solid rgba(124, 255, 152, 0.1);
  border-radius: 10px;
  background: rgba(12, 24, 18, 0.58);
}

.panel-rail-item {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 8px;
  border: 1px solid rgba(124, 255, 152, 0.11);
  border-radius: 10px;
  background: rgba(12, 24, 18, 0.74);
  color: var(--text);
  cursor: grab;
  user-select: none;
}

.panel-rail-item.dragging {
  opacity: 0.45;
}

.panel-rail-item.selected {
  border-color: rgba(124, 255, 152, 0.58);
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.18), rgba(12, 24, 18, 0.82));
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.12), 0 10px 24px rgba(0, 0, 0, 0.22);
}

.panel-rail-item.drop-before,
.panel-rail-item.drop-after {
  position: relative;
}

.panel-rail-item.drop-before::before,
.panel-rail-item.drop-after::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  height: 3px;
  border-radius: 999px;
  background: var(--accent-strong);
  box-shadow: 0 0 12px rgba(124, 255, 152, 0.55);
}

.panel-rail-item.drop-before::before {
  top: -6px;
}

.panel-rail-item.drop-after::after {
  bottom: -6px;
}

.panel-rail-item.hidden-panel {
  opacity: 0.58;
}

.panel-rail-toggle {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.36);
  background: var(--accent-strong);
  box-shadow: 0 0 12px rgba(124, 255, 152, 0.2);
  cursor: pointer;
}

.panel-rail-item.hidden-panel .panel-rail-toggle {
  background: transparent;
  border-color: rgba(139, 162, 146, 0.55);
  box-shadow: none;
}

.panel-rail-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.78rem;
  font-weight: 750;
  cursor: pointer;
}

.panel-managed-hidden {
  display: none !important;
}

.hero {
  position: relative;
  top: auto;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 20px;
  align-items: start;
  padding: 0 0 12px;
  background: transparent;
  backdrop-filter: none;
}

#station-subnav {
  position: fixed;
  top: 8px;
  right: 204px;
  left: min(34vw, 456px);
  z-index: 135;
  margin-top: 0;
  justify-content: flex-end;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding: 4px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(7, 18, 12, 0.98), rgba(5, 11, 8, 0.98));
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.28);
}

#station-subnav .subnav-button {
  flex: 0 0 auto;
  padding: 7px 7px;
  font-size: 0.68rem;
  white-space: nowrap;
}

.command-health-strip {
  position: fixed;
  top: 76px;
  left: 12px;
  right: 204px;
  z-index: 132;
  display: grid;
  grid-template-columns: minmax(230px, 0.68fr) minmax(0, 1.32fr);
  gap: 10px;
  align-items: center;
  min-height: 44px;
}

.command-box {
  min-width: 0;
  height: 44px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(7, 18, 12, 0.98), rgba(5, 11, 8, 0.98));
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
}

.command-prefix {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  border: 1px solid rgba(124, 255, 152, 0.14);
  color: var(--accent-strong);
  background: rgba(0, 200, 5, 0.08);
  font-weight: 900;
}

#command-palette-input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 0.82rem;
}

#command-palette-input::placeholder {
  color: rgba(139, 162, 146, 0.72);
}

.data-health-strip {
  min-width: 0;
  height: 44px;
  display: flex;
  gap: 8px;
  align-items: center;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(7, 18, 12, 0.98), rgba(5, 11, 8, 0.98));
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
  scrollbar-width: thin;
}

.health-group {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 6px 8px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 10px;
  background: rgba(12, 24, 18, 0.7);
}

.health-group-label {
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 850;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.health-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--text);
  font-size: 0.7rem;
  font-weight: 800;
  white-space: nowrap;
}

.health-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--muted);
  box-shadow: 0 0 0 2px rgba(139, 162, 146, 0.12);
}

.health-dot.good {
  background: var(--good);
  box-shadow: 0 0 12px rgba(124, 255, 152, 0.32);
}

.health-dot.lagging {
  background: var(--warn);
  box-shadow: 0 0 12px rgba(246, 196, 90, 0.3);
}

.health-dot.bad {
  background: var(--bad);
  box-shadow: 0 0 12px rgba(255, 107, 107, 0.28);
}

.health-dot.unknown {
  background: var(--muted);
}

.graph-data-toggle {
  width: 100%;
  margin: 12px 0 0;
  display: flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(4, 10, 7, 0.52);
  color: var(--text);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
  text-align: left;
}

.graph-data-toggle:hover {
  border-color: rgba(124, 255, 152, 0.3);
  background: rgba(0, 200, 5, 0.08);
}

.graph-data-arrow {
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(124, 255, 152, 0.1);
  color: var(--accent-strong);
  font-size: 1.1rem;
  line-height: 1;
  transition: transform 140ms ease;
}

.graph-data-toggle[aria-expanded="true"] .graph-data-arrow {
  transform: rotate(90deg);
}

.graph-data-collapsed {
  display: none;
}

.global-market-watch {
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, 1fr));
  gap: 10px;
  min-width: 0;
}

.master-shell {
  display: grid;
  grid-template-columns: 86px minmax(0, 1.5fr) minmax(292px, 0.58fr);
  gap: 10px;
  align-items: stretch;
  min-height: calc(100vh - 172px);
}

.master-meter-panel,
.master-panel {
  min-width: 0;
  overflow: hidden;
}

.master-meter-panel {
  padding: 10px 8px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
}

.master-meter-head h3,
.master-panel-head h3 {
  margin: 2px 0 0;
}

.master-workspace {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: minmax(430px, 50vh) auto auto auto;
  grid-template-areas:
    "temp range"
    "fields fields"
    "analog analog"
    "cams cams";
  gap: 10px;
}

.master-side {
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto minmax(250px, 1fr);
  gap: 10px;
}

.master-temperature-panel {
  grid-area: temp;
}

.master-range-panel {
  grid-area: range;
}

.master-field-panel {
  grid-area: fields;
}

.master-analog-panel {
  grid-area: analog;
}

.master-camera-panel {
  grid-area: cams;
}

.master-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}

.master-chip {
  flex: 0 0 auto;
  padding: 5px 8px;
  border: 1px solid rgba(124, 255, 152, 0.18);
  border-radius: 999px;
  background: rgba(0, 200, 5, 0.08);
  color: var(--accent-strong);
  font-size: 0.7rem;
  font-weight: 850;
  white-space: nowrap;
}

.master-chart {
  min-height: 0;
  height: 100%;
  overflow: hidden;
}

.master-chart-svg {
  display: block;
  width: 100%;
  height: calc(100% - 28px);
  min-height: 350px;
}

.master-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 2px 5px;
}

.master-chart-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.master-chart-legend-item i {
  width: 18px;
  height: 3px;
  border-radius: 999px;
}

.master-heat-meter {
  min-height: 520px;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 10px;
}

.master-meter-scale {
  position: relative;
  min-height: 390px;
}

.master-temperature-panel,
.master-range-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 430px;
}

.master-panel.command-focus,
.master-meter-panel.command-focus {
  border-color: rgba(124, 255, 152, 0.72);
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.2), 0 0 32px rgba(0, 200, 5, 0.2);
}

.dash-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
  padding: 0 2px;
}

.dash-toolbar h2 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.dash-toolbar .panel-note {
  margin: 4px 0 0;
}

.dash-toolbar .panel-note strong {
  color: var(--accent-strong);
}

.dash-actions {
  flex: 0 0 auto;
  display: flex;
  gap: 8px;
}

.dash-command-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 0.76rem;
}

.dash-command-list span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.42);
}

.dash-command-list b {
  color: var(--text);
}

.dash-command-list code {
  color: var(--accent-strong);
  font-family: "IBM Plex Mono", "Cascadia Code", monospace;
  font-size: 0.72rem;
}

.dash-canvas {
  position: relative;
  min-height: calc(100vh - 215px);
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 14px;
  background:
    linear-gradient(rgba(124, 255, 152, 0.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124, 255, 152, 0.026) 1px, transparent 1px),
    rgba(4, 10, 7, 0.38);
  background-size: 32px 32px;
}

.dash-mode .hero {
  display: none;
}

.dash-mode .main-panel {
  padding-top: 10px;
}

.dash-mode .dash-toolbar {
  margin-bottom: 6px;
}

.dash-mode .dash-command-list {
  display: none;
}

.dash-mode .dash-canvas {
  min-height: calc(100vh - 138px);
  border-radius: 10px;
}

.dash-mode #station-nav {
  visibility: hidden;
}

.dash-mode .command-health-strip {
  position: fixed;
  left: 18px;
  top: 8px;
  z-index: 160;
  width: min(32vw, 430px);
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 12px;
  background: rgba(5, 11, 8, 0.96);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.36);
}

.dash-mode .data-health-strip {
  display: none;
}

.dash-command-reference {
  position: sticky;
  bottom: 0;
  z-index: 40;
  display: flex;
  gap: 7px;
  align-items: center;
  min-height: 44px;
  margin-top: 8px;
  padding: 7px 8px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(7, 18, 12, 0.98), rgba(5, 11, 8, 0.98));
  box-shadow: 0 -12px 34px rgba(0, 0, 0, 0.24);
  overflow-x: auto;
}

.dash-command-reference-title {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
}

.dash-command-chip {
  flex: 0 0 auto;
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 8px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 999px;
  background: rgba(4, 10, 7, 0.52);
  color: var(--text);
  cursor: pointer;
}

.dash-command-chip:hover {
  border-color: rgba(124, 255, 152, 0.34);
  background: rgba(124, 255, 152, 0.08);
}

.dash-command-chip b {
  max-width: 7ch;
  overflow: hidden;
  color: var(--accent-strong);
  font-size: 0.68rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-command-chip code {
  color: var(--muted);
  font-family: "IBM Plex Mono", "Cascadia Code", monospace;
  font-size: 0.64rem;
}

.dash-widget-actions {
  display: inline-flex;
  gap: 6px;
}

.dash-widget-hidden {
  display: none;
}

.dash-widget.command-focus {
  border-color: rgba(124, 255, 152, 0.72);
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.2), 0 0 32px rgba(0, 200, 5, 0.2);
}

.dash-empty {
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  gap: 8px;
  text-align: center;
  color: var(--muted);
  pointer-events: none;
}

.dash-empty strong {
  color: var(--text);
  font-size: 1.35rem;
}

.dash-empty b {
  color: var(--accent-strong);
}

.dash-widget {
  position: absolute;
  z-index: 1;
  min-width: 340px;
  min-height: 280px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border: 1px solid rgba(124, 255, 152, 0.16);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(10, 21, 16, 0.98), rgba(5, 11, 8, 0.97));
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.34);
  overflow: auto;
  resize: both;
}

.dash-widget:hover {
  border-color: rgba(124, 255, 152, 0.32);
}

.dash-widget-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  min-height: 52px;
  padding: 9px 11px 7px;
  border-bottom: 1px solid rgba(124, 255, 152, 0.09);
  cursor: move;
  user-select: none;
}

.dash-widget-head h3 {
  margin: 1px 0 0;
  font-size: 0.98rem;
}

.dash-widget-close {
  width: 26px;
  height: 26px;
  border: 1px solid rgba(124, 255, 152, 0.14);
  border-radius: 8px;
  background: rgba(4, 10, 7, 0.52);
  color: var(--muted);
  font-size: 1rem;
  cursor: pointer;
}

.dash-widget-close:hover {
  color: var(--text);
  border-color: rgba(255, 107, 107, 0.44);
  background: rgba(255, 107, 107, 0.12);
}

.dash-widget-body {
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  overflow: hidden;
  padding: 8px 10px 10px;
}

.dash-widget-note {
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.3;
  margin-bottom: 6px;
}

.dash-widget-legend {
  min-height: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  margin-bottom: 4px;
}

.dash-widget-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-widget-legend-item i {
  width: 16px;
  height: 3px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.dash-widget-svg {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 260px;
}

.dash-widget-svg.dash-mini-chart {
  height: auto;
  min-height: 220px;
}

.dash-meter-panel {
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(230px, 1fr) auto;
  gap: 10px;
}

.dash-meter-track {
  position: relative;
  width: 38px;
  margin: 8px auto;
  border: 1px solid rgba(124, 255, 152, 0.18);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 138, 101, 0.08), rgba(87, 214, 255, 0.08));
  overflow: visible;
}

.dash-meter-heat,
.dash-meter-cool,
.dash-meter-likely {
  position: absolute;
  left: 6px;
  right: 6px;
  border-radius: 999px;
}

.dash-meter-heat {
  background: linear-gradient(180deg, rgba(255, 107, 107, 0.92), rgba(255, 138, 101, 0.40));
}

.dash-meter-cool {
  background: linear-gradient(180deg, rgba(87, 214, 255, 0.40), rgba(87, 214, 255, 0.92));
}

.dash-meter-likely {
  left: -8px;
  right: -8px;
  border: 2px solid rgba(246, 196, 90, 0.86);
  background: rgba(246, 196, 90, 0.10);
}

.dash-meter-marker {
  position: absolute;
  left: 50%;
  width: 16px;
  height: 16px;
  border: 2px solid #f5f7fa;
  border-radius: 999px;
  background: var(--accent);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 5px rgba(0, 200, 5, 0.18);
}

.dash-meter-marker span {
  position: absolute;
  left: 24px;
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  color: var(--text);
  font-size: 0.74rem;
  font-weight: 900;
}

.dash-mini-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 8px;
  overflow: auto;
}

.dash-mini-metric {
  min-height: 88px;
  display: grid;
  align-content: center;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 9px;
  background: rgba(4, 10, 7, 0.50);
}

.dash-mini-metric label,
.panel-profile-card label {
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
}

.dash-mini-metric strong {
  color: var(--text);
  font-size: 1.05rem;
}

.dash-mini-metric span,
.panel-profile-card span {
  color: var(--muted);
  font-size: 0.72rem;
}

.dash-cam-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
  overflow: auto;
}

.dash-cam-tile {
  min-height: 112px;
  display: grid;
  align-content: end;
  gap: 5px;
  padding: 10px;
  border: 1px solid rgba(87, 214, 255, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(87, 214, 255, 0.10), rgba(4, 10, 7, 0.82)),
    rgba(8, 18, 13, 0.9);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.dash-cam-tile:hover {
  transform: scale(1.08);
  z-index: 3;
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.46);
}

.dash-paper-ladder {
  display: grid;
  gap: 5px;
  margin-top: 8px;
  overflow: auto;
}

.dash-paper-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 54px 54px;
  gap: 8px;
  align-items: center;
  min-height: 30px;
  padding: 6px 8px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 8px;
  background: rgba(2, 6, 4, 0.38);
  font-size: 0.76rem;
}

.dash-paper-row span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-paper-row b {
  color: var(--accent-strong);
}

.dash-paper-row em {
  color: var(--muted);
  font-style: normal;
  text-align: right;
}

.panel-rail-profile {
  margin-bottom: 10px;
}

.panel-profile-card {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.48);
}

.panel-profile-card strong {
  color: var(--text);
  font-size: 0.9rem;
}

.panel-rail-close {
  border: 0;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font-weight: 900;
  margin-left: auto;
}

.panel-rail-close:hover {
  color: var(--bad);
}

.settings-layout-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  margin-top: 12px;
}

.settings-layout-row input {
  min-height: 40px;
  border: 1px solid rgba(124, 255, 152, 0.14);
  border-radius: 10px;
  background: rgba(2, 6, 4, 0.7);
  color: var(--text);
  padding: 8px 10px;
}

.dash-layout-list {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.dash-layout-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.42);
}

.dash-layout-row div {
  display: grid;
  gap: 3px;
}

.dash-layout-row span {
  color: var(--muted);
  font-size: 0.76rem;
}

.dash-widget-forecast .dash-widget-body {
  grid-template-rows: auto minmax(0, 1fr);
}

.dash-forecast-wrap {
  min-height: 0;
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 10px;
  background: rgba(2, 6, 4, 0.42);
}

.dash-forecast-grid {
  --forecast-cell: 34px;
  display: grid;
  grid-template-columns: 148px repeat(var(--forecast-cols), var(--forecast-cell));
  grid-auto-rows: 38px;
  width: max-content;
  min-width: 100%;
  font-family: "IBM Plex Mono", "Cascadia Code", monospace;
}

.dash-forecast-corner,
.dash-forecast-hour,
.dash-forecast-source,
.dash-forecast-cell {
  border-right: 1px solid rgba(124, 255, 152, 0.08);
  border-bottom: 1px solid rgba(124, 255, 152, 0.08);
}

.dash-forecast-corner {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  padding: 0 10px;
  background: rgba(6, 14, 10, 0.98);
  color: var(--muted);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dash-forecast-hour {
  position: sticky;
  top: 0;
  z-index: 3;
  display: grid;
  place-items: center;
  gap: 1px;
  padding: 3px 0;
  background: rgba(6, 14, 10, 0.96);
  color: var(--text);
  font-size: 0.62rem;
  line-height: 1.05;
}

.dash-forecast-day {
  color: var(--accent-strong);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.dash-forecast-day.ghost {
  color: rgba(124, 255, 152, 0.18);
}

.dash-forecast-source {
  position: sticky;
  left: 0;
  z-index: 2;
  display: grid;
  align-content: center;
  gap: 1px;
  padding: 4px 8px;
  background: rgba(6, 14, 10, 0.98);
  line-height: 1.05;
}

.dash-forecast-source strong {
  color: var(--text);
  font-size: 0.72rem;
}

.dash-forecast-source span {
  color: var(--muted);
  font-size: 0.58rem;
}

.dash-forecast-source-obs strong {
  color: #57d6ff;
}

.dash-forecast-cell {
  position: relative;
  display: grid;
  place-items: center;
  background: #dceff4;
  color: #0a1920;
  font-size: 1.05rem;
  line-height: 1;
}

.dash-forecast-cell b {
  display: block;
  font-weight: 900;
  transform: translateY(-1px);
}

.dash-forecast-cell small {
  position: absolute;
  right: 2px;
  bottom: 2px;
  min-width: 15px;
  padding: 1px 2px;
  border-radius: 4px;
  background: rgba(5, 11, 8, 0.72);
  color: #f5f7fa;
  font-size: 0.48rem;
  font-weight: 900;
}

.dash-forecast-cell.sun {
  background: linear-gradient(180deg, #e9f7ff, #cceaf2);
  color: #f4bd1a;
}

.dash-forecast-cell.moon {
  background: linear-gradient(180deg, #dceff6, #b9d6e0);
  color: #203946;
}

.dash-forecast-cell.partly {
  background: linear-gradient(180deg, #e5f4f8, #c8e4ed);
  color: #d99e19;
}

.dash-forecast-cell.cloud,
.dash-forecast-cell.overcast {
  background: linear-gradient(180deg, #d9e6ea, #b9c8ce);
  color: #52636b;
}

.dash-forecast-cell.rain {
  background: linear-gradient(180deg, #c9e8f6, #9dc3d6);
  color: #1f70c1;
}

.dash-forecast-cell.empty {
  background: rgba(255, 255, 255, 0.035);
  color: rgba(245, 247, 250, 0.14);
}

.master-meter-track {
  position: absolute;
  top: 8px;
  bottom: 8px;
  left: 38px;
  width: 22px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.2);
  background: linear-gradient(180deg, rgba(255, 138, 101, 0.08), rgba(87, 214, 255, 0.08));
  overflow: hidden;
}

.master-meter-heat,
.master-meter-cool,
.master-meter-likely {
  position: absolute;
  left: 0;
  right: 0;
}

.master-meter-heat {
  background: linear-gradient(180deg, rgba(255, 89, 89, 0.78), rgba(255, 138, 101, 0.28));
}

.master-meter-cool {
  background: linear-gradient(180deg, rgba(87, 214, 255, 0.30), rgba(87, 214, 255, 0.76));
}

.master-meter-likely {
  left: 3px;
  right: 3px;
  border-radius: 999px;
  border: 1px solid rgba(246, 196, 90, 0.75);
  background: rgba(246, 196, 90, 0.18);
}

.master-meter-marker {
  position: absolute;
  left: 58px;
  right: 0;
  transform: translateY(-50%);
  font-size: 0.68rem;
  font-weight: 900;
  color: var(--text);
  white-space: nowrap;
}

.master-meter-marker::before {
  content: "";
  position: absolute;
  left: -24px;
  top: 50%;
  width: 24px;
  height: 2px;
  background: var(--text);
  transform: translateY(-50%);
}

.master-meter-tick {
  position: absolute;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 6px;
}

.master-meter-tick span {
  height: 1px;
  background: rgba(124, 255, 152, 0.22);
}

.master-meter-tick b {
  color: var(--muted);
  font-size: 0.64rem;
  white-space: nowrap;
}

.master-meter-stats {
  display: grid;
  gap: 7px;
}

.master-meter-stats div,
.master-analog-stat,
.master-market-summary div {
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.42);
  padding: 8px;
}

.master-meter-stats label,
.master-analog-stat label,
.master-market-summary label,
.master-field-card label {
  display: block;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.master-meter-stats strong,
.master-analog-stat strong,
.master-market-summary strong,
.master-field-card strong {
  display: block;
  margin-top: 2px;
  color: var(--text);
  font-size: 0.95rem;
}

.master-field-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.master-field-card {
  min-width: 0;
  min-height: 118px;
  padding: 11px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(12, 24, 18, 0.92), rgba(4, 10, 7, 0.74));
}

.master-field-card.cloud {
  background: linear-gradient(135deg, rgba(87, 214, 255, 0.16), rgba(4, 10, 7, 0.74));
}

.master-field-card.wind {
  background: linear-gradient(135deg, rgba(124, 255, 152, 0.13), rgba(4, 10, 7, 0.74));
}

.master-field-card.pressure {
  background: linear-gradient(135deg, rgba(196, 143, 255, 0.14), rgba(4, 10, 7, 0.74));
}

.master-field-card.dewpoint {
  background: linear-gradient(135deg, rgba(246, 196, 90, 0.15), rgba(4, 10, 7, 0.74));
}

.master-field-card span,
.master-field-card small,
.master-analog-stat span,
.master-market-summary span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.35;
}

.master-analog-grid,
.master-market-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.master-camera-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px;
}

.master-camera-tile {
  min-height: 84px;
  display: grid;
  align-content: end;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.11);
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(87, 214, 255, 0.10), rgba(4, 10, 7, 0.72)),
    radial-gradient(circle at 70% 24%, rgba(246, 196, 90, 0.18), transparent 34%);
}

.master-camera-tile strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.82rem;
}

.master-camera-tile span {
  color: var(--muted);
  font-size: 0.72rem;
}

.master-market-card {
  display: grid;
  gap: 9px;
}

.master-market-ladder {
  display: grid;
  gap: 6px;
  max-height: 220px;
  overflow: auto;
  padding-right: 2px;
}

.master-market-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px 42px;
  gap: 8px;
  align-items: center;
  padding: 7px 8px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 9px;
  background: rgba(4, 10, 7, 0.38);
  font-size: 0.76rem;
}

.master-market-row span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.master-market-row b {
  color: var(--accent-strong);
  text-align: right;
}

.master-market-row em {
  color: var(--muted);
  font-style: normal;
  text-align: right;
}

.master-mini-map {
  min-height: 100%;
}

.master-mini-map-card {
  position: relative;
  min-height: 300px;
  height: 100%;
  overflow: hidden;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(19, 54, 33, 0.92), rgba(7, 18, 12, 0.92)),
    radial-gradient(circle at 34% 26%, rgba(87, 214, 255, 0.18), transparent 26%),
    radial-gradient(circle at 76% 66%, rgba(246, 196, 90, 0.14), transparent 28%);
  padding: 14px;
}

.master-mini-map-dot {
  position: absolute;
  top: 45%;
  left: 48%;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--accent-strong);
  box-shadow: 0 0 0 8px rgba(124, 255, 152, 0.12), 0 0 24px rgba(124, 255, 152, 0.52);
}

.master-mini-map-rings {
  position: absolute;
  inset: 42px 28px 70px;
  border: 1px solid rgba(124, 255, 152, 0.16);
  border-radius: 48% 52% 44% 56%;
  transform: rotate(-12deg);
}

.master-mini-map-label {
  position: absolute;
  left: 14px;
  bottom: 52px;
  right: 14px;
}

.master-mini-map-label strong,
.master-mini-map-label span {
  display: block;
}

.master-mini-map-label span,
.master-mini-map-card p {
  color: var(--muted);
  font-size: 0.75rem;
  line-height: 1.35;
}

.master-mini-map-card p {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 10px;
  margin: 0;
}

.master-map-layer-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.master-map-layer-list span {
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 999px;
  padding: 4px 7px;
  background: rgba(4, 10, 7, 0.4);
  color: var(--text);
  font-size: 0.7rem;
  font-weight: 850;
}

.model-lab-market-watch {
  margin-top: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.market-watch-card {
  min-width: 0;
  border: 1px solid rgba(124, 255, 152, 0.14);
  border-radius: 12px;
  background: rgba(8, 17, 12, 0.82);
  color: var(--text);
  padding: 9px 11px;
  text-align: left;
  font: inherit;
  cursor: help;
}

.market-watch-card label,
.market-watch-card span,
.market-watch-card strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.market-watch-card label {
  color: var(--muted);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.market-watch-card strong {
  margin-top: 3px;
  color: #edf8ef;
  font-size: 0.86rem;
}

.market-watch-card span {
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.74rem;
}

.market-watch-card.hot {
  border-color: rgba(124, 255, 152, 0.48);
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.18), rgba(9, 19, 14, 0.88));
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.08);
}

.market-watch-card.warm {
  border-color: rgba(246, 196, 90, 0.34);
  background: linear-gradient(180deg, rgba(246, 196, 90, 0.12), rgba(9, 19, 14, 0.86));
}

.market-watch-card.muted {
  opacity: 0.72;
}

.station-subnav {
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.graph-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.subnav-button {
  border: 1px solid rgba(124, 255, 152, 0.14);
  background: rgba(11, 23, 17, 0.86);
  color: var(--muted);
  border-radius: 999px;
  padding: 10px 14px;
  cursor: pointer;
  font: inherit;
  font-weight: 600;
}

.subnav-button.active {
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.18), rgba(0, 200, 5, 0.1));
  color: var(--text);
  border-color: rgba(124, 255, 152, 0.42);
  box-shadow: inset 0 0 0 1px rgba(124, 255, 152, 0.08);
}

.chart-wrap {
  margin-top: 16px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(9, 18, 13, 0.98), rgba(7, 13, 10, 0.98));
  overflow: auto;
}

#analogs-view .analogs-grid > .panel {
  order: 20;
}

#analogs-view .analogs-trace-panel {
  order: 0;
}

#analogs-view .analogs-recent-metar-panel {
  order: 1;
  grid-column: 1 / -1;
}

.analogs-recent-metar-chart-wrap {
  min-height: 360px;
}

#analogs-recent-metar-chart {
  display: block;
  width: 100%;
  min-width: 980px;
  height: auto;
}

.analogs-recent-metar-table-wrap {
  margin-top: 14px;
  max-height: 280px;
  overflow: auto;
}

.multigraph-chart-wrap {
  min-height: 560px;
}

#multigraph-chart {
  display: block;
  width: 100%;
  height: auto;
  min-height: 540px;
  cursor: crosshair;
  user-select: none;
  background:
    radial-gradient(circle at top, rgba(124, 255, 152, 0.06), transparent 30%),
    linear-gradient(180deg, rgba(10, 21, 16, 0.98), rgba(6, 12, 9, 0.98));
}

#multigraph-chart.multigraph-selecting {
  cursor: cell;
}

#multigraph-zoom-toggle .market-day-button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.flow-strip {
  margin-top: 18px;
  padding: 16px 18px;
  background: linear-gradient(180deg, rgba(12, 26, 19, 0.96), rgba(8, 18, 13, 0.96));
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
}

.flow-head {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.flow-head p {
  margin: 6px 0 0;
}

.flow-dot {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  margin-top: 6px;
  background: #66786d;
  box-shadow: 0 0 0 6px rgba(102, 120, 109, 0.16);
}

.flow-dot.flowing {
  background: var(--good);
  box-shadow: 0 0 0 6px rgba(124, 255, 152, 0.12);
}

.flow-dot.waiting {
  background: var(--warn);
  box-shadow: 0 0 0 6px rgba(246, 196, 90, 0.12);
}

.flow-dot.blocked {
  background: var(--bad);
  box-shadow: 0 0 0 6px rgba(255, 107, 107, 0.12);
}

.flow-meta {
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.5;
}

.project-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 700;
  background: rgba(124, 255, 152, 0.1);
  color: var(--accent-strong);
  border: 1px solid rgba(124, 255, 152, 0.2);
}

.access-settings-button {
  border: 1px solid rgba(124, 255, 152, 0.18);
  border-radius: 999px;
  background: rgba(4, 10, 7, 0.56);
  color: var(--text);
  padding: 4px 8px;
  font-size: 0.68rem;
  font-weight: 900;
  cursor: pointer;
}

.access-settings-button:hover {
  border-color: rgba(124, 255, 152, 0.38);
  background: rgba(124, 255, 152, 0.10);
}

.grid {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.single-column {
  grid-template-columns: 1fr;
}

.panel {
  padding: 20px;
  background:
    linear-gradient(180deg, rgba(12, 24, 18, 0.96) 0%, rgba(8, 17, 13, 0.97) 100%);
}

.panel-note {
  margin: 14px 0 0;
}

.table-panel {
  grid-column: 1 / -1;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.observation-health-panel {
  padding: 14px 18px;
}

.observation-current-panel {
  display: grid;
  gap: 16px;
}

.solstitium-signal-panel {
  grid-column: 1 / -1;
}

.solstitium-signal-why {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 10px 0;
}

.solstitium-signal-why > div {
  padding: 12px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.44);
}

.solstitium-signal-why ul {
  margin: 6px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.42;
}

.solstitium-signal-tables {
  display: grid;
  grid-template-columns: minmax(220px, 0.75fr) minmax(320px, 1.25fr);
  gap: 12px;
}

.observation-strip-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.observation-strip-head .panel-note {
  margin: 0;
}

.source-health-strip {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.source-health-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  background: rgba(255, 255, 255, 0.025);
  cursor: help;
}

.source-health-light {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.03);
}

.source-health-pill.good .source-health-light {
  background: var(--good);
  box-shadow: 0 0 10px rgba(124, 255, 152, 0.65);
}

.source-health-pill.warn .source-health-light {
  background: var(--warn);
  box-shadow: 0 0 10px rgba(246, 196, 90, 0.5);
}

.source-health-pill.bad .source-health-light {
  background: var(--bad);
  box-shadow: 0 0 10px rgba(255, 107, 107, 0.5);
}

.source-health-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text);
}

.observation-map {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.observation-regime-inline {
  display: grid;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(124, 255, 152, 0.08);
}

.regime-signal-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.observation-tile {
  min-height: 124px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background: linear-gradient(180deg, rgba(14, 28, 20, 0.98), rgba(9, 18, 13, 0.98));
  display: grid;
  gap: 10px;
  align-content: start;
  position: relative;
  overflow: hidden;
  cursor: help;
}

.observation-tile::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 3px;
  background: var(--tile-accent, rgba(124, 255, 152, 0.6));
}

.observation-tile.wide {
  grid-column: span 2;
}

.observation-tile-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.observation-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--tile-accent, var(--accent-strong));
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.observation-tile label,
.observation-full-label,
.observation-tile span,
.observation-tile strong {
  display: block;
}

.observation-tile label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.observation-full-label {
  margin-top: 2px;
  font-size: 0.82rem;
  color: var(--text);
}

.observation-tile strong {
  font-size: 1.25rem;
  line-height: 1.15;
  color: var(--text);
}

.observation-tile span {
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1.45;
}

.observation-tile.tone-temp { --tile-accent: #ff8c69; }
.observation-tile.tone-dew { --tile-accent: #70c8ff; }
.observation-tile.tone-wind { --tile-accent: #8ce8ff; }
.observation-tile.tone-gust { --tile-accent: #e8d07a; }
.observation-tile.tone-vis { --tile-accent: #b5ffd8; }
.observation-tile.tone-pressure { --tile-accent: #d9c3ff; }
.observation-tile.tone-cloud { --tile-accent: #c6d3dc; }
.observation-tile.tone-precip { --tile-accent: #67a8ff; }
.observation-tile.tone-solar { --tile-accent: #ffd66b; }
.observation-tile.tone-soil { --tile-accent: #d4a46a; }
.observation-tile.tone-soilmoisture { --tile-accent: #65d4a8; }
.observation-tile.tone-time { --tile-accent: #8ba292; }

.metric {
  padding: 14px;
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(15, 31, 23, 0.98) 0%, rgba(11, 22, 17, 0.98) 100%);
  border: 1px solid rgba(124, 255, 152, 0.08);
  position: relative;
  overflow: hidden;
}

.metric::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.05), rgba(124, 255, 152, 0.7), rgba(0, 200, 5, 0.05));
}

.metric label,
.metric span {
  display: block;
}

.metric label {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 8px;
}

.metric strong {
  font-size: 1.32rem;
  color: var(--text);
}

.metric span {
  margin-top: 5px;
  color: var(--muted);
}

.source-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.8rem;
  font-weight: 700;
}

.source-chip.madis {
  color: #061b0d;
  background: rgba(124, 255, 152, 0.85);
}

.source-chip.nws {
  color: #241600;
  background: rgba(246, 196, 90, 0.85);
}

.source-chip.truth {
  color: #031a21;
  background: rgba(87, 214, 255, 0.82);
}

.source-chip.climatesight {
  color: #111017;
  background: rgba(204, 150, 255, 0.82);
}

.source-chip.missing {
  color: #c4d0c7;
  background: rgba(111, 132, 119, 0.26);
}

.source-chip.stale {
  color: #230a0a;
  background: rgba(255, 107, 107, 0.82);
}

.obs-timeline-wrap {
  margin-top: 6px;
}

.nws-obs-controls {
  display: grid;
  gap: 8px;
  justify-items: end;
}

.nws-obs-controls .market-day-toggle {
  margin-top: 0;
}

.obs-timeline-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  cursor: grab;
  user-select: none;
  touch-action: pan-x;
  -webkit-user-select: none;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(11, 23, 17, 0.95), rgba(8, 16, 12, 0.98));
  scrollbar-color: rgba(124, 255, 152, 0.45) rgba(255, 255, 255, 0.04);
  scrollbar-width: thin;
}

.obs-timeline-scroll:active {
  cursor: grabbing;
}

.obs-timeline-scroll.dragging {
  cursor: grabbing;
}

.obs-timeline-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.obs-timeline-table th,
.obs-timeline-table td {
  min-width: 84px;
  text-align: center;
  padding: 10px 8px;
  border-right: 1px solid rgba(124, 255, 152, 0.05);
  border-bottom: 1px solid rgba(124, 255, 152, 0.05);
}

.obs-timeline-table th {
  position: sticky;
  left: 0;
  z-index: 1;
  min-width: 76px;
  background: rgba(8, 17, 13, 0.98);
  color: var(--accent-strong);
}

.obs-timeline-table td {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.obs-timeline-table tr.time td { color: var(--muted); }
.obs-timeline-table tr.temp td { background: rgba(255, 140, 105, 0.08); }
.obs-timeline-table tr.dew td { background: rgba(112, 200, 255, 0.08); }
.obs-timeline-table tr.wind td { background: rgba(140, 232, 255, 0.08); }
.obs-timeline-table tr.gust td { background: rgba(232, 208, 122, 0.08); }
.obs-timeline-table tr.vis td { background: rgba(181, 255, 216, 0.06); }
.obs-timeline-table tr.pressure td { background: rgba(217, 195, 255, 0.08); }
.obs-timeline-table tr.cloud td { background: rgba(198, 211, 220, 0.08); }
.obs-timeline-table tr.precip td { background: rgba(103, 168, 255, 0.08); }

.obs-timeline-table .dir {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.76rem;
}

.obs-mobile-cards {
  display: none;
}

.truth-panel th,
.truth-panel td {
  padding: 10px 8px;
}

.truth-panel table {
  table-layout: auto;
}

.compact-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}

.compact-panel-head h3 {
  margin: 0;
}

.mini-arrow-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.25);
  background: rgba(0, 200, 5, 0.1);
  color: var(--accent-strong);
  font-size: 1.15rem;
  font-weight: 900;
  cursor: pointer;
}

.mini-arrow-button:hover {
  border-color: rgba(124, 255, 152, 0.48);
  background: rgba(0, 200, 5, 0.18);
}

.climatesight-table-wrap {
  max-height: none;
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(10, 20, 15, 0.92), rgba(6, 12, 9, 0.96));
}

.climatesight-table-wrap table {
  table-layout: auto;
  min-width: 760px;
}

.climatesight-table-wrap thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(8, 17, 13, 0.98);
}

.climatesight-table-wrap th,
.climatesight-table-wrap td {
  white-space: nowrap;
  padding: 9px 10px;
  font-variant-numeric: tabular-nums;
}

.climatesight-table-wrap tbody tr.latest-row {
  background: rgba(124, 255, 152, 0.08);
}

.high-frequency-temp {
  color: var(--accent-strong);
  font-weight: 900;
  font-size: 1rem;
}

.metar-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
}

.metar-truth-table {
  min-width: 1180px;
}

.metar-truth-table th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(8, 17, 13, 0.98);
}

.metar-truth-table tr.speci-row td {
  background: rgba(246, 196, 90, 0.055);
}

.metar-raw {
  max-width: 360px;
  color: var(--muted);
  font-family: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.72rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  text-align: left;
  padding: 12px 10px;
  border-bottom: 1px solid rgba(124, 255, 152, 0.06);
  vertical-align: top;
}

th {
  color: var(--accent-strong);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  background: rgba(255, 255, 255, 0.01);
}

td {
  color: var(--text);
}

td.delta-up {
  color: var(--bad);
}

td.delta-down {
  color: var(--good);
}

.checklist {
  margin: 0;
  padding-left: 20px;
  line-height: 1.6;
  color: var(--muted);
}

.section-view.hidden {
  display: none;
}

.history-timing-chart {
  margin-top: 16px;
  display: grid;
  gap: 10px;
}

.history-time-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}

.history-market-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}

.history-replay-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}

.history-market-controls {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.history-replay-slider-card {
  min-width: 250px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background: rgba(255, 255, 255, 0.025);
}

.history-replay-slider-card label {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.history-replay-slider-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.history-replay-slider-row input[type="range"] {
  flex: 1 1 auto;
  accent-color: var(--accent);
}

.history-replay-slider-row strong {
  min-width: 82px;
  text-align: right;
  font-size: 0.9rem;
}

.history-replay-controls {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.history-replay-controls .station-subnav.compact {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.history-replay-controls .station-subnav.compact .subnav-button {
  padding: 7px 10px;
  font-size: 0.76rem;
}

.history-market-controls .market-day-toggle {
  margin-top: 0;
}

.history-replay-chart-wrap {
  margin-top: 16px;
  overflow-x: auto;
  overflow-y: hidden;
  cursor: grab;
}

#history-replay-chart {
  display: block;
  width: 100%;
  height: auto;
  min-height: 360px;
  background:
    radial-gradient(circle at top, rgba(124, 255, 152, 0.06), transparent 32%),
    linear-gradient(180deg, rgba(9, 18, 13, 0.98), rgba(6, 12, 9, 0.98));
}

.history-replay-chart-wrap.dragging {
  cursor: grabbing;
}

.history-replay-run-groups {
  display: grid;
  gap: 14px;
}

.history-replay-run-group {
  border-radius: 16px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background: linear-gradient(180deg, rgba(14, 28, 20, 0.92), rgba(8, 16, 12, 0.95));
  overflow: hidden;
}

.history-replay-run-summary {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  padding: 14px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  cursor: pointer;
}

.history-replay-run-summary:hover {
  background: rgba(255, 255, 255, 0.02);
}

.history-replay-run-summary-main {
  display: grid;
  gap: 6px;
}

.history-replay-run-summary-main strong {
  font-size: 1rem;
}

.history-replay-run-summary-meta {
  color: var(--muted);
  font-size: 0.84rem;
}

.history-replay-run-summary-side {
  text-align: right;
  display: grid;
  gap: 6px;
}

.history-replay-run-summary-side .market-day-button {
  justify-self: end;
}

.history-replay-run-table-wrap {
  padding: 0 16px 16px;
}

.history-replay-run-table-wrap.hidden {
  display: none;
}

.history-grid-cell {
  min-height: 84px;
  padding: 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(15, 31, 23, 0.96), rgba(9, 19, 14, 0.96));
  border: 1px solid rgba(124, 255, 152, 0.08);
  display: grid;
  gap: 6px;
  align-content: start;
}

.hidden {
  display: none !important;
}

.history-grid-cell strong {
  font-size: 1.08rem;
  color: var(--text);
}

.cams-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.cams-board-panel {
  grid-column: 1 / -1;
}

.cams-replay-panel {
  min-width: min(560px, 100%);
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.025);
}

.cams-replay-panel .eyebrow {
  margin: 0;
}

.cams-card {
  padding: 7px;
  border-radius: 8px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  background: linear-gradient(180deg, rgba(12, 25, 18, 0.96), rgba(8, 16, 12, 0.98));
  display: grid;
  gap: 6px;
}

.cams-card.raw-missing {
  border-color: rgba(160, 185, 170, 0.16);
}

.cams-card-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.cams-card-head h4 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
  font-size: 0.92rem;
}

.cams-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.cams-meta-grid div {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(124, 255, 152, 0.06);
  background: rgba(255, 255, 255, 0.025);
}

.cams-meta-grid label {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.cams-meta-grid strong {
  display: block;
  color: var(--text);
  font-size: 0.96rem;
}

.cams-role {
  margin: 0;
}

.cams-toolbar {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.cams-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.cams-link-button {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.cams-preview-wrap {
  display: grid;
  gap: 8px;
}

.cams-preview-tile {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
}

.cams-preview-frame {
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 240px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  border-radius: 8px;
  background: rgba(5, 11, 8, 0.96);
}

.cams-preview-video {
  object-fit: cover;
}

.cams-preview-image {
  object-fit: cover;
}

.cams-preview-note {
  margin: 0;
  font-size: 0.82rem;
}

.cams-raw-empty {
  display: grid;
  place-items: center;
  gap: 6px;
  min-height: 240px;
  aspect-ratio: 16 / 9;
  padding: 14px;
  border: 1px dashed rgba(160, 185, 170, 0.24);
  border-radius: 8px;
  background: rgba(5, 11, 8, 0.68);
  text-align: center;
}

.cams-raw-empty strong {
  color: var(--text);
  font-size: 0.9rem;
}

.cams-raw-empty span {
  max-width: 280px;
  color: var(--muted);
  font-size: 0.78rem;
}

.weather-time-controls,
.camera-replay-controls {
  margin-top: 12px;
}

.map-control-panel {
  margin-top: 14px;
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 18px;
  background:
    radial-gradient(circle at 10% 10%, rgba(124, 255, 152, 0.08), transparent 34%),
    linear-gradient(180deg, rgba(8, 18, 13, 0.92), rgba(5, 12, 8, 0.96));
}

.map-control-panel .eyebrow {
  margin-bottom: 8px;
}

.map-control-panel .market-day-toggle,
.map-control-panel .weather-time-controls {
  margin-top: 0;
}

.weather-time-controls:empty,
.camera-replay-controls:empty {
  display: none;
}

.weather-time-head,
.camera-replay-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.025);
}

.weather-time-head {
  grid-template-columns: 1fr auto;
  align-items: center;
}

.camera-replay-card {
  min-width: min(520px, 100%);
  padding: 0;
  border: 0;
  background: transparent;
}

.weather-time-head strong,
.camera-replay-card strong {
  display: block;
  font-size: 0.95rem;
}

.weather-time-head span,
.camera-replay-card span {
  color: var(--muted);
  font-size: 0.82rem;
}

.weather-time-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.weather-time-card {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto;
  gap: 12px 16px;
  padding: 12px;
  border: 1px solid rgba(160, 185, 170, 0.2);
  border-radius: 8px;
  background: rgba(4, 11, 8, 0.72);
}

.weather-time-summary {
  min-width: 0;
}

.weather-time-summary .eyebrow {
  margin: 0 0 2px;
}

.weather-time-summary strong {
  display: block;
  color: var(--text);
  font-size: 1rem;
}

.weather-time-summary span,
.weather-time-note,
.weather-time-slider-row span {
  color: var(--muted);
  font-size: 0.76rem;
}

.weather-time-slider-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 76px minmax(160px, 1fr) minmax(100px, auto);
  gap: 10px;
  align-items: center;
}

.weather-time-slider-row label {
  color: #bfe9ff;
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.weather-time-slider-row.secondary {
  opacity: 0.88;
}

.weather-time-slider-row.secondary input[type="range"] {
  accent-color: #7cc9ff;
}

.weather-time-note {
  grid-column: 1 / -1;
  margin: -2px 0 0;
}

.weather-time-controls input[type="range"],
.camera-replay-card input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
}

.camera-lightbox-modal {
  position: fixed;
  inset: 0;
  z-index: 140;
}

.camera-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 5, 0.82);
  backdrop-filter: blur(10px);
}

.camera-lightbox-panel {
  position: relative;
  width: min(1480px, calc(100vw - 40px));
  max-height: calc(100vh - 40px);
  margin: 20px auto;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(124, 255, 152, 0.16);
  background: linear-gradient(180deg, rgba(8, 16, 12, 0.98), rgba(5, 10, 8, 0.99));
  overflow: auto;
  box-shadow: 0 24px 100px rgba(0, 0, 0, 0.46);
}

.camera-lightbox-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.camera-lightbox-head h3 {
  margin: 0;
}

.camera-lightbox-frame {
  min-height: 72vh;
}

.cams-map {
  min-height: 420px;
  width: 100%;
}

.cams-map-popup {
  min-width: 220px;
}

.cams-map-popup strong {
  display: block;
  margin-bottom: 6px;
}

.camera-options-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
}

.camera-options-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 7, 5, 0.78);
  backdrop-filter: blur(6px);
}

.camera-options-panel {
  position: relative;
  width: min(1520px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  margin: 24px auto;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  background: linear-gradient(180deg, rgba(8, 16, 12, 0.98), rgba(5, 10, 8, 0.99));
  overflow: auto;
  box-shadow: 0 20px 80px rgba(0, 0, 0, 0.46);
}

.camera-options-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.camera-options-head h3,
.camera-option-detail-head h4 {
  margin: 0;
}

.camera-options-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.camera-options-layout {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.9fr;
  gap: 18px;
  align-items: start;
}

.camera-options-list {
  display: grid;
  gap: 10px;
}

.camera-option-row {
  width: 100%;
  text-align: left;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  cursor: pointer;
}

.camera-option-row.active {
  border-color: rgba(124, 255, 152, 0.38);
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.16);
}

.camera-option-row strong,
.camera-option-row span {
  display: block;
}

.camera-option-row span {
  color: var(--muted);
  font-size: 0.82rem;
}

.camera-option-detail-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 14px;
}

body.modal-open {
  overflow: hidden;
}

.history-grid-cell span,
.history-grid-cell label {
  color: var(--muted);
  font-size: 0.8rem;
}

.history-grid-day {
  color: var(--accent-strong);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.history-time-histogram {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
  min-height: 220px;
}

.history-hist-bin {
  display: grid;
  gap: 8px;
  justify-items: center;
  align-items: end;
}

.history-hist-count {
  color: var(--muted);
  font-size: 0.78rem;
}

.history-hist-bar-wrap {
  width: 100%;
  height: 148px;
  border-radius: 14px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background: linear-gradient(180deg, rgba(8, 17, 13, 0.92), rgba(6, 12, 9, 0.92));
  display: flex;
  align-items: flex-end;
  padding: 6px;
}

.history-hist-bar {
  width: 100%;
  border-radius: 10px 10px 6px 6px;
  background: linear-gradient(180deg, rgba(124, 255, 152, 0.96), rgba(0, 200, 5, 0.58));
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.08);
  min-height: 2px;
}

.history-hist-label {
  text-align: center;
  color: var(--text);
  font-size: 0.78rem;
  line-height: 1.35;
}

.history-chart-row {
  display: grid;
  grid-template-columns: 92px 1fr 150px;
  gap: 12px;
  align-items: center;
}

.history-chart-date,
.history-chart-label {
  font-size: 0.88rem;
  color: var(--muted);
}

.history-chart-lane {
  position: relative;
  height: 18px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(255, 107, 107, 0.08) 0%, rgba(255, 255, 255, 0.02) 50%, rgba(124, 255, 152, 0.08) 100%);
  border: 1px solid rgba(124, 255, 152, 0.08);
  overflow: hidden;
}

.history-chart-midline {
  position: absolute;
  top: -2px;
  bottom: -2px;
  left: 50%;
  width: 1px;
  background: rgba(246, 196, 90, 0.85);
  box-shadow: 0 0 0 1px rgba(246, 196, 90, 0.1);
}

.history-chart-bar {
  position: absolute;
  top: 2px;
  bottom: 2px;
  border-radius: 999px;
}

.history-chart-bar.after {
  background: linear-gradient(90deg, rgba(0, 200, 5, 0.55), rgba(124, 255, 152, 0.88));
}

.history-chart-bar.before {
  background: linear-gradient(90deg, rgba(255, 107, 107, 0.88), rgba(255, 170, 170, 0.5));
}

.history-chart-empty {
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed rgba(124, 255, 152, 0.15);
  color: var(--muted);
  background: rgba(255, 255, 255, 0.015);
}

.market-subhead {
  margin: 18px 0 10px;
  font-size: 0.92rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.market-view-toolbar {
  margin: 0 0 14px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.market-view-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.market-grid {
  min-width: 0;
}

.daily-backtest-actions {
  justify-content: flex-start;
  margin: 12px 0 8px;
  align-items: end;
}

.backtest-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: 14px;
  align-items: start;
}

.model-lab-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.seasonality-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.seasonality-grid > .panel {
  min-width: 0;
}

.seasonality-hero-panel,
.seasonality-average-panel,
.seasonality-years-panel,
.seasonality-table-panel {
  grid-column: span 12;
}

.seasonality-controls {
  display: flex;
  align-items: end;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.seasonality-controls label {
  display: grid;
  gap: 5px;
  min-width: 130px;
  color: var(--muted);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.seasonality-controls select {
  height: 34px;
  border: 1px solid rgba(124, 255, 152, 0.18);
  border-radius: 8px;
  background: rgba(2, 8, 6, 0.78);
  color: var(--text);
  padding: 0 10px;
}

.seasonality-chart-wrap {
  min-height: 330px;
  overflow: hidden;
}

.seasonality-average-svg,
.seasonality-mini-svg {
  width: 100%;
  display: block;
}

.seasonality-average-svg {
  min-height: 300px;
}

.seasonality-gridlines line,
.seasonality-mini-svg line {
  stroke: rgba(220, 255, 226, 0.1);
  stroke-width: 1;
}

.seasonality-gridlines text,
.seasonality-axis text {
  fill: var(--muted);
  font-size: 11px;
}

.seasonality-average-line,
.seasonality-normal-line,
.seasonality-mini-svg path {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.seasonality-average-area,
.seasonality-mini-svg .area {
  stroke: none;
  fill: rgba(98, 183, 255, 0.16);
}

.seasonality-average-area {
  fill: rgba(124, 255, 152, 0.16);
}

.seasonality-average-line {
  stroke: #7cff98;
  stroke-width: 4;
}

.seasonality-normal-line {
  stroke: rgba(255, 210, 122, 0.8);
  stroke-width: 2;
  stroke-dasharray: 7 7;
}

.seasonality-legend {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 0.82rem;
}

.seasonality-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.seasonality-legend i {
  width: 18px;
  height: 3px;
  border-radius: 999px;
  display: inline-block;
}

.seasonality-legend .avg {
  background: #7cff98;
}

.seasonality-legend .normal {
  background: #ffd27a;
}

.seasonality-year-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}

.seasonality-year-card {
  display: grid;
  gap: 7px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 8px;
  background: rgba(4, 12, 9, 0.62);
}

.seasonality-year-head,
.seasonality-year-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.seasonality-year-head strong {
  color: var(--text);
}

.seasonality-year-head span,
.seasonality-year-meta {
  color: var(--muted);
  font-size: 0.78rem;
}

.seasonality-mini-svg {
  height: 86px;
}

.seasonality-mini-svg path {
  stroke: #62b7ff;
  stroke-width: 3;
}

.seasonality-mini-svg .area {
  stroke: none;
}

.seasonality-table-wrap {
  max-height: 440px;
  overflow: auto;
}

.model-lab-grid > .panel {
  min-width: 0;
}

.model-lab-hero-panel,
.model-lab-station-panel {
  grid-column: span 12;
}

.model-lab-hero-panel {
  order: 0;
}

.model-lab-guide-panel {
  grid-column: span 12;
  order: 1;
}

.forward-test-panel {
  grid-column: span 12;
  order: 2;
}

.model-lab-market-watch-panel {
  grid-column: span 12;
  order: 2;
}

.model-lab-strategy-panel {
  order: 3;
}

.model-lab-advanced-panel {
  order: 4;
}

.model-lab-station-panel,
.model-lab-table-panel {
  order: 5;
}

.model-lab-plan-panel,
.model-lab-table-panel {
  grid-column: span 6;
}

.model-lab-grid > .panel:not(.model-lab-hero-panel):not(.model-lab-station-panel):not(.model-lab-plan-panel):not(.model-lab-table-panel) {
  grid-column: span 6;
}

.model-lab-grid > .model-lab-guide-panel,
.model-lab-grid > .forward-test-panel {
  grid-column: span 12;
}

.model-lab-guide-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.model-lab-guide-grid > div {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.44);
}

.model-lab-guide-grid span {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.model-lab-quantiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(82px, 1fr));
  gap: 8px;
}

.model-lab-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.model-lab-quantile,
.model-lab-parser-card,
.model-lab-step,
.model-lab-table-card,
.model-lab-empty-model,
.model-lab-trained-model {
  border: 1px solid rgba(124, 255, 152, 0.10);
  background: rgba(4, 10, 7, 0.42);
  border-radius: 10px;
}

.model-lab-model-summary {
  margin-top: 14px;
}

.model-lab-model-spacer {
  height: 10px;
}

.model-lab-empty-model {
  display: grid;
  gap: 4px;
  padding: 12px;
}

.model-lab-empty-model span,
.model-lab-model-head span,
.model-lab-mini-table small {
  color: var(--muted);
  font-size: 0.78rem;
}

.model-lab-trained-model {
  padding: 12px;
  display: grid;
  gap: 12px;
}

.model-lab-model-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.model-lab-model-head > div {
  display: grid;
  gap: 2px;
}

.model-lab-model-head > div:last-child {
  text-align: right;
}

.model-lab-mini-table {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(115px, 1fr));
  gap: 8px;
}

.model-lab-mini-table > div {
  display: grid;
  gap: 2px;
  padding: 8px;
  border-radius: 8px;
  background: rgba(124, 255, 152, 0.05);
}

.model-diagnostics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
  margin: 10px 0;
}

.model-diagnostic-card {
  display: grid;
  gap: 4px;
  min-height: 98px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 10px;
  background: rgba(4, 10, 7, 0.42);
}

.model-diagnostic-card span {
  color: var(--muted);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.model-diagnostic-card strong {
  font-size: 1rem;
}

.model-diagnostic-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.35;
}

.model-diagnostic-card.pass {
  border-color: rgba(124, 255, 152, 0.32);
}

.model-diagnostic-card.watch {
  border-color: rgba(246, 215, 118, 0.34);
}

.model-diagnostic-card.fail {
  border-color: rgba(255, 155, 155, 0.34);
}

.model-diagnostic-card.fail strong {
  color: #ff9b9b;
}

.model-diagnostic-card.watch strong {
  color: #f6d776;
}

.forward-test-explainer {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0;
}

.forward-test-explainer > div,
.forward-test-status {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 10px;
  background: rgba(124, 255, 152, 0.05);
}

.forward-test-explainer span,
.forward-test-status span {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.forward-test-status {
  margin: 10px 0;
  border-color: rgba(124, 255, 152, 0.22);
  background: rgba(4, 10, 7, 0.52);
}

.forward-test-subhead {
  margin-top: 16px;
}

.forward-decision-wrap {
  max-height: 360px;
}

.model-lab-quantile {
  padding: 10px;
  display: grid;
  gap: 3px;
}

.model-lab-quantile span,
.model-lab-parser-card span,
.model-lab-step p,
.model-lab-table-row small {
  color: var(--muted);
  font-size: 0.76rem;
}

.model-lab-parser-sets {
  display: grid;
  gap: 10px;
}

.model-lab-parser-card {
  padding: 12px;
}

.model-lab-parser-card.active {
  border-color: rgba(124, 255, 152, 0.32);
  background: rgba(124, 255, 152, 0.07);
}

.model-lab-parser-card > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.model-lab-parser-card p {
  margin: 6px 0 8px;
}

.model-lab-parser-card ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.82rem;
}

.model-lab-step-list {
  display: grid;
  gap: 10px;
}

.model-lab-step {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
}

.model-lab-step > span,
.model-lab-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  border-radius: 999px;
  background: rgba(124, 255, 152, 0.10);
  color: var(--accent);
  font-weight: 700;
  font-size: 0.76rem;
}

.model-lab-step p {
  margin: 4px 0 0;
  line-height: 1.35;
}

.model-lab-table-wrap {
  max-height: 460px;
  overflow: auto;
}

.model-lab-chip {
  padding: 2px 10px;
  text-transform: capitalize;
}

.model-lab-chip.partial {
  color: #f6d776;
  background: rgba(246, 215, 118, 0.12);
}

.model-lab-chip.thin {
  color: #ff9b9b;
  background: rgba(255, 155, 155, 0.12);
}

.model-lab-table-cards {
  display: grid;
  gap: 10px;
  max-height: 460px;
  overflow: auto;
}

.model-lab-table-card {
  padding: 12px;
}

.model-lab-table-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  padding: 8px 0;
  border-top: 1px solid rgba(124, 255, 152, 0.08);
  align-items: baseline;
}

.backtest-lab-panel,
.backtest-selected-agent-panel,
.backtest-compact-grid,
#backtest-view > .backtest-page-grid > .table-panel:not(.backtest-agent-rail) {
  min-width: 0;
}

.backtest-lab-panel {
  grid-column: 1;
}

.backtest-agent-rail {
  grid-column: 2;
  grid-row: 1 / span 6;
  position: sticky;
  top: 8px;
  min-height: min(860px, calc(100vh - 16px));
  max-height: calc(100vh - 16px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.backtest-agent-list-wrap {
  flex: 1 1 auto;
  min-height: 520px;
  max-height: none;
  overflow: auto;
  overscroll-behavior: contain;
}

.backtest-selected-agent-panel,
.backtest-compact-grid,
#backtest-view > .backtest-page-grid > .table-panel:not(.backtest-agent-rail) {
  grid-column: 1;
}

.backtest-compact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.market-volatility-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 12px;
}

.market-volatility-screener-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: end;
  margin-top: 12px;
}

.market-volatility-table {
  min-width: 0;
}

.market-volatility-table h3 {
  margin-top: 0;
}

.portfolio-page-head,
.portfolio-layout,
.portfolio-form-row,
.portfolio-station-body {
  display: grid;
  gap: 14px;
}

.portfolio-page-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  margin-bottom: 14px;
}

.portfolio-layout {
  grid-template-columns: minmax(300px, 0.8fr) minmax(320px, 1fr);
  align-items: start;
}

.portfolio-entry-panel {
  grid-row: span 2;
}

.portfolio-blotter-panel {
  grid-column: 2;
}

.portfolio-trade-form {
  display: grid;
  gap: 10px;
}

.portfolio-trade-form label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.82rem;
}

.portfolio-trade-form input,
.portfolio-trade-form select,
.portfolio-trade-form textarea {
  width: 100%;
  border: 1px solid rgba(221, 246, 224, 0.14);
  border-radius: 8px;
  background: rgba(5, 12, 9, 0.86);
  color: var(--text);
  padding: 9px 10px;
  font: inherit;
}

.portfolio-form-row {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.portfolio-table-wrap {
  max-height: 440px;
}

.portfolio-station-context {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.portfolio-station-card {
  border: 1px solid rgba(221, 246, 224, 0.11);
  border-radius: 8px;
  background: rgba(7, 18, 13, 0.78);
  overflow: hidden;
}

.portfolio-station-card summary {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  padding: 12px 14px;
}

.portfolio-station-body {
  grid-template-columns: 220px minmax(280px, 360px) minmax(0, 1fr);
  padding: 0 14px 14px;
  align-items: stretch;
}

.portfolio-indicator-mini {
  min-height: 120px;
  border: 1px solid rgba(221, 246, 224, 0.1);
  border-radius: 8px;
  padding: 10px;
  display: grid;
  gap: 6px;
}

.portfolio-indicator-mini.muted {
  align-content: center;
  color: var(--muted);
}

.portfolio-indicator-scale {
  position: relative;
  min-height: 88px;
  border-left: 1px solid rgba(221, 246, 224, 0.24);
}

.portfolio-indicator-scale span {
  position: absolute;
  left: 8px;
  transform: translateY(-50%);
  font-size: 0.72rem;
  white-space: nowrap;
}

.portfolio-indicator-scale b {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  margin-right: 5px;
  background: currentColor;
}

.portfolio-indicator-scale .now {
  color: #57d6ff;
}

.portfolio-indicator-scale .expected {
  color: #7cff98;
}

.portfolio-indicator-scale .market {
  color: #f6c45a;
}

.portfolio-contract-svg {
  width: 100%;
  min-height: 120px;
  border: 1px solid rgba(221, 246, 224, 0.1);
  border-radius: 8px;
  background: rgba(2, 8, 5, 0.38);
}

.portfolio-contract-table-wrap {
  max-height: 260px;
}

@media (max-width: 1100px) {
  .portfolio-layout,
  .portfolio-station-body {
    grid-template-columns: 1fr;
  }

  .portfolio-blotter-panel {
    grid-column: auto;
  }

  .agent-inspector-grid {
    grid-template-columns: 1fr;
  }
}

.compact-metrics {
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
}

.agent-row-button {
  width: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  display: grid;
  gap: 2px;
  cursor: pointer;
}

.agent-row-button span {
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.15;
}

.active-agent-row {
  background: rgba(124, 255, 152, 0.08);
}

.agent-trade-chart {
  width: 100%;
  min-height: 260px;
  max-height: 320px;
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 12px;
  background: rgba(4, 10, 7, 0.42);
}

.agent-trade-svg {
  display: block;
  width: max(100%, 760px);
  height: 260px;
}

.backtest-availability-strip {
  margin: 10px 0 8px;
  display: grid;
  gap: 8px;
}

.availability-summary,
.availability-days {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
}

.availability-legend,
.availability-count,
.availability-loading {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 0.78rem;
}

.availability-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 1.85rem;
  border: 1px solid rgba(124, 255, 152, 0.13);
  border-radius: 999px;
  padding: 0.28rem 0.56rem;
  background: rgba(7, 14, 10, 0.72);
  color: #dcebe0;
  font-size: 0.78rem;
  white-space: nowrap;
}

.availability-dot {
  width: 0.58rem;
  height: 0.58rem;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 14px currentColor;
}

.availability-full {
  color: #7cff98;
  border-color: rgba(124, 255, 152, 0.28);
}

.availability-partial {
  color: #f6c45a;
  border-color: rgba(246, 196, 90, 0.28);
}

.availability-none {
  color: #7f8f86;
  border-color: rgba(127, 143, 134, 0.20);
}

.availability-muted {
  color: var(--muted);
  border-color: rgba(139, 162, 146, 0.16);
}

.backtest-control-label {
  display: grid;
  gap: 5px;
  min-width: 118px;
  color: var(--muted);
  font-size: 0.76rem;
}

.backtest-control-label span {
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.backtest-decision-wrap {
  max-height: 340px;
  overflow: auto;
}

.backtest-feature-wrap {
  max-height: 320px;
  overflow: auto;
}

.backtest-master-wrap {
  max-height: 380px;
  overflow: auto;
}

.backtest-core-wrap {
  max-height: 380px;
  overflow: auto;
}

.backtest-portfolio-wrap {
  max-height: 360px;
  overflow: auto;
}

.backtest-portfolio-wrap table {
  min-width: 980px;
}

.portfolio-logic-cell {
  min-width: 340px;
  max-width: 520px;
  white-space: normal;
  line-height: 1.35;
}

.agent-inspector-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
}

.agent-inspector-card {
  min-width: 0;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 8px;
  background: rgba(7, 18, 13, 0.62);
  padding: 12px;
}

.agent-inspector-card h3 {
  margin: 0 0 10px;
  font-size: 0.92rem;
}

.agent-feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
}

.agent-feature-fact,
.agent-diagnostic-card {
  display: grid;
  gap: 3px;
  min-width: 0;
  border: 1px solid rgba(221, 246, 224, 0.09);
  border-radius: 8px;
  padding: 9px;
  background: rgba(2, 8, 5, 0.34);
}

.agent-feature-fact span,
.agent-diagnostic-card span,
.agent-feature-fact small,
.agent-diagnostic-card small {
  color: var(--muted);
  line-height: 1.25;
}

.agent-feature-fact strong,
.agent-diagnostic-card strong {
  color: var(--text);
  overflow-wrap: anywhere;
}

.agent-inspector-table-wrap {
  max-height: 300px;
}

.agent-inspector-card table {
  min-width: 760px;
}

.agent-diagnostic-list {
  display: grid;
  gap: 8px;
}

#backtest-view .paper-agent-table-wrap {
  overflow: auto;
}

#backtest-view .market-contract-chart-wrap {
  max-height: 520px;
  overflow: auto;
}

.paper-trader-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.paper-agent-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.market-backtest-panel {
  grid-column: 1 / -1;
}

.backtest-lab-panel {
  grid-column: 1 / -1;
}

.backtest-date-input {
  min-height: 2.35rem;
  border: 1px solid rgba(124, 255, 152, 0.18);
  border-radius: 6px;
  background: rgba(6, 18, 12, 0.86);
  color: #edf8ef;
  padding: 0.45rem 0.6rem;
  font: inherit;
}

.backtest-date-input:focus {
  outline: 2px solid rgba(124, 255, 152, 0.35);
  outline-offset: 2px;
}

.backtest-day-list-input {
  min-height: 4.5rem;
  width: min(100%, 740px);
  resize: vertical;
}

.backtest-scatter-control {
  margin-top: 10px;
  max-width: 780px;
}

.paper-agent-table-wrap {
  margin-top: 10px;
  max-height: 260px;
}

.paper-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.paper-page-head h2 {
  margin: 2px 0 4px;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.paper-page-summary {
  margin-bottom: 14px;
}

.paper-broker-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(260px, 0.9fr) minmax(420px, 1.35fr);
  gap: 12px;
  margin-bottom: 14px;
  align-items: start;
}

.paper-order-ticket {
  min-width: 0;
}

.paper-order-form {
  display: grid;
  gap: 10px;
}

.paper-order-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;
}

.paper-order-form label,
.paper-page-command label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.78rem;
}

.paper-order-form input,
.paper-order-form select,
.paper-page-command input {
  width: 100%;
  border: 1px solid rgba(124, 255, 152, 0.16);
  background: rgba(7, 14, 10, 0.92);
  color: var(--text);
  border-radius: 8px;
  padding: 10px 12px;
  font: inherit;
}

.paper-order-quote {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(139, 162, 146, 0.12);
  border-radius: 8px;
  background: rgba(4, 10, 7, 0.44);
}

.paper-order-quote div {
  min-width: 0;
}

.paper-order-quote label {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
  text-transform: uppercase;
}

.paper-order-quote strong {
  display: block;
  margin-top: 2px;
  color: #edf8ef;
  font-family: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.82rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

.paper-order-form .market-day-button {
  width: 100%;
  justify-content: center;
}

.paper-page-command .panel-note {
  grid-column: 1 / -1;
  margin: -2px 0 0;
}

.paper-page-portfolio-grid {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(360px, 1.2fr) minmax(360px, 1.2fr);
  gap: 12px;
  margin-bottom: 14px;
  align-items: start;
}

.paper-page-portfolio-panel {
  min-width: 0;
}

.paper-broker-layout .paper-page-portfolio-panel {
  min-height: 100%;
}

.paper-page-portfolio-panel h3 {
  margin-top: 0;
}

.paper-page-table-wrap {
  max-height: 240px;
  overflow: auto;
}

.paper-page-table-wrap table {
  min-width: 980px;
}

.paper-page-pnl-graph {
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow: auto;
}

.paper-page-pnl-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(110px, 1fr) 68px;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: 0.74rem;
}

.paper-page-pnl-row > span:first-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.paper-page-pnl-track {
  position: relative;
  height: 14px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  background: linear-gradient(90deg, rgba(255, 107, 107, 0.14), rgba(255, 255, 255, 0.04), rgba(124, 255, 152, 0.14));
  overflow: hidden;
}

.paper-page-pnl-track::before {
  content: "";
  position: absolute;
  top: -2px;
  bottom: -2px;
  left: 50%;
  width: 1px;
  background: rgba(246, 196, 90, 0.7);
}

.paper-page-pnl-fill {
  position: absolute;
  top: 2px;
  bottom: 2px;
  border-radius: 999px;
}

.paper-page-pnl-fill.positive {
  left: 50%;
  background: rgba(124, 255, 152, 0.78);
}

.paper-page-pnl-fill.negative {
  right: 50%;
  background: rgba(255, 107, 107, 0.78);
}

.paper-page-ladders {
  display: grid;
  grid-template-columns: repeat(5, minmax(210px, 1fr));
  gap: 12px;
  align-items: start;
}

.signals-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.signals-head h2 {
  margin: 2px 0 4px;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.signals-summary {
  margin-bottom: 14px;
}

.signals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  align-items: stretch;
}

.signal-card {
  display: grid;
  gap: 8px;
  min-height: 230px;
  border-color: rgba(139, 162, 146, 0.14);
}

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

.signal-card-head h3 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
  font-size: 1rem;
}

.signal-card-head > span {
  border: 1px solid rgba(139, 162, 146, 0.18);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  font-size: 0.68rem;
  white-space: nowrap;
}

.signal-card > strong {
  color: #edf8ef;
  font-family: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 1.15rem;
}

.signal-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.45;
}

.signal-card ul {
  margin: 0;
  padding-left: 17px;
  color: #c8d8cd;
  font-size: 0.78rem;
  line-height: 1.5;
}

.signal-card.bullish,
.signal-card.watch-hot {
  border-color: rgba(124, 255, 152, 0.24);
  background: linear-gradient(180deg, rgba(18, 44, 28, 0.84), rgba(8, 14, 11, 0.88));
}

.signal-card.bearish,
.signal-card.watch-cold {
  border-color: rgba(87, 214, 255, 0.24);
  background: linear-gradient(180deg, rgba(11, 35, 44, 0.82), rgba(8, 14, 11, 0.88));
}

.signal-card.caution {
  border-color: rgba(246, 196, 90, 0.24);
}

.signal-card.bullish .signal-card-head > span,
.signal-card.watch-hot .signal-card-head > span {
  border-color: rgba(124, 255, 152, 0.38);
  color: #bfffd0;
}

.signal-card.bearish .signal-card-head > span,
.signal-card.watch-cold .signal-card-head > span {
  border-color: rgba(87, 214, 255, 0.38);
  color: #c9f4ff;
}

.signals-detail-panel {
  margin-top: 12px;
}

.signals-notes {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.55;
}

.signals-notes p {
  margin: 0;
}

.agent-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.agents-summary {
  margin-bottom: 14px;
}

.agents-layout {
  display: grid;
  grid-template-columns: minmax(300px, 0.72fr) minmax(420px, 1.28fr);
  gap: 12px;
  align-items: start;
}

.agents-cloud-panel,
.agents-agent-panel,
.agents-detail-panel {
  min-width: 0;
}

.agent-cloud-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 8px;
}

.agents-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.agent-output-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid rgba(139, 162, 146, 0.14);
  border-radius: 8px;
  padding: 12px;
  background: rgba(7, 18, 13, 0.58);
}

.agent-output-card.experimental {
  border-color: rgba(246, 196, 90, 0.22);
}

.agent-output-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.agent-output-head h3 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
  font-size: 1.15rem;
}

.agent-output-head > span {
  border: 1px solid rgba(139, 162, 146, 0.18);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  font-size: 0.68rem;
  white-space: nowrap;
}

.agent-card-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
}

.agent-reason-list {
  margin: 0;
  padding-left: 17px;
  color: #c8d8cd;
  font-size: 0.78rem;
  line-height: 1.5;
}

.agents-mini-table-wrap {
  max-height: 240px;
  overflow: auto;
}

.agents-mini-table-wrap table {
  min-width: 440px;
}

.agents-input-detail {
  margin-top: 6px;
}

.paper-ladder-card {
  padding: 12px;
  min-width: 0;
}

.paper-ladder-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.paper-ladder-head h3 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
  font-size: 1.15rem;
}

.paper-ladder-mini-metrics {
  display: grid;
  gap: 4px;
  text-align: right;
  color: var(--muted);
  font-size: 0.72rem;
  white-space: nowrap;
}

.paper-ladder-table-wrap {
  max-height: calc(100vh - 330px);
  min-height: 280px;
  overflow: auto;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 12px;
  background: rgba(4, 10, 7, 0.46);
}

.paper-ladder-table {
  min-width: 0;
}

.paper-ladder-table th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(6, 14, 10, 0.98);
}

.paper-ladder-table th,
.paper-ladder-table td {
  padding: 8px 7px;
  font-size: 0.76rem;
  vertical-align: middle;
}

.paper-ladder-temp {
  color: #f6c45a;
  font-family: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 6px;
}

.paper-ladder-temp small {
  color: var(--muted);
  font-family: inherit;
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
}

.paper-ladder-position-badge {
  display: inline-flex;
  min-width: 1.35rem;
  height: 1.35rem;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(246, 196, 90, 0.52);
  border-radius: 999px;
  background: rgba(246, 196, 90, 0.18);
  color: #ffe39a;
  font-size: 0.68rem;
  font-weight: 900;
  box-shadow: 0 0 0 2px rgba(246, 196, 90, 0.08);
}

.paper-ladder-price {
  width: 100%;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 10px;
  padding: 7px 6px;
  color: var(--text);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.paper-ladder-price.yes {
  background: rgba(124, 255, 152, 0.12);
}

.paper-ladder-price.no {
  background: rgba(87, 214, 255, 0.11);
}

.paper-ladder-table tr.paper-ladder-owned {
  background: linear-gradient(90deg, rgba(246, 196, 90, 0.13), rgba(124, 255, 152, 0.04));
}

.paper-ladder-table tr.paper-ladder-owned td {
  border-bottom-color: rgba(246, 196, 90, 0.18);
}

.paper-ladder-table tr.owned-yes .paper-ladder-price.yes {
  border-color: rgba(124, 255, 152, 0.58);
  background: rgba(124, 255, 152, 0.22);
  box-shadow: inset 3px 0 0 rgba(124, 255, 152, 0.8);
}

.paper-ladder-table tr.owned-no .paper-ladder-price.no {
  border-color: rgba(87, 214, 255, 0.58);
  background: rgba(87, 214, 255, 0.22);
  box-shadow: inset 3px 0 0 rgba(87, 214, 255, 0.8);
}

@media (max-width: 1500px) {
  .paper-page-ladders {
    grid-template-columns: repeat(3, minmax(230px, 1fr));
  }

  .paper-broker-layout {
    grid-template-columns: minmax(280px, 0.75fr) minmax(320px, 1fr);
  }

  .paper-page-portfolio-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 960px) {
  .paper-page-head {
    display: grid;
  }

  .signals-head {
    display: grid;
  }

  .agent-page-actions {
    justify-content: flex-start;
  }

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

  .paper-page-ladders {
    grid-template-columns: 1fr;
  }

  .paper-broker-layout,
  .paper-order-row,
  .paper-page-command {
    grid-template-columns: 1fr;
  }
}

.paper-ladder-table-wrap {
  max-height: 520px;
}

.indicators-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.indicators-head h2 {
  margin: 0;
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicators-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 16px;
}

.indicators-filter-panel,
.indicators-meter-panel,
.indicators-scorecard-panel,
.indicators-events-panel,
.indicators-metrics-panel {
  grid-column: 1 / -1;
}

.indicators-steps {
  display: grid;
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}

.indicator-step {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  padding: 11px;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 12px;
  background: rgba(7, 16, 11, 0.72);
}

.indicator-step > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(124, 255, 152, 0.13);
  color: var(--accent-strong);
  font-weight: 900;
}

.indicator-step strong,
.indicator-target strong {
  display: block;
  color: var(--text);
}

.indicator-step p,
.indicator-step small,
.indicator-target span {
  display: block;
  margin: 4px 0 0;
  color: var(--muted);
  line-height: 1.42;
}

.indicators-targets {
  display: grid;
  gap: 10px;
}

.indicator-target {
  padding: 12px;
  border: 1px solid rgba(87, 214, 255, 0.12);
  border-radius: 12px;
  background: rgba(6, 17, 18, 0.62);
}

.indicator-target code {
  display: block;
  margin-top: 7px;
  color: var(--accent-strong);
  white-space: normal;
}

.indicators-rule-wrap {
  max-height: 620px;
  overflow: auto;
}

.indicators-rule-wrap table {
  min-width: 1180px;
}

.indicators-rule-wrap th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(8, 17, 13, 0.98);
}

.indicators-rule-wrap td {
  vertical-align: top;
}

.indicators-rule-wrap td:nth-child(4) {
  min-width: 320px;
}

.indicators-rule-wrap small {
  color: var(--muted);
}

.indicators-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.indicators-metrics span {
  border: 1px solid rgba(124, 255, 152, 0.1);
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(255, 255, 255, 0.03);
  color: var(--muted);
  font-size: 0.82rem;
}

.indicator-temp-meter {
  margin-top: 16px;
}

.indicator-meter-shell {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.indicator-meter-scale {
  position: relative;
  min-height: 420px;
  overflow: hidden;
  border: 1px solid rgba(124, 255, 152, 0.11);
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 96, 72, 0.16), transparent 28%),
    radial-gradient(circle at 50% 84%, rgba(68, 166, 255, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(20, 10, 8, 0.9), rgba(8, 17, 13, 0.96) 48%, rgba(5, 13, 22, 0.94));
}

.indicator-meter-track {
  position: absolute;
  top: 24px;
  bottom: 24px;
  left: 50%;
  width: 46px;
  transform: translateX(-50%);
  overflow: hidden;
  border: 1px solid rgba(237, 248, 239, 0.16);
  border-radius: 999px;
  background: rgba(2, 8, 6, 0.78);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.03),
    0 18px 42px rgba(0, 0, 0, 0.28);
}

.indicator-meter-track::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.16), transparent 42%, rgba(0, 0, 0, 0.20));
  pointer-events: none;
}

.indicator-meter-heat,
.indicator-meter-cool {
  position: absolute;
  left: 0;
  right: 0;
}

.indicator-meter-heat {
  background: linear-gradient(180deg, rgba(255, 58, 58, 0.95), rgba(255, 150, 84, 0.84));
  box-shadow: 0 0 24px rgba(255, 88, 56, 0.22);
}

.indicator-meter-cool {
  background: linear-gradient(180deg, rgba(65, 198, 255, 0.88), rgba(52, 86, 255, 0.88));
  box-shadow: 0 0 24px rgba(70, 165, 255, 0.20);
}

.indicator-meter-tick {
  position: absolute;
  left: 18px;
  right: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  transform: translateY(-50%);
  color: var(--muted);
  font-size: 0.78rem;
  pointer-events: none;
}

.indicator-meter-tick span {
  flex: 1;
  height: 1px;
  background: rgba(237, 248, 239, 0.12);
}

.indicator-meter-tick b {
  min-width: 42px;
  color: var(--text);
  font-weight: 800;
  text-align: right;
}

.indicator-meter-marker {
  position: absolute;
  z-index: 3;
  left: calc(50% + 31px);
  width: 100px;
  border-top: 2px solid var(--accent-strong);
  transform: translateY(-50%);
  pointer-events: none;
}

.indicator-meter-marker span {
  position: absolute;
  top: -13px;
  left: 108px;
  white-space: nowrap;
  border: 1px solid rgba(124, 255, 152, 0.2);
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(4, 12, 8, 0.94);
  color: var(--text);
  font-size: 0.77rem;
  font-weight: 800;
}

.indicator-meter-marker.expected {
  left: calc(50% - 131px);
  border-color: rgba(255, 205, 112, 0.92);
}

.indicator-meter-marker.expected span {
  right: 108px;
  left: auto;
  border-color: rgba(255, 205, 112, 0.24);
}

.indicator-meter-readout {
  display: grid;
  gap: 12px;
  align-content: center;
}

.indicator-meter-readout > div {
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 16px;
  padding: 14px;
  background: rgba(7, 16, 11, 0.70);
}

.indicator-meter-dual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 0;
  border: 0;
  background: transparent;
}

.indicator-meter-dual > div {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 13px;
  background: rgba(255, 255, 255, 0.025);
}

.indicator-meter-readout label,
.indicator-meter-readout span {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.4;
}

.indicator-meter-readout strong {
  display: block;
  margin: 4px 0;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
  font-size: clamp(1.35rem, 3vw, 2.2rem);
}

.indicator-meter-readout strong.heat {
  color: #ff9b68;
}

.indicator-meter-readout strong.cool {
  color: #61d5ff;
}

.indicator-range-history-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(124, 255, 152, 0.10);
}

.indicator-range-history-head h4 {
  margin: 0;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicator-range-history-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  min-width: min(100%, 430px);
}

.indicator-date-picker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  padding: 0 9px;
  border: 1px solid rgba(124, 255, 152, 0.12);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.indicator-date-picker input {
  width: 132px;
  border: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
  color-scheme: dark;
}

.indicator-date-picker input:focus {
  outline: none;
}

.indicator-range-history-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
  padding: 10px;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 14px;
  background: rgba(3, 9, 6, 0.48);
}

.indicator-range-toolset {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.indicator-range-toolset > span {
  margin-right: 2px;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.indicator-range-tool {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 5px 9px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.72rem;
  font-weight: 800;
  cursor: pointer;
}

.indicator-range-tool:hover,
.indicator-range-tool:focus-visible {
  color: var(--text);
  border-color: rgba(124, 255, 152, 0.28);
  outline: none;
}

.indicator-range-tool.active {
  color: #06130c;
  border-color: rgba(124, 255, 152, 0.58);
  background: linear-gradient(180deg, rgba(124, 255, 152, 0.92), rgba(107, 218, 132, 0.78));
}

.indicator-range-tool.line.active {
  color: var(--text);
  background: rgba(124, 255, 152, 0.08);
}

.indicator-range-tool i {
  display: inline-block;
  width: 16px;
  height: 3px;
  border-radius: 999px;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.12);
}

.indicator-range-tool:not(.active) i {
  opacity: 0.38;
}

.indicator-probability-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin: 18px 0 10px;
}

.indicator-probability-head h4 {
  margin: 0 0 4px;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicator-probability-wrap {
  max-height: 300px;
  overflow: auto;
}

.indicator-probability-cards {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin: 10px 0 12px;
}

.indicator-probability-cards .metric {
  min-width: 0;
}

.indicator-probability-chart {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(42px, 1fr);
  gap: 7px;
  align-items: end;
  min-height: 190px;
  margin: 0 0 12px;
  padding: 14px 12px 10px;
  overflow-x: auto;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(124, 255, 152, 0.04), transparent),
    rgba(3, 9, 6, 0.52);
}

.indicator-prob-column {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 6px;
  min-width: 42px;
  height: 160px;
  color: var(--muted);
  text-align: center;
}

.indicator-prob-column-bars {
  position: relative;
  align-self: stretch;
  overflow: hidden;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.055);
}

.indicator-prob-column-bars span {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 10px 10px 0 0;
}

.indicator-prob-column-bars .exceed {
  opacity: 0.34;
  background: linear-gradient(180deg, rgba(97, 213, 255, 0.95), rgba(97, 213, 255, 0.18));
}

.indicator-prob-column-bars .exact {
  left: 18%;
  right: 18%;
  z-index: 2;
  background: linear-gradient(180deg, rgba(124, 255, 152, 0.95), rgba(255, 205, 112, 0.75));
  box-shadow: 0 0 16px rgba(124, 255, 152, 0.18);
}

.indicator-prob-column.mode b {
  color: var(--accent-strong);
}

.indicator-timing-panel {
  display: grid;
  gap: 12px;
  margin: 14px 0 12px;
  padding: 14px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 16px;
  background:
    radial-gradient(circle at 12% 12%, rgba(124, 255, 152, 0.08), transparent 30%),
    rgba(4, 11, 8, 0.64);
}

.indicator-timing-panel h4 {
  margin: 0 0 4px;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicator-timing-content {
  display: grid;
  gap: 12px;
}

.indicator-timing-gauge {
  display: grid;
  grid-template-columns: 156px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.indicator-timing-ring {
  --timing-color: #61d5ff;
  --timing-score: 0;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 3px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(3, 9, 6, 0.96) 0 58%, transparent 59%),
    conic-gradient(var(--timing-color) var(--timing-score), rgba(255, 255, 255, 0.08) 0);
  box-shadow: inset 0 0 22px rgba(0, 0, 0, 0.38);
}

.indicator-timing-gauge.low .indicator-timing-ring {
  --timing-color: #61d5ff;
}

.indicator-timing-gauge.uncertain .indicator-timing-ring {
  --timing-color: #ffcd70;
}

.indicator-timing-gauge.high .indicator-timing-ring,
.indicator-timing-gauge.very_high .indicator-timing-ring {
  --timing-color: #ff9b68;
}

.indicator-timing-ring strong {
  color: var(--text);
  font-size: 2rem;
  line-height: 1;
}

.indicator-timing-ring span {
  max-width: 92px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 750;
  line-height: 1.15;
  text-align: center;
  text-transform: uppercase;
}

.indicator-timing-bars {
  display: grid;
  gap: 9px;
}

.indicator-timing-bar {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 750;
}

.indicator-timing-bar div {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
}

.indicator-timing-bar b {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(97, 213, 255, 0.78), rgba(255, 155, 104, 0.86));
}

.indicator-timing-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.indicator-timing-reasons {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.indicator-timing-reasons span {
  padding: 6px 9px;
  border-radius: 999px;
  border: 1px solid rgba(124, 255, 152, 0.10);
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.76rem;
}

.indicator-probability-wrap table {
  min-width: 100%;
}

.indicator-probability-mode {
  background: rgba(124, 255, 152, 0.08);
}

.indicator-prob-bar {
  height: 5px;
  margin-top: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
}

.indicator-prob-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(124, 255, 152, 0.58), rgba(255, 205, 112, 0.8));
}

.indicator-prob-bar.exceed span {
  background: linear-gradient(90deg, rgba(97, 213, 255, 0.58), rgba(124, 255, 152, 0.78));
}

.indicator-prob-bar.no span {
  background: linear-gradient(90deg, rgba(255, 139, 92, 0.52), rgba(255, 205, 112, 0.78));
}

.indicator-contract-tone {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--muted);
  text-transform: capitalize;
}

.indicator-contract-tone.very-likely {
  color: #7cff98;
  background: rgba(124, 255, 152, 0.10);
}

.indicator-contract-tone.likely {
  color: #dff8e7;
  background: rgba(124, 255, 152, 0.07);
}

.indicator-contract-tone.tail {
  color: #ffb889;
  background: rgba(255, 139, 92, 0.10);
}

.indicator-contract-tone.balanced {
  color: #61d5ff;
  background: rgba(97, 213, 255, 0.09);
}

.indicator-range-history-wrap {
  margin-top: 12px;
  overflow-x: auto;
  border: 1px solid rgba(124, 255, 152, 0.09);
  border-radius: 16px;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 139, 92, 0.10), transparent 32%),
    radial-gradient(circle at 90% 82%, rgba(97, 213, 255, 0.10), transparent 34%),
    rgba(4, 11, 8, 0.70);
}

.indicator-range-history-chart {
  display: block;
  width: 100%;
  min-width: 760px;
  min-height: 500px;
}

.indicator-correlation-marker {
  cursor: pointer;
  outline: none;
  filter: drop-shadow(0 0 8px rgba(124, 255, 152, 0.28));
}

.indicator-correlation-marker.diverged {
  filter: drop-shadow(0 0 8px rgba(255, 205, 112, 0.25));
}

.indicator-correlation-marker:hover,
.indicator-correlation-marker:focus {
  opacity: 0.9;
  filter: drop-shadow(0 0 12px rgba(245, 247, 250, 0.42));
}

.indicators-scorecard-actions {
  justify-content: flex-end;
  margin-top: 0;
}

.indicators-scorecard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: 16px;
  margin-top: 16px;
}

.indicators-scorecard-grid h4 {
  margin: 0 0 10px;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicators-scorecard-wrap {
  max-height: 430px;
  overflow: auto;
}

.indicators-scorecard-wrap table {
  min-width: 720px;
}

.indicators-scorecard-wrap th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(8, 17, 13, 0.98);
}

.indicators-scorecard-wrap td {
  vertical-align: top;
}

.indicators-split-scorecard,
.indicator-split-section {
  display: grid;
  gap: 9px;
}

.indicator-split-section + .indicator-split-section {
  margin-top: 14px;
}

.indicator-split-section > label {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.indicator-split-card {
  display: grid;
  grid-template-columns: minmax(54px, 0.55fr) minmax(0, 1.2fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(124, 255, 152, 0.10);
  border-radius: 14px;
  padding: 10px;
  background: rgba(7, 16, 11, 0.66);
}

.indicator-split-card strong {
  color: var(--text);
}

.indicator-split-card span,
.indicator-split-card small {
  color: var(--muted);
  font-size: 0.78rem;
}

.indicator-split-card b {
  color: var(--accent-strong);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicator-split-card small {
  grid-column: 2 / -1;
}

.indicator-split-card.muted {
  opacity: 0.68;
}

.indicators-events-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  margin-top: 16px;
}

.indicators-events-grid h4 {
  margin: 0 0 10px;
  color: var(--text);
  font-family: "Space Grotesk", "Segoe UI", sans-serif;
}

.indicators-events-wrap {
  max-height: 430px;
  overflow: auto;
}

.indicators-events-wrap table {
  min-width: 680px;
}

.indicators-events-wrap th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(8, 17, 13, 0.98);
}

.indicator-event-result {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 3px 8px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.indicator-event-result.hit {
  border-color: rgba(124, 255, 152, 0.32);
  color: var(--good);
  background: rgba(124, 255, 152, 0.08);
}

.indicator-event-result.miss {
  border-color: rgba(255, 140, 140, 0.32);
  color: var(--bad);
  background: rgba(255, 140, 140, 0.08);
}

.pnl-up {
  color: var(--good);
}

.pnl-down {
  color: var(--bad);
}

.market-contract-legend {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.market-day-toggle {
  margin-top: 14px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.market-day-button {
  border: 1px solid rgba(124, 255, 152, 0.14);
  background: rgba(10, 19, 14, 0.92);
  color: var(--muted);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 600;
}

.market-day-button.active {
  color: var(--text);
  border-color: rgba(124, 255, 152, 0.42);
  background: linear-gradient(180deg, rgba(0, 200, 5, 0.18), rgba(0, 200, 5, 0.08));
}

.market-day-button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.market-contract-chip {
  border: 1px solid rgba(124, 255, 152, 0.16);
  background: rgba(10, 19, 14, 0.92);
  color: var(--text);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
  font: inherit;
  font-size: 0.8rem;
  transition: opacity 120ms ease, border-color 120ms ease, transform 120ms ease;
}

.market-contract-chip:hover {
  transform: translateY(-1px);
}

.market-contract-chip.hidden {
  opacity: 0.45;
  border-color: rgba(255, 255, 255, 0.08);
}

.market-contract-chip.today {
  box-shadow: inset 0 0 0 1px rgba(124, 255, 152, 0.08);
}

.market-contract-chip.tomorrow {
  border-color: rgba(87, 214, 255, 0.18);
  box-shadow: inset 0 0 0 1px rgba(87, 214, 255, 0.08);
}

.market-contract-chart-wrap {
  margin-top: 14px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(10, 20, 15, 0.98), rgba(6, 12, 9, 0.98));
  overflow: hidden;
}

.market-contract-chart {
  min-height: 340px;
  padding: 18px 16px 12px;
}

.precip-graph-panel {
  grid-column: 1 / -1;
}

.precip-chart-wrap {
  margin-top: 14px;
  border: 1px solid rgba(124, 255, 152, 0.08);
  border-radius: 18px;
  background:
    radial-gradient(circle at 18% 18%, rgba(87, 214, 255, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(10, 20, 15, 0.98), rgba(6, 12, 9, 0.98));
  overflow: hidden;
}

#precip-accumulation-chart {
  width: 100%;
  min-height: 420px;
  display: block;
}

.precip-month-hit {
  cursor: zoom-in;
}

.precip-control-divider {
  width: 1px;
  align-self: stretch;
  min-height: 28px;
  background: rgba(124, 255, 152, 0.12);
  margin: 0 2px;
}

.station-product-panel {
  grid-column: 1 / -1;
}

.station-info-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.station-info-link {
  display: block;
  padding: 12px;
  border: 1px solid rgba(124, 255, 152, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.025);
  color: var(--text);
  text-decoration: none;
}

.station-info-link:hover {
  border-color: rgba(124, 255, 152, 0.34);
  background: rgba(124, 255, 152, 0.06);
}

.station-info-link strong,
.station-info-link span {
  display: block;
}

.station-info-link span {
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.station-info-link-button {
  text-decoration: none;
  white-space: nowrap;
}

.nws-product-text {
  margin: 14px 0 0;
  max-height: 560px;
  overflow: auto;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(124, 255, 152, 0.09);
  background:
    linear-gradient(180deg, rgba(2, 10, 7, 0.96), rgba(5, 13, 9, 0.98)),
    repeating-linear-gradient(0deg, rgba(124, 255, 152, 0.04), rgba(124, 255, 152, 0.04) 1px, transparent 1px, transparent 24px);
  color: #dff8e7;
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.82rem;
  line-height: 1.45;
  white-space: pre-wrap;
}

.weather-map {
  min-height: 620px;
  width: 100%;
}

.leaflet-container {
  background: #5f7f72;
  font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
}

.weather-map {
  isolation: isolate;
}

.weather-replay-pane .leaflet-layer {
  transition: opacity 420ms ease-in-out;
  will-change: opacity;
}

.weather-replay-pane .leaflet-tile,
.leaflet-fade-anim .weather-replay-pane .leaflet-tile {
  transition: none;
}

.weather-windflow-pane {
  pointer-events: none;
  mix-blend-mode: screen;
}

.weather-windflow-canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.82;
  filter: drop-shadow(0 0 4px rgba(124, 255, 152, 0.22));
}

.weather-windflow-canvas.observed {
  opacity: 0.74;
  filter: drop-shadow(0 0 5px rgba(95, 220, 255, 0.24));
}

.terrain-base-tile {
  filter: saturate(1.42) contrast(1.08) brightness(0.96);
}

.goes-cloud-tile {
  filter: brightness(1.04) contrast(1.72) saturate(0);
  mix-blend-mode: screen;
}

.radar-tile {
  filter: saturate(1.22) contrast(1.08);
}

.precip-qpe-tile {
  filter: saturate(1.25) contrast(1.1);
}

.pressure-field-tile,
.weather-pressure-pane img {
  filter: hue-rotate(300deg) saturate(2.6) contrast(2.15) brightness(0.98);
  mix-blend-mode: normal;
}

.pressure-legend {
  margin-top: 12px;
  display: grid;
  grid-template-columns: auto minmax(120px, 1fr) auto;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pressure-legend-ramp {
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(90deg, #3277ff 0%, #f3f7f8 50%, #ef3e42 100%);
  box-shadow: 0 0 20px rgba(124, 255, 152, 0.08);
}

.isobar-label-icon {
  background: transparent;
  border: 0;
}

.isobar-label-icon span {
  display: inline-grid;
  min-width: 42px;
  height: 18px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 999px;
  background: rgba(4, 8, 10, 0.82);
  color: #f7fbff;
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.42);
}

.model-wind-divicon {
  background: transparent;
  border: 0;
}

.model-wind-icon {
  width: 38px;
  height: 34px;
  display: grid;
  grid-template-columns: 24px 1fr;
  align-items: center;
  gap: 2px;
  color: var(--wind-color, #bfe9ff);
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.45));
}

.model-wind-icon.compact {
  width: 24px;
  height: 24px;
  grid-template-columns: 1fr;
}

.model-wind-icon svg {
  width: 26px;
  height: 26px;
  overflow: visible;
  transform: rotate(var(--wind-rotation, 0deg));
}

.model-wind-icon.compact svg {
  width: 22px;
  height: 22px;
}

.model-wind-arrow line,
.model-wind-arrow polygon {
  stroke: currentColor;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: currentColor;
}

.model-wind-icon span {
  display: inline-grid;
  min-width: 18px;
  height: 16px;
  place-items: center;
  border-radius: 999px;
  background: rgba(4, 8, 10, 0.74);
  color: #ffffff;
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 0.58rem;
  font-weight: 800;
  line-height: 1;
}

.past-observation-divicon {
  background: transparent;
  border: 0;
}

.past-observation-icon {
  width: 62px;
  min-height: 58px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1px 5px;
  align-items: center;
  padding: 6px 7px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 8px;
  background: rgba(4, 9, 10, 0.82);
  color: #edf8ef;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(3px);
}

.past-observation-icon strong,
.past-observation-icon label,
.past-observation-icon em {
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  line-height: 1;
}

.past-observation-icon strong {
  color: #8bd3ff;
  font-size: 0.66rem;
  letter-spacing: 0.04em;
}

.past-observation-icon span {
  justify-self: end;
  font-size: 0.86rem;
  font-weight: 800;
}

.past-observation-icon label {
  color: #f6c45a;
  font-size: 0.68rem;
}

.past-observation-icon em {
  justify-self: end;
  color: var(--muted);
  font-size: 0.62rem;
  font-style: normal;
}

.map-station-divicon {
  background: transparent;
  border: 0;
}

.map-station-icon {
  width: 58px;
  min-height: 48px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1px 5px;
  align-items: center;
  padding: 5px 6px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-left: 4px solid var(--station-temp-color, #96a3ad);
  border-radius: 7px;
  background: rgba(5, 10, 10, 0.78);
  color: #f0f7f1;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(3px);
}

.map-station-icon.primary {
  border-color: rgba(124, 255, 152, 0.5);
  border-left-color: #7cff98;
}

.map-station-icon.nearby_market {
  border-color: rgba(139, 211, 255, 0.44);
}

.map-station-icon.compact {
  width: 34px;
  min-height: 32px;
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
  padding: 3px 4px;
  border-left-width: 3px;
  background: rgba(5, 10, 10, 0.7);
}

.map-station-icon.dot {
  width: 16px;
  min-height: 16px;
  display: grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.map-station-icon.dot i {
  width: 9px;
  height: 9px;
  display: block;
  border: 1.5px solid rgba(255, 255, 255, 0.86);
  border-radius: 999px;
  background: var(--station-temp-color, #96a3ad);
  box-shadow: 0 0 0 2px rgba(4, 8, 10, 0.58), 0 2px 8px rgba(0, 0, 0, 0.45);
}

.map-station-icon.dot.primary i {
  width: 12px;
  height: 12px;
  border-color: #7cff98;
  box-shadow: 0 0 0 2px rgba(4, 8, 10, 0.64), 0 0 14px rgba(124, 255, 152, 0.4);
}

.map-station-icon.value-mode {
  border-left-color: var(--station-temp-color, #96a3ad);
}

.map-station-icon strong,
.map-station-icon label,
.map-station-icon em {
  font-family: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  line-height: 1;
}

.map-station-icon strong {
  min-width: 0;
  color: #bfe9ff;
  font-size: 0.61rem;
  letter-spacing: 0.03em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.map-station-icon span {
  justify-self: end;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
}

.map-station-icon.compact span {
  justify-self: center;
  font-size: 0.68rem;
}

.map-station-icon.compact label {
  justify-self: center;
  font-size: 0.48rem;
}

.map-station-icon label {
  color: #b8f0d0;
  font-size: 0.58rem;
}

.map-station-icon em {
  justify-self: end;
  color: #d5d9dd;
  font-size: 0.56rem;
  font-style: normal;
}

.weather-station-divicon {
  background: transparent;
  border: 0;
}

.weather-station-icon {
  width: 64px;
  height: 64px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 2px;
  border-radius: 18px;
  border: 1px solid rgba(139, 211, 255, 0.28);
  background: rgba(5, 11, 8, 0.9);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.34);
  color: #dff8e7;
  backdrop-filter: blur(4px);
}

.weather-station-icon.active {
  border-color: rgba(124, 255, 152, 0.6);
  box-shadow: 0 0 0 1px rgba(124, 255, 152, 0.28), 0 12px 28px rgba(0, 0, 0, 0.42);
}

.weather-station-code {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1;
}

.weather-station-barb {
  height: 34px;
  width: 34px;
  display: grid;
  place-items: center;
  color: #8bd3ff;
}

.weather-station-barb-svg {
  width: 34px;
  height: 34px;
  overflow: visible;
  filter: drop-shadow(0 0 6px rgba(87, 214, 255, 0.16));
}

.weather-station-calm-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #8bd3ff;
  box-shadow: 0 0 0 4px rgba(87, 214, 255, 0.12);
}

.weather-station-temp {
  font-size: 0.64rem;
  font-weight: 600;
  line-height: 1;
}

.weather-map-popup {
  min-width: 180px;
}

.market-contract-empty {
  padding: 36px 18px;
  color: var(--muted);
  text-align: center;
}

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

.positive {
  color: #7cff98;
}

.negative {
  color: #ff8c8c;
}

@media (max-width: 1180px) {
  body {
    overflow: auto;
  }

  .master-shell {
    grid-template-columns: 86px minmax(0, 1fr);
  }

  .master-workspace {
    grid-template-rows: minmax(380px, 46vh) auto auto auto;
  }

  .master-side {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: none;
  }

  .master-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .master-camera-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .app-shell {
    height: auto;
    grid-template-columns: 1fr;
    overflow: visible;
  }

  .panel-rail {
    display: none;
  }

  .sidebar {
    position: static;
    min-height: auto;
    height: auto;
    overflow: visible;
  }

  .main-panel {
    padding: 20px 18px 24px;
    height: auto;
    overflow: visible;
  }

  .command-health-strip {
    position: static;
    grid-template-columns: 1fr;
    margin: 12px 0 4px;
  }

  #station-subnav {
    position: static;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 18px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .observation-map {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .backtest-page-grid,
  .backtest-compact-grid,
  .market-volatility-grid,
  .model-lab-grid,
  .seasonality-grid {
    grid-template-columns: 1fr;
  }

  .backtest-agent-rail,
  .backtest-lab-panel,
  .backtest-selected-agent-panel,
  .backtest-compact-grid,
  #backtest-view > .backtest-page-grid > .table-panel:not(.backtest-agent-rail),
  .model-lab-guide-panel,
  .model-lab-grid > .panel,
  .seasonality-grid > .panel,
  .model-lab-plan-panel,
  .model-lab-table-panel,
  .model-lab-hero-panel,
  .model-lab-station-panel {
    grid-column: 1;
  }

  .model-lab-guide-grid,
  .seasonality-year-grid,
  .forward-test-explainer {
    grid-template-columns: 1fr;
  }

  .seasonality-controls {
    justify-content: stretch;
  }

  .seasonality-controls label,
  .seasonality-controls .market-day-button {
    width: 100%;
  }

  .backtest-agent-rail {
    grid-row: auto;
    position: static;
    min-height: auto;
    max-height: none;
  }

  .backtest-agent-list-wrap {
    min-height: 360px;
    max-height: 520px;
  }
}

@media (max-width: 900px) {
  body {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .master-shell,
  .master-workspace,
  .master-side {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    grid-template-areas: none;
  }

  .master-meter-panel,
  .master-temperature-panel,
  .master-range-panel,
  .master-field-panel,
  .master-analog-panel,
  .master-camera-panel {
    grid-area: auto;
  }

  .master-heat-meter {
    min-height: 360px;
  }

  .master-meter-scale {
    min-height: 300px;
  }

  .master-field-grid,
  .master-analog-grid,
  .master-market-summary,
  .master-camera-grid {
    grid-template-columns: 1fr;
  }

  .mobile-topbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 220;
    height: 64px;
    padding: 10px 12px;
    display: grid;
    grid-template-columns: 46px 1fr 46px;
    gap: 10px;
    align-items: center;
    background: linear-gradient(180deg, rgba(5, 14, 9, 0.96), rgba(5, 14, 9, 0.82));
    border-bottom: 1px solid rgba(124, 255, 152, 0.12);
    backdrop-filter: blur(14px);
    pointer-events: auto;
  }

  .mobile-orb {
    position: relative;
    z-index: 260;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(124, 255, 152, 0.24);
    background:
      radial-gradient(circle at 35% 28%, rgba(124, 255, 152, 0.24), transparent 34%),
      rgba(9, 21, 14, 0.96);
    color: var(--text);
    font-size: 1.2rem;
    font-weight: 800;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.3);
  }

  #mobile-station-menu {
    justify-self: start;
  }

  #mobile-page-menu {
    justify-self: end;
  }

  .mobile-title {
    position: relative;
    z-index: 255;
    display: grid;
    min-width: 0;
    text-align: center;
    line-height: 1.12;
    pointer-events: none;
  }

  .mobile-title strong {
    font-family: "Space Grotesk", "Segoe UI", sans-serif;
    letter-spacing: 0.04em;
  }

  .mobile-title span {
    color: var(--accent-strong);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
  }

  .mobile-backdrop {
    position: fixed;
    inset: 0;
    z-index: 190;
    border: 0;
    background: rgba(2, 8, 5, 0.62);
    backdrop-filter: blur(4px);
  }

  .mobile-backdrop:not(.hidden) {
    display: block;
  }

  .mobile-page-dropdown {
    position: fixed;
    top: 72px;
    right: 12px;
    z-index: 230;
    width: min(280px, calc(100vw - 24px));
    max-height: calc(100vh - 92px);
    overflow: auto;
    padding: 10px;
    border-radius: 22px;
    border: 1px solid rgba(124, 255, 152, 0.18);
    background: linear-gradient(180deg, rgba(8, 18, 13, 0.98), rgba(4, 10, 7, 0.98));
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.46);
  }

  .mobile-page-dropdown:not(.hidden) {
    display: grid;
    gap: 8px;
  }

  .mobile-page-dropdown button {
    border: 1px solid rgba(124, 255, 152, 0.1);
    border-radius: 15px;
    padding: 12px 13px;
    text-align: left;
    background: rgba(255, 255, 255, 0.025);
    color: var(--text);
    font: inherit;
    font-weight: 750;
  }

  .mobile-page-dropdown button.active {
    border-color: rgba(124, 255, 152, 0.42);
    background: rgba(0, 200, 5, 0.14);
    color: var(--accent-strong);
  }

  .app-shell {
    display: block;
    min-height: 100vh;
  }

  .panel-rail {
    display: none;
  }

  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 230;
    width: min(86vw, 340px);
    height: 100vh;
    padding-top: 76px;
    transform: translateX(-105%);
    transition: transform 180ms ease;
    overflow-y: auto;
  }

  body.mobile-sidebar-open .sidebar {
    transform: translateX(0);
  }

  .flow-strip {
    display: grid;
  }

  .main-panel {
    padding: 126px 12px 18px;
    height: auto;
    overflow: visible;
    max-width: 100vw;
  }

  .hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .global-market-watch {
    grid-template-columns: 1fr;
  }

  #station-subnav {
    display: none;
  }

  .command-health-strip {
    display: none;
  }

  .grid,
  .metric-grid,
  .station-mini-grid,
  .observation-map,
  .indicators-layout,
  .solstitium-signal-why,
  .solstitium-signal-tables {
    grid-template-columns: 1fr;
  }

  .indicators-head {
    display: grid;
  }

  .indicators-rule-wrap table {
    min-width: 960px;
  }

  .indicator-meter-shell,
  .indicator-meter-dual,
  .indicators-events-grid,
  .indicators-scorecard-grid {
    grid-template-columns: 1fr;
  }

  .indicator-meter-scale {
    min-height: 360px;
  }

  .indicator-range-history-head {
    display: grid;
  }

  .indicator-range-history-actions {
    justify-content: flex-start;
    min-width: 0;
  }

  .indicator-date-picker input {
    width: 124px;
  }

  .indicator-meter-marker {
    width: 56px;
  }

  .indicator-meter-marker span {
    left: 62px;
  }

  .indicator-meter-marker.expected {
    left: calc(50% - 87px);
  }

  .indicator-meter-marker.expected span {
    right: 62px;
  }

  .observation-tile.wide {
    grid-column: span 1;
  }

  .observation-strip-head,
  .source-health-strip {
    display: grid;
  }

  .observation-strip-head {
    gap: 10px;
  }

  .observation-strip-head .panel-note {
    font-size: 0.82rem;
  }

  .observation-health-panel {
    padding: 12px;
  }

  .source-health-strip {
    gap: 8px;
  }

  .source-health-pill {
    width: 100%;
    min-height: 34px;
    padding: 7px 10px;
    border-radius: 12px;
  }

  .source-health-label {
    letter-spacing: 0.06em;
    font-size: 0.72rem;
  }

  .observation-current-panel {
    gap: 10px;
  }

  .observation-map {
    gap: 8px;
  }

  .observation-tile {
    min-height: auto;
    padding: 11px;
    border-radius: 12px;
    gap: 7px;
  }

  .observation-tile-head {
    gap: 8px;
  }

  .observation-icon {
    min-width: 28px;
    height: 28px;
    border-radius: 8px;
    padding: 0 7px;
    font-size: 0.68rem;
  }

  .observation-tile label {
    letter-spacing: 0.08em;
    font-size: 0.64rem;
  }

  .observation-full-label {
    font-size: 0.76rem;
  }

  .observation-tile strong {
    font-size: 1.12rem;
    line-height: 1.1;
  }

  .regime-signal-grid {
    grid-template-columns: 1fr;
  }

  .nws-obs-controls {
    justify-items: stretch;
  }

  .nws-obs-controls .market-day-toggle {
    gap: 6px;
  }

  .nws-obs-controls .market-day-button {
    flex: 1 1 auto;
    padding: 7px 9px;
    font-size: 0.74rem;
  }

  #nws-obs-pan-controls {
    display: none;
  }

  .obs-timeline-scroll {
    display: none;
  }

  .obs-mobile-cards {
    display: grid;
    gap: 10px;
  }

  .obs-mobile-card {
    border: 1px solid rgba(124, 255, 152, 0.1);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(11, 23, 17, 0.96), rgba(7, 15, 11, 0.98));
    overflow: hidden;
  }

  .obs-mobile-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(124, 255, 152, 0.08);
  }

  .obs-mobile-card-head strong {
    color: var(--accent-strong);
    font-size: 0.94rem;
  }

  .obs-mobile-card-head span {
    color: var(--muted);
    font-size: 0.78rem;
    text-align: right;
  }

  .obs-mobile-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .obs-mobile-card-grid div {
    min-width: 0;
    padding: 9px 10px;
    border-right: 1px solid rgba(124, 255, 152, 0.05);
    border-bottom: 1px solid rgba(124, 255, 152, 0.05);
  }

  .obs-mobile-card-grid div:nth-child(2n) {
    border-right: 0;
  }

  .obs-mobile-card-grid label,
  .obs-mobile-card-grid span {
    display: block;
    color: var(--muted);
    font-size: 0.7rem;
  }

  .obs-mobile-card-grid label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 3px;
  }

  .obs-mobile-card-grid strong {
    display: block;
    color: var(--text);
    font-size: 0.92rem;
    font-variant-numeric: tabular-nums;
  }

  .cams-grid,
  .cams-meta-grid {
    grid-template-columns: 1fr;
  }

  .history-time-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .history-time-histogram {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .history-chart-row {
    grid-template-columns: 1fr;
  }

  .history-market-head,
  .history-market-controls,
  .history-replay-head,
  .history-replay-controls {
    display: grid;
  }

  .paper-agent-actions {
    justify-content: stretch;
  }

  .paper-agent-actions .market-day-button {
    flex: 1;
  }

  .weather-time-card {
    grid-template-columns: 1fr;
  }

  .weather-time-buttons {
    justify-content: stretch;
  }

  .weather-time-buttons .market-day-button {
    flex: 1 1 72px;
  }

  .weather-time-slider-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .panel {
    padding: 14px;
    border-radius: 18px;
  }

  .table-wrap,
  .metar-table-wrap,
  .climatesight-table-wrap,
  .market-contract-chart-wrap {
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
  }

  .climatesight-table-wrap {
    max-height: none;
  }

  .compact-panel-head {
    align-items: center;
  }

  table {
    min-width: 760px;
  }

  .obs-timeline-table {
    min-width: 0;
  }

  .obs-timeline-table,
  .metar-truth-table {
    min-width: max-content;
  }

  .weather-map,
  .cams-map {
    min-height: 62vh;
  }

  .chart-wrap,
  .history-replay-chart-wrap,
  .market-contract-chart-wrap {
    max-width: 100%;
  }
}
