{
  "contract_version": "gab_084_contract_v1",
  "gab_id": "GAB-084",
  "canonical_name": "VisualInteractiveLegend",
  "module_owner": "EdTechVisualLearning",
  "renderer_key": "text_cta",
  "required_fields": [
    "gab_id",
    "legend_id",
    "title",
    "visual_alt",
    "items"
  ],
  "optional_fields": [
    "visual_description",
    "caption_default"
  ],
  "field_types": {
    "legend_id": "string — identifiant unique de cette instance de légende",
    "title": "string — titre affiché dans le hero",
    "visual_description": "string — description textuelle du schéma visuel",
    "visual_alt": "string — texte alternatif accessible pour le schéma",
    "items": "array<{zone_id:string, label:string, color:string, bullet_class:string, zone_class:string, description:string}> — au moins 2 items",
    "caption_default": "string — texte d'instruction affiché avant toute sélection"
  },
  "constraints": [
    "items doit contenir au moins 2 éléments.",
    "Chaque item doit avoir zone_id, label, color, bullet_class, zone_class, description.",
    "zone_id doit être unique dans le tableau items.",
    "bullet_class et zone_class permettent au HTML de lier visuellement item et zone.",
    "visual_alt est obligatoire pour l'accessibilité."
  ],
  "blocked_conditions": [
    "items absent ou tableau vide",
    "legend_id absent",
    "visual_alt absent"
  ],
  "accessibility": [
    "keyboard_navigable",
    "focus_visible",
    "prefers_reduced_motion",
    "visual_alt sur le schéma",
    "aria-label sur les items interactifs"
  ],
  "qa_cases": [
    { "case": "instance conforme", "expected": "rendu complet, zones et items cliquables, 0 erreur" },
    { "case": "items absent ou vide", "expected": "BLOCKED listant items absent" },
    { "case": "legend_id absent", "expected": "BLOCKED listant legend_id absent" },
    { "case": "visual_alt absent", "expected": "BLOCKED listant visual_alt absent" },
    { "case": "clic item liste", "expected": "zone correspondante surlignée sur le schéma, item actif dans la liste" },
    { "case": "instance externe injectée via init(ext)", "expected": "le rendu change sans modifier le HTML" },
    { "case": "responsive 375/768/1024", "expected": "aucun débordement horizontal, layout colonne sur mobile" }
  ],
  "traceability": {
    "derived_from_core_gab": "GAB-084",
    "note": "Ce schema VALIDE l'instance. Le contrat pédagogique complet (input_contract/validation_logic/feedback_scoring_logic) vit dans le CORE-GAB officiel, pas ici (évite la duplication)."
  }
}
