{
  "contract_version": "gab_086_contract_v1",
  "gab_id": "GAB-086",
  "canonical_name": "VisualMethodSteps",
  "module_owner": "EdTechVisualLearning",
  "renderer_key": "text_cta",
  "required_fields": [
    "gab_id",
    "method_steps_id",
    "title",
    "steps"
  ],
  "optional_fields": [
    "icon",
    "show_progress",
    "cta_label",
    "_note_dev"
  ],
  "field_types": {
    "method_steps_id": "string — identifiant unique de l'instance (slug)",
    "title": "string — titre de la fiche méthode affiché en en-tête",
    "icon": "string — emoji affiché dans l'icône d'en-tête (défaut: 📝)",
    "steps": "array<{order:number, text:string}> — liste ordonnée des étapes à cocher",
    "show_progress": "boolean — affiche la barre de progression (défaut: true)",
    "cta_label": "string — libellé du bouton CTA principal (défaut: 'Commencer')"
  },
  "constraints": [
    "steps doit contenir au moins 1 élément.",
    "Chaque étape doit avoir un champ text non vide.",
    "order est indicatif pour l'affichage ; l'index de tableau fait foi pour l'ordre réel.",
    "icon : emoji uniquement, pas d'HTML brut.",
    "cta_label : libellé court (≤ 40 caractères recommandé)."
  ],
  "blocked_conditions": [
    "gab_id absent",
    "method_steps_id absent",
    "title absent",
    "steps vides"
  ],
  "accessibility": [
    "keyboard_navigable",
    "focus_visible",
    "prefers_reduced_motion",
    "tabindex sur chaque étape"
  ],
  "qa_cases": [
    { "case": "instance conforme", "expected": "rendu complet : en-tête, barre de progression, toutes les étapes, CTA — 0 erreur" },
    { "case": "champ requis manquant (steps vides)", "expected": "BLOCKED listant le champ manquant, aucune étape affichée" },
    { "case": "cocher toutes les étapes", "expected": "barre à 100%, message de complétion, étapes barrées" },
    { "case": "instance externe injectée via ENGINE.init(ext)", "expected": "le rendu change sans modifier le HTML" },
    { "case": "responsive 375/768/1024", "expected": "aucun débordement horizontal, étapes lisibles" },
    { "case": "show_progress: false", "expected": "barre de progression absente, reste fonctionnel" }
  ],
  "traceability": {
    "derived_from_core_gab": "GAB-086",
    "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)."
  }
}
