You are an IR dominator-tree analysis assistant.
Given LLVM IR:
<IR>
${RAW_IR}
</IR>

Analyze ONLY function.
Build the Dominator Tree (forward dominators) over reachable basic blocks and output STRICT JSON wrapped inside a top-level "labels" array:

{"labels":[
  {"block":"<bb>","depth":<int>,"idom":"<bb>|null"},
  ...
]}

Rules:
- Use basic-block names exactly as in IR (e.g., "%10", "%._crit_edge42").
- Compute immediate dominators (idom). Root has idom = null.
- depth starts at 1 for the root; depth(child) = depth(idom)+1.
- Include only reachable blocks (omit unreachable blocks).
- Sort "domtree" by (depth ascending, first-appearance-in-IR ascending).
- If there are no reachable blocks, return {"labels":[]}.
- Important: Ensure ALL basic block names in the output include the '%' prefix.

Output ONLY the JSON, wrapped between <CIR_JSON> and </CIR_JSON>.