.visual-panel {
  border: 1px solid rgba(160, 141, 131, 0.3);
  border-radius: 8px;
  background: rgba(20, 19, 18, 0.72);
  padding: clamp(18px, 3vw, 28px);
}

.visual-title {
  display: block;
  color: #85d3de;
  font-family: "Geist", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  margin-bottom: 14px;
  text-transform: uppercase;
}

.visual-caption {
  color: #d7c2b7;
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
  margin-top: 14px;
}

.split-panel,
.evidence-grid,
.heatmap-grid,
.swimlane,
.decision-tree {
  display: grid;
  gap: 12px;
}

.split-panel {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.heatmap-grid {
  grid-template-columns: minmax(120px, 0.75fr) repeat(4, minmax(0, 1fr));
}

.swimlane {
  grid-template-columns: minmax(120px, 0.55fr) repeat(4, minmax(0, 1fr));
}

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

.visual-card,
.heatmap-cell,
.swimlane-cell,
.decision-node {
  border: 1px solid rgba(133, 211, 222, 0.24);
  border-radius: 8px;
  background: rgba(13, 12, 11, 0.72);
  color: #d7c2b7;
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.42;
  padding: 13px;
}

.visual-card strong,
.decision-node strong {
  color: #fefcf9;
  display: block;
  font-size: 15px;
  line-height: 1.3;
  margin-bottom: 8px;
}

.visual-card.warn,
.decision-node.warn,
.heatmap-cell.high {
  border-color: rgba(255, 182, 136, 0.52);
  box-shadow: 0 0 24px rgba(255, 182, 136, 0.08);
}

.heatmap-cell,
.swimlane-cell {
  min-height: 74px;
}

.heatmap-cell.header,
.swimlane-cell.header {
  color: #85d3de;
  font-family: "Geist", system-ui, sans-serif;
  font-size: 10px;
  letter-spacing: 0.1em;
  min-height: auto;
  text-transform: uppercase;
}

.heatmap-cell.medium {
  border-color: rgba(189, 203, 173, 0.46);
}

.heatmap-cell.low {
  opacity: 0.72;
}

.swimlane-cell.role {
  color: #85d3de;
}

.visual-checklist {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
}

.visual-checklist li {
  list-style: none;
  border-left: 3px solid rgba(133, 211, 222, 0.58);
  background: rgba(13, 12, 11, 0.6);
  border-radius: 6px;
  color: #d7c2b7;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.45;
  padding: 10px 12px;
}

@media (max-width: 900px) {
  .split-panel,
  .evidence-grid,
  .decision-tree {
    grid-template-columns: 1fr;
  }

  .heatmap-grid,
  .swimlane {
    grid-template-columns: 1fr;
  }
}
