(1) Personalized rubric with 1–5 scores for each criterion

Need Alignment
- 5: Laser-focused on the user’s Django use case. Clearly contrasts DDD vs MTV in Django terms: where business logic lives; model responsibility (Active Record vs rich, persistence-ignorant domain model); repositories; layered architecture mapped to Django (Presentation–Application–Domain–Infrastructure); DDD building blocks (Entities, Value Objects, Aggregates, Domain Services, Repositories, Bounded Context) tied to Django apps. Includes pros/cons, “when to use which,” a concrete Django directory layout, and small code that wires views→application services→domain→repository. No metaphors, no irrelevant detours (e.g., microservice deployment), no “Doc X” references.
- 4: Covers most of the above but misses one or two concrete items (e.g., lacks either code or directory tree, or only briefly mentions repositories/DDD blocks). Still Django-centered and actionable.
- 3: Generic comparison that requires the reader to translate to Django. May discuss DDD/MTV correctly but without Django wiring, code, or structure, or omits “when to use which.”
- 2: On-topic but overly high-level or metaphor-heavy; weak or no Django tie-ins; lacks concrete structures and code; unclear about model responsibilities or where business logic belongs.
- 1: Off-topic/misdirected (e.g., unrelated patterns, other frameworks), or materially misunderstands DDD/MTV in Django.

Content Depth
- 5: Right-sized for an intermediate Django practitioner. Uses accurate DDD terminology (Entities, Value Objects, Aggregates, Domain Services, Repositories, Bounded Context) and maps them to Django. Shows practical wiring (e.g., Protocol-based repository interface, Django ORM implementation, @transaction.atomic for use cases). Avoids deep theory (event sourcing, CQRS) unless necessary. Concise, correct, and directly applicable.
- 4: Mostly correct and practical with minor gaps (e.g., skips one DDD building block or omits transaction boundary) or slightly light on Django-specifics. Still easy to apply.
- 3: Understandable but mismatched depth: either too generic/high-level or drifts into theory without Django grounding; requires extra effort to apply.
- 2: Too basic or too abstract; missing key DDD pieces and/or Django mapping; little to no usable code or structure.
- 1: Severely mismatched (e.g., academic deep dive or superficial overview with significant inaccuracies).

Tone
- 5: Concise, professional, and friendly. Direct and neutral; no hype. Avoids analogies/metaphors and marketing language. No or minimal emojis.
- 4: Generally professional with minor stylistic fluff (e.g., a single emoji or light embellishment) that doesn’t distract.
- 3: Functionally acceptable but somewhat playful, chatty, or stiff/robotic. May include mild analogies or emojis.
- 2: Prominently metaphorical or gimmicky (e.g., “Avengers,” “symphony”), causing distraction or reduced clarity.
- 1: Inappropriate, condescending, or otherwise off-putting.

Explanation Style
- 5: Highly scannable. Clear sectioning with short bullet lists; small, focused code snippets; a simple Django directory tree; and a concise final comparison summary (bulleted or a very compact table—no full-sentence cells). Avoids long paragraphs and irrelevant references (e.g., “Doc 1/2/3”). Highlights key points (bold sparingly) without visual clutter.
- 4: Well organized and mostly scannable but missing one preferred artifact (e.g., either code or directory tree) or uses slightly long bullets/sentences. Still easy to follow.
- 3: Understandable but requires extra effort: fewer headings, longer bullets/paragraphs, or a wordy table. Lacks either code or directory layout.
- 2: Hard to scan: narrative-heavy, metaphor-first, minimal structure, no code or directory tree, no concise summary.
- 1: Disorganized and incompatible with the preferred learning style; no clear sections, bullets, code, or summary.