diff --git a/translated_images/es/.co-op-translator.json b/translated_images/es/.co-op-translator.json
new file mode 100644
index 00000000..f461fb83
--- /dev/null
+++ b/translated_images/es/.co-op-translator.json
@@ -0,0 +1,752 @@
+{
+ "agent-file-placement-decision-tree.d8d4810a5984edc7.webp": {
+ "original_hash": "ce88b9c96bf3728ff5f71a560e97623d",
+ "translation_date": "2026-06-30T08:32:40+00:00",
+ "source_file": "04-agents-custom-instructions/assets/agent-file-placement-decision-tree.png",
+ "language_code": "es"
+ },
+ "auth-device-flow.9a0e754dba878d2e.webp": {
+ "original_hash": "0aff0784cbc9cd963cbc0ede73d75f70",
+ "translation_date": "2026-06-30T08:35:08+00:00",
+ "source_file": "00-quick-start/assets/auth-device-flow.png",
+ "language_code": "es"
+ },
+ "browser-extensions-analogy.95b41c62fc9d09a2.webp": {
+ "original_hash": "8cd7fa5f65d0efee0ee75dd4473db650",
+ "translation_date": "2026-06-30T08:33:54+00:00",
+ "source_file": "06-mcp-servers/assets/browser-extensions-analogy.png",
+ "language_code": "es"
+ },
+ "carpenter-workflow-steps.8b68419bb4018a49.webp": {
+ "original_hash": "f1ccaf91d5438bda0b702e13e84d1b7a",
+ "translation_date": "2026-06-30T08:25:36+00:00",
+ "source_file": "03-development-workflows/assets/carpenter-workflow-steps.png",
+ "language_code": "es"
+ },
+ "ch00-clone.16352cc945d101a9.webp": {
+ "original_hash": "836604f5fbc2ad4a95c7bb3043a022d4",
+ "translation_date": "2026-06-30T08:30:43+00:00",
+ "source_file": "docs/assets/img/ch00-clone.webp",
+ "language_code": "es"
+ },
+ "ch00-codespaces.8a84ca9f96184631.webp": {
+ "original_hash": "c8acdbe2bcf61ef43812b7cc402301e9",
+ "translation_date": "2026-06-30T08:31:03+00:00",
+ "source_file": "docs/assets/img/ch00-codespaces.webp",
+ "language_code": "es"
+ },
+ "ch00-install.8f3a9e8dae87d0d5.webp": {
+ "original_hash": "5a025de8a0e6486e33320904534a4e20",
+ "translation_date": "2026-06-30T08:30:38+00:00",
+ "source_file": "docs/assets/img/ch00-install.webp",
+ "language_code": "es"
+ },
+ "ch00-login.e5fca09acbcda313.webp": {
+ "original_hash": "f612b5bbe8d9acb17d243fcb216e08d8",
+ "translation_date": "2026-06-30T08:31:00+00:00",
+ "source_file": "docs/assets/img/ch00-login.webp",
+ "language_code": "es"
+ },
+ "ch00-ready.1d85317bff16850d.webp": {
+ "original_hash": "173c03b00cec826b11fc3d2c8ffe1234",
+ "translation_date": "2026-06-30T08:31:20+00:00",
+ "source_file": "docs/assets/img/ch00-ready.webp",
+ "language_code": "es"
+ },
+ "ch00-verify.d53479158d93f42a.webp": {
+ "original_hash": "c045a8ee32ee2347d2840d38fc9ce337",
+ "translation_date": "2026-06-30T08:30:35+00:00",
+ "source_file": "docs/assets/img/ch00-verify.webp",
+ "language_code": "es"
+ },
+ "ch00-welcome.f74d92711c1ad617.webp": {
+ "original_hash": "48bc90f59017fe0dfb036bea1c650e1b",
+ "translation_date": "2026-06-30T08:31:18+00:00",
+ "source_file": "docs/assets/img/ch00-welcome.webp",
+ "language_code": "es"
+ },
+ "ch01-commands.16a99e46fa3dec36.webp": {
+ "original_hash": "7dd054920de9e27ca8871976c1525115",
+ "translation_date": "2026-06-30T08:31:44+00:00",
+ "source_file": "docs/assets/img/ch01-commands.webp",
+ "language_code": "es"
+ },
+ "ch01-interactive.2ebdca0ddaa3495c.webp": {
+ "original_hash": "7d5998f00b6b7efa91bfb43707b738cc",
+ "translation_date": "2026-06-30T08:32:15+00:00",
+ "source_file": "docs/assets/img/ch01-interactive.webp",
+ "language_code": "es"
+ },
+ "ch01-magic.0487ae1a9da17a6f.webp": {
+ "original_hash": "cb8fa238c19c4d0ea813cd0547142c5f",
+ "translation_date": "2026-06-30T08:32:08+00:00",
+ "source_file": "docs/assets/img/ch01-magic.webp",
+ "language_code": "es"
+ },
+ "ch01-modes.e671651c4d070dd6.webp": {
+ "original_hash": "79217589b52270104d03aafb363dfb17",
+ "translation_date": "2026-06-30T08:31:19+00:00",
+ "source_file": "docs/assets/img/ch01-modes.webp",
+ "language_code": "es"
+ },
+ "ch01-next.1a23bf38f6c40433.webp": {
+ "original_hash": "a857daa8c41fce1792824fc11363d6ca",
+ "translation_date": "2026-06-30T08:32:07+00:00",
+ "source_file": "docs/assets/img/ch01-next.webp",
+ "language_code": "es"
+ },
+ "ch01-permissions.55725a7dec198230.webp": {
+ "original_hash": "d77d5ece537998f4ed937ba03c91f283",
+ "translation_date": "2026-06-30T08:31:40+00:00",
+ "source_file": "docs/assets/img/ch01-permissions.webp",
+ "language_code": "es"
+ },
+ "ch01-plan.e40e7b0b6b8f7ccd.webp": {
+ "original_hash": "1d83a49e48831c5a51983750fa1c1f1e",
+ "translation_date": "2026-06-30T08:31:09+00:00",
+ "source_file": "docs/assets/img/ch01-plan.webp",
+ "language_code": "es"
+ },
+ "ch01-programmatic.21edc4a4609135b5.webp": {
+ "original_hash": "9e18588eb151c453d94f7ec1b6785a2b",
+ "translation_date": "2026-06-30T08:30:36+00:00",
+ "source_file": "docs/assets/img/ch01-programmatic.webp",
+ "language_code": "es"
+ },
+ "ch01-review.01f09a31479e396d.webp": {
+ "original_hash": "896e372936f1ca6572a875c4c500ea34",
+ "translation_date": "2026-06-30T08:31:53+00:00",
+ "source_file": "docs/assets/img/ch01-review.webp",
+ "language_code": "es"
+ },
+ "ch02-atsyntax.36bdf00b204730c7.webp": {
+ "original_hash": "2a1909290d57a17d7e6b7c913fff5a06",
+ "translation_date": "2026-06-30T08:31:26+00:00",
+ "source_file": "docs/assets/img/ch02-atsyntax.webp",
+ "language_code": "es"
+ },
+ "ch02-context-limit.3d9c9b9ebb0a4a36.webp": {
+ "original_hash": "f9d6e95cf3a4ec64a4ad0e561ddc4d2b",
+ "translation_date": "2026-06-30T08:31:41+00:00",
+ "source_file": "docs/assets/img/ch02-context-limit.webp",
+ "language_code": "es"
+ },
+ "ch02-context.7d7b297d649065b5.webp": {
+ "original_hash": "a5bc9372f29997cc3c2d8c24b2c63221",
+ "translation_date": "2026-06-30T08:30:44+00:00",
+ "source_file": "docs/assets/img/ch02-context.webp",
+ "language_code": "es"
+ },
+ "ch02-images.ee8e51872fa7be82.webp": {
+ "original_hash": "6e616d53d5019e08010ce2c279b04a9a",
+ "translation_date": "2026-06-30T08:32:14+00:00",
+ "source_file": "docs/assets/img/ch02-images.webp",
+ "language_code": "es"
+ },
+ "ch02-memory.90a53b01501bef07.webp": {
+ "original_hash": "964b4b4a54c1e550bf79ed994ac5961b",
+ "translation_date": "2026-06-30T08:32:07+00:00",
+ "source_file": "docs/assets/img/ch02-memory.webp",
+ "language_code": "es"
+ },
+ "ch02-multifile.86988013e1164f02.webp": {
+ "original_hash": "8c7a8de867f4a4b1252d441c79213196",
+ "translation_date": "2026-06-30T08:31:04+00:00",
+ "source_file": "docs/assets/img/ch02-multifile.webp",
+ "language_code": "es"
+ },
+ "ch02-next.e9e9c5bdfa29dee0.webp": {
+ "original_hash": "107a9cbf03a47091cb9f515ca760135b",
+ "translation_date": "2026-06-30T08:31:53+00:00",
+ "source_file": "docs/assets/img/ch02-next.webp",
+ "language_code": "es"
+ },
+ "ch02-sessions.a1094c152e546bea.webp": {
+ "original_hash": "0de0db9cbf6c3f5c736792f9ffc5e5ba",
+ "translation_date": "2026-06-30T08:31:14+00:00",
+ "source_file": "docs/assets/img/ch02-sessions.webp",
+ "language_code": "es"
+ },
+ "ch02-what-is-context.0301588e8db9d14a.webp": {
+ "original_hash": "7ebe3ab43a9c23935d3c821dc349257f",
+ "translation_date": "2026-06-30T08:31:23+00:00",
+ "source_file": "docs/assets/img/ch02-what-is-context.webp",
+ "language_code": "es"
+ },
+ "ch03-debug.f46fbdd63679a16e.webp": {
+ "original_hash": "84e54baf9f4619c09282b165b88b776d",
+ "translation_date": "2026-06-30T08:30:48+00:00",
+ "source_file": "docs/assets/img/ch03-debug.webp",
+ "language_code": "es"
+ },
+ "ch03-delegate.7063ed7fbc64cee3.webp": {
+ "original_hash": "5d8bf8acb835f9ec8b2c659dd2bdf751",
+ "translation_date": "2026-06-30T08:32:00+00:00",
+ "source_file": "docs/assets/img/ch03-delegate.webp",
+ "language_code": "es"
+ },
+ "ch03-next.73dce2f19174151b.webp": {
+ "original_hash": "3e6f65bc52b161520f322e4d4fd5fce3",
+ "translation_date": "2026-06-30T08:31:52+00:00",
+ "source_file": "docs/assets/img/ch03-next.webp",
+ "language_code": "es"
+ },
+ "ch03-pr.eefe2af9a13d5a8f.webp": {
+ "original_hash": "712812210d1b89cd62d137b576872951",
+ "translation_date": "2026-06-30T08:32:08+00:00",
+ "source_file": "docs/assets/img/ch03-pr.webp",
+ "language_code": "es"
+ },
+ "ch03-refactor.22a097aa4bf5ab07.webp": {
+ "original_hash": "5e8a800d2e43e8762b590071931199fd",
+ "translation_date": "2026-06-30T08:30:39+00:00",
+ "source_file": "docs/assets/img/ch03-refactor.webp",
+ "language_code": "es"
+ },
+ "ch03-review.1d950e5693c90313.webp": {
+ "original_hash": "5bd269472dc7c01faa4cd633c1b89bce",
+ "translation_date": "2026-06-30T08:31:17+00:00",
+ "source_file": "docs/assets/img/ch03-review.webp",
+ "language_code": "es"
+ },
+ "ch03-ship.d2a1722060ca422f.webp": {
+ "original_hash": "82713511f81cc321e3324594b0569fad",
+ "translation_date": "2026-06-30T08:31:59+00:00",
+ "source_file": "docs/assets/img/ch03-ship.webp",
+ "language_code": "es"
+ },
+ "ch03-test.8816391c73d1b295.webp": {
+ "original_hash": "8e1ed94c3bcae7d4a1d392b0aede6778",
+ "translation_date": "2026-06-30T08:31:49+00:00",
+ "source_file": "docs/assets/img/ch03-test.webp",
+ "language_code": "es"
+ },
+ "ch03-workflows.a899d71ab51395d7.webp": {
+ "original_hash": "68778b86380f9bb658c45b7916b72cca",
+ "translation_date": "2026-06-30T08:31:21+00:00",
+ "source_file": "docs/assets/img/ch03-workflows.webp",
+ "language_code": "es"
+ },
+ "ch04-agents.69de16c29c7e5489.webp": {
+ "original_hash": "6a971b0e956aa7031da099a02846a084",
+ "translation_date": "2026-06-30T08:32:02+00:00",
+ "source_file": "docs/assets/img/ch04-agents.webp",
+ "language_code": "es"
+ },
+ "ch04-builtin.741d35728c6b6830.webp": {
+ "original_hash": "2ece45dabfd3900acf4854867509b47b",
+ "translation_date": "2026-06-30T08:31:58+00:00",
+ "source_file": "docs/assets/img/ch04-builtin.webp",
+ "language_code": "es"
+ },
+ "ch04-custom.7b3f5ef9430c8aee.webp": {
+ "original_hash": "c39e0092b5c5450d1d30fe83c1fc5db1",
+ "translation_date": "2026-06-30T08:31:09+00:00",
+ "source_file": "docs/assets/img/ch04-custom.webp",
+ "language_code": "es"
+ },
+ "ch04-init.d65c1056d041acaa.webp": {
+ "original_hash": "2c40f5821d1e5f8e6d4e8a3b51cd85e5",
+ "translation_date": "2026-06-30T08:31:32+00:00",
+ "source_file": "docs/assets/img/ch04-init.webp",
+ "language_code": "es"
+ },
+ "ch04-instructions.519b082ec473475b.webp": {
+ "original_hash": "db94b4e44cfc6f795f6e17d480de123a",
+ "translation_date": "2026-06-30T08:31:04+00:00",
+ "source_file": "docs/assets/img/ch04-instructions.webp",
+ "language_code": "es"
+ },
+ "ch04-multiagent.d88e2940fe37a392.webp": {
+ "original_hash": "c5b96c9ee14c9e1a1b8882d0e156c818",
+ "translation_date": "2026-06-30T08:32:09+00:00",
+ "source_file": "docs/assets/img/ch04-multiagent.webp",
+ "language_code": "es"
+ },
+ "ch04-next.7dc7b0142b3a0048.webp": {
+ "original_hash": "dd073293be6946a286f3c9c481908a65",
+ "translation_date": "2026-06-30T08:32:15+00:00",
+ "source_file": "docs/assets/img/ch04-next.webp",
+ "language_code": "es"
+ },
+ "ch04-pick.99090fec629c59f0.webp": {
+ "original_hash": "9a117b9202c77a8053d73fd42daedffa",
+ "translation_date": "2026-06-30T08:30:34+00:00",
+ "source_file": "docs/assets/img/ch04-pick.webp",
+ "language_code": "es"
+ },
+ "ch04-scope.a5ab812c0c0dbd1e.webp": {
+ "original_hash": "6522da344656109f1f04047d118ad217",
+ "translation_date": "2026-06-30T08:31:17+00:00",
+ "source_file": "docs/assets/img/ch04-scope.webp",
+ "language_code": "es"
+ },
+ "ch05-auto.7e5d67bc45ea556c.webp": {
+ "original_hash": "1420f4561e04cc0a40887d531ed5f3a0",
+ "translation_date": "2026-06-30T08:31:21+00:00",
+ "source_file": "docs/assets/img/ch05-auto.webp",
+ "language_code": "es"
+ },
+ "ch05-community.4e17c29453404339.webp": {
+ "original_hash": "022007f93d17089c01437ba2de1b7608",
+ "translation_date": "2026-06-30T08:32:09+00:00",
+ "source_file": "docs/assets/img/ch05-community.webp",
+ "language_code": "es"
+ },
+ "ch05-create.631921853ed36760.webp": {
+ "original_hash": "c37c89717eb6bd0aa30d854efd76cf3f",
+ "translation_date": "2026-06-30T08:32:00+00:00",
+ "source_file": "docs/assets/img/ch05-create.webp",
+ "language_code": "es"
+ },
+ "ch05-invoke.2d651726daade56a.webp": {
+ "original_hash": "a21063b84db5f192fbb929c6ce0deb8c",
+ "translation_date": "2026-06-30T08:32:01+00:00",
+ "source_file": "docs/assets/img/ch05-invoke.webp",
+ "language_code": "es"
+ },
+ "ch05-next.32c31aaa4026fd9a.webp": {
+ "original_hash": "03cddd57e057d025b076c5ed951d3b1c",
+ "translation_date": "2026-06-30T08:30:22+00:00",
+ "source_file": "docs/assets/img/ch05-next.webp",
+ "language_code": "es"
+ },
+ "ch05-skills.a61c99d0edb8fb92.webp": {
+ "original_hash": "2c5c8af58a9e5f9adb7272c787c0ac0b",
+ "translation_date": "2026-06-30T08:30:40+00:00",
+ "source_file": "docs/assets/img/ch05-skills.webp",
+ "language_code": "es"
+ },
+ "ch05-vs.18d11315b769c9f8.webp": {
+ "original_hash": "2f54a203b8771442eec38c0f35faba32",
+ "translation_date": "2026-06-30T08:31:23+00:00",
+ "source_file": "docs/assets/img/ch05-vs.webp",
+ "language_code": "es"
+ },
+ "ch06-add.c6afd586acb7fad2.webp": {
+ "original_hash": "f2823058395794f496a21248072aa79e",
+ "translation_date": "2026-06-30T08:30:37+00:00",
+ "source_file": "docs/assets/img/ch06-add.webp",
+ "language_code": "es"
+ },
+ "ch06-docs.24f3fb991c97201e.webp": {
+ "original_hash": "e9d70497ea5964b6342dacf25d3619eb",
+ "translation_date": "2026-06-30T08:31:40+00:00",
+ "source_file": "docs/assets/img/ch06-docs.webp",
+ "language_code": "es"
+ },
+ "ch06-github.5038097672345b8d.webp": {
+ "original_hash": "8f14bbfc24312e8eef0dec7fb807f75c",
+ "translation_date": "2026-06-30T08:30:37+00:00",
+ "source_file": "docs/assets/img/ch06-github.webp",
+ "language_code": "es"
+ },
+ "ch06-mcp.77f2236c67615f41.webp": {
+ "original_hash": "06bf560099729dc76056a11320f0d245",
+ "translation_date": "2026-06-30T08:31:51+00:00",
+ "source_file": "docs/assets/img/ch06-mcp.webp",
+ "language_code": "es"
+ },
+ "ch06-next.2a33ff6e8cdff8bb.webp": {
+ "original_hash": "20f530a12ee555133559ae8e2052ff59",
+ "translation_date": "2026-06-30T08:30:23+00:00",
+ "source_file": "docs/assets/img/ch06-next.webp",
+ "language_code": "es"
+ },
+ "ch06-workflow.6d2075bd5c931489.webp": {
+ "original_hash": "156266d55c85af8118d5dbb1a865107e",
+ "translation_date": "2026-06-30T08:31:59+00:00",
+ "source_file": "docs/assets/img/ch06-workflow.webp",
+ "language_code": "es"
+ },
+ "ch07-done.ec3e307bd122550d.webp": {
+ "original_hash": "e16851fafa6715e10a2a05103a0963c6",
+ "translation_date": "2026-06-30T08:32:14+00:00",
+ "source_file": "docs/assets/img/ch07-done.webp",
+ "language_code": "es"
+ },
+ "ch07-flow.0ba0f5ef6583fc02.webp": {
+ "original_hash": "43e97dd8ce84b8bbe42ce38756a47e68",
+ "translation_date": "2026-06-30T08:31:39+00:00",
+ "source_file": "docs/assets/img/ch07-flow.webp",
+ "language_code": "es"
+ },
+ "ch07-idea.74ebdf9d69301177.webp": {
+ "original_hash": "3fd1c9c880ef7de6336d0b0e5b5990df",
+ "translation_date": "2026-06-30T08:30:48+00:00",
+ "source_file": "docs/assets/img/ch07-idea.webp",
+ "language_code": "es"
+ },
+ "ch07-orchestra.98e37243ccc93895.webp": {
+ "original_hash": "e3980c3c650e5c01ccccd18704e2516f",
+ "translation_date": "2026-06-30T08:31:58+00:00",
+ "source_file": "docs/assets/img/ch07-orchestra.webp",
+ "language_code": "es"
+ },
+ "chapter-header-bg.56756ae38dd58a91.webp": {
+ "original_hash": "9e3c9b35f5f4c9b6caae0aedaff83ae9",
+ "translation_date": "2026-06-30T08:23:35+00:00",
+ "source_file": "assets/chapter-header-bg.png",
+ "language_code": "es"
+ },
+ "chapter-header.068de5970b5370c5.webp": {
+ "original_hash": "e6d35479ce5d48487738d67eaae8e84e",
+ "translation_date": "2026-06-30T08:35:45+00:00",
+ "source_file": "05-skills/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.072be406fc63998c.webp": {
+ "original_hash": "76a3fa97ea96ebb9cebf9a424584e7df",
+ "translation_date": "2026-06-30T08:29:43+00:00",
+ "source_file": "01-setup-and-first-steps/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.0d209053007eadc0.webp": {
+ "original_hash": "c859d099d5aec7d20c5d65f6326bd2ef",
+ "translation_date": "2026-06-30T08:28:43+00:00",
+ "source_file": "07-putting-it-together/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.4a33d857c6f18860.webp": {
+ "original_hash": "00b003624fc19987e2103741bc284af8",
+ "translation_date": "2026-06-30T08:25:42+00:00",
+ "source_file": "03-development-workflows/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.5c3c39ec9904be17.webp": {
+ "original_hash": "0fb4cecbd9727aa3246c35858cd11e66",
+ "translation_date": "2026-06-30T08:34:48+00:00",
+ "source_file": "00-quick-start/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.644b94bc708395d8.webp": {
+ "original_hash": "0c172eba0213f6265b01a9d6d8ba2211",
+ "translation_date": "2026-06-30T08:33:35+00:00",
+ "source_file": "06-mcp-servers/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.99f9a913bc8808cc.webp": {
+ "original_hash": "c492562a32b93454300deb6bc7aaf091",
+ "translation_date": "2026-06-30T08:32:26+00:00",
+ "source_file": "04-agents-custom-instructions/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "chapter-header.9e9098f7db433996.webp": {
+ "original_hash": "ae11d44aa41ec843853b56f14d69c82f",
+ "translation_date": "2026-06-30T08:27:19+00:00",
+ "source_file": "02-context-conversations/assets/chapter-header.png",
+ "language_code": "es"
+ },
+ "code-review-swimlane-single.76c892f3c803a942.webp": {
+ "original_hash": "46dc8b4eadf0f569c23f4befb8e1334a",
+ "translation_date": "2026-06-30T08:26:08+00:00",
+ "source_file": "03-development-workflows/assets/code-review-swimlane-single.png",
+ "language_code": "es"
+ },
+ "codebase-understanding.0a084dfeec54119d.webp": {
+ "original_hash": "fb82efe6dfc6deff163214aeda5db964",
+ "translation_date": "2026-06-30T08:28:03+00:00",
+ "source_file": "02-context-conversations/assets/codebase-understanding.png",
+ "language_code": "es"
+ },
+ "colleague-context-analogy.dd8cb6ee73fba16f.webp": {
+ "original_hash": "c879561cf7b6ec87022d3eeab5ddb3ec",
+ "translation_date": "2026-06-30T08:28:30+00:00",
+ "source_file": "02-context-conversations/assets/colleague-context-analogy.png",
+ "language_code": "es"
+ },
+ "combined-workflows.833d1b0f28ee9187.webp": {
+ "original_hash": "953b1777ada1b45c369db582fae8f1d9",
+ "translation_date": "2026-06-30T08:28:34+00:00",
+ "source_file": "07-putting-it-together/assets/combined-workflows.png",
+ "language_code": "es"
+ },
+ "configuring-mcp-servers.d3a6dfc11d514277.webp": {
+ "original_hash": "9e16e65ceecdf98a7cc2dedecc06f2d8",
+ "translation_date": "2026-06-30T08:33:59+00:00",
+ "source_file": "06-mcp-servers/assets/configuring-mcp-servers.png",
+ "language_code": "es"
+ },
+ "context-window-visualization.dc48490ff212d12f.webp": {
+ "original_hash": "c2305c60350131e36873681ea8117d73",
+ "translation_date": "2026-06-30T08:27:33+00:00",
+ "source_file": "02-context-conversations/assets/context-window-visualization.png",
+ "language_code": "es"
+ },
+ "copilot-banner.0f612aa32652bafb.webp": {
+ "original_hash": "fb2dc5aee3dc6723697a2a53504260f9",
+ "translation_date": "2026-06-30T08:24:05+00:00",
+ "source_file": "assets/copilot-banner.png",
+ "language_code": "es"
+ },
+ "copilot-dev-days.aa104ffc4da4844e.webp": {
+ "original_hash": "9b1dde39a0fe60f695857a3d7e6c8547",
+ "translation_date": "2026-06-30T08:25:27+00:00",
+ "source_file": "assets/copilot-dev-days.png",
+ "language_code": "es"
+ },
+ "copilot-trust.f21051666ebb7f13.webp": {
+ "original_hash": "74ff05e67ca332d53370c1970bc73782",
+ "translation_date": "2026-06-30T08:34:38+00:00",
+ "source_file": "00-quick-start/assets/copilot-trust.png",
+ "language_code": "es"
+ },
+ "creating-custom-agents.9433443b252022ef.webp": {
+ "original_hash": "6889fbdcd82f6afd2a1f0f93097e60bf",
+ "translation_date": "2026-06-30T08:32:41+00:00",
+ "source_file": "04-agents-custom-instructions/assets/creating-custom-agents.png",
+ "language_code": "es"
+ },
+ "creating-managing-skills.dfa089ffc37004de.webp": {
+ "original_hash": "eeb6d0103ac737e23dca05881d32c844",
+ "translation_date": "2026-06-30T08:36:07+00:00",
+ "source_file": "05-skills/assets/creating-managing-skills.png",
+ "language_code": "es"
+ },
+ "cross-file-intelligence.06c691a169a72ebf.webp": {
+ "original_hash": "7094d0478f03a53b03c0889a57c6e52c",
+ "translation_date": "2026-06-30T08:27:12+00:00",
+ "source_file": "02-context-conversations/assets/cross-file-intelligence.png",
+ "language_code": "es"
+ },
+ "debugging-swimlane-single.e277602180ccb764.webp": {
+ "original_hash": "c53fc6fb407a6f657737bbbb82409765",
+ "translation_date": "2026-06-30T08:26:32+00:00",
+ "source_file": "03-development-workflows/assets/debugging-swimlane-single.png",
+ "language_code": "es"
+ },
+ "essential-basic-context.928622a2209eb287.webp": {
+ "original_hash": "143fa66f8e98352e4281e2dc528fef2a",
+ "translation_date": "2026-06-30T08:28:13+00:00",
+ "source_file": "02-context-conversations/assets/essential-basic-context.png",
+ "language_code": "es"
+ },
+ "first-copilot-experience.4ebe72574ce5e9fd.webp": {
+ "original_hash": "65f18fcac3328b142041e7cd4b4ab6c9",
+ "translation_date": "2026-06-30T08:29:43+00:00",
+ "source_file": "01-setup-and-first-steps/assets/first-copilot-experience.png",
+ "language_code": "es"
+ },
+ "five-workflows-swimlane.5d5c7ca95363f7a8.webp": {
+ "original_hash": "e78bba3128ebca8e359250d66ba151b4",
+ "translation_date": "2026-06-30T08:26:55+00:00",
+ "source_file": "03-development-workflows/assets/five-workflows-swimlane.png",
+ "language_code": "es"
+ },
+ "five-workflows.79c1125329964d79.webp": {
+ "original_hash": "bc72dbaf1f5ea795e7c89176d4fd68e2",
+ "translation_date": "2026-06-30T08:25:50+00:00",
+ "source_file": "03-development-workflows/assets/five-workflows.png",
+ "language_code": "es"
+ },
+ "git-integration-swimlane-single.48aa7ca7a64cde50.webp": {
+ "original_hash": "63f0fa69534384567e46e28c80d77b8c",
+ "translation_date": "2026-06-30T08:25:59+00:00",
+ "source_file": "03-development-workflows/assets/git-integration-swimlane-single.png",
+ "language_code": "es"
+ },
+ "github-skills-logo.369e18e53c74874d.webp": {
+ "original_hash": "9ff3dbe4de8f0bd4404ecdbd25feceab",
+ "translation_date": "2026-06-30T08:24:10+00:00",
+ "source_file": "assets/github-skills-logo.png",
+ "language_code": "es"
+ },
+ "hiring-specialists-analogy.0559fa250f7bf75e.webp": {
+ "original_hash": "bb2208a734ed0de7f8ab1c169b6a49ac",
+ "translation_date": "2026-06-30T08:33:01+00:00",
+ "source_file": "04-agents-custom-instructions/assets/hiring-specialists-analogy.png",
+ "language_code": "es"
+ },
+ "how-skills-work.d0b288623028d4fc.webp": {
+ "original_hash": "324d2ea7266294202b5b223324286523",
+ "translation_date": "2026-06-30T08:36:08+00:00",
+ "source_file": "05-skills/assets/how-skills-work.png",
+ "language_code": "es"
+ },
+ "integration-pattern.949caacd87d83eda.webp": {
+ "original_hash": "255d5b0ac7745ae151f1319626faa488",
+ "translation_date": "2026-06-30T08:29:14+00:00",
+ "source_file": "07-putting-it-together/assets/integration-pattern.png",
+ "language_code": "es"
+ },
+ "interactive-mode.303237fddcebd5fd.webp": {
+ "original_hash": "710e2c92e99c497b409a24df891ff625",
+ "translation_date": "2026-06-30T08:30:02+00:00",
+ "source_file": "01-setup-and-first-steps/assets/interactive-mode.png",
+ "language_code": "es"
+ },
+ "issue-to-pr-workflow.3283131a7a8c7017.webp": {
+ "original_hash": "14918a4187e5c814a25597bd8b56b57e",
+ "translation_date": "2026-06-30T08:33:29+00:00",
+ "source_file": "06-mcp-servers/assets/issue-to-pr-workflow.png",
+ "language_code": "es"
+ },
+ "learning-path.6c7069656df25927.webp": {
+ "original_hash": "8c79d81f23f7dde3f0acb698a139bb6f",
+ "translation_date": "2026-06-30T08:23:53+00:00",
+ "source_file": "assets/learning-path.png",
+ "language_code": "es"
+ },
+ "managing-sharing-skills.32af99cc9ffca3f2.webp": {
+ "original_hash": "614c9502ee8fb34712e6cd36aaddbedc",
+ "translation_date": "2026-06-30T08:36:07+00:00",
+ "source_file": "05-skills/assets/managing-sharing-skills.png",
+ "language_code": "es"
+ },
+ "mockup.4618d97445bd29b7.webp": {
+ "original_hash": "dd2d6d88e65e9d869554da6b298336cf",
+ "translation_date": "2026-06-30T08:24:49+00:00",
+ "source_file": "assets/mockup.png",
+ "language_code": "es"
+ },
+ "modes-and-commands.6150c011b961166e.webp": {
+ "original_hash": "00341bffac71159445bc313ed1a9c113",
+ "translation_date": "2026-06-30T08:29:43+00:00",
+ "source_file": "01-setup-and-first-steps/assets/modes-and-commands.png",
+ "language_code": "es"
+ },
+ "multi-server-workflow.c44948f3a225e6c9.webp": {
+ "original_hash": "654c129ad56ff48325c105790664fb8d",
+ "translation_date": "2026-06-30T08:33:16+00:00",
+ "source_file": "06-mcp-servers/assets/multi-server-workflow.png",
+ "language_code": "es"
+ },
+ "objectives.f073d5b7ae9cffbd.webp": {
+ "original_hash": "d8a5080b46fce941a510b646aedb0e17",
+ "translation_date": "2026-06-30T08:30:31+00:00",
+ "source_file": "docs/assets/img/objectives.webp",
+ "language_code": "es"
+ },
+ "optional-going-deeper.bdeed7f7838fd922.webp": {
+ "original_hash": "b709a70015a36e616d13d84b191cec8a",
+ "translation_date": "2026-06-30T08:27:12+00:00",
+ "source_file": "02-context-conversations/assets/optional-going-deeper.png",
+ "language_code": "es"
+ },
+ "orchestra-analogy.fff0e1dc0799ec5c.webp": {
+ "original_hash": "ad1d0d18ef7c0f5cef7b7f4b5f1420e9",
+ "translation_date": "2026-06-30T08:28:58+00:00",
+ "source_file": "07-putting-it-together/assets/orchestra-analogy.png",
+ "language_code": "es"
+ },
+ "ordering-food-analogy.248925fdf6fc7241.webp": {
+ "original_hash": "31ccedda9e34732dc710b04e5d92440c",
+ "translation_date": "2026-06-30T08:29:35+00:00",
+ "source_file": "01-setup-and-first-steps/assets/ordering-food-analogy.png",
+ "language_code": "es"
+ },
+ "pip-avatar-hat.1ef1631dc5ba9975.webp": {
+ "original_hash": "f093b7cf3bb26753b16f3567559d7540",
+ "translation_date": "2026-06-30T08:31:20+00:00",
+ "source_file": "docs/assets/img/pip-avatar-hat.webp",
+ "language_code": "es"
+ },
+ "pip-avatar.2a2c028b08d7d574.webp": {
+ "original_hash": "f588825c30bf65ec8d634673bbdd6bda",
+ "translation_date": "2026-06-30T08:30:49+00:00",
+ "source_file": "docs/assets/img/pip-avatar.webp",
+ "language_code": "es"
+ },
+ "pip-hero.142a26a1d23f30af.webp": {
+ "original_hash": "a1d4665fbc495b64c229cc215a096cd6",
+ "translation_date": "2026-06-30T08:31:22+00:00",
+ "source_file": "docs/assets/img/pip-hero.webp",
+ "language_code": "es"
+ },
+ "plan-mode.befa623cdcdcb8ff.webp": {
+ "original_hash": "1018cb44df06735028d197ed6dfb18a2",
+ "translation_date": "2026-06-30T08:30:21+00:00",
+ "source_file": "01-setup-and-first-steps/assets/plan-mode.png",
+ "language_code": "es"
+ },
+ "power-tools-analogy.8b2bcf6fcf1eeb35.webp": {
+ "original_hash": "20b8409665af15c8ce162c22319bc042",
+ "translation_date": "2026-06-30T08:35:56+00:00",
+ "source_file": "05-skills/assets/power-tools-analogy.png",
+ "language_code": "es"
+ },
+ "practice.ca83e957212c4945.webp": {
+ "original_hash": "53de278a98a50827d7698a1ed88ebd28",
+ "translation_date": "2026-06-30T08:23:39+00:00",
+ "source_file": "assets/practice.png",
+ "language_code": "es"
+ },
+ "programmatic-mode.986a0b20f0fa67d4.webp": {
+ "original_hash": "5b4eb0a5ce59dadb6cdc3f6a0188ab59",
+ "translation_date": "2026-06-30T08:29:50+00:00",
+ "source_file": "01-setup-and-first-steps/assets/programmatic-mode.png",
+ "language_code": "es"
+ },
+ "qr.de083a7d935fc8d4.webp": {
+ "original_hash": "6552fe56f0b3d172add19e33f0c80126",
+ "translation_date": "2026-06-30T08:24:10+00:00",
+ "source_file": "assets/qr.png",
+ "language_code": "es"
+ },
+ "quick-reference-header.860a3b7a46b3bfa0.webp": {
+ "original_hash": "065feb773bd998af6018d455ac27ecf1",
+ "translation_date": "2026-06-30T08:23:32+00:00",
+ "source_file": "assets/quick-reference-header.png",
+ "language_code": "es"
+ },
+ "quick-start-mcp.fd090cca49f20565.webp": {
+ "original_hash": "e508f2942556059db4734f7657ada914",
+ "translation_date": "2026-06-30T08:33:39+00:00",
+ "source_file": "06-mcp-servers/assets/quick-start-mcp.png",
+ "language_code": "es"
+ },
+ "refactoring-swimlane-single.66e8e2c5072a1304.webp": {
+ "original_hash": "1f2ed7bba6c0cced04b660fab0a00cd7",
+ "translation_date": "2026-06-30T08:26:24+00:00",
+ "source_file": "03-development-workflows/assets/refactoring-swimlane-single.png",
+ "language_code": "es"
+ },
+ "screenshot.8712f552a008236b.webp": {
+ "original_hash": "31ccedda9e34732dc710b04e5d92440c",
+ "translation_date": "2026-06-30T08:25:16+00:00",
+ "source_file": "assets/screenshot.png",
+ "language_code": "es"
+ },
+ "session-persistence-timeline.2a5a3758ff1d3c16.webp": {
+ "original_hash": "b55b9d9b4e2312a5ba2c58a99f7ed35b",
+ "translation_date": "2026-06-30T08:27:52+00:00",
+ "source_file": "02-context-conversations/assets/session-persistence-timeline.png",
+ "language_code": "es"
+ },
+ "skill-auto-discovery-flow.52644f9f1d8f0bf1.webp": {
+ "original_hash": "d37aa3a4382a9e2b9107e4d1b4d96d84",
+ "translation_date": "2026-06-30T08:35:36+00:00",
+ "source_file": "05-skills/assets/skill-auto-discovery-flow.png",
+ "language_code": "es"
+ },
+ "skills-agents-mcp-comparison.269e280641e1743e.webp": {
+ "original_hash": "1bdf646614c20edb879e4aff8784441e",
+ "translation_date": "2026-06-30T08:40:53+00:00",
+ "source_file": "05-skills/assets/skills-agents-mcp-comparison.png",
+ "language_code": "es"
+ },
+ "specialized-workflows.2ab9b8b540f95f3f.webp": {
+ "original_hash": "bbb3a512e8b3e845e76947254c7cb518",
+ "translation_date": "2026-06-30T08:26:36+00:00",
+ "source_file": "03-development-workflows/assets/specialized-workflows.png",
+ "language_code": "es"
+ },
+ "test-gen-swimlane-single.a5ca2cd4a07b5dbe.webp": {
+ "original_hash": "0a81cf5e319225b3cc16711044aeebef",
+ "translation_date": "2026-06-30T08:26:15+00:00",
+ "source_file": "03-development-workflows/assets/test-gen-swimlane-single.png",
+ "language_code": "es"
+ },
+ "using-agents.bb24c89aebe238a3.webp": {
+ "original_hash": "8942e4cdeb86359fb66b2b76fd3cb181",
+ "translation_date": "2026-06-30T08:32:18+00:00",
+ "source_file": "04-agents-custom-instructions/assets/using-agents.png",
+ "language_code": "es"
+ },
+ "using-mcp-servers.b3ef4e8f334c449c.webp": {
+ "original_hash": "a0ebd353ad2fe04046303a6f2bcc4c82",
+ "translation_date": "2026-06-30T08:34:15+00:00",
+ "source_file": "06-mcp-servers/assets/using-mcp-servers.png",
+ "language_code": "es"
+ }
+}
\ No newline at end of file
diff --git a/translated_images/es/agent-file-placement-decision-tree.d8d4810a5984edc7.webp b/translated_images/es/agent-file-placement-decision-tree.d8d4810a5984edc7.webp
new file mode 100644
index 00000000..1f72b5b0
Binary files /dev/null and b/translated_images/es/agent-file-placement-decision-tree.d8d4810a5984edc7.webp differ
diff --git a/translated_images/es/auth-device-flow.9a0e754dba878d2e.webp b/translated_images/es/auth-device-flow.9a0e754dba878d2e.webp
new file mode 100644
index 00000000..09acdbc6
Binary files /dev/null and b/translated_images/es/auth-device-flow.9a0e754dba878d2e.webp differ
diff --git a/translated_images/es/browser-extensions-analogy.95b41c62fc9d09a2.webp b/translated_images/es/browser-extensions-analogy.95b41c62fc9d09a2.webp
new file mode 100644
index 00000000..9bd1ed79
Binary files /dev/null and b/translated_images/es/browser-extensions-analogy.95b41c62fc9d09a2.webp differ
diff --git a/translated_images/es/carpenter-workflow-steps.8b68419bb4018a49.webp b/translated_images/es/carpenter-workflow-steps.8b68419bb4018a49.webp
new file mode 100644
index 00000000..1c07514e
Binary files /dev/null and b/translated_images/es/carpenter-workflow-steps.8b68419bb4018a49.webp differ
diff --git a/translated_images/es/ch00-clone.16352cc945d101a9.webp b/translated_images/es/ch00-clone.16352cc945d101a9.webp
new file mode 100644
index 00000000..aa5cb77e
Binary files /dev/null and b/translated_images/es/ch00-clone.16352cc945d101a9.webp differ
diff --git a/translated_images/es/ch00-codespaces.8a84ca9f96184631.webp b/translated_images/es/ch00-codespaces.8a84ca9f96184631.webp
new file mode 100644
index 00000000..f903b929
Binary files /dev/null and b/translated_images/es/ch00-codespaces.8a84ca9f96184631.webp differ
diff --git a/translated_images/es/ch00-install.8f3a9e8dae87d0d5.webp b/translated_images/es/ch00-install.8f3a9e8dae87d0d5.webp
new file mode 100644
index 00000000..02270e8f
Binary files /dev/null and b/translated_images/es/ch00-install.8f3a9e8dae87d0d5.webp differ
diff --git a/translated_images/es/ch00-login.e5fca09acbcda313.webp b/translated_images/es/ch00-login.e5fca09acbcda313.webp
new file mode 100644
index 00000000..88f251d9
Binary files /dev/null and b/translated_images/es/ch00-login.e5fca09acbcda313.webp differ
diff --git a/translated_images/es/ch00-ready.1d85317bff16850d.webp b/translated_images/es/ch00-ready.1d85317bff16850d.webp
new file mode 100644
index 00000000..c89e6a1a
Binary files /dev/null and b/translated_images/es/ch00-ready.1d85317bff16850d.webp differ
diff --git a/translated_images/es/ch00-verify.d53479158d93f42a.webp b/translated_images/es/ch00-verify.d53479158d93f42a.webp
new file mode 100644
index 00000000..a63cca3d
Binary files /dev/null and b/translated_images/es/ch00-verify.d53479158d93f42a.webp differ
diff --git a/translated_images/es/ch00-welcome.f74d92711c1ad617.webp b/translated_images/es/ch00-welcome.f74d92711c1ad617.webp
new file mode 100644
index 00000000..3fc9d742
Binary files /dev/null and b/translated_images/es/ch00-welcome.f74d92711c1ad617.webp differ
diff --git a/translated_images/es/ch01-commands.16a99e46fa3dec36.webp b/translated_images/es/ch01-commands.16a99e46fa3dec36.webp
new file mode 100644
index 00000000..87d53219
Binary files /dev/null and b/translated_images/es/ch01-commands.16a99e46fa3dec36.webp differ
diff --git a/translated_images/es/ch01-interactive.2ebdca0ddaa3495c.webp b/translated_images/es/ch01-interactive.2ebdca0ddaa3495c.webp
new file mode 100644
index 00000000..7b23609d
Binary files /dev/null and b/translated_images/es/ch01-interactive.2ebdca0ddaa3495c.webp differ
diff --git a/translated_images/es/ch01-magic.0487ae1a9da17a6f.webp b/translated_images/es/ch01-magic.0487ae1a9da17a6f.webp
new file mode 100644
index 00000000..165810be
Binary files /dev/null and b/translated_images/es/ch01-magic.0487ae1a9da17a6f.webp differ
diff --git a/translated_images/es/ch01-modes.e671651c4d070dd6.webp b/translated_images/es/ch01-modes.e671651c4d070dd6.webp
new file mode 100644
index 00000000..d29936ac
Binary files /dev/null and b/translated_images/es/ch01-modes.e671651c4d070dd6.webp differ
diff --git a/translated_images/es/ch01-next.1a23bf38f6c40433.webp b/translated_images/es/ch01-next.1a23bf38f6c40433.webp
new file mode 100644
index 00000000..02f421d8
Binary files /dev/null and b/translated_images/es/ch01-next.1a23bf38f6c40433.webp differ
diff --git a/translated_images/es/ch01-permissions.55725a7dec198230.webp b/translated_images/es/ch01-permissions.55725a7dec198230.webp
new file mode 100644
index 00000000..5955e3dd
Binary files /dev/null and b/translated_images/es/ch01-permissions.55725a7dec198230.webp differ
diff --git a/translated_images/es/ch01-plan.e40e7b0b6b8f7ccd.webp b/translated_images/es/ch01-plan.e40e7b0b6b8f7ccd.webp
new file mode 100644
index 00000000..45ca76f6
Binary files /dev/null and b/translated_images/es/ch01-plan.e40e7b0b6b8f7ccd.webp differ
diff --git a/translated_images/es/ch01-programmatic.21edc4a4609135b5.webp b/translated_images/es/ch01-programmatic.21edc4a4609135b5.webp
new file mode 100644
index 00000000..5edf3938
Binary files /dev/null and b/translated_images/es/ch01-programmatic.21edc4a4609135b5.webp differ
diff --git a/translated_images/es/ch01-review.01f09a31479e396d.webp b/translated_images/es/ch01-review.01f09a31479e396d.webp
new file mode 100644
index 00000000..b093429c
Binary files /dev/null and b/translated_images/es/ch01-review.01f09a31479e396d.webp differ
diff --git a/translated_images/es/ch02-atsyntax.36bdf00b204730c7.webp b/translated_images/es/ch02-atsyntax.36bdf00b204730c7.webp
new file mode 100644
index 00000000..d682a0ab
Binary files /dev/null and b/translated_images/es/ch02-atsyntax.36bdf00b204730c7.webp differ
diff --git a/translated_images/es/ch02-context-limit.3d9c9b9ebb0a4a36.webp b/translated_images/es/ch02-context-limit.3d9c9b9ebb0a4a36.webp
new file mode 100644
index 00000000..c026cb55
Binary files /dev/null and b/translated_images/es/ch02-context-limit.3d9c9b9ebb0a4a36.webp differ
diff --git a/translated_images/es/ch02-context.7d7b297d649065b5.webp b/translated_images/es/ch02-context.7d7b297d649065b5.webp
new file mode 100644
index 00000000..16787386
Binary files /dev/null and b/translated_images/es/ch02-context.7d7b297d649065b5.webp differ
diff --git a/translated_images/es/ch02-images.ee8e51872fa7be82.webp b/translated_images/es/ch02-images.ee8e51872fa7be82.webp
new file mode 100644
index 00000000..27f24717
Binary files /dev/null and b/translated_images/es/ch02-images.ee8e51872fa7be82.webp differ
diff --git a/translated_images/es/ch02-memory.90a53b01501bef07.webp b/translated_images/es/ch02-memory.90a53b01501bef07.webp
new file mode 100644
index 00000000..8494ffb6
Binary files /dev/null and b/translated_images/es/ch02-memory.90a53b01501bef07.webp differ
diff --git a/translated_images/es/ch02-multifile.86988013e1164f02.webp b/translated_images/es/ch02-multifile.86988013e1164f02.webp
new file mode 100644
index 00000000..aca2ef15
Binary files /dev/null and b/translated_images/es/ch02-multifile.86988013e1164f02.webp differ
diff --git a/translated_images/es/ch02-next.e9e9c5bdfa29dee0.webp b/translated_images/es/ch02-next.e9e9c5bdfa29dee0.webp
new file mode 100644
index 00000000..f1df6d00
Binary files /dev/null and b/translated_images/es/ch02-next.e9e9c5bdfa29dee0.webp differ
diff --git a/translated_images/es/ch02-sessions.a1094c152e546bea.webp b/translated_images/es/ch02-sessions.a1094c152e546bea.webp
new file mode 100644
index 00000000..4af25e8c
Binary files /dev/null and b/translated_images/es/ch02-sessions.a1094c152e546bea.webp differ
diff --git a/translated_images/es/ch02-what-is-context.0301588e8db9d14a.webp b/translated_images/es/ch02-what-is-context.0301588e8db9d14a.webp
new file mode 100644
index 00000000..eee63279
Binary files /dev/null and b/translated_images/es/ch02-what-is-context.0301588e8db9d14a.webp differ
diff --git a/translated_images/es/ch03-debug.f46fbdd63679a16e.webp b/translated_images/es/ch03-debug.f46fbdd63679a16e.webp
new file mode 100644
index 00000000..4e3c6e5a
Binary files /dev/null and b/translated_images/es/ch03-debug.f46fbdd63679a16e.webp differ
diff --git a/translated_images/es/ch03-delegate.7063ed7fbc64cee3.webp b/translated_images/es/ch03-delegate.7063ed7fbc64cee3.webp
new file mode 100644
index 00000000..6022e516
Binary files /dev/null and b/translated_images/es/ch03-delegate.7063ed7fbc64cee3.webp differ
diff --git a/translated_images/es/ch03-next.73dce2f19174151b.webp b/translated_images/es/ch03-next.73dce2f19174151b.webp
new file mode 100644
index 00000000..5806e4be
Binary files /dev/null and b/translated_images/es/ch03-next.73dce2f19174151b.webp differ
diff --git a/translated_images/es/ch03-pr.eefe2af9a13d5a8f.webp b/translated_images/es/ch03-pr.eefe2af9a13d5a8f.webp
new file mode 100644
index 00000000..b8d95495
Binary files /dev/null and b/translated_images/es/ch03-pr.eefe2af9a13d5a8f.webp differ
diff --git a/translated_images/es/ch03-refactor.22a097aa4bf5ab07.webp b/translated_images/es/ch03-refactor.22a097aa4bf5ab07.webp
new file mode 100644
index 00000000..1cc68698
Binary files /dev/null and b/translated_images/es/ch03-refactor.22a097aa4bf5ab07.webp differ
diff --git a/translated_images/es/ch03-review.1d950e5693c90313.webp b/translated_images/es/ch03-review.1d950e5693c90313.webp
new file mode 100644
index 00000000..dd9d9d25
Binary files /dev/null and b/translated_images/es/ch03-review.1d950e5693c90313.webp differ
diff --git a/translated_images/es/ch03-ship.d2a1722060ca422f.webp b/translated_images/es/ch03-ship.d2a1722060ca422f.webp
new file mode 100644
index 00000000..ed408ba4
Binary files /dev/null and b/translated_images/es/ch03-ship.d2a1722060ca422f.webp differ
diff --git a/translated_images/es/ch03-test.8816391c73d1b295.webp b/translated_images/es/ch03-test.8816391c73d1b295.webp
new file mode 100644
index 00000000..e17d9637
Binary files /dev/null and b/translated_images/es/ch03-test.8816391c73d1b295.webp differ
diff --git a/translated_images/es/ch03-workflows.a899d71ab51395d7.webp b/translated_images/es/ch03-workflows.a899d71ab51395d7.webp
new file mode 100644
index 00000000..a5dd5e31
Binary files /dev/null and b/translated_images/es/ch03-workflows.a899d71ab51395d7.webp differ
diff --git a/translated_images/es/ch04-agents.69de16c29c7e5489.webp b/translated_images/es/ch04-agents.69de16c29c7e5489.webp
new file mode 100644
index 00000000..173daee0
Binary files /dev/null and b/translated_images/es/ch04-agents.69de16c29c7e5489.webp differ
diff --git a/translated_images/es/ch04-builtin.741d35728c6b6830.webp b/translated_images/es/ch04-builtin.741d35728c6b6830.webp
new file mode 100644
index 00000000..d16f619f
Binary files /dev/null and b/translated_images/es/ch04-builtin.741d35728c6b6830.webp differ
diff --git a/translated_images/es/ch04-custom.7b3f5ef9430c8aee.webp b/translated_images/es/ch04-custom.7b3f5ef9430c8aee.webp
new file mode 100644
index 00000000..e4187865
Binary files /dev/null and b/translated_images/es/ch04-custom.7b3f5ef9430c8aee.webp differ
diff --git a/translated_images/es/ch04-init.d65c1056d041acaa.webp b/translated_images/es/ch04-init.d65c1056d041acaa.webp
new file mode 100644
index 00000000..2238c81d
Binary files /dev/null and b/translated_images/es/ch04-init.d65c1056d041acaa.webp differ
diff --git a/translated_images/es/ch04-instructions.519b082ec473475b.webp b/translated_images/es/ch04-instructions.519b082ec473475b.webp
new file mode 100644
index 00000000..4357dec7
Binary files /dev/null and b/translated_images/es/ch04-instructions.519b082ec473475b.webp differ
diff --git a/translated_images/es/ch04-multiagent.d88e2940fe37a392.webp b/translated_images/es/ch04-multiagent.d88e2940fe37a392.webp
new file mode 100644
index 00000000..0d347e10
Binary files /dev/null and b/translated_images/es/ch04-multiagent.d88e2940fe37a392.webp differ
diff --git a/translated_images/es/ch04-next.7dc7b0142b3a0048.webp b/translated_images/es/ch04-next.7dc7b0142b3a0048.webp
new file mode 100644
index 00000000..9c8e2e38
Binary files /dev/null and b/translated_images/es/ch04-next.7dc7b0142b3a0048.webp differ
diff --git a/translated_images/es/ch04-pick.99090fec629c59f0.webp b/translated_images/es/ch04-pick.99090fec629c59f0.webp
new file mode 100644
index 00000000..3bc396e5
Binary files /dev/null and b/translated_images/es/ch04-pick.99090fec629c59f0.webp differ
diff --git a/translated_images/es/ch04-scope.a5ab812c0c0dbd1e.webp b/translated_images/es/ch04-scope.a5ab812c0c0dbd1e.webp
new file mode 100644
index 00000000..66dc383a
Binary files /dev/null and b/translated_images/es/ch04-scope.a5ab812c0c0dbd1e.webp differ
diff --git a/translated_images/es/ch05-auto.7e5d67bc45ea556c.webp b/translated_images/es/ch05-auto.7e5d67bc45ea556c.webp
new file mode 100644
index 00000000..0dfd64f4
Binary files /dev/null and b/translated_images/es/ch05-auto.7e5d67bc45ea556c.webp differ
diff --git a/translated_images/es/ch05-community.4e17c29453404339.webp b/translated_images/es/ch05-community.4e17c29453404339.webp
new file mode 100644
index 00000000..7c09f73d
Binary files /dev/null and b/translated_images/es/ch05-community.4e17c29453404339.webp differ
diff --git a/translated_images/es/ch05-create.631921853ed36760.webp b/translated_images/es/ch05-create.631921853ed36760.webp
new file mode 100644
index 00000000..afb94458
Binary files /dev/null and b/translated_images/es/ch05-create.631921853ed36760.webp differ
diff --git a/translated_images/es/ch05-invoke.2d651726daade56a.webp b/translated_images/es/ch05-invoke.2d651726daade56a.webp
new file mode 100644
index 00000000..a5ae115b
Binary files /dev/null and b/translated_images/es/ch05-invoke.2d651726daade56a.webp differ
diff --git a/translated_images/es/ch05-next.32c31aaa4026fd9a.webp b/translated_images/es/ch05-next.32c31aaa4026fd9a.webp
new file mode 100644
index 00000000..3296b7ff
Binary files /dev/null and b/translated_images/es/ch05-next.32c31aaa4026fd9a.webp differ
diff --git a/translated_images/es/ch05-skills.a61c99d0edb8fb92.webp b/translated_images/es/ch05-skills.a61c99d0edb8fb92.webp
new file mode 100644
index 00000000..32787b6b
Binary files /dev/null and b/translated_images/es/ch05-skills.a61c99d0edb8fb92.webp differ
diff --git a/translated_images/es/ch05-vs.18d11315b769c9f8.webp b/translated_images/es/ch05-vs.18d11315b769c9f8.webp
new file mode 100644
index 00000000..97d4126c
Binary files /dev/null and b/translated_images/es/ch05-vs.18d11315b769c9f8.webp differ
diff --git a/translated_images/es/ch06-add.c6afd586acb7fad2.webp b/translated_images/es/ch06-add.c6afd586acb7fad2.webp
new file mode 100644
index 00000000..33a83fed
Binary files /dev/null and b/translated_images/es/ch06-add.c6afd586acb7fad2.webp differ
diff --git a/translated_images/es/ch06-docs.24f3fb991c97201e.webp b/translated_images/es/ch06-docs.24f3fb991c97201e.webp
new file mode 100644
index 00000000..39ad372f
Binary files /dev/null and b/translated_images/es/ch06-docs.24f3fb991c97201e.webp differ
diff --git a/translated_images/es/ch06-github.5038097672345b8d.webp b/translated_images/es/ch06-github.5038097672345b8d.webp
new file mode 100644
index 00000000..99041cff
Binary files /dev/null and b/translated_images/es/ch06-github.5038097672345b8d.webp differ
diff --git a/translated_images/es/ch06-mcp.77f2236c67615f41.webp b/translated_images/es/ch06-mcp.77f2236c67615f41.webp
new file mode 100644
index 00000000..6e2c816d
Binary files /dev/null and b/translated_images/es/ch06-mcp.77f2236c67615f41.webp differ
diff --git a/translated_images/es/ch06-next.2a33ff6e8cdff8bb.webp b/translated_images/es/ch06-next.2a33ff6e8cdff8bb.webp
new file mode 100644
index 00000000..8700dd88
Binary files /dev/null and b/translated_images/es/ch06-next.2a33ff6e8cdff8bb.webp differ
diff --git a/translated_images/es/ch06-workflow.6d2075bd5c931489.webp b/translated_images/es/ch06-workflow.6d2075bd5c931489.webp
new file mode 100644
index 00000000..e62d6167
Binary files /dev/null and b/translated_images/es/ch06-workflow.6d2075bd5c931489.webp differ
diff --git a/translated_images/es/ch07-done.ec3e307bd122550d.webp b/translated_images/es/ch07-done.ec3e307bd122550d.webp
new file mode 100644
index 00000000..9e2ea7bb
Binary files /dev/null and b/translated_images/es/ch07-done.ec3e307bd122550d.webp differ
diff --git a/translated_images/es/ch07-flow.0ba0f5ef6583fc02.webp b/translated_images/es/ch07-flow.0ba0f5ef6583fc02.webp
new file mode 100644
index 00000000..ce0ee94f
Binary files /dev/null and b/translated_images/es/ch07-flow.0ba0f5ef6583fc02.webp differ
diff --git a/translated_images/es/ch07-idea.74ebdf9d69301177.webp b/translated_images/es/ch07-idea.74ebdf9d69301177.webp
new file mode 100644
index 00000000..6081649f
Binary files /dev/null and b/translated_images/es/ch07-idea.74ebdf9d69301177.webp differ
diff --git a/translated_images/es/ch07-orchestra.98e37243ccc93895.webp b/translated_images/es/ch07-orchestra.98e37243ccc93895.webp
new file mode 100644
index 00000000..f0bdf07f
Binary files /dev/null and b/translated_images/es/ch07-orchestra.98e37243ccc93895.webp differ
diff --git a/translated_images/es/chapter-header-bg.56756ae38dd58a91.webp b/translated_images/es/chapter-header-bg.56756ae38dd58a91.webp
new file mode 100644
index 00000000..84f3e96a
Binary files /dev/null and b/translated_images/es/chapter-header-bg.56756ae38dd58a91.webp differ
diff --git a/translated_images/es/chapter-header.068de5970b5370c5.webp b/translated_images/es/chapter-header.068de5970b5370c5.webp
new file mode 100644
index 00000000..f6564780
Binary files /dev/null and b/translated_images/es/chapter-header.068de5970b5370c5.webp differ
diff --git a/translated_images/es/chapter-header.072be406fc63998c.webp b/translated_images/es/chapter-header.072be406fc63998c.webp
new file mode 100644
index 00000000..3aebea35
Binary files /dev/null and b/translated_images/es/chapter-header.072be406fc63998c.webp differ
diff --git a/translated_images/es/chapter-header.0d209053007eadc0.webp b/translated_images/es/chapter-header.0d209053007eadc0.webp
new file mode 100644
index 00000000..d63a7423
Binary files /dev/null and b/translated_images/es/chapter-header.0d209053007eadc0.webp differ
diff --git a/translated_images/es/chapter-header.4a33d857c6f18860.webp b/translated_images/es/chapter-header.4a33d857c6f18860.webp
new file mode 100644
index 00000000..1fd3f251
Binary files /dev/null and b/translated_images/es/chapter-header.4a33d857c6f18860.webp differ
diff --git a/translated_images/es/chapter-header.5c3c39ec9904be17.webp b/translated_images/es/chapter-header.5c3c39ec9904be17.webp
new file mode 100644
index 00000000..280ceadf
Binary files /dev/null and b/translated_images/es/chapter-header.5c3c39ec9904be17.webp differ
diff --git a/translated_images/es/chapter-header.644b94bc708395d8.webp b/translated_images/es/chapter-header.644b94bc708395d8.webp
new file mode 100644
index 00000000..7088f673
Binary files /dev/null and b/translated_images/es/chapter-header.644b94bc708395d8.webp differ
diff --git a/translated_images/es/chapter-header.99f9a913bc8808cc.webp b/translated_images/es/chapter-header.99f9a913bc8808cc.webp
new file mode 100644
index 00000000..7b7ecc7f
Binary files /dev/null and b/translated_images/es/chapter-header.99f9a913bc8808cc.webp differ
diff --git a/translated_images/es/chapter-header.9e9098f7db433996.webp b/translated_images/es/chapter-header.9e9098f7db433996.webp
new file mode 100644
index 00000000..c1c2cc36
Binary files /dev/null and b/translated_images/es/chapter-header.9e9098f7db433996.webp differ
diff --git a/translated_images/es/code-review-swimlane-single.76c892f3c803a942.webp b/translated_images/es/code-review-swimlane-single.76c892f3c803a942.webp
new file mode 100644
index 00000000..ef55f434
Binary files /dev/null and b/translated_images/es/code-review-swimlane-single.76c892f3c803a942.webp differ
diff --git a/translated_images/es/codebase-understanding.0a084dfeec54119d.webp b/translated_images/es/codebase-understanding.0a084dfeec54119d.webp
new file mode 100644
index 00000000..569ab012
Binary files /dev/null and b/translated_images/es/codebase-understanding.0a084dfeec54119d.webp differ
diff --git a/translated_images/es/colleague-context-analogy.dd8cb6ee73fba16f.webp b/translated_images/es/colleague-context-analogy.dd8cb6ee73fba16f.webp
new file mode 100644
index 00000000..d626ff7e
Binary files /dev/null and b/translated_images/es/colleague-context-analogy.dd8cb6ee73fba16f.webp differ
diff --git a/translated_images/es/combined-workflows.833d1b0f28ee9187.webp b/translated_images/es/combined-workflows.833d1b0f28ee9187.webp
new file mode 100644
index 00000000..275774b8
Binary files /dev/null and b/translated_images/es/combined-workflows.833d1b0f28ee9187.webp differ
diff --git a/translated_images/es/configuring-mcp-servers.d3a6dfc11d514277.webp b/translated_images/es/configuring-mcp-servers.d3a6dfc11d514277.webp
new file mode 100644
index 00000000..e5f1e053
Binary files /dev/null and b/translated_images/es/configuring-mcp-servers.d3a6dfc11d514277.webp differ
diff --git a/translated_images/es/context-window-visualization.dc48490ff212d12f.webp b/translated_images/es/context-window-visualization.dc48490ff212d12f.webp
new file mode 100644
index 00000000..cfef33d2
Binary files /dev/null and b/translated_images/es/context-window-visualization.dc48490ff212d12f.webp differ
diff --git a/translated_images/es/copilot-banner.0f612aa32652bafb.webp b/translated_images/es/copilot-banner.0f612aa32652bafb.webp
new file mode 100644
index 00000000..7bcc3877
Binary files /dev/null and b/translated_images/es/copilot-banner.0f612aa32652bafb.webp differ
diff --git a/translated_images/es/copilot-dev-days.aa104ffc4da4844e.webp b/translated_images/es/copilot-dev-days.aa104ffc4da4844e.webp
new file mode 100644
index 00000000..24ed3344
Binary files /dev/null and b/translated_images/es/copilot-dev-days.aa104ffc4da4844e.webp differ
diff --git a/translated_images/es/copilot-trust.f21051666ebb7f13.webp b/translated_images/es/copilot-trust.f21051666ebb7f13.webp
new file mode 100644
index 00000000..b8f2d250
Binary files /dev/null and b/translated_images/es/copilot-trust.f21051666ebb7f13.webp differ
diff --git a/translated_images/es/creating-custom-agents.9433443b252022ef.webp b/translated_images/es/creating-custom-agents.9433443b252022ef.webp
new file mode 100644
index 00000000..3b0d2245
Binary files /dev/null and b/translated_images/es/creating-custom-agents.9433443b252022ef.webp differ
diff --git a/translated_images/es/creating-managing-skills.dfa089ffc37004de.webp b/translated_images/es/creating-managing-skills.dfa089ffc37004de.webp
new file mode 100644
index 00000000..f3132a71
Binary files /dev/null and b/translated_images/es/creating-managing-skills.dfa089ffc37004de.webp differ
diff --git a/translated_images/es/cross-file-intelligence.06c691a169a72ebf.webp b/translated_images/es/cross-file-intelligence.06c691a169a72ebf.webp
new file mode 100644
index 00000000..ee0bbd29
Binary files /dev/null and b/translated_images/es/cross-file-intelligence.06c691a169a72ebf.webp differ
diff --git a/translated_images/es/debugging-swimlane-single.e277602180ccb764.webp b/translated_images/es/debugging-swimlane-single.e277602180ccb764.webp
new file mode 100644
index 00000000..00da6fc9
Binary files /dev/null and b/translated_images/es/debugging-swimlane-single.e277602180ccb764.webp differ
diff --git a/translated_images/es/essential-basic-context.928622a2209eb287.webp b/translated_images/es/essential-basic-context.928622a2209eb287.webp
new file mode 100644
index 00000000..9a2a8c4e
Binary files /dev/null and b/translated_images/es/essential-basic-context.928622a2209eb287.webp differ
diff --git a/translated_images/es/first-copilot-experience.4ebe72574ce5e9fd.webp b/translated_images/es/first-copilot-experience.4ebe72574ce5e9fd.webp
new file mode 100644
index 00000000..7c789562
Binary files /dev/null and b/translated_images/es/first-copilot-experience.4ebe72574ce5e9fd.webp differ
diff --git a/translated_images/es/five-workflows-swimlane.5d5c7ca95363f7a8.webp b/translated_images/es/five-workflows-swimlane.5d5c7ca95363f7a8.webp
new file mode 100644
index 00000000..99cd07ae
Binary files /dev/null and b/translated_images/es/five-workflows-swimlane.5d5c7ca95363f7a8.webp differ
diff --git a/translated_images/es/five-workflows.79c1125329964d79.webp b/translated_images/es/five-workflows.79c1125329964d79.webp
new file mode 100644
index 00000000..439c80e6
Binary files /dev/null and b/translated_images/es/five-workflows.79c1125329964d79.webp differ
diff --git a/translated_images/es/git-integration-swimlane-single.48aa7ca7a64cde50.webp b/translated_images/es/git-integration-swimlane-single.48aa7ca7a64cde50.webp
new file mode 100644
index 00000000..859ac538
Binary files /dev/null and b/translated_images/es/git-integration-swimlane-single.48aa7ca7a64cde50.webp differ
diff --git a/translated_images/es/github-skills-logo.369e18e53c74874d.webp b/translated_images/es/github-skills-logo.369e18e53c74874d.webp
new file mode 100644
index 00000000..ac9663ac
Binary files /dev/null and b/translated_images/es/github-skills-logo.369e18e53c74874d.webp differ
diff --git a/translated_images/es/hiring-specialists-analogy.0559fa250f7bf75e.webp b/translated_images/es/hiring-specialists-analogy.0559fa250f7bf75e.webp
new file mode 100644
index 00000000..525f472c
Binary files /dev/null and b/translated_images/es/hiring-specialists-analogy.0559fa250f7bf75e.webp differ
diff --git a/translated_images/es/how-skills-work.d0b288623028d4fc.webp b/translated_images/es/how-skills-work.d0b288623028d4fc.webp
new file mode 100644
index 00000000..5e4e5c2d
Binary files /dev/null and b/translated_images/es/how-skills-work.d0b288623028d4fc.webp differ
diff --git a/translated_images/es/integration-pattern.949caacd87d83eda.webp b/translated_images/es/integration-pattern.949caacd87d83eda.webp
new file mode 100644
index 00000000..0452d3ca
Binary files /dev/null and b/translated_images/es/integration-pattern.949caacd87d83eda.webp differ
diff --git a/translated_images/es/interactive-mode.303237fddcebd5fd.webp b/translated_images/es/interactive-mode.303237fddcebd5fd.webp
new file mode 100644
index 00000000..6be6b660
Binary files /dev/null and b/translated_images/es/interactive-mode.303237fddcebd5fd.webp differ
diff --git a/translated_images/es/issue-to-pr-workflow.3283131a7a8c7017.webp b/translated_images/es/issue-to-pr-workflow.3283131a7a8c7017.webp
new file mode 100644
index 00000000..123ddb00
Binary files /dev/null and b/translated_images/es/issue-to-pr-workflow.3283131a7a8c7017.webp differ
diff --git a/translated_images/es/learning-path.6c7069656df25927.webp b/translated_images/es/learning-path.6c7069656df25927.webp
new file mode 100644
index 00000000..c67a4426
Binary files /dev/null and b/translated_images/es/learning-path.6c7069656df25927.webp differ
diff --git a/translated_images/es/managing-sharing-skills.32af99cc9ffca3f2.webp b/translated_images/es/managing-sharing-skills.32af99cc9ffca3f2.webp
new file mode 100644
index 00000000..99ea0c5a
Binary files /dev/null and b/translated_images/es/managing-sharing-skills.32af99cc9ffca3f2.webp differ
diff --git a/translated_images/es/mockup.4618d97445bd29b7.webp b/translated_images/es/mockup.4618d97445bd29b7.webp
new file mode 100644
index 00000000..4ab73f73
Binary files /dev/null and b/translated_images/es/mockup.4618d97445bd29b7.webp differ
diff --git a/translated_images/es/modes-and-commands.6150c011b961166e.webp b/translated_images/es/modes-and-commands.6150c011b961166e.webp
new file mode 100644
index 00000000..3ba64ff3
Binary files /dev/null and b/translated_images/es/modes-and-commands.6150c011b961166e.webp differ
diff --git a/translated_images/es/multi-server-workflow.c44948f3a225e6c9.webp b/translated_images/es/multi-server-workflow.c44948f3a225e6c9.webp
new file mode 100644
index 00000000..d0e127b6
Binary files /dev/null and b/translated_images/es/multi-server-workflow.c44948f3a225e6c9.webp differ
diff --git a/translated_images/es/objectives.f073d5b7ae9cffbd.webp b/translated_images/es/objectives.f073d5b7ae9cffbd.webp
new file mode 100644
index 00000000..99967dbd
Binary files /dev/null and b/translated_images/es/objectives.f073d5b7ae9cffbd.webp differ
diff --git a/translated_images/es/optional-going-deeper.bdeed7f7838fd922.webp b/translated_images/es/optional-going-deeper.bdeed7f7838fd922.webp
new file mode 100644
index 00000000..90fbd6b6
Binary files /dev/null and b/translated_images/es/optional-going-deeper.bdeed7f7838fd922.webp differ
diff --git a/translated_images/es/orchestra-analogy.fff0e1dc0799ec5c.webp b/translated_images/es/orchestra-analogy.fff0e1dc0799ec5c.webp
new file mode 100644
index 00000000..7c8adc16
Binary files /dev/null and b/translated_images/es/orchestra-analogy.fff0e1dc0799ec5c.webp differ
diff --git a/translated_images/es/ordering-food-analogy.248925fdf6fc7241.webp b/translated_images/es/ordering-food-analogy.248925fdf6fc7241.webp
new file mode 100644
index 00000000..fe6f906b
Binary files /dev/null and b/translated_images/es/ordering-food-analogy.248925fdf6fc7241.webp differ
diff --git a/translated_images/es/pip-avatar-hat.1ef1631dc5ba9975.webp b/translated_images/es/pip-avatar-hat.1ef1631dc5ba9975.webp
new file mode 100644
index 00000000..82acd6b4
Binary files /dev/null and b/translated_images/es/pip-avatar-hat.1ef1631dc5ba9975.webp differ
diff --git a/translated_images/es/pip-avatar.2a2c028b08d7d574.webp b/translated_images/es/pip-avatar.2a2c028b08d7d574.webp
new file mode 100644
index 00000000..91c4ff0c
Binary files /dev/null and b/translated_images/es/pip-avatar.2a2c028b08d7d574.webp differ
diff --git a/translated_images/es/pip-hero.142a26a1d23f30af.webp b/translated_images/es/pip-hero.142a26a1d23f30af.webp
new file mode 100644
index 00000000..ff6220a8
Binary files /dev/null and b/translated_images/es/pip-hero.142a26a1d23f30af.webp differ
diff --git a/translated_images/es/plan-mode.befa623cdcdcb8ff.webp b/translated_images/es/plan-mode.befa623cdcdcb8ff.webp
new file mode 100644
index 00000000..73ae3f6b
Binary files /dev/null and b/translated_images/es/plan-mode.befa623cdcdcb8ff.webp differ
diff --git a/translated_images/es/power-tools-analogy.8b2bcf6fcf1eeb35.webp b/translated_images/es/power-tools-analogy.8b2bcf6fcf1eeb35.webp
new file mode 100644
index 00000000..2faa8e6e
Binary files /dev/null and b/translated_images/es/power-tools-analogy.8b2bcf6fcf1eeb35.webp differ
diff --git a/translated_images/es/practice.ca83e957212c4945.webp b/translated_images/es/practice.ca83e957212c4945.webp
new file mode 100644
index 00000000..0bd121ab
Binary files /dev/null and b/translated_images/es/practice.ca83e957212c4945.webp differ
diff --git a/translated_images/es/programmatic-mode.986a0b20f0fa67d4.webp b/translated_images/es/programmatic-mode.986a0b20f0fa67d4.webp
new file mode 100644
index 00000000..af325cd9
Binary files /dev/null and b/translated_images/es/programmatic-mode.986a0b20f0fa67d4.webp differ
diff --git a/translated_images/es/qr.de083a7d935fc8d4.webp b/translated_images/es/qr.de083a7d935fc8d4.webp
new file mode 100644
index 00000000..53a57266
Binary files /dev/null and b/translated_images/es/qr.de083a7d935fc8d4.webp differ
diff --git a/translated_images/es/quick-reference-header.860a3b7a46b3bfa0.webp b/translated_images/es/quick-reference-header.860a3b7a46b3bfa0.webp
new file mode 100644
index 00000000..04269de9
Binary files /dev/null and b/translated_images/es/quick-reference-header.860a3b7a46b3bfa0.webp differ
diff --git a/translated_images/es/quick-start-mcp.fd090cca49f20565.webp b/translated_images/es/quick-start-mcp.fd090cca49f20565.webp
new file mode 100644
index 00000000..43d54d8c
Binary files /dev/null and b/translated_images/es/quick-start-mcp.fd090cca49f20565.webp differ
diff --git a/translated_images/es/refactoring-swimlane-single.66e8e2c5072a1304.webp b/translated_images/es/refactoring-swimlane-single.66e8e2c5072a1304.webp
new file mode 100644
index 00000000..6eece9e1
Binary files /dev/null and b/translated_images/es/refactoring-swimlane-single.66e8e2c5072a1304.webp differ
diff --git a/translated_images/es/screenshot.8712f552a008236b.webp b/translated_images/es/screenshot.8712f552a008236b.webp
new file mode 100644
index 00000000..62e184bd
Binary files /dev/null and b/translated_images/es/screenshot.8712f552a008236b.webp differ
diff --git a/translated_images/es/session-persistence-timeline.2a5a3758ff1d3c16.webp b/translated_images/es/session-persistence-timeline.2a5a3758ff1d3c16.webp
new file mode 100644
index 00000000..52c07f19
Binary files /dev/null and b/translated_images/es/session-persistence-timeline.2a5a3758ff1d3c16.webp differ
diff --git a/translated_images/es/skill-auto-discovery-flow.52644f9f1d8f0bf1.webp b/translated_images/es/skill-auto-discovery-flow.52644f9f1d8f0bf1.webp
new file mode 100644
index 00000000..59e3d4f4
Binary files /dev/null and b/translated_images/es/skill-auto-discovery-flow.52644f9f1d8f0bf1.webp differ
diff --git a/translated_images/es/skills-agents-mcp-comparison.269e280641e1743e.webp b/translated_images/es/skills-agents-mcp-comparison.269e280641e1743e.webp
new file mode 100644
index 00000000..f491fa5f
Binary files /dev/null and b/translated_images/es/skills-agents-mcp-comparison.269e280641e1743e.webp differ
diff --git a/translated_images/es/specialized-workflows.2ab9b8b540f95f3f.webp b/translated_images/es/specialized-workflows.2ab9b8b540f95f3f.webp
new file mode 100644
index 00000000..01788b51
Binary files /dev/null and b/translated_images/es/specialized-workflows.2ab9b8b540f95f3f.webp differ
diff --git a/translated_images/es/test-gen-swimlane-single.a5ca2cd4a07b5dbe.webp b/translated_images/es/test-gen-swimlane-single.a5ca2cd4a07b5dbe.webp
new file mode 100644
index 00000000..6df24734
Binary files /dev/null and b/translated_images/es/test-gen-swimlane-single.a5ca2cd4a07b5dbe.webp differ
diff --git a/translated_images/es/using-agents.bb24c89aebe238a3.webp b/translated_images/es/using-agents.bb24c89aebe238a3.webp
new file mode 100644
index 00000000..b4876232
Binary files /dev/null and b/translated_images/es/using-agents.bb24c89aebe238a3.webp differ
diff --git a/translated_images/es/using-mcp-servers.b3ef4e8f334c449c.webp b/translated_images/es/using-mcp-servers.b3ef4e8f334c449c.webp
new file mode 100644
index 00000000..8ef32179
Binary files /dev/null and b/translated_images/es/using-mcp-servers.b3ef4e8f334c449c.webp differ
diff --git a/translations/es/.co-op-translator.json b/translations/es/.co-op-translator.json
new file mode 100644
index 00000000..cfaea895
--- /dev/null
+++ b/translations/es/.co-op-translator.json
@@ -0,0 +1,206 @@
+{
+ "00-quick-start/README.md": {
+ "original_hash": "19ae3c8d9c941024d1abd4c00977dd53",
+ "translation_date": "2026-06-30T08:08:53+00:00",
+ "source_file": "00-quick-start/README.md",
+ "language_code": "es"
+ },
+ "01-setup-and-first-steps/README.md": {
+ "original_hash": "b219ac90c68fd6d78b20bc0dc5aaf770",
+ "translation_date": "2026-06-30T07:57:49+00:00",
+ "source_file": "01-setup-and-first-steps/README.md",
+ "language_code": "es"
+ },
+ "02-context-conversations/README.md": {
+ "original_hash": "fffcec1e7d5a4cf56bba0e8609ab53dd",
+ "translation_date": "2026-06-30T07:50:01+00:00",
+ "source_file": "02-context-conversations/README.md",
+ "language_code": "es"
+ },
+ "03-development-workflows/README.md": {
+ "original_hash": "35f628ad39880ce5574999c806f36e01",
+ "translation_date": "2026-06-30T07:45:01+00:00",
+ "source_file": "03-development-workflows/README.md",
+ "language_code": "es"
+ },
+ "04-agents-custom-instructions/README.md": {
+ "original_hash": "84c4ab048668b7ecc1b9d05fa463a813",
+ "translation_date": "2026-06-30T08:01:58+00:00",
+ "source_file": "04-agents-custom-instructions/README.md",
+ "language_code": "es"
+ },
+ "05-skills/README.md": {
+ "original_hash": "9f51aee940d8f84e8f49076faf6b336d",
+ "translation_date": "2026-06-30T08:15:38+00:00",
+ "source_file": "05-skills/README.md",
+ "language_code": "es"
+ },
+ "06-mcp-servers/README.md": {
+ "original_hash": "fe163bd287e103882a71c0632acd043e",
+ "translation_date": "2026-06-30T08:07:51+00:00",
+ "source_file": "06-mcp-servers/README.md",
+ "language_code": "es"
+ },
+ "06-mcp-servers/mcp-custom-server.md": {
+ "original_hash": "7947b6e5482c966d51b2b3b853feeeeb",
+ "translation_date": "2026-06-30T08:02:54+00:00",
+ "source_file": "06-mcp-servers/mcp-custom-server.md",
+ "language_code": "es"
+ },
+ "07-putting-it-together/README.md": {
+ "original_hash": "f6e4cc01b3e814d2b7af2ff194d72659",
+ "translation_date": "2026-06-30T07:54:17+00:00",
+ "source_file": "07-putting-it-together/README.md",
+ "language_code": "es"
+ },
+ "AGENTS.md": {
+ "original_hash": "ee92ae79ac3ebc6ad521a1ee273fae41",
+ "translation_date": "2026-06-30T07:37:23+00:00",
+ "source_file": "AGENTS.md",
+ "language_code": "es"
+ },
+ "CODE_OF_CONDUCT.md": {
+ "original_hash": "8b6516f8c2a7f71d51c047f2cf67da7b",
+ "translation_date": "2026-06-30T07:39:13+00:00",
+ "source_file": "CODE_OF_CONDUCT.md",
+ "language_code": "es"
+ },
+ "CONTRIBUTING.md": {
+ "original_hash": "b42221679e9ecaa79509af1242eaab75",
+ "translation_date": "2026-06-30T07:37:00+00:00",
+ "source_file": "CONTRIBUTING.md",
+ "language_code": "es"
+ },
+ "GLOSSARY.md": {
+ "original_hash": "0df506dde6938b83ef8eca2de865d2ac",
+ "translation_date": "2026-06-30T07:36:12+00:00",
+ "source_file": "GLOSSARY.md",
+ "language_code": "es"
+ },
+ "README.md": {
+ "original_hash": "5a929cd1dc7e2d45b1d1d398603447d9",
+ "translation_date": "2026-06-30T07:35:31+00:00",
+ "source_file": "README.md",
+ "language_code": "es"
+ },
+ "SECURITY.md": {
+ "original_hash": "c540a9732501726bf7fff2f58b143ac3",
+ "translation_date": "2026-06-30T07:36:34+00:00",
+ "source_file": "SECURITY.md",
+ "language_code": "es"
+ },
+ "SUPPORT.md": {
+ "original_hash": "3999b38d93fe3d9a90e6ffd908f14cbf",
+ "translation_date": "2026-06-30T07:34:47+00:00",
+ "source_file": "SUPPORT.md",
+ "language_code": "es"
+ },
+ "appendices/README.md": {
+ "original_hash": "fb5794d955fefcbaace78d80a2543720",
+ "translation_date": "2026-06-30T08:09:14+00:00",
+ "source_file": "appendices/README.md",
+ "language_code": "es"
+ },
+ "appendices/additional-context.md": {
+ "original_hash": "26568aa839758755533c1576e07d929c",
+ "translation_date": "2026-06-30T08:10:51+00:00",
+ "source_file": "appendices/additional-context.md",
+ "language_code": "es"
+ },
+ "appendices/ci-cd-integration.md": {
+ "original_hash": "d5c480c342afce29154a81efed641145",
+ "translation_date": "2026-06-30T08:09:49+00:00",
+ "source_file": "appendices/ci-cd-integration.md",
+ "language_code": "es"
+ },
+ "samples/agents/README.md": {
+ "original_hash": "9de7cf939dcf741b2982297ad5cf6581",
+ "translation_date": "2026-06-30T08:19:07+00:00",
+ "source_file": "samples/agents/README.md",
+ "language_code": "es"
+ },
+ "samples/agents/hello-world.agent.md": {
+ "original_hash": "db3c04f3976846c58ddf05144e624b09",
+ "translation_date": "2026-06-30T08:19:23+00:00",
+ "source_file": "samples/agents/hello-world.agent.md",
+ "language_code": "es"
+ },
+ "samples/agents/pytest-helper.agent.md": {
+ "original_hash": "3cfa8198900378848104d6e970aafbf4",
+ "translation_date": "2026-06-30T08:18:04+00:00",
+ "source_file": "samples/agents/pytest-helper.agent.md",
+ "language_code": "es"
+ },
+ "samples/agents/python-reviewer.agent.md": {
+ "original_hash": "f7bd2c6f349fa270519c6d186b8e77f3",
+ "translation_date": "2026-06-30T08:19:55+00:00",
+ "source_file": "samples/agents/python-reviewer.agent.md",
+ "language_code": "es"
+ },
+ "samples/book-app-buggy/README.md": {
+ "original_hash": "969121831d9dba9314f1fd75f29ebfe0",
+ "translation_date": "2026-06-30T08:16:11+00:00",
+ "source_file": "samples/book-app-buggy/README.md",
+ "language_code": "es"
+ },
+ "samples/book-app-project-cs/README.md": {
+ "original_hash": "99c4f97ce8c39547e0a0fede1ab2d400",
+ "translation_date": "2026-06-30T08:20:10+00:00",
+ "source_file": "samples/book-app-project-cs/README.md",
+ "language_code": "es"
+ },
+ "samples/book-app-project-js/README.md": {
+ "original_hash": "98bb7fe8a2cf1d73c31e3911683b8476",
+ "translation_date": "2026-06-30T08:20:33+00:00",
+ "source_file": "samples/book-app-project-js/README.md",
+ "language_code": "es"
+ },
+ "samples/book-app-project/README.md": {
+ "original_hash": "8e014705b00d769d7b1d5954b890fc16",
+ "translation_date": "2026-06-30T08:17:33+00:00",
+ "source_file": "samples/book-app-project/README.md",
+ "language_code": "es"
+ },
+ "samples/buggy-code/README.md": {
+ "original_hash": "15b20ed65bd5136c5ce1e719f88d5d05",
+ "translation_date": "2026-06-30T08:21:07+00:00",
+ "source_file": "samples/buggy-code/README.md",
+ "language_code": "es"
+ },
+ "samples/skills/README.md": {
+ "original_hash": "668a73830bd833ecaf8303615c53342a",
+ "translation_date": "2026-06-30T08:17:18+00:00",
+ "source_file": "samples/skills/README.md",
+ "language_code": "es"
+ },
+ "samples/skills/code-checklist/SKILL.md": {
+ "original_hash": "fa98bdb133a0a3494587b9e1cdb46d22",
+ "translation_date": "2026-06-30T08:22:46+00:00",
+ "source_file": "samples/skills/code-checklist/SKILL.md",
+ "language_code": "es"
+ },
+ "samples/skills/commit-message/SKILL.md": {
+ "original_hash": "b7d664a594d498d95b1d79751f508b3f",
+ "translation_date": "2026-06-30T08:22:16+00:00",
+ "source_file": "samples/skills/commit-message/SKILL.md",
+ "language_code": "es"
+ },
+ "samples/skills/hello-world/SKILL.md": {
+ "original_hash": "37e425f6e5b4a3a0147ff6c4e1f49903",
+ "translation_date": "2026-06-30T08:21:37+00:00",
+ "source_file": "samples/skills/hello-world/SKILL.md",
+ "language_code": "es"
+ },
+ "samples/skills/pytest-gen/SKILL.md": {
+ "original_hash": "ed0dc993c3006abb96495ca309bd9a1f",
+ "translation_date": "2026-06-30T08:23:18+00:00",
+ "source_file": "samples/skills/pytest-gen/SKILL.md",
+ "language_code": "es"
+ },
+ "samples/src/README.md": {
+ "original_hash": "07d30c7bddf8817f7754183573ac9303",
+ "translation_date": "2026-06-30T08:16:32+00:00",
+ "source_file": "samples/src/README.md",
+ "language_code": "es"
+ }
+}
\ No newline at end of file
diff --git a/translations/es/00-quick-start/README.md b/translations/es/00-quick-start/README.md
new file mode 100644
index 00000000..20e2e683
--- /dev/null
+++ b/translations/es/00-quick-start/README.md
@@ -0,0 +1,308 @@
+
+
+
+
+¡Bienvenido! En este capítulo, instalarás GitHub Copilot CLI (Interfaz de Línea de Comandos), iniciarás sesión con tu cuenta de GitHub y verificarás que todo funciona. Este es un capítulo de configuración rápida. ¡Una vez que estés en marcha, las demostraciones reales comienzan en el Capítulo 01!
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, habrás:
+
+- Instalado GitHub Copilot CLI
+- Iniciado sesión con tu cuenta de GitHub
+- Verificado que funciona con una prueba sencilla
+
+> ⏱️ **Tiempo estimado**: ~10 minutos (5 min lectura + 5 min práctica)
+
+---
+
+## ✅ Requisitos previos
+
+- **Cuenta de GitHub** con acceso a Copilot. [Ver opciones de suscripción](https://github.com/features/copilot/plans). Los estudiantes/profesores pueden acceder a Copilot Pro [gratis a través de GitHub Education](https://education.github.com/pack).
+- **Conceptos básicos de terminal**: Cómodo usando comandos como `cd` y `ls`
+
+### Qué significa "acceso a Copilot"
+
+GitHub Copilot CLI requiere una suscripción activa a Copilot. Puedes comprobar tu estado en [github.com/settings/copilot](https://github.com/settings/copilot). Deberías ver una de las siguientes opciones:
+
+- **Copilot Individual** - Suscripción personal
+- **Copilot Business** - A través de tu organización
+- **Copilot Enterprise** - A través de tu empresa
+- **GitHub Education** - Gratis para estudiantes/profesores verificados
+
+Si ves "You don't have access to GitHub Copilot", necesitarás usar la opción gratuita, suscribirte a un plan o unirte a una organización que proporcione acceso.
+
+---
+
+## Instalación
+
+> ⏱️ **Estimación de tiempo**: La instalación toma 2-5 minutos. La autenticación añade 1-2 minutos más.
+
+### GitHub Codespaces (Sin configuración)
+
+Si no quieres instalar ninguno de los requisitos previos, puedes usar GitHub Codespaces, que tiene GitHub Copilot CLI listo para usar (necesitarás iniciar sesión) y preinstala Python y pytest.
+
+1. [Haz un fork de este repositorio](https://github.com/github/copilot-cli-for-beginners/fork) a tu cuenta de GitHub
+2. Selecciona **Code** > **Codespaces** > **Create codespace on main**
+3. Espera unos minutos a que el contenedor se construya
+4. ¡Listo para comenzar! La terminal se abrirá automáticamente en el entorno del Codespace.
+
+> 💡 **Verificar en Codespace**: Ejecuta `cd samples/book-app-project && python book_app.py help` para confirmar que Python y la aplicación de muestra funcionan.
+
+### Instalación local
+
+Sigue estos pasos si quieres ejecutar Copilot CLI en tu máquina local con las muestras del curso.
+
+1. Clona el repositorio para obtener las muestras del curso en tu máquina:
+
+ ```bash
+ git clone https://github.com/github/copilot-cli-for-beginners
+ cd copilot-cli-for-beginners
+ ```
+
+2. Instala Copilot CLI usando una de las siguientes opciones.
+
+ > 💡 **¿No estás seguro cuál escoger?** Usa `npm` si tienes Node.js instalado. De lo contrario, elige la opción que coincida con tu sistema.
+
+ ### Todas las plataformas (npm)
+
+ ```bash
+ # Si tienes Node.js instalado, esta es una forma rápida de obtener la CLI
+ npm install -g @github/copilot
+ ```
+
+ ### macOS/Linux (Homebrew)
+
+ ```bash
+ brew install copilot-cli
+ ```
+
+ ### Windows (WinGet)
+
+ ```bash
+ winget install GitHub.Copilot
+ ```
+
+ ### macOS/Linux (Install Script)
+
+ ```bash
+ curl -fsSL https://gh.io/copilot-install | bash
+ ```
+
+
+Opcional: Habilitar autocompletado con Tab en la shell
+
+El autocompletado en la shell te permite presionar **Tab** para completar subcomandos de `copilot`, opciones de comando y algunos valores de opciones. Esto es opcional, pero puede ser útil una vez que te sientas cómodo usando la CLI.
+
+Copilot CLI actualmente admite scripts de autocompletado para Bash, Zsh y Fish:
+
+```shell
+# Bash, solo para la sesión actual
+source <(copilot completion bash)
+
+# Bash, persistente en Linux
+copilot completion bash | sudo tee /etc/bash_completion.d/copilot
+
+# Zsh
+copilot completion zsh > "${fpath[1]}/_copilot"
+
+# Fish
+copilot completion fish > ~/.config/fish/completions/copilot.fish
+```
+
+Reinicia tu shell después de agregar el autocompletado persistente. PowerShell es compatible para ejecutar Copilot CLI en Windows, pero `copilot completion` actualmente solo admite Bash, Zsh y Fish.
+
+
+
+---
+
+## Autenticación
+
+Abre una ventana de terminal en la raíz del repositorio `copilot-cli-for-beginners`, inicia la CLI y permite el acceso a la carpeta.
+
+```bash
+copilot
+```
+
+Se te pedirá que confíes en la carpeta que contiene el repositorio (si no lo has hecho ya). Puedes confiar una sola vez o en todas las sesiones futuras.
+
+
+
+Después de confiar en la carpeta, puedes iniciar sesión con tu cuenta de GitHub.
+
+```
+> /login
+```
+
+**Qué ocurre a continuación:**
+
+1. Copilot CLI muestra un código de una sola vez (como `ABCD-1234`)
+2. Tu navegador se abre en la página de autorización de dispositivo de GitHub. Inicia sesión en GitHub si no lo has hecho ya.
+3. Introduce el código cuando se te solicite
+4. Selecciona "Authorize" para otorgar acceso a GitHub Copilot CLI
+5. Vuelve a tu terminal: ¡ahora has iniciado sesión!
+
+
+
+*El flujo de autorización de dispositivo: tu terminal genera un código, lo verificas en el navegador y Copilot CLI queda autenticado.*
+
+**Consejo**: El inicio de sesión persiste entre sesiones. Solo necesitas hacerlo una vez a menos que tu token expire o cierres la sesión explícitamente.
+
+---
+
+## Verificar que funciona
+
+### Paso 1: Probar Copilot CLI
+
+Ahora que has iniciado sesión, verifiquemos que Copilot CLI está funcionando para ti. En la terminal, inicia la CLI si no lo has hecho ya:
+
+```bash
+> Say hello and tell me what you can help with
+```
+
+Después de recibir una respuesta, puedes salir de la CLI:
+
+```bash
+> /exit
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas serán diferentes de lo mostrado aquí.*
+
+
+
+---
+
+**Salida esperada**: Una respuesta amigable que enumere las capacidades de Copilot CLI.
+
+### Paso 2: Ejecutar la aplicación de ejemplo del libro
+
+El curso proporciona una aplicación de ejemplo que explorarás y mejorarás durante el curso usando la CLI *(Puedes ver el código de esto en /samples/book-app-project)*. Comprueba que la *aplicación de terminal de colección de libros en Python* funciona antes de empezar. Ejecuta `python` o `python3` según tu sistema.
+
+> **Nota:** Los ejemplos principales mostrados a lo largo del curso usan Python (`samples/book-app-project`), por lo que necesitarás tener [Python 3.10+](https://www.python.org/downloads/) disponible en tu máquina local si elegiste esa opción (el Codespace ya lo tiene instalado). También hay versiones en JavaScript (`samples/book-app-project-js`) y C# (`samples/book-app-project-cs`) si prefieres trabajar con esos lenguajes. Cada muestra tiene un README con instrucciones para ejecutar la aplicación en ese lenguaje.
+
+```bash
+cd samples/book-app-project
+python book_app.py list
+```
+
+**Salida esperada**: Una lista de 5 libros que incluye "The Hobbit", "1984" y "Dune".
+
+### Paso 3: Probar Copilot CLI con la aplicación del libro
+
+Navega de vuelta a la raíz del repositorio primero (si ejecutaste el Paso 2):
+
+```bash
+cd ../.. # Volver a la raíz del repositorio si es necesario
+copilot
+> What does @samples/book-app-project/book_app.py do?
+```
+
+**Salida esperada**: Un resumen de las principales funciones y comandos de la aplicación de libros.
+
+Si ves un error, consulta la [sección de resolución de problemas](#you-dont-have-access-to-github-copilot) más abajo.
+
+Una vez que termines puedes salir de Copilot CLI:
+
+```bash
+> /exit
+```
+
+---
+
+## ✅ ¡Estás listo!
+
+Eso es todo para la instalación. La diversión real comienza en el Capítulo 01, donde:
+
+- Verás a la IA revisar la aplicación de libros y encontrar problemas de calidad de código al instante
+- Aprenderás tres formas diferentes de usar Copilot CLI
+- Generarás código funcional a partir de lenguaje natural
+
+**[Continuar al Capítulo 01: Primeros pasos →](../01-setup-and-first-steps/README.md)**
+
+---
+
+## Resolución de problemas
+
+### "copilot: command not found"
+
+La CLI no está instalada. Prueba un método de instalación diferente:
+
+```bash
+# Si brew falló, prueba con npm:
+npm install -g @github/copilot
+
+# O el script de instalación:
+curl -fsSL https://gh.io/copilot-install | bash
+```
+
+### "You don't have access to GitHub Copilot"
+
+1. Verifica que tienes una suscripción a Copilot en [github.com/settings/copilot](https://github.com/settings/copilot)
+2. Comprueba que tu organización permite el acceso a la CLI si usas una cuenta de trabajo
+
+### "Authentication failed"
+
+Vuelve a autenticarte:
+
+```bash
+copilot
+> /login
+```
+
+### El navegador no se abre automáticamente
+
+Visita manualmente [github.com/login/device](https://github.com/login/device) e introduce el código que se muestra en tu terminal.
+
+### Token caducado
+
+Simplemente ejecuta `/login` de nuevo:
+
+```bash
+copilot
+> /login
+```
+
+### ¿Todavía atascado?
+
+- Consulta la [documentación de GitHub Copilot CLI](https://docs.github.com/copilot/concepts/agents/about-copilot-cli)
+- Busca en [GitHub Issues](https://github.com/github/copilot-cli/issues)
+
+---
+
+## 🔑 Puntos clave
+
+1. **Un GitHub Codespace es una forma rápida de empezar** - Python, pytest y GitHub Copilot CLI vienen preinstalados para que puedas saltar directamente a las demos
+2. **Múltiples métodos de instalación** - Elige lo que funcione para tu sistema (Homebrew, WinGet, npm o script de instalación)
+3. **Autenticación de una sola vez** - El inicio de sesión persiste hasta que el token expire
+4. **La aplicación de libros funciona** - Usarás `samples/book-app-project` a lo largo de todo el curso
+
+> 📚 **Documentación oficial**: [Install Copilot CLI](https://docs.github.com/copilot/how-tos/copilot-cli/cli-getting-started) para opciones de instalación y requisitos.
+
+> 📋 **Referencia rápida**: Consulta la [GitHub Copilot CLI command reference](https://docs.github.com/en/copilot/reference/cli-command-reference) para una lista completa de comandos y atajos.
+
+---
+
+**[Continuar al Capítulo 01: Primeros pasos →](../01-setup-and-first-steps/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/01-setup-and-first-steps/README.md b/translations/es/01-setup-and-first-steps/README.md
new file mode 100644
index 00000000..0f13213f
--- /dev/null
+++ b/translations/es/01-setup-and-first-steps/README.md
@@ -0,0 +1,714 @@
+
+
+
+
+> **Observa cómo la IA encuentra errores al instante, explica código confuso y genera scripts funcionales. Luego aprende tres formas diferentes de usar GitHub Copilot CLI.**
+
+¡Este capítulo es donde empieza la magia! Experimentarás de primera mano por qué los desarrolladores describen GitHub Copilot CLI como tener a un ingeniero senior en marcación rápida. Verás cómo la IA detecta vulnerabilidades de seguridad en segundos, obtendrás explicaciones de código complejo en lenguaje sencillo y generarás scripts funcionales al instante. Luego dominarás los tres modos de interacción (Interactivo, Plan y Programático) para saber exactamente cuál usar para cada tarea.
+
+> ⚠️ **Prerequisitos**: Asegúrate de haber completado primero **[Capítulo 00: Quick Start](../00-quick-start/README.md)**. Necesitarás tener instalado y autenticado GitHub Copilot CLI antes de ejecutar las demos a continuación.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, serás capaz de:
+
+- Experimentar el aumento de productividad que proporciona GitHub Copilot CLI mediante demos prácticos
+- Elegir el modo adecuado (Interactivo, Plan o Programático) para cualquier tarea
+- Usar comandos con slash para controlar tus sesiones
+
+> ⏱️ **Tiempo estimado**: ~45 minutos (15 min lectura + 30 min práctica)
+
+---
+
+# Tu primera experiencia con Copilot CLI
+
+
+
+Sumérgete y descubre lo que Copilot CLI puede hacer.
+
+---
+
+## Ponerse cómodo: Tus primeras indicaciones
+
+Antes de sumergirnos en las demos impresionantes, empecemos con algunas indicaciones sencillas que puedes probar ahora mismo. **¡No se necesita un repositorio de código!** Solo abre una terminal y inicia Copilot CLI:
+
+```bash
+copilot
+```
+
+Prueba estas indicaciones para principiantes:
+
+```
+> Explain what a dataclass is in Python in simple terms
+
+> Write a function that sorts a list of dictionaries by a specific key
+
+> What's the difference between a list and a tuple in Python?
+
+> Give me 5 best practices for writing clean Python code
+```
+
+¿No usas Python? ¡No hay problema! Simplemente haz preguntas sobre el lenguaje que prefieras.
+
+Fíjate lo natural que se siente. Haz preguntas como se las harías a un colega. Cuando termines de explorar, escribe `/exit` para salir de la sesión.
+
+**La idea clave**: GitHub Copilot CLI es conversacional. No necesitas una sintaxis especial para empezar. Simplemente haz preguntas en inglés sencillo.
+
+## Verlo en acción
+
+Ahora veamos por qué los desarrolladores dicen que esto es "tener a un ingeniero senior en marcación rápida".
+
+> 📖 **Cómo leer los ejemplos**: Las líneas que comienzan con `>` son indicaciones que escribes dentro de una sesión interactiva de Copilot CLI. Las líneas sin el prefijo `>` son comandos de shell que ejecutas en tu terminal.
+
+> 💡 **Sobre las salidas de ejemplo**: Las salidas de ejemplo mostradas a lo largo de este curso son ilustrativas. Dado que las respuestas de Copilot CLI varían cada vez, tus resultados diferirán en redacción, formato y detalle. Concéntrate en el *tipo* de información devuelta, no en el texto exacto.
+
+### Demo 1: Revisión de código en segundos
+
+El curso incluye archivos de ejemplo con problemas intencionales de calidad de código. Si trabajas en tu máquina local y aún no has clonado el repositorio, ejecuta el comando `git clone` a continuación, navega a la carpeta `copilot-cli-for-beginners` y luego ejecuta el comando `copilot`.
+
+```bash
+# Clona el repositorio del curso si estás trabajando localmente y aún no lo has hecho
+git clone https://github.com/github/copilot-cli-for-beginners
+cd copilot-cli-for-beginners
+
+# Inicia Copilot
+copilot
+```
+
+Una vez dentro de la sesión interactiva de Copilot CLI, ejecuta lo siguiente:
+
+```
+> Review @samples/book-app-project/book_app.py for code quality issues and suggest improvements
+```
+
+> 💡 **¿Para qué se usa el símbolo `@`?** El símbolo `@` indica a Copilot CLI que lea un archivo. Aprenderás todo esto en el Capítulo 02. Por ahora, copia el comando exactamente como aparece.
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas serán diferentes a lo mostrado aquí.*
+
+
+
+---
+
+**La conclusión**: Una revisión de código profesional en segundos. La revisión manual tomaría... bueno... mucho más tiempo que eso.
+
+---
+
+### Demo 2: Explicar código confuso
+
+¿Alguna vez te has quedado mirando código preguntándote qué hace? Prueba esto en tu sesión de Copilot CLI:
+
+```
+> Explain what @samples/book-app-project/books.py does in simple terms
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas serán diferentes a lo mostrado aquí.*
+
+
+
+---
+
+**Qué sucede**: (tu salida será diferente) Copilot CLI lee el archivo, entiende el código y lo explica en inglés sencillo.
+
+```
+This is a book collection management module using Python dataclasses.
+
+Think of it like a digital bookshelf:
+- Book is a dataclass - a simple way to store book information (title, author, year, read status)
+- BookCollection manages the entire collection and handles saving/loading
+
+Key components:
+
+1. @dataclass decorator (line 8)
+ - Automatically creates __init__, __repr__, etc.
+ - Clean way to define data structures in Python
+
+2. BookCollection class (line 16)
+ - Maintains a list of Book objects
+ - Handles persistence with JSON file I/O
+ - load_books() reads from data.json
+ - save_books() writes to data.json using asdict()
+
+3. Book operations:
+ - add_book() - creates and saves new books
+ - find_book_by_title() - searches collection
+ - mark_as_read() - updates read status
+ - find_by_author() - filters by author name
+
+Common pattern: Read from JSON → Work with Python objects → Write back to JSON
+```
+
+**La conclusión**: Código complejo explicado como lo haría un mentor paciente.
+
+---
+
+### Demo 3: Generar código funcional
+
+¿Necesitas una función para la que de otro modo pasarías 15 minutos buscando en Google? Aún en tu sesión:
+
+```
+> Write a Python function that takes a list of books and returns statistics:
+ total count, number read, number unread, oldest and newest book
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas serán diferentes a lo mostrado aquí.*
+
+
+
+---
+
+**Qué sucede**: Una función completa y funcional en segundos que puedes copiar-pegar-ejecutar.
+
+Cuando termines de explorar, sal de la sesión:
+
+```
+> /exit
+```
+
+**La conclusión**: Gratificación instantánea, y permaneciste en una sesión continua todo el tiempo.
+
+---
+
+# Modos y comandos
+
+
+
+Acabas de ver lo que Copilot CLI puede hacer. Ahora entendamos *cómo* usar estas capacidades de forma efectiva. La clave es saber cuál de los tres modos de interacción usar según la situación.
+
+> 💡 **Nota**: Copilot CLI también tiene un modo **Autopilot** donde trabaja en las tareas sin esperar tu entrada. Es poderoso pero requiere otorgar permisos completos y usa solicitudes premium de forma autónoma. Este curso se centra en los tres modos que se describen a continuación. Te indicaremos Autopilot una vez que estés cómodo con lo básico.
+
+---
+
+## 🧩 Analogía del mundo real: Salir a comer
+
+Piensa en usar GitHub Copilot CLI como salir a comer. Desde planear el viaje hasta hacer tu pedido, diferentes situaciones requieren distintos enfoques:
+
+| Mode | Dining Analogy | When to Use |
+|------|----------------|-------------|
+| **Plan** | Ruta GPS al restaurante | Tareas complejas - traza la ruta, revisa paradas, acuerda el plan y luego conduce |
+| **Interactive** | Hablar con el camarero | Exploración e iteración - haz preguntas, personaliza, obtén retroalimentación en tiempo real |
+| **Programmatic** | Pedido en el autoservicio | Tareas rápidas y específicas - permanece en tu entorno y obtén un resultado rápido |
+
+Al igual que al salir a comer, aprenderás de forma natural cuándo cada enfoque se siente apropiado.
+
+
+
+*Elige tu modo según la tarea: Plan para trazarla primero, Interactivo para colaboración de ida y vuelta, Programático para resultados rápidos de una sola vez*
+
+### ¿Con qué modo debería empezar?
+
+**Comienza con el modo interactivo.**
+- Puedes experimentar y hacer preguntas de seguimiento
+- El contexto se construye de forma natural mediante la conversación
+- Los errores son fáciles de corregir con `/clear`
+
+Una vez que te sientas cómodo, prueba:
+- **Modo programático** (`copilot -p ""`) para preguntas rápidas y puntuales
+- **Modo Plan** (`/plan`) cuando necesites planear las cosas con más detalle antes de codificar
+
+---
+
+## Los tres modos
+
+### Modo 1: Modo interactivo (comienza aquí)
+
+
+
+**Mejor para**: Exploración, iteración y conversaciones de múltiples turnos. Como hablar con un camarero que puede responder preguntas, aceptar feedback y ajustar el pedido al instante.
+
+Inicia una sesión interactiva:
+
+```bash
+copilot
+```
+
+Como has visto hasta ahora, verás un prompt donde puedes escribir de forma natural. Para obtener ayuda sobre los comandos disponibles, escribe:
+
+```
+> /help
+```
+
+**Idea clave**: El modo interactivo mantiene el contexto. Cada mensaje se construye sobre los anteriores, como en una conversación real.
+
+#### Ejemplo de modo interactivo
+
+```bash
+copilot
+
+> Review @samples/book-app-project/utils.py and suggest improvements
+
+> Add type hints to all functions
+
+> Make the error handling more robust
+
+> /exit
+```
+
+Fíjate cómo cada indicación se basa en la respuesta anterior. Estás manteniendo una conversación, no empezando de cero cada vez.
+
+---
+
+### Modo 2: Modo Plan
+
+
+
+**Mejor para**: Tareas complejas donde quieres revisar el enfoque antes de la ejecución. Similar a planear una ruta antes de un viaje usando GPS.
+
+El modo Plan te ayuda a crear un plan paso a paso antes de escribir cualquier código. Usa el comando `/plan`, presiona **Shift+Tab** para cambiar al Modo Plan:
+
+```bash
+copilot
+
+> /plan Add a "mark as read" command to the book app
+```
+
+> 💡 **Consejo**: **Shift+Tab** cambia entre modos: Interactive → Plan → Autopilot. Púlsalo en cualquier momento durante una sesión interactiva para cambiar de modo sin teclear un comando.
+
+También puedes iniciar Copilot CLI directamente en modo Plan usando la bandera `--plan`:
+
+```bash
+copilot --plan
+```
+
+**Salida del modo Plan:** (tu salida puede variar)
+
+```
+📋 Implementation Plan
+
+Step 1: Update the command handler in book_app.py
+ - Add new elif branch for "mark" command
+ - Create handle_mark_as_read() function
+
+Step 2: Implement the handler function
+ - Prompt user for book title
+ - Call collection.mark_as_read(title)
+ - Display success/failure message
+
+Step 3: Update help text
+ - Add "mark" to available commands list
+ - Document the command usage
+
+Step 4: Test the flow
+ - Add a book
+ - Mark it as read
+ - Verify status changes in list output
+
+Proceed with implementation? [Y/n]
+```
+
+**Idea clave**: El modo Plan te permite revisar y modificar el enfoque antes de escribir código. Una vez que un plan está completo, incluso puedes pedirle a Copilot CLI que lo guarde en un archivo para referencia posterior. Por ejemplo, "Save this plan to `mark_as_read_plan.md`" crearía un archivo markdown con los detalles del plan.
+
+> 💡 **¿Quieres algo más complejo?** Prueba: `/plan Add search and filter capabilities to the book app`. El modo Plan escala desde características simples hasta aplicaciones completas.
+
+> 📚 **Modo Autopilot**: Puede que hayas notado que Shift+Tab recorre un tercer modo llamado **Autopilot**. En el modo autopilot, Copilot ejecuta un plan completo sin esperar tu entrada después de cada paso — como delegar una tarea a un colega y decir “avísame cuando termines”. El flujo típico es plan → aceptar → autopilot, lo que significa que debes ser bueno escribiendo planes primero. También puedes iniciar directamente en autopilot con `copilot --autopilot`. Familiarízate primero con los modos Interactivo y Plan, y luego consulta la [documentación oficial](https://docs.github.com/copilot/concepts/agents/copilot-cli/autopilot) cuando estés listo.
+
+---
+
+### Modo 3: Modo Programático
+
+
+
+**Mejor para**: Automatización, scripts, CI/CD, comandos de un solo uso. Como usar un autoservicio para un pedido rápido sin necesidad de hablar con un camarero.
+
+Usa la bandera `-p` para comandos puntuales que no requieren interacción:
+
+```bash
+# Generar código
+copilot -p "Write a function that checks if a number is even or odd"
+
+# Obtener ayuda rápida
+copilot -p "How do I read a JSON file in Python?"
+```
+
+**Idea clave**: El modo programático te da una respuesta rápida y sale. No hay conversación, solo entrada → salida.
+
+
+📚 Ir más allá: Usar el modo programático en scripts (haz clic para expandir)
+
+Una vez que estés cómodo, puedes usar `-p` en scripts de shell:
+
+```bash
+#!/bin/bash
+
+# Generar mensajes de commit automáticamente
+COMMIT_MSG=$(copilot -p "Generate a commit message for: $(git diff --staged)")
+git commit -m "$COMMIT_MSG"
+
+# Revisar un archivo
+copilot --allow-all -p "Review @myfile.py for issues"
+```
+> ⚠️ **Sobre `--allow-all`**: Esta bandera omite todos los avisos de permisos, permitiendo que Copilot CLI lea archivos, ejecute comandos y acceda a URLs sin pedir aprobación primero. Esto es necesario para el modo programático (`-p`) ya que no hay una sesión interactiva para aprobar acciones. Usa `--allow-all` solo con indicaciones que hayas escrito tú mismo y en directorios en los que confíes. Nunca lo uses con entradas no confiables o en directorios sensibles.
+
+
+
+---
+
+## Comandos esenciales con slash
+
+Estos comandos son geniales para aprender inicialmente mientras te familiarizas con Copilot CLI:
+
+| Command | What It Does | When to Use |
+|---------|--------------|-------------|
+| `/ask` | Ask a quick question without it affecting your conversation history | When you want a quick answer without derailing your current task |
+| `/clear` | Clear conversation and start fresh | When switching topics |
+| `/help` | Show all available commands | When you forget a command |
+| `/model` | Show or switch AI model | When you want to change the AI model |
+| `/plan` | Plan your work out before coding | For more complex features |
+| `/research` | Deep research using GitHub and web sources | When you need to investigate a topic before coding |
+| `/exit` | End the session | When you're done |
+
+> 💡 **`/ask` vs chat normal**: Normalmente, cada mensaje que envías pasa a formar parte de la conversación en curso y afecta a las respuestas futuras. `/ask` es un atajo "off the record" — perfecto para preguntas puntuales como `/ask What does YAML mean?` sin ensuciar el contexto de tu sesión.
+> 💡 **Autocompletar con Tab**: Al escribir un comando con barra, presiona **Tab** para autocompletar el nombre del comando o recorrer los subcomandos y argumentos disponibles. Esto es especialmente útil cuando no recuerdas el nombre exacto de un comando.
+
+¡Eso es todo para comenzar! A medida que te familiarices, puedes explorar comandos adicionales.
+
+> 📚 **Documentación oficial**: [Referencia de comandos CLI](https://docs.github.com/copilot/reference/cli-command-reference) para la lista completa de comandos y flags.
+
+
+📚 Comandos adicionales (haga clic para expandir)
+
+> 💡 Los comandos esenciales anteriores cubren gran parte de lo que harás en el uso diario. Esta referencia está aquí para cuando estés listo para explorar más.
+
+### Entorno del agente
+
+| Command | What It Does |
+|---------|--------------|
+| `/agent` | Browse and select from available agents |
+| `/env` | Show loaded environment details — what instructions, MCP servers, skills, agents, and plugins are active |
+| `/init` | Initialize Copilot instructions for your repository |
+| `/mcp` | Manage MCP server configuration |
+| `/settings` | Open an interactive dialog to browse and edit all user settings in one place |
+| `/skills` | Manage skills for enhanced capabilities |
+
+> 💡 Agents are covered in [Chapter 04](../04-agents-custom-instructions/README.md), skills are covered in [Chapter 05](../05-skills/README.md), and MCP servers are covered in [Chapter 06](../06-mcp-servers/README.md).
+
+### Models and Subagents
+
+| Command | What It Does |
+|---------|--------------|
+| `/delegate` | Hand off task to GitHub Copilot cloud agent |
+| `/fleet` | Split a complex task into parallel subtasks for faster completion |
+| `/model` | Show or switch AI model |
+| `/tasks` | View background subagents and detached shell sessions |
+
+### Code
+
+| Command | What It Does |
+|---------|--------------|
+| `/diff` | Review the changes made in the current directory |
+| `/pr` | Operate on pull requests for the current branch |
+| `/research` | Run deep research investigation using GitHub and web sources |
+| `/review` | Run the code-review agent to analyze changes |
+| `/terminal-setup` | Enable multiline input support (shift+enter and ctrl+enter) |
+
+### Permissions
+
+| Command | What It Does |
+|---------|--------------|
+| `/add-dir ` | Add a directory to allowed list |
+| `/allow-all [on\|off\|show]` | Auto-approve all permission prompts; use `on` to enable, `off` to disable, `show` to check current status |
+| `/yolo` | Quick alias for `/allow-all on` — auto-approves all permission prompts. |
+| `/cwd`, `/cd [directory]` | View or change working directory |
+| `/list-dirs` | Show all allowed directories |
+
+> ⚠️ **Usar con precaución**: `/allow-all` y `/yolo` omiten los avisos de confirmación. Genial para proyectos de confianza, pero ten cuidado con código no confiable.
+
+### Session
+
+| Command | What It Does |
+|---------|--------------|
+| `/clear` | Abandons the current session (no history saved) and starts a fresh conversation |
+| `/compact` | Summarize conversation to reduce context usage (optionally add focus instructions, e.g. `/compact focus on the bug list`) |
+| `/context` | Show context window token usage and visualization |
+| `/keep-alive` | Prevent your system from sleeping while Copilot CLI is active — handy for long-running tasks on a laptop |
+| `/memory [on\|off\|show]` | Enable, disable, or view persistent memory — facts and preferences remembered across all sessions |
+| `/new` | Ends the current session (saving it to history for search/resume) and starts a fresh conversation. |
+| `/resume` | Switch to a different session (optionally specify session ID or name) |
+| `/rename` | Rename the current session (omit the name to auto-generate one) |
+| `/rewind` | Open a timeline picker to roll back to any earlier point in the conversation |
+| `/usage` | Display session usage metrics and statistics, including quota progress bars |
+| `/session` | Show session info and workspace summary; use `/session delete`, `/session delete `, or `/session delete-all` to remove sessions |
+| `/share` | Export session as a markdown file, GitHub gist, or self-contained HTML file |
+| `/every ` | Schedule a prompt to run on a recurring interval (e.g., `/every 1h summarize new commits`). Use natural language for the interval. `/loop` is an alias for `/every`. |
+| `/after
+
+---
+
+# Practice
+
+
+
+Es hora de poner en práctica lo que has aprendido.
+
+---
+
+## ▶️ Pruébalo tú mismo
+
+### Exploración interactiva
+
+Inicia Copilot y usa indicaciones de seguimiento para mejorar iterativamente la aplicación de libros:
+
+```bash
+copilot
+
+> Review @samples/book-app-project/book_app.py - what could be improved?
+
+> Refactor the if/elif chain into a more maintainable structure
+
+> Add type hints to all the handler functions
+
+> /exit
+```
+
+### Planifica una función
+
+Usa `/plan` para que Copilot CLI diseñe una implementación antes de escribir código:
+
+```bash
+copilot
+
+> /plan Add a search feature to the book app that can find books by title or author
+
+# Revisar el plan
+# Aprobar o modificar
+# Observar cómo se implementa paso a paso
+```
+
+### Automatiza con el modo programático
+
+La opción `-p` te permite ejecutar Copilot CLI directamente desde tu terminal sin entrar en modo interactivo. Copia y pega el siguiente script en tu terminal (no dentro de Copilot) desde la raíz del repositorio para revisar todos los archivos Python en la aplicación de libros.
+
+```bash
+# Revisar todos los archivos Python en la aplicación del libro
+for file in samples/book-app-project/*.py; do
+ echo "Reviewing $file..."
+ copilot --allow-all -p "Quick code quality review of @$file - critical issues only"
+done
+```
+
+**PowerShell (Windows):**
+
+```powershell
+# Revisar todos los archivos Python en la aplicación de libros
+Get-ChildItem samples/book-app-project/*.py | ForEach-Object {
+ $relativePath = "samples/book-app-project/$($_.Name)";
+ Write-Host "Reviewing $relativePath...";
+ copilot --allow-all -p "Quick code quality review of @$relativePath - critical issues only"
+}
+```
+
+---
+
+Después de completar las demostraciones, prueba estas variaciones:
+
+1. **Desafío interactivo**: Inicia `copilot` y explora la aplicación de libros. Pregunta por `@samples/book-app-project/books.py` y solicita mejoras 3 veces seguidas.
+
+2. **Desafío en modo Plan**: Ejecuta `/plan Add rating and review features to the book app`. Lee el plan cuidadosamente. ¿Tiene sentido?
+
+3. **Desafío programático**: Ejecuta `copilot --allow-all -p "List all functions in @samples/book-app-project/book_app.py and describe what each does"`. ¿Funcionó a la primera?
+
+---
+
+## 💡 Consejo: Controla tu sesión CLI desde la web o el móvil
+
+GitHub Copilot CLI admite **sesiones remotas**, que te permiten monitorizar e interactuar con una sesión CLI en ejecución desde un navegador web (en escritorio o móvil) o desde la app GitHub Mobile sin estar físicamente en tu terminal.
+
+Inicia una sesión remota con la opción `--remote`:
+
+```bash
+copilot --remote
+```
+
+Copilot CLI mostrará un enlace y proporcionará acceso a un código QR. Abre el enlace en tu teléfono o en una pestaña del navegador de escritorio para ver la sesión en tiempo real, enviar indicaciones de seguimiento, revisar planes y dirigir el agente de forma remota. Las sesiones son específicas del usuario, por lo que solo puedes acceder a tus propias sesiones de Copilot CLI.
+
+También puedes habilitar el acceso remoto desde dentro de una sesión activa en cualquier momento:
+
+```
+> /remote
+```
+
+Detalles adicionales sobre las sesiones remotas se pueden encontrar en la [documentación de Copilot CLI](https://docs.github.com/copilot/how-tos/copilot-cli/steer-remotely).
+
+---
+
+## 📝 Tarea
+
+### Desafío principal: Mejora las utilidades de la aplicación de libros
+
+Los ejemplos prácticos se centraron en revisar y refactorizar `book_app.py`. Ahora practica las mismas habilidades en un archivo diferente, `utils.py`:
+
+1. Inicia una sesión interactiva: `copilot`
+2. Pide a Copilot CLI que resuma el archivo: "Summarize @samples/book-app-project/utils.py and explain what each function in this file does"
+3. Pídele que añada validación de entrada: "Add validation to `get_user_choice()` so it handles empty input and non-numeric entries"
+4. Pídele que mejore el manejo de errores: "What happens if `get_book_details()` receives an empty string for the title? Add guards for that."
+5. Pide una docstring: "Add a comprehensive docstring to `get_book_details()` with parameter descriptions and return values"
+6. Observa cómo el contexto se traslada entre las indicaciones. Cada mejora se construye sobre la anterior
+7. Sal con `/exit`
+
+**Criterios de éxito**: Debes tener un `utils.py` mejorado con validación de entrada, manejo de errores y una docstring, todo construido mediante una conversación de múltiples turnos.
+
+
+💡 Consejos (haga clic para expandir)
+
+**Indicaciones de ejemplo para probar:**
+```bash
+> @samples/book-app-project/utils.py What does each function in this file do?
+> Add validation to get_user_choice() so it handles empty input and non-numeric entries
+> What happens if get_book_details() receives an empty string for the title? Add guards for that.
+> Add a comprehensive docstring to get_book_details() with parameter descriptions and return values
+```
+
+**Problemas comunes:**
+- Si Copilot CLI hace preguntas aclaratorias, respóndelas de forma natural
+- El contexto se mantiene, así que cada indicación se basa en la anterior
+- Usa `/clear` si quieres empezar de nuevo
+
+
+
+### Desafío adicional: Compara los modos
+
+Los ejemplos usaron `/plan` para una función de búsqueda y `-p` para revisiones por lotes. Ahora prueba los tres modos en una sola tarea nueva: añadir un método `list_by_year()` a la clase `BookCollection`:
+
+1. **Interactivo**: `copilot` → pídele que diseñe y construya el método paso a paso
+2. **Plan**: `/plan Add a list_by_year(start, end) method to BookCollection that filters books by publication year range`
+3. **Programático**: `copilot --allow-all -p "@samples/book-app-project/books.py Add a list_by_year(start, end) method that returns books published between start and end year inclusive"`
+
+**Reflexión**: ¿Qué modo te resultó más natural? ¿Cuándo usarías cada uno?
+
+---
+
+
+🔧 Errores comunes y solución de problemas (haga clic para expandir)
+
+### Errores comunes
+
+| Mistake | What Happens | Fix |
+|---------|--------------|-----|
+| Typing `exit` instead of `/exit` | Copilot CLI treats "exit" as a prompt, not a command | Slash commands always start with `/` |
+| Using `-p` for multi-turn conversations | Each `-p` call is isolated with no memory of previous calls | Use interactive mode (`copilot`) for conversations that build on context |
+| Forgetting quotes around prompts with `$` or `!` | Shell interprets special characters before Copilot CLI sees them | Wrap prompts in quotes: `copilot -p "What does $HOME mean?"` |
+| Pressing Esc once to cancel a running task | A single Esc no longer cancels in-flight work (to prevent accidents) | Press **Esc twice** to cancel while Copilot CLI is processing |
+
+### Solución de problemas
+
+**"Model not available"** - Your subscription may not include all models. Use `/model` to see what's available.
+
+**"Context too long"** - Your conversation has used the full context window. Use `/clear` to reset, or start a new session.
+
+**"Rate limit exceeded"** - Wait a few minutes and try again. Consider using programmatic mode for batch operations with delays.
+
+
+
+---
+
+# Summary
+
+## 🔑 Puntos clave
+1. **Modo interactivo** es para la exploración y la iteración - el contexto se mantiene. Es como mantener una conversación con alguien que recuerda lo que has dicho hasta ese momento.
+2. **Modo de planificación** suele ser para tareas más complejas. Revisa antes de implementar.
+3. **Modo programático** es para la automatización. No se necesita interacción.
+4. **Comandos esenciales** (`/ask`, `/help`, `/clear`, `/plan`, `/research`, `/model`, `/exit`) cubren la mayoría del uso diario.
+
+> 📋 **Referencia rápida**: Consulta la [Referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para obtener una lista completa de comandos y atajos.
+
+---
+
+## ➡️ ¿Qué sigue?
+
+Ahora que entiendes los tres modos, aprendamos cómo proporcionar a Copilot CLI contexto sobre tu código.
+
+En **[Capítulo 02: Contexto y conversaciones](../02-context-conversations/README.md)**, aprenderás:
+
+- La sintaxis `@` para referenciar archivos y directorios
+- Gestión de sesiones con `--resume` y `--continue`
+- Cómo la gestión del contexto hace que Copilot CLI sea realmente potente
+
+---
+
+**[← Volver al inicio del curso](../README.md)** | **[Continuar al Capítulo 02 →](../02-context-conversations/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/02-context-conversations/README.md b/translations/es/02-context-conversations/README.md
new file mode 100644
index 00000000..6d890042
--- /dev/null
+++ b/translations/es/02-context-conversations/README.md
@@ -0,0 +1,961 @@
+
+
+
+
+> **¿Y si la IA pudiera ver todo tu código, no solo un archivo a la vez?**
+
+En este capítulo, desbloquearás el verdadero poder de GitHub Copilot CLI: el contexto. Aprenderás a usar la sintaxis `@` para referenciar archivos y directorios, dándole a Copilot CLI una comprensión profunda de tu base de código. Descubrirás cómo mantener conversaciones a lo largo de sesiones, reanudar trabajo días después exactamente donde lo dejaste, y verás cómo el análisis entre archivos detecta errores que la revisión de un solo archivo no descubre en absoluto.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, podrás:
+
+- Usar la sintaxis `@` para referenciar archivos, directorios e imágenes
+- Reanudar sesiones anteriores con `--resume` y `--continue`
+- Entender cómo funcionan las [ventanas de contexto](../GLOSSARY.md#context-window)
+- Escribir conversaciones multi-turno efectivas
+- Administrar permisos de directorio para flujos de trabajo multi-proyecto
+
+> ⏱️ **Tiempo estimado**: ~50 minutos (20 min lectura + 30 min práctica)
+
+---
+
+## 🧩 Analogía del mundo real: Trabajar con un colega
+
+
+
+*Al igual que tus colegas, Copilot CLI no es un lector de mentes. Proporcionar más información ayuda tanto a los humanos como a Copilot a ofrecer soporte más preciso.*
+
+Imagina explicar un error a un colega:
+
+> **Sin contexto**: "La app de libros no funciona."
+
+> **Con contexto**: "Mira `books.py`, especialmente la función `find_book_by_title`. No está haciendo coincidencia sin distinguir mayúsculas y minúsculas."
+
+Para proporcionar contexto a Copilot CLI usa *la sintaxis `@`* para señalar a Copilot CLI archivos específicos.
+
+---
+
+# Esencial: Contexto básico
+
+
+
+Esta sección cubre todo lo que necesitas para trabajar efectivamente con contexto. Domina estos conceptos básicos primero.
+
+---
+
+## La sintaxis @
+
+El símbolo `@` referencia archivos y directorios en tus prompts. Es la forma de decirle a Copilot CLI "mira este archivo".
+
+> 💡 **Nota**: Todos los ejemplos en este curso usan la carpeta `samples/` incluida en este repositorio, así que puedes probar cada comando directamente.
+
+### Pruébalo ahora (sin configuración)
+
+Puedes probar esto con cualquier archivo en tu ordenador:
+
+```bash
+copilot
+
+# Señala cualquier archivo que tengas
+> Explain what @package.json does
+> Summarize @README.md
+> What's in @.gitignore and why?
+```
+
+> 💡 **¿No tienes un proyecto a mano?** Crea un archivo de prueba rápido:
+> ```bash
+> echo "def greet(name): return 'Hello ' + name" > test.py
+> copilot
+> > What does @test.py do?
+> ```
+
+### Patrones básicos con @
+
+| Patrón | Qué hace | Ejemplo de uso |
+|--------|----------|----------------|
+| `@file.py` | Referencia un único archivo | `Review @samples/book-app-project/books.py` |
+| `@folder/` | Referencia todos los archivos en un directorio | `Review @samples/book-app-project/` |
+| `@file1.py @file2.py` | Referencia múltiples archivos | `Compare @samples/book-app-project/book_app.py @samples/book-app-project/books.py` |
+
+### Referenciar un solo archivo
+
+```bash
+copilot
+
+> Explain what @samples/book-app-project/utils.py does
+```
+
+---
+
+
+🎬 ¡Verlo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+### Referenciar múltiples archivos
+
+```bash
+copilot
+
+> Compare @samples/book-app-project/book_app.py and @samples/book-app-project/books.py for consistency
+```
+
+### Referenciar un directorio entero
+
+```bash
+copilot
+
+> Review all files in @samples/book-app-project/ for error handling
+```
+
+---
+
+## Inteligencia entre archivos
+
+Aquí es donde el contexto se convierte en una superpotencia. El análisis de un solo archivo es útil. El análisis entre archivos es transformador.
+
+
+
+### Demo: Encontrar errores que abarcan múltiples archivos
+
+```bash
+copilot
+
+> @samples/book-app-project/book_app.py @samples/book-app-project/books.py
+>
+> How do these files work together? What's the data flow?
+```
+
+> 💡 **Opción avanzada**: Para análisis entre archivos centrados en seguridad, prueba los ejemplos de seguridad en Python:
+> ```bash
+> > @samples/buggy-code/python/user_service.py @samples/buggy-code/python/payment_processor.py
+> > Find security vulnerabilities that span BOTH files
+> ```
+
+---
+
+
+🎬 ¡Verlo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+**Qué descubre Copilot CLI**:
+
+```
+Cross-Module Analysis
+=====================
+
+1. DATA FLOW PATTERN
+ book_app.py creates BookCollection instance and calls methods
+ books.py defines BookCollection class and manages data persistence
+
+ Flow: book_app.py (UI) → books.py (business logic) → data.json (storage)
+
+2. DUPLICATE DISPLAY FUNCTIONS
+ book_app.py:9-21 show_books() function
+ utils.py:28-36 print_books() function
+
+ Impact: Two nearly identical functions doing the same thing. If you update
+ one (like changing the format), you must remember to update the other.
+
+3. INCONSISTENT ERROR HANDLING
+ book_app.py handles ValueError from year conversion
+ books.py silently returns None/False on errors
+
+ Pattern: No unified approach to error handling across modules
+```
+
+**Por qué esto importa**: Una revisión de un solo archivo perdería la imagen completa. Solo el análisis entre archivos revela:
+- **Código duplicado** que debería consolidarse
+- **Patrones de flujo de datos** que muestran cómo interactúan los componentes
+- **Problemas de arquitectura** que afectan la mantenibilidad
+
+---
+
+### Demo: Entender una base de código en 60 segundos
+
+
+
+¿Nuevo en un proyecto? Conócelo rápidamente usando Copilot CLI.
+
+```bash
+copilot
+
+> @samples/book-app-project/
+>
+> In one paragraph, what does this app do and what are its biggest quality issues?
+```
+
+**Qué obtienes**:
+```
+This is a CLI book collection manager that lets users add, list, remove, and
+search books stored in a JSON file. The biggest quality issues are:
+
+1. Duplicate display logic - show_books() and print_books() do the same thing
+2. Inconsistent error handling - some errors raise exceptions, others return False
+3. No input validation - year can be 0, empty strings accepted for title/author
+4. Missing tests - no test coverage for critical functions like find_book_by_title
+
+Priority fix: Consolidate duplicate display functions and add input validation.
+```
+
+**Resultado**: Lo que toma una hora de lectura de código comprimido en 10 segundos. Sabes exactamente en qué enfocarte.
+
+---
+
+## Ejemplos prácticos
+
+### Ejemplo 1: Revisión de código con contexto
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Review this file for potential bugs
+
+# Copilot CLI ahora tiene el contenido completo del archivo y puede dar retroalimentación específica:
+# "Línea 49: La comparación que distingue entre mayúsculas y minúsculas puede no detectar algunos libros..."
+# "Línea 29: Los errores de decodificación JSON se capturan pero la corrupción de datos no se registra..."
+
+> What about @samples/book-app-project/book_app.py?
+
+# Ahora revisando book_app.py, pero aún consciente del contexto de books.py
+```
+
+### Ejemplo 2: Entender una base de código
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py What does this module do?
+
+# Copilot CLI lee books.py y comprende la clase BookCollection
+
+> @samples/book-app-project/ Give me an overview of the code structure
+
+# Copilot CLI examina el directorio y resume
+
+> How does the app save and load books?
+
+# Copilot CLI puede rastrear el código que ya ha visto
+```
+
+
+🎬 ¡Ver una conversación de múltiples turnos en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+### Ejemplo 3: Refactorización en múltiples archivos
+
+```bash
+copilot
+
+> @samples/book-app-project/book_app.py @samples/book-app-project/utils.py
+> I see duplicate display functions: show_books() and print_books(). Help me consolidate these.
+
+# Copilot CLI ve ambos archivos y puede sugerir cómo fusionar el código duplicado
+```
+
+---
+
+## Gestión de sesiones
+
+Las sesiones se guardan automáticamente mientras trabajas. Puedes reanudar sesiones anteriores para continuar donde lo dejaste.
+
+### Las sesiones se guardan automáticamente
+
+Cada conversación se guarda automáticamente. Simplemente sal normalmente:
+
+```bash
+copilot
+
+> @samples/book-app-project/ Let's improve error handling across all modules
+
+[... do some work ...]
+
+> /exit
+```
+
+### Reanudar la sesión más reciente
+
+```bash
+# Continúa donde lo dejaste
+copilot --continue
+```
+
+### Reanudar una sesión específica
+
+```bash
+# Selecciona de una lista de sesiones de forma interactiva
+copilot --resume
+
+# -r es una abreviatura de --resume (¡ahorra algo de escritura!)
+copilot -r
+
+# O reanuda una sesión específica por su ID
+copilot --resume=abc123
+
+# O reanuda usando el nombre que le diste a la sesión
+copilot --resume="my book app review"
+```
+
+> 💡 **¿Cómo encuentro un ID de sesión?** No necesitas memorizarlos. Ejecutar `copilot --resume` sin un ID muestra una lista interactiva de tus sesiones anteriores, sus nombres, IDs y cuándo estuvieron activas por última vez. Solo elige la que quieras.
+>
+> **¿Y múltiples terminales?** Cada ventana de terminal es su propia sesión con su propio contexto. Si tienes Copilot CLI abierto en tres terminales, eso son tres sesiones separadas. Ejecutar `--resume` desde cualquier terminal te permite explorar todas ellas. La bandera `--continue` toma la sesión desde el directorio de trabajo actual primero; si no existe ninguna allí, elige la sesión más recientemente activa.
+>
+> **¿Puedo cambiar de sesión sin reiniciar?** Sí. Usa el comando con barra `/resume` desde dentro de una sesión activa:
+> ```
+> > /resume
+> # Shows a list of sessions to switch to
+> ```
+
+### Organiza tus sesiones
+
+Pon nombres significativos a las sesiones para que puedas encontrarlas luego. Puedes nombrar una sesión cuando la inicias, o renombrarla en cualquier momento mientras estás dentro de la sesión:
+
+```bash
+# Nombra una sesión justo cuando la inicias
+copilot --name book-app-review
+
+# O renombra la sesión actual desde dentro
+copilot
+
+> /rename book-app-review
+# Sesión renombrada para facilitar su identificación
+```
+
+Una vez que una sesión tiene nombre, puedes reanudarla directamente por nombre sin navegar por una lista:
+
+```bash
+copilot --resume=book-app-review
+```
+
+Para limpiar sesiones que ya no necesitas, usa `/session delete` desde dentro de una sesión:
+
+```bash
+copilot
+
+> /session delete # Elimina la sesión actual
+> /session delete abc123 # Elimina una sesión específica por su ID
+> /session delete-all # Elimina todas las sesiones (¡usar con precaución!)
+```
+
+### Memoria persistente entre sesiones
+
+Las sesiones guardan el historial de la conversación, pero la **memoria** va un paso más allá y permite que Copilot CLI recuerde preferencias y hechos *a través de todas las sesiones*, no solo dentro de una sola.
+
+```bash
+copilot
+
+> /memory show
+# Muestra lo que Copilot CLI recuerda actualmente sobre ti y tu proyecto
+
+> /memory on
+# Activa la memoria (activada por defecto si tu cuenta la admite)
+
+> /memory off
+# Desactiva la memoria (útil si prefieres empezar de cero cada vez)
+```
+
+Por ejemplo, si le dices a Copilot CLI "Siempre prefiero pytest para pruebas en Python", puede recordar esa preferencia y aplicarla automáticamente en sesiones futuras. Todo sin que tengas que repetirlo.
+
+> 💡 **Memoria vs. Sesiones**: Las sesiones guardan el historial de conversación para que puedas reanudar una tarea específica. La memoria guarda hechos reutilizables del repositorio y preferencias del usuario que Copilot puede aplicar en trabajos futuros. Piensa en las sesiones como cuadernos de tareas, y en la memoria como contexto reutilizable que Copilot puede llevar adelante.
+
+### Comprobar y gestionar el contexto
+
+A medida que añades archivos y conversación, la [ventana de contexto](../GLOSSARY.md#context-window) de Copilot CLI se va llenando. Hay varios comandos disponibles para ayudarte a mantener el control:
+
+```bash
+copilot
+
+> /context
+Context usage: 62k/200k tokens (31%)
+
+> /clear
+# Abandona la sesión actual (no se guarda el historial) y comienza una conversación nueva
+
+> /new
+# Termina la sesión actual (guardándola en el historial para búsqueda/reanudación) y comienza una conversación nueva
+
+> /rewind
+# Abre un selector de línea temporal que te permite retroceder a un punto anterior de la conversación
+```
+
+> 💡 **¿Cuándo usar `/clear` o `/new`?** Si estuviste revisando books.py y quieres cambiar a discutir utils.py, ejecuta /new primero (o /clear si no necesitas el historial de la sesión). De lo contrario, el contexto antiguo del tema anterior puede confundir las respuestas.
+
+> 💡 **¿Cometiste un error o quieres probar un enfoque diferente?** Usa `/rewind` (o presiona Esc dos veces) para abrir un **selector de línea de tiempo** que te permite retroceder a cualquier punto anterior en tu conversación, no solo al más reciente. Esto es útil cuando tomaste un camino equivocado y quieres retroceder sin empezar completamente de nuevo.
+
+---
+
+### Retomar donde lo dejaste
+
+
+
+*Las sesiones se guardan automáticamente al salir. Reanuda días después con todo el contexto: archivos, incidencias y progreso recordados.*
+
+Imagina este flujo de trabajo a lo largo de varios días:
+
+```bash
+# Lunes: Comenzar la revisión de la aplicación de libros con un nombre desde el principio
+copilot --name book-app-review
+
+> @samples/book-app-project/books.py
+> Review and number all code quality issues
+
+Quality Issues Found:
+1. Duplicate display functions (book_app.py & utils.py) - MEDIUM
+2. No input validation for empty strings - MEDIUM
+3. Year can be 0 or negative - LOW
+4. No type hints on all functions - LOW
+5. Missing error logging - LOW
+
+> Fix issue #1 (funciones duplicadas)
+# Trabajar en la corrección...
+
+> /exit
+```
+
+```bash
+# Miércoles: Reanuda exactamente donde lo dejaste, por nombre
+copilot --resume=book-app-review
+
+> What issues remain unfixed from our book app review?
+
+Remaining issues from our book-app-review session:
+2. No input validation for empty strings - MEDIUM
+3. Year can be 0 or negative - LOW
+4. No type hints on all functions - LOW
+5. Missing error logging - LOW
+
+Issue #1 (funciones duplicadas) se resolvió el lunes.
+
+> Let's tackle issue #2 next
+```
+
+**Qué hace esto poderoso**: Días después, Copilot CLI recuerda:
+- El archivo exacto en el que estabas trabajando
+- La lista numerada de incidencias
+- Cuáles ya has abordado
+- El contexto de tu conversación
+
+Sin volver a explicar. Sin volver a leer archivos. Simplemente continúa trabajando.
+
+---
+
+**🎉 ¡Ya conoces lo esencial!** La sintaxis `@`, la gestión de sesiones (`--name`/`--continue`/`--resume`/`/rename`) y los comandos de contexto (`/context`/`/clear`) son suficientes para ser altamente productivo. Todo lo de abajo es opcional. Vuelve a ello cuando estés listo.
+
+---
+
+# Opcional: Profundizar
+
+
+
+Estos temas se basan en lo esencial anterior. **Elige lo que te interese, o salta a [Práctica](#el-espectro-de-especificidad).**
+
+| Quiero aprender sobre... | Ir a |
+|---|---|
+| Patrones comodín y comandos avanzados de sesión | [Patrones @ adicionales y comandos de sesión](#comprobar-y-gestionar-el-contexto) |
+| Construir sobre el contexto a través de múltiples prompts | [Conversaciones conscientes del contexto](#patrones-adicionales) |
+| Límites de tokens y `/compact` | [Entender las ventanas de contexto](#compartir-tu-sesión) |
+| Cómo elegir los archivos correctos para referenciar | [Elegir qué referenciar](#el-comando-compact) |
+| Analizar capturas de pantalla y maquetas | [Trabajar con imágenes](#qué-incluir-vs-excluir) |
+
+
+Patrones @ adicionales y comandos de sesión
+
+
+### Patrones @ adicionales
+
+Para usuarios avanzados, Copilot CLI admite patrones comodín y referencias de imágenes:
+
+| Patrón | Qué hace |
+|--------|----------|
+| `@folder/*.py` | Todos los archivos .py en la carpeta |
+| `@**/test_*.py` | Comodín recursivo: encuentra todos los archivos de prueba en cualquier lugar |
+| `@image.png` | Archivo de imagen para revisión de UI |
+
+```bash
+copilot
+
+> Find all TODO comments in @samples/book-app-project/**/*.py
+```
+
+### Ver información de la sesión
+
+```bash
+copilot
+
+> /session
+# Muestra los detalles de la sesión actual y un resumen del espacio de trabajo
+
+> /usage
+# Muestra métricas y estadísticas de la sesión
+```
+
+### Compartir tu sesión
+
+```bash
+copilot
+
+> /share file ./my-session.md
+# Exporta la sesión como un archivo Markdown
+
+> /share gist
+# Crea un gist en GitHub con la sesión
+
+> /share html
+# Exporta la sesión como un archivo HTML interactivo y autónomo
+# Útil para compartir informes de sesión pulidos con compañeros de equipo o para guardarlos como referencia
+```
+
+
+
+
+Conversaciones conscientes del contexto
+
+
+### Conversaciones conscientes del contexto
+
+La magia ocurre cuando tienes conversaciones multi-turno que se construyen unas sobre otras.
+
+#### Ejemplo: Mejora progresiva
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Review the BookCollection class
+
+Copilot CLI: "The class looks functional, but I notice:
+1. Missing type hints on some methods
+2. No validation for empty title/author
+3. Could benefit from better error handling"
+
+> Add type hints to all methods
+
+Copilot CLI: "Here's the class with complete type hints..."
+[Shows typed version]
+
+> Now improve error handling
+
+Copilot CLI: "Building on the typed version, here's improved error handling..."
+[Adds validation and proper exceptions]
+
+> Generate tests for this final version
+
+Copilot CLI: "Based on the class with types and error handling..."
+[Generates comprehensive tests]
+```
+
+Fíjate cómo cada prompt se basa en el trabajo anterior. Este es el poder del contexto.
+
+
+
+
+Entendiendo las ventanas de contexto
+
+
+### Entendiendo las ventanas de contexto
+
+Ya conoces `/context` y `/clear` de lo esencial. Aquí está la imagen más profunda de cómo funcionan las ventanas de contexto.
+
+Todo modelo de IA tiene una "ventana de contexto", que es la cantidad de texto que puede considerar a la vez.
+
+
+
+*La ventana de contexto es como un escritorio: solo puede contener una cierta cantidad a la vez. Los archivos, el historial de conversación y los prompts del sistema ocupan espacio.*
+
+#### Qué sucede al alcanzar el límite
+
+```bash
+copilot
+
+> /context
+
+Context usage: 45,000 / 128,000 tokens (35%)
+
+# A medida que agregas más archivos y conversación, esto crece
+
+> @large-codebase/
+
+Context usage: 120,000 / 128,000 tokens (94%)
+
+# Advertencia: Se acerca al límite de contexto
+
+> @another-large-file.py
+
+Context limit reached. Older context will be summarized.
+```
+
+#### El comando `/compact`
+Cuando tu contexto se está llenando pero no quieres perder la conversación, `/compact` resume tu historial para liberar tokens:
+
+```bash
+copilot
+
+> /compact
+# Resume el historial de la conversación, liberando espacio en el contexto
+# Se conservan sus hallazgos y decisiones clave
+```
+
+También puedes darle a `/compact` instrucciones de enfoque opcionales para determinar qué se prioriza en el resumen:
+
+```bash
+copilot
+
+> /compact focus on the list of bugs we found and decisions made
+# Resume el historial, manteniendo la lista de errores y las decisiones destacadas.
+```
+
+> 💡 **Cuándo usar instrucciones de enfoque**: Si tu conversación abarcó muchos temas, las instrucciones de enfoque ayudan a `/compact` a conservar las partes más relevantes para tus siguientes pasos, para que no pierdas el hilo.
+
+#### Consejos para la eficiencia del contexto
+
+| Situación | Acción | Por qué |
+|-----------|--------|-----|
+| Starting new topic | `/clear` | Elimina el contexto irrelevante |
+| Went down wrong path | `/rewind` | Retrocede a cualquier punto anterior |
+| Long conversation | `/compact` | Resume el historial, libera tokens |
+| Need specific file | `@file.py` not `@folder/` | Carga solo lo que necesitas |
+| Hitting limits | `/new` or `/clear` | Contexto limpio |
+| Multiple topics | Use `/rename` per topic | Fácil de reanudar la sesión correcta |
+
+#### Mejores prácticas para bases de código grandes
+
+1. **Sé específico**: `@samples/book-app-project/books.py` instead of `@samples/book-app-project/`
+2. **Borra el contexto entre temas**: Use `/new` or `/clear` when switching focus
+3. **Usa `/compact`**: Summarize conversation to free up context
+4. **Usa múltiples sesiones**: One session per feature or topic
+
+
+
+
+Elegir qué referenciar
+
+
+### Elegir qué referenciar
+
+Not all files are equal when it comes to context. Here's how to choose wisely:
+
+#### Consideraciones sobre el tamaño de los archivos
+
+| Tamaño de archivo | Aproximado [Tokens](../GLOSSARY.md#token) | Estrategia |
+|-----------|-------------------|----------|
+| Pequeño (<100 líneas) | ~500-1,500 tokens | Referenciar libremente |
+| Mediano (100-500 líneas) | ~1,500-7,500 tokens | Referenciar archivos específicos |
+| Grande (500+ líneas) | 7,500+ tokens | Sé selectivo, usa archivos específicos |
+| Muy grande (1000+ líneas) | 15,000+ tokens | Considera dividir o apuntar a secciones |
+
+**Ejemplos concretos:**
+- Los 4 archivos Python de la app de libros combinados ≈ 2,000-3,000 tokens
+- Un módulo Python típico (200 líneas) ≈ 3,000 tokens
+- Un archivo de API Flask (400 líneas) ≈ 6,000 tokens
+- Tu package.json ≈ 200-500 tokens
+- Un prompt corto + respuesta ≈ 500-1,500 tokens
+
+> 💡 **Estimación rápida para código:** Multiplica las líneas de código por ~15 para obtener una estimación aproximada de tokens. Ten en cuenta que esto es solo una estimación.
+
+#### Qué incluir vs. excluir
+
+**Alto valor** (incluir estos):
+- Puntos de entrada (`book_app.py`, `main.py`, `app.py`)
+- Los archivos específicos sobre los que preguntas
+- Archivos importados directamente por tu archivo objetivo
+- Archivos de configuración (`requirements.txt`, `pyproject.toml`)
+- Modelos de datos o dataclasses
+
+**Bajo valor** (considera excluir):
+- Archivos generados (salida compilada, assets empaquetados)
+- Módulos de Node o directorios vendor
+- Archivos de datos grandes o fixtures
+- Archivos no relacionados con tu pregunta
+
+#### El espectro de especificidad
+
+```
+Less specific ────────────────────────► More specific
+@samples/book-app-project/ @samples/book-app-project/books.py:47-52
+ │ │
+ └─ Scans everything └─ Just what you need
+ (uses more context) (preserves context)
+```
+
+**Cuando optar por una visión amplia** (`@samples/book-app-project/`):
+- Exploración inicial del código
+- Encontrar patrones en muchos archivos
+- Revisiones de arquitectura
+
+**Cuándo optar por ser específico** (`@samples/book-app-project/books.py`):
+- Depurar un problema particular
+- Revisión de código de un archivo específico
+- Preguntar sobre una sola función
+
+#### Ejemplo práctico: Carga por etapas del contexto
+
+```bash
+copilot
+
+# Paso 1: Comienza con la estructura
+> @package.json What frameworks does this project use?
+
+# Paso 2: Acota según la respuesta
+> @samples/book-app-project/ Show me the project structure
+
+# Paso 3: Enfócate en lo que importa
+> @samples/book-app-project/books.py Review the BookCollection class
+
+# Paso 4: Agrega solo los archivos relacionados según sea necesario
+> @samples/book-app-project/book_app.py @samples/book-app-project/books.py How does the CLI use the BookCollection?
+```
+
+Este enfoque por etapas mantiene el contexto enfocado y eficiente.
+
+
+
+
+Trabajar con imágenes
+
+
+### Trabajar con imágenes
+
+Puedes incluir imágenes en tus conversaciones usando la `@` syntax, o simplemente **pegarlas desde tu portapapeles** (Cmd+V / Ctrl+V). Copilot CLI puede analizar capturas de pantalla, maquetas y diagramas para ayudar con UI debugging, implementación de diseño, y análisis de errores.
+
+```bash
+copilot
+
+> @assets/screenshot.png What is happening in this image?
+
+> @assets/mockup.png Write the HTML and CSS to match this design. Place it in a new file called index.html and put the CSS in styles.css.
+```
+
+> 📖 **Más información**: Consulta [Funciones de contexto adicionales](../appendices/additional-context.md#trabajar-con-imágenes) para formatos compatibles, casos de uso prácticos, y consejos para combinar imágenes con código.
+
+
+
+---
+
+# Práctica
+
+
+
+Es hora de aplicar tus habilidades de gestión de contexto y sesiones.
+
+---
+
+## ▶️ Pruébalo tú mismo
+
+### Revisión del proyecto completo
+
+El curso incluye archivos de ejemplo que puedes revisar directamente. Inicia copilot y ejecuta el prompt que se muestra a continuación:
+
+```bash
+copilot
+
+> @samples/book-app-project/ Give me a code quality review of this project
+
+# Copilot CLI identificará problemas como:
+# - Funciones de visualización duplicadas
+# - Falta de validación de entradas
+# - Manejo de errores inconsistente
+```
+
+> 💡 **¿Quieres probar con tus propios archivos?** Crea un pequeño proyecto Python (`mkdir -p my-project/src`), añade algunos archivos .py, luego usa `@my-project/src/` para revisarlos. Puedes pedirle a copilot que cree código de ejemplo si quieres.
+
+### Flujo de trabajo de sesión
+
+```bash
+copilot
+
+> /rename book-app-review
+> @samples/book-app-project/books.py Let's add input validation for empty titles
+
+[Copilot CLI suggests validation approach]
+
+> Implement that fix
+> Now consolidate the duplicate display functions in @samples/book-app-project/
+> /exit
+
+# Más tarde - retoma donde lo dejaste
+copilot --continue
+
+> Generate tests for the changes we made
+```
+
+---
+
+Después de completar las demostraciones, prueba estas variaciones:
+
+1. **Desafío entre archivos**: Analiza cómo funcionan book_app.py y books.py juntos:
+ ```bash
+ copilot
+ > @samples/book-app-project/book_app.py @samples/book-app-project/books.py
+ > What's the relationship between these files? Are there any code smells?
+ ```
+
+2. **Desafío de sesión**: Inicia una sesión, nómbrala con `/rename my-first-session`, trabaja en algo, sal con `/exit`, luego ejecuta `copilot --continue`. ¿Recuerda lo que estabas haciendo?
+
+3. **Desafío de contexto**: Ejecuta `/context` a mitad de la sesión. ¿Cuántos tokens estás usando? Prueba `/compact` y verifica de nuevo. (Consulta [Comprender las ventanas de contexto](#compartir-tu-sesión) en Going Deeper para más información sobre `/compact`.)
+
+**Autoevaluación**: Entiendes el contexto cuando puedes explicar por qué `@folder/` es más potente que abrir cada archivo individualmente.
+
+---
+
+## 📝 Tarea
+
+### Desafío principal: Rastrear el flujo de datos
+
+Los ejemplos prácticos se centraron en revisiones de calidad de código y validación de entradas. Ahora practica las mismas habilidades de contexto en una tarea diferente, rastreando cómo se mueve la información a través de la app:
+
+1. Inicia una sesión interactiva: `copilot`
+2. Referencia `books.py` y `book_app.py` juntos:
+ `@samples/book-app-project/books.py @samples/book-app-project/book_app.py Trace how a book goes from user input to being saved in data.json. What functions are involved at each step?`
+3. Trae el archivo de datos para contexto adicional:
+ `@samples/book-app-project/data.json What happens if this JSON file is missing or corrupted? Which functions would fail?`
+4. Pide una mejora cruzada entre archivos:
+ `@samples/book-app-project/books.py @samples/book-app-project/utils.py Suggest a consistent error-handling strategy that works across both files.`
+5. Renombra la sesión: `/rename data-flow-analysis`
+6. Sal con `/exit`, luego reanuda con `copilot --continue` y haz una pregunta de seguimiento sobre el flujo de datos
+
+**Criterios de éxito**: Puedes rastrear datos a través de múltiples archivos, reanudar una sesión con nombre y obtener sugerencias entre archivos.
+
+
+💡 Sugerencias (haz clic para expandir)
+
+**Para empezar:**
+```bash
+cd /path/to/copilot-cli-for-beginners
+copilot
+> @samples/book-app-project/books.py @samples/book-app-project/book_app.py Trace how a book goes from user input to being saved in data.json.
+> @samples/book-app-project/data.json What happens if this file is missing or corrupted?
+> /rename data-flow-analysis
+> /exit
+```
+
+Luego reanuda con: `copilot --continue`
+
+**Comandos útiles:**
+- `@file.py` - Referencia un único archivo
+- `@folder/` - Referencia todos los archivos en una carpeta (nota la barra `/` final)
+- `/context` - Comprueba cuánto contexto estás usando
+- `/rename ` - Nombra tu sesión para reanudarla fácilmente
+
+
+
+### Desafío extra: Límites de contexto
+
+1. Referencia todos los archivos de la app de libros a la vez con `@samples/book-app-project/`
+2. Haz varias preguntas detalladas sobre diferentes archivos (`books.py`, `utils.py`, `book_app.py`, `data.json`)
+3. Ejecuta `/context` para ver el uso. ¿Qué tan rápido se llena?
+4. Practica usar `/compact` para recuperar espacio, luego continúa la conversación
+5. Intenta ser más específico con las referencias de archivos (p. ej., `@samples/book-app-project/books.py` en lugar de toda la carpeta) y observa cómo afecta al uso del contexto
+
+---
+
+
+🔧 Errores comunes y resolución de problemas (haz clic para expandir)
+
+### Errores comunes
+
+| Error | Qué ocurre | Solución |
+|---------|--------------|-----|
+| Olvidar `@` antes de los nombres de archivo | Copilot CLI trata "books.py" como texto sin formato | Usa `@samples/book-app-project/books.py` para referenciar archivos |
+| Esperar que las sesiones persistan automáticamente | Iniciar `copilot` desde cero hace que se pierda todo el contexto previo | Usa `--continue` (última sesión) o `--resume` (elige una sesión) |
+| Referenciar archivos fuera del directorio actual | "Permission denied" o "File not found" errors | Usa `/add-dir /path/to/directory` para otorgar acceso |
+| No usar `/clear` al cambiar de tema | El contexto antiguo confunde las respuestas sobre el nuevo tema | Ejecuta `/clear` antes de empezar una tarea distinta |
+
+### Resolución de problemas
+
+**Errores 'File not found'** - Asegúrate de estar en el directorio correcto:
+
+```bash
+pwd # Comprobar el directorio actual
+ls # Listar archivos
+
+# Luego inicia copilot y usa rutas relativas
+copilot
+
+> Review @samples/book-app-project/books.py
+```
+
+**'Permission denied'** - Añade el directorio a tu lista de permitidos:
+
+```bash
+copilot --add-dir /path/to/directory
+
+# O en una sesión:
+> /add-dir /path/to/directory
+```
+
+**El contexto se llena demasiado rápido**:
+- Sé más específico con las referencias de archivos
+- Usa `/clear` entre diferentes temas
+- Divide el trabajo en varias sesiones
+
+
+
+---
+
+# Resumen
+
+## 🔑 Puntos clave
+
+1. **La sintaxis `@`** le da a Copilot CLI contexto sobre archivos, directorios e imágenes
+2. **Las conversaciones de múltiples turnos** se basan unas en otras a medida que el contexto se acumula
+3. **Las sesiones se guardan automáticamente**: nómbralas al iniciar con `--name`, reanúdalas por nombre con `--resume=`, o usa `--continue` para retomar la sesión más reciente
+4. **Las ventanas de contexto** tienen límites: gérnalas con `/clear`, `/compact`, `/context`, `/new` y `/rewind`. Usa `/compact focus on ` para dar forma a lo que se conserva en el resumen
+5. **La memoria persistente** (`/memory`) permite que Copilot CLI recuerde preferencias y hechos en *todas* las sesiones — no solo en la actual
+6. **Las banderas de permiso** (`--add-dir`, `--allow-all`) controlan el acceso a múltiples directorios. ¡Úsalas con cuidado!
+7. **Las referencias a imágenes** (`@screenshot.png`) ayudan a depurar problemas de UI de forma visual
+
+> 📚 **Documentación oficial**: [Usar Copilot CLI](https://docs.github.com/copilot/how-tos/copilot-cli/use-copilot-cli) para la referencia completa sobre contexto, sesiones y trabajo con archivos.
+
+> 📋 **Referencia rápida**: Consulta la [referencia de comandos del GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para una lista completa de comandos y atajos.
+
+---
+
+## ➡️ Qué sigue
+
+Ahora que puedes proporcionar contexto a Copilot CLI, pongámoslo a trabajar en tareas de desarrollo reales. Las técnicas de contexto que acabas de aprender (referencias de archivos, análisis entre archivos y gestión de sesiones) son la base para los potentes flujos de trabajo del siguiente capítulo.
+
+En **[Capítulo 03: Flujos de trabajo de desarrollo](../03-development-workflows/README.md)**, aprenderás:
+
+- Flujos de trabajo de revisión de código
+- Patrones de refactorización
+- Asistencia para depuración
+- Generación de tests
+- Integración con Git
+
+---
+
+**[← Volver al Capítulo 01](../01-setup-and-first-steps/README.md)** | **[Continuar al Capítulo 03 →](../03-development-workflows/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/03-development-workflows/README.md b/translations/es/03-development-workflows/README.md
new file mode 100644
index 00000000..abaffb3e
--- /dev/null
+++ b/translations/es/03-development-workflows/README.md
@@ -0,0 +1,1012 @@
+
+
+
+
+> **¿Y si la IA pudiera encontrar errores que ni siquiera sabías que deberías preguntar?**
+
+En este capítulo, GitHub Copilot CLI se convierte en tu herramienta diaria. Lo usarás dentro de los flujos de trabajo en los que ya confías todos los días: pruebas, refactorización, depuración y Git.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, podrás:
+
+- Realizar revisiones de código completas con Copilot CLI
+- Refactorizar código legado de forma segura
+- Depurar problemas con ayuda de IA
+- Generar pruebas automáticamente
+- Integrar Copilot CLI en tu flujo de trabajo con git
+
+> ⏱️ **Tiempo estimado**: ~60 minutos (15 min lectura + 45 min práctico)
+
+---
+
+## 🧩 Analogía del mundo real: El flujo de trabajo de un carpintero
+
+Un carpintero no solo sabe usar herramientas, tiene *flujos de trabajo* para diferentes tareas:
+
+
+
+De manera similar, los desarrolladores tienen flujos de trabajo para distintas tareas. GitHub Copilot CLI mejora cada uno de estos flujos, haciéndote más eficiente y eficaz en tus tareas de programación diarias.
+
+---
+
+# Los cinco flujos de trabajo
+
+
+
+Cada flujo de trabajo a continuación es autosuficiente. Elige los que coincidan con tus necesidades actuales, o recórrelos todos.
+
+---
+
+## Elige tu propia aventura
+
+Este capítulo cubre cinco flujos de trabajo que los desarrolladores suelen usar. **¡Sin embargo, no necesitas leerlos todos de una vez!** Cada flujo está contenido en una sección plegable más abajo. Elige los que coincidan con lo que necesitas y lo que mejor se adapte a tu proyecto actual. Siempre puedes volver y explorar los demás más tarde.
+
+
+
+| Quiero... | Ir a |
+|---|---|
+| Revisar código antes de fusionar | [Flujo 1: Revisión de código](#workflow-1-code-review) |
+| Limpiar código desordenado o legado | [Flujo 2: Refactorización](#workflow-2-refactoring) |
+| Localizar y arreglar un error | [Flujo 3: Depuración](#workflow-3-debugging) |
+| Generar pruebas para mi código | [Flujo 4: Generación de pruebas](#workflow-4-test-generation) |
+| Escribir mejores commits y PRs | [Flujo 5: Integración con Git](#workflow-5-git-integration) |
+| Investigar antes de codificar | [Consejo rápido: Investiga antes de planear o codificar](#usar-delegate-para-tareas-en-segundo-plano) |
+| Ver un flujo de trabajo de corrección de errores de principio a fin | [Poniéndolo todo junto](#usar-diff-para-revisar-los-cambios-de-la-sesión) |
+
+**Selecciona un flujo de trabajo abajo para expandirlo** y ver cómo GitHub Copilot CLI puede mejorar tu proceso de desarrollo en esa área.
+
+---
+
+
+
+Flujo 1: Revisión de código - Revisar archivos, usar el agente /review, crear listas de verificación por severidad
+
+
+
+### Revisión básica
+
+Este ejemplo usa el símbolo `@` para referenciar un archivo, dando a Copilot CLI acceso directo a su contenido para revisión.
+
+```bash
+copilot
+
+> Review @samples/book-app-project/book_app.py for code quality
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+### Revisión de validación de entrada
+
+Pide a Copilot CLI que centre su revisión en una preocupación específica (aquí, la validación de entrada) enumerando las categorías que te interesan en el prompt.
+
+```text
+copilot
+
+> Review @samples/book-app-project/utils.py for input validation issues. Check for: missing validation, error handling gaps, and edge cases
+```
+
+
+### Revisión del proyecto entre archivos
+
+Referencia un directorio entero con `@` para permitir que Copilot CLI escanee todos los archivos del proyecto a la vez.
+
+```bash
+copilot
+
+> @samples/book-app-project/ Review this entire project. Create a markdown checklist of issues found, categorized by severity
+```
+
+### Revisión de código interactiva
+
+Usa una conversación de varios turnos para profundizar. Comienza con una revisión general y luego haz preguntas de seguimiento sin reiniciar.
+
+```bash
+copilot
+
+> @samples/book-app-project/book_app.py Review this file for:
+> - Input validation
+> - Error handling
+> - Code style and best practices
+
+# Copilot CLI proporciona una revisión detallada
+
+> The user input handling - are there any edge cases I'm missing?
+
+# Copilot CLI muestra problemas potenciales con cadenas vacías y caracteres especiales
+
+> Create a checklist of all issues found, prioritized by severity
+
+# Copilot CLI genera elementos de acción priorizados
+```
+
+### Plantilla de lista de verificación de revisión
+
+Pide a Copilot CLI que estructure su salida en un formato específico (aquí, una lista de verificación en markdown categorizada por severidad que puedes pegar en un issue).
+
+```bash
+copilot
+
+> Review @samples/book-app-project/ and create a markdown checklist of issues found, categorized by:
+> - Critical (data loss risks, crashes)
+> - High (bugs, incorrect behavior)
+> - Medium (performance, maintainability)
+> - Low (style, minor improvements)
+```
+
+### Entender los cambios de Git (Importante para /review)
+
+Antes de usar el comando `/review`, necesitas entender dos tipos de cambios en git:
+
+| Tipo de cambio | Qué significa | Cómo verlo |
+|-------------|---------------|------------|
+| **Cambios preparados** | Archivos que has marcado para el siguiente commit con `git add` | `git diff --staged` |
+| **Cambios no preparados** | Archivos que has modificado pero no has añadido aún | `git diff` |
+
+```bash
+# Referencia rápida
+git status # Muestra tanto los cambios preparados como los no preparados
+git add file.py # Prepara un archivo para el commit
+git diff # Muestra los cambios no preparados
+git diff --staged # Muestra los cambios preparados
+```
+
+### Usando el comando /review
+
+El comando `/review` invoca el **agente de revisión de código** integrado, que está optimizado para analizar cambios preparados y no preparados con una salida de alta relación señal-ruido. Usa un comando de barra para activar un agente integrado especializado en lugar de escribir un prompt en forma libre.
+
+```bash
+copilot
+
+> /review
+# Invoca al agente de revisión de código sobre los cambios preparados o no preparados
+# Proporciona retroalimentación enfocada y accionable
+
+> /review Check for security issues in authentication
+# Ejecuta la revisión con un área de enfoque específica
+```
+
+> 💡 **Consejo**: El agente de revisión de código funciona mejor cuando tienes cambios pendientes. Prepara tus archivos con `git add` para revisiones más focalizadas.
+
+
+
+---
+
+
+
+Flujo 2: Refactorización - Reestructurar código, separar responsabilidades, mejorar manejo de errores
+
+
+
+### Refactorización simple
+
+> **Prueba esto primero:** `@samples/book-app-project/book_app.py The command handling uses if/elif chains. Refactor it to use a dictionary dispatch pattern.`
+
+Start with straightforward improvements. Try these on the book app. Each prompt uses an `@` file reference paired with a specific refactoring instruction so Copilot CLI knows exactly what to change.
+
+```bash
+copilot
+
+> @samples/book-app-project/book_app.py The command handling uses if/elif chains. Refactor it to use a dictionary dispatch pattern.
+
+> @samples/book-app-project/utils.py Add type hints to all functions
+
+> @samples/book-app-project/book_app.py Extract the book display logic into utils.py for better separation of concerns
+```
+
+> 💡 **¿Nuevo en la refactorización?** Empieza con solicitudes simples como añadir anotaciones de tipo o mejorar nombres de variables antes de abordar transformaciones complejas.
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+### Separar responsabilidades
+
+Referencia múltiples archivos con `@` en un solo prompt para que Copilot CLI pueda mover código entre ellos como parte del refactor.
+
+```bash
+copilot
+
+> @samples/book-app-project/utils.py @samples/book-app-project/book_app.py
+> The utils.py file has print statements mixed with logic. Refactor to separate display functions from data processing.
+```
+
+### Mejorar el manejo de errores
+
+Proporciona dos archivos relacionados y describe la preocupación transversal para que Copilot CLI pueda sugerir una corrección consistente en ambos.
+
+```bash
+copilot
+
+> @samples/book-app-project/utils.py @samples/book-app-project/books.py
+> These files have inconsistent error handling. Suggest a unified approach using custom exceptions.
+```
+
+### Añadir documentación
+
+Usa una lista detallada con viñetas para especificar exactamente qué debe contener cada docstring.
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Add comprehensive docstrings to all methods:
+> - Include parameter types and descriptions
+> - Document return values
+> - Note any exceptions raised
+> - Add usage examples
+```
+
+### Refactorización segura con pruebas
+
+Encadena dos solicitudes relacionadas en una conversación de varios turnos. Primero genera pruebas y luego refactoriza usando esas pruebas como red de seguridad.
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Before refactoring, generate tests for current behavior
+
+# Obtén las pruebas primero
+
+> Now refactor the BookCollection class to use a context manager for file operations
+
+# Refactoriza con confianza: las pruebas verifican que el comportamiento se mantiene
+```
+
+
+
+---
+
+
+
+Flujo 3: Depuración - Rastrear errores, auditorías de seguridad, seguir problemas entre archivos
+
+
+
+### Depuración simple
+
+> **Prueba esto primero:** `@samples/book-app-buggy/books_buggy.py Users report that searching for "The Hobbit" returns no results even though it's in the data. Debug why.`
+
+Empieza describiendo qué está mal. Aquí tienes patrones comunes de depuración que puedes probar con la app de libros con errores. Cada prompt empareja una referencia de archivo `@` con una descripción clara del síntoma para que Copilot CLI pueda localizar y diagnosticar el error.
+
+```bash
+copilot
+
+# Patrón: "Se esperaba X pero se obtuvo Y"
+> @samples/book-app-buggy/books_buggy.py Users report that searching for "The Hobbit" returns no results even though it's in the data. Debug why.
+
+# Patrón: "Comportamiento inesperado"
+> @samples/book-app-buggy/book_app_buggy.py When I remove a book that doesn't exist, the app says it was removed. Help me find why.
+
+# Patrón: "Resultados incorrectos"
+> @samples/book-app-buggy/books_buggy.py When I mark one book as read, ALL books get marked. What's the bug?
+```
+
+> 💡 **Consejo de depuración**: Describe el *síntoma* (lo que ves) y la *expectativa* (lo que debería ocurrir). Copilot CLI se encarga del resto.
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+### El "detective de bugs" - La IA encuentra errores relacionados
+
+Aquí es donde la depuración con contexto destaca. Prueba este escenario con la app de libros con errores. Proporciona el archivo completo vía `@` y describe solo el síntoma reportado por el usuario. Copilot CLI rastreará la causa raíz y puede detectar errores adicionales cercanos.
+
+```bash
+copilot
+
+> @samples/book-app-buggy/books_buggy.py
+>
+> Users report: "Finding books by author name doesn't work for partial names"
+> Debug why this happens
+```
+
+**Lo que hace Copilot CLI**:
+```
+Root Cause: Line 80 uses exact match (==) instead of partial match (in).
+
+Line 80: return [b for b in self.books if b.author == author]
+
+The find_by_author function requires an exact match. Searching for "Tolkien"
+won't find books by "J.R.R. Tolkien".
+
+Fix: Change to case-insensitive partial match:
+return [b for b in self.books if author.lower() in b.author.lower()]
+```
+
+**Por qué importa esto**: Copilot CLI lee todo el archivo, entiende el contexto de tu informe de error y te da una corrección específica con una explicación clara.
+
+> 💡 **Extra**: Debido a que Copilot CLI analiza todo el archivo, a menudo descubre *otros* problemas que no pediste. Por ejemplo, mientras arregla la búsqueda por autor, ¡Copilot CLI podría también notar el error de sensibilidad a mayúsculas en `find_book_by_title`!
+
+### Recuadro de seguridad del mundo real
+
+Aunque depurar tu propio código es importante, entender las vulnerabilidades de seguridad en aplicaciones de producción es crítico. Prueba este ejemplo: apunta Copilot CLI a un archivo desconocido y pídele que audite problemas de seguridad.
+
+```bash
+copilot
+
+> @samples/buggy-code/python/user_service.py Find all security vulnerabilities in this Python user service
+```
+
+Este archivo demuestra patrones de seguridad del mundo real que encontrarás en aplicaciones de producción.
+
+> 💡 **Términos comunes de seguridad que encontrarás:**
+> - **SQL Injection**: Cuando la entrada del usuario se inserta directamente en una consulta a la base de datos, permitiendo que atacantes ejecuten comandos maliciosos
+> - **Consultas parametrizadas**: La alternativa segura: los marcadores de posición (`?`) separan los datos del usuario de los comandos SQL
+> - **Condición de carrera**: Cuando dos operaciones ocurren al mismo tiempo e interfieren entre sí
+> - **XSS (Cross-Site Scripting)**: Cuando atacantes inyectan scripts maliciosos en páginas web
+
+---
+
+### Entender un error
+
+Pega un stack trace directamente en tu prompt junto con una referencia de archivo `@` para que Copilot CLI pueda mapear el error al código fuente.
+
+```bash
+copilot
+
+> I'm getting this error:
+> AttributeError: 'NoneType' object has no attribute 'title'
+> at show_books (book_app.py:19)
+>
+> @samples/book-app-project/book_app.py Explain why and how to fix it
+```
+
+### Depuración con un caso de prueba
+
+Describe la entrada exacta y la salida observada para darle a Copilot CLI un caso de prueba concreto y reproducible sobre el que razonar.
+
+```bash
+copilot
+
+> @samples/book-app-buggy/books_buggy.py The remove_book function has a bug. When I try to remove "Dune",
+> it also removes "Dune Messiah". Debug this: explain the root cause and provide a fix.
+```
+
+### Rastrear un problema a través del código
+
+Referencia múltiples archivos y pide a Copilot CLI que siga el flujo de datos entre ellos para localizar dónde se origina el problema.
+
+```bash
+copilot
+
+> Users report that the book list numbering starts at 0 instead of 1.
+> @samples/book-app-buggy/book_app_buggy.py @samples/book-app-buggy/books_buggy.py
+> Trace through the list display flow and identify where the issue occurs
+```
+
+### Entender problemas de datos
+
+Incluye un archivo de datos junto al código que lo lee para que Copilot CLI entienda el panorama completo al sugerir mejoras en el manejo de errores.
+
+```bash
+copilot
+
+> @samples/book-app-project/data.json @samples/book-app-project/books.py
+> Sometimes the JSON file gets corrupted and the app crashes. How should we handle this gracefully?
+```
+
+
+
+---
+
+
+
+Flujo 4: Generación de pruebas - Generar pruebas exhaustivas y casos límite automáticamente
+
+
+
+> **Prueba esto primero:** `@samples/book-app-project/books.py Generate pytest tests for all functions including edge cases`
+
+### La "Explosión de pruebas" - 2 pruebas vs 15+ pruebas
+
+Manualmente escribiendo pruebas, los desarrolladores típicamente crean 2-3 pruebas básicas:
+- Probar entrada válida
+- Probar entrada inválida
+- Probar un caso límite
+
+Observa lo que pasa cuando le pides a Copilot CLI que genere pruebas exhaustivas. Este prompt usa una lista estructurada con viñetas y una referencia de archivo `@` para guiar a Copilot CLI hacia una cobertura de pruebas completa:
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Generate comprehensive pytest tests. Include tests for:
+> - Adding books
+> - Removing books
+> - Finding by title
+> - Finding by author
+> - Marking as read
+> - Edge cases with empty data
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+**Lo que obtienes**: 15+ pruebas exhaustivas que incluyen:
+
+```python
+class TestBookCollection:
+ # Camino feliz
+ def test_add_book_creates_new_book(self):
+ ...
+ def test_list_books_returns_all_books(self):
+ ...
+
+ # Operaciones de búsqueda
+ def test_find_book_by_title_case_insensitive(self):
+ ...
+ def test_find_book_by_title_returns_none_when_not_found(self):
+ ...
+ def test_find_by_author_partial_match(self):
+ ...
+ def test_find_by_author_case_insensitive(self):
+ ...
+
+ # Casos límite
+ def test_add_book_with_empty_title(self):
+ ...
+ def test_remove_nonexistent_book(self):
+ ...
+ def test_mark_as_read_nonexistent_book(self):
+ ...
+
+ # Persistencia de datos
+ def test_save_books_persists_to_json(self):
+ ...
+ def test_load_books_handles_missing_file(self):
+ ...
+ def test_load_books_handles_corrupted_json(self):
+ ...
+
+ # Caracteres especiales
+ def test_add_book_with_unicode_characters(self):
+ ...
+ def test_find_by_author_with_special_characters(self):
+ ...
+```
+
+**Resultado**: En 30 segundos, obtienes pruebas de casos límite que te tomaría una hora idear y escribir.
+
+---
+
+### Pruebas unitarias
+
+Apunta a una sola función y enumera las categorías de entrada que quieres probar para que Copilot CLI genere pruebas unitarias enfocadas y exhaustivas.
+
+```bash
+copilot
+
+> @samples/book-app-project/utils.py Generate comprehensive pytest tests for get_book_details covering:
+> - Valid input
+> - Empty strings
+> - Invalid year formats
+> - Very long titles
+> - Special characters in author names
+```
+
+### Ejecutar pruebas
+
+Pídele a Copilot CLI una pregunta en inglés sencillo sobre tu cadena de herramientas. Puede generar el comando de shell correcto para ti.
+
+```bash
+copilot
+
+> How do I run the tests? Show me the pytest command.
+
+# Copilot CLI responde:
+# cd samples/book-app-project && python -m pytest tests/
+# O para salida detallada: python -m pytest tests/ -v
+# Para ver las declaraciones print: python -m pytest tests/ -s
+```
+
+### Prueba para escenarios específicos
+
+Enumera escenarios avanzados o complicados que quieras cubrir para que Copilot CLI vaya más allá del camino feliz.
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Generate tests for these scenarios:
+> - Adding duplicate books (same title and author)
+> - Removing a book by partial title match
+> - Finding books when collection is empty
+> - File permission errors during save
+> - Concurrent access to the book collection
+```
+
+### Agregar pruebas a un archivo existente
+
+Solicita pruebas *adicionales* para una sola función para que Copilot CLI genere nuevos casos que complementen los que ya tienes.
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py
+> Generate additional tests for the find_by_author function with edge cases:
+> - Author name with hyphens (e.g., "Jean-Paul Sartre")
+> - Author with multiple first names
+> - Empty string as author
+> - Author name with accented characters
+```
+
+
+
+---
+
+
+
+Flujo de trabajo 5: Integración con Git - Mensajes de commit, descripciones de PR, /pr, /delegate, /diff y /branch
+
+
+
+> 💡 **Este flujo de trabajo asume familiaridad básica con git** (preparar cambios, realizar commits, usar ramas). Si git es nuevo para ti, prueba primero los otros cuatro flujos de trabajo.
+
+### Generar mensajes de commit
+
+> **Prueba esto primero:** `copilot -p "Generate a conventional commit message for: $(git diff --staged)"` — prepara algunos cambios, luego ejecuta esto para ver a Copilot CLI escribir tu mensaje de commit.
+
+Este ejemplo usa la opción de prompt inline `-p` con sustitución de comandos de shell para canalizar la salida de `git diff` directamente a Copilot CLI y obtener un mensaje de commit de una sola ejecución. La sintaxis `$(...)` ejecuta el comando dentro de los paréntesis e inserta su salida en el comando exterior.
+
+```bash
+
+# Ver qué cambió
+git diff --staged
+
+# Generar mensaje de commit usando el formato [Conventional Commit](../GLOSSARY.md#conventional-commit)
+# (mensajes estructurados como "feat(books): add search" o "fix(data): handle empty input")
+copilot -p "Generate a conventional commit message for: $(git diff --staged)"
+
+# Salida: "feat(books): agregar búsqueda parcial por nombre de autor
+#
+# - Actualizar find_by_author para admitir coincidencias parciales
+# - Añadir comparación que no distinga entre mayúsculas y minúsculas
+# - Mejorar la experiencia del usuario al buscar autores"
+```
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demostración varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+### Explicar cambios
+
+Canaliza la salida de `git show` a un prompt con `-p` para obtener un resumen en inglés claro del último commit.
+
+```bash
+# ¿Qué cambió este commit?
+copilot -p "Explain what this commit does: $(git show HEAD --stat)"
+```
+
+### Descripción del PR
+
+Combina la salida de `git log` con una plantilla de prompt estructurada para generar automáticamente una descripción completa del pull request.
+
+```bash
+# Generar la descripción del PR a partir de los cambios en la rama
+copilot -p "Generate a pull request description for these changes:
+$(git log main..HEAD --oneline)
+
+Include:
+- Summary of changes
+- Why these changes were made
+- Testing done
+- Breaking changes? (yes/no)"
+```
+
+### Usar /pr en modo interactivo para la rama actual
+
+Si estás trabajando con una rama en el modo interactivo de Copilot CLI, puedes usar el comando `/pr` para trabajar con pull requests. Usa `/pr` para ver un PR, crear uno nuevo, corregir un PR existente o dejar que Copilot CLI decida automáticamente según el estado de la rama.
+
+```bash
+copilot
+
+> /pr [view|create|fix|auto]
+```
+
+### Revisar antes de hacer push
+
+Usa `git diff main..HEAD` dentro de un prompt con `-p` para una comprobación rápida de coherencia antes del push de todos los cambios de la rama.
+
+```bash
+# Última comprobación antes de hacer push
+copilot -p "Review these changes for issues before I push:
+$(git diff main..HEAD)"
+```
+
+### Usar /delegate para tareas en segundo plano
+
+El comando `/delegate` delega trabajo al agente en la nube de GitHub Copilot. Usa el comando slash `/delegate` (o el atajo `&`) para descargar una tarea bien definida a un agente en segundo plano.
+
+```bash
+copilot
+
+> /delegate Add input validation to the login form
+
+# O usa el atajo de prefijo &:
+> & Fix the typo in the README header
+
+# Copilot CLI:
+# 1. Confirma tus cambios en una nueva rama
+# 2. Abre una solicitud de extracción en borrador
+# 3. Trabaja en segundo plano en GitHub
+# 4. Solicita tu revisión cuando termine
+```
+
+Esto es ideal para tareas bien definidas que quieres que se completen mientras te concentras en otro trabajo.
+
+### Usar /diff para revisar los cambios de la sesión
+
+El comando `/diff` muestra todos los cambios realizados durante tu sesión actual. Usa este comando slash para ver un diff visual de todo lo que Copilot CLI ha modificado antes de que confirmes (commit). También funciona en carpetas que no son repositorios git.
+
+```bash
+copilot
+
+# Después de hacer algunos cambios...
+> /diff
+
+# Muestra una comparación visual de todos los archivos modificados en esta sesión
+# Ideal para revisar antes de confirmar
+```
+
+### Ramificar tu sesión con /branch o /fork
+
+A veces quieres explorar dos enfoques diferentes a un problema sin perder tu conversación original. El comando `/branch` (también disponible como `/fork`) crea una copia de tu sesión actual para que puedas probar una dirección distinta y luego comparar resultados.
+
+```bash
+copilot
+
+> Fix the find_by_author function to support partial matches
+
+# Quieres probar un enfoque diferente — ¡primero crea una rama!
+> /branch
+
+# Ahora estás en una nueva copia de la sesión. Prueba tu enfoque alternativo:
+> Fix find_by_author using a different regex-based strategy
+
+# Si no te gusta el resultado, vuelve a tu sesión original usando /session
+```
+
+> 💡 **`/branch` y `/fork` son lo mismo**: Ambos comandos hacen cosas idénticas. `/branch` se añadió como un nombre más intuitivo. Usa el que tenga más sentido para ti.
+
+> 💡 **Cuándo ramificar**: Ramificar es excelente cuando no estás seguro de qué enfoque es mejor y quieres mantener ambas opciones abiertas.
+
+
+
+---
+
+## Consejo rápido: Investiga antes de planear o codificar
+
+Cuando necesitas investigar una biblioteca, entender buenas prácticas o explorar un tema desconocido, usa `/research` para ejecutar una investigación profunda antes de escribir código:
+
+```bash
+copilot
+
+> /research What are the best Python libraries for validating user input in CLI apps?
+```
+
+Copilot busca en repositorios de GitHub y fuentes web, y luego devuelve un resumen con referencias. Esto es útil cuando estás a punto de empezar una nueva funcionalidad y quieres tomar decisiones informadas primero. Puedes compartir los resultados usando `/share`.
+
+> 💡 **Consejo**: `/research` funciona bien *antes de* `/plan`. Investiga el enfoque, luego planifica la implementación.
+
+---
+
+## Integrándolo todo: Flujo de trabajo para corrección de bugs
+
+Aquí tienes un flujo de trabajo completo para corregir un bug reportado:
+
+```bash
+
+# 1. Entender el informe de error
+copilot
+
+> Users report: 'Finding books by author name doesn't work for partial names'
+> @samples/book-app-project/books.py Analyze and identify the likely cause
+
+# 2. Depurar el problema y corregirlo (continuando en la misma sesión)
+> Based on the analysis, show me the find_by_author function and explain the issue
+
+> Fix the find_by_author function to handle partial name matches
+
+# 3. Generar pruebas para la corrección
+> @samples/book-app-project/books.py Generate pytest tests specifically for:
+> - Full author name match
+> - Partial author name match
+> - Case-insensitive matching
+> - Author name not found
+
+# Salir de la sesión interactiva
+
+> /exit
+
+# 4. Ejecutar git add
+
+# Agregar los cambios al área de preparación para que git diff --staged tenga algo con lo que trabajar
+git add .
+
+# 5. Generar el mensaje de commit
+copilot -p "Generate commit message for: $(git diff --staged)"
+
+# Ejemplo de salida: "fix(books): admitir búsqueda parcial del nombre del autor"
+
+# 6. Confirmar los cambios (opcional)
+
+git commit -m ""
+```
+
+### Resumen del flujo de corrección de bugs
+
+| Paso | Acción | Comando de Copilot |
+|------|--------|--------------------|
+| 1 | Entender el bug | `> [describe bug] @relevant-file.py Analyze the likely cause` |
+| 2 | Análisis y corrección | `> Show me the function and fix the issue` |
+| 3 | Generar pruebas | `> Generate tests for [specific scenarios]` |
+| 4 | Preparar cambios | `git add .` |
+| 5 | Generar mensaje de commit | `copilot -p "Generate a conventional commit message for: $(git diff --staged)"` |
+| 6 | Hacer commit de los cambios| `git commit -m ""` |
+
+---
+
+# Práctica
+
+
+
+Ahora es tu turno para aplicar estos flujos de trabajo.
+
+---
+
+## ▶️ Inténtalo tú mismo
+
+Después de completar las demostraciones, prueba estas variaciones:
+
+1. **Desafío detective de bugs**: Pide a Copilot CLI que depure la función `mark_as_read` en `samples/book-app-buggy/books_buggy.py`. ¿Explicó por qué la función marca TODOS los libros como leídos en lugar de solo uno?
+
+2. **Desafío de pruebas**: Genera pruebas para la función `add_book` en la aplicación de libros. Cuenta cuántos casos límite incluye Copilot CLI que tú no habrías pensado.
+
+3. **Desafío de mensaje de commit**: Haz cualquier pequeño cambio en un archivo de la aplicación de libros, prepáralo (`git add .`), luego ejecuta:
+ ```bash
+ copilot -p "Generate a conventional commit message for: $(git diff --staged)"
+ ```
+ ¿El mensaje es mejor que lo que habrías escrito rápidamente?
+
+**Autoevaluación**: Entiendes los flujos de trabajo de desarrollo cuando puedes explicar por qué "depura este bug" es más poderoso que "encuentra bugs" (¡el contexto importa!).
+
+---
+
+## 📝 Tarea
+
+### Desafío principal: Refactorizar, probar y enviar
+
+Los ejemplos prácticos se centraron en `find_book_by_title` y revisiones de código. Ahora practica las mismas habilidades de flujo de trabajo en funciones diferentes dentro de `book-app-project`:
+
+1. **Revisión**: Pide a Copilot CLI que revise `remove_book()` en `books.py` buscando casos límite y problemas potenciales:
+ `@samples/book-app-project/books.py Review the remove_book() function. What happens if the title partially matches another book (e.g., "Dune" vs "Dune Messiah")? Are there any edge cases not handled?`
+2. **Refactorización**: Pide a Copilot CLI que mejore `remove_book()` para manejar casos límite como coincidencia insensible a mayúsculas/minúsculas y devolver retroalimentación útil cuando no se encuentra un libro
+3. **Prueba**: Genera pruebas pytest específicamente para la función `remove_book()` mejorada, cubriendo:
+ - Eliminar un libro que existe
+ - Coincidencia de título sin distinguir mayúsculas/minúsculas
+ - Un libro que no existe devuelve una respuesta apropiada
+ - Eliminar desde una colección vacía
+4. **Revisión**: Prepara tus cambios y ejecuta `/review` para comprobar si quedan problemas
+5. **Commit**: Genera un mensaje de commit convencional:
+ `copilot -p "Generate a conventional commit message for: $(git diff --staged)"`
+
+
+💡 Pistas (haz clic para expandir)
+
+**Prompts de ejemplo para cada paso:**
+
+```bash
+copilot
+
+# Paso 1: Revisar
+> @samples/book-app-project/books.py Review the remove_book() function. What edge cases are not handled?
+
+# Paso 2: Refactorizar
+> Improve remove_book() to use case-insensitive matching and return a clear message when the book isn't found. Show me the before and after code.
+
+# Paso 3: Probar
+> Generate pytest tests for the improved remove_book() function, including:
+> - Removing a book that exists
+> - Case-insensitive matching ("dune" should remove "Dune")
+> - Book not found returns appropriate response
+> - Removing from an empty collection
+
+# Paso 4: Revisar
+> /review
+
+# Paso 5: Confirmar
+> Generate a conventional commit message for this refactor
+```
+
+**Consejo:** Después de mejorar `remove_book()`, prueba a preguntar a Copilot CLI: "¿Hay otras funciones en este archivo que podrían beneficiarse de las mismas mejoras?". Puede sugerir cambios similares en `find_book_by_title()` o `find_by_author()`.
+
+
+
+### Desafío extra: Crea una aplicación con Copilot CLI
+
+> 💡 **Nota**: Este ejercicio de GitHub Skills usa **Node.js** en lugar de Python. Las técnicas de GitHub Copilot CLI que practicarás - crear issues, generar código y colaborar desde la terminal - se aplican a cualquier lenguaje.
+
+El ejercicio muestra a los desarrolladores cómo usar GitHub Copilot CLI para crear issues, generar código y colaborar desde la terminal mientras construyen una calculadora en Node.js. Instalarás la CLI, usarás plantillas y agentes, y practicarás desarrollo iterativo desde la línea de comandos.
+
+##### [Inicia el ejercicio "Crear aplicaciones con Copilot CLI"](https://github.com/skills/create-applications-with-the-copilot-cli)
+
+---
+
+
+🔧 Errores comunes y solución de problemas (haz clic para expandir)
+
+### Errores comunes
+
+| Error | Qué sucede | Solución |
+|-------|-----------:|---------|
+| Usar prompts vagos como "Review this code" | Retroalimentación genérica que omite problemas específicos | Sé específico: "Review for SQL injection, XSS, and auth issues" |
+| No usar `/review` para revisiones de código | Falta el agente de revisión de código optimizado | Usa `/review` que está afinado para salida de alta señal y bajo ruido |
+| Pedir "find bugs" sin contexto | Copilot CLI no sabe qué bug estás experimentando | Describe el síntoma: "Users report X happens when Y" |
+| Generar pruebas sin especificar el framework | Las pruebas pueden usar sintaxis o librería de aserciones incorrectas | Especifica: "Generate tests using Jest" o "using pytest" |
+
+### Solución de problemas
+
+**La revisión parece incompleta** - Sé más específico sobre qué buscar:
+
+```bash
+copilot
+
+# En lugar de:
+> Review @samples/book-app-project/book_app.py
+
+# Prueba:
+> Review @samples/book-app-project/book_app.py for input validation, error handling, and edge cases
+```
+
+**Las pruebas no coinciden con mi framework** - Especifica el framework:
+
+```bash
+copilot
+
+> @samples/book-app-project/books.py Generate tests using pytest (not unittest)
+```
+
+**La refactorización cambia el comportamiento** - Pide a Copilot CLI que preserve el comportamiento:
+
+```bash
+copilot
+
+> @samples/book-app-project/book_app.py Refactor command handling to use dictionary dispatch. IMPORTANT: Maintain identical external behavior - no breaking changes
+```
+
+
+
+---
+
+# Resumen
+
+## 🔑 Conclusiones clave
+
+
+
+1. **La revisión de código** se vuelve más exhaustiva con prompts específicos
+2. **La refactorización** es más segura cuando primero generas pruebas
+3. **La depuración** se beneficia de mostrar a Copilot CLI el error Y el código
+4. **La generación de pruebas** debe incluir casos límite y escenarios de error
+5. **La integración con Git** automatiza mensajes de commit y descripciones de PR
+
+> 📋 **Referencia rápida**: Consulta la [referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para una lista completa de comandos y atajos.
+
+---
+
+## ✅ Punto de control: Has dominado lo esencial
+
+**¡Felicidades!** Ahora tienes todas las habilidades principales para ser productivo con GitHub Copilot CLI:
+
+| Habilidad | Capítulo | Ahora puedes... |
+|----------:|---------:|-----------------|
+| Comandos básicos | Ch 01 | Usar modo interactivo, modo plan, modo programático (-p) y comandos slash |
+| Contexto | Ch 02 | Referenciar archivos con `@`, gestionar sesiones, entender ventanas de contexto |
+| Flujos de trabajo | Ch 03 | Revisar código, refactorizar, depurar, generar pruebas, integrar con git |
+
+Los capítulos 04-06 cubren características adicionales que agregan aún más potencia y valen la pena aprender.
+
+---
+
+## 🛠️ Construyendo tu flujo de trabajo personal
+
+No existe una única manera "correcta" de usar GitHub Copilot CLI. Aquí tienes algunos consejos mientras desarrollas tus propios patrones:
+
+> 📚 **Documentación oficial**: [Buenas prácticas de Copilot CLI](https://docs.github.com/copilot/how-tos/copilot-cli/cli-best-practices) para flujos de trabajo recomendados y consejos de GitHub.
+
+- **Comienza con `/plan`** para cualquier cosa no trivial. Refina el plan antes de ejecutar: un buen plan conduce a mejores resultados.
+- **Guarda prompts que funcionen bien.** Cuando Copilot CLI cometa un error, anota qué salió mal. Con el tiempo, esto se convierte en tu manual personal.
+- **Experimenta libremente.** Algunos desarrolladores prefieren prompts largos y detallados. Otros prefieren prompts cortos con seguimientos. Prueba distintos enfoques y nota lo que se siente natural.
+
+> 💡 **Próximo:** En los capítulos 04 y 05 aprenderás cómo codificar tus mejores prácticas en instrucciones personalizadas y habilidades que Copilot CLI cargará automáticamente.
+
+---
+
+## ➡️ Qué sigue
+
+Los capítulos restantes cubren características adicionales que amplían las capacidades de Copilot CLI:
+
+| Capítulo | Qué cubre | Cuándo lo querrás |
+|---------:|----------|-------------------|
+| Ch 04: Agents | Crear personas AI especializadas | Cuando quieras expertos de dominio (frontend, seguridad) |
+| Ch 05: Skills | Cargar instrucciones automáticamente para tareas | Cuando repitas los mismos prompts con frecuencia |
+| Cap. 06: MCP | Conectar servicios externos | Cuando necesites datos en vivo de GitHub, bases de datos |
+
+**Recomendación**: Prueba los flujos de trabajo principales durante una semana, luego vuelve a los Capítulos 04-06 cuando tengas necesidades específicas.
+
+---
+
+## Continuar con temas adicionales
+
+En **[Capítulo 04: Agentes e Instrucciones Personalizadas](../04-agents-custom-instructions/README.md)**, aprenderás:
+
+- Uso de agentes integrados (`/plan`, `/review`)
+- Creación de agentes especializados (experto en frontend, auditor de seguridad) con archivos `.agent.md`
+- Patrones de colaboración multiagente
+- Archivos de instrucciones personalizadas para estándares del proyecto
+
+---
+
+**[← Volver al Capítulo 02](../02-context-conversations/README.md)** | **[Continuar al Capítulo 04 →](../04-agents-custom-instructions/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/04-agents-custom-instructions/README.md b/translations/es/04-agents-custom-instructions/README.md
new file mode 100644
index 00000000..b4196a25
--- /dev/null
+++ b/translations/es/04-agents-custom-instructions/README.md
@@ -0,0 +1,829 @@
+
+
+
+
+> **¿Y si pudieras contratar a un revisor de código Python, un experto en pruebas y un revisor de seguridad... todo en una única herramienta?**
+
+En el Capítulo 03, dominaste los flujos de trabajo esenciales: revisión de código, refactorización, depuración, generación de pruebas e integración con git. Esos te hacen muy productivo con GitHub Copilot CLI. Ahora, vamos más allá.
+
+Hasta ahora, has estado usando Copilot CLI como un asistente de propósito general. Los agentes te permiten darle una persona específica con estándares incorporados, como un revisor de código que aplica anotaciones de tipo y PEP 8, o un ayudante de pruebas que escribe casos con pytest. Verás cómo el mismo prompt obtiene resultados notablemente mejores cuando lo maneja un agente con instrucciones dirigidas.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, serás capaz de:
+
+- Usar agentes integrados: Plan (`/plan`), Code-review (`/review`), y entender agentes automáticos (Explore, Task)
+- Crear agentes especializados usando archivos de agente (`.agent.md`)
+- Usar agentes para tareas específicas de dominio
+- Cambiar entre agentes usando `/agent` y `--agent`
+- Escribir archivos de instrucciones personalizadas para estándares específicos del proyecto
+
+> ⏱️ **Tiempo estimado**: ~55 minutos (20 min lectura + 35 min práctica)
+
+---
+
+## 🧩 Analogía del mundo real: Contratación de especialistas
+
+Cuando necesitas ayuda con tu casa, no llamas a un "ayudante general". Llamas a especialistas:
+
+| Problema | Especialista | Por qué |
+|---------|------------|-----|
+| Tubería con fugas | Fontanero | Conoce los códigos de fontanería, tiene herramientas especializadas |
+| Re-cableado | Electricista | Entiende los requisitos de seguridad, cumple con la normativa |
+| Tejado nuevo | Techador | Conoce los materiales y las consideraciones meteorológicas locales |
+
+Los agentes funcionan de la misma manera. En lugar de una IA genérica, usa agentes que se centran en tareas específicas y conocen el proceso correcto a seguir. Configura las instrucciones una vez y reutilízalas cada vez que necesites esa especialidad: revisión de código, pruebas, seguridad, documentación.
+
+
+
+---
+
+# Usando agentes
+
+Comienza a usar agentes integrados y personalizados de inmediato.
+
+---
+
+## *¿Nuevo en agentes?* ¡Comienza aquí!
+¿Nunca has usado ni creado un agente? Esto es todo lo que necesitas saber para empezar en este curso.
+
+1. **Prueba un agente *integrado* ahora mismo:**
+ ```bash
+ copilot
+ > /plan Add input validation for book year in the book app
+ ```
+ Esto invoca al agente Plan para crear un plan de implementación paso a paso.
+
+2. **Ve uno de nuestros ejemplos de agentes personalizados:** Es simple definir las instrucciones de un agente; mira nuestro archivo proporcionado [python-reviewer.agent.md](../../../.github/agents/python-reviewer.agent.md) para ver el patrón.
+
+3. **Entiende el concepto central:** Los agentes son como consultar a un especialista en lugar de a un generalista. Un "frontend agent" se centrará automáticamente en la accesibilidad y en patrones de componentes; no tienes que recordárselo porque ya está especificado en las instrucciones del agente.
+
+
+## Agentes integrados
+
+**¡Ya has usado algunos agentes integrados en el Capítulo 03 Development Workflow!**
+ `/plan` y `/review` son en realidad agentes integrados. Ahora sabes qué sucede tras bambalinas. Aquí está la lista completa:
+
+| Agente | Cómo invocar | Qué hace |
+|-------|---------------|--------------|
+| **Plan** | `/plan` or `Shift+Tab` (cycle modes) | Crea planes de implementación paso a paso antes de codificar |
+| **Code-review** | `/review` | Revisa cambios staged/unstaged con retroalimentación enfocada y accionable |
+| **Init** | `/init` | Genera archivos de configuración del proyecto (instrucciones, agentes) |
+| **Explore** | *Automatic* | Usado internamente cuando le pides a Copilot que explore o analice la base de código |
+| **Task** | *Automatic* | Ejecuta comandos como pruebas, compilaciones, lints e instalaciones de dependencias |
+
+
+
+**Agentes integrados en acción** - Ejemplos de invocación de Plan, Code-review, Explore y Task
+
+```bash
+copilot
+
+# Invoca el agente Plan para crear un plan de implementación
+> /plan Add input validation for book year in the book app
+
+# Invoca el agente de revisión de código sobre tus cambios
+> /review
+
+# Los agentes Explore y Task se invocan automáticamente cuando sea relevante:
+> Run the test suite # Usa el agente Task
+
+> Explore how book data is loaded # Usa el agente Explore
+```
+
+¿Qué pasa con el Task Agent? Funciona detrás de escena para gestionar y rastrear lo que está ocurriendo y para informar de vuelta en un formato claro y ordenado:
+
+| Resultado | Lo que ves |
+|---------|--------------|
+| ✅ **Éxito** | Resumen breve (p. ej., "All 247 tests passed", "Build succeeded") |
+| ❌ **Fallo** | Salida completa con stack traces, errores de compilador y registros detallados |
+
+
+> 📚 **Documentación oficial**: [Agentes de GitHub Copilot CLI](https://docs.github.com/copilot/how-tos/use-copilot-agents/use-copilot-cli#use-custom-agents)
+
+---
+
+# Añadir agentes a Copilot CLI
+
+¡Puedes definir tus propios agentes para formar parte de tu flujo de trabajo! Define una vez, ¡luego dirígelos!
+
+
+
+## 🗂️ Añade tus agentes
+
+Los archivos de agente son archivos markdown con la extensión `.agent.md`. Tienen dos partes: frontmatter YAML (metadatos) e instrucciones en markdown.
+
+> 💡 **¿Nuevo en frontmatter YAML?** Es un pequeño bloque de ajustes en la parte superior del archivo, rodeado por marcadores `---`. YAML son solo pares `clave: valor`. El resto del archivo es markdown normal.
+
+Aquí hay un agente mínimo:
+
+```markdown
+---
+name: my-reviewer
+description: Code reviewer focused on bugs and security issues
+---
+
+# Code Reviewer
+
+You are a code reviewer focused on finding bugs and security issues.
+
+When reviewing code, always check for:
+- SQL injection vulnerabilities
+- Missing error handling
+- Hardcoded secrets
+```
+
+> 💡 **Requerido vs Opcional**: El campo `description` es obligatorio. Otros campos como `name`, `tools`, y `model` son opcionales.
+
+## Dónde colocar archivos de agentes
+
+| Ubicación | Alcance | Mejor para |
+|----------|-------|----------|
+| `.github/agents/` | Específico del proyecto | Agentes compartidos por el equipo con convenciones del proyecto |
+| `~/.copilot/agents/` | Global (todos los proyectos) | Agentes personales que usas en todas partes |
+
+**Este proyecto incluye archivos de agente de ejemplo en la carpeta [.github/agents/](../../../.github/agents)**. Puedes escribir los tuyos propios o personalizar los que ya se proporcionan.
+
+
+📂 Ver los agentes de ejemplo en este curso
+
+| Archivo | Descripción |
+|------|-------------|
+| `hello-world.agent.md` | Ejemplo mínimo - comienza aquí |
+| `python-reviewer.agent.md` | Revisor de calidad de código Python |
+| `pytest-helper.agent.md` | Especialista en pruebas con Pytest |
+
+```bash
+# O copia uno en tu carpeta de agentes personales (disponible en cada proyecto)
+cp .github/agents/python-reviewer.agent.md ~/.copilot/agents/
+```
+
+Para más agentes de la comunidad, consulta [github/awesome-copilot](https://github.com/github/awesome-copilot)
+
+
+
+
+## 🚀 Dos formas de usar agentes personalizados
+
+### Modo interactivo
+Dentro del modo interactivo, lista agentes usando `/agent` y selecciona el agente con el que empezar a trabajar.
+Selecciona un agente para continuar la conversación con él.
+
+```bash
+copilot
+> /agent
+```
+
+Para cambiar a un agente diferente, o volver al modo predeterminado, usa el comando `/agent` de nuevo.
+
+### Modo programático
+
+Inicia directamente una nueva sesión con un agente.
+
+```bash
+copilot --agent python-reviewer
+> Review @samples/book-app-project/books.py
+```
+
+> 💡 **Cambiar de agente**: Puedes cambiar a un agente diferente en cualquier momento usando `/agent` o `--agent` de nuevo. Para volver a la experiencia estándar de Copilot CLI, usa `/agent` y selecciona **no agent**.
+
+> 💡 **El modo agente es por sesión**: El agente que selecciones se aplica solo a la sesión actual. Cuando inicias una nueva sesión con `/new`, `/clear`, o al abrir un terminal nuevo, Copilot vuelve a su modo predeterminado: la selección de agente no se mantiene automáticamente. Esto significa que cada sesión comienza con una pizarra limpia, lo cual es una buena práctica para mantener tu trabajo enfocado.
+
+---
+
+# Profundizando con los agentes
+
+
+
+> 💡 **Esta sección es opcional.** Los agentes integrados (`/plan`, `/review`) son lo suficientemente potentes para la mayoría de los flujos de trabajo. Crea agentes personalizados cuando necesites experiencia especializada que se aplique de forma consistente en tu trabajo.
+
+Cada tema a continuación es autónomo. **Elige lo que te interese - no necesitas leerlos todos de una vez.**
+
+| Quiero... | Ir a |
+|---|---|
+| Ver por qué los agentes superan a los prompts genéricos | [Especialista vs Genérico](#especialista-vs-genérico-ve-la-diferencia) |
+| Combinar agentes en una función | [Trabajar con múltiples agentes](#trabajando-con-múltiples-agentes) |
+| Organizar, nombrar y compartir agentes | [Organizar y compartir agentes](#organizar-y-compartir-agentes) |
+| Configurar contexto siempre activo para el proyecto | [Configurar tu proyecto para Copilot](#configuración-de-tu-proyecto-para-copilot) |
+| Consultar propiedades YAML y herramientas | [Referencia de archivos de agente](#referencia-de-archivos-de-agente) |
+
+Selecciona un escenario a continuación para expandirlo.
+
+---
+
+
+
+Especialista vs Genérico: Ve la diferencia - Por qué los agentes producen mejores resultados que los prompts genéricos
+
+## Especialista vs Genérico: Ve la diferencia
+
+Aquí es donde los agentes demuestran su valor. Observa la diferencia:
+
+### Sin un agente (Copilot genérico)
+
+```bash
+copilot
+
+> Add a function to search books by year range in the book app
+```
+
+**Salida genérica**:
+```python
+def search_by_year_range(books, start_year, end_year):
+ results = []
+ for book in books:
+ if book['year'] >= start_year and book['year'] <= end_year:
+ results.append(book)
+ return results
+```
+
+Básico. Funciona. Pero le faltan muchas cosas.
+
+---
+
+### Con el agente python-reviewer
+
+```bash
+copilot
+
+> /agent
+# Seleccione "python-reviewer"
+
+> Add a function to search books by year range in the book app
+```
+
+**Salida del especialista**:
+```python
+from typing import List, Dict, Any
+
+def search_by_year_range(
+ books: List[Dict[str, Any]],
+ start_year: int,
+ end_year: int
+) -> List[Dict[str, Any]]:
+ """
+ Search for books within a specified year range.
+
+ Args:
+ books: List of book dictionaries
+ start_year: Starting year (inclusive)
+ end_year: Ending year (inclusive)
+
+ Returns:
+ List of books published within the year range
+
+ Raises:
+ ValueError: If start_year is greater than end_year
+ TypeError: If year values are not integers
+ """
+ if not isinstance(start_year, int) or not isinstance(end_year, int):
+ raise TypeError("Year values must be integers")
+
+ if start_year > end_year:
+ raise ValueError(f"Start year ({start_year}) cannot be greater than end year ({end_year})")
+
+ return [
+ book for book in books
+ if isinstance(book.get('year'), int)
+ and start_year <= book['year'] <= end_year
+ ]
+```
+
+**Lo que el agente python-reviewer incluye automáticamente**:
+- ✅ Anotaciones de tipo en todos los parámetros y valores de retorno
+- ✅ Docstring completo con Args/Returns/Raises
+- ✅ Validación de entradas con manejo adecuado de errores
+- ✅ Comprensión de listas para mejor rendimiento
+- ✅ Manejo de casos límite (valores de año faltantes/inválidos)
+- ✅ Formato conforme a PEP 8
+- ✅ Prácticas de programación defensiva
+
+**La diferencia**: Mismo prompt, salida dramáticamente mejor. El agente aporta experiencia que olvidarías pedir.
+
+
+
+---
+
+
+
+Trabajando con múltiples agentes - Combina especialistas, cambia a mitad de sesión, agente-como-herramientas
+
+## Trabajando con múltiples agentes
+
+El verdadero poder llega cuando los especialistas trabajan juntos en una funcionalidad.
+
+### Ejemplo: Construyendo una funcionalidad simple
+
+```bash
+copilot
+
+> I want to add a "search by year range" feature to the book app
+
+# Usa python-reviewer para el diseño
+> /agent
+# Selecciona "python-reviewer"
+
+> @samples/book-app-project/books.py Design a find_by_year_range method. What's the best approach?
+
+# Cambia a pytest-helper para el diseño de pruebas
+> /agent
+# Selecciona "pytest-helper"
+
+> @samples/book-app-project/tests/test_books.py Design test cases for a find_by_year_range method.
+> What edge cases should we cover?
+
+# Sintetiza ambos diseños
+> Create an implementation plan that includes the method implementation and comprehensive tests.
+```
+
+**La idea clave**: Tú eres el arquitecto que dirige a los especialistas. Ellos se encargan de los detalles, tú te encargas de la visión.
+
+
+🎬 ¡Véalo en acción!
+
+
+
+*La salida de la demo varía: tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+### Agente como herramienta
+
+Cuando los agentes están configurados, Copilot también puede llamarlos como herramientas durante tareas complejas. Si pides una funcionalidad full-stack, Copilot puede delegar automáticamente partes a los agentes especialistas correspondientes.
+
+
+
+---
+
+
+
+Organizar y compartir agentes - Nombres, ubicación de archivos, archivos de instrucciones y compartir en equipo
+
+## Organizar y compartir agentes
+
+### Nombrar a tus agentes
+
+Cuando creas archivos de agente, el nombre importa. Es lo que escribirás después de `/agent` o `--agent`, y lo que verán tus compañeros en la lista de agentes.
+
+| ✅ Buenos nombres | ❌ Evitar |
+|--------------|----------|
+| `frontend` | `my-agent` |
+| `backend-api` | `agent1` |
+| `security-reviewer` | `helper` |
+| `react-specialist` | `code` |
+| `python-backend` | `assistant` |
+
+**Convenciones de nombres:**
+- Usa minúsculas con guiones: `my-agent-name.agent.md`
+- Incluye el dominio: `frontend`, `backend`, `devops`, `security`
+- Sé específico cuando sea necesario: `react-typescript` vs solo `frontend`
+
+---
+
+### Compartir con tu equipo
+
+Coloca archivos de agente en `.github/agents/` y estarán bajo control de versiones. Haz push a tu repo y todos los miembros del equipo los obtendrán automáticamente. Pero los agentes son solo un tipo de archivo que Copilot lee de tu proyecto. También admite **archivos de instrucciones** que se aplican automáticamente a cada sesión, sin que nadie tenga que ejecutar `/agent`.
+
+Piénsalo de esta manera: los agentes son especialistas a los que llamas, y los archivos de instrucciones son reglas del equipo que están siempre activas.
+
+### Dónde colocar tus archivos
+
+Ya conoces las dos ubicaciones principales (ver [Dónde colocar archivos de agente](#dónde-colocar-archivos-de-agentes) arriba). Usa este árbol de decisiones para elegir:
+
+
+**Comienza simple:** Crea un único `*.agent.md` archivo en la carpeta de tu proyecto. Muévelo a una ubicación permanente una vez que estés satisfecho.
+
+Más allá de los archivos de agente, Copilot también lee automáticamente los **archivos de instrucciones a nivel de proyecto**, no se necesita `/agent`. Consulta [Configuración de tu proyecto para Copilot](#configuración-de-tu-proyecto-para-copilot) abajo para `AGENTS.md`, `.instructions.md`, y `/init`
+
+
+
+---
+
+
+
+Configuración de tu proyecto para Copilot - AGENTS.md, archivos de instrucciones, y configuración /init
+
+## Configuración de tu proyecto para Copilot
+
+Los agentes son especialistas que invocas bajo demanda. Los **archivos de configuración del proyecto** son diferentes: Copilot los lee automáticamente en cada sesión para entender las convenciones, la pila tecnológica y las reglas de tu proyecto. Nadie necesita ejecutar `/agent`; el contexto está siempre activo para todas las personas que trabajan en el repositorio.
+
+### Configuración rápida con /init
+
+La forma más rápida para comenzar es dejar que Copilot genere archivos de configuración por ti:
+
+```bash
+copilot
+> /init
+```
+
+Copilot escaneará tu proyecto y creará archivos de instrucciones personalizados. Puedes editarlos después.
+
+### Formatos de archivos de instrucciones
+
+| Archivo | Ámbito | Notas |
+|------|-------|-------|
+| `AGENTS.md` | Raíz del proyecto o anidado | **Estándar multiplataforma** - funciona con Copilot y otros asistentes de IA |
+| `.github/copilot-instructions.md` | Proyecto | Específico de GitHub Copilot |
+| `.github/instructions/*.instructions.md` | Proyecto | Instrucciones granulares y específicas por tema |
+| `~/.copilot/instructions/**/*.instructions.md` | Usuario (todos los proyectos) | Instrucciones personales que se aplican en todas partes, en todos tus repositorios |
+| `CLAUDE.md`, `GEMINI.md` | Raíz del proyecto | Admitidos por compatibilidad |
+
+> 🎯 **¿Apenas empezando?** Usa `AGENTS.md` para las instrucciones del proyecto. Puedes explorar los otros formatos más adelante según sea necesario.
+
+### AGENTS.md
+
+`AGENTS.md` es el formato recomendado. Es un [estándar abierto](https://agents.md/) que funciona con Copilot y otras herramientas de codificación con IA. Colócalo en la raíz de tu repositorio y Copilot lo lee automáticamente. El propio [AGENTS.md](../AGENTS.md) de este proyecto es un ejemplo en funcionamiento.
+
+Un `AGENTS.md` típico describe el contexto del proyecto, el estilo de código, los requisitos de seguridad y los estándares de pruebas. Escribe el tuyo siguiendo el patrón en nuestro archivo de ejemplo.
+
+### Archivos de instrucciones personalizados (.instructions.md)
+
+Para equipos que quieren más control granular, divide las instrucciones en archivos específicos por tema. Cada archivo cubre una preocupación y se aplica automáticamente:
+
+```
+.github/
+└── instructions/
+ ├── python-standards.instructions.md
+ ├── security-checklist.instructions.md
+ └── api-design.instructions.md
+```
+
+> 💡 **Nota**: Los archivos de instrucciones funcionan con cualquier lenguaje. Este ejemplo usa Python para coincidir con el proyecto del curso, pero puedes crear archivos similares para TypeScript, Go, Rust, o cualquier tecnología que use tu equipo.
+
+#### Delimitar el ámbito de las instrucciones con `applyTo`
+
+Por defecto, un archivo de instrucciones se aplica a cada conversación. Para limitarlo a tipos de archivo específicos, añade un campo `applyTo` en el frontmatter YAML (el bloque entre marcadores `---` en la parte superior del archivo):
+
+```markdown
+---
+applyTo: "**/*.py"
+---
+# Python Standards
+Always follow PEP 8 style conventions.
+Use type hints in all function signatures.
+```
+
+Con `applyTo: "**/*.py"`, Copilot solo carga ese archivo de instrucciones cuando estás trabajando con archivos Python. Las instrucciones para el estilo de Python nunca ensucian una conversación sobre, por ejemplo, un Dockerfile o una consulta SQL.
+
+Aquí hay algunos patrones comunes:
+
+| `applyTo` value | When it applies |
+|---|---|
+| `"**/*.py"` | Cualquier archivo Python |
+| `"**/*.{ts,tsx}"` | Archivos TypeScript y TSX |
+| `"tests/**"` | Cualquier archivo dentro de una carpeta `tests/` |
+| (no frontmatter) | Cada conversación — por defecto |
+
+> 💡 **Consejo**: Rodea el patrón glob con comillas (ej., `"**/*.py"`) para asegurar que se interprete correctamente en todos los sistemas operativos y shells.
+
+**Encontrar archivos de instrucciones de la comunidad**: Explora [github/awesome-copilot](https://github.com/github/awesome-copilot) para archivos de instrucciones prefabricados que cubren .NET, Angular, Azure, Python, Docker y muchas más tecnologías.
+
+### Desactivar instrucciones personalizadas
+
+Si necesitas que Copilot ignore todas las configuraciones específicas del proyecto (útil para depuración o para comparar comportamientos):
+
+```bash
+copilot --no-custom-instructions
+```
+
+
+
+---
+
+
+
+Referencia de archivos de agente - propiedades YAML, alias de herramientas y ejemplos completos
+
+## Referencia de archivos de agente
+
+### Un ejemplo más completo
+
+Has visto el [formato mínimo de agente](#-add-your-agents) arriba. Aquí hay un agente más completo que usa la propiedad `tools`. Crea `~/.copilot/agents/python-reviewer.agent.md`:
+
+```markdown
+---
+name: python-reviewer
+description: Python code quality specialist for reviewing Python projects
+tools: ["read", "edit", "search", "execute"]
+---
+
+# Python Code Reviewer
+
+You are a Python specialist focused on code quality and best practices.
+
+**Your focus areas:**
+- Code quality (PEP 8, type hints, docstrings)
+- Performance optimization (list comprehensions, generators)
+- Error handling (proper exception handling)
+- Maintainability (DRY principles, clear naming)
+
+**Code style requirements:**
+- Use Python 3.10+ features (dataclasses, type hints, pattern matching)
+- Follow PEP 8 naming conventions
+- Use context managers for file I/O
+- All functions must have type hints and docstrings
+
+**When reviewing code, always check:**
+- Missing type hints on function signatures
+- Mutable default arguments
+- Proper error handling (no bare except)
+- Input validation completeness
+```
+
+### Propiedades YAML
+
+| Propiedad | Requerido | Descripción |
+|----------|----------|-------------|
+| `name` | No | Nombre para mostrar (por defecto: el nombre de archivo) |
+| `description` | **Sí** | Lo que hace el agente: ayuda a Copilot a entender cuándo sugerirlo |
+| `tools` | No | Lista de herramientas permitidas (omitir = todas las herramientas disponibles). Ver alias de herramientas abajo. |
+| `target` | No | Limitar a `vscode` o solo `github-copilot` |
+
+### Alias de herramientas
+
+Usa estos nombres en la lista `tools`:
+- `read` - Leer el contenido de archivos
+- `edit` - Editar archivos
+- `search` - Buscar archivos (grep/glob)
+- `execute` - Ejecutar comandos de shell (también: `shell`, `Bash`)
+- `agent` - Invocar otros agentes personalizados
+
+> 📖 **Documentación oficial**: [Custom agents configuration](https://docs.github.com/copilot/reference/custom-agents-configuration)
+>
+> ⚠️ **Solo VS Code**: La propiedad `model` (para seleccionar modelos de IA) funciona en VS Code pero no es compatible con GitHub Copilot CLI. Puedes incluirla con seguridad para archivos de agentes multiplataforma. GitHub Copilot CLI la ignorará.
+
+### Más plantillas de agentes
+
+> 💡 **Nota para principiantes**: Los ejemplos a continuación son plantillas. **Reemplaza las tecnologías específicas por las que use tu proyecto.** Lo importante es la *estructura* del agente, no las tecnologías específicas mencionadas.
+
+This project includes working examples in the [.github/agents/](../../../.github/agents) folder:
+- [hello-world.agent.md](../../../.github/agents/hello-world.agent.md) - Minimal example, start here
+- [python-reviewer.agent.md](../../../.github/agents/python-reviewer.agent.md) - Python code quality reviewer
+- [pytest-helper.agent.md](../../../.github/agents/pytest-helper.agent.md) - Pytest testing specialist
+
+For community agents, see [github/awesome-copilot](https://github.com/github/awesome-copilot).
+
+
+
+---
+
+# Practice
+
+
+
+Crea tus propios agentes y pruébalos en acción.
+
+---
+
+## ▶️ Pruébalo tú mismo
+
+```bash
+
+# Crear el directorio agents (si no existe)
+mkdir -p .github/agents
+
+# Crear un agente revisor de código
+cat > .github/agents/reviewer.agent.md << 'EOF'
+---
+name: reviewer
+description: Senior code reviewer focused on security and best practices
+---
+
+# Agente revisor de código
+
+You are a senior code reviewer focused on code quality.
+
+**Review priorities:**
+1. Security vulnerabilities
+2. Performance issues
+3. Maintainability concerns
+4. Best practice violations
+
+**Output format:**
+Provide issues as a numbered list with severity tags:
+[CRITICAL], [HIGH], [MEDIUM], [LOW]
+EOF
+
+# Crear un agente de documentación
+cat > .github/agents/documentor.agent.md << 'EOF'
+---
+name: documentor
+description: Technical writer for clear and complete documentation
+---
+
+# Agente de documentación
+
+You are a technical writer who creates clear documentation.
+
+**Documentation standards:**
+- Start with a one-sentence summary
+- Include usage examples
+- Document parameters and return values
+- Note any gotchas or limitations
+EOF
+
+# Ahora úsalos
+copilot --agent reviewer
+> Review @samples/book-app-project/books.py
+
+# O cambia de agente
+copilot
+> /agent
+# Selecciona "documentor"
+> Document @samples/book-app-project/books.py
+```
+
+---
+
+## 📝 Tarea
+
+### Desafío principal: Construye un equipo de agentes especializados
+
+El ejemplo práctico creó los agentes `reviewer` y `documentor`. Ahora practica creando y usando agentes para una tarea diferente: mejorar la validación de datos en la aplicación de libros:
+
+1. Crea 3 archivos de agente (`.agent.md`) adaptados a la aplicación de libros, uno por agente, colocados en `.github/agents/`
+2. Tus agentes:
+ - **data-validator**: comprueba `data.json` en busca de datos faltantes o malformados (autores vacíos, year=0, campos faltantes)
+ - **error-handler**: revisa el código Python en busca de manejo de errores inconsistente y sugiere un enfoque unificado
+ - **doc-writer**: genera o actualiza docstrings y contenido del README
+3. Usa cada agente en la aplicación de libros:
+ - `data-validator` → auditar `@samples/book-app-project/data.json`
+ - `error-handler` → revisar `@samples/book-app-project/books.py` y `@samples/book-app-project/utils.py`
+ - `doc-writer` → añadir docstrings a `@samples/book-app-project/books.py`
+4. Colaborar: usa `error-handler` para identificar lagunas en el manejo de errores, luego `doc-writer` para documentar el enfoque mejorado
+
+**Criterios de éxito**: Tienes 3 agentes funcionando que producen salida consistente y de alta calidad y puedes cambiar entre ellos con `/agent`.
+
+
+💡 Sugerencias (hacer clic para expandir)
+
+**Plantillas iniciales**: crea un archivo por agente en `.github/agents/`:
+
+`data-validator.agent.md`:
+```markdown
+---
+description: Analyzes JSON data files for missing or malformed entries
+---
+
+You analyze JSON data files for missing or malformed entries.
+
+**Focus areas:**
+- Empty or missing author fields
+- Invalid years (year=0, future years, negative years)
+- Missing required fields (title, author, year, read)
+- Duplicate entries
+```
+
+`error-handler.agent.md`:
+```markdown
+---
+description: Reviews Python code for error handling consistency
+---
+
+You review Python code for error handling consistency.
+
+**Standards:**
+- No bare except clauses
+- Use custom exceptions where appropriate
+- All file operations use context managers
+- Consistent return types for success/failure
+```
+
+`doc-writer.agent.md`:
+```markdown
+---
+description: Technical writer for clear Python documentation
+---
+
+You are a technical writer who creates clear Python documentation.
+
+**Standards:**
+- Google-style docstrings
+- Include parameter types and return values
+- Add usage examples for public methods
+- Note any exceptions raised
+```
+
+**Probando tus agentes:**
+
+> 💡 **Nota:** Deberías ya tener `samples/book-app-project/data.json` en tu copia local de este repo. Si falta, descarga la versión original del repo fuente:
+> [data.json](https://github.com/github/copilot-cli-for-beginners/blob/main/samples/book-app-project/data.json)
+
+```bash
+copilot
+> /agent
+# Selecciona "data-validator" de la lista
+> @samples/book-app-project/data.json Check for books with empty author fields or invalid years
+```
+
+**Consejo:** El campo `description` en el frontmatter YAML es obligatorio para que los agentes funcionen.
+
+
+
+### Desafío extra: Biblioteca de instrucciones
+
+Has construido agentes que invocas bajo demanda. Ahora prueba el otro lado: los **archivos de instrucciones** que Copilot lee automáticamente en cada sesión, sin necesidad de `/agent`.
+
+Crea una carpeta `.github/instructions/` con al menos 3 archivos de instrucciones:
+- `python-style.instructions.md` para aplicar PEP 8 y convenciones de anotaciones de tipo
+- `test-standards.instructions.md` para aplicar las convenciones de pytest en los archivos de pruebas
+- `data-quality.instructions.md` para validar entradas de datos JSON
+
+Prueba cada archivo de instrucciones en el código de la aplicación de libros.
+
+---
+
+
+🔧 Errores comunes y solución de problemas (hacer clic para expandir)
+
+### Errores comunes
+
+| Error | Qué ocurre | Solución |
+|---------|--------------|-----|
+| Falta `description` en el frontmatter del agente | El agente no se cargará o no será detectable | Incluye siempre `description:` en el frontmatter YAML |
+| Ubicación incorrecta del archivo para los agentes | Agente no encontrado cuando intentas usarlo | Colócalo en `~/.copilot/agents/` (personal) o `.github/agents/` (proyecto) |
+| Usar `.md` en lugar de `.agent.md` | El archivo puede no ser reconocido como agente | Nombra los archivos como `python-reviewer.agent.md` |
+| Prompts de agente excesivamente largos | Puede alcanzar el límite de 30,000 caracteres | Mantén las definiciones de agentes enfocadas; usa skills para instrucciones detalladas |
+
+### Solución de problemas
+
+Agente no encontrado - Comprueba que el archivo de agente exista en una de estas ubicaciones:
+- `~/.copilot/agents/`
+- `.github/agents/`
+
+List available agents:
+
+```bash
+copilot
+> /agent
+# Muestra todos los agentes disponibles
+```
+
+El agente no sigue las instrucciones - Sé explícito en tus prompts y añade más detalles en las definiciones de los agentes:
+- Marcos/librerías específicas con versiones
+- Convenciones del equipo
+- Patrones de código de ejemplo
+
+**Las instrucciones personalizadas no se cargan** - Ejecuta `/init` en tu proyecto para configurar instrucciones específicas del proyecto:
+
+```bash
+copilot
+> /init
+```
+
+O comprueba si están deshabilitadas:
+```bash
+# No uses --no-custom-instructions si quieres que se carguen
+copilot # Esto carga las instrucciones personalizadas por defecto
+```
+
+
+
+---
+
+# Resumen
+
+## 🔑 Puntos clave
+
+1. **Agentes integrados**: `/plan` y `/review` se invocan directamente; Explore y Task funcionan automáticamente
+2. Los **agentes personalizados** son especialistas definidos en archivos `.agent.md`
+3. Los **buenos agentes** tienen experiencia clara, estándares y formatos de salida
+4. La **colaboración multiagente** resuelve problemas complejos combinando experiencia
+5. Los **archivos de instrucciones** (`.instructions.md`) codifican estándares del equipo para su aplicación automática
+6. La **salida consistente** proviene de instrucciones de agente bien definidas
+
+> 📋 **Referencia rápida**: Consulta la [Referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para una lista completa de comandos y atajos.
+
+---
+
+## ➡️ ¿Qué sigue?
+
+Los agentes cambian *cómo Copilot aborda y realiza acciones específicas* en tu código. A continuación, aprenderás sobre las **skills** (habilidades) — que cambian *qué pasos* sigue. ¿Te preguntas cómo difieren los agentes y las skills? El Capítulo 05 trata eso directamente.
+
+En **[Capítulo 05: Sistema de skills](../05-skills/README.md)**, aprenderás:
+
+- Cómo las skills se activan automáticamente a partir de tus prompts (no se necesita comando con /)
+- Instalar skills de la comunidad
+- Crear skills personalizados con archivos SKILL.md
+- La diferencia entre agentes, skills y MCP
+- Cuándo usar cada uno
+
+---
+
+**[← Volver al Capítulo 03](../03-development-workflows/README.md)** | **[Continuar al Capítulo 05 →](../05-skills/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/05-skills/README.md b/translations/es/05-skills/README.md
new file mode 100644
index 00000000..ca3e1557
--- /dev/null
+++ b/translations/es/05-skills/README.md
@@ -0,0 +1,938 @@
+
+
+
+
+> **¿Y si Copilot pudiera aplicar automáticamente las mejores prácticas de tu equipo sin que tengas que explicarlas cada vez?**
+
+En este capítulo aprenderás sobre las Habilidades de Agente: carpetas de instrucciones que Copilot carga automáticamente cuando son relevantes para tu tarea. Mientras los agentes cambian *cómo* piensa Copilot, las habilidades le enseñan *formas específicas de completar tareas*. Crearás una habilidad de auditoría de seguridad que Copilot aplicará siempre que preguntes sobre seguridad, construirás criterios de revisión estándar del equipo para garantizar una calidad de código consistente y aprenderás cómo funcionan las habilidades en Copilot CLI, VS Code y el agente en la nube de GitHub Copilot.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, serás capaz de:
+
+- Entender cómo funcionan las Habilidades de Agente y cuándo usarlas
+- Crear habilidades personalizadas con archivos SKILL.md
+- Usar habilidades de la comunidad desde repositorios compartidos
+- Saber cuándo usar habilidades vs agentes vs MCP
+
+> ⏱️ **Tiempo estimado**: ~55 minutos (20 min de lectura + 35 min práctico)
+
+---
+
+## 🧩 Analogía del mundo real: Herramientas eléctricas
+
+Un taladro de uso general es útil, pero los accesorios especializados lo hacen poderoso.
+
+
+Las habilidades funcionan igual. Al igual que cambiar brocas para diferentes trabajos, puedes añadir habilidades a Copilot para distintas tareas:
+
+| Accesorio de habilidad | Propósito |
+|------------|---------|
+| `commit` | Generar mensajes de commit consistentes |
+| `security-audit` | Buscar vulnerabilidades OWASP |
+| `generate-tests` | Crear tests exhaustivos con pytest |
+| `code-checklist` | Aplicar estándares de calidad de código del equipo |
+
+
+
+*Las habilidades son accesorios especializados que amplían lo que Copilot puede hacer*
+
+---
+
+# Cómo funcionan las Habilidades
+
+
+
+Aprende qué son las habilidades, por qué importan y cómo se diferencian de los agentes y MCP.
+
+---
+
+## *¿Nuevo en las habilidades?* ¡Empieza aquí!
+
+1. **Consulta qué habilidades ya están disponibles:**
+ ```bash
+ copilot
+ > /skills list
+ ```
+ Esto muestra todas las habilidades que Copilot puede encontrar, incluidas las **habilidades integradas** que vienen con la propia CLI, además de las habilidades en tu proyecto y carpetas personales.
+
+ > 💡 **Habilidades integradas**: La Copilot CLI incluye habilidades preinstaladas desde el primer momento. Por ejemplo, la habilidad `customizing-copilot-cloud-agents-environment` proporciona una guía para personalizar el entorno del agente en la nube de Copilot. No necesitas crear ni instalar nada para usarlas. Ejecuta `/skills list` para ver qué hay disponible.
+
+2. **Mira un archivo de habilidad real:** Revisa nuestro [code-checklist SKILL.md](../../../.github/skills/code-checklist/SKILL.md) para ver el patrón. Es solo frontmatter YAML más instrucciones en markdown.
+
+3. **Entiende el concepto principal:** Las habilidades son instrucciones específicas de la tarea que Copilot carga *automáticamente* cuando tu solicitud coincide con la descripción de la habilidad. No necesitas activarlas, solo pregunta de forma natural.
+
+
+## Entendiendo las habilidades
+
+Las Habilidades de Agente son carpetas que contienen instrucciones, scripts y recursos que Copilot **carga automáticamente cuando son relevantes** para tu tarea. Copilot lee tu solicitud, comprueba si alguna habilidad coincide y aplica las instrucciones relevantes automáticamente.
+
+```bash
+copilot
+
+> Check books.py against our quality checklist
+# Copilot detecta que esto coincide con tu habilidad "code-checklist"
+# y aplica automáticamente su lista de verificación de calidad para Python
+
+> Generate tests for the BookCollection class
+# Copilot carga tu habilidad "pytest-gen"
+# y aplica tu estructura de pruebas preferida
+
+> What are the code quality issues in this file?
+# Copilot carga tu habilidad "code-checklist"
+# y comprueba que cumple los estándares de tu equipo
+```
+
+> 💡 **Idea clave**: Las habilidades se **activan automáticamente** según la coincidencia de tu solicitud con la descripción de la habilidad. Simplemente pregunta de forma natural y Copilot aplica las habilidades relevantes detrás de escena. También puedes invocar habilidades directamente, lo cual aprenderás a continuación.
+
+> 🧰 **Plantillas listas para usar**: Revisa la carpeta [.github/skills](../../../.github/skills) para encontrar habilidades sencillas que puedes copiar y probar.
+
+### Invocación directa con comandos slash
+
+Aunque la activación automática es la forma principal en que funcionan las habilidades, también puedes **invocar habilidades directamente** usando su nombre como comando slash:
+
+```bash
+> /generate-tests Create tests for the user authentication module
+
+> /code-checklist Check books.py for code quality issues
+
+> /security-audit Check the API endpoints for vulnerabilities
+```
+
+Esto te da control explícito cuando quieres asegurarte de que se use una habilidad específica.
+
+#### Combinar múltiples habilidades en un solo mensaje
+
+Puedes invocar **más de una habilidad en un mismo mensaje**, y el comando slash de la habilidad puede aparecer en cualquier parte de tu solicitud — no solo al principio. Esto es útil cuando quieres que se realicen dos comprobaciones diferentes a la vez:
+
+```bash
+> Check @samples/book-app-project/book_app.py with /code-checklist and also run /generate-tests for it
+
+> Review the auth module /security-audit then /code-checklist the result
+```
+
+Copilot aplicará cada habilidad nombrada en la misma respuesta, ahorrándote el enviar varios mensajes separados.
+
+> 💡 **Consejo**: Coloca los comandos slash de las habilidades donde más natural te parezca en la frase. Puedes ponerlos al inicio, en medio o al final de tu mensaje.
+
+> 📝 **Invocación: Habilidades vs Agentes**: No confundas la invocación de habilidades con la de agentes:
+> - **Habilidades**: `/skill-name `, p. ej., `/code-checklist Check this file`
+> - **Agentes**: `/agent` (selecciona de la lista) o `copilot --agent ` (línea de comandos)
+>
+> Si tienes tanto una habilidad como un agente con el mismo nombre (p. ej., "code-reviewer"), escribir `/code-reviewer` invoca la **habilidad**, no el agente.
+
+### ¿Cómo sé si se usó una habilidad?
+
+Puedes preguntarle directamente a Copilot:
+
+```bash
+> What skills did you use for that response?
+
+> What skills do you have available for security reviews?
+```
+
+### Habilidades vs Agentes vs MCP
+
+Las habilidades son solo una pieza del modelo de extensibilidad de GitHub Copilot. Aquí se muestra cómo se comparan con los agentes y los servidores MCP.
+
+> *No te preocupes por MCP todavía. Lo cubriremos en [Chapter 06](../../../06-mcp-servers). Se incluye aquí para que puedas ver cómo encajan las habilidades en el panorama general.*
+
+
+
+| Característica | Qué hace | Cuándo usar |
+|---------|--------------|-------------|
+| **Agents** | Cambia cómo piensa la IA | Necesitas pericia especializada en muchas tareas |
+| **Skills** | Proporciona instrucciones específicas de la tarea | Tareas específicas y repetibles con pasos detallados |
+| **MCP** | Conecta servicios externos | Necesitas datos en vivo desde APIs |
+
+Usa agentes para experiencia amplia, habilidades para instrucciones específicas de tareas y MCP para datos externos. Un agente puede usar una o más habilidades durante una conversación. Por ejemplo, cuando pides a un agente que revise tu código, podría aplicar automáticamente tanto una habilidad `security-audit` como una `code-checklist`.
+
+> 📚 **Aprende más**: Consulta la documentación oficial [Acerca de las habilidades de agente](https://docs.github.com/copilot/concepts/agents/about-agent-skills) para la referencia completa sobre formatos de habilidades y buenas prácticas.
+
+---
+
+## De solicitudes manuales a experiencia automática
+
+Antes de profundizar en cómo crear habilidades, veamos *por qué* vale la pena aprenderlas. Una vez que veas las ganancias en consistencia, el "cómo" tendrá más sentido.
+
+### Antes de las habilidades: Revisiones inconsistentes
+
+En cada revisión de código, podrías olvidar algo:
+
+```bash
+copilot
+
+> Review this code for issues
+# Revisión genérica - podría pasar por alto las preocupaciones específicas de su equipo
+```
+
+O escribes un prompt largo cada vez:
+
+```bash
+> Review this code checking for bare except clauses, missing type hints,
+> mutable default arguments, missing context managers for file I/O,
+> functions over 50 lines, print statements in production code...
+```
+
+Tiempo: **30+ segundos** para escribir. Consistencia: **varía según la memoria**.
+
+### Después de las habilidades: Mejores prácticas automáticas
+
+Con una habilidad `code-checklist` instalada, solo pregunta de forma natural:
+
+```bash
+copilot
+
+> Check the book collection code for quality issues
+```
+
+**Qué ocurre detrás de escena**:
+1. Copilot detecta "calidad de código" y "problemas" en tu solicitud
+2. Comprueba las descripciones de habilidades, encuentra que tu habilidad `code-checklist` coincide
+3. Carga automáticamente la lista de verificación de calidad de tu equipo
+4. Aplica todas las comprobaciones sin que tengas que enumerarlas
+
+
+
+*Pregunta de forma natural. Copilot asigna tu solicitud a la habilidad adecuada y la aplica automáticamente.*
+
+**Salida**:
+```
+## Code Checklist: books.py
+
+### Code Quality
+- [PASS] All functions have type hints
+- [PASS] No bare except clauses
+- [PASS] No mutable default arguments
+- [PASS] Context managers used for file I/O
+- [PASS] Functions are under 50 lines
+- [PASS] Variable and function names follow PEP 8
+
+### Input Validation
+- [FAIL] User input is not validated - add_book() accepts any year value
+- [FAIL] Edge cases not fully handled - empty strings accepted for title/author
+- [PASS] Error messages are clear and helpful
+
+### Testing
+- [FAIL] No corresponding pytest tests found
+
+### Summary
+3 items need attention before merge
+```
+
+**La diferencia**: Los estándares de tu equipo se aplican automáticamente, siempre, sin tener que escribirlos.
+
+---
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo mostrado aquí.*
+
+
+
+---
+
+## Consistencia a escala: Habilidad de revisión de PR del equipo
+
+Imagínate que tu equipo tiene una lista de verificación de PR de 10 puntos. Sin una habilidad, cada desarrollador debe recordar los 10 puntos, y alguien siempre olvida uno. Con una habilidad `pr-review`, todo el equipo obtiene revisiones consistentes:
+
+```bash
+copilot
+
+> Can you review this PR?
+```
+
+Copilot carga automáticamente la habilidad `pr-review` de tu equipo y comprueba los 10 puntos:
+
+```
+PR Review: feature/user-auth
+
+## Security ✅
+- No hardcoded secrets
+- Input validation present
+- No bare except clauses
+
+## Code Quality ⚠️
+- [WARN] print statement on line 45 - remove before merge
+- [WARN] TODO on line 78 missing issue reference
+- [WARN] Missing type hints on public functions
+
+## Testing ✅
+- New tests added
+- Edge cases covered
+
+## Documentation ❌
+- [FAIL] Breaking change not documented in CHANGELOG
+- [FAIL] API changes need OpenAPI spec update
+```
+
+**El poder**: Cada miembro del equipo aplica los mismos estándares automáticamente. Los nuevos empleados no necesitan memorizar la lista porque la habilidad se encarga.
+
+---
+
+# Creación de habilidades personalizadas
+
+
+
+Crea tus propias habilidades desde archivos SKILL.md.
+
+---
+
+## Ubicaciones de las habilidades
+
+Las habilidades se almacenan en `.github/skills/` (específicas del proyecto) o `~/.copilot/skills/` (a nivel de usuario).
+
+### Cómo encuentra Copilot las habilidades
+
+Copilot escanea automáticamente estas ubicaciones en busca de habilidades:
+
+| Ubicación | Alcance |
+|----------|-------|
+| `.github/skills/` | Específico del proyecto (compartido con el equipo vía git) |
+| `~/.copilot/skills/` | Específico del usuario (tus habilidades personales) |
+
+### Estructura de una habilidad
+
+Cada habilidad vive en su propia carpeta con un archivo `SKILL.md`. Opcionalmente puedes incluir scripts, ejemplos u otros recursos:
+
+```
+.github/skills/
+└── my-skill/
+ ├── SKILL.md # Required: Skill definition and instructions
+ ├── examples/ # Optional: Example files Copilot can reference
+ │ └── sample.py
+ └── scripts/ # Optional: Scripts the skill can use
+ └── validate.sh
+```
+
+> 💡 **Consejo**: El nombre del directorio debe coincidir con el `name` en el frontmatter de tu SKILL.md (minúsculas con guiones).
+
+### Formato de SKILL.md
+
+Las habilidades usan un formato simple en markdown con frontmatter YAML:
+
+```markdown
+---
+name: code-checklist
+description: Comprehensive code quality checklist with security, performance, and maintainability checks
+license: MIT
+---
+
+# Code Checklist
+
+When checking code, look for:
+
+## Security
+- SQL injection vulnerabilities
+- XSS vulnerabilities
+- Authentication/authorization issues
+- Sensitive data exposure
+
+## Performance
+- N+1 query problems (running one query per item instead of one query for all items)
+- Unnecessary loops or computations
+- Memory leaks
+- Blocking operations
+
+## Maintainability
+- Function length (flag functions > 50 lines)
+- Code duplication
+- Missing error handling
+- Unclear naming
+
+## Output Format
+Provide issues as a numbered list with severity:
+- [CRITICAL] - Must fix before merge
+- [HIGH] - Should fix before merge
+- [MEDIUM] - Should address soon
+- [LOW] - Nice to have
+```
+
+**Propiedades YAML:**
+
+| Propiedad | Requerido | Descripción |
+|----------|----------|-------------|
+| `name` | **Sí** | Identificador único (minúsculas, guiones para espacios) |
+| `description` | **Sí** | Qué hace la habilidad y cuándo Copilot debería usarla |
+| `license` | No | Licencia que aplica a esta habilidad |
+| `argument-hint` | No | Sugerencia corta que se muestra a los usuarios describiendo qué argumento espera la habilidad (p. ej., `"file path or code snippet"`) |
+
+> 💡 **¿Qué es `argument-hint`?** Cuando los usuarios invocan una habilidad directamente (p. ej., `/security-audit`), el texto `argument-hint` aparece como un marcador que muestra qué escribir a continuación — como un mini prompt de ayuda. Por ejemplo, configurar `argument-hint: "file path to review"` indica al usuario que debe proporcionar una ruta de archivo después del nombre de la habilidad.
+
+> 📖 **Documentación oficial**: [Acerca de las habilidades de agente](https://docs.github.com/copilot/concepts/agents/about-agent-skills)
+
+### Creando tu primera habilidad
+
+Construyamos una habilidad de auditoría de seguridad que busque las 10 principales vulnerabilidades OWASP:
+
+```bash
+# Crear directorio de skill
+mkdir -p .github/skills/security-audit
+
+# Crear el archivo SKILL.md
+cat > .github/skills/security-audit/SKILL.md << 'EOF'
+---
+name: security-audit
+description: Security-focused code review checking OWASP (Open Web Application Security Project) Top 10 vulnerabilities
+---
+
+# Auditoría de seguridad
+
+Perform a security audit checking for:
+
+## Vulnerabilidades de inyección
+- SQL injection (string concatenation in queries)
+- Command injection (unsanitized shell commands)
+- LDAP injection
+- XPath injection
+
+## Problemas de autenticación
+- Hardcoded credentials
+- Weak password requirements
+- Missing rate limiting
+- Session management flaws
+
+## Datos sensibles
+- Plaintext passwords
+- API keys in code
+- Logging sensitive information
+- Missing encryption
+
+## Control de acceso
+- Missing authorization checks
+- Insecure direct object references
+- Path traversal vulnerabilities
+
+## Salida
+For each issue found, provide:
+1. File and line number
+2. Vulnerability type
+3. Severity (CRITICAL/HIGH/MEDIUM/LOW)
+4. Recommended fix
+EOF
+
+# Prueba tu skill (las skills se cargan automáticamente según tu prompt)
+copilot
+
+> @samples/book-app-project/ Check this code for security vulnerabilities
+# Copilot detecta que "security vulnerabilities" coinciden con tu skill
+# y aplica automáticamente su lista de verificación OWASP
+```
+
+**Salida esperada** (tus resultados variarán):
+
+```
+Security Audit: book-app-project
+
+[HIGH] Hardcoded file path (book_app.py, line 12)
+ File path is hardcoded rather than configurable
+ Fix: Use environment variable or config file
+
+[MEDIUM] No input validation (book_app.py, line 34)
+ User input passed directly to function without sanitization
+ Fix: Add input validation before processing
+
+✅ No SQL injection found
+✅ No hardcoded credentials found
+```
+
+---
+
+## Escribir buenas descripciones de habilidades
+
+El campo `description` en tu SKILL.md es crucial. ¡Es la forma en que Copilot decide si debe cargar tu habilidad!
+
+```markdown
+---
+name: security-audit
+description: Use for security reviews, vulnerability scanning,
+ checking for SQL injection, XSS, authentication issues,
+ OWASP Top 10 vulnerabilities, and security best practices
+---
+```
+
+> 💡 **Consejo**: Incluye palabras clave que coincidan con la forma en que preguntas de forma natural. Si dices "revisión de seguridad", incluye "revisión de seguridad" en la descripción.
+
+### Combinar habilidades con agentes
+
+Las habilidades y los agentes funcionan juntos. El agente aporta pericia, la habilidad aporta instrucciones específicas:
+
+```bash
+# Empieza con un agente revisor de código
+copilot --agent code-reviewer
+
+> Check the book app for quality issues
+# La experiencia del agente revisor de código se combina
+# con la lista de verificación de tu habilidad code-checklist
+```
+
+---
+
+# Gestionar y compartir habilidades
+
+Descubre las habilidades instaladas, encuentra habilidades de la comunidad y comparte las tuyas.
+
+
+
+---
+
+## Gestionar habilidades con el comando `copilot skill` y `/skills`
+
+La Copilot CLI te ofrece dos maneras de gestionar habilidades. Puedes hacerlo directamente desde la terminal antes de iniciar Copilot o desde dentro de una sesión de Copilot.
+
+### Opción 1: `copilot skill` (comando de terminal)
+
+El subcomando `copilot skill` te permite gestionar habilidades directamente desde la terminal, sin abrir una sesión interactiva de Copilot. Esto es útil para automatizar con scripts, verificaciones rápidas o añadir habilidades antes de empezar a trabajar.
+
+```bash
+# Ver todas las habilidades instaladas
+copilot skill list
+
+# Agregar una habilidad desde un archivo local, URL o directorio
+copilot skill add .github/skills/my-skill/SKILL.md
+copilot skill add https://example.com/skills/security-audit/SKILL.md
+
+# Eliminar una habilidad por nombre
+copilot skill remove security-audit
+```
+
+### Opción 2: `/skills` (dentro de una sesión de Copilot)
+
+Una vez estés en una sesión interactiva de Copilot, usa `/skills` (o su atajo `/skill`) para gestionar habilidades sin salir:
+
+| Command | What It Does |
+|---------|--------------|
+| `/skills list` | Mostrar todas las skills instaladas |
+| `/skills info ` | Obtener detalles sobre una skill específica |
+| `/skills add ` | Habilitar una skill (desde un repositorio o marketplace) |
+| `/skills remove ` | Deshabilitar o desinstalar una skill |
+| `/skills reload` | Recargar skills después de editar archivos SKILL.md |
+
+> 💡 **`/skill` atajo**: Puedes escribir `/skill` en lugar de `/skills` — son intercambiables. Por ejemplo, `/skill list` funciona igual que `/skills list`.
+
+> 💡 **Recuerda**: No necesitas "activar" las skills para cada prompt. Una vez instaladas, las skills se **activan automáticamente** cuando tu prompt coincide con su descripción. Estos comandos son para gestionar qué skills están disponibles, no para usarlas.
+
+### Ejemplo: Ver tus skills
+
+```bash
+# Desde la terminal (no se necesita sesión interactiva):
+copilot skill list
+
+Available skills:
+- security-audit: Security-focused code review checking OWASP Top 10
+- generate-tests: Generate comprehensive unit tests with edge cases
+- code-checklist: Team code quality checklist
+...
+
+# O desde dentro de una sesión de Copilot:
+copilot
+
+> /skills list
+
+Available skills:
+- security-audit: Security-focused code review checking OWASP Top 10
+- generate-tests: Generate comprehensive unit tests with edge cases
+- code-checklist: Team code quality checklist
+...
+
+> /skills info security-audit
+
+Skill: security-audit
+Source: Project
+Location: .github/skills/security-audit/SKILL.md
+Description: Security-focused code review checking OWASP Top 10 vulnerabilities
+```
+
+---
+
+
+¡Míralo en acción!
+
+
+
+*La salida de la demostración varía. Tu modelo, herramientas y respuestas diferirán de lo mostrado aquí.*
+
+
+
+---
+
+### Cuándo usar `/skills reload`
+
+Después de crear o editar el archivo SKILL.md de una skill, ejecuta `/skills reload` para aplicar los cambios sin reiniciar Copilot:
+
+```bash
+# Edita tu archivo de habilidad
+# Luego en Copilot:
+> /skills reload
+Skills reloaded successfully.
+```
+
+> 💡 **Dato útil**: Las skills siguen siendo efectivas incluso después de usar `/compact` para resumir el historial de conversación. No es necesario recargar después de compactar.
+
+---
+
+## Encontrar y usar skills de la comunidad
+
+### Usar plugins para instalar skills
+
+> 💡 **¿Qué son los plugins?** Los plugins son paquetes instalables que pueden agrupar skills, agentes y configuraciones de servidor MCP. Considéralos como extensiones tipo "app store" para Copilot CLI.
+
+El comando `/plugin` te permite navegar e instalar estos paquetes:
+
+```bash
+copilot
+
+> /plugin list
+# Muestra los plugins instalados
+
+> /plugin marketplace
+# Explorar plugins disponibles
+
+> /plugin install
+# Instalar un plugin desde el mercado
+```
+
+Para mantener actualizado tu catálogo local de plugins, ráfrescalo con:
+
+```bash
+copilot plugin marketplace update
+```
+
+Los plugins pueden agrupar múltiples capacidades. Un solo plugin podría incluir skills, agentes y configuraciones de servidor MCP relacionadas que trabajen en conjunto.
+
+### Repositorios de skills comunitarios
+
+También hay skills preconstruidas disponibles en repositorios comunitarios:
+
+- **[Awesome Copilot](https://github.com/github/awesome-copilot)** - Recursos oficiales de GitHub Copilot que incluyen documentación de skills y ejemplos
+
+### Instalar una skill comunitaria con GitHub CLI
+
+La forma más fácil de instalar una skill desde un repositorio de GitHub es usando el comando `gh skill install` (requiere [GitHub CLI v2.90.0+](https://github.blog/changelog/2026-04-16-manage-agent-skills-with-github-cli/)):
+
+```bash
+# Explorar y seleccionar interactivamente una habilidad de awesome-copilot
+gh skill install github/awesome-copilot
+
+# O instalar una habilidad específica directamente
+gh skill install github/awesome-copilot ai-ready
+
+# Instalar para uso personal en todos los proyectos (ámbito de usuario)
+gh skill install github/awesome-copilot ai-ready --scope user
+```
+
+> ⚠️ **Revisa antes de instalar**: Siempre lee el `SKILL.md` de una skill antes de instalarla. Las skills controlan lo que Copilot hace, y una skill maliciosa podría instruirlo para ejecutar comandos dañinos o modificar código de maneras inesperadas.
+
+---
+
+# Práctica
+
+
+
+Aplica lo que aprendiste creando y probando tus propias skills.
+
+---
+
+## ▶️ Pruébalo tú mismo
+
+### Crea más skills
+
+Aquí tienes dos skills más que muestran diferentes patrones. Sigue el mismo flujo de trabajo `mkdir` + `cat` de "Crear tu primera skill" arriba o copia y pega las skills en la ubicación adecuada. Hay más ejemplos disponibles en [.github/skills](../../../.github/skills).
+
+### Skill de generación de tests pytest
+
+Una skill que asegura una estructura consistente de pytest en todo tu código:
+
+```bash
+mkdir -p .github/skills/pytest-gen
+
+cat > .github/skills/pytest-gen/SKILL.md << 'EOF'
+---
+name: pytest-gen
+description: Generate comprehensive pytest tests with fixtures and edge cases
+---
+
+# Generación de pruebas pytest
+
+Generate pytest tests that include:
+
+## Estructura de pruebas
+- Use pytest conventions (test_ prefix)
+- One assertion per test when possible
+- Clear test names describing expected behavior
+- Use fixtures for setup/teardown
+
+## Cobertura
+- Happy path scenarios
+- Edge cases: None, empty strings, empty lists
+- Boundary values
+- Error scenarios with pytest.raises()
+
+## Fixtures
+- Use @pytest.fixture for reusable test data
+- Use tmpdir/tmp_path for file operations
+- Mock external dependencies with pytest-mock
+
+## Salida
+Provide complete, runnable test file with proper imports.
+EOF
+```
+
+### Skill de revisión de PR del equipo
+
+Una skill que aplica estándares consistentes de revisión de PR en tu equipo:
+
+```bash
+mkdir -p .github/skills/pr-review
+
+cat > .github/skills/pr-review/SKILL.md << 'EOF'
+---
+name: pr-review
+description: Team-standard PR review checklist
+---
+
+# Revisión de PR
+
+Review code changes against team standards:
+
+## Lista de verificación de seguridad
+- [ ] No hardcoded secrets or API keys
+- [ ] Input validation on all user data
+- [ ] No bare except clauses
+- [ ] No sensitive data in logs
+
+## Calidad del código
+- [ ] Functions under 50 lines
+- [ ] No print statements in production code
+- [ ] Type hints on public functions
+- [ ] Context managers for file I/O
+- [ ] No TODOs without issue references
+
+## Pruebas
+- [ ] New code has tests
+- [ ] Edge cases covered
+- [ ] No skipped tests without explanation
+
+## Documentación
+- [ ] API changes documented
+- [ ] Breaking changes noted
+- [ ] README updated if needed
+
+## Formato de salida
+Provide results as:
+- ✅ PASS: Items that look good
+- ⚠️ WARN: Items that could be improved
+- ❌ FAIL: Items that must be fixed before merge
+EOF
+```
+
+### Ir más lejos
+
+1. **Desafío de creación de skills**: Crea una skill `quick-review` que haga una lista de verificación de 3 puntos:
+ - Cláusulas except sin especificar
+ - Faltan anotaciones de tipo
+ - Nombres de variables poco claros
+
+ Pruébala pidiendo: "Haz una revisión rápida de books.py"
+
+2. **Comparación de skills**: Cronométrate mientras escribes manualmente un prompt detallado para una revisión de seguridad. Luego simplemente pide "Check for security issues in this file" y deja que tu skill de auditoría de seguridad se cargue automáticamente. ¿Cuánto tiempo ahorró la skill?
+
+3. **Desafío de skill para el equipo**: Piensa en la lista de verificación de revisión de código de tu equipo. ¿Podrías codificarla como una skill? Anota 3 cosas que la skill debería comprobar siempre.
+
+**Autoevaluación**: Entiendes las skills cuando puedes explicar por qué el campo `description` importa (es como Copilot decide si cargar tu skill).
+
+---
+
+## 📝 Tarea
+
+### Desafío principal: Crea una skill de resumen de libros
+
+Los ejemplos anteriores crearon las skills `pytest-gen` y `pr-review`. Ahora practica creando un tipo de skill completamente diferente: una para generar salida formateada a partir de datos.
+
+1. Lista tus skills actuales: Ejecuta Copilot y pásale `/skills list`. También puedes usar `ls .github/skills/` para ver las skills del proyecto o `ls ~/.copilot/skills/` para las skills personales.
+2. Crea una skill `book-summary` en `.github/skills/book-summary/SKILL.md` que genere un resumen en markdown formateado de la colección de libros
+3. Tu skill debería tener:
+ - Nombre y descripción claros (¡la descripción es crucial para el emparejamiento!)
+ - Reglas de formato específicas (por ejemplo, tabla en markdown con título, autor, año, estado de lectura)
+ - Convenciones de salida (por ejemplo, usa ✅/❌ para el estado de lectura, ordenar por año)
+4. Testea la skill: `@samples/book-app-project/data.json Summarize the books in this collection`
+5. Verifica que la skill se active automáticamente comprobando `/skills list`
+6. Intenta invocarla directamente con `/book-summary Summarize the books in this collection`
+
+**Criterios de éxito**: Tienes una skill `book-summary` funcional que Copilot aplica automáticamente cuando preguntas sobre la colección de libros.
+
+
+💡 Pistas (haz clic para expandir)
+
+**Plantilla de inicio**: Crea `.github/skills/book-summary/SKILL.md`:
+
+```markdown
+---
+name: book-summary
+description: Generate a formatted markdown summary of a book collection
+---
+
+# Book Summary Generator
+
+Generate a summary of the book collection following these rules:
+
+1. Output a markdown table with columns: Title, Author, Year, Status
+2. Use ✅ for read books and ❌ for unread books
+3. Sort by year (oldest first)
+4. Include a total count at the bottom
+5. Flag any data issues (missing authors, invalid years)
+
+Example:
+| Title | Author | Year | Status |
+|-------|--------|------|--------|
+| 1984 | George Orwell | 1949 | ✅ |
+| Dune | Frank Herbert | 1965 | ❌ |
+
+**Total: 2 books (1 read, 1 unread)**
+```
+
+**Pruébalo:**
+```bash
+copilot
+> @samples/book-app-project/data.json Summarize the books in this collection
+# La habilidad debería activarse automáticamente en función de la coincidencia de la descripción
+```
+
+**Si no se activa:** Prueba `/skills reload` y luego pregunta de nuevo.
+
+
+
+### Desafío extra: Skill de mensajes de commit
+
+1. Crea una skill `commit-message` que genere mensajes de commit convencionales con un formato consistente
+2. Pruébala preparando un cambio y preguntando: "Generate a commit message for my staged changes"
+3. Documenta tu skill y compártela en GitHub con el topic `copilot-skill`
+
+---
+
+
+🔧 Errores comunes y solución de problemas (haz clic para expandir)
+
+### Errores comunes
+
+| Error | Qué sucede | Solución |
+|---------|--------------|-----|
+| Naming the file something other than `SKILL.md` | La skill no será reconocida | El archivo debe llamarse exactamente `SKILL.md` |
+| Vague `description` field | La skill nunca se carga automáticamente | La descripción es el mecanismo PRIMARIO de descubrimiento. Usa palabras clave específicas |
+| Missing `name` or `description` in frontmatter | La skill no se carga | Añade ambos campos en el frontmatter YAML |
+| Wrong folder location | Skill no encontrada | Usa `.github/skills/skill-name/` (proyecto) o `~/.copilot/skills/skill-name/` (personal) |
+
+### Solución de problemas
+
+**Skill no utilizada** - Si Copilot no está utilizando tu skill cuando se espera:
+
+1. **Comprueba la descripción**: ¿Coincide con cómo lo estás pidiendo?
+ ```markdown
+ # Bad: Too vague
+ description: Reviews code
+
+ # Good: Includes trigger words
+ description: Use for code reviews, checking code quality,
+ finding bugs, security issues, and best practice violations
+ ```
+
+2. **Verifica la ubicación del archivo**:
+ ```bash
+ # Habilidades del proyecto
+ ls .github/skills/
+
+ # Habilidades del usuario
+ ls ~/.copilot/skills/
+ ```
+
+3. **Comprueba el formato de SKILL.md**: El frontmatter es obligatorio:
+ ```markdown
+ ---
+ name: skill-name
+ description: What the skill does and when to use it
+ ---
+
+ # Instructions here
+ ```
+
+**Skill que no aparece** - Verifica la estructura de carpetas:
+```
+.github/skills/
+└── my-skill/ # Folder name
+ └── SKILL.md # Must be exactly SKILL.md (case-sensitive)
+```
+
+Ejecuta `/skills reload` después de crear o editar skills para asegurarte de que los cambios se apliquen.
+
+**Probar si una skill se carga** - Pregunta a Copilot directamente:
+```bash
+> What skills do you have available for checking code quality?
+# Copilot describirá las habilidades relevantes que encontró
+```
+
+**¿Cómo sé si mi skill está realmente funcionando?**
+
+1. **Comprueba el formato de salida**: Si tu skill especifica un formato de salida (como etiquetas `[CRITICAL]`), búscalo en la respuesta
+2. **Pregunta directamente**: Después de obtener una respuesta, pregunta "¿Usaste alguna skill para eso?"
+3. **Compara con/sin**: Prueba el mismo prompt con `--no-custom-instructions` para ver la diferencia:
+ ```bash
+ # Con habilidades
+ copilot --allow-all -p "Review @file.py for security issues"
+
+ # Sin habilidades (comparación de referencia)
+ copilot --allow-all -p "Review @file.py for security issues" --no-custom-instructions
+ ```
+4. **Comprueba comprobaciones específicas**: Si tu skill incluye comprobaciones específicas (como "functions over 50 lines"), verifica si aparecen en la salida
+
+
+
+---
+
+# Resumen
+
+## 🔑 Puntos clave
+
+1. **Las skills son automáticas**: Copilot las carga cuando tu prompt coincide con la descripción de la skill
+2. **Invocación directa**: También puedes invocar skills directamente con `/skill-name` como un comando con barra
+3. **Formato SKILL.md**: Frontmatter YAML (name, description, optional license, argument-hint) más instrucciones en markdown
+4. **La ubicación importa**: `.github/skills/` para compartir en proyecto/equipo, `~/.copilot/skills/` para uso personal
+5. **La descripción es clave**: Escribe descripciones que coincidan con cómo formulas las preguntas de forma natural
+6. **Dos maneras de gestionar skills**: Usa `copilot skill` desde la terminal o `/skills` (atajo: `/skill`) dentro de una sesión
+
+> 📋 **Referencia rápida**: Consulta la [referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para una lista completa de comandos y atajos.
+
+---
+
+## ➡️ ¿Qué sigue?
+
+Las skills amplían lo que Copilot puede hacer con instrucciones cargadas automáticamente. ¿Pero qué pasa con la conexión a servicios externos? Ahí es donde entra MCP.
+
+En **[Capítulo 06: Servidores MCP](../06-mcp-servers/README.md)**, aprenderás:
+
+- Qué es MCP (Model Context Protocol)
+- Conexión a GitHub, sistema de archivos y servicios de documentación
+- Configurar servidores MCP
+- Flujos de trabajo con múltiples servidores
+
+---
+
+**[← Volver al Capítulo 04](../04-agents-custom-instructions/README.md)** | **[Continuar al Capítulo 06 →](../06-mcp-servers/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/06-mcp-servers/README.md b/translations/es/06-mcp-servers/README.md
new file mode 100644
index 00000000..0d7887e7
--- /dev/null
+++ b/translations/es/06-mcp-servers/README.md
@@ -0,0 +1,992 @@
+
+
+
+
+> **¿Y si Copilot pudiera leer tus issues de GitHub, revisar tu base de datos y crear PRs... todo desde la terminal?**
+
+Hasta ahora, Copilot solo puede trabajar con lo que le das directamente: archivos que referencias con `@`, el historial de la conversación y sus propios datos de entrenamiento. Pero, ¿y si pudiera conectarse por su cuenta para revisar tu repositorio de GitHub, explorar los archivos del proyecto o buscar la documentación más reciente de una librería?
+
+Eso es lo que hace MCP (Model Context Protocol). Es una forma de conectar Copilot a servicios externos para que tenga acceso a datos en vivo y del mundo real. Cada servicio al que Copilot se conecta se llama "servidor MCP". En este capítulo, configurarás algunas de estas conexiones y verás cómo hacen que Copilot sea mucho más útil.
+
+> 💡 **¿Ya conoces MCP?** [Ve al inicio rápido](#-use-the-built-in-github-mcp) para confirmar que funciona y empezar a configurar servidores.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, serás capaz de:
+
+- Entender qué es MCP y por qué importa
+- Administrar servidores MCP usando comandos `/mcp`
+- Configurar servidores MCP para GitHub, sistema de archivos y documentación
+- Usar flujos de trabajo potenciados por MCP con el proyecto de la app del libro
+- Saber cuándo y cómo construir un servidor MCP personalizado (opcional)
+
+> ⏱️ **Tiempo estimado**: ~50 minutos (15 min de lectura + 35 min prácticos)
+
+---
+
+## 🧩 Analogía del mundo real: Extensiones del navegador
+
+
+
+Piensa en los servidores MCP como extensiones del navegador. Tu navegador por sí solo puede mostrar páginas web, pero las extensiones lo conectan a servicios adicionales:
+
+| Browser Extension | What It Connects To | MCP Equivalent |
+|-------------------|---------------------|----------------|
+| Password manager | Your password vault | **GitHub MCP** → your repos, issues, PRs |
+| Grammarly | Writing analysis service | **Context7 MCP** → library documentation |
+| File manager | Cloud storage | **Filesystem MCP** → local project files |
+
+Sin extensiones, tu navegador sigue siendo útil, pero con ellas se convierte en una máquina potente. Los servidores MCP hacen lo mismo por Copilot. Lo conectan a fuentes de datos reales y en vivo para que pueda leer tus issues de GitHub, explorar tu sistema de archivos, obtener documentación actualizada y más.
+
+***Los servidores MCP conectan a Copilot con el mundo exterior: GitHub, repositorios, documentación y más***
+
+> 💡 **Idea clave**: Sin MCP, Copilot solo puede ver archivos que compartes explícitamente con `@`. Con MCP, puede explorar proactivamente tu proyecto, revisar tu repo de GitHub y consultar documentación, todo automáticamente.
+
+---
+
+
+
+# Inicio rápido: MCP en 30 segundos
+
+## Comienza con el servidor MCP de GitHub integrado
+Veamos MCP en acción ahora mismo, antes de configurar nada.
+El servidor MCP de GitHub está incluido por defecto. Prueba esto:
+
+```bash
+copilot
+> List the recent commits in this repository
+```
+
+Si Copilot devuelve datos reales de commits, acabas de ver MCP en acción. Ese es el servidor MCP de GitHub contactando a GitHub en tu nombre. Pero GitHub es solo *un* servidor. Este capítulo te muestra cómo añadir más (acceso al sistema de archivos, documentación actualizada y otros) para que Copilot pueda hacer aún más.
+
+---
+
+## El comando `/mcp show`
+
+Usa `/mcp show` para ver qué servidores MCP están configurados y si están habilitados:
+
+```bash
+copilot
+
+> /mcp show
+
+MCP Servers:
+✓ github (enabled) - GitHub integration
+✓ filesystem (enabled) - File system access
+```
+
+> 💡 **¿Solo ves el servidor de GitHub?** ¡Eso es normal! Si no has añadido servidores MCP adicionales todavía, GitHub es el único que aparece. Añadirás más en la siguiente sección.
+
+> 📚 **¿Quieres ver todos los comandos de gestión de MCP?** Puedes administrar servidores con comandos slash `/mcp` dentro del chat, o con `copilot mcp` directamente desde tu terminal. Consulta la [referencia completa de comandos](#-additional-mcp-commands) al final de este capítulo.
+
+
+🎬 ¡Míralo en acción!
+
+
+
+*La salida de la demostración varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+---
+
+## ¿Qué cambia con MCP?
+
+He aquí la diferencia que hace MCP en la práctica:
+
+**Sin MCP:**
+```bash
+> What's in GitHub issue #42?
+
+"I don't have access to GitHub. You'll need to copy and paste the issue content."
+```
+
+**Con MCP:**
+```bash
+> What's in GitHub issue #42 of this repository?
+
+Issue #42: El inicio de sesión falla con caracteres especiales
+Status: Open
+Labels: bug, priority-high
+Description: Users report that passwords containing...
+```
+
+MCP permite que Copilot conozca tu entorno de desarrollo real.
+
+> 📚 **Documentación oficial**: [Acerca de MCP](https://docs.github.com/copilot/concepts/context/mcp) para una mirada más profunda de cómo MCP funciona con GitHub Copilot.
+
+---
+
+# Configurar servidores MCP
+
+
+
+Ahora que has visto MCP en acción, vamos a configurar servidores adicionales. Puedes añadir servidores de dos formas: **desde el registro incorporado** (lo más fácil — configuración guiada directamente en la CLI) o editando el archivo de configuración manualmente (más flexible). Comienza con la opción del registro si no estás seguro de cuál elegir.
+
+---
+
+## Instalar servidores MCP desde el registro
+
+La CLI tiene un registro incorporado de servidores MCP que te permite descubrir e instalar servidores populares con una configuración guiada — sin necesidad de editar JSON.
+
+```bash
+copilot
+
+> /mcp search
+```
+
+Copilot abre un selector interactivo que muestra los servidores disponibles. Selecciona uno y la CLI te guía a través de la configuración requerida (claves API, rutas, etc.) y lo añade a tu configuración automáticamente.
+
+> 💡 **¿Por qué usar el registro?** Es la forma más sencilla de empezar — no necesitas conocer el nombre del paquete npm, los argumentos del comando o la estructura JSON. La CLI se encarga de todo eso por ti.
+
+---
+
+## Archivo de configuración de MCP
+
+Los servidores MCP pueden configurarse a nivel de usuario en `~/.copilot/mcp-config.json`, lo que aplica a través de proyectos, a nivel de proyecto en `.mcp.json`, o en el archivo de configuración del espacio de trabajo `.github/mcp.json`. `.github/mcp.json` se carga automáticamente junto con `.mcp.json`. Si usaste `/mcp search`, la CLI creó o actualizó tu `~/.copilot/mcp-config.json` a nivel de usuario, pero entender el formato JSON es útil cuando quieras personalizar o compartir la configuración MCP a nivel de proyecto.
+
+> ⚠️ **Nota**: `.vscode/mcp.json` ya no es compatible como fuente de configuración MCP. Si tienes un `.vscode/mcp.json` existente, migralo a `.mcp.json` en la raíz de tu proyecto. La CLI mostrará una sugerencia de migración si detecta un archivo de configuración antiguo.
+
+```json
+{
+ "mcpServers": {
+ "server-name": {
+ "type": "local",
+ "command": "npx",
+ "args": ["@package/server-name"],
+ "tools": ["*"]
+ }
+ }
+}
+```
+
+*La mayoría de los servidores MCP se distribuyen como paquetes npm y se ejecutan mediante el comando `npx`.*
+
+
+💡 ¿Nuevo en JSON? Haz clic aquí para aprender qué significa cada campo
+
+| Field | What It Means |
+|-------|---------------|
+| `"mcpServers"` | Contenedor de todas tus configuraciones de servidores MCP |
+| `"server-name"` | Un nombre que eliges (e.g., "github", "filesystem") |
+| `"type": "local"` | El servidor se ejecuta en tu máquina |
+| `"command": "npx"` | El programa a ejecutar (npx ejecuta paquetes npm) |
+| `"args": [...]` | Argumentos pasados al comando |
+| `"tools": ["*"]` | Permite todas las herramientas de este servidor |
+
+**Reglas importantes de JSON:**
+- Usa comillas dobles `"` para cadenas (no comillas simples)
+- No uses comas finales después del último elemento
+- El archivo debe ser JSON válido (usa un [validador JSON](https://jsonlint.com/) si no estás seguro)
+
+
+
+---
+
+## Agregar servidores MCP
+
+El servidor MCP de GitHub está integrado y no requiere configuración. A continuación tienes servidores adicionales que puedes añadir. **Elige lo que te interese o recórrelos en orden.**
+
+| Quiero... | Ir a |
+|---|---|
+| Permitir que Copilot explore los archivos de mi proyecto | [Servidor del sistema de archivos](#servidor-del-sistema-de-archivos) |
+| Obtener documentación actualizada de bibliotecas | [Servidor Context7](#servidor-context7-documentación) |
+| Explorar extras opcionales (servidores personalizados, web_fetch) | [Más allá de lo básico](#más-allá-de-lo-básico) |
+
+
+Filesystem Server - Permite que Copilot explore los archivos de tu proyecto
+
+
+### Servidor del sistema de archivos
+
+```json
+{
+ "mcpServers": {
+ "filesystem": {
+ "type": "local",
+ "command": "npx",
+ "args": ["-y", "@modelcontextprotocol/server-filesystem", "."],
+ "tools": ["*"]
+ }
+ }
+}
+```
+
+> 💡 **La ruta `.`**: El `.` significa "directorio actual". Copilot puede acceder a archivos relativos al lugar donde lo iniciaste. En un Codespace, esto es la raíz de tu espacio de trabajo. También puedes usar una ruta absoluta como `/workspaces/copilot-cli-for-beginners` si lo prefieres.
+
+Añade esto a tu `~/.copilot/mcp-config.json` y reinicia Copilot.
+
+
+
+
+Context7 Server - Obtener documentación de librerías actualizada
+
+
+### Servidor Context7 (Documentación)
+
+Context7 le da a Copilot acceso a documentación actualizada para frameworks y librerías populares. En lugar de depender de datos de entrenamiento que podrían estar desactualizados, Copilot obtiene la documentación actual y real.
+
+```json
+{
+ "mcpServers": {
+ "context7": {
+ "type": "local",
+ "command": "npx",
+ "args": ["-y", "@upstash/context7-mcp"],
+ "tools": ["*"]
+ }
+ }
+}
+```
+
+- ✅ **No se requiere clave API**
+- ✅ **No se necesita cuenta**
+- ✅ **Tu código permanece local**
+
+Añade esto a tu `~/.copilot/mcp-config.json` y reinicia Copilot.
+
+
+
+
+Más allá de lo básico - Servidores personalizados y acceso web (opcional)
+
+
+Estos son extras opcionales para cuando te sientas cómodo con los servidores básicos anteriores.
+
+### Servidor MCP de Microsoft Learn
+
+Todos los servidores MCP que has visto hasta ahora (filesystem, Context7) se ejecutan localmente en tu máquina. Pero los servidores MCP también pueden ejecutarse de forma remota, lo que significa que solo apuntas la Copilot CLI a una URL y ella se encarga del resto. No hay `npx` ni `python`, no hay proceso local, ni dependencias que instalar.
+
+El [Microsoft Learn MCP Server](https://github.com/microsoftdocs/mcp) es un buen ejemplo. Le da a la Copilot CLI acceso directo a la documentación oficial de Microsoft (Azure, Microsoft Foundry y otros temas de IA, .NET, Microsoft 365 y mucho más) para que pueda buscar en la documentación, obtener páginas completas y encontrar ejemplos de código oficiales en lugar de depender de los datos de entrenamiento del modelo.
+
+- ✅ **No se requiere clave API**
+- ✅ **No se necesita cuenta**
+- ✅ **No se requiere instalación local**
+
+**Instalación rápida con `/plugin install`:**
+
+En lugar de editar tu archivo JSON manualmente, puedes instalarlo con un solo comando:
+
+```bash
+copilot
+
+> /plugin install microsoftdocs/mcp
+```
+
+Esto añade el servidor y sus habilidades de agente asociadas automáticamente. Las habilidades instaladas incluyen:
+
+- **microsoft-docs**: Conceptos, tutoriales y búsquedas de hechos
+- **microsoft-code-reference**: Búsquedas de API, ejemplos de código y solución de problemas
+- **microsoft-skill-creator**: Una meta-habilidad para generar habilidades personalizadas sobre tecnologías de Microsoft
+
+**Uso:**
+```bash
+copilot
+
+> What's the recommended way to deploy a Python app to Azure App Service? Search Microsoft Learn.
+```
+
+📚 Más información: [Resumen del Servidor MCP de Microsoft Learn](https://learn.microsoft.com/training/support/mcp-get-started)
+
+### Acceso web con `web_fetch`
+
+La Copilot CLI incluye una herramienta integrada `web_fetch` que puede obtener contenido de cualquier URL. Esto es útil para recuperar README, documentación de API o notas de versiones sin salir de la terminal. No se necesita un servidor MCP.
+
+Puedes controlar qué URLs son accesibles mediante `~/.copilot/config.json` (configuración general de Copilot), que es independiente de `~/.copilot/mcp-config.json` (definiciones de servidores MCP).
+
+```json
+{
+ "permissions": {
+ "allowedUrls": [
+ "https://api.github.com/**",
+ "https://docs.github.com/**",
+ "https://*.npmjs.org/**"
+ ],
+ "blockedUrls": [
+ "http://**"
+ ]
+ }
+}
+```
+
+**Uso:**
+```bash
+copilot
+
+> Fetch and summarize the README from https://github.com/facebook/react
+```
+
+### Crear un servidor MCP personalizado
+
+¿Quieres conectar Copilot a tus propias APIs, bases de datos o herramientas internas? Puedes crear un servidor MCP personalizado en Python. Esto es completamente opcional, ya que los servidores preconstruidos (GitHub, filesystem, Context7) cubren la mayoría de los casos de uso.
+
+📖 Consulta la [Guía de servidor MCP personalizado](mcp-custom-server.md) para un recorrido completo usando la app del libro como ejemplo.
+
+📚 Para más información, consulta el [curso MCP para principiantes](https://github.com/microsoft/mcp-for-beginners).
+
+
+
+
+
+### Archivo de configuración completo
+
+Aquí tienes un `mcp-config.json` completo con los servidores filesystem y Context7:
+
+> 💡 **Nota:** GitHub MCP está integrado. No necesitas añadirlo a tu archivo de configuración.
+```json
+{
+ "mcpServers": {
+ "filesystem": {
+ "type": "local",
+ "command": "npx",
+ "args": ["-y", "@modelcontextprotocol/server-filesystem", "."],
+ "tools": ["*"]
+ },
+ "context7": {
+ "type": "local",
+ "command": "npx",
+ "args": ["-y", "@upstash/context7-mcp"],
+ "tools": ["*"]
+ }
+ }
+}
+```
+
+Save this as `~/.copilot/mcp-config.json` for global access or `.mcp.json` in the project root for project-specific configuration.
+
+---
+
+# Usando servidores MCP
+
+Now that you have MCP servers configured, let's see what they can do.
+
+
+
+---
+
+## Ejemplos de uso del servidor
+
+**Elige un servidor para explorar, o recórrelos en orden.**
+
+| Quiero probar... | Ir a |
+|---|---|
+| Repositorios, issues, y PRs de GitHub | [Servidor GitHub](#servidor-github-integrado) |
+| Navegar archivos del proyecto | [Uso del servidor Filesystem](#filesystem-server-usage) |
+| Búsqueda de documentación de la biblioteca | [Uso del servidor Context7](#context7-server-usage) |
+| Servidor personalizado, Microsoft Learn MCP y uso de web_fetch | [Más allá de lo básico](#más-allá-de-lo-básico) |
+
+
+Servidor GitHub (integrado) - Accede a repos, issues, PRs y más
+
+
+### Servidor GitHub (integrado)
+
+The GitHub MCP server is **built-in**. If you logged into Copilot (which you did during initial setup), it already works. No configuration needed!
+
+> 💡 **¿No funciona?** Ejecuta `/login` para volver a autenticarte con GitHub.
+
+
+Autenticación en contenedores de desarrollo
+
+- **GitHub Codespaces** (recomendado): La autenticación es automática. El CLI `gh` hereda tu token de Codespace. No se necesita ninguna acción.
+- **Contenedor de desarrollo local (Docker)**: Ejecuta `gh auth login` después de que el contenedor inicie, luego reinicia Copilot.
+
+**Solución de problemas de autenticación:**
+```bash
+# Comprueba si estás autenticado
+gh auth status
+
+# Si no, inicia sesión
+gh auth login
+
+# Verifica que GitHub MCP esté conectado
+copilot
+> /mcp show
+```
+
+
+
+| Funcionalidad | Ejemplo |
+|---------|----------|
+| **Información del repositorio** | Ver commits, ramas, colaboradores |
+| **Issues** | Listar, crear, buscar y comentar issues |
+| **Pull requests** | Ver PRs, diffs, crear PRs, comprobar estado |
+| **Búsqueda de código** | Buscar código en repositorios |
+| **Actions** | Consultar ejecuciones de workflows y estado |
+
+```bash
+copilot
+
+# Ver la actividad reciente en este repositorio
+> List the last 5 commits in this repository
+
+Recent commits:
+1. abc1234 - Update chapter 05 skills examples (2 days ago)
+2. def5678 - Add book app test fixtures (3 days ago)
+3. ghi9012 - Fix typo in chapter 03 README (4 days ago)
+...
+
+# Explorar la estructura del repositorio
+> What branches exist in this repository?
+
+Branches:
+- main (default)
+- chapter6 (current)
+
+# Buscar patrones de código en todo el repositorio
+> Search this repository for files that import pytest
+
+Found 1 file:
+- samples/book-app-project/tests/test_books.py
+```
+
+> 💡 **¿Trabajando en tu propio fork?** Si hiciste fork de este repositorio del curso, también puedes intentar operaciones de escritura como crear issues y pull requests. Practicaremos eso en los ejercicios abajo.
+
+> ⚠️ **¿No ves resultados?** El MCP de GitHub opera sobre el remoto del repositorio (en github.com), no solo archivos locales. Asegúrate de que tu repo tenga un remoto: ejecuta `git remote -v` para comprobar.
+
+
+
+
+Servidor del sistema de archivos - Navegar y analizar archivos del proyecto
+
+
+### Servidor del sistema de archivos
+
+Once configured, the filesystem MCP provides tools that Copilot can use automatically:
+
+```bash
+copilot
+
+> How many Python files are in the book-app-project directory?
+
+Found 3 Python files in samples/book-app-project/:
+- book_app.py
+- books.py
+- utils.py
+
+> What's the total size of the data.json file?
+
+samples/book-app-project/data.json: 2.4 KB
+
+> Find all functions that don't have type hints in the book app
+
+Found 2 functions without type hints:
+- samples/book-app-project/utils.py:10 - get_user_choice()
+- samples/book-app-project/utils.py:14 - get_book_details()
+```
+
+
+
+
+Servidor Context7 - Buscar documentación de librerías
+
+
+### Servidor Context7
+
+```bash
+copilot
+
+> What are the best practices for using pytest fixtures?
+
+From pytest Documentation:
+
+Fixtures - Use fixtures to provide a fixed baseline for tests:
+
+ import pytest
+
+ @pytest.fixture
+ def sample_books():
+ return [
+ {"title": "1984", "author": "George Orwell", "year": 1949},
+ {"title": "Dune", "author": "Frank Herbert", "year": 1965},
+ ]
+
+ def test_find_by_author(sample_books):
+ # fixture se pasa automáticamente como argumento
+ results = [b for b in sample_books if "Orwell" in b["author"]]
+ assert len(results) == 1
+
+Best practices:
+- Use fixtures instead of setup/teardown methods
+- Use tmp_path fixture for temporary files
+- Use monkeypatch for modifying environment
+- Scope fixtures appropriately (function, class, module, session)
+
+> How can I apply this to the book app's test file?
+
+# Copilot ahora conoce los patrones oficiales de pytest
+# y puede aplicarlos a samples/book-app-project/tests/test_books.py
+```
+
+
+
+
+Más allá de lo básico - Uso de servidor personalizado y web_fetch
+
+
+### Más allá de lo básico
+
+**Servidor MCP personalizado**: Si construiste el servidor book-lookup a partir de la [Guía del servidor MCP personalizado](mcp-custom-server.md), puedes consultar tu colección de libros directamente:
+
+```bash
+copilot
+
+> Look up information about "1984" using the book lookup server. Search for books by George Orwell
+```
+
+**Microsoft Learn MCP**: Si instalaste el [servidor Microsoft Learn MCP](#servidor-mcp-de-microsoft-learn), puedes consultar la documentación oficial de Microsoft directamente:
+
+```bash
+copilot
+
+> How do I configure managed identity for an Azure Function? Search Microsoft Learn.
+```
+
+**Web Fetch**: Usa la herramienta integrada `web_fetch` para obtener contenido de cualquier URL:
+
+```bash
+copilot
+
+> Fetch and summarize the README from https://github.com/facebook/react
+```
+
+
+
+---
+
+## Flujos de trabajo con varios servidores
+
+Estos flujos de trabajo muestran por qué los desarrolladores dicen «Nunca quiero volver a trabajar sin esto». Cada ejemplo combina varios servidores MCP en una sola sesión.
+
+
+
+*Flujo MCP completo: GitHub MCP recupera datos del repositorio, Filesystem MCP encuentra el código, Context7 MCP proporciona mejores prácticas, y Copilot realiza el análisis*
+
+Cada ejemplo a continuación es independiente. **Elige uno que te interese, o léelos todos.**
+
+| Quiero ver... | Ir a |
+|---|---|
+| Varios servidores trabajando juntos | [Exploración multi-servidor](#multi-server-exploration) |
+| De un issue a un PR en una sesión | [Flujo Issue a PR](#flujo-issue-a-pr-en-tu-propio-repo) |
+| Una comprobación rápida del estado del proyecto | [Panel de salud](#panel-de-salud-de-la-aplicación-book) |
+
+
+Exploración multi-servidor - Combina filesystem, GitHub y Context7 en una sesión
+
+
+#### Explorando la aplicación Book con múltiples servidores MCP
+
+```bash
+copilot
+
+# Paso 1: Utilice el MCP del sistema de archivos para explorar la aplicación de libros
+> List all Python files in samples/book-app-project/ and summarize
+> what each file does
+
+Found 3 Python files:
+- book_app.py: CLI entry point with command routing (list, add, remove, find)
+- books.py: BookCollection class with data persistence via JSON
+- utils.py: Helper functions for user input and display
+
+# Paso 2: Utilice el MCP de GitHub para revisar los cambios recientes
+> What were the last 3 commits that touched files in samples/book-app-project/?
+
+Recent commits affecting book app:
+1. abc1234 - Add test fixtures for BookCollection (2 days ago)
+2. def5678 - Add find_by_author method (5 days ago)
+3. ghi9012 - Initial book app setup (1 week ago)
+
+# Paso 3: Utilice el MCP Context7 para las mejores prácticas
+> What are Python best practices for JSON data persistence?
+
+From Python Documentation:
+- Use context managers (with statements) for file I/O
+- Handle JSONDecodeError for corrupted files
+- Use dataclasses for structured data
+- Consider atomic writes to prevent data corruption
+
+# Paso 4: Sintetice una recomendación
+> Based on the book app code and these best practices,
+> what improvements would you suggest?
+
+Suggestions:
+1. Add input validation in add_book() for empty strings and invalid years
+2. Consider atomic writes in save_books() to prevent data corruption
+3. Add type hints to utils.py functions (get_user_choice, get_book_details)
+```
+
+
+🎬 ¡Ve el flujo MCP en acción!
+
+
+
+*La salida de la demo varía. Tu modelo, herramientas y respuestas diferirán de lo que se muestra aquí.*
+
+
+
+**El resultado**: Exploración del código → revisión del historial → consulta de mejores prácticas → plan de mejora. **Todo desde una sesión de terminal, usando tres servidores MCP juntos.**
+
+
+
+
+Flujo Issue a PR - Pasa de un issue de GitHub a un pull request sin salir del terminal
+
+
+#### Flujo Issue a PR (en tu propio repo)
+
+This works best on your own fork or repository where you have write access:
+
+> 💡 **No te preocupes si no puedes probar esto ahora mismo.** Si estás en un clon de solo lectura, practicarás esto en la tarea. Por ahora, simplemente léelo para entender el flujo.
+
+```bash
+copilot
+
+> Get the details of GitHub issue #1
+
+Issue #1: Agregar validación de entrada para el año del libro
+Status: Open
+Description: The add_book function accepts any year value...
+
+> @samples/book-app-project/books.py Fix the issue described in issue #1
+
+[Copilot implements year validation in add_book()]
+
+> Run the tests to make sure the fix works
+
+All 8 tests passed ✓
+
+> Create a pull request titled "Add year validation to book app"
+
+✓ Created PR #2: Agregar validación del año a la aplicación de libros
+```
+
+**Cero copiar-pegar. Cero cambio de contexto. Una sesión de terminal.**
+
+
+
+
+Panel de salud - Obtén una verificación rápida de la salud del proyecto usando múltiples servidores
+
+
+#### Panel de salud de la aplicación Book
+
+```bash
+copilot
+
+> Give me a health report for the book app project:
+> 1. List all functions across the Python files in samples/book-app-project/
+> 2. Check which functions have type hints and which don't
+> 3. Show what tests exist in samples/book-app-project/tests/
+> 4. Check the recent commit history for this directory
+
+Book App Health Report
+======================
+
+📊 Functions Found:
+- books.py: 8 methods in BookCollection (all have type hints ✓)
+- book_app.py: 6 functions (4 have type hints, 2 missing)
+- utils.py: 3 functions (1 has type hints, 2 missing)
+
+🧪 Test Coverage:
+- test_books.py: 8 test functions covering BookCollection
+- Missing: no tests for book_app.py CLI functions
+- Missing: no tests for utils.py helper functions
+
+📝 Recent Activity:
+- 3 commits in the last week
+- Most recent: added test fixtures
+
+Recommendations:
+- Add type hints to utils.py functions
+- Add tests for book_app.py CLI handlers
+- All files well-sized (<100 lines) - good structure!
+```
+
+**El resultado**: Múltiples fuentes de datos agregadas en segundos. Manualmente, esto significaría ejecutar grep, contar líneas, comprobar git log y revisar archivos de pruebas. Fácilmente más de 15 minutos de trabajo.
+
+
+
+---
+
+# Práctica
+
+
+
+**🎉 ¡Ahora conoces lo esencial!** Entiendes MCP, has visto cómo configurar servidores y has visto flujos de trabajo reales en acción. Ahora es momento de intentarlo tú mismo.
+
+---
+
+## ▶️ Inténtalo tú mismo
+
+Now it's your turn! Complete these exercises to practice using MCP servers with the book app project.
+
+### Ejercicio 1: Comprueba el estado de tu MCP
+
+Start by seeing what MCP servers are available:
+
+```bash
+copilot
+
+> /mcp show
+```
+
+You should see the GitHub server listed as enabled. If not, run `/login` to authenticate.
+
+---
+
+### Ejercicio 2: Explora la aplicación Book con Filesystem MCP
+
+If you've configured the filesystem server, use it to explore the book app:
+
+```bash
+copilot
+
+> How many Python files are in samples/book-app-project/?
+> What functions are defined in each file?
+```
+
+**Resultado esperado**: Copilot lista `book_app.py`, `books.py` y `utils.py` con sus funciones.
+
+> 💡 **¿No tienes configurado el filesystem MCP todavía?** Crea el archivo de configuración a partir de la sección [Configuración completa](#archivo-de-configuración-completo) arriba. Luego reinicia Copilot.
+
+---
+
+### Ejercicio 3: Consulta el historial del repositorio con GitHub MCP
+
+Use the built-in GitHub MCP to explore this course repository:
+
+```bash
+copilot
+
+> List the last 5 commits in this repository
+
+> What branches exist in this repository?
+```
+
+**Resultado esperado**: Copilot muestra mensajes de commits recientes y nombres de ramas desde el remoto de GitHub.
+
+> ⚠️ **¿En un Codespace?** Esto funciona automáticamente. La autenticación se hereda. Si estás en un clon local, asegúrate de que `gh auth status` muestre que has iniciado sesión.
+
+---
+
+### Ejercicio 4: Combina múltiples servidores MCP
+
+Now combine filesystem and GitHub MCP in a single session:
+
+```bash
+copilot
+
+> Read samples/book-app-project/data.json and tell me what books are
+> in the collection. Then check the recent commits to see when this
+> file was last modified.
+```
+
+**Resultado esperado**: Copilot lee el archivo JSON (filesystem MCP), lista los 5 libros incluyendo "The Hobbit", "1984", "Dune", "To Kill a Mockingbird", y "Mysterious Book", luego consulta GitHub por el historial de commits.
+
+**Autocomprobación**: Entiendes MCP cuando puedas explicar por qué "Check my repo's commit history" is better than manually running `git log` and pasting the output into your prompt.
+
+---
+
+## 📝 Asignación
+
+### Desafío principal: Exploración MCP de la aplicación Book
+
+Practica usando servidores MCP juntos en el proyecto de la aplicación Book. Completa estos pasos en una sola sesión de Copilot:
+
+1. **Verificar que MCP funciona**: Ejecuta `/mcp show` y confirma que al menos el servidor GitHub está habilitado
+2. **Configurar filesystem MCP** (si no está hecho): Crea `~/.copilot/mcp-config.json` con la configuración del servidor del sistema de archivos
+3. **Explorar el código**: Pídele a Copilot que use el servidor del sistema de archivos para:
+ - Listar todas las funciones en `samples/book-app-project/books.py`
+ - Comprobar qué funciones en `samples/book-app-project/utils.py` no tienen anotaciones de tipo
+ - Leer `samples/book-app-project/data.json` e identificar cualquier problema de calidad de datos (sugerencia: mira la última entrada)
+4. **Comprobar actividad del repositorio**: Pídele a Copilot que use GitHub MCP para:
+ - Listar commits recientes que tocaron archivos en `samples/book-app-project/`
+ - Comprobar si hay issues abiertos o pull requests
+5. **Combinar servidores**: En un único prompt, pide a Copilot que:
+ - Leer el archivo de pruebas en `samples/book-app-project/tests/test_books.py`
+ - Comparar las funciones probadas contra todas las funciones en `books.py`
+ - Resumir qué cobertura de pruebas falta
+
+**Criterios de éxito**: Puedes combinar sin problemas los datos de filesystem y GitHub MCP en una sola sesión de Copilot, y puedes explicar qué contribuyó cada servidor MCP a la respuesta.
+
+
+💡 Sugerencias (haz clic para expandir)
+
+**Paso 1: Verificar MCP**
+```bash
+copilot
+> /mcp show
+# Debería mostrar "github" como habilitado
+# Si no, ejecuta: /login
+```
+
+**Paso 2: Crear el archivo de configuración**
+
+Usa el JSON de la sección [Configuración completa](#archivo-de-configuración-completo) arriba y guárdalo como `~/.copilot/mcp-config.json`.
+
+**Paso 3: Problema de calidad de datos a buscar**
+
+El último libro en `data.json` es:
+```json
+{
+ "title": "Mysterious Book",
+ "author": "",
+ "year": 0,
+ "read": false
+}
+```
+¡Un autor vacío y año 0. Ese es el problema de calidad de datos!
+
+**Paso 5: Comparación de cobertura de pruebas**
+
+Las pruebas en `test_books.py` cubren: `add_book`, `mark_as_read`, `remove_book`, `get_unread_books`, y `find_book_by_title`. Funciones como `load_books`, `save_books`, y `list_books` no tienen pruebas directas. Las funciones CLI en `book_app.py` y los ayudantes en `utils.py` no tienen pruebas en absoluto.
+
+**Si MCP no funciona:** Reinicia Copilot después de editar el archivo de configuración.
+
+
+
+### Desafío extra: Construye un servidor MCP personalizado
+
+Ready to go deeper? Follow the [Guía del servidor MCP personalizado](mcp-custom-server.md) to build your own MCP server in Python that connects to any API.
+
+---
+
+
+🔧 Errores comunes y solución de problemas (haz clic para expandir)
+
+### Errores comunes
+
+| Error | Qué sucede | Solución |
+|---------|--------------|-----|
+| Not knowing GitHub MCP is built-in | Trying to install/configure it manually | GitHub MCP está incluido por defecto. Simplemente intenta: "List the recent commits in this repo" |
+| Looking for config in wrong location | Can't find or edit MCP settings | La config a nivel de usuario está en `~/.copilot/mcp-config.json`, a nivel de proyecto es `.mcp.json` en la raíz del proyecto |
+| Invalid JSON in config file | MCP servers fail to load | Usa `/mcp show` para comprobar la configuración; valida la sintaxis JSON |
+| Forgetting to authenticate MCP servers | "Authentication failed" errors | Algunos MCP requieren autenticación separada. Revisa los requisitos de cada servidor |
+
+### Solución de problemas
+
+**"MCP server not found"** - Comprueba que:
+1. The npm package exists: `npm view @modelcontextprotocol/server-github`
+2. Your configuration is valid JSON
+3. The server name matches your config
+
+Use `/mcp show` to see the current configuration.
+
+
+**"La autenticación de GitHub falló"** - El MCP de GitHub integrado utiliza tus credenciales de `/login`. Intenta:
+
+```bash
+copilot
+> /login
+```
+
+Esto te volverá a autenticar con GitHub. Si los problemas persisten, verifica que tu cuenta de GitHub tenga los permisos necesarios para el repositorio al que intentas acceder.
+
+**"El servidor MCP no pudo iniciarse"** - Revisa los registros del servidor:
+```bash
+# Ejecuta el comando del servidor manualmente para ver los errores
+npx -y @modelcontextprotocol/server-github
+```
+
+**Herramientas MCP no disponibles** - Asegúrate de que el servidor esté habilitado:
+```bash
+copilot
+
+> /mcp show
+# Comprobar si el servidor está listado y habilitado
+```
+
+Si un servidor está deshabilitado, consulta los [comandos `/mcp` adicionales](#-additional-mcp-commands) a continuación para saber cómo volver a habilitarlo.
+
+
+
+---
+
+
+📚 Comandos MCP adicionales (haz clic para expandir)
+
+
+Puedes administrar servidores MCP de dos maneras: usando **comandos slash dentro de una sesión de chat**, o usando el **comando `copilot mcp` directamente en tu terminal** (no se necesita una sesión de chat).
+
+### Opción 1: Comandos slash (dentro de una sesión de chat)
+
+Estos funcionan cuando ya estás dentro de `copilot`:
+
+| Command | What It Does |
+|---------|--------------|
+| `/mcp show` | Mostrar todos los servidores MCP configurados y su estado |
+| `/mcp add` | Configuración interactiva para agregar un nuevo servidor |
+| `/mcp edit ` | Editar la configuración de un servidor existente |
+| `/mcp enable ` | Habilitar un servidor deshabilitado (persiste entre sesiones) |
+| `/mcp disable ` | Deshabilitar un servidor (persiste entre sesiones) |
+| `/mcp delete ` | Eliminar un servidor permanentemente |
+| `/mcp auth ` | Volver a autenticar con un servidor MCP que usa OAuth (p. ej., después de cambiar de cuenta) |
+
+### Opción 2: comando `copilot mcp` (desde tu terminal)
+
+También puedes administrar servidores MCP directamente desde tu terminal sin iniciar primero una sesión de chat:
+
+```bash
+# Listar todos los servidores MCP configurados
+copilot mcp list
+
+# Habilitar un servidor
+copilot mcp enable filesystem
+
+# Deshabilitar un servidor
+copilot mcp disable context7
+```
+
+> 💡 **¿Cuándo usar cuál?** Usa los comandos slash `/mcp` cuando ya estés en una sesión de chat. Usa `copilot mcp` desde la terminal cuando quieras comprobar o cambiar rápidamente la configuración de tu servidor antes de iniciar una sesión.
+
+Para la mayor parte de este curso, `/mcp show` es todo lo que necesitas. Los otros comandos resultan útiles a medida que gestionas más servidores con el tiempo.
+
+
+
+---
+
+# Resumen
+
+## 🔑 Puntos clave
+
+1. **MCP** conecta Copilot con servicios externos (GitHub, sistema de archivos, documentación)
+2. **El MCP de GitHub está integrado** - no se necesita configuración, solo `/login`
+3. **El sistema de archivos y Context7** se configuran mediante `~/.copilot/mcp-config.json`
+4. **Los flujos de trabajo multi-servidor** combinan datos de múltiples fuentes en una sola sesión
+5. **Administra servidores de dos maneras**: usa los comandos slash `/mcp` dentro del chat, o `copilot mcp` desde la terminal
+6. **Los servidores personalizados** te permiten conectar cualquier API (opcional, cubierto en la guía del apéndice)
+
+> 📋 **Referencia rápida**: Consulta la [referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para obtener una lista completa de comandos y atajos.
+
+---
+
+## ➡️ ¿Qué sigue?
+
+Ahora tienes todos los bloques de construcción: modos, contexto, flujos de trabajo, agentes, habilidades y MCP. Es hora de ponerlos todos juntos.
+
+En **[Capítulo 07: Poniéndolo todo junto](../07-putting-it-together/README.md)**, aprenderás:
+
+- Cómo combinar agentes, habilidades y MCP en flujos de trabajo unificados
+- Desarrollo completo de una funcionalidad desde la idea hasta un PR fusionado
+- Automatización con hooks
+- Mejores prácticas para entornos de equipo
+
+---
+
+**[← Volver al Capítulo 05](../05-skills/README.md)** | **[Continuar al Capítulo 07 →](../07-putting-it-together/README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/06-mcp-servers/mcp-custom-server.md b/translations/es/06-mcp-servers/mcp-custom-server.md
new file mode 100644
index 00000000..be2511f6
--- /dev/null
+++ b/translations/es/06-mcp-servers/mcp-custom-server.md
@@ -0,0 +1,194 @@
+
+
+# Construyendo un servidor MCP personalizado
+
+> ⚠️ **Este contenido es completamente opcional.** Puedes ser muy productivo con Copilot CLI usando únicamente los servidores MCP preconstruidos (GitHub, filesystem, Context7). Esta guía es para desarrolladores que quieran conectar Copilot a APIs internas personalizadas. Consulta el [MCP for Beginners course](https://github.com/microsoft/mcp-for-beginners) para más detalles.
+>
+> **Requisitos previos:**
+> - Familiaridad con Python
+> - Comprensión de los patrones `async`/`await`
+> - `pip` disponible en tu sistema (incluido en este contenedor de desarrollo)
+>
+> **[← Volver al Capítulo 06: Servidores MCP](README.md)**
+
+---
+
+¿Quieres conectar Copilot a tus propias APIs? Aquí tienes cómo construir un servidor MCP simple en Python que busca información de libros, vinculándolo con el proyecto de la aplicación de libros que has estado usando a lo largo de este curso.
+
+## Configuración del proyecto
+
+```bash
+mkdir book-lookup-mcp-server
+cd book-lookup-mcp-server
+pip install mcp
+```
+
+> 💡 **¿Qué es el paquete `mcp`?** Es el SDK oficial de Python para crear servidores MCP. Se encarga de los detalles del protocolo para que puedas centrarte en tus herramientas.
+
+## Implementación del servidor
+
+Crea un archivo llamado `server.py`:
+
+```python
+# server.py
+import json
+from mcp.server.fastmcp import FastMCP
+
+# Crear el servidor MCP
+mcp = FastMCP("book-lookup")
+
+# Base de datos de libros de ejemplo (en un servidor real, esto podría consultar una API o una base de datos)
+BOOKS_DB = {
+ "978-0-547-92822-7": {
+ "title": "The Hobbit",
+ "author": "J.R.R. Tolkien",
+ "year": 1937,
+ "genre": "Fantasy",
+ },
+ "978-0-451-52493-5": {
+ "title": "1984",
+ "author": "George Orwell",
+ "year": 1949,
+ "genre": "Dystopian Fiction",
+ },
+ "978-0-441-17271-9": {
+ "title": "Dune",
+ "author": "Frank Herbert",
+ "year": 1965,
+ "genre": "Science Fiction",
+ },
+}
+
+
+@mcp.tool()
+def lookup_book(isbn: str) -> str:
+ """Look up a book by its ISBN and return title, author, year, and genre."""
+ book = BOOKS_DB.get(isbn)
+ if book:
+ return json.dumps(book, indent=2)
+ return f"No book found with ISBN: {isbn}"
+
+
+@mcp.tool()
+def search_books(query: str) -> str:
+ """Search for books by title or author. Returns all matching results."""
+ query_lower = query.lower()
+ results = [
+ {**book, "isbn": isbn}
+ for isbn, book in BOOKS_DB.items()
+ if query_lower in book["title"].lower()
+ or query_lower in book["author"].lower()
+ ]
+ if results:
+ return json.dumps(results, indent=2)
+ return f"No books found matching: {query}"
+
+
+@mcp.tool()
+def list_all_books() -> str:
+ """List all books in the database with their ISBNs."""
+ books_list = [
+ {"isbn": isbn, "title": book["title"], "author": book["author"]}
+ for isbn, book in BOOKS_DB.items()
+ ]
+ return json.dumps(books_list, indent=2)
+
+
+if __name__ == "__main__":
+ mcp.run()
+```
+
+**Qué está pasando aquí:**
+
+| Parte | Qué hace |
+|------|-------------|
+| `FastMCP("book-lookup")` | Crea un servidor llamado "book-lookup" |
+| `@mcp.tool()` | Registra una función como una herramienta que Copilot puede invocar |
+| Anotaciones de tipo + docstrings | Indican a Copilot qué hace cada herramienta y qué parámetros necesita |
+| `mcp.run()` | Inicia el servidor y escucha las solicitudes |
+
+> 💡 **¿Por qué los decoradores?** El decorador `@mcp.tool()` es todo lo que necesitas. El SDK de MCP lee automáticamente el nombre de tu función, las anotaciones de tipo y el docstring para generar el esquema de la herramienta. ¡No se necesita un esquema JSON manual!
+
+## Configuración
+
+Agrega a tu `~/.copilot/mcp-config.json`:
+
+```json
+{
+ "mcpServers": {
+ "book-lookup": {
+ "type": "local",
+ "command": "python3",
+ "args": ["./book-lookup-mcp-server/server.py"],
+ "tools": ["*"]
+ }
+ }
+}
+```
+
+## Uso
+
+```bash
+copilot
+
+> Look up the book with ISBN 978-0-547-92822-7
+
+{
+ "title": "The Hobbit",
+ "author": "J.R.R. Tolkien",
+ "year": 1937,
+ "genre": "Fantasy"
+}
+
+> Search for books by Orwell
+
+[
+ {
+ "title": "1984",
+ "author": "George Orwell",
+ "year": 1949,
+ "genre": "Dystopian Fiction",
+ "isbn": "978-0-451-52493-5"
+ }
+]
+
+> List all available books
+
+[Shows all books in the database with ISBNs]
+```
+
+## Próximos pasos
+
+Una vez que hayas creado un servidor básico, puedes:
+
+1. **Añadir más herramientas** - Cada función `@mcp.tool()` se convierte en una herramienta que Copilot puede invocar
+2. **Conectar APIs reales** - Reemplaza la base de datos simulada `BOOKS_DB` con llamadas a APIs reales o consultas a bases de datos
+3. **Agregar autenticación** - Maneja las claves de API y los tokens de forma segura
+4. **Comparte tu servidor** - Publícalo en PyPI para que otros puedan instalarlo con `pip`
+
+## Recursos
+
+- [MCP Python SDK](https://github.com/modelcontextprotocol/python-sdk)
+- [MCP TypeScript SDK](https://github.com/modelcontextprotocol/typescript-sdk)
+- [Example MCP Servers](https://github.com/modelcontextprotocol/servers)
+- [MCP for Beginners Course](https://github.com/microsoft/mcp-for-beginners)
+
+---
+
+**[← Volver al Capítulo 06: Servidores MCP](README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/07-putting-it-together/README.md b/translations/es/07-putting-it-together/README.md
new file mode 100644
index 00000000..86fca86a
--- /dev/null
+++ b/translations/es/07-putting-it-together/README.md
@@ -0,0 +1,529 @@
+
+
+
+
+> **Todo lo que aprendiste se combina aquí. Pasa de la idea a un PR fusionado en una sola sesión.**
+
+En este capítulo, reunirás todo lo que aprendiste en flujos de trabajo completos. Construirás funcionalidades usando colaboración multinagente, configurarás hooks de pre-commit que detecten problemas de seguridad antes de que se haga el commit, integrarás Copilot en pipelines de CI/CD y pasarás de la idea de una funcionalidad a un PR fusionado en una sola sesión de terminal. Aquí es donde GitHub Copilot CLI se convierte en un multiplicador de fuerza real.
+
+> 💡 **Nota**: Este capítulo muestra cómo combinar todo lo que has aprendido. **No necesitas agentes, skills ni MCP para ser productivo (aunque pueden ser muy útiles).** El flujo de trabajo central — describir, planificar, implementar, probar, revisar, desplegar — funciona solo con las funciones incorporadas de los Capítulos 00-03.
+
+## 🎯 Objetivos de aprendizaje
+
+Al final de este capítulo, podrás:
+
+- Combinar agentes, skills y MCP (Model Context Protocol) en flujos de trabajo unificados
+- Construir funcionalidades completas usando enfoques multi-herramienta
+- Configurar automatización básica con hooks
+- Aplicar buenas prácticas para el desarrollo profesional
+
+> ⏱️ **Tiempo estimado**: ~75 minutos (15 min lectura + 60 min práctica)
+
+---
+
+## 🧩 Analogía del mundo real: La orquesta
+
+
+
+Una orquesta sinfónica tiene muchas secciones:
+- **Cuerdas** aportan la base (como tus flujos de trabajo principales)
+- **Metales** añaden potencia (como agentes con experiencia especializada)
+- **Vientos** añaden color (como skills que amplían las capacidades)
+- **Percusión** marca el ritmo (como MCP que conecta con sistemas externos)
+
+Individualmente, cada sección suena limitada. Juntas, bien dirigidas, crean algo magnífico.
+
+**¡Esto es lo que enseña este capítulo!**
+*Como un director con una orquesta, diriges agentes, skills y MCP en flujos de trabajo unificados*
+
+Comencemos recorriendo un escenario que modifica código, genera pruebas, lo revisa y crea un PR — todo en una sesión.
+
+---
+
+## De idea a PR fusionado en una sola sesión
+
+En lugar de cambiar entre tu editor, terminal, ejecutor de pruebas, documentación y la interfaz de GitHub y perder contexto cada vez, puedes combinar todas tus herramientas en una sesión de terminal. Desglosaremos este patrón en la sección [Patrón de integración](#the-integration-pattern-for-power-users) más abajo.
+
+```bash
+# Inicia Copilot en modo interactivo
+copilot
+
+> I need to add a "list unread" command to the book app that shows only
+> books where read is False. What files need to change?
+
+# Copilot crea un plan de alto nivel...
+
+# CAMBIAR AL AGENTE PYTHON-REVIEWER
+> /agent
+# Selecciona "python-reviewer"
+
+> @samples/book-app-project/books.py Design a get_unread_books method.
+> What is the best approach?
+
+# El agente python-reviewer produce:
+# - Firma del método y tipo de retorno
+# - Implementación del filtro usando comprensión de listas
+# - Manejo de casos límite para colecciones vacías
+
+# CAMBIAR AL AGENTE PYTEST-HELPER
+> /agent
+# Selecciona "pytest-helper"
+
+> @samples/book-app-project/tests/test_books.py Design test cases for
+> filtering unread books.
+
+# El agente pytest-helper produce:
+# - Casos de prueba para colecciones vacías
+# - Casos de prueba con libros mezclados leídos/no leídos
+# - Casos de prueba con todos los libros leídos
+
+# IMPLEMENTAR
+> Add a get_unread_books method to BookCollection in books.py
+> Add a "list unread" command option in book_app.py
+> Update the help text in the show_help function
+
+# PROBAR
+> Generate comprehensive tests for the new feature
+
+# Se generan múltiples pruebas similares a las siguientes:
+# - Camino feliz (3 pruebas) — filtra correctamente, excluye los leídos, incluye los no leídos
+# - Casos límite (4 pruebas) — colección vacía, todos leídos, ninguno leído, libro único
+# - Parametrizado (5 casos) — variando las proporciones leídos/no leídos mediante @pytest.mark.parametrize
+# - Integración (4 pruebas) — interacción con mark_as_read, remove_book, add_book e integridad de datos
+
+# Revisa los cambios
+> /review
+
+# Si la revisión pasa, usa /pr para operar en la pull request de la rama actual
+> /pr [view|create|fix|auto]
+
+# O pide de forma natural si quieres que Copilot lo redacte desde la terminal
+> Create a pull request titled "Feature: Add list unread books command"
+```
+
+**Enfoque tradicional**: Cambiar entre editor, terminal, ejecutor de pruebas, documentación y la interfaz de GitHub. Cada cambio provoca pérdida de contexto y fricción.
+
+**La idea clave**: Tú dirigiste a especialistas como un arquitecto. Ellos se encargaron de los detalles. Tú te encargaste de la visión.
+
+> 💡 **Para profundizar**: Para planes grandes de varios pasos como este, prueba `/fleet` para dejar que Copilot ejecute subtareas independientes en paralelo. Consulta la [documentación oficial](https://docs.github.com/copilot/concepts/agents/copilot-cli/fleet) para más detalles.
+
+---
+
+# Flujos de trabajo adicionales
+
+
+
+Para usuarios avanzados que completaron los Capítulos 04-06, estos flujos muestran cómo agentes, skills y MCP multiplican tu efectividad.
+
+## El patrón de integración
+
+Aquí está el modelo mental para combinar todo:
+
+
+
+---
+
+## Flujo de trabajo 1: Investigación y corrección de errores
+
+Corrección de errores del mundo real con integración completa de herramientas:
+
+```bash
+copilot
+
+# FASE 1: Entender el error desde GitHub (MCP proporciona esto)
+> Get the details of issue #1
+
+# Aprender: "find_by_author no funciona con nombres parciales"
+
+# FASE 2: Investigar las mejores prácticas (investigación profunda con fuentes web y de GitHub)
+> /research Best practices for Python case-insensitive string matching
+
+# FASE 3: Encontrar código relacionado
+> @samples/book-app-project/books.py Show me the find_by_author method
+
+# FASE 4: Obtener análisis de expertos
+> /agent
+# Seleccionar "python-reviewer"
+
+> Analyze this method for issues with partial name matching
+
+# Agente identifica: el método usa igualdad exacta en lugar de coincidencia por subcadena
+
+# FASE 5: Corregir con la orientación del agente
+> Implement the fix using lowercase comparison and 'in' operator
+
+# FASE 6: Generar pruebas
+> /agent
+# Seleccionar "pytest-helper"
+
+> Generate pytest tests for find_by_author with partial matches
+> Include test cases: partial name, case variations, no matches
+
+# FASE 7: Hacer commit y PR
+> Generate a commit message for this fix
+
+> Create a pull request linking to issue #1
+```
+
+---
+
+## Flujo de trabajo 2: Automatización de revisión de código (Opcional)
+
+> 💡 **Esta sección es opcional.** Los hooks de pre-commit son útiles para equipos pero no necesarios para ser productivos. Omite esto si recién comienzas.
+>
+> ⚠️ **Nota de rendimiento**: Este hook llama a `copilot -p` por cada archivo en el área de preparación (staged), lo que toma varios segundos por archivo. Para commits grandes, considera limitarlo a archivos críticos o ejecutar las revisiones manualmente con `/review` en su lugar.
+
+Un **git hook** es un script que Git ejecuta automáticamente en ciertos puntos; por ejemplo, justo antes de un commit. Puedes usar esto para ejecutar comprobaciones automatizadas en tu código. Aquí se muestra cómo configurar una revisión automática de Copilot en tus commits:
+
+```bash
+# Crear un hook de pre-commit
+cat > .git/hooks/pre-commit << 'EOF'
+#!/bin/bash
+
+# Obtener archivos en el área de preparación (solo archivos Python)
+STAGED=$(git diff --cached --name-only --diff-filter=ACM | grep -E '\.py$')
+
+if [ -n "$STAGED" ]; then
+ echo "Running Copilot review on staged files..."
+
+ for file in $STAGED; do
+ echo "Reviewing $file..."
+
+ # Usar un tiempo de espera para evitar que se quede colgado (60 segundos por archivo)
+ # --allow-all aprueba automáticamente lecturas/escrituras de archivos para que el hook pueda ejecutarse sin supervisión.
+ # Usar esto solo en scripts automatizados. En sesiones interactivas, deje que Copilot solicite permiso.
+ REVIEW=$(timeout 60 copilot --allow-all -p "Quick security review of @$file - critical issues only" 2>/dev/null)
+
+ # Comprobar si se agotó el tiempo de espera
+ if [ $? -eq 124 ]; then
+ echo "Warning: Review timed out for $file (skipping)"
+ continue
+ fi
+
+ if echo "$REVIEW" | grep -qi "CRITICAL"; then
+ echo "Critical issues found in $file:"
+ echo "$REVIEW"
+ exit 1
+ fi
+ done
+
+ echo "Review passed"
+fi
+EOF
+
+chmod +x .git/hooks/pre-commit
+```
+
+> ⚠️ **Usuarios de macOS**: El comando `timeout` no está incluido por defecto en macOS. Instálalo con `brew install coreutils` o reemplaza `timeout 60` con una invocación simple sin límite de tiempo.
+
+> 📚 **Documentación oficial**: [Usar hooks](https://docs.github.com/copilot/how-tos/copilot-cli/use-hooks) y [Referencia de configuración de Hooks](https://docs.github.com/copilot/reference/hooks-configuration) para la API completa de hooks.
+>
+> 💡 **Alternativa incorporada**: Copilot CLI también tiene un sistema de hooks incorporado (`copilot hooks`) que puede ejecutarse automáticamente en eventos como pre-commit. El git hook manual anterior te da control total, mientras que el sistema incorporado es más sencillo de configurar. Consulta la documentación anterior para decidir qué enfoque se adapta a tu flujo de trabajo.
+
+Ahora cada commit recibe una rápida revisión de seguridad:
+
+```bash
+git add samples/book-app-project/books.py
+git commit -m "Update book collection methods"
+
+# Salida:
+# Ejecutando la revisión de Copilot en los archivos preparados...
+# Revisando samples/book-app-project/books.py...
+# Se han encontrado problemas críticos en samples/book-app-project/books.py:
+# - Línea 15: Vulnerabilidad de inyección de ruta de archivo en load_from_file
+#
+# Corrige el problema y vuelve a intentarlo.
+```
+
+---
+
+## Flujo de trabajo 3: Incorporación a una nueva base de código
+
+Al unirte a un nuevo proyecto, combina contexto, agentes y MCP para subir tu ritmo rápidamente:
+
+```bash
+# Inicia Copilot en modo interactivo
+copilot
+
+# FASE 1: Obtén una visión general con contexto
+> @samples/book-app-project/ Explain the high-level architecture of this codebase
+
+# FASE 2: Comprende un flujo específico
+> @samples/book-app-project/book_app.py Walk me through what happens
+> when a user runs "python book_app.py add"
+
+# FASE 3: Obtén un análisis experto con un agente
+> /agent
+# Selecciona "python-reviewer"
+
+> @samples/book-app-project/books.py Are there any design issues,
+> missing error handling, or improvements you would recommend?
+
+# FASE 4: Encuentra algo en lo que trabajar (MCP proporciona acceso a GitHub)
+> List open issues labeled "good first issue"
+
+# FASE 5: Comienza a contribuir
+> Pick the simplest open issue and outline a plan to fix it
+```
+
+Este flujo de trabajo combina el contexto `@`, agentes y MCP en una sola sesión de incorporación, exactamente el patrón de integración visto anteriormente en este capítulo.
+
+---
+
+# Mejores prácticas y automatización
+
+Patrones y hábitos que hacen tus flujos de trabajo más eficaces.
+
+---
+
+## Mejores prácticas
+
+### 1. Comienza con contexto antes de analizar
+
+Siempre reúne contexto antes de solicitar un análisis:
+
+```bash
+# Bueno
+> Get the details of issue #42
+> /agent
+# Seleccionar python-reviewer
+> Analyze this issue
+
+# Menos eficaz
+> /agent
+# Seleccionar python-reviewer
+> Fix login bug
+# El agente no tiene contexto del problema
+```
+
+### 2. Conoce la diferencia: Agents, Skills e Instrucciones personalizadas
+
+Cada herramienta tiene su punto ideal:
+
+```bash
+# Agentes: Personas especializadas que activas explícitamente
+> /agent
+# Selecciona python-reviewer
+> Review this authentication code for security issues
+
+# Habilidades: Capacidades modulares que se activan automáticamente cuando tu prompt
+# coincide con la descripción de la habilidad (debes crearlas primero — ver Cap. 05)
+> Generate comprehensive tests for this code
+# Si tienes una habilidad de pruebas configurada, se activa automáticamente
+
+# Instrucciones personalizadas (.github/copilot-instructions.md): Siempre activas
+# orientación que se aplica a cada sesión sin necesidad de cambiar o activar
+```
+
+> 💡 **Punto clave**: Agents y skills pueden tanto analizar COMO generar código. La verdadera diferencia es **cómo se activan** — los agents son explícitos (`/agent`), las skills son automáticas (se activan por coincidencia de prompt), y las instrucciones personalizadas están siempre activas.
+
+### 3. Mantén las sesiones centradas
+
+Usa `/rename` para etiquetar tu sesión (hace que sea fácil de encontrar en el historial) y `/exit` para cerrarla correctamente:
+
+```bash
+# Bueno: Una característica por sesión
+> /rename list-unread-feature
+# Trabajar en la lista de no leídos
+> /exit
+
+copilot
+> /rename export-csv-feature
+# Trabajar en la exportación a CSV
+> /exit
+
+# Menos efectivo: Todo en una sola sesión larga
+```
+
+### 4. Haz los flujos de trabajo reutilizables con Copilot
+
+En lugar de solo documentar los flujos de trabajo en una wiki, codifícalos directamente en tu repo donde Copilot pueda usarlos:
+
+- **Instrucciones personalizadas** (`.github/copilot-instructions.md`): Orientación siempre activa para estándares de codificación, reglas de arquitectura y pasos de compilación/prueba/despliegue. Cada sesión las sigue automáticamente.
+- **Archivos de prompts** (`.github/prompts/`): Prompts reutilizables y parametrizados que tu equipo puede compartir — como plantillas para revisiones de código, generación de componentes o descripciones de PR.
+- **Agentes personalizados** (`.github/agents/`): Codifica personas especializadas (p. ej., un revisor de seguridad o un redactor de documentación) que cualquiera en el equipo puede activar con `/agent`.
+- **Skills personalizadas** (`.github/skills/`): Empaqueta instrucciones paso a paso para flujos de trabajo que se activan automáticamente cuando son relevantes.
+
+> 💡 **La recompensa**: Los nuevos miembros del equipo obtienen tus flujos de trabajo gratis — están integrados en el repo, no atrapados en la cabeza de alguien.
+
+---
+
+## Bonus: Patrones de producción
+
+Estos patrones son opcionales pero valiosos para entornos profesionales.
+
+### Generador de descripción de PR
+
+```bash
+# Generar descripciones completas de PR
+BRANCH=$(git branch --show-current)
+COMMITS=$(git log main..$BRANCH --oneline)
+
+copilot -p "Generate a PR description for:
+Branch: $BRANCH
+Commits:
+$COMMITS
+
+Include: Summary, Changes Made, Testing Done, Screenshots Needed"
+```
+
+### Integración CI/CD
+
+Para equipos con pipelines de CI/CD existentes, puedes automatizar revisiones de Copilot en cada pull request usando GitHub Actions. Esto incluye publicar comentarios de revisión automáticamente y filtrar problemas críticos.
+
+> 📖 **Más información**: Consulta [CI/CD Integration](../appendices/ci-cd-integration.md) para workflows completos de GitHub Actions, opciones de configuración y consejos de solución de problemas.
+
+---
+
+# Práctica
+
+
+
+Pon el flujo de trabajo completo en práctica.
+
+---
+
+## ▶️ Pruébalo tú mismo
+
+Después de completar las demos, prueba estas variaciones:
+
+1. **Desafío de extremo a extremo**: Elige una pequeña funcionalidad (p. ej., "listar libros no leídos" o "exportar a CSV"). Usa el flujo completo:
+ - Planifica con `/plan`
+ - Diseña con agents (python-reviewer, pytest-helper)
+ - Implementa
+ - Genera pruebas
+ - Crea PR
+
+2. **Desafío de automatización**: Configura el hook de pre-commit del flujo "Automatización de revisión de código". Haz un commit con una vulnerabilidad intencional en la ruta de un archivo. ¿Se bloquea?
+
+3. **Tu flujo de trabajo de producción**: Diseña tu propio flujo para una tarea común que realices. Escríbelo como una lista de verificación. ¿Qué partes podrían automatizarse con skills, agents o hooks?
+
+**Autoevaluación**: Has completado el curso cuando puedas explicarle a un colega cómo agentes, skills y MCP funcionan juntos — y cuándo usar cada uno.
+
+---
+
+## 📝 Tarea
+
+### Reto principal: Funcionalidad de extremo a extremo
+
+Los ejemplos prácticos mostraron cómo construir una funcionalidad "listar libros no leídos". Ahora practica el flujo completo con una funcionalidad diferente: **search books by year range**:
+
+1. Inicia Copilot y reúne contexto: `@samples/book-app-project/books.py`
+2. Planifica con `/plan Add a "search by year" command that lets users find books published between two years`
+3. Implementa un método `find_by_year_range(start_year, end_year)` en `BookCollection`
+4. Añade una función `handle_search_year()` en `book_app.py` que solicite al usuario los años de inicio y fin
+5. Genera pruebas: `@samples/book-app-project/books.py @samples/book-app-project/tests/test_books.py Generate tests for find_by_year_range() including edge cases like invalid years, reversed range, and no results.`
+6. Revisa con `/review`
+7. Actualiza el README: `@samples/book-app-project/README.md Add documentation for the new "search by year" command.`
+8. Genera un mensaje de commit
+
+Documenta tu flujo de trabajo mientras avanzas.
+
+**Criterios de éxito**: Has completado la funcionalidad desde la idea hasta el commit usando Copilot CLI, incluyendo planificación, implementación, pruebas, documentación y revisión.
+
+> 💡 **Bonus**: Si tienes agentes configurados desde el Capítulo 04, intenta crear y usar agentes personalizados. Por ejemplo, un agente de manejo de errores para la revisión de implementación y un agente redactor de docs para la actualización del README.
+
+
+💡 Pistas (haz clic para expandir)
+
+**Sigue el patrón del ejemplo ["De idea a PR fusionado"](#de-idea-a-pr-fusionado-en-una-sola-sesión)** al inicio de este capítulo. Los pasos clave son:
+
+1. Reúne contexto con `@samples/book-app-project/books.py`
+2. Planifica con `/plan Add a "search by year" command`
+3. Implementa el método y el manejador de comando
+4. Genera pruebas con casos límite (entrada inválida, sin resultados, rango invertido)
+5. Revisa con `/review`
+6. Actualiza el README con `@samples/book-app-project/README.md`
+7. Genera el mensaje de commit con `-p`
+
+**Casos límite a considerar:**
+- ¿Qué pasa si el usuario introduce "2000" y "1990" (rango invertido)?
+- ¿Qué pasa si no hay libros que coincidan con el rango?
+- ¿Qué pasa si el usuario introduce datos no numéricos?
+
+**La clave es practicar el flujo completo** desde idea → contexto → plan → implementar → probar → documentar → commit.
+
+
+
+---
+
+
+🔧 Errores comunes (haz clic para expandir)
+
+| Error | Qué sucede | Solución |
+|---------|--------------|-----|
+| Saltar directamente a la implementación | Se pasan por alto problemas de diseño que son costosos de corregir después | Usa `/plan` primero para pensar en el enfoque |
+| Usar una sola herramienta cuando varias ayudarían | Resultados más lentos y menos exhaustivos | Combina: Agent para análisis → Skill para ejecución → MCP para integración |
+| No revisar antes de commitear | Problemas de seguridad o bugs se escapan | Siempre ejecuta `/review` o usa un [pre-commit hook](#codeblock1) |
+| Olvidar compartir los flujos con el equipo | Cada persona reinventa la rueda | Documenta los patrones en agentes, skills e instrucciones compartidas |
+
+
+
+---
+
+# Resumen
+
+## 🔑 Puntos clave
+
+1. **Integración > Aislamiento**: Combina herramientas para un impacto máximo
+2. **Contexto primero**: Siempre reúne el contexto requerido antes de analizar
+3. **Agentes analizan, Skills ejecutan**: Usa la herramienta adecuada para cada tarea
+4. **Automatiza lo repetitivo**: Hooks y scripts multiplican tu efectividad
+5. **Documenta los flujos de trabajo**: Los patrones compartibles benefician a todo el equipo
+> 📋 **Referencia rápida**: Consulta la [Referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference) para obtener una lista completa de comandos y atajos.
+
+---
+
+## 🎓 ¡Curso completado!
+
+¡Felicidades! Has aprendido:
+
+| Chapter | Qué aprendiste |
+|---------|-------------------|
+| 00 | Instalación de Copilot CLI y inicio rápido |
+| 01 | Tres modos de interacción |
+| 02 | Gestión de contexto con la sintaxis @ |
+| 03 | Flujos de trabajo de desarrollo |
+| 04 | Agentes especializados |
+| 05 | Habilidades extensibles |
+| 06 | Conexiones externas con MCP |
+| 07 | Flujos de trabajo de producción unificados |
+
+Ahora estás preparado para usar GitHub Copilot CLI como un verdadero multiplicador de fuerza en tu flujo de trabajo de desarrollo.
+
+## ➡️ ¿Qué sigue?
+
+Tu aprendizaje no termina aquí:
+
+1. **Practica a diario**: Usa Copilot CLI para trabajo real
+2. **Crea herramientas personalizadas**: Crea agentes y habilidades para tus necesidades específicas
+3. **Comparte conocimiento**: Ayuda a tu equipo a adoptar estos flujos de trabajo
+4. **Mantente actualizado**: Sigue las actualizaciones de GitHub Copilot para nuevas funciones
+
+### Recursos
+
+- [Documentación de GitHub Copilot CLI](https://docs.github.com/copilot/concepts/agents/about-copilot-cli)
+- [Registro de servidores MCP](https://github.com/modelcontextprotocol/servers)
+- [Habilidades de la comunidad](https://github.com/topics/copilot-skill)
+
+---
+
+**¡Buen trabajo! Ahora ve y construye algo increíble.**
+
+**[← Volver al Capítulo 06](../06-mcp-servers/README.md)** | **[Volver al inicio del curso →](../README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/AGENTS.md b/translations/es/AGENTS.md
new file mode 100644
index 00000000..686f6d47
--- /dev/null
+++ b/translations/es/AGENTS.md
@@ -0,0 +1,46 @@
+# AGENTS.md
+
+Curso para principiantes que enseña GitHub Copilot CLI. Contenido educativo, no software.
+
+## Estructura
+
+| Path | Propósito |
+|------|---------|
+| `00-07/` | Capítulos: analogía → conceptos → práctico → tarea → siguiente |
+| `samples/book-app-project/` | **Muestra principal**: Aplicación CLI de Python para gestionar una colección de libros usada en todos los capítulos |
+| `samples/book-app-project-cs/` | Versión en C# de la aplicación de colección de libros |
+| `samples/book-app-project-js/` | Versión en JavaScript de la aplicación de colección de libros |
+| `samples/book-app-buggy/` | **Errores intencionales** para ejercicios de depuración (Cap. 03) |
+| `samples/agents/` | Ejemplos de plantillas de agentes (python-reviewer, pytest-helper, hello-world) |
+| `samples/skills/` | Ejemplos de plantillas de skills (code-checklist, pytest-gen, commit-message, hello-world) |
+| `samples/mcp-configs/` | Ejemplos de configuración del servidor MCP |
+| `samples/buggy-code/` | **Extra opcional**: Código con errores enfocado en seguridad (JS y Python) |
+| `samples/src/` | **Extra opcional**: Ejemplos heredados de JS/React de una versión anterior del curso |
+| `appendices/` | Material de referencia complementario |
+
+## Hacer
+
+- Mantener las explicaciones amigables para principiantes; explicar la jerga de IA/ML cuando se utilice
+- Asegurarse de que los ejemplos en bash estén listos para copiar y pegar
+- Tono: amistoso, alentador, práctico
+- Usar rutas `samples/book-app-project/` en todos los ejemplos principales
+- Usar contexto de Python/pytest para los ejemplos de código
+
+## No hacer
+
+- Corregir errores en `samples/book-app-buggy/` o `samples/buggy-code/` — son intencionales
+- Agregar capítulos sin actualizar la tabla del curso en README.md
+- Asumir que los lectores conocen la terminología de IA/ML
+
+## Compilación
+
+```bash
+npm install && npm run release
+```
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/CODE_OF_CONDUCT.md b/translations/es/CODE_OF_CONDUCT.md
new file mode 100644
index 00000000..e67fd7b5
--- /dev/null
+++ b/translations/es/CODE_OF_CONDUCT.md
@@ -0,0 +1,133 @@
+# Código de Conducta del Contributor Covenant
+
+## Nuestro Compromiso
+
+Nosotros, como miembros, colaboradores y líderes, nos comprometemos a hacer que la participación en nuestra
+comunidad sea una experiencia libre de acoso para todas las personas, independientemente de la edad, el tamaño
+corporal, una discapacidad visible o invisible, la etnia, las características sexuales, la identidad
+y expresión de género, el nivel de experiencia, la educación, la condición socioeconómica,
+nacionalidad, la apariencia personal, la raza, la religión, o la identidad sexual
+y orientación.
+
+Nos comprometemos a actuar e interactuar de maneras que contribuyan a una comunidad abierta, acogedora,
+diversa, inclusiva y saludable.
+
+## Nuestros Estándares
+
+Ejemplos de comportamientos que contribuyen a un entorno positivo para nuestra
+comunidad incluyen:
+
+* Demostrar empatía y amabilidad hacia otras personas
+* Ser respetuoso con opiniones, puntos de vista y experiencias diferentes
+* Dar y aceptar con gracia comentarios constructivos
+* Asumir la responsabilidad y pedir disculpas a quienes se vieron afectados por nuestros errores,
+ y aprender de la experiencia
+* Centrarse en lo que es mejor no solo para nosotros como individuos, sino para la
+ comunidad en general
+
+Ejemplos de comportamientos inaceptables incluyen:
+
+* El uso de lenguaje o imágenes sexualizados, y la atención o avances sexuales de cualquier tipo
+* Troleo, comentarios insultantes o despectivos, y ataques personales o políticos
+* Acoso público o privado
+* Publicar información privada de otras personas, como una dirección física o de correo electrónico, sin su permiso explícito
+* Otra conducta que razonablemente podría considerarse inapropiada en un
+ entorno profesional
+
+## Responsabilidades de Aplicación
+
+Los líderes de la comunidad son responsables de clarificar y hacer cumplir nuestros estándares de
+comportamiento aceptable y tomarán medidas correctivas apropiadas y justas en
+respuesta a cualquier comportamiento que consideren inapropiado, amenazante, ofensivo,
+o dañino.
+
+Los líderes de la comunidad tienen el derecho y la responsabilidad de eliminar, editar o rechazar
+comentarios, commits, código, ediciones de wiki, issues y otras contribuciones que no estén
+alineadas con este Código de Conducta, y comunicarán las razones para las decisiones de
+moderación cuando sea apropiado.
+
+## Alcance
+
+Este Código de Conducta se aplica dentro de todos los espacios de la comunidad, y también se aplica cuando
+una persona representa oficialmente a la comunidad en espacios públicos.
+Ejemplos de representar a nuestra comunidad incluyen usar una dirección de correo electrónico oficial,
+publicar a través de una cuenta oficial en redes sociales, o actuar como un
+representante designado en un evento en línea o presencial.
+
+## Aplicación
+
+Los casos de comportamiento abusivo, de acoso o de otro modo inaceptable pueden ser
+reportados a los líderes de la comunidad responsables de la aplicación en
+GitHub.
+Todas las quejas serán revisadas e investigadas de manera pronta y justa.
+
+Todos los líderes de la comunidad están obligados a respetar la privacidad y la seguridad de la
+persona que informe cualquier incidente.
+
+## Directrices de Aplicación
+
+Los líderes de la comunidad seguirán estas Directrices de Impacto Comunitario al determinar
+las consecuencias de cualquier acción que consideren una violación de este Código de Conducta:
+
+### 1. Corrección
+
+**Impacto en la comunidad**: Uso de un lenguaje inapropiado u otro comportamiento considerado
+poco profesional o no bienvenido en la comunidad.
+
+**Consecuencia**: Una advertencia privada y por escrito por parte de los líderes de la comunidad, que
+aclare la naturaleza de la violación y una explicación de por qué el
+comportamiento fue inapropiado. Se puede solicitar una disculpa pública.
+
+### 2. Advertencia
+
+**Impacto en la comunidad**: Una violación mediante un único incidente o una serie
+de acciones.
+
+**Consecuencia**: Una advertencia con consecuencias por la continuación del comportamiento. No
+interacción con las personas involucradas, incluida la interacción no solicitada con
+quienes hacen cumplir el Código de Conducta, durante un periodo de tiempo especificado. Esto
+incluye evitar interacciones en los espacios de la comunidad así como en canales externos
+como las redes sociales. Violar estos términos puede llevar a una prohibición temporal o
+permanente.
+
+### 3. Prohibición temporal
+
+**Impacto en la comunidad**: Una violación grave de los estándares de la comunidad, incluyendo
+comportamiento inapropiado sostenido.
+
+**Consecuencia**: Una prohibición temporal de cualquier tipo de interacción o comunicación pública
+con la comunidad por un periodo de tiempo especificado. No se permite interacción pública ni
+privada con las personas involucradas, incluida la interacción no solicitada
+con quienes hacen cumplir el Código de Conducta, durante este periodo.
+Violar estos términos puede llevar a una prohibición permanente.
+
+### 4. Prohibición permanente
+
+**Impacto en la comunidad**: Demostrar un patrón de violación de los estándares de la
+comunidad, incluyendo comportamiento inapropiado sostenido, acoso a un
+individuo, o agresión hacia o menosprecio de clases de individuos.
+
+**Consecuencia**: Una prohibición permanente de cualquier tipo de interacción pública dentro
+de la comunidad.
+
+## Atribución
+
+Este Código de Conducta está adaptado del [Contributor Covenant][homepage],
+versión 2.0, disponible en
+https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
+
+Las Directrices de Impacto Comunitario fueron inspiradas por [la escalera de aplicación del código de conducta de Mozilla
+](https://github.com/mozilla/diversity).
+
+[homepage]: https://www.contributor-covenant.org
+
+Para respuestas a preguntas comunes sobre este código de conducta, consulte las FAQ en
+https://www.contributor-covenant.org/faq. Las traducciones están disponibles en
+https://www.contributor-covenant.org/translations.
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/CONTRIBUTING.md b/translations/es/CONTRIBUTING.md
new file mode 100644
index 00000000..70a988a2
--- /dev/null
+++ b/translations/es/CONTRIBUTING.md
@@ -0,0 +1,17 @@
+## Contribuir
+
+[fork]: https://github.com/github/REPO/fork
+[pr]: https://github.com/github/REPO/compare
+
+¡Hola! Nos entusiasma que quieras contribuir a este proyecto. Tu ayuda es esencial para que siga siendo excelente.
+
+Las contribuciones a este proyecto se [publican](https://help.github.com/articles/github-terms-of-service/#6-contributions-under-repository-license) para el público bajo la [licencia de código abierto del proyecto](../../LICENSE.txt).
+
+Ten en cuenta que este proyecto se publica con un [Código de conducta para colaboradores](CODE_OF_CONDUCT.md). Al participar en este proyecto, aceptas cumplir con sus términos.
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/GLOSSARY.md b/translations/es/GLOSSARY.md
new file mode 100644
index 00000000..e8d5deb2
--- /dev/null
+++ b/translations/es/GLOSSARY.md
@@ -0,0 +1,176 @@
+# Glosario
+
+Referencia rápida de términos técnicos usados a lo largo de este curso. No te preocupes por memorizar estos ahora; consúltalos según los necesites.
+
+---
+
+## A
+
+### Agent
+
+Una personalidad de IA especializada con experiencia en un dominio (por ejemplo, frontend, seguridad). Definida en archivos `.agent.md` con frontmatter YAML que contiene como mínimo un campo `description`.
+
+### API
+
+Interfaz de Programación de Aplicaciones. Una forma para que los programas se comuniquen entre sí.
+
+---
+
+## C
+
+### CI/CD
+
+Integración Continua/Despliegue Continuo. Pipelines automatizados de pruebas y despliegue.
+
+### CLI
+
+Interfaz de Línea de Comandos. Una forma basada en texto para interactuar con software (¡como esta herramienta!).
+
+### Context Window
+
+La cantidad de texto que una IA puede considerar a la vez. Como un escritorio que solo puede contener cierta cantidad. Cuando agregas archivos, el historial de conversación y los prompts del sistema, todos ocupan espacio en esta ventana.
+
+### Context Manager
+
+Un constructo de Python que usa la sentencia `with` y que maneja automáticamente la configuración y la limpieza (como abrir y cerrar archivos). Ejemplo: `with open("file.txt") as f:` asegura que el archivo se cierre incluso si ocurre un error.
+
+### Conventional Commit
+
+Un formato de mensaje de commit que sigue una estructura estandarizada: `type(scope): description`. Los tipos comunes incluyen `feat` (nueva característica), `fix` (corrección de errores), `docs` (documentación), `refactor` y `test`. Ejemplo: `feat(auth): add password reset flow`.
+
+### Dataclass
+
+Un decorador de Python (`@dataclass`) que genera automáticamente `__init__`, `__repr__` y otros métodos para clases que principalmente almacenan datos. Usado en la aplicación del libro para definir la clase `Book` con campos como `title`, `author`, `year` y `read`.
+
+---
+
+## F
+
+### Frontmatter
+
+Metadatos en la parte superior de un archivo Markdown encerrados entre los delimitadores `---`. Usado en archivos de agent y skill para definir propiedades como `description` y `name` en formato YAML.
+
+---
+
+## G
+
+### Glob Pattern
+
+Un patrón que usa comodines para hacer coincidir rutas de archivos (por ejemplo, `*.py` coincide con todos los archivos Python, `*.js` coincide con todos los archivos JavaScript).
+
+---
+
+## J
+
+### JWT
+
+JSON Web Token. Una forma segura de transmitir información de autenticación entre sistemas.
+
+---
+
+## M
+
+### MCP
+
+Model Context Protocol. Un estándar para conectar asistentes de IA a fuentes de datos externas.
+
+---
+
+### Memory (Copilot CLI)
+
+Una característica que permite que Copilot CLI recuerde hechos y preferencias a través de todas las sesiones, no solo dentro de una sola. A diferencia del historial de sesión (que guarda una conversación específica), la memoria persiste globalmente y se aplica automáticamente en sesiones futuras. Se administra con el comando slash `/memory` (`/memory on`, `/memory off`, `/memory show`). La memoria puede estar limitada a tu cuenta de usuario (visible en todos los repositorios) o a un repositorio específico (compartida con colaboradores).
+
+---
+
+## N
+
+### npx
+
+Una herramienta de Node.js que ejecuta paquetes npm sin instalarlos globalmente. Usada en configuraciones de servidores MCP para lanzar servidores (por ejemplo, `npx @modelcontextprotocol/server-filesystem`).
+
+---
+
+## O
+
+### OWASP
+
+Open Web Application Security Project. Una organización que publica buenas prácticas de seguridad y mantiene la lista "OWASP Top 10" de los riesgos de seguridad más críticos en aplicaciones web.
+
+---
+
+## P
+
+### PEP 8
+
+Python Enhancement Proposal 8. La guía de estilo oficial para código Python, que cubre convenciones de nombres (snake_case para funciones, PascalCase para clases), indentación (4 spaces) y disposición del código. Seguir PEP 8 hace que el código Python sea consistente y legible.
+
+### Pre-commit Hook
+
+Un script que se ejecuta automáticamente antes de cada `git commit`. Puede usarse para ejecutar revisiones de seguridad de Copilot o comprobaciones de calidad de código antes de que el código se confirme.
+
+### pytest
+
+Un framework de pruebas popular para Python conocido por su sintaxis simple, fixtures potentes y ecosistema de plugins. Usado a lo largo de este curso para probar la aplicación del libro. Las pruebas se ejecutan con `python -m pytest tests/`.
+
+### Programmatic Mode
+
+Ejecutar Copilot con la bandera `-p` para comandos únicos sin interacción.
+
+---
+
+## R
+
+### Rate Limiting
+
+Restricciones sobre cuántas solicitudes puedes hacer a una API dentro de un periodo de tiempo. Copilot puede limitar temporalmente las respuestas si excedes la cuota de uso de tu plan.
+
+---
+
+## S
+
+### Session
+
+Una conversación con Copilot que mantiene contexto y puede reanudarse más tarde.
+
+### Skill
+
+Una carpeta con instrucciones que Copilot carga automáticamente cuando son relevantes para tu prompt. Definida en archivos `SKILL.md` con frontmatter YAML.
+
+### Slash Command
+
+Comandos que comienzan con `/` que controlan Copilot (por ejemplo, `/help`, `/clear`, `/model`).
+
+---
+
+## T
+
+### Token
+
+Una unidad de texto que los modelos de IA procesan. Aproximadamente 4 caracteres o 0.75 palabras. Usado para medir tanto la entrada (tus prompts y el contexto) como la salida (respuestas de la IA).
+
+### Type Hints
+
+Anotaciones de Python que indican los tipos esperados de los parámetros de funciones y de los valores de retorno (por ejemplo, `def add_book(title: str, year: int) -> Book:`). No imponen tipos en tiempo de ejecución, pero ayudan con la claridad del código, el soporte del IDE y herramientas de análisis estático como mypy.
+
+---
+
+## W
+
+### WCAG
+
+Web Content Accessibility Guidelines. Estándares publicados por el W3C para hacer el contenido web accesible a personas con discapacidades. WCAG 2.1 AA es un objetivo común de cumplimiento.
+
+---
+
+## Y
+
+### YAML
+
+YAML no es un lenguaje de marcado. Un formato de datos legible por humanos usado para configuración. En este curso, YAML aparece en el frontmatter de agent y skill (el bloque delimitado por `---` en la parte superior de los archivos `.agent.md` y `SKILL.md`).
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/README.md b/translations/es/README.md
new file mode 100644
index 00000000..7c283060
--- /dev/null
+++ b/translations/es/README.md
@@ -0,0 +1,122 @@
+
+
+
+
+[](../../LICENSE)
+[](https://codespaces.new/github/copilot-cli-for-beginners?hide_repo_select=true&ref=main&quickstart=true)
+[](https://docs.github.com/en/copilot/how-tos/copilot-cli)
+[](https://aka.ms/foundry/discord)
+
+🎯 [Qué aprenderás](#qué-aprenderás) ✅ [Requisitos previos](#requisitos-previos) 🤖 [Comprender la familia GitHub Copilot](#comprender-la-familia-github-copilot) 📚 [Estructura del curso](#estructura-del-curso) 📋 [Referencia de comandos de GitHub Copilot CLI](#referencia-de-comandos-de-github-copilot-cli)
+
+# GitHub Copilot CLI para principiantes
+
+> **✨ Aprende a potenciar tu flujo de trabajo de desarrollo con asistencia en la línea de comandos impulsada por IA.**
+
+GitHub Copilot CLI lleva la asistencia de IA directamente a tu terminal. En lugar de cambiar a un navegador o editor de código, puedes hacer preguntas, generar aplicaciones completas, revisar código, generar pruebas y depurar problemas sin salir de tu línea de comandos.
+
+Piénsalo como tener un colega conocedor disponible 24/7 que puede leer tu código, explicar patrones confusos y ayudarte a trabajar más rápido.
+
+> 📘 **¿Prefieres una experiencia web?** Puedes seguir este curso aquí en GitHub, o verlo en [Awesome Copilot](https://awesome-copilot.github.com/learning-hub/cli-for-beginners/) para una experiencia de navegación más tradicional.
+
+Este curso está diseñado para:
+
+- **Desarrolladores de software** que quieren usar IA desde la línea de comandos
+- **Usuarios de terminal** que prefieren flujos de trabajo impulsados por teclado en lugar de integraciones en IDE
+- **Equipos que buscan estandarizar** prácticas de revisión de código y desarrollo asistido por IA
+
+## 🎯 Qué aprenderás
+
+Este curso práctico te lleva de cero a productivo con GitHub Copilot CLI. Trabajarás con una única aplicación de colección de libros en Python a lo largo de todos los capítulos, mejorándola progresivamente usando flujos de trabajo asistidos por IA. Al final, usarás la IA con confianza para revisar código, generar pruebas, depurar problemas y automatizar flujos de trabajo: todo desde tu terminal.
+
+**No se requiere experiencia previa con IA.** Si sabes usar un terminal, puedes aprender esto.
+
+**Perfecto para:** Desarrolladores, estudiantes y cualquier persona con experiencia en desarrollo de software.
+
+## ✅ Requisitos previos
+
+Antes de empezar, asegúrate de tener:
+
+- **Cuenta de GitHub**: [Crea una gratis](https://github.com/signup)
+- **Acceso a GitHub Copilot**: [Oferta gratuita](https://github.com/features/copilot/plans), [Suscripción mensual](https://github.com/features/copilot/plans), o [Gratis para estudiantes/profesores](https://education.github.com/pack)
+- **Conceptos básicos de terminal**: Cómodo con `cd`, `ls`, ejecutar comandos
+
+## 🤖 Comprender la familia GitHub Copilot
+
+GitHub Copilot ha evolucionado a una familia de herramientas impulsadas por IA. Aquí es donde vive cada una:
+
+| Producto | Dónde se ejecuta | Descripción |
+|---------|---------------|----------|
+| [**GitHub Copilot CLI**](https://docs.github.com/copilot/how-tos/copilot-cli/cli-getting-started) (este curso) | Tu terminal | Asistente de codificación con IA nativo de terminal |
+| [**GitHub Copilot**](https://docs.github.com/copilot) | VS Code, Visual Studio, JetBrains, etc. | Modo agente, chat, sugerencias en línea |
+| [**Copilot on GitHub.com**](https://github.com/copilot) | GitHub | Chat inmersivo sobre tus repositorios, crea agentes y más |
+| [**GitHub Copilot cloud agent**](https://docs.github.com/copilot/using-github-copilot/using-copilot-coding-agent-to-work-on-tasks) | GitHub | Asigna issues a agentes, recibe PRs de vuelta |
+
+Este curso se centra en **GitHub Copilot CLI**, llevando la asistencia de IA directamente a tu terminal.
+
+## 📚 Estructura del curso
+
+
+
+| Capítulo | Título | Qué construirás |
+|:-------:|-------|-------------------|
+| 00 | 🚀 [Inicio rápido](./00-quick-start/README.md) | Instalación y verificación |
+| 01 | 👋 [Primeros pasos](./01-setup-and-first-steps/README.md) | Demostraciones en vivo + tres modos de interacción |
+| 02 | 🔍 [Contexto y conversaciones](./02-context-conversations/README.md) | Análisis de proyectos con múltiples archivos |
+| 03 | ⚡ [Flujos de trabajo de desarrollo](./03-development-workflows/README.md) | Revisión de código, depuración, generación de pruebas |
+| 04 | 🤖 [Crear asistentes de IA especializados](./04-agents-custom-instructions/README.md) | Agentes personalizados para tu flujo de trabajo |
+| 05 | 🛠️ [Automatizar tareas repetitivas](./05-skills/README.md) | Habilidades que se cargan automáticamente |
+| 06 | 🔌 [Conectar con GitHub, bases de datos y APIs](./06-mcp-servers/README.md) | Integración de servidores MCP |
+| 07 | 🎯 [Integrándolo todo](./07-putting-it-together/README.md) | Flujos de trabajo completos de funciones |
+
+## 📖 Cómo funciona este curso
+
+Cada capítulo sigue el mismo patrón:
+
+1. **Analogía del mundo real**: Entiende el concepto mediante comparaciones familiares
+2. **Conceptos clave**: Aprende el conocimiento esencial
+3. **Ejemplos prácticos**: Ejecuta comandos reales y ve los resultados
+4. **Tarea**: Practica lo que aprendiste
+5. **Qué sigue**: Vista previa del siguiente capítulo
+
+**Los ejemplos de código se pueden ejecutar.** Cada bloque de texto de Copilot en este curso puede copiarse y ejecutarse en tu terminal.
+
+## 📋 Referencia de comandos de GitHub Copilot CLI
+
+La **[Referencia de comandos de GitHub Copilot CLI](https://docs.github.com/en/copilot/reference/cli-command-reference)** te ayuda a encontrar comandos y atajos de teclado para usar Copilot CLI de forma efectiva.
+
+## 🙋 Obtener ayuda
+
+- 🐛 **¿Encontraste un error?** [Abre un Issue](https://github.com/github/copilot-cli-for-beginners/issues)
+- 📚 **Documentación oficial:** [Documentación de GitHub Copilot CLI](https://docs.github.com/copilot/concepts/agents/about-copilot-cli)
+
+## Contribuir
+
+> **Nota**: El código usado en el curso está diseñado para generar tipos específicos de salida durante revisiones, explicaciones y depuración, por lo que no podemos aceptar PRs que cambien el código existente.
+
+**Cómo contribuir:**
+
+1. Haz un fork de este repositorio y clónalo en tu máquina
+2. Crea una rama de características (`git checkout -b my-improvement`)
+3. Realiza tus cambios
+4. Envía un pull request
+
+## Licencia
+
+Este proyecto está licenciado bajo los términos de la licencia de código abierto MIT. Consulta el archivo [LICENSE](../../LICENSE) para los términos completos.
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/SECURITY.md b/translations/es/SECURITY.md
new file mode 100644
index 00000000..24c43984
--- /dev/null
+++ b/translations/es/SECURITY.md
@@ -0,0 +1,38 @@
+Gracias por ayudar a que GitHub sea seguro para todos.
+
+# Seguridad
+
+GitHub se toma en serio la seguridad de nuestros productos de software y servicios, incluidos todos los repositorios de código abierto gestionados a través de nuestras organizaciones de GitHub, como [GitHub](https://github.com/GitHub).
+
+Aunque [los repositorios de código abierto están fuera del alcance de nuestro programa de recompensas por errores](https://bounty.github.com/index.html#scope) y, por lo tanto, no son elegibles para recompensas, nos aseguraremos de que su hallazgo se comunique a los mantenedores apropiados para su remediación.
+
+## Reportar problemas de seguridad
+
+Si cree que ha encontrado una vulnerabilidad de seguridad en cualquier repositorio propiedad de GitHub, infórmenos a través de una divulgación coordinada.
+
+**Por favor, no informe vulnerabilidades de seguridad a través de problemas públicos de GitHub, discusiones o pull requests.**
+
+En su lugar, envíe un correo electrónico a opensource-security[@]github.com.
+
+Incluya tanta de la información que se indica a continuación como pueda para ayudarnos a comprender y resolver mejor el problema:
+
+ * El tipo de problema (p. ej., desbordamiento de búfer, inyección SQL o cross-site scripting)
+ * Rutas completas de los archivos fuente relacionados con la manifestación del problema
+ * La ubicación del código fuente afectado (tag/branch/commit or direct URL)
+ * Cualquier configuración especial necesaria para reproducir el problema
+ * Instrucciones paso a paso para reproducir el problema
+ * Código de prueba de concepto o de explotación (si es posible)
+ * Impacto del problema, incluyendo cómo un atacante podría explotar la vulnerabilidad
+
+Esta información nos ayudará a clasificar su informe más rápidamente.
+
+## Política
+
+Consulte [GitHub's Safe Harbor Policy](https://docs.github.com/en/site-policy/security-policies/github-bug-bounty-program-legal-safe-harbor#1-safe-harbor-terms)
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/SUPPORT.md b/translations/es/SUPPORT.md
new file mode 100644
index 00000000..2658409f
--- /dev/null
+++ b/translations/es/SUPPORT.md
@@ -0,0 +1,18 @@
+# Soporte
+
+## Cómo presentar incidencias y obtener ayuda
+
+Este proyecto utiliza las incidencias de GitHub para rastrear errores y solicitudes de funciones. Por favor, busque en las incidencias existentes antes de crear nuevas para evitar duplicados. Para nuevas incidencias, presente su informe de error o solicitud de función como una nueva incidencia.
+
+Para obtener ayuda o si tiene preguntas sobre el uso de este proyecto, por favor abra una incidencia.
+
+## Política de soporte de GitHub
+
+El soporte para este proyecto se limita a los recursos enumerados anteriormente.
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/appendices/README.md b/translations/es/appendices/README.md
new file mode 100644
index 00000000..fcf2c0c5
--- /dev/null
+++ b/translations/es/appendices/README.md
@@ -0,0 +1,30 @@
+
+
+# Apéndices
+
+Estos apéndices cubren temas adicionales que amplían el contenido principal del curso. Son lecturas opcionales para cuando necesites estas capacidades específicas.
+
+| Apéndice | Descripción | Prerrequisito |
+|----------|-------------|--------------|
+| [Funciones de contexto adicionales](additional-context.md) | Trabajo con imágenes y permisos en múltiples directorios | Capítulo 02 |
+| [Integración CI/CD](ci-cd-integration.md) | Flujos de trabajo de GitHub Actions para revisiones automatizadas | Capítulo 07 |
+
+---
+
+**[← Volver al inicio del curso](../README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/appendices/additional-context.md b/translations/es/appendices/additional-context.md
new file mode 100644
index 00000000..c7642e28
--- /dev/null
+++ b/translations/es/appendices/additional-context.md
@@ -0,0 +1,158 @@
+
+
+# Características adicionales de contexto
+
+> 📖 **Requisito previo**: Completa [Capítulo 02: Contexto y conversaciones](../02-context-conversations/README.md) antes de leer este apéndice.
+
+Este apéndice cubre dos funciones de contexto adicionales: trabajar con imágenes y administrar permisos en múltiples directorios.
+
+---
+
+## Trabajar con imágenes
+
+Puedes incluir imágenes en tus conversaciones usando la sintaxis `@`. Copilot puede analizar capturas de pantalla, maquetas, diagramas y otros contenidos visuales.
+
+### Referencia básica de imágenes
+
+```bash
+copilot
+
+> @screenshot.png What's happening in this UI?
+
+# Copilot analiza la imagen y responde
+
+> @mockup.png @current-design.png Compare these two designs
+
+# También puedes arrastrar y soltar imágenes o pegar desde el portapapeles
+```
+
+### Formatos de imagen compatibles
+
+| Formato | Mejor para |
+|--------|----------|
+| PNG | Capturas de pantalla, maquetas de UI, diagramas |
+| JPG/JPEG | Fotos, imágenes complejas |
+| GIF | Diagramas simples (solo primer fotograma) |
+| WebP | Capturas de pantalla web |
+
+### Casos prácticos de uso de imágenes
+
+**1. Depuración de la interfaz de usuario**
+```bash
+> @bug-screenshot.png The button doesn't align properly. What CSS might cause this?
+```
+
+**2. Implementación de diseño**
+```bash
+> @figma-export.png Write the HTML and Tailwind CSS to match this design
+```
+
+**3. Análisis de errores**
+```bash
+> @error-screenshot.png What does this error mean and how do I fix it?
+```
+
+**4. Revisión de arquitectura**
+```bash
+> @whiteboard-diagram.png Convert this architecture diagram to a Mermaid diagram I can put in docs
+```
+
+**5. Comparación antes/después**
+```bash
+> @before.png @after.png What changed between these two versions of the UI?
+```
+
+### Combinar imágenes con código
+
+Las imágenes se vuelven aún más poderosas cuando se combinan con el contexto de código:
+
+```bash
+copilot
+
+> @screenshot-of-bug.png @src/components/Header.jsx
+> The header looks wrong in the screenshot. What's causing it in the code?
+```
+
+### Consejos para imágenes
+
+- **Recorta las capturas de pantalla** para mostrar solo las partes relevantes (ahorra tokens de contexto)
+- **Usa alto contraste** para los elementos de la interfaz que quieras analizar
+- **Anota si es necesario** - rodea o resalta las áreas problemáticas antes de subirlas
+- **Una imagen por concepto** - varias imágenes funcionan, pero mantente enfocado
+
+---
+
+## Patrones de permisos
+
+Por defecto, Copilot puede acceder a los archivos en tu directorio actual. Para archivos en otras ubicaciones, necesitas otorgar acceso.
+
+### Agregar directorios
+
+```bash
+# Agregar un directorio a la lista permitida
+copilot --add-dir /path/to/other/project
+
+# Agregar varios directorios
+copilot --add-dir ~/workspace --add-dir /tmp
+```
+
+### Permitir todas las rutas
+
+```bash
+# Desactivar las restricciones de ruta por completo (usar con precaución)
+copilot --allow-all-paths
+```
+
+### Dentro de una sesión
+
+```bash
+copilot
+
+> /add-dir /path/to/other/project
+# Ahora puedes hacer referencia a archivos desde ese directorio
+
+> /list-dirs
+# Ver todos los directorios permitidos
+
+> /yolo
+# Alias rápido para /allow-all activado — aprueba automáticamente todos los avisos de permisos
+```
+
+### Para automatización
+
+```bash
+# Permitir todos los permisos para scripts no interactivos
+copilot -p "Review @src/" --allow-all
+
+# O usa el alias memorable
+copilot -p "Review @src/" --yolo
+```
+
+### Cuando necesitas acceso a múltiples directorios
+
+Escenarios comunes en los que necesitarás estos permisos:
+
+1. **Trabajo en monorepo** - Comparar código entre paquetes
+2. **Refactorización entre proyectos** - Actualizar bibliotecas compartidas
+3. **Proyectos de documentación** - Referenciar múltiples bases de código
+4. **Trabajo de migración** - Comparar implementaciones antiguas y nuevas
+
+---
+
+**[← Volver al Capítulo 02](../02-context-conversations/README.md)** | **[Volver a los apéndices](README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file
diff --git a/translations/es/appendices/ci-cd-integration.md b/translations/es/appendices/ci-cd-integration.md
new file mode 100644
index 00000000..e570e89b
--- /dev/null
+++ b/translations/es/appendices/ci-cd-integration.md
@@ -0,0 +1,217 @@
+
+
+# Integración CI/CD
+
+> 📖 **Prerrequisito**: Completa [Capítulo 07: Poniéndolo todo junto](../07-putting-it-together/README.md) antes de leer este apéndice.
+>
+> ⚠️ **Este apéndice es para equipos con pipelines CI/CD existentes.** Si eres nuevo en GitHub Actions o en conceptos de CI/CD, comienza con el enfoque más sencillo del hook pre-commit en la sección [Automatización de revisión de código](../07-putting-it-together/README.md#workflow-3-code-review-automation-optional) del Capítulo 07.
+
+Este apéndice muestra cómo integrar GitHub Copilot CLI en tus pipelines CI/CD para la revisión automática de código en pull requests.
+
+---
+
+## Flujo de trabajo de GitHub Actions
+
+Este flujo de trabajo revisa automáticamente los archivos cambiados cuando se abre o actualiza un pull request:
+
+```yaml
+# .github/workflows/copilot-review.yml
+name: Copilot Review
+
+on:
+ pull_request:
+ types: [opened, synchronize]
+
+jobs:
+ review:
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v4
+ with:
+ fetch-depth: 0 # Needed to compare with main branch
+
+ - name: Install Copilot CLI
+ run: npm install -g @github/copilot
+
+ - name: Review Changed Files
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ run: |
+ # Get list of changed JS/TS files
+ FILES=$(git diff --name-only origin/main...HEAD | grep -E '\.(js|ts|jsx|tsx)$' || true)
+
+ if [ -z "$FILES" ]; then
+ echo "No JavaScript/TypeScript files changed"
+ exit 0
+ fi
+
+ echo "# Copilot Code Review" > review.md
+ echo "" >> review.md
+
+ for file in $FILES; do
+ echo "Reviewing $file..."
+ echo "## $file" >> review.md
+ echo "" >> review.md
+
+ # Use --silent to suppress progress output
+ copilot --allow-all -p "Quick security and quality review of @$file. List only critical issues." --silent >> review.md 2>/dev/null || echo "Review skipped" >> review.md
+ echo "" >> review.md
+ done
+
+ - name: Post Review Comment
+ uses: actions/github-script@v7
+ with:
+ script: |
+ const fs = require('fs');
+ const review = fs.readFileSync('review.md', 'utf8');
+
+ // Only post if there's meaningful content
+ if (review.includes('CRITICAL') || review.includes('HIGH')) {
+ github.rest.issues.createComment({
+ issue_number: context.issue.number,
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ body: review
+ });
+ } else {
+ console.log('No critical issues found, skipping comment');
+ }
+```
+
+---
+
+## Opciones de configuración
+
+### Limitando el alcance de la revisión
+
+Puedes centrar la revisión en tipos específicos de problemas:
+
+```yaml
+# Security-only review
+copilot --allow-all -p "Security review of @$file. Check for: SQL injection, XSS, hardcoded secrets, authentication issues." --silent
+
+# Performance-only review
+copilot --allow-all -p "Performance review of @$file. Check for: N+1 queries, memory leaks, blocking operations." --silent
+```
+
+### Manejo de PRs grandes
+
+Para PRs con muchos archivos, considera agrupar o limitar:
+
+```yaml
+# Limit to first 10 files
+FILES=$(git diff --name-only origin/main...HEAD | grep -E '\.(js|ts)$' | head -10)
+
+# Or set a timeout per file
+timeout 60 copilot --allow-all -p "Review @$file" --silent || echo "Review timed out"
+```
+
+### Configuración del equipo
+
+Para revisiones consistentes en todo tu equipo, crea una configuración compartida:
+
+```json
+// .copilot/config.json (committed to repo)
+{
+ "model": "claude-sonnet-4.5",
+ "permissions": {
+ "allowedPaths": ["src/**/*", "tests/**/*"],
+ "deniedPaths": [".env*", "secrets/**/*", "*.min.js"]
+ }
+}
+```
+
+---
+
+## Alternativa: Bot de revisión de PR
+
+Para flujos de revisión más sofisticados, considera usar el agente en la nube de GitHub Copilot:
+
+```yaml
+# .github/workflows/copilot-agent-review.yml
+name: Request Copilot Review
+
+on:
+ pull_request:
+ types: [opened, ready_for_review]
+
+jobs:
+ request-review:
+ runs-on: ubuntu-latest
+ steps:
+ - name: Request Copilot Review
+ uses: actions/github-script@v7
+ with:
+ script: |
+ await github.rest.pulls.requestReviewers({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ pull_number: context.issue.number,
+ reviewers: ['copilot[bot]']
+ });
+```
+
+---
+
+## Mejores prácticas para la integración CI/CD
+
+1. **Usa el flag `--silent`** - Suprime la salida de progreso para registros más limpios
+2. **Establece tiempos de espera** - Evita que revisiones colgadas bloqueen tu pipeline
+3. **Filtra tipos de archivo** - Revisa solo archivos relevantes (omite código generado, dependencias)
+4. **Ten en cuenta los límites de tasa** - Espacia las revisiones para PRs grandes
+5. **Falla de forma elegante** - No bloquees los merges por fallos en la revisión; registra y continúa
+
+---
+
+## Resolución de problemas
+
+### "Authentication failed" en CI
+
+Asegúrate de que tu flujo de trabajo tenga los permisos correctos:
+
+```yaml
+permissions:
+ contents: read
+ pull-requests: write
+ issues: write
+```
+
+### Revisiones que alcanzan el tiempo de espera
+
+Aumenta el tiempo de espera o reduce el alcance:
+
+```bash
+timeout 120 copilot --allow-all -p "Quick review of @$file - critical issues only" --silent
+```
+
+### Límites de tokens en archivos grandes
+
+Omite archivos muy grandes:
+
+```bash
+if [ $(wc -l < "$file") -lt 500 ]; then
+ copilot --allow-all -p "Review @$file" --silent
+else
+ echo "Skipping $file (too large)"
+fi
+```
+
+---
+
+**[← Volver al Capítulo 07](../07-putting-it-together/README.md)** | **[Volver a los Apéndices](README.md)**
+
+---
+
+
+**Descargo de responsabilidad**:
+Este documento ha sido traducido utilizando el servicio de traducción automática [Co-op Translator](https://github.com/Azure/co-op-translator). Aunque nos esforzamos por la precisión, tenga en cuenta que las traducciones automatizadas pueden contener errores o inexactitudes. El documento original en su idioma nativo debe considerarse la fuente autorizada. Para información crítica, se recomienda una traducción profesional humana. No somos responsables de cualquier malentendido o interpretación errónea que surja del uso de esta traducción.
+
\ No newline at end of file