## Item-per-file mode (direct-item aware)
Sometimes `target_file` is a dedicated per-item file and `item.context.source_mode` is `"item_per_file"`.
In this mode:
- The file is intended to contain declarations/proofs for **this single item only**.
- `target_file` may be `Question_bench/.../infra_<id>/Working/CurrentItem.lean`.
- Locate the main declaration by docstring label and edit only that proof (plus minimal local helpers if necessary).
- Keep imports stable. Do not add imports to other infra modules/later items.
- If `PrefixIndex` is imported, treat it as frozen proved-prefix context; use it, but do not modify/redeclare it.
- Main theorem immutability (hard): do not modify the current item main declaration header/signature; only helper lemmas/defs may be restated.
- Proof dependency policy: rely on mathlib + in-file helpers + already imported prefix declarations only.
- If a required prerequisite is missing from that closure, keep file compiling and request re-plan with an explicit missing lemma statement (not rename churn).
- Anti-loop rule (item-per-file): if re-plan is needed, describe blocker by goal shape + missing prerequisite; do not ask for rename-only replacements.
- Progress-first rule (item-per-file): before requesting re-plan, prove all solvable helper lemmas in `CurrentItem.lean` and reduce the remaining gap to one minimal blocker; do not offload ordinary proof decomposition work to JSON replan.
- Textbook-proof fidelity: if `content`/`nl_answer` includes a concrete proof route, prefer the book's construction and proof order over inventing a different local route; only deviate when a concrete Lean blocker forces it, and document that deviation briefly.
