@atoms-tech/atoms-mcp 0.2.1 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (129) hide show
  1. package/LICENSE +9 -0
  2. package/README.md +31 -19
  3. package/dist/apps/src/apps/coverage/coverage-app.html +237 -0
  4. package/dist/apps/src/apps/import/import-app.html +239 -0
  5. package/dist/apps/src/apps/mermaid/mermaid-app.html +112 -0
  6. package/dist/apps/src/apps/summary/summary-app.html +279 -0
  7. package/dist/apps/src/apps/trace/trace-app.html +171 -0
  8. package/dist/index.cjs +2 -0
  9. package/dist/index.js +1 -91
  10. package/package.json +21 -5
  11. package/dist/auth/login.d.ts +0 -25
  12. package/dist/auth/login.d.ts.map +0 -1
  13. package/dist/auth/login.js +0 -414
  14. package/dist/auth/login.js.map +0 -1
  15. package/dist/auth/refresh.d.ts +0 -17
  16. package/dist/auth/refresh.d.ts.map +0 -1
  17. package/dist/auth/refresh.js +0 -82
  18. package/dist/auth/refresh.js.map +0 -1
  19. package/dist/auth/token-store.d.ts +0 -34
  20. package/dist/auth/token-store.d.ts.map +0 -1
  21. package/dist/auth/token-store.js +0 -61
  22. package/dist/auth/token-store.js.map +0 -1
  23. package/dist/config.d.ts +0 -19
  24. package/dist/config.d.ts.map +0 -1
  25. package/dist/config.js +0 -19
  26. package/dist/config.js.map +0 -1
  27. package/dist/db/client.d.ts +0 -30
  28. package/dist/db/client.d.ts.map +0 -1
  29. package/dist/db/client.js +0 -110
  30. package/dist/db/client.js.map +0 -1
  31. package/dist/db/graph.d.ts +0 -8
  32. package/dist/db/graph.d.ts.map +0 -1
  33. package/dist/db/graph.js +0 -8
  34. package/dist/db/graph.js.map +0 -1
  35. package/dist/db/queries.d.ts +0 -77
  36. package/dist/db/queries.d.ts.map +0 -1
  37. package/dist/db/queries.js +0 -210
  38. package/dist/db/queries.js.map +0 -1
  39. package/dist/index.d.ts +0 -12
  40. package/dist/index.d.ts.map +0 -1
  41. package/dist/index.js.map +0 -1
  42. package/dist/middleware/audit.d.ts +0 -26
  43. package/dist/middleware/audit.d.ts.map +0 -1
  44. package/dist/middleware/audit.js +0 -44
  45. package/dist/middleware/audit.js.map +0 -1
  46. package/dist/middleware/rate-limiter.d.ts +0 -21
  47. package/dist/middleware/rate-limiter.d.ts.map +0 -1
  48. package/dist/middleware/rate-limiter.js +0 -43
  49. package/dist/middleware/rate-limiter.js.map +0 -1
  50. package/dist/middleware/validator.d.ts +0 -22
  51. package/dist/middleware/validator.d.ts.map +0 -1
  52. package/dist/middleware/validator.js +0 -91
  53. package/dist/middleware/validator.js.map +0 -1
  54. package/dist/server.d.ts +0 -14
  55. package/dist/server.d.ts.map +0 -1
  56. package/dist/server.js +0 -637
  57. package/dist/server.js.map +0 -1
  58. package/dist/tools/_base.d.ts +0 -58
  59. package/dist/tools/_base.d.ts.map +0 -1
  60. package/dist/tools/_base.js +0 -109
  61. package/dist/tools/_base.js.map +0 -1
  62. package/dist/tools/bulk-import.d.ts +0 -70
  63. package/dist/tools/bulk-import.d.ts.map +0 -1
  64. package/dist/tools/bulk-import.js +0 -188
  65. package/dist/tools/bulk-import.js.map +0 -1
  66. package/dist/tools/create-item.d.ts +0 -43
  67. package/dist/tools/create-item.d.ts.map +0 -1
  68. package/dist/tools/create-item.js +0 -118
  69. package/dist/tools/create-item.js.map +0 -1
  70. package/dist/tools/delete-item.d.ts +0 -38
  71. package/dist/tools/delete-item.d.ts.map +0 -1
  72. package/dist/tools/delete-item.js +0 -69
  73. package/dist/tools/delete-item.js.map +0 -1
  74. package/dist/tools/export-mermaid.d.ts +0 -36
  75. package/dist/tools/export-mermaid.d.ts.map +0 -1
  76. package/dist/tools/export-mermaid.js +0 -125
  77. package/dist/tools/export-mermaid.js.map +0 -1
  78. package/dist/tools/get-coverage.d.ts +0 -34
  79. package/dist/tools/get-coverage.d.ts.map +0 -1
  80. package/dist/tools/get-coverage.js +0 -36
  81. package/dist/tools/get-coverage.js.map +0 -1
  82. package/dist/tools/get-history.d.ts +0 -34
  83. package/dist/tools/get-history.d.ts.map +0 -1
  84. package/dist/tools/get-history.js +0 -53
  85. package/dist/tools/get-history.js.map +0 -1
  86. package/dist/tools/get-item.d.ts +0 -62
  87. package/dist/tools/get-item.d.ts.map +0 -1
  88. package/dist/tools/get-item.js +0 -93
  89. package/dist/tools/get-item.js.map +0 -1
  90. package/dist/tools/link-items.d.ts +0 -41
  91. package/dist/tools/link-items.d.ts.map +0 -1
  92. package/dist/tools/link-items.js +0 -150
  93. package/dist/tools/link-items.js.map +0 -1
  94. package/dist/tools/list-items.d.ts +0 -37
  95. package/dist/tools/list-items.d.ts.map +0 -1
  96. package/dist/tools/list-items.js +0 -36
  97. package/dist/tools/list-items.js.map +0 -1
  98. package/dist/tools/list-projects.d.ts +0 -38
  99. package/dist/tools/list-projects.d.ts.map +0 -1
  100. package/dist/tools/list-projects.js +0 -28
  101. package/dist/tools/list-projects.js.map +0 -1
  102. package/dist/tools/project-summary.d.ts +0 -64
  103. package/dist/tools/project-summary.d.ts.map +0 -1
  104. package/dist/tools/project-summary.js +0 -170
  105. package/dist/tools/project-summary.js.map +0 -1
  106. package/dist/tools/record-test-result.d.ts +0 -41
  107. package/dist/tools/record-test-result.d.ts.map +0 -1
  108. package/dist/tools/record-test-result.js +0 -80
  109. package/dist/tools/record-test-result.js.map +0 -1
  110. package/dist/tools/search.d.ts +0 -34
  111. package/dist/tools/search.d.ts.map +0 -1
  112. package/dist/tools/search.js +0 -28
  113. package/dist/tools/search.js.map +0 -1
  114. package/dist/tools/trace.d.ts +0 -53
  115. package/dist/tools/trace.d.ts.map +0 -1
  116. package/dist/tools/trace.js +0 -166
  117. package/dist/tools/trace.js.map +0 -1
  118. package/dist/tools/update-item.d.ts +0 -43
  119. package/dist/tools/update-item.d.ts.map +0 -1
  120. package/dist/tools/update-item.js +0 -98
  121. package/dist/tools/update-item.js.map +0 -1
  122. package/dist/types/responses.d.ts +0 -58
  123. package/dist/types/responses.d.ts.map +0 -1
  124. package/dist/types/responses.js +0 -6
  125. package/dist/types/responses.js.map +0 -1
  126. package/dist/types/work-item.d.ts +0 -69
  127. package/dist/types/work-item.d.ts.map +0 -1
  128. package/dist/types/work-item.js +0 -8
  129. package/dist/types/work-item.js.map +0 -1
@@ -0,0 +1,112 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <title>ATOMS Mermaid Diagram</title>
7
+ <script type="module" crossorigin>(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const r of document.querySelectorAll('link[rel="modulepreload"]'))n(r);new MutationObserver(r=>{for(const s of r)if(s.type==="childList")for(const i of s.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&n(i)}).observe(document,{childList:!0,subtree:!0});function o(r){const s={};return r.integrity&&(s.integrity=r.integrity),r.referrerPolicy&&(s.referrerPolicy=r.referrerPolicy),r.crossOrigin==="use-credentials"?s.credentials="include":r.crossOrigin==="anonymous"?s.credentials="omit":s.credentials="same-origin",s}function n(r){if(r.ep)return;r.ep=!0;const s=o(r);fetch(r.href,s)}})();function d(e,t,o){function n(u,p){var f;Object.defineProperty(u,"_zod",{value:u._zod??{},enumerable:!1}),(f=u._zod).traits??(f.traits=new Set),u._zod.traits.add(e),t(u,p);for(const g in i.prototype)g in u||Object.defineProperty(u,g,{value:i.prototype[g].bind(u)});u._zod.constr=i,u._zod.def=p}const r=o?.Parent??Object;class s extends r{}Object.defineProperty(s,"name",{value:e});function i(u){var p;const f=o?.Parent?new s:this;n(f,u),(p=f._zod).deferred??(p.deferred=[]);for(const g of f._zod.deferred)g();return f}return Object.defineProperty(i,"init",{value:n}),Object.defineProperty(i,Symbol.hasInstance,{value:u=>o?.Parent&&u instanceof o.Parent?!0:u?._zod?.traits?.has(e)}),Object.defineProperty(i,"name",{value:e}),i}class ce extends Error{constructor(){super("Encountered Promise during synchronous parse. Use .parseAsync() instead.")}}const Qt={};function J(e){return Qt}function Qo(e){const t=Object.values(e).filter(n=>typeof n=="number");return Object.entries(e).filter(([n,r])=>t.indexOf(+n)===-1).map(([n,r])=>r)}function Yo(e,t){return typeof t=="bigint"?t.toString():t}function Xe(e){return{get value(){{const t=e();return Object.defineProperty(this,"value",{value:t}),t}}}}function et(e){return e==null}function tt(e){const t=e.startsWith("^")?1:0,o=e.endsWith("$")?e.length-1:e.length;return e.slice(t,o)}function Xo(e,t){const o=(e.toString().split(".")[1]||"").length,n=(t.toString().split(".")[1]||"").length,r=o>n?o:n,s=Number.parseInt(e.toFixed(r).replace(".","")),i=Number.parseInt(t.toFixed(r).replace(".",""));return s%i/10**r}function Z(e,t,o){Object.defineProperty(e,t,{get(){{const n=o();return e[t]=n,n}},set(n){Object.defineProperty(e,t,{value:n})},configurable:!0})}function Ne(e,t,o){Object.defineProperty(e,t,{value:o,writable:!0,enumerable:!0,configurable:!0})}function ie(e){return JSON.stringify(e)}const Yt=Error.captureStackTrace?Error.captureStackTrace:(...e)=>{};function $e(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}const en=Xe(()=>{if(typeof navigator<"u"&&navigator?.userAgent?.includes("Cloudflare"))return!1;try{const e=Function;return new e(""),!0}catch{return!1}});function Ze(e){if($e(e)===!1)return!1;const t=e.constructor;if(t===void 0)return!0;const o=t.prototype;return!($e(o)===!1||Object.prototype.hasOwnProperty.call(o,"isPrototypeOf")===!1)}const tn=new Set(["string","number","symbol"]);function pe(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function te(e,t,o){const n=new e._zod.constr(t??e._zod.def);return(!t||o?.parent)&&(n._zod.parent=e),n}function h(e){const t=e;if(!t)return{};if(typeof t=="string")return{error:()=>t};if(t?.message!==void 0){if(t?.error!==void 0)throw new Error("Cannot specify both `message` and `error` params");t.error=t.message}return delete t.message,typeof t.error=="string"?{...t,error:()=>t.error}:t}function on(e){return Object.keys(e).filter(t=>e[t]._zod.optin==="optional"&&e[t]._zod.optout==="optional")}const nn={safeint:[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER],int32:[-2147483648,2147483647],uint32:[0,4294967295],float32:[-34028234663852886e22,34028234663852886e22],float64:[-Number.MAX_VALUE,Number.MAX_VALUE]};function rn(e,t){const o={},n=e._zod.def;for(const r in t){if(!(r in n.shape))throw new Error(`Unrecognized key: "${r}"`);t[r]&&(o[r]=n.shape[r])}return te(e,{...e._zod.def,shape:o,checks:[]})}function sn(e,t){const o={...e._zod.def.shape},n=e._zod.def;for(const r in t){if(!(r in n.shape))throw new Error(`Unrecognized key: "${r}"`);t[r]&&delete o[r]}return te(e,{...e._zod.def,shape:o,checks:[]})}function an(e,t){if(!Ze(t))throw new Error("Invalid input to extend: expected a plain object");const o={...e._zod.def,get shape(){const n={...e._zod.def.shape,...t};return Ne(this,"shape",n),n},checks:[]};return te(e,o)}function cn(e,t){return te(e,{...e._zod.def,get shape(){const o={...e._zod.def.shape,...t._zod.def.shape};return Ne(this,"shape",o),o},catchall:t._zod.def.catchall,checks:[]})}function un(e,t,o){const n=t._zod.def.shape,r={...n};if(o)for(const s in o){if(!(s in n))throw new Error(`Unrecognized key: "${s}"`);o[s]&&(r[s]=e?new e({type:"optional",innerType:n[s]}):n[s])}else for(const s in n)r[s]=e?new e({type:"optional",innerType:n[s]}):n[s];return te(t,{...t._zod.def,shape:r,checks:[]})}function ln(e,t,o){const n=t._zod.def.shape,r={...n};if(o)for(const s in o){if(!(s in r))throw new Error(`Unrecognized key: "${s}"`);o[s]&&(r[s]=new e({type:"nonoptional",innerType:n[s]}))}else for(const s in n)r[s]=new e({type:"nonoptional",innerType:n[s]});return te(t,{...t._zod.def,shape:r,checks:[]})}function ae(e,t=0){for(let o=t;o<e.issues.length;o++)if(e.issues[o]?.continue!==!0)return!0;return!1}function ee(e,t){return t.map(o=>{var n;return(n=o).path??(n.path=[]),o.path.unshift(e),o})}function Te(e){return typeof e=="string"?e:e?.message}function K(e,t,o){const n={...e,path:e.path??[]};if(!e.message){const r=Te(e.inst?._zod.def?.error?.(e))??Te(t?.error?.(e))??Te(o.customError?.(e))??Te(o.localeError?.(e))??"Invalid input";n.message=r}return delete n.inst,delete n.continue,t?.reportInput||delete n.input,n}function ot(e){return Array.isArray(e)?"array":typeof e=="string"?"string":"unknown"}function ue(...e){const[t,o,n]=e;return typeof t=="string"?{message:t,code:"custom",input:o,inst:n}:{...t}}const Xt=(e,t)=>{e.name="$ZodError",Object.defineProperty(e,"_zod",{value:e._zod,enumerable:!1}),Object.defineProperty(e,"issues",{value:t,enumerable:!1}),Object.defineProperty(e,"message",{get(){return JSON.stringify(t,Yo,2)},enumerable:!0}),Object.defineProperty(e,"toString",{value:()=>e.message,enumerable:!1})},eo=d("$ZodError",Xt),to=d("$ZodError",Xt,{Parent:Error});function dn(e,t=o=>o.message){const o={},n=[];for(const r of e.issues)r.path.length>0?(o[r.path[0]]=o[r.path[0]]||[],o[r.path[0]].push(t(r))):n.push(t(r));return{formErrors:n,fieldErrors:o}}function pn(e,t){const o=t||function(s){return s.message},n={_errors:[]},r=s=>{for(const i of s.issues)if(i.code==="invalid_union"&&i.errors.length)i.errors.map(u=>r({issues:u}));else if(i.code==="invalid_key")r({issues:i.issues});else if(i.code==="invalid_element")r({issues:i.issues});else if(i.path.length===0)n._errors.push(o(i));else{let u=n,p=0;for(;p<i.path.length;){const f=i.path[p];p===i.path.length-1?(u[f]=u[f]||{_errors:[]},u[f]._errors.push(o(i))):u[f]=u[f]||{_errors:[]},u=u[f],p++}}};return r(e),n}const mn=e=>(t,o,n,r)=>{const s=n?Object.assign(n,{async:!1}):{async:!1},i=t._zod.run({value:o,issues:[]},s);if(i instanceof Promise)throw new ce;if(i.issues.length){const u=new(r?.Err??e)(i.issues.map(p=>K(p,s,J())));throw Yt(u,r?.callee),u}return i.value},hn=e=>async(t,o,n,r)=>{const s=n?Object.assign(n,{async:!0}):{async:!0};let i=t._zod.run({value:o,issues:[]},s);if(i instanceof Promise&&(i=await i),i.issues.length){const u=new(r?.Err??e)(i.issues.map(p=>K(p,s,J())));throw Yt(u,r?.callee),u}return i.value},oo=e=>(t,o,n)=>{const r=n?{...n,async:!1}:{async:!1},s=t._zod.run({value:o,issues:[]},r);if(s instanceof Promise)throw new ce;return s.issues.length?{success:!1,error:new(e??eo)(s.issues.map(i=>K(i,r,J())))}:{success:!0,data:s.value}},no=oo(to),ro=e=>async(t,o,n)=>{const r=n?Object.assign(n,{async:!0}):{async:!0};let s=t._zod.run({value:o,issues:[]},r);return s instanceof Promise&&(s=await s),s.issues.length?{success:!1,error:new e(s.issues.map(i=>K(i,r,J())))}:{success:!0,data:s.value}},fn=ro(to),gn=/^[cC][^\s-]{8,}$/,_n=/^[0-9a-z]+$/,vn=/^[0-9A-HJKMNP-TV-Za-hjkmnp-tv-z]{26}$/,bn=/^[0-9a-vA-V]{20}$/,kn=/^[A-Za-z0-9]{27}$/,wn=/^[a-zA-Z0-9_-]{21}$/,yn=/^P(?:(\d+W)|(?!.*W)(?=\d|T\d)(\d+Y)?(\d+M)?(\d+D)?(T(?=\d)(\d+H)?(\d+M)?(\d+([.,]\d+)?S)?)?)$/,Sn=/^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$/,$t=e=>e?new RegExp(`^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-${e}[0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12})$`):/^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-8][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}|00000000-0000-0000-0000-000000000000)$/,Tn=/^(?!\.)(?!.*\.\.)([A-Za-z0-9_'+\-\.]*)[A-Za-z0-9_+-]@([A-Za-z0-9][A-Za-z0-9\-]*\.)+[A-Za-z]{2,}$/,zn="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$";function xn(){return new RegExp(zn,"u")}const In=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,Rn=/^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})$/,$n=/^((25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/([0-9]|[1-2][0-9]|3[0-2])$/,Zn=/^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,Pn=/^$|^(?:[0-9a-zA-Z+/]{4})*(?:(?:[0-9a-zA-Z+/]{2}==)|(?:[0-9a-zA-Z+/]{3}=))?$/,so=/^[A-Za-z0-9_-]*$/,En=/^([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+$/,Cn=/^\+(?:[0-9]){6,14}[0-9]$/,io="(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))",Nn=new RegExp(`^${io}$`);function ao(e){const t="(?:[01]\\d|2[0-3]):[0-5]\\d";return typeof e.precision=="number"?e.precision===-1?`${t}`:e.precision===0?`${t}:[0-5]\\d`:`${t}:[0-5]\\d\\.\\d{${e.precision}}`:`${t}(?::[0-5]\\d(?:\\.\\d+)?)?`}function qn(e){return new RegExp(`^${ao(e)}$`)}function Mn(e){const t=ao({precision:e.precision}),o=["Z"];e.local&&o.push(""),e.offset&&o.push("([+-]\\d{2}:\\d{2})");const n=`${t}(?:${o.join("|")})`;return new RegExp(`^${io}T(?:${n})$`)}const On=e=>{const t=e?`[\\s\\S]{${e?.minimum??0},${e?.maximum??""}}`:"[\\s\\S]*";return new RegExp(`^${t}$`)},An=/^\d+$/,Dn=/^-?\d+(?:\.\d+)?/i,Ln=/true|false/i,Un=/null/i,jn=/undefined/i,Hn=/^[^A-Z]*$/,Fn=/^[^a-z]*$/,U=d("$ZodCheck",(e,t)=>{var o;e._zod??(e._zod={}),e._zod.def=t,(o=e._zod).onattach??(o.onattach=[])}),co={number:"number",bigint:"bigint",object:"date"},uo=d("$ZodCheckLessThan",(e,t)=>{U.init(e,t);const o=co[typeof t.value];e._zod.onattach.push(n=>{const r=n._zod.bag,s=(t.inclusive?r.maximum:r.exclusiveMaximum)??Number.POSITIVE_INFINITY;t.value<s&&(t.inclusive?r.maximum=t.value:r.exclusiveMaximum=t.value)}),e._zod.check=n=>{(t.inclusive?n.value<=t.value:n.value<t.value)||n.issues.push({origin:o,code:"too_big",maximum:t.value,input:n.value,inclusive:t.inclusive,inst:e,continue:!t.abort})}}),lo=d("$ZodCheckGreaterThan",(e,t)=>{U.init(e,t);const o=co[typeof t.value];e._zod.onattach.push(n=>{const r=n._zod.bag,s=(t.inclusive?r.minimum:r.exclusiveMinimum)??Number.NEGATIVE_INFINITY;t.value>s&&(t.inclusive?r.minimum=t.value:r.exclusiveMinimum=t.value)}),e._zod.check=n=>{(t.inclusive?n.value>=t.value:n.value>t.value)||n.issues.push({origin:o,code:"too_small",minimum:t.value,input:n.value,inclusive:t.inclusive,inst:e,continue:!t.abort})}}),Bn=d("$ZodCheckMultipleOf",(e,t)=>{U.init(e,t),e._zod.onattach.push(o=>{var n;(n=o._zod.bag).multipleOf??(n.multipleOf=t.value)}),e._zod.check=o=>{if(typeof o.value!=typeof t.value)throw new Error("Cannot mix number and bigint in multiple_of check.");(typeof o.value=="bigint"?o.value%t.value===BigInt(0):Xo(o.value,t.value)===0)||o.issues.push({origin:typeof o.value,code:"not_multiple_of",divisor:t.value,input:o.value,inst:e,continue:!t.abort})}}),Vn=d("$ZodCheckNumberFormat",(e,t)=>{U.init(e,t),t.format=t.format||"float64";const o=t.format?.includes("int"),n=o?"int":"number",[r,s]=nn[t.format];e._zod.onattach.push(i=>{const u=i._zod.bag;u.format=t.format,u.minimum=r,u.maximum=s,o&&(u.pattern=An)}),e._zod.check=i=>{const u=i.value;if(o){if(!Number.isInteger(u)){i.issues.push({expected:n,format:t.format,code:"invalid_type",input:u,inst:e});return}if(!Number.isSafeInteger(u)){u>0?i.issues.push({input:u,code:"too_big",maximum:Number.MAX_SAFE_INTEGER,note:"Integers must be within the safe integer range.",inst:e,origin:n,continue:!t.abort}):i.issues.push({input:u,code:"too_small",minimum:Number.MIN_SAFE_INTEGER,note:"Integers must be within the safe integer range.",inst:e,origin:n,continue:!t.abort});return}}u<r&&i.issues.push({origin:"number",input:u,code:"too_small",minimum:r,inclusive:!0,inst:e,continue:!t.abort}),u>s&&i.issues.push({origin:"number",input:u,code:"too_big",maximum:s,inst:e})}}),Wn=d("$ZodCheckMaxLength",(e,t)=>{var o;U.init(e,t),(o=e._zod.def).when??(o.when=n=>{const r=n.value;return!et(r)&&r.length!==void 0}),e._zod.onattach.push(n=>{const r=n._zod.bag.maximum??Number.POSITIVE_INFINITY;t.maximum<r&&(n._zod.bag.maximum=t.maximum)}),e._zod.check=n=>{const r=n.value;if(r.length<=t.maximum)return;const i=ot(r);n.issues.push({origin:i,code:"too_big",maximum:t.maximum,inclusive:!0,input:r,inst:e,continue:!t.abort})}}),Jn=d("$ZodCheckMinLength",(e,t)=>{var o;U.init(e,t),(o=e._zod.def).when??(o.when=n=>{const r=n.value;return!et(r)&&r.length!==void 0}),e._zod.onattach.push(n=>{const r=n._zod.bag.minimum??Number.NEGATIVE_INFINITY;t.minimum>r&&(n._zod.bag.minimum=t.minimum)}),e._zod.check=n=>{const r=n.value;if(r.length>=t.minimum)return;const i=ot(r);n.issues.push({origin:i,code:"too_small",minimum:t.minimum,inclusive:!0,input:r,inst:e,continue:!t.abort})}}),Kn=d("$ZodCheckLengthEquals",(e,t)=>{var o;U.init(e,t),(o=e._zod.def).when??(o.when=n=>{const r=n.value;return!et(r)&&r.length!==void 0}),e._zod.onattach.push(n=>{const r=n._zod.bag;r.minimum=t.length,r.maximum=t.length,r.length=t.length}),e._zod.check=n=>{const r=n.value,s=r.length;if(s===t.length)return;const i=ot(r),u=s>t.length;n.issues.push({origin:i,...u?{code:"too_big",maximum:t.length}:{code:"too_small",minimum:t.length},inclusive:!0,exact:!0,input:n.value,inst:e,continue:!t.abort})}}),qe=d("$ZodCheckStringFormat",(e,t)=>{var o,n;U.init(e,t),e._zod.onattach.push(r=>{const s=r._zod.bag;s.format=t.format,t.pattern&&(s.patterns??(s.patterns=new Set),s.patterns.add(t.pattern))}),t.pattern?(o=e._zod).check??(o.check=r=>{t.pattern.lastIndex=0,!t.pattern.test(r.value)&&r.issues.push({origin:"string",code:"invalid_format",format:t.format,input:r.value,...t.pattern?{pattern:t.pattern.toString()}:{},inst:e,continue:!t.abort})}):(n=e._zod).check??(n.check=()=>{})}),Gn=d("$ZodCheckRegex",(e,t)=>{qe.init(e,t),e._zod.check=o=>{t.pattern.lastIndex=0,!t.pattern.test(o.value)&&o.issues.push({origin:"string",code:"invalid_format",format:"regex",input:o.value,pattern:t.pattern.toString(),inst:e,continue:!t.abort})}}),Qn=d("$ZodCheckLowerCase",(e,t)=>{t.pattern??(t.pattern=Hn),qe.init(e,t)}),Yn=d("$ZodCheckUpperCase",(e,t)=>{t.pattern??(t.pattern=Fn),qe.init(e,t)}),Xn=d("$ZodCheckIncludes",(e,t)=>{U.init(e,t);const o=pe(t.includes),n=new RegExp(typeof t.position=="number"?`^.{${t.position}}${o}`:o);t.pattern=n,e._zod.onattach.push(r=>{const s=r._zod.bag;s.patterns??(s.patterns=new Set),s.patterns.add(n)}),e._zod.check=r=>{r.value.includes(t.includes,t.position)||r.issues.push({origin:"string",code:"invalid_format",format:"includes",includes:t.includes,input:r.value,inst:e,continue:!t.abort})}}),er=d("$ZodCheckStartsWith",(e,t)=>{U.init(e,t);const o=new RegExp(`^${pe(t.prefix)}.*`);t.pattern??(t.pattern=o),e._zod.onattach.push(n=>{const r=n._zod.bag;r.patterns??(r.patterns=new Set),r.patterns.add(o)}),e._zod.check=n=>{n.value.startsWith(t.prefix)||n.issues.push({origin:"string",code:"invalid_format",format:"starts_with",prefix:t.prefix,input:n.value,inst:e,continue:!t.abort})}}),tr=d("$ZodCheckEndsWith",(e,t)=>{U.init(e,t);const o=new RegExp(`.*${pe(t.suffix)}$`);t.pattern??(t.pattern=o),e._zod.onattach.push(n=>{const r=n._zod.bag;r.patterns??(r.patterns=new Set),r.patterns.add(o)}),e._zod.check=n=>{n.value.endsWith(t.suffix)||n.issues.push({origin:"string",code:"invalid_format",format:"ends_with",suffix:t.suffix,input:n.value,inst:e,continue:!t.abort})}}),or=d("$ZodCheckOverwrite",(e,t)=>{U.init(e,t),e._zod.check=o=>{o.value=t.tx(o.value)}});class nr{constructor(t=[]){this.content=[],this.indent=0,this&&(this.args=t)}indented(t){this.indent+=1,t(this),this.indent-=1}write(t){if(typeof t=="function"){t(this,{execution:"sync"}),t(this,{execution:"async"});return}const n=t.split(`
8
+ `).filter(i=>i),r=Math.min(...n.map(i=>i.length-i.trimStart().length)),s=n.map(i=>i.slice(r)).map(i=>" ".repeat(this.indent*2)+i);for(const i of s)this.content.push(i)}compile(){const t=Function,o=this?.args,r=[...(this?.content??[""]).map(s=>` ${s}`)];return new t(...o,r.join(`
9
+ `))}}const rr={major:4,minor:0,patch:0},$=d("$ZodType",(e,t)=>{var o;e??(e={}),e._zod.def=t,e._zod.bag=e._zod.bag||{},e._zod.version=rr;const n=[...e._zod.def.checks??[]];e._zod.traits.has("$ZodCheck")&&n.unshift(e);for(const r of n)for(const s of r._zod.onattach)s(e);if(n.length===0)(o=e._zod).deferred??(o.deferred=[]),e._zod.deferred?.push(()=>{e._zod.run=e._zod.parse});else{const r=(s,i,u)=>{let p=ae(s),f;for(const g of i){if(g._zod.def.when){if(!g._zod.def.when(s))continue}else if(p)continue;const m=s.issues.length,_=g._zod.check(s);if(_ instanceof Promise&&u?.async===!1)throw new ce;if(f||_ instanceof Promise)f=(f??Promise.resolve()).then(async()=>{await _,s.issues.length!==m&&(p||(p=ae(s,m)))});else{if(s.issues.length===m)continue;p||(p=ae(s,m))}}return f?f.then(()=>s):s};e._zod.run=(s,i)=>{const u=e._zod.parse(s,i);if(u instanceof Promise){if(i.async===!1)throw new ce;return u.then(p=>r(p,n,i))}return r(u,n,i)}}e["~standard"]={validate:r=>{try{const s=no(e,r);return s.success?{value:s.data}:{issues:s.error?.issues}}catch{return fn(e,r).then(i=>i.success?{value:i.data}:{issues:i.error?.issues})}},vendor:"zod",version:1}}),nt=d("$ZodString",(e,t)=>{$.init(e,t),e._zod.pattern=[...e?._zod.bag?.patterns??[]].pop()??On(e._zod.bag),e._zod.parse=(o,n)=>{if(t.coerce)try{o.value=String(o.value)}catch{}return typeof o.value=="string"||o.issues.push({expected:"string",code:"invalid_type",input:o.value,inst:e}),o}}),E=d("$ZodStringFormat",(e,t)=>{qe.init(e,t),nt.init(e,t)}),sr=d("$ZodGUID",(e,t)=>{t.pattern??(t.pattern=Sn),E.init(e,t)}),ir=d("$ZodUUID",(e,t)=>{if(t.version){const n={v1:1,v2:2,v3:3,v4:4,v5:5,v6:6,v7:7,v8:8}[t.version];if(n===void 0)throw new Error(`Invalid UUID version: "${t.version}"`);t.pattern??(t.pattern=$t(n))}else t.pattern??(t.pattern=$t());E.init(e,t)}),ar=d("$ZodEmail",(e,t)=>{t.pattern??(t.pattern=Tn),E.init(e,t)}),cr=d("$ZodURL",(e,t)=>{E.init(e,t),e._zod.check=o=>{try{const n=o.value,r=new URL(n),s=r.href;t.hostname&&(t.hostname.lastIndex=0,t.hostname.test(r.hostname)||o.issues.push({code:"invalid_format",format:"url",note:"Invalid hostname",pattern:En.source,input:o.value,inst:e,continue:!t.abort})),t.protocol&&(t.protocol.lastIndex=0,t.protocol.test(r.protocol.endsWith(":")?r.protocol.slice(0,-1):r.protocol)||o.issues.push({code:"invalid_format",format:"url",note:"Invalid protocol",pattern:t.protocol.source,input:o.value,inst:e,continue:!t.abort})),!n.endsWith("/")&&s.endsWith("/")?o.value=s.slice(0,-1):o.value=s;return}catch{o.issues.push({code:"invalid_format",format:"url",input:o.value,inst:e,continue:!t.abort})}}}),ur=d("$ZodEmoji",(e,t)=>{t.pattern??(t.pattern=xn()),E.init(e,t)}),lr=d("$ZodNanoID",(e,t)=>{t.pattern??(t.pattern=wn),E.init(e,t)}),dr=d("$ZodCUID",(e,t)=>{t.pattern??(t.pattern=gn),E.init(e,t)}),pr=d("$ZodCUID2",(e,t)=>{t.pattern??(t.pattern=_n),E.init(e,t)}),mr=d("$ZodULID",(e,t)=>{t.pattern??(t.pattern=vn),E.init(e,t)}),hr=d("$ZodXID",(e,t)=>{t.pattern??(t.pattern=bn),E.init(e,t)}),fr=d("$ZodKSUID",(e,t)=>{t.pattern??(t.pattern=kn),E.init(e,t)}),gr=d("$ZodISODateTime",(e,t)=>{t.pattern??(t.pattern=Mn(t)),E.init(e,t)}),_r=d("$ZodISODate",(e,t)=>{t.pattern??(t.pattern=Nn),E.init(e,t)}),vr=d("$ZodISOTime",(e,t)=>{t.pattern??(t.pattern=qn(t)),E.init(e,t)}),br=d("$ZodISODuration",(e,t)=>{t.pattern??(t.pattern=yn),E.init(e,t)}),kr=d("$ZodIPv4",(e,t)=>{t.pattern??(t.pattern=In),E.init(e,t),e._zod.onattach.push(o=>{const n=o._zod.bag;n.format="ipv4"})}),wr=d("$ZodIPv6",(e,t)=>{t.pattern??(t.pattern=Rn),E.init(e,t),e._zod.onattach.push(o=>{const n=o._zod.bag;n.format="ipv6"}),e._zod.check=o=>{try{new URL(`http://[${o.value}]`)}catch{o.issues.push({code:"invalid_format",format:"ipv6",input:o.value,inst:e,continue:!t.abort})}}}),yr=d("$ZodCIDRv4",(e,t)=>{t.pattern??(t.pattern=$n),E.init(e,t)}),Sr=d("$ZodCIDRv6",(e,t)=>{t.pattern??(t.pattern=Zn),E.init(e,t),e._zod.check=o=>{const[n,r]=o.value.split("/");try{if(!r)throw new Error;const s=Number(r);if(`${s}`!==r)throw new Error;if(s<0||s>128)throw new Error;new URL(`http://[${n}]`)}catch{o.issues.push({code:"invalid_format",format:"cidrv6",input:o.value,inst:e,continue:!t.abort})}}});function po(e){if(e==="")return!0;if(e.length%4!==0)return!1;try{return atob(e),!0}catch{return!1}}const Tr=d("$ZodBase64",(e,t)=>{t.pattern??(t.pattern=Pn),E.init(e,t),e._zod.onattach.push(o=>{o._zod.bag.contentEncoding="base64"}),e._zod.check=o=>{po(o.value)||o.issues.push({code:"invalid_format",format:"base64",input:o.value,inst:e,continue:!t.abort})}});function zr(e){if(!so.test(e))return!1;const t=e.replace(/[-_]/g,n=>n==="-"?"+":"/"),o=t.padEnd(Math.ceil(t.length/4)*4,"=");return po(o)}const xr=d("$ZodBase64URL",(e,t)=>{t.pattern??(t.pattern=so),E.init(e,t),e._zod.onattach.push(o=>{o._zod.bag.contentEncoding="base64url"}),e._zod.check=o=>{zr(o.value)||o.issues.push({code:"invalid_format",format:"base64url",input:o.value,inst:e,continue:!t.abort})}}),Ir=d("$ZodE164",(e,t)=>{t.pattern??(t.pattern=Cn),E.init(e,t)});function Rr(e,t=null){try{const o=e.split(".");if(o.length!==3)return!1;const[n]=o;if(!n)return!1;const r=JSON.parse(atob(n));return!("typ"in r&&r?.typ!=="JWT"||!r.alg||t&&(!("alg"in r)||r.alg!==t))}catch{return!1}}const $r=d("$ZodJWT",(e,t)=>{E.init(e,t),e._zod.check=o=>{Rr(o.value,t.alg)||o.issues.push({code:"invalid_format",format:"jwt",input:o.value,inst:e,continue:!t.abort})}}),mo=d("$ZodNumber",(e,t)=>{$.init(e,t),e._zod.pattern=e._zod.bag.pattern??Dn,e._zod.parse=(o,n)=>{if(t.coerce)try{o.value=Number(o.value)}catch{}const r=o.value;if(typeof r=="number"&&!Number.isNaN(r)&&Number.isFinite(r))return o;const s=typeof r=="number"?Number.isNaN(r)?"NaN":Number.isFinite(r)?void 0:"Infinity":void 0;return o.issues.push({expected:"number",code:"invalid_type",input:r,inst:e,...s?{received:s}:{}}),o}}),Zr=d("$ZodNumber",(e,t)=>{Vn.init(e,t),mo.init(e,t)}),Pr=d("$ZodBoolean",(e,t)=>{$.init(e,t),e._zod.pattern=Ln,e._zod.parse=(o,n)=>{if(t.coerce)try{o.value=!!o.value}catch{}const r=o.value;return typeof r=="boolean"||o.issues.push({expected:"boolean",code:"invalid_type",input:r,inst:e}),o}}),Er=d("$ZodUndefined",(e,t)=>{$.init(e,t),e._zod.pattern=jn,e._zod.values=new Set([void 0]),e._zod.optin="optional",e._zod.optout="optional",e._zod.parse=(o,n)=>{const r=o.value;return typeof r>"u"||o.issues.push({expected:"undefined",code:"invalid_type",input:r,inst:e}),o}}),Cr=d("$ZodNull",(e,t)=>{$.init(e,t),e._zod.pattern=Un,e._zod.values=new Set([null]),e._zod.parse=(o,n)=>{const r=o.value;return r===null||o.issues.push({expected:"null",code:"invalid_type",input:r,inst:e}),o}}),Nr=d("$ZodUnknown",(e,t)=>{$.init(e,t),e._zod.parse=o=>o}),qr=d("$ZodNever",(e,t)=>{$.init(e,t),e._zod.parse=(o,n)=>(o.issues.push({expected:"never",code:"invalid_type",input:o.value,inst:e}),o)});function Zt(e,t,o){e.issues.length&&t.issues.push(...ee(o,e.issues)),t.value[o]=e.value}const Mr=d("$ZodArray",(e,t)=>{$.init(e,t),e._zod.parse=(o,n)=>{const r=o.value;if(!Array.isArray(r))return o.issues.push({expected:"array",code:"invalid_type",input:r,inst:e}),o;o.value=Array(r.length);const s=[];for(let i=0;i<r.length;i++){const u=r[i],p=t.element._zod.run({value:u,issues:[]},n);p instanceof Promise?s.push(p.then(f=>Zt(f,o,i))):Zt(p,o,i)}return s.length?Promise.all(s).then(()=>o):o}});function ze(e,t,o){e.issues.length&&t.issues.push(...ee(o,e.issues)),t.value[o]=e.value}function Pt(e,t,o,n){e.issues.length?n[o]===void 0?o in n?t.value[o]=void 0:t.value[o]=e.value:t.issues.push(...ee(o,e.issues)):e.value===void 0?o in n&&(t.value[o]=void 0):t.value[o]=e.value}const Or=d("$ZodObject",(e,t)=>{$.init(e,t);const o=Xe(()=>{const m=Object.keys(t.shape);for(const k of m)if(!(t.shape[k]instanceof $))throw new Error(`Invalid element at key "${k}": expected a Zod schema`);const _=on(t.shape);return{shape:t.shape,keys:m,keySet:new Set(m),numKeys:m.length,optionalKeys:new Set(_)}});Z(e._zod,"propValues",()=>{const m=t.shape,_={};for(const k in m){const M=m[k]._zod;if(M.values){_[k]??(_[k]=new Set);for(const F of M.values)_[k].add(F)}}return _});const n=m=>{const _=new nr(["shape","payload","ctx"]),k=o.value,M=S=>{const y=ie(S);return`shape[${y}]._zod.run({ value: input[${y}], issues: [] }, ctx)`};_.write("const input = payload.value;");const F=Object.create(null);let re=0;for(const S of k.keys)F[S]=`key_${re++}`;_.write("const newResult = {}");for(const S of k.keys)if(k.optionalKeys.has(S)){const y=F[S];_.write(`const ${y} = ${M(S)};`);const P=ie(S);_.write(`
10
+ if (${y}.issues.length) {
11
+ if (input[${P}] === undefined) {
12
+ if (${P} in input) {
13
+ newResult[${P}] = undefined;
14
+ }
15
+ } else {
16
+ payload.issues = payload.issues.concat(
17
+ ${y}.issues.map((iss) => ({
18
+ ...iss,
19
+ path: iss.path ? [${P}, ...iss.path] : [${P}],
20
+ }))
21
+ );
22
+ }
23
+ } else if (${y}.value === undefined) {
24
+ if (${P} in input) newResult[${P}] = undefined;
25
+ } else {
26
+ newResult[${P}] = ${y}.value;
27
+ }
28
+ `)}else{const y=F[S];_.write(`const ${y} = ${M(S)};`),_.write(`
29
+ if (${y}.issues.length) payload.issues = payload.issues.concat(${y}.issues.map(iss => ({
30
+ ...iss,
31
+ path: iss.path ? [${ie(S)}, ...iss.path] : [${ie(S)}]
32
+ })));`),_.write(`newResult[${ie(S)}] = ${y}.value`)}_.write("payload.value = newResult;"),_.write("return payload;");const Q=_.compile();return(S,y)=>Q(m,S,y)};let r;const s=$e,i=!Qt.jitless,p=i&&en.value,f=t.catchall;let g;e._zod.parse=(m,_)=>{g??(g=o.value);const k=m.value;if(!s(k))return m.issues.push({expected:"object",code:"invalid_type",input:k,inst:e}),m;const M=[];if(i&&p&&_?.async===!1&&_.jitless!==!0)r||(r=n(t.shape)),m=r(m,_);else{m.value={};const y=g.shape;for(const P of g.keys){const se=y[P],Se=se._zod.run({value:k[P],issues:[]},_),It=se._zod.optin==="optional"&&se._zod.optout==="optional";Se instanceof Promise?M.push(Se.then(Rt=>It?Pt(Rt,m,P,k):ze(Rt,m,P))):It?Pt(Se,m,P,k):ze(Se,m,P)}}if(!f)return M.length?Promise.all(M).then(()=>m):m;const F=[],re=g.keySet,Q=f._zod,S=Q.def.type;for(const y of Object.keys(k)){if(re.has(y))continue;if(S==="never"){F.push(y);continue}const P=Q.run({value:k[y],issues:[]},_);P instanceof Promise?M.push(P.then(se=>ze(se,m,y))):ze(P,m,y)}return F.length&&m.issues.push({code:"unrecognized_keys",keys:F,input:k,inst:e}),M.length?Promise.all(M).then(()=>m):m}});function Et(e,t,o,n){for(const r of e)if(r.issues.length===0)return t.value=r.value,t;return t.issues.push({code:"invalid_union",input:t.value,inst:o,errors:e.map(r=>r.issues.map(s=>K(s,n,J())))}),t}const ho=d("$ZodUnion",(e,t)=>{$.init(e,t),Z(e._zod,"optin",()=>t.options.some(o=>o._zod.optin==="optional")?"optional":void 0),Z(e._zod,"optout",()=>t.options.some(o=>o._zod.optout==="optional")?"optional":void 0),Z(e._zod,"values",()=>{if(t.options.every(o=>o._zod.values))return new Set(t.options.flatMap(o=>Array.from(o._zod.values)))}),Z(e._zod,"pattern",()=>{if(t.options.every(o=>o._zod.pattern)){const o=t.options.map(n=>n._zod.pattern);return new RegExp(`^(${o.map(n=>tt(n.source)).join("|")})$`)}}),e._zod.parse=(o,n)=>{let r=!1;const s=[];for(const i of t.options){const u=i._zod.run({value:o.value,issues:[]},n);if(u instanceof Promise)s.push(u),r=!0;else{if(u.issues.length===0)return u;s.push(u)}}return r?Promise.all(s).then(i=>Et(i,o,e,n)):Et(s,o,e,n)}}),Ar=d("$ZodDiscriminatedUnion",(e,t)=>{ho.init(e,t);const o=e._zod.parse;Z(e._zod,"propValues",()=>{const r={};for(const s of t.options){const i=s._zod.propValues;if(!i||Object.keys(i).length===0)throw new Error(`Invalid discriminated union option at index "${t.options.indexOf(s)}"`);for(const[u,p]of Object.entries(i)){r[u]||(r[u]=new Set);for(const f of p)r[u].add(f)}}return r});const n=Xe(()=>{const r=t.options,s=new Map;for(const i of r){const u=i._zod.propValues[t.discriminator];if(!u||u.size===0)throw new Error(`Invalid discriminated union option at index "${t.options.indexOf(i)}"`);for(const p of u){if(s.has(p))throw new Error(`Duplicate discriminator value "${String(p)}"`);s.set(p,i)}}return s});e._zod.parse=(r,s)=>{const i=r.value;if(!$e(i))return r.issues.push({code:"invalid_type",expected:"object",input:i,inst:e}),r;const u=n.value.get(i?.[t.discriminator]);return u?u._zod.run(r,s):t.unionFallback?o(r,s):(r.issues.push({code:"invalid_union",errors:[],note:"No matching discriminator",input:i,path:[t.discriminator],inst:e}),r)}}),Dr=d("$ZodIntersection",(e,t)=>{$.init(e,t),e._zod.parse=(o,n)=>{const r=o.value,s=t.left._zod.run({value:r,issues:[]},n),i=t.right._zod.run({value:r,issues:[]},n);return s instanceof Promise||i instanceof Promise?Promise.all([s,i]).then(([p,f])=>Ct(o,p,f)):Ct(o,s,i)}});function Je(e,t){if(e===t)return{valid:!0,data:e};if(e instanceof Date&&t instanceof Date&&+e==+t)return{valid:!0,data:e};if(Ze(e)&&Ze(t)){const o=Object.keys(t),n=Object.keys(e).filter(s=>o.indexOf(s)!==-1),r={...e,...t};for(const s of n){const i=Je(e[s],t[s]);if(!i.valid)return{valid:!1,mergeErrorPath:[s,...i.mergeErrorPath]};r[s]=i.data}return{valid:!0,data:r}}if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return{valid:!1,mergeErrorPath:[]};const o=[];for(let n=0;n<e.length;n++){const r=e[n],s=t[n],i=Je(r,s);if(!i.valid)return{valid:!1,mergeErrorPath:[n,...i.mergeErrorPath]};o.push(i.data)}return{valid:!0,data:o}}return{valid:!1,mergeErrorPath:[]}}function Ct(e,t,o){if(t.issues.length&&e.issues.push(...t.issues),o.issues.length&&e.issues.push(...o.issues),ae(e))return e;const n=Je(t.value,o.value);if(!n.valid)throw new Error(`Unmergable intersection. Error path: ${JSON.stringify(n.mergeErrorPath)}`);return e.value=n.data,e}const Lr=d("$ZodRecord",(e,t)=>{$.init(e,t),e._zod.parse=(o,n)=>{const r=o.value;if(!Ze(r))return o.issues.push({expected:"record",code:"invalid_type",input:r,inst:e}),o;const s=[];if(t.keyType._zod.values){const i=t.keyType._zod.values;o.value={};for(const p of i)if(typeof p=="string"||typeof p=="number"||typeof p=="symbol"){const f=t.valueType._zod.run({value:r[p],issues:[]},n);f instanceof Promise?s.push(f.then(g=>{g.issues.length&&o.issues.push(...ee(p,g.issues)),o.value[p]=g.value})):(f.issues.length&&o.issues.push(...ee(p,f.issues)),o.value[p]=f.value)}let u;for(const p in r)i.has(p)||(u=u??[],u.push(p));u&&u.length>0&&o.issues.push({code:"unrecognized_keys",input:r,inst:e,keys:u})}else{o.value={};for(const i of Reflect.ownKeys(r)){if(i==="__proto__")continue;const u=t.keyType._zod.run({value:i,issues:[]},n);if(u instanceof Promise)throw new Error("Async schemas not supported in object keys currently");if(u.issues.length){o.issues.push({origin:"record",code:"invalid_key",issues:u.issues.map(f=>K(f,n,J())),input:i,path:[i],inst:e}),o.value[u.value]=u.value;continue}const p=t.valueType._zod.run({value:r[i],issues:[]},n);p instanceof Promise?s.push(p.then(f=>{f.issues.length&&o.issues.push(...ee(i,f.issues)),o.value[u.value]=f.value})):(p.issues.length&&o.issues.push(...ee(i,p.issues)),o.value[u.value]=p.value)}}return s.length?Promise.all(s).then(()=>o):o}}),Ur=d("$ZodEnum",(e,t)=>{$.init(e,t);const o=Qo(t.entries);e._zod.values=new Set(o),e._zod.pattern=new RegExp(`^(${o.filter(n=>tn.has(typeof n)).map(n=>typeof n=="string"?pe(n):n.toString()).join("|")})$`),e._zod.parse=(n,r)=>{const s=n.value;return e._zod.values.has(s)||n.issues.push({code:"invalid_value",values:o,input:s,inst:e}),n}}),jr=d("$ZodLiteral",(e,t)=>{$.init(e,t),e._zod.values=new Set(t.values),e._zod.pattern=new RegExp(`^(${t.values.map(o=>typeof o=="string"?pe(o):o?o.toString():String(o)).join("|")})$`),e._zod.parse=(o,n)=>{const r=o.value;return e._zod.values.has(r)||o.issues.push({code:"invalid_value",values:t.values,input:r,inst:e}),o}}),Hr=d("$ZodTransform",(e,t)=>{$.init(e,t),e._zod.parse=(o,n)=>{const r=t.transform(o.value,o);if(n.async)return(r instanceof Promise?r:Promise.resolve(r)).then(i=>(o.value=i,o));if(r instanceof Promise)throw new ce;return o.value=r,o}}),Fr=d("$ZodOptional",(e,t)=>{$.init(e,t),e._zod.optin="optional",e._zod.optout="optional",Z(e._zod,"values",()=>t.innerType._zod.values?new Set([...t.innerType._zod.values,void 0]):void 0),Z(e._zod,"pattern",()=>{const o=t.innerType._zod.pattern;return o?new RegExp(`^(${tt(o.source)})?$`):void 0}),e._zod.parse=(o,n)=>t.innerType._zod.optin==="optional"?t.innerType._zod.run(o,n):o.value===void 0?o:t.innerType._zod.run(o,n)}),Br=d("$ZodNullable",(e,t)=>{$.init(e,t),Z(e._zod,"optin",()=>t.innerType._zod.optin),Z(e._zod,"optout",()=>t.innerType._zod.optout),Z(e._zod,"pattern",()=>{const o=t.innerType._zod.pattern;return o?new RegExp(`^(${tt(o.source)}|null)$`):void 0}),Z(e._zod,"values",()=>t.innerType._zod.values?new Set([...t.innerType._zod.values,null]):void 0),e._zod.parse=(o,n)=>o.value===null?o:t.innerType._zod.run(o,n)}),Vr=d("$ZodDefault",(e,t)=>{$.init(e,t),e._zod.optin="optional",Z(e._zod,"values",()=>t.innerType._zod.values),e._zod.parse=(o,n)=>{if(o.value===void 0)return o.value=t.defaultValue,o;const r=t.innerType._zod.run(o,n);return r instanceof Promise?r.then(s=>Nt(s,t)):Nt(r,t)}});function Nt(e,t){return e.value===void 0&&(e.value=t.defaultValue),e}const Wr=d("$ZodPrefault",(e,t)=>{$.init(e,t),e._zod.optin="optional",Z(e._zod,"values",()=>t.innerType._zod.values),e._zod.parse=(o,n)=>(o.value===void 0&&(o.value=t.defaultValue),t.innerType._zod.run(o,n))}),Jr=d("$ZodNonOptional",(e,t)=>{$.init(e,t),Z(e._zod,"values",()=>{const o=t.innerType._zod.values;return o?new Set([...o].filter(n=>n!==void 0)):void 0}),e._zod.parse=(o,n)=>{const r=t.innerType._zod.run(o,n);return r instanceof Promise?r.then(s=>qt(s,e)):qt(r,e)}});function qt(e,t){return!e.issues.length&&e.value===void 0&&e.issues.push({code:"invalid_type",expected:"nonoptional",input:e.value,inst:t}),e}const Kr=d("$ZodCatch",(e,t)=>{$.init(e,t),e._zod.optin="optional",Z(e._zod,"optout",()=>t.innerType._zod.optout),Z(e._zod,"values",()=>t.innerType._zod.values),e._zod.parse=(o,n)=>{const r=t.innerType._zod.run(o,n);return r instanceof Promise?r.then(s=>(o.value=s.value,s.issues.length&&(o.value=t.catchValue({...o,error:{issues:s.issues.map(i=>K(i,n,J()))},input:o.value}),o.issues=[]),o)):(o.value=r.value,r.issues.length&&(o.value=t.catchValue({...o,error:{issues:r.issues.map(s=>K(s,n,J()))},input:o.value}),o.issues=[]),o)}}),Gr=d("$ZodPipe",(e,t)=>{$.init(e,t),Z(e._zod,"values",()=>t.in._zod.values),Z(e._zod,"optin",()=>t.in._zod.optin),Z(e._zod,"optout",()=>t.out._zod.optout),e._zod.parse=(o,n)=>{const r=t.in._zod.run(o,n);return r instanceof Promise?r.then(s=>Mt(s,t,n)):Mt(r,t,n)}});function Mt(e,t,o){return ae(e)?e:t.out._zod.run({value:e.value,issues:e.issues},o)}const Qr=d("$ZodReadonly",(e,t)=>{$.init(e,t),Z(e._zod,"propValues",()=>t.innerType._zod.propValues),Z(e._zod,"values",()=>t.innerType._zod.values),Z(e._zod,"optin",()=>t.innerType._zod.optin),Z(e._zod,"optout",()=>t.innerType._zod.optout),e._zod.parse=(o,n)=>{const r=t.innerType._zod.run(o,n);return r instanceof Promise?r.then(Ot):Ot(r)}});function Ot(e){return e.value=Object.freeze(e.value),e}const Yr=d("$ZodCustom",(e,t)=>{U.init(e,t),$.init(e,t),e._zod.parse=(o,n)=>o,e._zod.check=o=>{const n=o.value,r=t.fn(n);if(r instanceof Promise)return r.then(s=>At(s,o,n,e));At(r,o,n,e)}});function At(e,t,o,n){if(!e){const r={code:"custom",input:o,inst:n,path:[...n._zod.def.path??[]],continue:!n._zod.def.abort};n._zod.def.params&&(r.params=n._zod.def.params),t.issues.push(ue(r))}}class Xr{constructor(){this._map=new Map,this._idmap=new Map}add(t,...o){const n=o[0];if(this._map.set(t,n),n&&typeof n=="object"&&"id"in n){if(this._idmap.has(n.id))throw new Error(`ID ${n.id} already exists in the registry`);this._idmap.set(n.id,t)}return this}clear(){return this._map=new Map,this._idmap=new Map,this}remove(t){const o=this._map.get(t);return o&&typeof o=="object"&&"id"in o&&this._idmap.delete(o.id),this._map.delete(t),this}get(t){const o=t._zod.parent;if(o){const n={...this.get(o)??{}};return delete n.id,{...n,...this._map.get(t)}}return this._map.get(t)}has(t){return this._map.has(t)}}function es(){return new Xr}const xe=es();function ts(e,t){return new e({type:"string",...h(t)})}function os(e,t){return new e({type:"string",format:"email",check:"string_format",abort:!1,...h(t)})}function Dt(e,t){return new e({type:"string",format:"guid",check:"string_format",abort:!1,...h(t)})}function ns(e,t){return new e({type:"string",format:"uuid",check:"string_format",abort:!1,...h(t)})}function rs(e,t){return new e({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v4",...h(t)})}function ss(e,t){return new e({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v6",...h(t)})}function is(e,t){return new e({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v7",...h(t)})}function as(e,t){return new e({type:"string",format:"url",check:"string_format",abort:!1,...h(t)})}function cs(e,t){return new e({type:"string",format:"emoji",check:"string_format",abort:!1,...h(t)})}function us(e,t){return new e({type:"string",format:"nanoid",check:"string_format",abort:!1,...h(t)})}function ls(e,t){return new e({type:"string",format:"cuid",check:"string_format",abort:!1,...h(t)})}function ds(e,t){return new e({type:"string",format:"cuid2",check:"string_format",abort:!1,...h(t)})}function ps(e,t){return new e({type:"string",format:"ulid",check:"string_format",abort:!1,...h(t)})}function ms(e,t){return new e({type:"string",format:"xid",check:"string_format",abort:!1,...h(t)})}function hs(e,t){return new e({type:"string",format:"ksuid",check:"string_format",abort:!1,...h(t)})}function fs(e,t){return new e({type:"string",format:"ipv4",check:"string_format",abort:!1,...h(t)})}function gs(e,t){return new e({type:"string",format:"ipv6",check:"string_format",abort:!1,...h(t)})}function _s(e,t){return new e({type:"string",format:"cidrv4",check:"string_format",abort:!1,...h(t)})}function vs(e,t){return new e({type:"string",format:"cidrv6",check:"string_format",abort:!1,...h(t)})}function bs(e,t){return new e({type:"string",format:"base64",check:"string_format",abort:!1,...h(t)})}function ks(e,t){return new e({type:"string",format:"base64url",check:"string_format",abort:!1,...h(t)})}function ws(e,t){return new e({type:"string",format:"e164",check:"string_format",abort:!1,...h(t)})}function ys(e,t){return new e({type:"string",format:"jwt",check:"string_format",abort:!1,...h(t)})}function Ss(e,t){return new e({type:"string",format:"datetime",check:"string_format",offset:!1,local:!1,precision:null,...h(t)})}function Ts(e,t){return new e({type:"string",format:"date",check:"string_format",...h(t)})}function zs(e,t){return new e({type:"string",format:"time",check:"string_format",precision:null,...h(t)})}function xs(e,t){return new e({type:"string",format:"duration",check:"string_format",...h(t)})}function Is(e,t){return new e({type:"number",checks:[],...h(t)})}function Rs(e,t){return new e({type:"number",check:"number_format",abort:!1,format:"safeint",...h(t)})}function $s(e,t){return new e({type:"boolean",...h(t)})}function Zs(e,t){return new e({type:"undefined",...h(t)})}function Ps(e,t){return new e({type:"null",...h(t)})}function Es(e){return new e({type:"unknown"})}function Cs(e,t){return new e({type:"never",...h(t)})}function Lt(e,t){return new uo({check:"less_than",...h(t),value:e,inclusive:!1})}function Fe(e,t){return new uo({check:"less_than",...h(t),value:e,inclusive:!0})}function Ut(e,t){return new lo({check:"greater_than",...h(t),value:e,inclusive:!1})}function Be(e,t){return new lo({check:"greater_than",...h(t),value:e,inclusive:!0})}function jt(e,t){return new Bn({check:"multiple_of",...h(t),value:e})}function fo(e,t){return new Wn({check:"max_length",...h(t),maximum:e})}function Pe(e,t){return new Jn({check:"min_length",...h(t),minimum:e})}function go(e,t){return new Kn({check:"length_equals",...h(t),length:e})}function Ns(e,t){return new Gn({check:"string_format",format:"regex",...h(t),pattern:e})}function qs(e){return new Qn({check:"string_format",format:"lowercase",...h(e)})}function Ms(e){return new Yn({check:"string_format",format:"uppercase",...h(e)})}function Os(e,t){return new Xn({check:"string_format",format:"includes",...h(t),includes:e})}function As(e,t){return new er({check:"string_format",format:"starts_with",...h(t),prefix:e})}function Ds(e,t){return new tr({check:"string_format",format:"ends_with",...h(t),suffix:e})}function me(e){return new or({check:"overwrite",tx:e})}function Ls(e){return me(t=>t.normalize(e))}function Us(){return me(e=>e.trim())}function js(){return me(e=>e.toLowerCase())}function Hs(){return me(e=>e.toUpperCase())}function Fs(e,t,o){return new e({type:"array",element:t,...h(o)})}function Bs(e,t,o){const n=h(o);return n.abort??(n.abort=!0),new e({type:"custom",check:"custom",fn:t,...n})}function Vs(e,t,o){return new e({type:"custom",check:"custom",fn:t,...h(o)})}function rt(e){return!!e._zod}function _o(e,t){return rt(e)?no(e,t):e.safeParse(t)}function Ws(e){if(!e)return;let t;if(rt(e)?t=e._zod?.def?.shape:t=e.shape,!!t){if(typeof t=="function")try{return t()}catch{return}return t}}function Js(e){if(rt(e)){const s=e._zod?.def;if(s){if(s.value!==void 0)return s.value;if(Array.isArray(s.values)&&s.values.length>0)return s.values[0]}}const o=e._def;if(o){if(o.value!==void 0)return o.value;if(Array.isArray(o.values)&&o.values.length>0)return o.values[0]}const n=e.value;if(n!==void 0)return n}const Ks=d("ZodISODateTime",(e,t)=>{gr.init(e,t),N.init(e,t)});function vo(e){return Ss(Ks,e)}const Gs=d("ZodISODate",(e,t)=>{_r.init(e,t),N.init(e,t)});function Qs(e){return Ts(Gs,e)}const Ys=d("ZodISOTime",(e,t)=>{vr.init(e,t),N.init(e,t)});function Xs(e){return zs(Ys,e)}const ei=d("ZodISODuration",(e,t)=>{br.init(e,t),N.init(e,t)});function ti(e){return xs(ei,e)}const oi=(e,t)=>{eo.init(e,t),e.name="ZodError",Object.defineProperties(e,{format:{value:o=>pn(e,o)},flatten:{value:o=>dn(e,o)},addIssue:{value:o=>e.issues.push(o)},addIssues:{value:o=>e.issues.push(...o)},isEmpty:{get(){return e.issues.length===0}}})},Me=d("ZodError",oi,{Parent:Error}),ni=mn(Me),ri=hn(Me),si=oo(Me),ii=ro(Me),C=d("ZodType",(e,t)=>($.init(e,t),e.def=t,Object.defineProperty(e,"_def",{value:t}),e.check=(...o)=>e.clone({...t,checks:[...t.checks??[],...o.map(n=>typeof n=="function"?{_zod:{check:n,def:{check:"custom"},onattach:[]}}:n)]}),e.clone=(o,n)=>te(e,o,n),e.brand=()=>e,e.register=((o,n)=>(o.add(e,n),e)),e.parse=(o,n)=>ni(e,o,n,{callee:e.parse}),e.safeParse=(o,n)=>si(e,o,n),e.parseAsync=async(o,n)=>ri(e,o,n,{callee:e.parseAsync}),e.safeParseAsync=async(o,n)=>ii(e,o,n),e.spa=e.safeParseAsync,e.refine=(o,n)=>e.check(Qi(o,n)),e.superRefine=o=>e.check(Yi(o)),e.overwrite=o=>e.check(me(o)),e.optional=()=>q(e),e.nullable=()=>Bt(e),e.nullish=()=>q(Bt(e)),e.nonoptional=o=>Hi(e,o),e.array=()=>v(e),e.or=o=>w([e,o]),e.and=o=>st(e,o),e.transform=o=>Qe(e,zo(o)),e.default=o=>Li(e,o),e.prefault=o=>ji(e,o),e.catch=o=>Bi(e,o),e.pipe=o=>Qe(e,o),e.readonly=()=>Ji(e),e.describe=o=>{const n=e.clone();return xe.add(n,{description:o}),n},Object.defineProperty(e,"description",{get(){return xe.get(e)?.description},configurable:!0}),e.meta=(...o)=>{if(o.length===0)return xe.get(e);const n=e.clone();return xe.add(n,o[0]),n},e.isOptional=()=>e.safeParse(void 0).success,e.isNullable=()=>e.safeParse(null).success,e)),bo=d("_ZodString",(e,t)=>{nt.init(e,t),C.init(e,t);const o=e._zod.bag;e.format=o.format??null,e.minLength=o.minimum??null,e.maxLength=o.maximum??null,e.regex=(...n)=>e.check(Ns(...n)),e.includes=(...n)=>e.check(Os(...n)),e.startsWith=(...n)=>e.check(As(...n)),e.endsWith=(...n)=>e.check(Ds(...n)),e.min=(...n)=>e.check(Pe(...n)),e.max=(...n)=>e.check(fo(...n)),e.length=(...n)=>e.check(go(...n)),e.nonempty=(...n)=>e.check(Pe(1,...n)),e.lowercase=n=>e.check(qs(n)),e.uppercase=n=>e.check(Ms(n)),e.trim=()=>e.check(Us()),e.normalize=(...n)=>e.check(Ls(...n)),e.toLowerCase=()=>e.check(js()),e.toUpperCase=()=>e.check(Hs())}),ai=d("ZodString",(e,t)=>{nt.init(e,t),bo.init(e,t),e.email=o=>e.check(os(ci,o)),e.url=o=>e.check(as(ui,o)),e.jwt=o=>e.check(ys(Ti,o)),e.emoji=o=>e.check(cs(li,o)),e.guid=o=>e.check(Dt(Ht,o)),e.uuid=o=>e.check(ns(Ie,o)),e.uuidv4=o=>e.check(rs(Ie,o)),e.uuidv6=o=>e.check(ss(Ie,o)),e.uuidv7=o=>e.check(is(Ie,o)),e.nanoid=o=>e.check(us(di,o)),e.guid=o=>e.check(Dt(Ht,o)),e.cuid=o=>e.check(ls(pi,o)),e.cuid2=o=>e.check(ds(mi,o)),e.ulid=o=>e.check(ps(hi,o)),e.base64=o=>e.check(bs(wi,o)),e.base64url=o=>e.check(ks(yi,o)),e.xid=o=>e.check(ms(fi,o)),e.ksuid=o=>e.check(hs(gi,o)),e.ipv4=o=>e.check(fs(_i,o)),e.ipv6=o=>e.check(gs(vi,o)),e.cidrv4=o=>e.check(_s(bi,o)),e.cidrv6=o=>e.check(vs(ki,o)),e.e164=o=>e.check(ws(Si,o)),e.datetime=o=>e.check(vo(o)),e.date=o=>e.check(Qs(o)),e.time=o=>e.check(Xs(o)),e.duration=o=>e.check(ti(o))});function c(e){return ts(ai,e)}const N=d("ZodStringFormat",(e,t)=>{E.init(e,t),bo.init(e,t)}),ci=d("ZodEmail",(e,t)=>{ar.init(e,t),N.init(e,t)}),Ht=d("ZodGUID",(e,t)=>{sr.init(e,t),N.init(e,t)}),Ie=d("ZodUUID",(e,t)=>{ir.init(e,t),N.init(e,t)}),ui=d("ZodURL",(e,t)=>{cr.init(e,t),N.init(e,t)}),li=d("ZodEmoji",(e,t)=>{ur.init(e,t),N.init(e,t)}),di=d("ZodNanoID",(e,t)=>{lr.init(e,t),N.init(e,t)}),pi=d("ZodCUID",(e,t)=>{dr.init(e,t),N.init(e,t)}),mi=d("ZodCUID2",(e,t)=>{pr.init(e,t),N.init(e,t)}),hi=d("ZodULID",(e,t)=>{mr.init(e,t),N.init(e,t)}),fi=d("ZodXID",(e,t)=>{hr.init(e,t),N.init(e,t)}),gi=d("ZodKSUID",(e,t)=>{fr.init(e,t),N.init(e,t)}),_i=d("ZodIPv4",(e,t)=>{kr.init(e,t),N.init(e,t)}),vi=d("ZodIPv6",(e,t)=>{wr.init(e,t),N.init(e,t)}),bi=d("ZodCIDRv4",(e,t)=>{yr.init(e,t),N.init(e,t)}),ki=d("ZodCIDRv6",(e,t)=>{Sr.init(e,t),N.init(e,t)}),wi=d("ZodBase64",(e,t)=>{Tr.init(e,t),N.init(e,t)}),yi=d("ZodBase64URL",(e,t)=>{xr.init(e,t),N.init(e,t)}),Si=d("ZodE164",(e,t)=>{Ir.init(e,t),N.init(e,t)}),Ti=d("ZodJWT",(e,t)=>{$r.init(e,t),N.init(e,t)}),ko=d("ZodNumber",(e,t)=>{mo.init(e,t),C.init(e,t),e.gt=(n,r)=>e.check(Ut(n,r)),e.gte=(n,r)=>e.check(Be(n,r)),e.min=(n,r)=>e.check(Be(n,r)),e.lt=(n,r)=>e.check(Lt(n,r)),e.lte=(n,r)=>e.check(Fe(n,r)),e.max=(n,r)=>e.check(Fe(n,r)),e.int=n=>e.check(Ft(n)),e.safe=n=>e.check(Ft(n)),e.positive=n=>e.check(Ut(0,n)),e.nonnegative=n=>e.check(Be(0,n)),e.negative=n=>e.check(Lt(0,n)),e.nonpositive=n=>e.check(Fe(0,n)),e.multipleOf=(n,r)=>e.check(jt(n,r)),e.step=(n,r)=>e.check(jt(n,r)),e.finite=()=>e;const o=e._zod.bag;e.minValue=Math.max(o.minimum??Number.NEGATIVE_INFINITY,o.exclusiveMinimum??Number.NEGATIVE_INFINITY)??null,e.maxValue=Math.min(o.maximum??Number.POSITIVE_INFINITY,o.exclusiveMaximum??Number.POSITIVE_INFINITY)??null,e.isInt=(o.format??"").includes("int")||Number.isSafeInteger(o.multipleOf??.5),e.isFinite=!0,e.format=o.format??null});function b(e){return Is(ko,e)}const zi=d("ZodNumberFormat",(e,t)=>{Zr.init(e,t),ko.init(e,t)});function Ft(e){return Rs(zi,e)}const xi=d("ZodBoolean",(e,t)=>{Pr.init(e,t),C.init(e,t)});function R(e){return $s(xi,e)}const Ii=d("ZodUndefined",(e,t)=>{Er.init(e,t),C.init(e,t)});function Ke(e){return Zs(Ii,e)}const Ri=d("ZodNull",(e,t)=>{Cr.init(e,t),C.init(e,t)});function wo(e){return Ps(Ri,e)}const $i=d("ZodUnknown",(e,t)=>{Nr.init(e,t),C.init(e,t)});function I(){return Es($i)}const Zi=d("ZodNever",(e,t)=>{qr.init(e,t),C.init(e,t)});function Pi(e){return Cs(Zi,e)}const Ei=d("ZodArray",(e,t)=>{Mr.init(e,t),C.init(e,t),e.element=t.element,e.min=(o,n)=>e.check(Pe(o,n)),e.nonempty=o=>e.check(Pe(1,o)),e.max=(o,n)=>e.check(fo(o,n)),e.length=(o,n)=>e.check(go(o,n)),e.unwrap=()=>e.element});function v(e,t){return Fs(Ei,e,t)}const yo=d("ZodObject",(e,t)=>{Or.init(e,t),C.init(e,t),Z(e,"shape",()=>t.shape),e.keyof=()=>j(Object.keys(e._zod.def.shape)),e.catchall=o=>e.clone({...e._zod.def,catchall:o}),e.passthrough=()=>e.clone({...e._zod.def,catchall:I()}),e.loose=()=>e.clone({...e._zod.def,catchall:I()}),e.strict=()=>e.clone({...e._zod.def,catchall:Pi()}),e.strip=()=>e.clone({...e._zod.def,catchall:void 0}),e.extend=o=>an(e,o),e.merge=o=>cn(e,o),e.pick=o=>rn(e,o),e.omit=o=>sn(e,o),e.partial=(...o)=>un(xo,e,o[0]),e.required=(...o)=>ln(Io,e,o[0])});function l(e,t){const o={type:"object",get shape(){return Ne(this,"shape",{...e}),this.shape},...h(t)};return new yo(o)}function L(e,t){return new yo({type:"object",get shape(){return Ne(this,"shape",{...e}),this.shape},catchall:I(),...h(t)})}const So=d("ZodUnion",(e,t)=>{ho.init(e,t),C.init(e,t),e.options=t.options});function w(e,t){return new So({type:"union",options:e,...h(t)})}const Ci=d("ZodDiscriminatedUnion",(e,t)=>{So.init(e,t),Ar.init(e,t)});function To(e,t,o){return new Ci({type:"union",options:t,discriminator:e,...h(o)})}const Ni=d("ZodIntersection",(e,t)=>{Dr.init(e,t),C.init(e,t)});function st(e,t){return new Ni({type:"intersection",left:e,right:t})}const qi=d("ZodRecord",(e,t)=>{Lr.init(e,t),C.init(e,t),e.keyType=t.keyType,e.valueType=t.valueType});function x(e,t,o){return new qi({type:"record",keyType:e,valueType:t,...h(o)})}const Ge=d("ZodEnum",(e,t)=>{Ur.init(e,t),C.init(e,t),e.enum=t.entries,e.options=Object.values(t.entries);const o=new Set(Object.keys(t.entries));e.extract=(n,r)=>{const s={};for(const i of n)if(o.has(i))s[i]=t.entries[i];else throw new Error(`Key ${i} not found in enum`);return new Ge({...t,checks:[],...h(r),entries:s})},e.exclude=(n,r)=>{const s={...t.entries};for(const i of n)if(o.has(i))delete s[i];else throw new Error(`Key ${i} not found in enum`);return new Ge({...t,checks:[],...h(r),entries:s})}});function j(e,t){const o=Array.isArray(e)?Object.fromEntries(e.map(n=>[n,n])):e;return new Ge({type:"enum",entries:o,...h(t)})}const Mi=d("ZodLiteral",(e,t)=>{jr.init(e,t),C.init(e,t),e.values=new Set(t.values),Object.defineProperty(e,"value",{get(){if(t.values.length>1)throw new Error("This schema contains multiple valid literal values. Use `.values` instead.");return t.values[0]}})});function a(e,t){return new Mi({type:"literal",values:Array.isArray(e)?e:[e],...h(t)})}const Oi=d("ZodTransform",(e,t)=>{Hr.init(e,t),C.init(e,t),e._zod.parse=(o,n)=>{o.addIssue=s=>{if(typeof s=="string")o.issues.push(ue(s,o.value,t));else{const i=s;i.fatal&&(i.continue=!1),i.code??(i.code="custom"),i.input??(i.input=o.value),i.inst??(i.inst=e),i.continue??(i.continue=!0),o.issues.push(ue(i))}};const r=t.transform(o.value,o);return r instanceof Promise?r.then(s=>(o.value=s,o)):(o.value=r,o)}});function zo(e){return new Oi({type:"transform",transform:e})}const xo=d("ZodOptional",(e,t)=>{Fr.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType});function q(e){return new xo({type:"optional",innerType:e})}const Ai=d("ZodNullable",(e,t)=>{Br.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType});function Bt(e){return new Ai({type:"nullable",innerType:e})}const Di=d("ZodDefault",(e,t)=>{Vr.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType,e.removeDefault=e.unwrap});function Li(e,t){return new Di({type:"default",innerType:e,get defaultValue(){return typeof t=="function"?t():t}})}const Ui=d("ZodPrefault",(e,t)=>{Wr.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType});function ji(e,t){return new Ui({type:"prefault",innerType:e,get defaultValue(){return typeof t=="function"?t():t}})}const Io=d("ZodNonOptional",(e,t)=>{Jr.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType});function Hi(e,t){return new Io({type:"nonoptional",innerType:e,...h(t)})}const Fi=d("ZodCatch",(e,t)=>{Kr.init(e,t),C.init(e,t),e.unwrap=()=>e._zod.def.innerType,e.removeCatch=e.unwrap});function Bi(e,t){return new Fi({type:"catch",innerType:e,catchValue:typeof t=="function"?t:()=>t})}const Vi=d("ZodPipe",(e,t)=>{Gr.init(e,t),C.init(e,t),e.in=t.in,e.out=t.out});function Qe(e,t){return new Vi({type:"pipe",in:e,out:t})}const Wi=d("ZodReadonly",(e,t)=>{Qr.init(e,t),C.init(e,t)});function Ji(e){return new Wi({type:"readonly",innerType:e})}const Ro=d("ZodCustom",(e,t)=>{Yr.init(e,t),C.init(e,t)});function Ki(e){const t=new U({check:"custom"});return t._zod.check=e,t}function Gi(e,t){return Bs(Ro,e??(()=>!0),t)}function Qi(e,t={}){return Vs(Ro,e,t)}function Yi(e){const t=Ki(o=>(o.addIssue=n=>{if(typeof n=="string")o.issues.push(ue(n,o.value,t._zod.def));else{const r=n;r.fatal&&(r.continue=!1),r.code??(r.code="custom"),r.input??(r.input=o.value),r.inst??(r.inst=t),r.continue??(r.continue=!t._zod.def.abort),o.issues.push(ue(r))}},e(o.value,o)));return t}function $o(e,t){return Qe(zo(e),t)}const X="io.modelcontextprotocol/related-task",Oe="2.0",O=Gi(e=>e!==null&&(typeof e=="object"||typeof e=="function")),Zo=w([c(),b().int()]),Po=c();L({ttl:w([b(),wo()]).optional(),pollInterval:b().optional()});const Xi=l({ttl:b().optional()}),ea=l({taskId:c()}),it=L({progressToken:Zo.optional(),[X]:ea.optional()}),H=l({_meta:it.optional()}),he=H.extend({task:Xi.optional()}),ta=e=>he.safeParse(e).success,A=l({method:c(),params:H.loose().optional()}),B=l({_meta:it.optional()}),V=l({method:c(),params:B.loose().optional()}),D=L({_meta:it.optional()}),fe=w([c(),b().int()]),Eo=l({jsonrpc:a(Oe),id:fe,...A.shape}).strict(),Vt=e=>Eo.safeParse(e).success,Co=l({jsonrpc:a(Oe),...V.shape}).strict(),oa=e=>Co.safeParse(e).success,at=l({jsonrpc:a(Oe),id:fe,result:D}).strict(),Re=e=>at.safeParse(e).success;var z;(function(e){e[e.ConnectionClosed=-32e3]="ConnectionClosed",e[e.RequestTimeout=-32001]="RequestTimeout",e[e.ParseError=-32700]="ParseError",e[e.InvalidRequest=-32600]="InvalidRequest",e[e.MethodNotFound=-32601]="MethodNotFound",e[e.InvalidParams=-32602]="InvalidParams",e[e.InternalError=-32603]="InternalError",e[e.UrlElicitationRequired=-32042]="UrlElicitationRequired"})(z||(z={}));const ct=l({jsonrpc:a(Oe),id:fe.optional(),error:l({code:b().int(),message:c(),data:I().optional()})}).strict(),na=e=>ct.safeParse(e).success,ra=w([Eo,Co,at,ct]);w([at,ct]);const ut=D.strict(),sa=B.extend({requestId:fe.optional(),reason:c().optional()}),lt=V.extend({method:a("notifications/cancelled"),params:sa}),ia=l({src:c(),mimeType:c().optional(),sizes:v(c()).optional(),theme:j(["light","dark"]).optional()}),ge=l({icons:v(ia).optional()}),oe=l({name:c(),title:c().optional()}),Ae=oe.extend({...oe.shape,...ge.shape,version:c(),websiteUrl:c().optional(),description:c().optional()}),aa=st(l({applyDefaults:R().optional()}),x(c(),I())),ca=$o(e=>e&&typeof e=="object"&&!Array.isArray(e)&&Object.keys(e).length===0?{form:{}}:e,st(l({form:aa.optional(),url:O.optional()}),x(c(),I()).optional())),ua=L({list:O.optional(),cancel:O.optional(),requests:L({sampling:L({createMessage:O.optional()}).optional(),elicitation:L({create:O.optional()}).optional()}).optional()}),la=L({list:O.optional(),cancel:O.optional(),requests:L({tools:L({call:O.optional()}).optional()}).optional()}),da=l({experimental:x(c(),O).optional(),sampling:l({context:O.optional(),tools:O.optional()}).optional(),elicitation:ca.optional(),roots:l({listChanged:R().optional()}).optional(),tasks:ua.optional()}),pa=H.extend({protocolVersion:c(),capabilities:da,clientInfo:Ae}),ma=A.extend({method:a("initialize"),params:pa}),ha=l({experimental:x(c(),O).optional(),logging:O.optional(),completions:O.optional(),prompts:l({listChanged:R().optional()}).optional(),resources:l({subscribe:R().optional(),listChanged:R().optional()}).optional(),tools:l({listChanged:R().optional()}).optional(),tasks:la.optional()}),fa=D.extend({protocolVersion:c(),capabilities:ha,serverInfo:Ae,instructions:c().optional()}),ga=V.extend({method:a("notifications/initialized"),params:B.optional()}),De=A.extend({method:a("ping"),params:H.optional()}),_a=l({progress:b(),total:q(b()),message:q(c())}),va=l({...B.shape,..._a.shape,progressToken:Zo}),dt=V.extend({method:a("notifications/progress"),params:va}),ba=H.extend({cursor:Po.optional()}),_e=A.extend({params:ba.optional()}),ve=D.extend({nextCursor:Po.optional()}),ka=j(["working","input_required","completed","failed","cancelled"]),be=l({taskId:c(),status:ka,ttl:w([b(),wo()]),createdAt:c(),lastUpdatedAt:c(),pollInterval:q(b()),statusMessage:q(c())}),pt=D.extend({task:be}),wa=B.merge(be),Ee=V.extend({method:a("notifications/tasks/status"),params:wa}),mt=A.extend({method:a("tasks/get"),params:H.extend({taskId:c()})}),ht=D.merge(be),ft=A.extend({method:a("tasks/result"),params:H.extend({taskId:c()})});D.loose();const gt=_e.extend({method:a("tasks/list")}),_t=ve.extend({tasks:v(be)}),vt=A.extend({method:a("tasks/cancel"),params:H.extend({taskId:c()})}),ya=D.merge(be),No=l({uri:c(),mimeType:q(c()),_meta:x(c(),I()).optional()}),qo=No.extend({text:c()}),bt=c().refine(e=>{try{return atob(e),!0}catch{return!1}},{message:"Invalid Base64 string"}),Mo=No.extend({blob:bt}),ke=j(["user","assistant"]),ne=l({audience:v(ke).optional(),priority:b().min(0).max(1).optional(),lastModified:vo({offset:!0}).optional()}),Oo=l({...oe.shape,...ge.shape,uri:c(),description:q(c()),mimeType:q(c()),annotations:ne.optional(),_meta:q(L({}))}),Sa=l({...oe.shape,...ge.shape,uriTemplate:c(),description:q(c()),mimeType:q(c()),annotations:ne.optional(),_meta:q(L({}))}),Ta=_e.extend({method:a("resources/list")}),Ao=ve.extend({resources:v(Oo)}),za=_e.extend({method:a("resources/templates/list")}),xa=ve.extend({resourceTemplates:v(Sa)}),kt=H.extend({uri:c()}),Ia=kt,Ra=A.extend({method:a("resources/read"),params:Ia}),Do=D.extend({contents:v(w([qo,Mo]))}),$a=V.extend({method:a("notifications/resources/list_changed"),params:B.optional()}),Za=kt,Pa=A.extend({method:a("resources/subscribe"),params:Za}),Ea=kt,Ca=A.extend({method:a("resources/unsubscribe"),params:Ea}),Na=B.extend({uri:c()}),qa=V.extend({method:a("notifications/resources/updated"),params:Na}),Ma=l({name:c(),description:q(c()),required:q(R())}),Oa=l({...oe.shape,...ge.shape,description:q(c()),arguments:q(v(Ma)),_meta:q(L({}))}),Aa=_e.extend({method:a("prompts/list")}),Da=ve.extend({prompts:v(Oa)}),La=H.extend({name:c(),arguments:x(c(),c()).optional()}),Ua=A.extend({method:a("prompts/get"),params:La}),wt=l({type:a("text"),text:c(),annotations:ne.optional(),_meta:x(c(),I()).optional()}),yt=l({type:a("image"),data:bt,mimeType:c(),annotations:ne.optional(),_meta:x(c(),I()).optional()}),St=l({type:a("audio"),data:bt,mimeType:c(),annotations:ne.optional(),_meta:x(c(),I()).optional()}),ja=l({type:a("tool_use"),name:c(),id:c(),input:x(c(),I()),_meta:x(c(),I()).optional()}),Lo=l({type:a("resource"),resource:w([qo,Mo]),annotations:ne.optional(),_meta:x(c(),I()).optional()}),Uo=Oo.extend({type:a("resource_link")}),we=w([wt,yt,St,Uo,Lo]),Ha=l({role:ke,content:we}),Fa=D.extend({description:c().optional(),messages:v(Ha)}),Ba=V.extend({method:a("notifications/prompts/list_changed"),params:B.optional()}),Va=l({title:c().optional(),readOnlyHint:R().optional(),destructiveHint:R().optional(),idempotentHint:R().optional(),openWorldHint:R().optional()}),Wa=l({taskSupport:j(["required","optional","forbidden"]).optional()}),Tt=l({...oe.shape,...ge.shape,description:c().optional(),inputSchema:l({type:a("object"),properties:x(c(),O).optional(),required:v(c()).optional()}).catchall(I()),outputSchema:l({type:a("object"),properties:x(c(),O).optional(),required:v(c()).optional()}).catchall(I()).optional(),annotations:Va.optional(),execution:Wa.optional(),_meta:x(c(),I()).optional()}),jo=_e.extend({method:a("tools/list")}),Ja=ve.extend({tools:v(Tt)}),Le=D.extend({content:v(we).default([]),structuredContent:x(c(),I()).optional(),isError:R().optional()});Le.or(D.extend({toolResult:I()}));const Ka=he.extend({name:c(),arguments:x(c(),I()).optional()}),Ho=A.extend({method:a("tools/call"),params:Ka}),Ga=V.extend({method:a("notifications/tools/list_changed"),params:B.optional()});l({autoRefresh:R().default(!0),debounceMs:b().int().nonnegative().default(300)});const Fo=j(["debug","info","notice","warning","error","critical","alert","emergency"]),Qa=H.extend({level:Fo}),Ya=A.extend({method:a("logging/setLevel"),params:Qa}),Xa=B.extend({level:Fo,logger:c().optional(),data:I()}),ec=V.extend({method:a("notifications/message"),params:Xa}),tc=l({name:c().optional()}),oc=l({hints:v(tc).optional(),costPriority:b().min(0).max(1).optional(),speedPriority:b().min(0).max(1).optional(),intelligencePriority:b().min(0).max(1).optional()}),nc=l({mode:j(["auto","required","none"]).optional()}),rc=l({type:a("tool_result"),toolUseId:c().describe("The unique identifier for the corresponding tool call."),content:v(we).default([]),structuredContent:l({}).loose().optional(),isError:R().optional(),_meta:x(c(),I()).optional()}),sc=To("type",[wt,yt,St]),Ce=To("type",[wt,yt,St,ja,rc]),ic=l({role:ke,content:w([Ce,v(Ce)]),_meta:x(c(),I()).optional()}),ac=he.extend({messages:v(ic),modelPreferences:oc.optional(),systemPrompt:c().optional(),includeContext:j(["none","thisServer","allServers"]).optional(),temperature:b().optional(),maxTokens:b().int(),stopSequences:v(c()).optional(),metadata:O.optional(),tools:v(Tt).optional(),toolChoice:nc.optional()}),cc=A.extend({method:a("sampling/createMessage"),params:ac}),uc=D.extend({model:c(),stopReason:q(j(["endTurn","stopSequence","maxTokens"]).or(c())),role:ke,content:sc}),lc=D.extend({model:c(),stopReason:q(j(["endTurn","stopSequence","maxTokens","toolUse"]).or(c())),role:ke,content:w([Ce,v(Ce)])}),dc=l({type:a("boolean"),title:c().optional(),description:c().optional(),default:R().optional()}),pc=l({type:a("string"),title:c().optional(),description:c().optional(),minLength:b().optional(),maxLength:b().optional(),format:j(["email","uri","date","date-time"]).optional(),default:c().optional()}),mc=l({type:j(["number","integer"]),title:c().optional(),description:c().optional(),minimum:b().optional(),maximum:b().optional(),default:b().optional()}),hc=l({type:a("string"),title:c().optional(),description:c().optional(),enum:v(c()),default:c().optional()}),fc=l({type:a("string"),title:c().optional(),description:c().optional(),oneOf:v(l({const:c(),title:c()})),default:c().optional()}),gc=l({type:a("string"),title:c().optional(),description:c().optional(),enum:v(c()),enumNames:v(c()).optional(),default:c().optional()}),_c=w([hc,fc]),vc=l({type:a("array"),title:c().optional(),description:c().optional(),minItems:b().optional(),maxItems:b().optional(),items:l({type:a("string"),enum:v(c())}),default:v(c()).optional()}),bc=l({type:a("array"),title:c().optional(),description:c().optional(),minItems:b().optional(),maxItems:b().optional(),items:l({anyOf:v(l({const:c(),title:c()}))}),default:v(c()).optional()}),kc=w([vc,bc]),wc=w([gc,_c,kc]),yc=w([wc,dc,pc,mc]),Sc=he.extend({mode:a("form").optional(),message:c(),requestedSchema:l({type:a("object"),properties:x(c(),yc),required:v(c()).optional()})}),Tc=he.extend({mode:a("url"),message:c(),elicitationId:c(),url:c().url()}),zc=w([Sc,Tc]),xc=A.extend({method:a("elicitation/create"),params:zc}),Ic=B.extend({elicitationId:c()}),Rc=V.extend({method:a("notifications/elicitation/complete"),params:Ic}),$c=D.extend({action:j(["accept","decline","cancel"]),content:$o(e=>e===null?void 0:e,x(c(),w([c(),b(),R(),v(c())])).optional())}),Zc=l({type:a("ref/resource"),uri:c()}),Pc=l({type:a("ref/prompt"),name:c()}),Ec=H.extend({ref:w([Pc,Zc]),argument:l({name:c(),value:c()}),context:l({arguments:x(c(),c()).optional()}).optional()}),Cc=A.extend({method:a("completion/complete"),params:Ec}),Nc=D.extend({completion:L({values:v(c()).max(100),total:q(b().int()),hasMore:q(R())})}),qc=l({uri:c().startsWith("file://"),name:c().optional(),_meta:x(c(),I()).optional()}),Mc=A.extend({method:a("roots/list"),params:H.optional()}),Oc=D.extend({roots:v(qc)}),Ac=V.extend({method:a("notifications/roots/list_changed"),params:B.optional()});w([De,ma,Cc,Ya,Ua,Aa,Ta,za,Ra,Pa,Ca,Ho,jo,mt,ft,gt,vt]);w([lt,dt,ga,Ac,Ee]);w([ut,uc,lc,$c,Oc,ht,_t,pt]);w([De,cc,xc,Mc,mt,ft,gt,vt]);w([lt,dt,ec,qa,$a,Ga,Ba,Ee,Rc]);w([ut,fa,Nc,Fa,Da,Ao,xa,Do,Le,Ja,ht,_t,pt]);class T extends Error{constructor(t,o,n){super(`MCP error ${t}: ${o}`),this.code=t,this.data=n,this.name="McpError"}static fromError(t,o,n){if(t===z.UrlElicitationRequired&&n){const r=n;if(r.elicitations)return new Dc(r.elicitations,o)}return new T(t,o,n)}}class Dc extends T{constructor(t,o=`URL elicitation${t.length>1?"s":""} required`){super(z.UrlElicitationRequired,o,{elicitations:t})}get elicitations(){return this.data?.elicitations??[]}}function Y(e){return e==="completed"||e==="failed"||e==="cancelled"}new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function Wt(e){const o=Ws(e)?.method;if(!o)throw new Error("Schema is missing a method literal");const n=Js(o);if(typeof n!="string")throw new Error("Schema method literal must be a string");return n}function Jt(e,t){const o=_o(e,t);if(!o.success)throw o.error;return o.data}const Lc=6e4;class Uc{constructor(t){this._options=t,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(lt,o=>{this._oncancel(o)}),this.setNotificationHandler(dt,o=>{this._onprogress(o)}),this.setRequestHandler(De,o=>({})),this._taskStore=t?.taskStore,this._taskMessageQueue=t?.taskMessageQueue,this._taskStore&&(this.setRequestHandler(mt,async(o,n)=>{const r=await this._taskStore.getTask(o.params.taskId,n.sessionId);if(!r)throw new T(z.InvalidParams,"Failed to retrieve task: Task not found");return{...r}}),this.setRequestHandler(ft,async(o,n)=>{const r=async()=>{const s=o.params.taskId;if(this._taskMessageQueue){let u;for(;u=await this._taskMessageQueue.dequeue(s,n.sessionId);){if(u.type==="response"||u.type==="error"){const p=u.message,f=p.id,g=this._requestResolvers.get(f);if(g)if(this._requestResolvers.delete(f),u.type==="response")g(p);else{const m=p,_=new T(m.error.code,m.error.message,m.error.data);g(_)}else{const m=u.type==="response"?"Response":"Error";this._onerror(new Error(`${m} handler missing for request ${f}`))}continue}await this._transport?.send(u.message,{relatedRequestId:n.requestId})}}const i=await this._taskStore.getTask(s,n.sessionId);if(!i)throw new T(z.InvalidParams,`Task not found: ${s}`);if(!Y(i.status))return await this._waitForTaskUpdate(s,n.signal),await r();if(Y(i.status)){const u=await this._taskStore.getTaskResult(s,n.sessionId);return this._clearTaskQueue(s),{...u,_meta:{...u._meta,[X]:{taskId:s}}}}return await r()};return await r()}),this.setRequestHandler(gt,async(o,n)=>{try{const{tasks:r,nextCursor:s}=await this._taskStore.listTasks(o.params?.cursor,n.sessionId);return{tasks:r,nextCursor:s,_meta:{}}}catch(r){throw new T(z.InvalidParams,`Failed to list tasks: ${r instanceof Error?r.message:String(r)}`)}}),this.setRequestHandler(vt,async(o,n)=>{try{const r=await this._taskStore.getTask(o.params.taskId,n.sessionId);if(!r)throw new T(z.InvalidParams,`Task not found: ${o.params.taskId}`);if(Y(r.status))throw new T(z.InvalidParams,`Cannot cancel task in terminal status: ${r.status}`);await this._taskStore.updateTaskStatus(o.params.taskId,"cancelled","Client cancelled task execution.",n.sessionId),this._clearTaskQueue(o.params.taskId);const s=await this._taskStore.getTask(o.params.taskId,n.sessionId);if(!s)throw new T(z.InvalidParams,`Task not found after cancellation: ${o.params.taskId}`);return{_meta:{},...s}}catch(r){throw r instanceof T?r:new T(z.InvalidRequest,`Failed to cancel task: ${r instanceof Error?r.message:String(r)}`)}}))}async _oncancel(t){if(!t.params.requestId)return;this._requestHandlerAbortControllers.get(t.params.requestId)?.abort(t.params.reason)}_setupTimeout(t,o,n,r,s=!1){this._timeoutInfo.set(t,{timeoutId:setTimeout(r,o),startTime:Date.now(),timeout:o,maxTotalTimeout:n,resetTimeoutOnProgress:s,onTimeout:r})}_resetTimeout(t){const o=this._timeoutInfo.get(t);if(!o)return!1;const n=Date.now()-o.startTime;if(o.maxTotalTimeout&&n>=o.maxTotalTimeout)throw this._timeoutInfo.delete(t),T.fromError(z.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:o.maxTotalTimeout,totalElapsed:n});return clearTimeout(o.timeoutId),o.timeoutId=setTimeout(o.onTimeout,o.timeout),!0}_cleanupTimeout(t){const o=this._timeoutInfo.get(t);o&&(clearTimeout(o.timeoutId),this._timeoutInfo.delete(t))}async connect(t){if(this._transport)throw new Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=t;const o=this.transport?.onclose;this._transport.onclose=()=>{o?.(),this._onclose()};const n=this.transport?.onerror;this._transport.onerror=s=>{n?.(s),this._onerror(s)};const r=this._transport?.onmessage;this._transport.onmessage=(s,i)=>{r?.(s,i),Re(s)||na(s)?this._onresponse(s):Vt(s)?this._onrequest(s,i):oa(s)?this._onnotification(s):this._onerror(new Error(`Unknown message type: ${JSON.stringify(s)}`))},await this._transport.start()}_onclose(){const t=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(const n of this._requestHandlerAbortControllers.values())n.abort();this._requestHandlerAbortControllers.clear();const o=T.fromError(z.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(const n of t.values())n(o)}_onerror(t){this.onerror?.(t)}_onnotification(t){const o=this._notificationHandlers.get(t.method)??this.fallbackNotificationHandler;o!==void 0&&Promise.resolve().then(()=>o(t)).catch(n=>this._onerror(new Error(`Uncaught error in notification handler: ${n}`)))}_onrequest(t,o){const n=this._requestHandlers.get(t.method)??this.fallbackRequestHandler,r=this._transport,s=t.params?._meta?.[X]?.taskId;if(n===void 0){const g={jsonrpc:"2.0",id:t.id,error:{code:z.MethodNotFound,message:"Method not found"}};s&&this._taskMessageQueue?this._enqueueTaskMessage(s,{type:"error",message:g,timestamp:Date.now()},r?.sessionId).catch(m=>this._onerror(new Error(`Failed to enqueue error response: ${m}`))):r?.send(g).catch(m=>this._onerror(new Error(`Failed to send an error response: ${m}`)));return}const i=new AbortController;this._requestHandlerAbortControllers.set(t.id,i);const u=ta(t.params)?t.params.task:void 0,p=this._taskStore?this.requestTaskStore(t,r?.sessionId):void 0,f={signal:i.signal,sessionId:r?.sessionId,_meta:t.params?._meta,sendNotification:async g=>{if(i.signal.aborted)return;const m={relatedRequestId:t.id};s&&(m.relatedTask={taskId:s}),await this.notification(g,m)},sendRequest:async(g,m,_)=>{if(i.signal.aborted)throw new T(z.ConnectionClosed,"Request was cancelled");const k={..._,relatedRequestId:t.id};s&&!k.relatedTask&&(k.relatedTask={taskId:s});const M=k.relatedTask?.taskId??s;return M&&p&&await p.updateTaskStatus(M,"input_required"),await this.request(g,m,k)},authInfo:o?.authInfo,requestId:t.id,requestInfo:o?.requestInfo,taskId:s,taskStore:p,taskRequestedTtl:u?.ttl,closeSSEStream:o?.closeSSEStream,closeStandaloneSSEStream:o?.closeStandaloneSSEStream};Promise.resolve().then(()=>{u&&this.assertTaskHandlerCapability(t.method)}).then(()=>n(t,f)).then(async g=>{if(i.signal.aborted)return;const m={result:g,jsonrpc:"2.0",id:t.id};s&&this._taskMessageQueue?await this._enqueueTaskMessage(s,{type:"response",message:m,timestamp:Date.now()},r?.sessionId):await r?.send(m)},async g=>{if(i.signal.aborted)return;const m={jsonrpc:"2.0",id:t.id,error:{code:Number.isSafeInteger(g.code)?g.code:z.InternalError,message:g.message??"Internal error",...g.data!==void 0&&{data:g.data}}};s&&this._taskMessageQueue?await this._enqueueTaskMessage(s,{type:"error",message:m,timestamp:Date.now()},r?.sessionId):await r?.send(m)}).catch(g=>this._onerror(new Error(`Failed to send response: ${g}`))).finally(()=>{this._requestHandlerAbortControllers.delete(t.id)})}_onprogress(t){const{progressToken:o,...n}=t.params,r=Number(o),s=this._progressHandlers.get(r);if(!s){this._onerror(new Error(`Received a progress notification for an unknown token: ${JSON.stringify(t)}`));return}const i=this._responseHandlers.get(r),u=this._timeoutInfo.get(r);if(u&&i&&u.resetTimeoutOnProgress)try{this._resetTimeout(r)}catch(p){this._responseHandlers.delete(r),this._progressHandlers.delete(r),this._cleanupTimeout(r),i(p);return}s(n)}_onresponse(t){const o=Number(t.id),n=this._requestResolvers.get(o);if(n){if(this._requestResolvers.delete(o),Re(t))n(t);else{const i=new T(t.error.code,t.error.message,t.error.data);n(i)}return}const r=this._responseHandlers.get(o);if(r===void 0){this._onerror(new Error(`Received a response for an unknown message ID: ${JSON.stringify(t)}`));return}this._responseHandlers.delete(o),this._cleanupTimeout(o);let s=!1;if(Re(t)&&t.result&&typeof t.result=="object"){const i=t.result;if(i.task&&typeof i.task=="object"){const u=i.task;typeof u.taskId=="string"&&(s=!0,this._taskProgressTokens.set(u.taskId,o))}}if(s||this._progressHandlers.delete(o),Re(t))r(t);else{const i=T.fromError(t.error.code,t.error.message,t.error.data);r(i)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream(t,o,n){const{task:r}=n??{};if(!r){try{yield{type:"result",result:await this.request(t,o,n)}}catch(i){yield{type:"error",error:i instanceof T?i:new T(z.InternalError,String(i))}}return}let s;try{const i=await this.request(t,pt,n);if(i.task)s=i.task.taskId,yield{type:"taskCreated",task:i.task};else throw new T(z.InternalError,"Task creation did not return a task");for(;;){const u=await this.getTask({taskId:s},n);if(yield{type:"taskStatus",task:u},Y(u.status)){u.status==="completed"?yield{type:"result",result:await this.getTaskResult({taskId:s},o,n)}:u.status==="failed"?yield{type:"error",error:new T(z.InternalError,`Task ${s} failed`)}:u.status==="cancelled"&&(yield{type:"error",error:new T(z.InternalError,`Task ${s} was cancelled`)});return}if(u.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:s},o,n)};return}const p=u.pollInterval??this._options?.defaultTaskPollInterval??1e3;await new Promise(f=>setTimeout(f,p)),n?.signal?.throwIfAborted()}}catch(i){yield{type:"error",error:i instanceof T?i:new T(z.InternalError,String(i))}}}request(t,o,n){const{relatedRequestId:r,resumptionToken:s,onresumptiontoken:i,task:u,relatedTask:p}=n??{};return new Promise((f,g)=>{const m=S=>{g(S)};if(!this._transport){m(new Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{this.assertCapabilityForMethod(t.method),u&&this.assertTaskCapability(t.method)}catch(S){m(S);return}n?.signal?.throwIfAborted();const _=this._requestMessageId++,k={...t,jsonrpc:"2.0",id:_};n?.onprogress&&(this._progressHandlers.set(_,n.onprogress),k.params={...t.params,_meta:{...t.params?._meta||{},progressToken:_}}),u&&(k.params={...k.params,task:u}),p&&(k.params={...k.params,_meta:{...k.params?._meta||{},[X]:p}});const M=S=>{this._responseHandlers.delete(_),this._progressHandlers.delete(_),this._cleanupTimeout(_),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:_,reason:String(S)}},{relatedRequestId:r,resumptionToken:s,onresumptiontoken:i}).catch(P=>this._onerror(new Error(`Failed to send cancellation: ${P}`)));const y=S instanceof T?S:new T(z.RequestTimeout,String(S));g(y)};this._responseHandlers.set(_,S=>{if(!n?.signal?.aborted){if(S instanceof Error)return g(S);try{const y=_o(o,S.result);y.success?f(y.data):g(y.error)}catch(y){g(y)}}}),n?.signal?.addEventListener("abort",()=>{M(n?.signal?.reason)});const F=n?.timeout??Lc,re=()=>M(T.fromError(z.RequestTimeout,"Request timed out",{timeout:F}));this._setupTimeout(_,F,n?.maxTotalTimeout,re,n?.resetTimeoutOnProgress??!1);const Q=p?.taskId;if(Q){const S=y=>{const P=this._responseHandlers.get(_);P?P(y):this._onerror(new Error(`Response handler missing for side-channeled request ${_}`))};this._requestResolvers.set(_,S),this._enqueueTaskMessage(Q,{type:"request",message:k,timestamp:Date.now()}).catch(y=>{this._cleanupTimeout(_),g(y)})}else this._transport.send(k,{relatedRequestId:r,resumptionToken:s,onresumptiontoken:i}).catch(S=>{this._cleanupTimeout(_),g(S)})})}async getTask(t,o){return this.request({method:"tasks/get",params:t},ht,o)}async getTaskResult(t,o,n){return this.request({method:"tasks/result",params:t},o,n)}async listTasks(t,o){return this.request({method:"tasks/list",params:t},_t,o)}async cancelTask(t,o){return this.request({method:"tasks/cancel",params:t},ya,o)}async notification(t,o){if(!this._transport)throw new Error("Not connected");this.assertNotificationCapability(t.method);const n=o?.relatedTask?.taskId;if(n){const u={...t,jsonrpc:"2.0",params:{...t.params,_meta:{...t.params?._meta||{},[X]:o.relatedTask}}};await this._enqueueTaskMessage(n,{type:"notification",message:u,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes(t.method)&&!t.params&&!o?.relatedRequestId&&!o?.relatedTask){if(this._pendingDebouncedNotifications.has(t.method))return;this._pendingDebouncedNotifications.add(t.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete(t.method),!this._transport)return;let u={...t,jsonrpc:"2.0"};o?.relatedTask&&(u={...u,params:{...u.params,_meta:{...u.params?._meta||{},[X]:o.relatedTask}}}),this._transport?.send(u,o).catch(p=>this._onerror(p))});return}let i={...t,jsonrpc:"2.0"};o?.relatedTask&&(i={...i,params:{...i.params,_meta:{...i.params?._meta||{},[X]:o.relatedTask}}}),await this._transport.send(i,o)}setRequestHandler(t,o){const n=Wt(t);this.assertRequestHandlerCapability(n),this._requestHandlers.set(n,(r,s)=>{const i=Jt(t,r);return Promise.resolve(o(i,s))})}removeRequestHandler(t){this._requestHandlers.delete(t)}assertCanSetRequestHandler(t){if(this._requestHandlers.has(t))throw new Error(`A request handler for ${t} already exists, which would be overridden`)}setNotificationHandler(t,o){const n=Wt(t);this._notificationHandlers.set(n,r=>{const s=Jt(t,r);return Promise.resolve(o(s))})}removeNotificationHandler(t){this._notificationHandlers.delete(t)}_cleanupTaskProgressHandler(t){const o=this._taskProgressTokens.get(t);o!==void 0&&(this._progressHandlers.delete(o),this._taskProgressTokens.delete(t))}async _enqueueTaskMessage(t,o,n){if(!this._taskStore||!this._taskMessageQueue)throw new Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");const r=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue(t,o,n,r)}async _clearTaskQueue(t,o){if(this._taskMessageQueue){const n=await this._taskMessageQueue.dequeueAll(t,o);for(const r of n)if(r.type==="request"&&Vt(r.message)){const s=r.message.id,i=this._requestResolvers.get(s);i?(i(new T(z.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(s)):this._onerror(new Error(`Resolver missing for request ${s} during task ${t} cleanup`))}}}async _waitForTaskUpdate(t,o){let n=this._options?.defaultTaskPollInterval??1e3;try{const r=await this._taskStore?.getTask(t);r?.pollInterval&&(n=r.pollInterval)}catch{}return new Promise((r,s)=>{if(o.aborted){s(new T(z.InvalidRequest,"Request cancelled"));return}const i=setTimeout(r,n);o.addEventListener("abort",()=>{clearTimeout(i),s(new T(z.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore(t,o){const n=this._taskStore;if(!n)throw new Error("No task store configured");return{createTask:async r=>{if(!t)throw new Error("No request provided");return await n.createTask(r,t.id,{method:t.method,params:t.params},o)},getTask:async r=>{const s=await n.getTask(r,o);if(!s)throw new T(z.InvalidParams,"Failed to retrieve task: Task not found");return s},storeTaskResult:async(r,s,i)=>{await n.storeTaskResult(r,s,i,o);const u=await n.getTask(r,o);if(u){const p=Ee.parse({method:"notifications/tasks/status",params:u});await this.notification(p),Y(u.status)&&this._cleanupTaskProgressHandler(r)}},getTaskResult:r=>n.getTaskResult(r,o),updateTaskStatus:async(r,s,i)=>{const u=await n.getTask(r,o);if(!u)throw new T(z.InvalidParams,`Task "${r}" not found - it may have been cleaned up`);if(Y(u.status))throw new T(z.InvalidParams,`Cannot update task "${r}" from terminal status "${u.status}" to "${s}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await n.updateTaskStatus(r,s,i,o);const p=await n.getTask(r,o);if(p){const f=Ee.parse({method:"notifications/tasks/status",params:p});await this.notification(f),Y(p.status)&&this._cleanupTaskProgressHandler(r)}},listTasks:r=>n.listTasks(r,o)}}}var jc="2026-01-26",Hc="ui/notifications/tool-input-partial";class Bo{eventTarget;eventSource;messageListener;constructor(t=window.parent,o){this.eventTarget=t,this.eventSource=o,this.messageListener=n=>{if(o&&n.source!==this.eventSource){console.debug("Ignoring message from unknown source",n);return}let r=ra.safeParse(n.data);r.success?(console.debug("Parsed message",r.data),this.onmessage?.(r.data)):n.data?.jsonrpc!=="2.0"?console.debug("Ignoring non-JSON-RPC message",r.error.message,n):(console.error("Failed to parse message",r.error.message,n),this.onerror?.(Error("Invalid JSON-RPC message received: "+r.error.message)))}}async start(){window.addEventListener("message",this.messageListener)}async send(t,o){t.method!==Hc&&console.debug("Sending message",t),this.eventTarget.postMessage(t,"*")}async close(){window.removeEventListener("message",this.messageListener),this.onclose?.()}onclose;onerror;onmessage;sessionId;setProtocolVersion}var Fc=w([a("light"),a("dark")]).describe("Color theme preference for the host environment."),le=w([a("inline"),a("fullscreen"),a("pip")]).describe("Display mode for UI presentation."),Bc=w([a("--color-background-primary"),a("--color-background-secondary"),a("--color-background-tertiary"),a("--color-background-inverse"),a("--color-background-ghost"),a("--color-background-info"),a("--color-background-danger"),a("--color-background-success"),a("--color-background-warning"),a("--color-background-disabled"),a("--color-text-primary"),a("--color-text-secondary"),a("--color-text-tertiary"),a("--color-text-inverse"),a("--color-text-ghost"),a("--color-text-info"),a("--color-text-danger"),a("--color-text-success"),a("--color-text-warning"),a("--color-text-disabled"),a("--color-border-primary"),a("--color-border-secondary"),a("--color-border-tertiary"),a("--color-border-inverse"),a("--color-border-ghost"),a("--color-border-info"),a("--color-border-danger"),a("--color-border-success"),a("--color-border-warning"),a("--color-border-disabled"),a("--color-ring-primary"),a("--color-ring-secondary"),a("--color-ring-inverse"),a("--color-ring-info"),a("--color-ring-danger"),a("--color-ring-success"),a("--color-ring-warning"),a("--font-sans"),a("--font-mono"),a("--font-weight-normal"),a("--font-weight-medium"),a("--font-weight-semibold"),a("--font-weight-bold"),a("--font-text-xs-size"),a("--font-text-sm-size"),a("--font-text-md-size"),a("--font-text-lg-size"),a("--font-heading-xs-size"),a("--font-heading-sm-size"),a("--font-heading-md-size"),a("--font-heading-lg-size"),a("--font-heading-xl-size"),a("--font-heading-2xl-size"),a("--font-heading-3xl-size"),a("--font-text-xs-line-height"),a("--font-text-sm-line-height"),a("--font-text-md-line-height"),a("--font-text-lg-line-height"),a("--font-heading-xs-line-height"),a("--font-heading-sm-line-height"),a("--font-heading-md-line-height"),a("--font-heading-lg-line-height"),a("--font-heading-xl-line-height"),a("--font-heading-2xl-line-height"),a("--font-heading-3xl-line-height"),a("--border-radius-xs"),a("--border-radius-sm"),a("--border-radius-md"),a("--border-radius-lg"),a("--border-radius-xl"),a("--border-radius-full"),a("--border-width-regular"),a("--shadow-hairline"),a("--shadow-sm"),a("--shadow-md"),a("--shadow-lg")]).describe("CSS variable keys available to MCP apps for theming."),Vc=x(Bc.describe(`Style variables for theming MCP apps.
33
+
34
+ Individual style keys are optional - hosts may provide any subset of these values.
35
+ Values are strings containing CSS values (colors, sizes, font stacks, etc.).
36
+
37
+ Note: This type uses \`Record<K, string | undefined>\` rather than \`Partial<Record<K, string>>\`
38
+ for compatibility with Zod schema generation. Both are functionally equivalent for validation.`),w([c(),Ke()]).describe(`Style variables for theming MCP apps.
39
+
40
+ Individual style keys are optional - hosts may provide any subset of these values.
41
+ Values are strings containing CSS values (colors, sizes, font stacks, etc.).
42
+
43
+ Note: This type uses \`Record<K, string | undefined>\` rather than \`Partial<Record<K, string>>\`
44
+ for compatibility with Zod schema generation. Both are functionally equivalent for validation.`)).describe(`Style variables for theming MCP apps.
45
+
46
+ Individual style keys are optional - hosts may provide any subset of these values.
47
+ Values are strings containing CSS values (colors, sizes, font stacks, etc.).
48
+
49
+ Note: This type uses \`Record<K, string | undefined>\` rather than \`Partial<Record<K, string>>\`
50
+ for compatibility with Zod schema generation. Both are functionally equivalent for validation.`);l({method:a("ui/open-link"),params:l({url:c().describe("URL to open in the host's browser")})});var Wc=l({isError:R().optional().describe("True if the host failed to open the URL (e.g., due to security policy).")}).passthrough(),Jc=l({isError:R().optional().describe("True if the download failed (e.g., user cancelled or host denied).")}).passthrough(),Kc=l({isError:R().optional().describe("True if the host rejected or failed to deliver the message.")}).passthrough();l({method:a("ui/notifications/sandbox-proxy-ready"),params:l({})});var zt=l({connectDomains:v(c()).optional().describe(`Origins for network requests (fetch/XHR/WebSocket).
51
+
52
+ - Maps to CSP \`connect-src\` directive
53
+ - Empty or omitted → no network connections (secure default)`),resourceDomains:v(c()).optional().describe("Origins for static resources (images, scripts, stylesheets, fonts, media).\n\n- Maps to CSP `img-src`, `script-src`, `style-src`, `font-src`, `media-src` directives\n- Wildcard subdomains supported: `https://*.example.com`\n- Empty or omitted → no network resources (secure default)"),frameDomains:v(c()).optional().describe("Origins for nested iframes.\n\n- Maps to CSP `frame-src` directive\n- Empty or omitted → no nested iframes allowed (`frame-src 'none'`)"),baseUriDomains:v(c()).optional().describe("Allowed base URIs for the document.\n\n- Maps to CSP `base-uri` directive\n- Empty or omitted → only same origin allowed (`base-uri 'self'`)")}),xt=l({camera:l({}).optional().describe("Request camera access.\n\nMaps to Permission Policy `camera` feature."),microphone:l({}).optional().describe("Request microphone access.\n\nMaps to Permission Policy `microphone` feature."),geolocation:l({}).optional().describe("Request geolocation access.\n\nMaps to Permission Policy `geolocation` feature."),clipboardWrite:l({}).optional().describe("Request clipboard write access.\n\nMaps to Permission Policy `clipboard-write` feature.")});l({method:a("ui/notifications/size-changed"),params:l({width:b().optional().describe("New width in pixels."),height:b().optional().describe("New height in pixels.")})});var Gc=l({method:a("ui/notifications/tool-input"),params:l({arguments:x(c(),I().describe("Complete tool call arguments as key-value pairs.")).optional().describe("Complete tool call arguments as key-value pairs.")})}),Qc=l({method:a("ui/notifications/tool-input-partial"),params:l({arguments:x(c(),I().describe("Partial tool call arguments (incomplete, may change).")).optional().describe("Partial tool call arguments (incomplete, may change).")})}),Yc=l({method:a("ui/notifications/tool-cancelled"),params:l({reason:c().optional().describe('Optional reason for the cancellation (e.g., "user action", "timeout").')})}),Xc=l({fonts:c().optional()}),eu=l({variables:Vc.optional().describe("CSS variables for theming the app."),css:Xc.optional().describe("CSS blocks that apps can inject.")}),tu=l({method:a("ui/resource-teardown"),params:l({})});x(c(),I());var Kt=l({text:l({}).optional().describe("Host supports text content blocks."),image:l({}).optional().describe("Host supports image content blocks."),audio:l({}).optional().describe("Host supports audio content blocks."),resource:l({}).optional().describe("Host supports resource content blocks."),resourceLink:l({}).optional().describe("Host supports resource link content blocks."),structuredContent:l({}).optional().describe("Host supports structured content.")});l({method:a("ui/notifications/request-teardown"),params:l({}).optional()});var ou=l({experimental:l({}).optional().describe("Experimental features (structure TBD)."),openLinks:l({}).optional().describe("Host supports opening external URLs."),downloadFile:l({}).optional().describe("Host supports file downloads via ui/download-file."),serverTools:l({listChanged:R().optional().describe("Host supports tools/list_changed notifications.")}).optional().describe("Host can proxy tool calls to the MCP server."),serverResources:l({listChanged:R().optional().describe("Host supports resources/list_changed notifications.")}).optional().describe("Host can proxy resource reads to the MCP server."),logging:l({}).optional().describe("Host accepts log messages."),sandbox:l({permissions:xt.optional().describe("Permissions granted by the host (camera, microphone, geolocation)."),csp:zt.optional().describe("CSP domains approved by the host.")}).optional().describe("Sandbox configuration applied by the host."),updateModelContext:Kt.optional().describe("Host accepts context updates (ui/update-model-context) to be included in the model's context for future turns."),message:Kt.optional().describe("Host supports receiving content messages (ui/message) from the view.")}),nu=l({experimental:l({}).optional().describe("Experimental features (structure TBD)."),tools:l({listChanged:R().optional().describe("App supports tools/list_changed notifications.")}).optional().describe("App exposes MCP-style tools that the host can call."),availableDisplayModes:v(le).optional().describe("Display modes the app supports.")});l({method:a("ui/notifications/initialized"),params:l({}).optional()});l({csp:zt.optional().describe("Content Security Policy configuration for UI resources."),permissions:xt.optional().describe("Sandbox permissions requested by the UI resource."),domain:c().optional().describe(`Dedicated origin for view sandbox.
54
+
55
+ Useful when views need stable, dedicated origins for OAuth callbacks, CORS policies, or API key allowlists.
56
+
57
+ **Host-dependent:** The format and validation rules for this field are determined by each host. Servers MUST consult host-specific documentation for the expected domain format. Common patterns include:
58
+ - Hash-based subdomains (e.g., \`{hash}.claudemcpcontent.com\`)
59
+ - URL-derived subdomains (e.g., \`www-example-com.oaiusercontent.com\`)
60
+
61
+ If omitted, host uses default sandbox origin (typically per-conversation).`),prefersBorder:R().optional().describe(`Visual boundary preference - true if view prefers a visible border.
62
+
63
+ Boolean requesting whether a visible border and background is provided by the host. Specifying an explicit value for this is recommended because hosts' defaults may vary.
64
+
65
+ - \`true\`: request visible border + background
66
+ - \`false\`: request no visible border + background
67
+ - omitted: host decides border`)});l({method:a("ui/request-display-mode"),params:l({mode:le.describe("The display mode being requested.")})});var ru=l({mode:le.describe("The display mode that was actually set. May differ from requested if not supported.")}).passthrough(),su=w([a("model"),a("app")]).describe("Tool visibility scope - who can access the tool.");l({resourceUri:c().optional(),visibility:v(su).optional().describe(`Who can access this tool. Default: ["model", "app"]
68
+ - "model": Tool visible to and callable by the agent
69
+ - "app": Tool callable by the app from this server only`)});l({mimeTypes:v(c()).optional().describe('Array of supported MIME types for UI resources.\nMust include `"text/html;profile=mcp-app"` for MCP Apps support.')});l({method:a("ui/download-file"),params:l({contents:v(w([Lo,Uo])).describe("Resource contents to download — embedded (inline data) or linked (host fetches). Uses standard MCP resource types.")})});l({method:a("ui/message"),params:l({role:a("user").describe('Message role, currently only "user" is supported.'),content:v(we).describe("Message content blocks (text, image, etc.).")})});l({method:a("ui/notifications/sandbox-resource-ready"),params:l({html:c().describe("HTML content to load into the inner iframe."),sandbox:c().optional().describe("Optional override for the inner iframe's sandbox attribute."),csp:zt.optional().describe("CSP configuration from resource metadata."),permissions:xt.optional().describe("Sandbox permissions from resource metadata.")})});var iu=l({method:a("ui/notifications/tool-result"),params:Le.describe("Standard MCP tool execution result.")}),Vo=l({toolInfo:l({id:fe.optional().describe("JSON-RPC id of the tools/call request."),tool:Tt.describe("Tool definition including name, inputSchema, etc.")}).optional().describe("Metadata of the tool call that instantiated this App."),theme:Fc.optional().describe("Current color theme preference."),styles:eu.optional().describe("Style configuration for theming the app."),displayMode:le.optional().describe("How the UI is currently displayed."),availableDisplayModes:v(le).optional().describe("Display modes the host supports."),containerDimensions:w([l({height:b().describe("Fixed container height in pixels.")}),l({maxHeight:w([b(),Ke()]).optional().describe("Maximum container height in pixels.")})]).and(w([l({width:b().describe("Fixed container width in pixels.")}),l({maxWidth:w([b(),Ke()]).optional().describe("Maximum container width in pixels.")})])).optional().describe(`Container dimensions. Represents the dimensions of the iframe or other
70
+ container holding the app. Specify either width or maxWidth, and either height or maxHeight.`),locale:c().optional().describe("User's language and region preference in BCP 47 format."),timeZone:c().optional().describe("User's timezone in IANA format."),userAgent:c().optional().describe("Host application identifier."),platform:w([a("web"),a("desktop"),a("mobile")]).optional().describe("Platform type for responsive design decisions."),deviceCapabilities:l({touch:R().optional().describe("Whether the device supports touch input."),hover:R().optional().describe("Whether the device supports hover interactions.")}).optional().describe("Device input capabilities."),safeAreaInsets:l({top:b().describe("Top safe area inset in pixels."),right:b().describe("Right safe area inset in pixels."),bottom:b().describe("Bottom safe area inset in pixels."),left:b().describe("Left safe area inset in pixels.")}).optional().describe("Mobile safe area boundaries in pixels.")}).passthrough(),au=l({method:a("ui/notifications/host-context-changed"),params:Vo.describe("Partial context update containing only changed fields.")});l({method:a("ui/update-model-context"),params:l({content:v(we).optional().describe("Context content blocks (text, image, etc.)."),structuredContent:x(c(),I().describe("Structured content for machine-readable context data.")).optional().describe("Structured content for machine-readable context data.")})});l({method:a("ui/initialize"),params:l({appInfo:Ae.describe("App identification (name and version)."),appCapabilities:nu.describe("Features and capabilities this app provides."),protocolVersion:c().describe("Protocol version this app supports.")})});var cu=l({protocolVersion:c().describe('Negotiated protocol version string (e.g., "2025-11-21").'),hostInfo:Ae.describe("Host application identification and version."),hostCapabilities:ou.describe("Features and capabilities provided by the host."),hostContext:Vo.describe("Rich context about the host environment.")}).passthrough();function uu(e,t=document.documentElement){for(let[o,n]of Object.entries(e))n!==void 0&&t.style.setProperty(o,n)}function lu(e){if(document.getElementById("__mcp-host-fonts"))return;let t=document.createElement("style");t.id="__mcp-host-fonts",t.textContent=e,document.head.appendChild(t)}class du extends Uc{_appInfo;_capabilities;options;_hostCapabilities;_hostInfo;_hostContext;constructor(t,o={},n={autoResize:!0}){super(n),this._appInfo=t,this._capabilities=o,this.options=n,this.setRequestHandler(De,r=>(console.log("Received ping:",r.params),{})),this.onhostcontextchanged=()=>{}}getHostCapabilities(){return this._hostCapabilities}getHostVersion(){return this._hostInfo}getHostContext(){return this._hostContext}set ontoolinput(t){this.setNotificationHandler(Gc,o=>t(o.params))}set ontoolinputpartial(t){this.setNotificationHandler(Qc,o=>t(o.params))}set ontoolresult(t){this.setNotificationHandler(iu,o=>t(o.params))}set ontoolcancelled(t){this.setNotificationHandler(Yc,o=>t(o.params))}set onhostcontextchanged(t){this.setNotificationHandler(au,o=>{this._hostContext={...this._hostContext,...o.params},t(o.params)})}set onteardown(t){this.setRequestHandler(tu,(o,n)=>t(o.params,n))}set oncalltool(t){this.setRequestHandler(Ho,(o,n)=>t(o.params,n))}set onlisttools(t){this.setRequestHandler(jo,(o,n)=>t(o.params,n))}assertCapabilityForMethod(t){}assertRequestHandlerCapability(t){switch(t){case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Client does not support tool capability (required for ${t})`);return;case"ping":case"ui/resource-teardown":return;default:throw Error(`No handler for method ${t} registered`)}}assertNotificationCapability(t){}assertTaskCapability(t){throw Error("Tasks are not supported in MCP Apps")}assertTaskHandlerCapability(t){throw Error("Task handlers are not supported in MCP Apps")}async callServerTool(t,o){if(typeof t=="string")throw Error(`callServerTool() expects an object as its first argument, but received a string ("${t}"). Did you mean: callServerTool({ name: "${t}", arguments: { ... } })?`);return await this.request({method:"tools/call",params:t},Le,o)}async readServerResource(t,o){return await this.request({method:"resources/read",params:t},Do,o)}async listServerResources(t,o){return await this.request({method:"resources/list",params:t},Ao,o)}sendMessage(t,o){return this.request({method:"ui/message",params:t},Kc,o)}sendLog(t){return this.notification({method:"notifications/message",params:t})}updateModelContext(t,o){return this.request({method:"ui/update-model-context",params:t},ut,o)}openLink(t,o){return this.request({method:"ui/open-link",params:t},Wc,o)}sendOpenLink=this.openLink;downloadFile(t,o){return this.request({method:"ui/download-file",params:t},Jc,o)}requestTeardown(t={}){return this.notification({method:"ui/notifications/request-teardown",params:t})}requestDisplayMode(t,o){return this.request({method:"ui/request-display-mode",params:t},ru,o)}sendSizeChanged(t){return this.notification({method:"ui/notifications/size-changed",params:t})}setupSizeChangedNotifications(){let t=!1,o=0,n=0,r=()=>{t||(t=!0,requestAnimationFrame(()=>{t=!1;let i=document.documentElement,u=i.style.width,p=i.style.height;i.style.width="fit-content",i.style.height="max-content";let f=i.getBoundingClientRect();i.style.width=u,i.style.height=p;let g=window.innerWidth-i.clientWidth,m=Math.ceil(f.width+g),_=Math.ceil(f.height);(m!==o||_!==n)&&(o=m,n=_,this.sendSizeChanged({width:m,height:_}))}))};r();let s=new ResizeObserver(r);return s.observe(document.documentElement),s.observe(document.body),()=>s.disconnect()}async connect(t=new Bo(window.parent,window.parent),o){if(this.transport)throw Error("App is already connected. Call close() before connecting again.");await super.connect(t);try{let n=await this.request({method:"ui/initialize",params:{appCapabilities:this._capabilities,appInfo:this._appInfo,protocolVersion:jc}},cu,o);if(n===void 0)throw Error(`Server sent invalid initialize result: ${n}`);this._hostCapabilities=n.hostCapabilities,this._hostInfo=n.hostInfo,this._hostContext=n.hostContext,await this.notification({method:"ui/notifications/initialized"}),this.options?.autoResize&&this.setupSizeChangedNotifications()}catch(n){throw this.close(),n}}}async function pu(e){const t=new du({name:e.name,version:e.version});return t.ontoolresult=o=>{try{const n=o.structuredContent;if(n&&typeof n=="object"&&n.status==="success")e.onData(n.data);else if(n&&typeof n=="object"&&n.status==="error"){const r=n.message;Ve(r||"Unknown error"),e.onError?.(r||"Unknown error")}else{const r=o.content?.find(s=>s.type==="text");if(r&&"text"in r){const s=JSON.parse(r.text);s.status==="success"?e.onData(s.data):Ve(s.message||"Unknown error")}}}catch(n){const r=n instanceof Error?n.message:String(n);Ve(`Failed to parse result: ${r}`),e.onError?.(r)}},t.onhostcontextchanged=o=>{if(o.styles?.variables&&uu(o.styles.variables),o.styles?.css?.fonts&&lu(o.styles.css.fonts),o.safeAreaInsets){const{top:n,right:r,bottom:s,left:i}=o.safeAreaInsets;document.body.style.padding=`${n}px ${r}px ${s}px ${i}px`}},t.onteardown=async()=>({}),await t.connect(new Bo),t}function Ve(e){const t=document.querySelector(".atoms-error");t&&t.remove();const o=document.createElement("div");o.className="atoms-error",o.textContent=e,document.body.prepend(o)}let We=!1,Ye="";async function mu(){if(We)return;const e=document.createElement("script");e.src="https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.min.js",e.onload=()=>{We=!0,window.mermaid&&window.mermaid.initialize({startOnLoad:!1,theme:"dark",themeVariables:{primaryColor:"#a855f7",primaryTextColor:"#fafafa",primaryBorderColor:"#7c22cb",lineColor:"#606060",secondaryColor:"#181818",tertiaryColor:"#252525"}})},document.head.appendChild(e),await new Promise(t=>{e.onload=()=>{We=!0,t()}})}let G=1,Ue=0,je=0,He=!1,Wo=0,Jo=0;const W=document.getElementById("diagram-container"),de=document.getElementById("mermaid-output"),Gt=document.getElementById("loading"),hu=document.getElementById("stats");function ye(){de.style.transform=`translate(${Ue}px, ${je}px) scale(${G})`,de.style.transformOrigin="0 0"}W.addEventListener("mousedown",e=>{He=!0,Wo=e.clientX-Ue,Jo=e.clientY-je,W.style.cursor="grabbing"});W.addEventListener("mousemove",e=>{He&&(Ue=e.clientX-Wo,je=e.clientY-Jo,ye())});W.addEventListener("mouseup",()=>{He=!1,W.style.cursor="grab"});W.addEventListener("mouseleave",()=>{He=!1,W.style.cursor="grab"});W.addEventListener("wheel",e=>{e.preventDefault();const t=e.deltaY>0?.9:1.1;G=Math.max(.2,Math.min(5,G*t)),ye()},{passive:!1});document.getElementById("zoom-in-btn").addEventListener("click",()=>{G=Math.min(5,G*1.2),ye()});document.getElementById("zoom-out-btn").addEventListener("click",()=>{G=Math.max(.2,G/1.2),ye()});document.getElementById("reset-btn").addEventListener("click",()=>{G=1,Ue=0,je=0,ye()});document.getElementById("copy-svg-btn").addEventListener("click",async()=>{const e=de.querySelector("svg");e&&(await navigator.clipboard.writeText(e.outerHTML),Ko("SVG copied to clipboard"))});document.getElementById("copy-mermaid-btn").addEventListener("click",async()=>{Ye&&(await navigator.clipboard.writeText(Ye),Ko("Mermaid source copied to clipboard"))});function Ko(e){const t=document.createElement("div");t.style.cssText=`
71
+ position: fixed; bottom: 40px; left: 50%; transform: translateX(-50%);
72
+ background: var(--atoms-purple, #9333ea); color: #fff; padding: 8px 16px;
73
+ font-size: 12px; font-family: var(--font-main); z-index: 100;
74
+ `,t.textContent=e,document.body.appendChild(t),setTimeout(()=>t.remove(),2e3)}async function fu(e){Ye=e.mermaid,hu.textContent=`${e.node_count} nodes, ${e.edge_count} edges`,await mu();const t=window.mermaid;t.initialize({startOnLoad:!1,theme:"dark",themeVariables:{primaryColor:"#a855f7",primaryTextColor:"#fafafa",primaryBorderColor:"#7c22cb",lineColor:"#606060"}});try{const{svg:o}=await t.render("atoms-diagram",e.mermaid);Gt.style.display="none",de.innerHTML=o,W.style.cursor="grab"}catch(o){Gt.style.display="none",de.innerHTML=`<div class="atoms-error">Failed to render diagram: ${o instanceof Error?o.message:String(o)}</div>`}}const Go=document.createElement("style");Go.textContent=`
75
+ #diagram-container {
76
+ overflow: hidden;
77
+ position: relative;
78
+ min-height: 400px;
79
+ background: var(--bg-primary);
80
+ }
81
+ #mermaid-output {
82
+ transition: none;
83
+ padding: 20px;
84
+ }
85
+ #mermaid-output svg {
86
+ max-width: none !important;
87
+ }
88
+ `;document.head.appendChild(Go);pu({name:"ATOMS Mermaid Diagram",version:"1.0.0",onData:e=>{fu(e)}});</script>
89
+ <style rel="stylesheet" crossorigin>@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--atoms-purple: #a855f7;--atoms-purple-light: #c084fc;--atoms-purple-hover: #b975f9;--atoms-green: #22c55e;--atoms-green-light: #4ade80;--atoms-red: #ef4444;--atoms-red-light: #f87171;--atoms-amber: #f59e0b;--atoms-blue: #58a6ff;--bg-primary: var(--color-background-primary, #0c0c0c);--bg-secondary: var(--color-background-secondary, #121212);--bg-tertiary: var(--color-background-tertiary, #181818);--text-primary: var(--color-text-primary, #fafafa);--text-secondary: var(--color-text-secondary, #a0a0a0);--text-muted: var(--color-text-muted, #606060);--border-color: var(--color-border-primary, #252525);--font-main: var(--font-sans, "IBM Plex Sans", sans-serif);--font-code: var(--font-mono, "IBM Plex Mono", monospace)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.atoms-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:0;padding:16px}.atoms-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.atoms-header .logo{width:20px;height:20px;filter:invert(1)}.atoms-header .title{font-size:14px;font-weight:600;color:var(--text-primary)}.atoms-header .subtitle{font-size:12px;color:var(--text-muted);margin-left:auto}.atoms-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;font-family:var(--font-main);border:1px solid var(--border-color);border-radius:0;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:background .1s ease}.atoms-btn:hover{background:var(--bg-tertiary)}.atoms-btn-primary{background:var(--atoms-purple);color:#fff;border-color:var(--atoms-purple)}.atoms-btn-primary:hover{background:var(--atoms-purple-hover)}.atoms-watermark{position:fixed;bottom:8px;right:12px;display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-muted);opacity:.5;font-family:var(--font-main);pointer-events:none}.atoms-watermark img{width:14px;height:14px;filter:invert(1);opacity:.6}.atoms-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:13px}.atoms-loading:before{content:"";width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--atoms-purple);border-radius:50%;margin-right:10px;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.atoms-error{padding:16px;background:color-mix(in srgb,var(--atoms-red) 10%,var(--bg-primary));border:1px solid var(--atoms-red);color:var(--text-primary);font-size:13px}.atoms-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;padding:16px}.atoms-metric{background:var(--bg-secondary);border:1px solid var(--border-color);padding:12px;text-align:center}.atoms-metric .value{font-size:24px;font-weight:700;color:var(--atoms-purple);font-variant-numeric:tabular-nums}.atoms-metric .label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.atoms-toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-wrap:wrap}</style>
90
+ </head>
91
+ <body>
92
+ <div id="app">
93
+ <div class="atoms-header">
94
+ <img class="logo" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAYAAAD0eNT6AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAACAASURBVHic7d17rB7Vuef5b/bZx2cfx+1xuz320G4ft9vHbo5luaHpNB4awdC0GQSDQAiEYEBWEBxoEAwMjBkQDCAYiABBOkEhNISBQHOLcCAhNCQhMVdzx4C5GGyMMcbG+IKNr9v7Mn8sv2Gz2eupVddV9b6/j1TK5fWueuqtemutWpdngYiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiICMD3YgcgIqUbD8wHDgP+HpgI/C3QvffzPmAHsB74EPgT8P8B2yqPVERERHKZATwAbAYGM25fAncC+1Qcu4iIiKR0CrCK7IW+b1sGHFnheYiIiEiAE4ENFF/wD99WA4dXdE4iIiLiMRP4gPIL/uHbYmBSBecnIiIiw1yJG8BXdeHf2vYA55d+liIiIgK4Uf3LiFfwj9Qa0FPqGYuIiHS4g4HtpC+kdwAvAjfi+vCHjuyfBMwDbtj7b3Zk2P9G3MwDERERKdhZwADhhXI/8AJwUIZjHbL3b/tTHG8PcGymMxMREZERXUe6gv9RYFwBxx0PPEZ4RWAAOKOA44qIiHS82wkv/N8BJpcQw1Tg3RRxXFJCDCIiIh3jZ4Q3v59TQTznEj7z4KIK4hEREWk7txBW0K4DplcY14y9xwyJ7ewK4xIREWm8CwmfgtcVIb5u4NWA+AaA4yLEJyIi0jjHEzba/6FYAQ7xIGHdE/vFClBERKQJZhHWx/7zWAGO4E6S490GTIgVoIiISJ2NJmz53p/FCtBwG8lxr4wWnYiISI0tIbkQfThadMlCugPqHL+IiEjlbiK58Hw2WnThnif5PJQoSEREBJeqN2nQ30rijPZPqwtYTfKgwCmxAhQREamDHmALdoG5g2YNoBuPG/RnndPyaNGJiIjUwO+xC8p+YG606LI7mORWjR9Hi05ERCSiY0nuL78iWnT5XY99bgPA7GjRiYiIRNBDcjP5a9GiK86b2Of4abzQREREqvcYyf3+Y6JFV5zxwG7sc702WnQiIiIVmk1y//ip0aIr3rnY59oH7BMtOhERkYp8iF0gvhQvtNIkJTlqx3MWERH5i1NJniM/MVp05ZkA9GKf+5HRohMRESlRF8lz/i+JFl35kpY43hAvNBERkfLcjl0AfhgvtMosw/4Orhryb4/ApUj+LfA2sA7YCKzBZRtcCfx57785EhhVxQmIiIiksQ/2Mr/9wPRo0VUnaQBkH/ABriskKUfCSNs64JfA1KpOSERExPICdsHVSavkJWU/LGpbCZxc0TmJiIh8xwzst95e2mPOf6hxZH/Dz9oqcEwlZyYiIjLEYuwC6qZ4oUWzlOoqAK3tWVwGRhERkdLNxH77/5pmLPNblH1xo/2rLvyHft+HlX6WIiLS8ZLe/i+MF1rljiQ5F0AV2wBwXcnnKlJ734sdgEgbm4kb0e77na2jc1Lgngf8F9I9c/pwiwW9jKtIfYob2NcLTMJ9v3OBA3AtC3+TMqZb98YlIiJSqKS3/04ZmLaAdG/oG4D5GY5zOK6fvz/Fse7KeE4iIiIj2he77/+zeKFV6jSSFz5qbStwMybyGg/8OsVx1R0gIiKFeRG70Gmn1f58ZmEnP2ptW3FZ/4o2G5c1MGRMwOElHF9ERDrMeOy3z07Jef8FyYXvW5SfA+FXAXHsxC1YJCIiktkvsQubC+KFVplbSC50H6ownmsC4nmzwnhERKQN7cRfyGyLGFdVppDc9P9EhLhCBiMeGyEuERFpAxdhFzDXxgutMkuwv4M34oXGvUZcg7ipmSIiIqmtxV+47AK644VWienYBewOYGy06JyVqItGREQKdAh2wXJnvNAq8xT2d1CH3AfTsXMFfBovNBERaaJX8RcqA7T/KPPR2H3/S+OF9h33YFdUZsYLTUREmmQC9tS/V+OFVpnLsQvVg+KF9h2jsZckXhgvNBERaZKkqX/z4oVWmdfwn/+HEePyeRR/vFsjxiUiIg2yFX9h0imJf3bh/w4uiRiXzyzsStu4eKGJiEgTzMMuSK6PF1pl9sce/zA6XmimzfjjPjtiXCIi0gAv4C9E+qhv4VekS2jmqPo/4Y/78YhxiZSuK3YAIg3XDRxofP4sbu57u5ttfPZRZVGk94zx2b6VRSESgSoAIvlcBPxVwuedYLrxWZ1nQCwyPhtfVRAiItI8K/E3Ia+PGFfVPsb/PcyPGFeScfjj3hkxLpHSqQVAJLvJwL80Pq9ytbvYrGfJ9sqiSO8r4zOrZUdERDpY0tz/ifFCq9xy/N/D0RHjStKFP+7eiHGJlE4tACLZWUvHrqCzugD6jM/qnAJ5qvGZKgDS1lQBEMnmQOxV7f5rVYHUxC7js39TWRTp/SvjM1UApK2pAiCSzWXGZ/3Aj6sKpCaWGZ/968qiSO9g47NOyeAoHUoVAJFsDjM+e53Oe3t8yfhsTmVRpHeE8dnyyqIQEZFGmIM9+O+EeKFFsy92KuBR8UIzWamAr44Yl4iI1NBD+AsNqy+83fXRrLz6SRW5KfFCExGROtqEv9D4Q8S4YvsQ//dSx+b0J/HHuy1iXCIiUkMzsd8aj4kXWnTXY383+8UL7Tt6cOM0fLE+FS80ERGpIyv5T6cN/BtuDK6/3/f9vBYvtO94ALuyMjdeaCIiUkdf4i80FkeMqy5ewy5YT4wX2l9MwU3V9MWo6X8iIvItU7ELt9PjhVYbc7G/o23EnxFgpS0eBC6MF5qIiNTRbfgLjT6gO15otfI+dgG7JF5oiU3/W+KFJiIidfUJ/oLjnXhh1c4c7LEAg8DCCHEtSIhpkHovXSwiIhF0Y/cbL4gXWi3dQ3JhW+VyyVcHxLO0wnhERKQhzsBfcAzgRsDLt31OcqH7BuWPCUhatnkQN4NjcslxiIhIAy3CX3h8HC+sWpuJ3WrS2r4Cjirh+DOANQHHHwROLuH4IiLSBrbhLzw6beW/NE4neTxAa3sWmFbAMccDjxJW+RgEbi3gmCIi0oaSsv/tGy+0RjifsIK41Z3yNnBshuPMA35PeME/CPw64zmJiEgHuBV/AaKc8WEuJ7xQbm17cFMKfwFcAByMayGYtve/n7b3s5WEtzIM3WLMRBARkQZZgd1sLWFOx14xsMpN3TYiImJKmv5Xx2Vu62wmLtVurIJ/N/VIRywiIjV3GnZ/dU+80BprFPA42Zrt82xLgEkVnJ+IiLSBP+IvUD6LGFc7mAW8R/kF/0bgpIrOSURE2sQm/AXLLyPG1U6Oxr2dF90i0AecWeF5iIhImxiDXcAcFC+0tjQO+CmwlnRT+XxbP9BV6RmIiEhbOAd/4bIrYlyd4kjgTly64NW41pjte7eNuIpCUsvB0ZVHLSIijfcH/AXLmxHjkm9bjv86VbngkEijqHlMxG9/47OnKotCkiwyPvsPVQUhIiLtoQe7aXlWvNBkmAPxX6cBXC4HERGRINbyv+r/r59e/NdLK/2JjEBdACIjO9747KPKopBQy43PTqgsCpEGUQVAZGT/zvjsz5VFIaH+aHz2g8qiEBGRRhuF3f9vDQ6UOA7ATggkIiKS6FT8hUlvxLjEZq00eHDEuERqSV0AIt9lrRa3srIoJC1rbYZTKotCpCFUARD5rgOMz56tLApJ6xXjs0Mqi0KkITQ/VuS7/ifjs3sri0LS+jX+1pvpVQbSIaYAk4F/DoxO+Le7gTW4lM6rS45LAn0vdgAiNbMf/jS//ajSXGejcDkafM+1v0OFj6UH+De4FrBZwN/jCvj/ce9no4C/Bv6K/GXHAG48zdfAZtx1eQd4CXga2JBz/xJAD7N6mQJM49s/rn/Gd2vX23ALo6wGvgB2VBJdZ7DWjf+8sigki17c7+KfeT6fD1xbXTi1NAY4AtclcgDwL4DxuGdMleVBF65S0YOrYMwEDh/yeavFYAnwCPAwms1ROLUAVGc68L8C/x5XyE/G/fC+j/vh5R2P0Vr+tA/3INyCq0V/unf7AFiK+0FtzXmsdvYC/mV+HweOqTAWSe/PwP/i+ew5OmcswBjgPwGHAv8W+FfARNxbfBMN4irgvweuR8m4pMb2Ba7BPXA2UMza5kVu/bhWg9XA88BtwGnAPmV8GQ2zEf/3dm7EuCTMAvzX78uIcZWpBzf24V5gGbCT+M+YsrcNwO24lyiRqHqAi3H9VzuI/+PIs/XhCsF3cEupLsD1i3eCLuwEQBPjhSaBpuC/fgO0x8ynucDNwKvAV8R/ZsTcBnCtmp3SsiM10QWcD7xL/d7wy9j6gLW4ATpXArPzf4W1cwz+89c4i+bYjf86Nq2gGIVrnfst7vfXCc+arNtyYF62r1kkzFTcdCPrIdMpWx+uX+4PwOW4ro8muxP/ub4fMS5J52P81/GWiHGF6MatXvgosA67RSrm1o+bcbF97/YVruVwI9+e7vfl3s+248Ym9VVwTq/gxliJFGYf4Anq+4Osy9aP++HfCxyb6ZuOZyn+87onYlySziP4r+PLEeMaSRdutcJHcJXp2M+XXlyh/Q5ugaV7cYPuzgGOAmYUdN6jcLMQzgBuxD1bP8RNCyzqOXRlQbFKBxuNG/1dxQ+zNTd2O25u7Bd8U6tuba3a9HZcs7SV/7wOWx8ufe4DuApBnftgt+M/Dy0p2xxn4r+OmyLG1TILuAM3OydGk/6Ovcd+EVexvQg386UuMwRGAccBv8A16+f5jt4BxlUbfnNoGqDtPFzt9G8K2NcArvBeDazAjdZdCryNq/nnfTCNxU31mYqb2/svgEm45CdTgAnAP8El8ohpAFexeRn4FfDg3v8vtnG4SpfP3+KaPKX+rGs5iCtgqpxT3mrWPx23NPH3KzpuP+65sgJ4DTd+5/c0czzL8bjn8f9M+ufx17iBk+8VHZS0px7cFL48tezNe/dxNS7JRV104ZazPQv4KfAUrjKyjTjNj/24PtvbcG9GsZyBP8avIsYl2VizcY6q4PhTcCP1P6Kat/xe3O/oEeAC2jv18Sm4Z1aa72cP3040JDKimWSbWjOA68O6Dvfm3URduGVTrwR+h2t+20a1FYLtuGQ855GcX7xIDxgxWYvMSD19gP96/rykYx6B6y7cbBy7qG0zsBiX2TBmxTmmGbjvIPQ768MlRhIZ0TxcTTrND3ED8CNcE3y76sb9cG7GFYabqW5MxOfAfZQ/fetdI466jxyX77oX//VcUuBxjsNlHywz+U4frhn/QVxXQk+B8beDWbiXlZDvcg+dW2ESwzzSNdUtp7PTwg4dqLMUewBdUdsuXI3/dIofTLjVOO4RBR9LyncK/utpjfUI3feLlDcVuB9YhavEqNk63EWEDYreTLWti1Jzc3E1w5Af5zo6u+C3jMP1pT9G+XOY+3Bv7Zfi8p7n0Z0QqxbNap4x+K9n2oyAXbj7+hXCnxNptgFckp+FuMFudZ4pU3f74lplk77zl2IFKPUynrD0vf3ATyLF2FTduNX1FuKSg5Q1GGoA+ATXVJ9lPYPDjX1/nWF/Ug9Ws/zchL/tws19X0I5U2234Abg/pD6TL9rFz24qcdJ12B+rAClPj4i+UbZihs5L/l04boNHsZNhyyrQrAe13w6JzCuG419aepQc63Af12v8fzN0bgFsop+029VUm+luGQ64tdN8riAHah1r6NdR/IP92PyNzHLyLpwg5qepLyR05txgwitqZjPGH//UEHnKtX7Df7r+sch/24GrsK4xfj3WbZeXAvCAtTnHMNoXB4E6xr9NFp0EtU+JDftLUM1xCpNxs2oeI9y+lrX45YQHZ4nfK3xN1oCuLmspYE/x90LIf3Fae+xB3CZ9SS+WdgtjbvRM74jPUvyD1l9c3EdjRtQWPRDehA3JuEm3BgQq7IxtfSzlLLsS/H3zUjbWlxuAd0r9fRj7Ot3ebzQJIbp2KO+e3GZvKQ+JuC6bD6i2NkF1r72VHJmUqayxpmsxg0KzjLoVKpnTfNdEzEuieBp7B/3+fFCkwCjgAtx/atldBUMfbOTZpqIy1FRVGWxNYjvRlxlVJrlMuzrq4pch+jGLjSWxwtNMjoFt+5C0dnYNuOWLJXmOA2XH6Kogv8TXLpdrSjXbF3YWV6vixeaVOlC7B+8Mm8122HAb7Gb/NJu63E5Bto53XOTTcWlyQ3J5xGybcANENRbYXuxZvssjRiXVOh1/DfBpxHjkuLNxS3OUlTBMAC8hWtxkPhOxc0YKeLa7gIW4RbDkvZ0Jv7rvy1iXFKhXfhvAl9yEGm+g4EnsK9/2gLjCbSwSNWm4ebsF9XdswSXi0La32jse0GLLLW5Gdhvd0r40xlOwi0qVNQAwjW4yqMeIOU5D9dCV8T1GrppQF9nsZY3L3vFUYnsfPwXf0PEuCSO/0yxhUk/rmKhZuRijMX1xRfVhTPSdkJlZyN1sBL/vXBmxLii6LRVp6zsXBoE0nn+XcH768KNO3gO+AK4CmUZy+IgXEXqK+Afgb/NuJ9B4A3cQ986lnSOL4zPplcWRU10WgVgqvHZ+5VFIXVh9d9/hHvzzGoicCXfDC7TWIFk5+AS7LyAq0h9L+N+tuLWf5iAm8b5ivFvQxeMkvaw0/hMs3za3DL8zT/K+d55Psd/P/xw7785GTdQrIh55StxhZx8YyKusM47qK8PV3E4dIRjXGz83cflnJbU1OP474U7IsYlFbAWfVFfYOexZgQMby0ai1s7YL3xN6HbTtyCMZ08z/xQ4FXyV6zW4RL1WAMwf2D8vaZ/dZY/4r8X7owYl1RgHf6Lf0TEuKR6o/DfC/0Jf7sfsJD8b60DuHnsJxV3WrXWBVyC/TsM2fbgHuShWRq78Fc0Bui8rtBOthj/fXVjxLikAlYLwLyIcUn1Dsd/L3yVYj9nY3cthW5bcIvLtONUwtG41fLyVpg2AzeQbZVOaybBftlOSxroffz3wUUR45IKfIb/4p8aMS6p3lX474UsA0KnAL8if6KhPlw/5dRMZ1Uv+wCP4s4pz3fyHnB8zlhWGfu/IOe+pTmspcVPjBiXVOBd/Bf/4ohxSfUew38v/CbHfrtw602sNvYfsg3gBh8emiOWWOYAL5Kvf38Pbk2HaQXFtMg41v0FHUPqbzf++2ByxLikAs/jv/gaANJZrBzyVxd0jNm4dMF5Mw6uAxYUFFOZDsNVWvKc6xbgZorvCvmpccw3Cj6W1NME/PdA0rgfaQMP4L8BnosYl1RvM/57oejxIKOA67GbH0O2bdRznMCZ2FMqQ1o7lgLHlBjjKcbx15d4XKmPM7ArntLmrPnAqyPGJdXrx38vjC7xuIeTf/rbHtw4gSklxpmkGzf9bgvZz6MXN0agivOYmBCHtL9f4b8HlkSMSypizQfeEzEuqdYU/PfB7opiGIdLPGItThLy5lz1OIExwF3kG+y4BVd5qDpNsjUYUQuBtb81+K//zyPGJRWx5gMPonStneI0/PfA2gjxnEX+QYOrKXdZ27HAg+Qb0b+GuAuubPLENYgbvyDtaxT2s195YDqElcntpohxSXVuxH8PvBoxrkNwiUrydA9sodgZLeOAh8lX8L8PHFlgTFl9iD9GzQJqb2fhv/Z9EeOSiv0J/43wXsS4pDq/xX8PPBwxrpZ9cJkG88we2AJcQ/Ysd2OAe8le8Le6J0Kz9VXhz/jjvTteWFKB1/Bf+2UR45KKXYD/RtA4gM7wFv57oKgpgEXoAX5MvnEC24AfEd7fPgE3MM8aJGltfXv/vo7rHNyBP+5nI8Yl5bMq0z+JGJdUbDR2E6syArY/Kxf9cRHjspwKrCB7RWAXcDv+KYQTcQmQshb8O3EDqcqcQZHX+fjjXxExLinXmdj3rhIAdRhrTYCXIsYl1bBy0tfxzXWovOME9uC6F8bv3d/Evf87a8Gft6uhSgfhP4806z9Is1j5/2MM+pXI7sZ+QDbhYSbZWSvDNcUU4Hfka6r/guwVifXA6aWfZbGsFSA1EKw9TcC+x2+PF5rEMh374aYRwe3LuvbbI8aV1Tjc9Ly86YZDt3XA/ErOrBzW96RcAO3nLuz7ue4tflKSL/DfFKsixiXlslLCrokYV16jcW8zeVcj9G0baXbB36JcAJ3FWgb6w4hxSWS3Yj/wlBSoPd2A/5q/HjGuonTjFtOxHnxp3/hPq/QMyqVcAJ3jQux7+9x4oUlsY7H7TxdFi0zK9Cj+a74wYlxleITsffwDuPUG2s2f8Z/z3fHCkhJYSd92obFeHe8N/DdIP9+MlJb28Sb+a35dxLiKdCT5Uwu3tq246XPtQrkAOsN87Pv6nnihSV0cjX2T3B8vNCmJNQX0xIhxFWEGbopgEQX/SF0Bdc2RkIZyAXQGa+ltvdzJX3yJ/0bpw42ylvZh9Y1PjRhXHuOBJ8m3hkDotgKXi6CplAug/Z2DfQ+rpUf+YgH2zfJovNCkBO2QA6ClC/gZ2aYAbgX+K3aLiLW9RTMHyioXQPuzZnoMADPjhSZ1ZL0V9qO5ou1iKv7rvCNiXFmchsvCl7bg3o2bJTB0ANQJZB8zsIjmNaf24j+fOqcylmQXYd+vL8cLTerqx9g3zZ/ihSYFOgH/NW5KStADgI9JX1D3Aw9gF3Dn4loG0u67D7cOQOiCQ7Ftxn8uB0aMS/LpIvn+nR0tOqmtbuz88AO4AVbSbJdhN2nX2XjgCbL18y8m3YInC7B/D75tO27udd19gv8c5scLS3K6Dfv+fDFeaFJ3N6Gmo3b3C/zX9/cR40pyDdn6+VcA+2U8ZiuhUJbjbqTeMwasteGvjRiXZLcPriXKagGbEi06qb0ukrOnzYsWnRThKfzX9q6IcfmcghuZnqUAPqGgGCaQfYbBO8C+BcVRpMfxx3xfxLgku9ex70VdV0lkzRFuPViluZbgv7ZXRoxruP2Aj0hf4G4DzispphnAqxliGsBVIOo0ndZqKl4ULyzJ6Djse3AX0BMtOmmUpNHQt8YLTXKyru3JEeNqGYNLR5z2bbsPuJdqBuEdiOtaSFsRqDLGJBfjj/O9iHFJNta0v0HginihSdMciH0z9QPTokUneVjN6Vn7yotyDfb0NN+2mDjTVOeTrXtiO3BBhHiHOgZ/fE2ZDSJO0qJum+KFJk31DPZNtTReaJKDVcDGaiI8GXtamm9bhctqF1vWikvMgYLTjbi2RYpJ0puBvaDbIMWNhZEOMp7k0c9nRotOsvI1rfdHiGU28IEnnqQ36HMixGsZjWveT3oYj7S9R/Vzs7uMeJQNsDlWYd9bdZ/aKzX2U+ybawfKGtYkE7GvZVVGk62fvx9XyI6qMNa0pmFPsfNtA8DvqHagoFXBr8M4BbH9BPue2oMyuEoOXST3cT4fLTpJ63D81/HLimJoWj9/VoeRLbXwHlw+jip8bcRRx6mL8o39SK5AXxYtOmkbh5L80GqntdLb2bn4r+FHJR/7cNxyumkLxHW4e7Cpfki2gYJfA2eUHNsa4/jqN663L7Dvnw/jhSbt5lGS31rSpFmVOG7Gfw3LShE6ATevPG0BuIv2eoPJ2vKRJ5NhkqXGcdvpu283v8S+ZzRLSwrVTfJbzPJo0UmoR/Bfv4UlHC9L+t6BvbHUuZ8/qzwDBRdR/PiAp43j3VnwsaQYB5Pc9H9DtOikbR1C8o3342jRSYgX8F+7Wwo8zklkW6b3FTojV/k03JiGtN9PH3A7317GOI97jGM9VdAxpDijSf5drY4WnbQ96w2y9fZ2QLToJMky/NeuiHEcM7CblX3bWtwYgU5zOPAZ6b+vrygma+NVxjGWFLB/KdYr2PdFP1rqV0oU0hWwkfZsvm0H6/FftyNz7HcU8ADpp/Xtwi272+nOw+U2SFsRWAbMyXHc04x9f5Jjv1K860i+H66KFZx0jpCuAE0NrCdr2tfUjPucj8scl7bwWgSMzXjMdtSFa96vcnzAIcY+q5oWKsnmkvzMfTVadNJx7iL5oaSBKPVjjUJP26+8H9kWxFlBvrfWdjeRbLMmsowPmGLsT+mA62E0sBX72m/HLaIlUpmkpVoHgKOiRScj8b1dDqTYR9YsftuBs4s4iQ6RdcXBNPkDrHTAvQWdh+TzDsnP2TzddyKZjMelj7Vuzp24NxqJr4iH/cW4fvs0BVI7T+urwunYXTd5W1qKqBRKOW4h+TrfFi066XhHk/wmuDJadDLUZLI392bN4rcEJSQpQjeu2y3t+IDW+gJW8/Bu4++1HkA8x5D8bFW2P4kuaUGKQdz0QYnrIPzXZ4Pnb8aRrT96M3B8OafR0bKOD+gFrvDs02pdmF7OaUiCGSRnjdyFWlelJt4n+SFUt+VbO81J+K/NqhH+/SWkT13bh5JBVeEQsi00tBo3tmAoa2roYSWfh3zXGFwFOqllRxVsqY1xJI8HGADmxQpQuBD/tXl3yL+bQ7bBZ0to1mp97SDr+IBFfDMF82Pj382v5jRkiHdJvn5FZu0UKcQ8kvusdqM+4VhuwH9dXsT1995O+tH9G9Fsj5i6gbtJPz5gN3ApruLm+zdaEKhaSYuutSpvIrV0Kck38FcoAUwMd+O/Jq+T/k2yF2Ueq5Os4wOsQYA/rfIEOtxlJF+rtWhgptRc0noBg2j0agy/JX3hMNI2ADyBEo/U1aHAGoq51g9VHHunChnxvwt1sUlDhCwIo9XGqmWtBBi6reG7g8ikni7E5eHIc73/WHnUnWcmyYNtB9CATGmQ0cAmkh8wGsxSnSyr9LW2PuDG6kOWnEYDj5F+XEdre636kDvKeMKWzfZN4RSprenY/Yut7axYAXaYVWQrBBYDEyLEK8WZgT3Yz7dtR33OZekhLLnWr2MFKJLXkSS/ffTj+sCkPCEZG4dvXwHHxghWSnMqyQvLDN+2AEfECLaNdeGWck767t+PFaBIUS4hrIl5bqwA21gXcC/pVWsjGQAAIABJREFUHvit3P1682tP3cB9pK8QPoLuiaKEjMdZj2slEGm8+0m+4XcDs2IF2IYOITmj2PBtBbBvjGClcrOA5ag1oGohz8JtwKRYAYqUYRHJN/5OlCgor9Zbf5o3vJ1oqd5OZWWI9G1PoNUds7iO5O+2F5gdK0CRMoWkudyMGx0r6R1E2OyL4Zvm9He2tPfLIC5xlMaIhDuf5O+0H7WwSBvrBj4l+YewDjeFScJkeesf+tCRzpalAtDaFqMKZJKTCPttnh4rQJGqjMEtP5v0Y1iJBh2FmEPYdCLf1ld9yFIzWfMEtLaduBkG8l1HErZOw/WxAhSp2mTcHOOkH8WSWAE2xM3kf3jvqTxqqZu0Cwn5tmdQa8BQ8wj7bh+OFaBILDMJSxT0RqwAayzvW//QbXfFsUv99DHyvTFAtgGlJ1Qbfi0dhv97HbotihSfSHQHEvYjUSXgG5eQ7o1tGy7RkvXAls5m5aIHN7g0pNtu6PYEnduFdyCuZU3PNZEEJxD2hvFqrABrYixuwFWah/Bi3GDK8ca/2VblSUgtWS1xLV3APaRrDdgAHFDJGdTHbMJaNpfhvlORjhc6Svb1WAFGdjSwg3TNsCcP+fspxr/dWskZSJ1Z99bwbHRzgM+Nfz98GwB+VvoZ1MMs3LK9Sd/Jcjq3dURkRCcTVgnotBXKbif9W//wgVizjH+/qfQzkLrbhv/+8C0EdTPpuqJW095JvmYStvzyZyjFr8iIziCsEvBSrAArNBNYS/a3/qF+YPzdl6WdgTSFtSStVWjPId09ugeXEKfdzCSshW4tym8iYjoTjQm4mLDBkUMrRGON/R1m/O3aUs5AmmQj/vsjJC3t7aQbG7AE+35tktmEvfl/Sfucs0ipziXsQfIK7TWQpoewNRNaWz9wecB+jzb2sbrIE5BGWo///ghdpfMw0i01vAM4rrAziGMOYX3+W4CJkWIUaaRzCHureI/2GFAzD7svdvj2OTAjcN8nGftZWdgZSFNZg/oOT7GfUbjpf6H38CDNnS54EPb0yda2FdgnUowijXYxYQ+RT2h231raJtSFpGv5+KGxr48KOQNpMmt9jmMy7G8+YVPhWttGYL9cZ1Ctgwkr/Lfgsp6KSEaXEvYQWQeMixRjVpOBVaRrNs3yQD7T2Of7uc5A2oF1D2Ztpp8ALDX2O3zrxyW5qrujCBufswk1+4sU4jzC3pA305wa99GE9R+2tjwDp8429vtu5jOQdrES//1xfM59X0q6Aa1LqG9r3tGETX38Ei1pLlKo0wirBGzDTcupszRz+/uBq3Ie7xxj/6oAiFUBOLGA/c8E1hjHGOk3fEgBxy3SyYQV/utpXkukSCMcQ9jbxC7qmYJ0PPAh4Q/C9bgkPnmdZxzjnQL2L822Av/9cVKBx0mzeuXA3n9fB2cTFvcatBqiSKmOIGyhjV7cYJ26mEe6dL5Fjo4+3zjO2wUdQ5prOf7745SCj3UoduKh4dsbxC1Ur/bENXz7lPp2XYi0ldApOH3k78MswnWEv/nsoti3LoALjOO9VfCxpHk+wn9/nFbC8XqA54xjDt+24SoOVft5YHyrUHpfkUqFZuAaAC6LFGMP6VbwW0E5I4cvMo65pITjSbMsw39/zC/xuBcSPkBwAPhpibEMtzAwrmU0M4+BSONNA74m7Ida9Ypkc1PENgjcVWIsVj6FN0s8rjSDVQE4veRj74sbNZ+mkuxboKgIXbgFx0JiWUJ7ZSIVaZyJ2LnMh26LKorpIsJXSuulmJHWlgXG8Tt1iWX5xvv4748zKjh+F+Fv3IO4brIy0gj3YFeGhm6LSzi+iGQwnvBVyd7CpSwtQxfpUqF+DkwtKZahrGRKnba8snzXe/jvj7MqjOMc0uUMKLJLYAL2mghDt/sKPK6IFGAUbkR7aMFbdKKOWbjsX6EPr0cKPr7lMiOOdl5VUcK8i//+OKfiWKbgFqgK/R29R/7R9zMI7677Uc5jiUiJQpsSv8b1PxbhFMKmJg7u/Xdl96sOd7kRz8sVxyL18w7+++PcCPGk7RLYQva1BA4mLCPnAG42jYjUXOj0nV7SrXY2kh8HHmsQN1ahiMQ+aV1pxPRShHikXqyWs/MjxnUqYdN9B3FdB2m7K35I2FidflwmQBFpiEsIm3vfT7aBTqNIN8VvEfGmC11lxKXBTLIE//1xYcS4IH2XwEOB+/1R4P724JJ4iUjDhObvHgRuTbHfyYQPOqzDKmdWNrMXI8Yl9WBVAC6KGNdQDxBeCViOPcYntHthJ/VMKS4igQ4ifNW9xSS/pR9NeLPkZmBOoWeTzbX4Y3whYlxSD2/gvz8WRIxruDRjbXbw3eyBPdgDHof/dqeUejYiUolpwFeE/fA/w59o5ErCU/oWMTq5KNfhj/O5iHFJPViJb2K3Xg03A9hA2G9wAHfvA0wC1gX+3Wq0nK9IWxlP+JKk2/l201/a+f2/KP1s0rkef6zPRoxL6uFV/PdHrDTallG4wauhv8eXcb/pkH+7BKX2FWlLXbjBeCEPgn5cHvRJhA9C6qP6KX4hbsAf8zMR45J6eBn//XFFxLiSXEN4i1zIpgQ/Ih3gdsIfCqGZybZQj/7+kdyIP+5F8cKSmrDepq+MGFeIo4Hd5Cv4B3DrZUgH0mIOnecs4B9xP/wkfxXwbz7AzQx4O09QJfqe8VnIdyDtbdD4rO7Px98Bf4cbu5NFH3AscFNhEUmj1P0Gl3LcgRslvCvnfh4E/gG3ZnldWZUY6+EvncGqBIZUgGP7Aremxn9P+Xfbgf2B3xYekTSGKgCd63ngX+JGB6c1APyfND9DmCoA0uQWgJYBXFfXnhR/8znwcTnhSFM05QaXcrTeHt5I8Td9uNaDW0qJqHhWF4AqANIOXUSXAk8Df53ib2bgKgEzS4lIGkEVANkf14wfqhuXSrSsZYWrZD38pTM0vYL4W9x8/yz38v+AWwzpiEIjksZQBaCznYjLhve3Kf/uP+BaD2Is7pOW9Ran+1+sgrO/sijSG4dL+/u/5dzPKOBJNBOgI+kB2LluAB4m+0CnccBb1H8cgPUQVwuANLEFYC4usdf0gH/bmspr+R5uDIFyAXQYVQA600Lg/ypgP93A/cDdBeyrLNbDTxUAsZ6BdWwBOAfXaheSans1borukbg1PJL877g03j2ZoxOR2hpF+IIgXwN/Dvy3g7i+xDHVnUowpQIWS5NSAT9M+O/xSb5duZlJ+JogXwATSz8bEanMOMLXA1jFNwuCnEv4ssLbcM2TdaLFgMRiLQZ0acS4hhoLLCM8s58vhfEY4MPA/WwDZpdyNiJSqamE1/5HWhDkAGBr4N/3U5911MHlTPfFquWApe7LAc/FtcaF/PZ249IDJ1kYuL89uO4DEWmo/XHrg4f84O8w9jOW8O6DQeA31GOMyVX4Y1wcLyypiTfx3x+xR8ZfTfiCP18AU1LsO3QxoX7gh/lPRUSqdjSuFh/SbHhB4D5/EbC/oQ+l2IlGrkQVAPFbgv/+iNWSNYrwlTtb93GWZXxPIOz5MIirSItIQ5xNWA1/D+kTgZxM+IOjDzeOIJbLPXEN4paClc72Fv77I7RSXKT9Ce+uG8Al5cpjDm5dgJDj3Z/zWCJSgWsJ+0HvxPXvZzED2BB4nEHcG02M7IGXGTG9EiEeqZe38d8f51ccy/mED7jtBY4r6LiTgPWBx11MPbr2RGQEoU30m3BzhPPoAp4IPF7rmPvlPGZalxjxvFZxLFI/S/HfH+dVFEM38EcjjuHbOmBawTH04Jb2Djn+R4TlIRCRCj1A2A94DW5aYFF+RPhgpX6qHV29wIglzSJI0p6sga3nVHD8GYS/fbda0rL094foAl4MjEO5AkRqJPRNfKRpfkU4iPDpSq04qniLuMiI4c0Kji/1ZlUAzi752KcRPpamyorz3YExbSMsHbGIlGgR4W8PZerB9RGGVgK+IvsYhFAXGMdfUvKxpf7ex39/nFnice81jjt820z1XWdWAq2h23Zg34pjExHcm/w7hP1QrTn+RbuWdF0CV5UYy/nGsd8q8bjSDFa/9xklHG8y8JlxzOHb88Rbevt0wgYl7gZ+EClGkY7Ug1sONOQhcnWE+OYSnj1wEDciv4wugXONY75TwvGkWawUu6cXfKwzcKP3Q34PVkrfKh1JWDdFL3BIpBhFotsXlzHrFuBxXFP4H3B9808AP8ZN2ymikBuDW+kr5EFySQHHyyptl8A2ik89eo5xvHcLPpY0j5Ubf35Bx+gmPP1u63dQp8L0AGAXyXH3AUdFilGkUpNxK80tJbxW39p24uYfX0H6CsE4wkYND1BOE2YWFxM+v3kQ97Asaq7xWcZxVAGQj/DfH6cVsP8DCU/sM4gbl1LHVTWnEzbIdwClDpY2dhzhK3OFbP240eiHBRx7DG4OcMg+T8p7ogWbRbrEQRtwWdHyOsM4xvsF7F+azepGOzXnvm8gfCzMAK6VsM4m4XJ5hJzLWZFiFCnFWaQrwLJsq/BXBNIU/kVlCCtaN+kSB/XjWlnyON3Y/wc59y3NtwL//XFyxn2Ox15jYPi2Czgm8xlUawLwJWHnVZfllEUym0q6VfCK2J7j210D4wj70TVlIM6FpOsSWAbsk/FY8439fpj5DKRdfIz//sjSinYqblR86L39Pq7C0CRjCJ/JcHmkGEVyu550BVWR2zZgHuFv/k2bijOL8DeJVuUmS7PiqcY+l+c6A2kHq/DfH8en2E8X6Qb6DQA/KeQM4hiFPX5i6BZzILJIJk8Rp+Af/pDYGfDvdtLMZBxdpEuIMoibVZBmkNRJxr5WFnES0mif478/QlfJ3B/YaOxn+LaZZlXWfbqA1wk751hLK4ukMppsg/z6cQ+Tp4Ff4gYALcC1ItwBvACsJXxQUOi2E5hZyjdRnaMIX5J0ENc6Ejrd6FhjP58VdgbSVNaMmoMC/v4y0rUSLiJeYp+yPE/YuVe9uqJIKmNwi1ykKfQXk24AzyhcU/ZS8lcG2qHwb+khPKVxa3uC5HUNjjD+fl3B5yDNY725W+l3JxCehXMQ14VVdGKhOnmGsO/hglgBili6gU8Ju4n7gNtxhVYek4Hfk60i0NRm/yRnkS6vwpfYzamHGn+7oZQzkCax5ujP8PzN2aS7R5eTfRBrkzxL8nehKYJSS6E12OcpfhnMOdiDkTql8G+ZQLppVAO4sQQjJQ860Pi7zWWehDSCldxm0rB/Ow6XsjrNffnT0s+gXkIrAe3cGiINcwnJN20/bvpame4KiGOQ+s7zL9oVpOtf/Qo4fNg+9jP+/deln4HU3Q7898fQwabzCUuH29q2AgdXcgb18xxhlQBlDJToJpDcnLeL8petbbFy17e2jRXFUgdzCEt9PPTB8iDftAbMNP7tjqpOQmrLKtS7cJWAkAJt6LaI/N2DTfciYb/VE2MFKALJi9X0Uv1a3NcmxDSIm2XQSW4n3ViJLbiFhaYY/2ZXpWcgdWRV/k/EbiEYvu3BVeDFCZkd0E/4dEuRQh1H8s05N1Js1yfE1guMjRRbLIfgCvY0b2NPG5/1Vhu+1FDIUrch23Jc1lD5tpBKQC+upU+kUlYe8EHgynihAW45YSu+38QLLZoekr+X0K2v4tilfvJm+uwHflR51M3yGsnf43bcrCiRSuyPfUO+HS+0v+jGJb3xxbiH5Hnw7epYwpYnTXp4S2fLk4tjNe2Th6NMXbiFt5K+z824mRYipXsB/404gOs7rgMrl/0gnb3iVjfpUwkPv87S2bJWHG+JEWyDjcJVmJK+27W0X6ZEqZlu7Ka/P8ULbURr8Mf6acS46uJI0o8NaG3SuUaT/n5Zj2s9lPTGAptI/o6XxgpQOsMpNOPtv8Va036Q7yYs6USthYXSNuneHCNYie480s3rbyWbknwm4HIkJH3fiyLFJx3AWulvZcS4LNbDSittfeNQwt4yhm7rgMNiBCuVmw68R7r7YwMuo6QUYyZhla/7YgUo7c0qIOo6oncR/pj/GC+sWsraGrAEtaa0qy5cLom0o/4XMnKKacnnAMKmYC6IFaC0L6tgGB8xLsu5+GNeHzGuOpuLWywozQN/D/WtBEo2JxDW7Dy8yX94Wmkp1hEkV8gGUKIgKdB0/DfbzohxJRmLP25NZ7NlGSC4iXTLPEv9TCJsDvpI27II8XaipFlOg7hEQZpuKYWwBgCuihhXCCttqebP+qVZt3349iLFr/4o5buGfFn+Xq4+5I51E8nXYyNaX0EK8CP8N9kLEeMKYY1d0CAlv7SLuQzf+nD9x1J/BwCfke96D+IGCkt1nkCtMpXrxMEtY4zPdlcWRTbW4jX/tLIommdTzr//K+AfcW8h6haop3G4dR9eo5iUsp204mYdHEVyAT8TeLiCWDpGJ1YArH7+ui8OY/X1/01lUTTPBuOzNEsCj8etv/AeMCtXRFKka3ADYf9jir/ZArxrfP5Frogki39LcsXrROCq8kPpDJ1YAbDe8v+6siiy+b7x2brKomge62H+NvB/kG5p4H/AZStbiMsmJ3HMwxX8lxP+2x0Efo1LSGNVqPV7qt4OXBdOUkvs/4NmaEhGl9HcPqad+GOfGjGuujsP//f2/t5/04Mr0NPmDuhF2QSrNhE7L4ZvWwHsO2Q/K41/e2r5pyEeB5M8PXAn9Z2yLTV2JP6bKm9fcZm68RdOA3Rma06o4/Bf89XD/u0ckpeJHmn7Eo0PqEKW0f27GTlb5nrjbw4t8yQk0VkkX1erC0dkRKPw31D91Hd53WPwx709YlxNcADpK33zsZditt4yNT6geCeTLZ/D7/B301jLSU8t6Twk3MMkX9/bokUnjbWD5jX93YM/5pUR42qC8fi/O2sQ4CjgIdJ3Cwzg+pk1PiC/abgUzWkL/nXAQQn73m38fV1fBDrNxyT/1o6MFp00ktXEW9f5v2vxx3x/xLiawvfd7Qn422nAYmMfvk3jA7LrJlvu/t3ApYHH8O17oKiTkNzG41o4rWu+EzeoUyTIndgPkLrV/udg/wDmxQutMYp42B+BGzOQtiKwEZePXsLMJ333ywBuEGdotrguY191nw7caQ4muRXug2jRSePMxr6ZrogX2oh+jx5WeVnLj6ZNMXpZwv5829vAjJzn0c72I9sAzCzjLiYb+9uW8zykeNeQfB/8PFp00jjWKnF1mg0wDbsZ9E/xQmsUawDZvsbf+fTglhxO20Q9gEt7Ojb7qbSd0WSbgrkNOCPjMQ8y9msljpJ4QlJ6HxYtOmmUW7BvpJ/EC+1bklYzOyReaI1ijaHIM4hoGvCmsW/fthtlNAPX2mYNxhtp68d14+WZ+vpDY/+f5NivlKcb151m3Rub0JRoCdCDPZ+4H/dwj+lk7Jv903ihNc4y/N/j+QXsfx7ZxwecVMDxm+YI3Ej9tN/XEmBKAce/zjjGqwXsX8qxP8ktRQ9Fi04a5QHsG2ktbipYDNNJTniigWXhrObDIlt7LsbO2OjbVpM8ba0dZJ1RsQmX0Kko9xvH+m2Bx5HiWSu6tjalCpZEPSQ3P74RIa4x2GMUBoHlEeJqsofwf5ePFnysrFPYBnGFYxGr2dVN1u+krKWYFxnHVHKZ+luOfd9soX6zuaSGzif5IfR0hfGMx05ROohrAptdYUzt4Ab83+dLJR1zKtnedvtJN6Wt7i4iW6vIYmBSSTG9axz34pKOKcWZhJsBZd0/j0SLThol5CG9jPIzu83ANXUmxXJHyXG0ozPxf58rSj521vEBu2l2IqGs572O8ge3WoNCjy352FKMs0m+l5QjRRKNITnb1CBu2lFZC74swDV3JsWgpv9sDsb/nSatQV6US8mWP2ADzRrvMQU3kC7tee4CLqkoRivR0PSKYpD8kqYGbo4XmjTJ4YT3T34GjCvouAcC7wUedxtuKVRJbyx2wVOVHuA+so0PWIYbBV1Xo8h2bgPAr6i2y8OqbGsaWXOMxl7bZZBmt6JJhY4nPBnJAPAM2fvijwHeCjzWIK45OEvCGvmGtZxy1SbiEgKlTX4zSD0HCl5Itn7+JVT/xm2lAQ5ZG0LqZT72PdaH1gqQQKeR/qH8FS5d75n4C+mDgCuB50nfDLwbmFvoWXYm63uPlZnvAMJbgIZurYGCsaapthwGrCF9/F9SXndakhlGXF9HiknysQZ1DqKMqZLCySTPwU/aevdueffzNcofXxRrgGXsCtaxJM/+GGnbRZwmzslkm+FQhwyIx+GPb23EuCS7ySSPoeqEPBtSkP9CvoK7iG0FblqgFGMl/u/69IhxDbWAbE3pG4ETK4ivG7ibbP38j1L+TJoQC/DH+W7EuCSfn2HfgyvjhSZNMprkOaZlbv3AjaWfZed5Bf93fn3EuIbrwWWqyzJQ8EPKa824hOQBV75CdWZJMWXxc/yx/jliXJJf0loBZ8cLTZriV8Qr/N+kfgO82sVj+L/3ByLG5bMP8ALZ7qPXKa7QPYZs8/k3Uc/pi4/jj/m+iHFJfvOw78ltaJaHGCZhv3llGbUdsr2FmxIo5fkp/u//mYhxJck6UHAA10+fdfGcH2Q8bi/1nnplrbB5bcS4pBhJOSiuiRea1N0z2DfPVbhBeQvJ1hw6/A3pbopZ3UySXYj/WrwfMa5QpxCWKXKkisAThOeumEq2AX4DuLfrMbnOsnwr8Z9DXcaCSHYzsF/UdqBWABnBNOwbZ/0IfzMVt6b5s7ipTbtG2Ec/bmDXalzmqisoL8e5+B2F/9quixhXWteQvIjVSNse4E78UwfH4Cq2WVq53qc561NswX8eaoVrD3/Cvl/rNOZHaiLp7b+KUdZSnsn4r+3OiHFl0QPcS7aBgq01BlpvQV17/3eWga+bgZPKPNESWNPFYudVkGIkdeVuixea1NFU7DefT+OFJgWqUzbAIkzGJZdKW3AP4nJM/Bo7L75v68WtsNg0o7FbSKR9PIp9D58bLzSpm99j3yyxspZJsaxxG01eBGY26VJLZ90GcN0EdZjPn8Vh+M9tU8S4pHjjsBOxNanbT0o0GrtZ8ON4oUnBrLS1p0SMqyiH4u7XMgr/96jXfP4sLsJ/fh9GjEvKcT/2PX14vNCkLqzEIIPAkfFCk4K9jv86N7FJ2yfr3H3fm9Jh1YZfmrvwn+efI8Yl5RiHPRZgcbzQpC6sPlD1/beXhfiv9WMR4yrLL8g2ULC1PUO1y/SWzRroe2fEuKQ81jXvJ95CYFIDp2I/AJU6sr1ch/9aL4kYV9FOorgWgF7cm3Pd5/eHWI7/PC+IGJeUZzb2/X1TvNAktqX4b4wdEeOScpyI/3q3w0pwZ+Ka7Iso+Ed6W3qCZq+tvhn/+R0SMS4pl1UZXhMxLoloPPbUv1/EC01K0k65AIY6G9hAOQX/SBWBJ2nmmhXWqPCmzmyQZJdg39NNvJclp5uxH3KhqVOlWdopF8B5JK+AZt3jn2EXitY2gMts2ZQMgD34z0U5ANpbN/Z9/vN4oUksn+K/IV6NGJeUq+m5ALpxYxm2kq3g7sMNhhw/ZH/XANsz7m8QWAEcX9oZF+Ng/PF/FTEuqYa1HPiqiHFJBBOwH2haFKR9NTUXwBjgdtx6E1nf+J/gm4J/uC5cReDrjPsfxOXZv4Z6LrZyPnYFRtrbfOzWLKWB7iDXYr8h1fEBJsVoWi6AKbiCO+t0vj7gQdJNd7oM91actSKwC7iHenWj3YE/3mcjxiXV6MJO+HZWvNCkam/jvxHeiBiXlK8puQDmAIvItjrfIK7PcyH5CuGzyTeroB+XbOWAHDEUxVoh7u54YUmFluG/B56MGJdUzFpO9ZyIcUn5rNafOuQCmIeLI2uhW0TBP9zJ5M8rsAw4tsCY0rIe/gsixiXVsQZ+t8M0YAnwA+w3lu54oUkFTsB//WMuEHIe+d62Wwl7ypzOdhR2Mp2Q7UvgUqrvZrO6NJQTvjPMwX72Swf4Ef6b4JN4YUlFrFwAuyuOZRRu3EGegXc7gJ9Rbcre/YEXyd49MYgbJ/AwboxDFawxFO2U7lhs1jiAWRHjkoq8iP8GuD9iXFIdqzCoIiHMFFwzfdY5+IPUY8T9BOAB7C61pG0At9LgSSXGOdU4ftWVPonLmgWk7t8O8CX+G+CEiHFJdazm4CNKPO4JwAfGsUO2Vbg1LOqklUtgE/nObSsuKUvRswdON46pvt/Oshj/vXBXxLikItZbVzsseCLJ3sd/D1xT8LFahWPWjH2tbQXNWJr6RNwbfZ5zbbUKHFNQTLcbx3q5oGNIM9yD/154OmJcUoEx+C/+rohxSbV+g/8++G1Bx5hK/mb+AdyMgP0KiqlKRYwTGMS12F1HvkQtzxv7vyfHfutkLG4GyXm4FqJTcZWx/WMGVUOX4b8X6jALSEo0DzUFClyN/z74IOe+TwE+NPYfsu0BfgVMzBlLHRQxTmAQN3jrD7iR3GlZUxjPzXZaUfXgEtcswq1waA1sa1UktwDv4hY5y/Idtosz8H9PKyPGJRU4E//FXxoxLqnW4fjvgy0Z9jeKYpr5d+Caq9txVHo3ruJljcEJ3VYDVxLeKrDT2FeTRn6fBnxM/laV1n1+D+1RyUzjWOz7StrYlfgv/p8jxiXVGoX/PkgzH/gg4BmS38CStjXAhTnPqUkOww3GypreeOi1WoI9eLfb+PsmrADZhZsquoX8hb7vO3gO12XVCY5DFYCO9WP8F/93EeOS6lmL6sww/m40cCP532QHcIXgQcWeVqOMA24j+8qGI73RDl/b/SDjb7aVdmbFOJp8azKkvR8fpv0ToZ2C/zvQqoBtzqoAFDX4S5rBmg985gj/fh7FvLXuAO7F9Y3LN07E9VEX0by9Atei0gVckvDv6mgsrmWpioJ/+LYVd6+3q4vxn7u6gdvcTfgv/hMR45LqWQmhfrH334zDZdnbbPzb0G01zRxwVrV9cBWkHeT/zvuADcbnf6zonNI4ENcyEaPwb20D1HNlzCJY0wAXxQtLqnAV/ov/arywJAJredhluL7lvG/lP7ZRAAASg0lEQVSj/bgpaD+o6JzazXm49NxlFXQ3V3YmYU4mewvTDtxaEstx9+57uO/ua7Lfxw+UerZxWImA2mVKqHhY/T8fR4xLqmdNB8q7bce9xY6v7Gza2yzgKdyCR0Vep5OrPIkEZ5GuoO4HXsE1aU9K2HcXbvT7QtKvO/Gbgs6vLqwxFWdEjEsqsD/+i/91xLikelMpvuBfycjjB6QYXbhWgY8oZqxAP/AOLgd8zDUVTiT8fLbjFjTLs2bFsbjxD6Hf05M5jlUn47HPM6kiJQ3Xhf1DGxsvNKnQsbj+viIK/d248SMzqzwBYTyuCT9v7oXW1odrOq96QZj9CJtG2g/cTbGj9I8nfJbB1QUeNxZrEHjdZ4RIQaz5tGoCal8H4qZ6Wklh0mzL0Nt+XRyOm8ueNx/D0Erdc5S7QiG4fBQh8/s3AfuWFEMX7g0/KYYB4NCSYqjKOvzn92LEuKRCS/DfBC9FjEuKNxX31lTEKP7WW8J9fHeuudRDN3ApxQ4c7MUNHJtP8d0Evw44/kvkWwch1AKSuyF20NwF047BPjdV5jvEVfhvgj3E7QuU/Cbgpnta8/zTbAO4fuI6DRiTZFMpruI39PnwOnA2+Zvi55Jc4D6f8xhpnRoQ06MVx1SUT/Gf0+6IcUnFJmDf4NfHC00y2gf4KfAZxT3sB3BTBZWwp7mKrgAM3fpwiYuuJttsD6s5ehB4M8M+i3B+QlwDNG+8y1XY56QkcB3Gqg1uR60ATTANt3DOWsp5wO+p7lSkJNbbbN6MjsO3tcAvCVu6+ayEfW2hmmZ/n4c8cbW2t+OFltos7LEhA7gXCOkgC7Bv8J/HC00MM3F9+kWsKBeyTavkrKQMc/Ff1524FRcvxyXOKWJK4dBtG/A0Lu/ISC8T1vLEA8AhBX0HeSS1UDRhFcWxJA+yrGM2SClZN/ZiMAOE1eSlfPNwg6WKmu7V2r4Abt37n75/c14F5yfluAb/dR2e9GscboGnIruQWls/Lj/E7cAc7MWJBoFfFfgd5JEUZ90TBI0heRxQL+ri61g3Y98cW3EPBqlWD24u9mJcd0yRD+PtuGxos4cc71nj39flYSzp/QH/dX3c+LvWINJVFN8y0KoQ+D7ro17PnJfwx7orYlxJJgHrSb4WC2IFKPF1kbzoxiri9sV1iv1wTftrKP6huxvXHHuo59g3Gn+7rMiTlEpZzeyXBu5jHHAdLmteGZWBulc4Z2PHe3q80LyOxG7dbW2vxQpQ6uNkkm+U1TR37mtdjcWNNn6O4t/yB3ED+F7DTWtKcrixH2UHa67d+K/rbOPvfMYAVwAfUPwAwtY2JUNcZbMGTP8hYlzDdeMGL4ZU1L4iXyplaSPPEXbDaExAdqOAH+IyjlnLs+bZdgMvEFboD5WUHron/elKZNZU3/4C9t+Nyxr6AsVlltxUQFxlsMZSfBExrqHOInyRo53AjDhhSh2NImyAWT9wZaQYm6YLl2d8IW56VFnNpztwzfvH5ox3q3GMY3LuW6p3Ov7ruaGE4x0MPEy+yu0zJcRVhEn4Yx4g7pTpMwnr629tvbgF4US+ZSbhS41+itZ3H24cLjvaY7guk7KaSAdxNf3HgcMKjP8d43i3FngcqcZ9+K/nKyUfex/cuJL3cV1Rofd1HfvTW6y36yMqjmUKcA/puw630YypixLJgaT7wb5J53YLHIzLvLeE5IGURWybcAOkyqp43Wsc++WSjinlWYb/elad4+Mo4BHs6aaD1LtP2vo+L6vg+LOB28ie9Gs1WupXAhyKPXhopO0Tql9CtEpzcak0n8L9AMt8u29te4D3cGmZq8jSZTUZf1XB8aVYVr/8cZFi6jFiqvOUOnC/fV/svyj4WN24StNtuBeMvGMsHig4PmlzMwhbonOkQusl3KphRa7ZXZWJuILwl8BbuIKviqlPrW0TLid33v78LJLWh9BAwOZI6rOONa13uhHX15FiCvUA/tjTTl3swj1jj8HNw78d+BMuWdI2invmbMTN8BFJbTSurzDrzTeAa3Z6GFeo1iW5x3jcG9C1uOx6S3BNk6HjH4rc9uAWU7mOejTP7cAf64kR45J0LsSuZMZiVUzq3sp0B/azrhfXcrodV4hv3PufO/Z+1kd1LxO9wE/K+Rqk01xKcYXjTlyl4HlcrfciXFNXEakox+H6x0/BzVX+OW5A3mJcEpMtVNN0b239uAGUDwFHF3DORXsPf+z3RoxL0nkC/3VcHDGusUZcda8A/HfiPjtCC/77qPdYCmmg8bj5vmXfwAO4mnIvria9GbfozQZcjXrT3v9/O64y0Yt7i66ymT7N1odr1rsPV9Gpu7vwn4syAjaHlc//hohxdRlx9UaMK0TSwkAxt424VsQmdrtKgxwALCX+DV/XbQ+uteEumtn3dgz+c9sZMS5Jx1r6Nfb0XasVrs4px8vI1pln24Fr6TmwzJMWGcn+uGb82E3qMbcBXMvEi7i3qrm5vtF66MZuTZkcLzQJNAf/9SsiA2Bem/DHV+dKc5rp0WVs/bh1Qu4jfiVOBPhmCdGkJSebvg3gmtkW41ZJq8Na5WWxMkJeGDEuCXMd/uv3ecS4Wt7CH999EeOy7EP1z5uvcAOUf0Ezug+lw03BLS/8Ec1tGRjANfV9gkuvezPFZttrAmusx5MR45Iwz+O/fk9FjKvFylC4JmJcFmstgNZzI+TZ0o8b67ALNyh5Da5C9DRuzv9ZZFukSaR2jgDuxK0cVkWmvDTbHtzgwiW4+b0Xo2a1lmvxf291eIMUm9WCc3HEuFqOxS4k67gaoNXCOXz9gknAtL2busxq7nuxA+ggo4D/iBu0Mh2YivuB/FPcMqN5BwC1HiA7+WYe7nrctMNPcKPY39u71X3EcUyzcesCjGQA+KsKY5F0RuHeLn3Ptb/D/R5i24N/xPpviJMIy2cO7i3d5z9TfWplKYgqAPUzEfg+rib9N8A/xxU638c1z7eswRX064FVFcfY7qwH9KHAsxXGIuFOAf6b57Pd1Ceb48vAv/d81gf8E+qTGjgp1r/BVYxFRNrCKvxNnndEjEtsj+K/bh9FjGs4qxtgENcKUAeHYsf5fLzQRETKYRUkH0aMS2xWX3XdRthbYxUGgYPihfYXSSvvadyQiLQda2VAjZ+opy7s2Td1m0p2CXbhuom4KW0XeuJqbe/FC01EpDw92FOblH2sfo7Df736cRWEuklqBXg/UlznJMRVlxYKEZFSfIn/4XdrxLhkZA/iv16fRozLYlVaWtsfK47pTJLn9f+h4phERCr1JGr+bBJr4OaDEeNK8hjJlYC3qWadgAtJLvx34VY1FBFpW2fgfwjujhiXjMxaAKhO8+qH6ya5K2AQN913VkkxjAJ+HxBD3b9LEZFCJI0D2D9eaDLMPJrX/z/UAYSlDx/ArbRZ5Pkci8u7H1L4K+GPiHQMaxzALRHjkm+7G/91qmt+/eGOJXwNkW3AT8g3S+BoXIbQkOMN4loIREQ6hjUOwJcuWKq3Av91WhgxrrROIWxhndbWB7wGXAqMT9h3F259kseBr1McYxB4paDzExFpjDOxB0NJfEnz/0+KF1omp5N9NdFdwBe4Bcha634sx7UYpKlYDN1+V+7piojUU9I4AM2Fju8k7D5z35oOdbYf4f3yZW0DwE1ln6iISJ1twP+QvDdiXOI8gf/6rI0YV16jcc37MQr/bcDh5Z+iiEi9WdOjmjLArJ1twn99mtT/73MKsJnq3voXUk3OARGR2vsh9gMzZr72TjcRu0A7Il5ohbsB2El5Bf9zwIzKzkZEpAG6sQdlnRcvtI53Nf7rsidiXGU6A1hG9kF9Q7etuCyJUyo9AxGRBvkY/0P0hYhxdbq38F+Xdp+mORG4HHgGl0kwpEKwG1iJSyakAazC92IHINIAtwLnej7bAXy/wljkG73AX3s+uxa4osJY6mAO8A/AVFzLVR9uIOQ6XBO/pq6KiKQ0HfvNar94oXWsg7GvyaR4oYmISDuxsqfdHjGuTnU//uuxMWJcIiLSZp7GX+B8Ei+sjrUO//X4bcS4RESkzczHnkY1Jl5oHWcSdvP/cfFCExGRdpM0HfCyeKF1nFvwX4c+6r/8r4iINIy16ty7EePqNKvwX4f3I8Yl0iiqKYuEs1ZG25dmLjzTNGOxE9c8VlUgIiLSOaZh9z37cgVIca7AvgYT4oUmIiLt7Ev8hc/rEePqFB/g//5XR4xLRETa3D34C6A9qFutTEkDMX8cLzQREWl3M7CboE+NF1rbOxf7u98nXmgiItIJNuIvhJ6PGFe7ew3/9742YlwiItIh7sNfEGnBlXK0Frfxfe8/jxeaiIh0in2xm6JPjhda27oQ+zufFi80ERHpJJvRbIAqLcP/fa+PGJeIiHSYh/EXSP1AT7zQ2s443HoLvu/7rnihiYhIp9kfu0n6inihtZ2bsb/rmfFCExGRTvQV/kLpk3hhtZ21qPlfRERqxEoKNIids17CTMf+jm+JF5qIiHSqSdh903fGC61tPIj/+x0AxscLTUREOpm1RPCmiHG1i634v9+lEeMSEZEOlzQ/fW680BrvCOzv9ox4oYmISKfrAnrxF1LPxAut8d7A/73uRgsviYhIZIuwcwKMiRZZc43HHl/xZLzQREREnIOxm6q1TG16d2F/pwfGC01EROQbVmrgzRHjaqpt+L/PDRHjEmkb6kMTKcbDxmfjgOOqCqQNnAZ83/j8gaoCERERSTIBu8/6nXihNY618I/GVIiISO28hJ20ZnK80BpjKnbf/5/jhSYiIjKyudiF14PxQmuMR7G/wznxQhMREfFbjT13vTteaLU3GtiD//v7OF5oIiIitrOx32BvjBda7d2B/d3NjxeaiIhIMmsK2w40+2YkXcBO/N/b1nihibQnPYhEinef8dnfAv93VYE0yP8L9Bif31VVICIiIlmNBvpQYqA0rFX/+nDfqYiISO39Cbs/++x4odXOBdjf1VPxQhMREUlnBnZioC/ihVY7G7DzJ0yNF5qIiEh6z2O/2Z4UL7TamI/9Hf0xXmgiIiLZTMVuBVgfL7Ta2Ije/kVEpA09h/2Ge0m80KK7Gr39i4hIm0pqBdhBZ2YHHIU9719v/yIi0njPYL/p3hYvtGjuwf5Ono4XmoiISDGmYLcC9OGWE+4U47HzJOjtX0RE2kZSXoDfxQutcn9Aff8iItIhJpH81rtvtOiqsz92a8geXAuBiIhI27gV+813ZbzQKrMG+zvQaokiItKWNmMXgNfGC610SdP+NsULTUREpFzHYReCe4B9okVXnsnYXSCDwAnRohMREanAUuyC8K14oZXmXexzXhIvNBERkWpMA/qxC8RzokVXvPOwz3UAt3iSiIhI27sfu1DcBYyLFl1xJgC7sc/1vmjRiYiIVKwb+Aq7YHwnWnTFWYZ9jlvozFTIIiLSwQ7FLhwHgZ9Eiy6/m0k+v8OjRSciIhLRoyT3jx8WLbrsjsRO+DMIPBItOhERkci6cfPfrYJyJy6TYFNMJrnffwNq+hcRkQ53AMmzAtYAXbECTKEbWIt9Lv3AnFgBioiI1MkVJPeXvxotunBvknwe10SLTkREpIZeIrnwfDRadMl+R3L8L0SLTkREpKZG4frGkwrRuyPFZ0nKazAIrEf9/iIiIiOaDvSSXJj+MlaAI7iP5Hh7cRkQRURExOMokqfQDQKPxQpwiMdJjrMfmBcrQBERkSY5m+SCdRC3iM6oCPGNwmUqDInxjAjxiYiINNZ1hBWwG4BZFcY1m+TcBRrxLyIiksNNhBW0fcDFFcRzyd5jhcT0owriERERaVu3EFbgDuIW3yljsN104KMUcdxUQgwiIiIdZwFhAwMH9/67RcA+BRx3AvBEimMP4pIaiYiISEHmk5wyePjo+8VkW0zocFxiorTHm5/pzERERMQ0F9hGeKHc2nbiCvSbgCP4duvAZNzqfTfv/Tc7M+z/a+DAUs5YREREABgLvEv6Qrqs7Z29MYmIiEgFLiN8RH4ZWz+a5iciIhLFNGAp1Rf+bwNTKzg/ERERMRwDrKP8gn8dcHRF5yQiIiKBTgBWUHzBvwI4vsLzEBERkQymAfcAG8le6G/ALT2spn6RNvS92AGISOnG4ubn/yfg74GJwGige+/ne3BT/9YDHwJ/wlUetlYeqYiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIhU7P8HS49VowRPAyEAAAAASUVORK5CYII=" alt="ATOMS" />
95
+ <span class="title">Mermaid Diagram</span>
96
+ <span class="subtitle" id="stats"></span>
97
+ </div>
98
+ <div class="atoms-toolbar">
99
+ <button class="atoms-btn" id="zoom-in-btn" title="Zoom in">+</button>
100
+ <button class="atoms-btn" id="zoom-out-btn" title="Zoom out">&minus;</button>
101
+ <button class="atoms-btn" id="reset-btn" title="Reset view">Reset</button>
102
+ <button class="atoms-btn" id="copy-svg-btn" title="Copy SVG to clipboard">Copy SVG</button>
103
+ <button class="atoms-btn" id="copy-mermaid-btn" title="Copy Mermaid source">Copy Source</button>
104
+ </div>
105
+ <div id="diagram-container">
106
+ <div class="atoms-loading" id="loading">Loading diagram...</div>
107
+ <div id="mermaid-output"></div>
108
+ </div>
109
+ <div class="atoms-watermark"><img src="data:image/png;base64,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" alt="" />ATOMS.tech</div>
110
+ </div>
111
+ </body>
112
+ </html>