bytefun-ai-mcp 1.14.43 → 1.14.45

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.
@@ -0,0 +1,187 @@
1
+ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使用UI规范\`.bytefun/UI设计规范.md\`里面默认的主题皮肤来设计,不得使用其他主题皮肤。
2
+
3
+ ## 一、样式规则
4
+ - 样式代码必须使用类选择器样式Class-based Style / Class Selector Style方式,不得使用行内样式Inline Style或外部文件。
5
+ - 遵循手机尺寸规格(宽度 393px 高度 808px)
6
+ - 首页/推荐tab的分类/功能各个入口的图标一般需要使用不一样的颜色,很少会统一全部使用品牌主题色
7
+ - 所有radio、checkBox都必须使用i标签设置FontAwesome图标来实现,不得使用系统的input标签实现。
8
+ - 如用户没有明确描述说明页面背景色,只有闪屏页面的背景色允许设置品牌主色或品牌主色与品牌次色的渐变色,其他页面必须使用非 品牌主色 与非 品牌次色 的纯色做页面背景色,比如一般使用白色系,如果是暗黑风那就是黑色系。
9
+ - 输入框\`input\`如果需要展示文字 label,尽量使用 icon 代替文字 label,并且 icon 重叠在输入框的左侧,这样整个页面的空间利用率高。
10
+ - 如果主题风格是暗黑风格的话,默认可以给每个页面添加多个玻璃效果的圆形径向渐变背景,类似这样:\`background: radial-gradient(circle, rgba(0, 242, 255, 0.1) 0%, rgba(0, 0, 0, 0) 70%);\`,里面的颜色和渐变范围可以根据实际情况调整。
11
+ - 背景色为了增强层次感,添加的梦幻泡泡或者圆形径向渐变元素的div,必须只能声明为\`circle\`,并且一个div的\`background:\`只能声明一个\`radial-gradient\`,比如正确的写法:background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);,如果需要多个\`radial-gradient\`径向渐变背景,每个径向渐变背景都必须声明为一个div节点,每个div的\`background:\`只能声明一个\`radial-gradient\`。
12
+ - 按钮、卡片、item项等元素必须要有一个hover后改变背景色的反馈效果,不能使用transform效果,只能使用背景色效果。
13
+ - css样式里面的\`background-image\`属性的值必须是远程图片,不能设置不是远程图片的任何值,比如不能设置'base64'、渐变'radial-gradient'等。
14
+
15
+ ## 二、必须给每一个节点添加id、name、nodeType属性
16
+ - 特别注意,\`i\`和\`div\`等标签也必须添加 id、name、nodeType 属性,每一个节点都需要添加这三个属性,千万别漏掉了,这是必要条件
17
+ - id 属性必须只能使用英文或数字组成,且不能以数字开头,并且整个页面 id 属性的值必须唯一,使用驼峰的命名方式
18
+ - name 属性必须是中文或数字,并且不能包含特殊字符
19
+ - 如果是通过点击item项切换展示内容的,那么item项的nodeType必须是\`tabMenuBarItem\`,tab panel的nodeType必须是\`tabPanel\`,\`tabMenuBarItem\`的父亲容器是\`tabMenuBar\`,不得使用\`horizontalListView\`来代替\`tabMenuBar\`
20
+ - 页面的header标题栏nodeType必须是\`titleBar\`或者\`topNavigateBar\`,而不是\`container\`
21
+ - nodeType 属性的值必须是\`组件类型枚举 (nodeType)枚举\` 中的一个,一些布局容器需要遵守以下说明来选择正确的nodeType:
22
+ - 开关组件:\`switch\`,用于两个状态切换的场景,比如:打开/关闭、显示/隐藏、同意/拒绝等等,具体场景比如:设置中的开关功能、同意/拒绝协议、密码显示与隐藏图标开关等,比如:
23
+ \`\`\` html
24
+ <div
25
+ id="passwordShowHideCheckbox"
26
+ name="密码显示隐藏切换开关"
27
+ nodeType="switch"
28
+ class="password-show-hide-checkbox"
29
+ onclick="togglePasswordShowHide()"
30
+ >
31
+ <i
32
+ id="passwordShowHideIcon"
33
+ name="密码显示隐藏切换图标"
34
+ nodeType="icon"
35
+ class="far fa-eye"
36
+ checkedClass="far fa-eye-slash"
37
+ ></i>
38
+ </div>
39
+ \`\`\`
40
+ - 脱离文档流的弹窗/Toast窗口容器:\`dialogOverlay\`、\`dialog\`、\`toast\`,用于展示弹窗/Toast类别的loading,不得使用\`oneStateContentContainer\`,应该Toast类别使用\`toast\`,弹窗类别使用\`dialogOverlay\`包含1个\`dialog\`,\`dialog\`是对话框的内容容器,一般屏幕居中显示。
41
+ - 列表容器:\`verticalListView\`、\`horizontalListView\`、\`listItemCard\`,用于布局多个列表项,比如:商品列表、分类列表、标签列表等,可以支持多行多列的列表布局
42
+ - 列表页脚容器:\`listFooterContainer\`,用于布局列表的页脚,比如:加载更多、没有更多了等
43
+ - tab选项卡:\`tabPanelFather\`与\`tabMenuBar\`组合实现tab选项卡,注意tabMenuBar支持横向和竖向的tab选项卡,比如分类竖向的tab选项卡菜单栏,一般分类都使用tab选项卡来实现,禁止使用\`verticalListView\`和\`horizontalListView\`列表来代替tab选项卡。
44
+ - 网格容器:gridContainer用于布局多个网格项,里面包含N个gridItem,比如:分类网格入口
45
+ - 流式容器:用于布局多个子项,子项可以在一行显示,当位置不够时就换行显示,比如:一组标签tag的排版布局
46
+ - 多状态容器:\`multiStateContainer\`, \`oneStateContentContainer\`,用于不是通过交互,而是通过逻辑状态变量变化而显示不同状态的内容容器,比如:登录状态和未登录状态分别显示不同的内容、加载中/加载失败/加载成功有数据/没有数据等状态切换、不同权限/等级/时期等等显示不同的功能,等等这些通过逻辑状态变量变化而显示不同状态的内容容器,都必须使用\`multiStateContainer\`和\`oneStateContentContainer\`来实现,特别注意脱离文档流的弹窗/Toast窗口容器类别的loading,不得使用\`oneStateContentContainer\`,应该使用\`dialogOverlay/dialog\`或者\`toast\`。
47
+ - 高级组件节点的nodeType结构规则:
48
+ - 对话框:\`dialogOverlay\`是弹窗/Toast窗口容器的遮罩层,\`dialog\`是对话框的内容容器,\`dialogOverlay\`包含一个\`dialog\`,\`dialog\`一般屏幕居中显示
49
+ - tab 选项卡:\`tabMenuBar\`是tab选项卡菜单栏,里面包含N个\`tabMenuBarItem\`,\`tabPanelFather\`是tab选项卡内容容器,里面包含N个\`tabPanel\`,\`tabMenuBar\`和\`tabPanelFather\`必须同时存在,\`tabPanel\`的数量必须和\`tabMenuBarItem\`的数量相同,注意tabMenuBar支持横向和竖向的tab选项卡,比如分类竖向的tab选项卡菜单栏,一般分类都使用tab选项卡来实现,禁止使用\`verticalListView\`和\`horizontalListView\`列表来代替tab选项卡。
50
+ - viewPager 轮播:\`viewPager\`是轮播容器,里面包含N个\`viewPagerItem\`,\`viewPagerIndicatorContainer\`是轮播指示器容器,\`viewPager\`与\`viewPagerIndicatorContainer\`必须同时存在
51
+ - 一行不够位置显示就换行的容器:\`inlineBlockAndWrap\`,里面包含N个\`blockItem\`,\`blockItem\`是它的子项
52
+ - 多状态容器:一个\`multiStateContainer\`多状态容器包含多个\`oneStateContentContainer\`
53
+
54
+ - 组件类型枚举 (nodeType)枚举:
55
+
56
+ - 形状:\`rect\`, \`circle\`, \`line\`
57
+ - 基础组件:\`text\`、\`button\`、\`input\`、\`icon\`、\`image\`
58
+ - 基础容器:\`container\`
59
+ - 网格容器:\`gridContainer\`、\`gridItem\`
60
+ - 流式容器:\`inlineBlockAndWrap\`、\`blockItem\`
61
+ - 开关:\`switch\`
62
+ - 单选:\`radioGroup\`、\`radio\`
63
+ - 多选:\`checkBoxGroup\`、\`checkBox\`
64
+ - 顶部导航栏:\`titleBar\`、\`topNavigateBar\`
65
+ - 底部操作栏:\`bottomOperateBar\`
66
+ - 多状态容器:\`multiStateContainer\`, \`oneStateContentContainer\`
67
+ - 列表:\`verticalListView\`, \`horizontalListView\`, \`listItemCard\`、\`listFooterContainer\`
68
+ - 轮播:\`viewPager\`, \`viewPagerItem\`, \`viewPagerIndicatorContainer\`
69
+ - tab 选项卡:\`tabPanelFather\`, \`tabPanel\`, \`tabMenuBar\`, \`tabMenuBarItem\`
70
+ - 底部导航: \`bottomTabContentContainer\`, \`subPage\`, \`bottomTabNavigateBar\`, \`bottomTabNavigateBarItem\`
71
+ - 对话框:\`dialogOverlay\`, \`dialogContent\`
72
+ - toast 提示:\`toast\`
73
+ - 下拉菜单:\`dropDownMenu\`
74
+ - 侧滑面板:\`sideSlidePanel\`
75
+ - 手机硬件元素:\`phoneTopStatusBar\`、\`phoneBottomIndicatorBar\`,这两个元素是手机硬件自带的元素,不能在页面中添加。
76
+
77
+ ## 三、轮播与Tabs组件的规则
78
+ - 轮播的每一个Slide和Tabs选项卡组件每一个Tab Panel都必须使用\`display: none\`和\`display: block/flex\`来实现隐藏和显示的互斥切换
79
+ - 轮播的每一个Slide必须有html代码实现,不得只写第1个Slide的具体内容的html代码,其他Slide的具体内容的html代码也必须要写,绝对禁止敷衍地使用\`Placeholder content/待开发/开发中/即将上线\`等等来敷衍地展示轮播的每一个Slide,必须每一个Slide都有具体真实的内容展示实现。
80
+ - Tabs选项卡组件需要添加点击切换Tab Panel的功能,不得只写第1个Tab Panel的html代码,其他Tab Panel的具体内容的html代码也必须要写,绝对禁止敷衍地使用\`Placeholder content/待开发/开发中/即将上线\`等等来敷衍地展示Tabs选项卡组件的每一个Tab Panel,必须每一个Tab Panel都有具体真实的内容展示实现。
81
+ - 例子:
82
+ \`\`\`html
83
+ <tabPanelFather nodeType="tabPanelFather" id="tabPanelFather" name="Tabs选项卡内容容器">
84
+ <!-- Tab Panel 1 -->
85
+ <tabPanel nodeType="tabPanel" id="tabPanel1" name="Tabs选项卡1">
86
+ <text nodeType="text" id="tabPanel1Text" name="Tabs选项卡1的文本">Tabs选项卡1的内容</text>
87
+ ...
88
+ <div nodeType="div" id="tabPanel1Div" name="Tabs选项卡1的div容器">
89
+ ...
90
+ </div>
91
+ </tabPanel>
92
+ <!-- Tab Panel 2 -->
93
+ <tabPanel nodeType="tabPanel" id="tabPanel2" name="Tabs选项卡2">
94
+ <text nodeType="text" id="tabPanel2Text" name="Tabs选项卡2的文本">Tabs选项卡2的内容</text>
95
+ ...
96
+ <div nodeType="div" id="tabPanel2Div" name="Tabs选项卡2的div容器">
97
+ ...
98
+ </div>
99
+ </tabPanel>
100
+ <!-- 更多Tab Panel和具体内容... -->
101
+ </tabPanelFather>
102
+ \`\`\`
103
+
104
+ ## 四、列表组件规则
105
+ - 如果该列表的数据是从网络接口拉取的,那么必须使用多状态容器\`multiStateContainer\`将loading、联网失败、没有数据、有数据的四个状态使用\`oneStateContentContainer\`包起来并展示出来,其中有数据状态的\`oneStateContentContainer\`包含的就是该列表组件。
106
+ - 如果列表数据只是网络聚合业务接口的一部分,那么该列表不需要loading和联网失败状态,只需要有数据状态和没有数据状态,比如首页的推荐列表、分类列表、最新动态列表等这些是首页业务聚合接口获取的,这些列表数据只是业务接口的一部分,不是独立的接口,所以不需要loading和联网失败状态。
107
+ - 例子:
108
+ \`\`\`html
109
+ <multiStateContainer nodeType="multiStateContainer" id="listMultiStateContainer" name="列表多状态容器">
110
+ <!-- 有数据状态的oneStateContentContainer -->
111
+ <oneStateContentContainer nodeType="oneStateContentContainer" id="hasDataStateContainer" name="有数据状态的容器">
112
+ <!-- 列表组件 -->
113
+ <verticalListView nodeType="verticalListView" id="listView" fromApiOrCacheData="true" name="列表组件">
114
+ <!-- 列表项 -->
115
+ <listItemCard nodeType="listItemCard" id="listItem1" name="列表项1">
116
+ <!-- 列表项内容 -->
117
+ <text nodeType="text" id="listItem1Text" name="列表项1的文本">列表项1</text>
118
+ </listItemCard>
119
+ <!-- 更多列表项... -->
120
+ </verticalListView>
121
+ </oneStateContentContainer>
122
+ <oneStateContentContainer nodeType="oneStateContentContainer" id="noDataStateContainer" name="没有数据状态的容器">
123
+ <!-- 没有数据状态的提示 -->
124
+ </oneStateContentContainer>
125
+ <oneStateContentContainer nodeType="oneStateContentContainer" id="loadingStateContainer" name="loading状态的容器">
126
+ <!-- loading状态的提示 -->
127
+ </oneStateContentContainer>
128
+ <oneStateContentContainer nodeType="oneStateContentContainer" id="networkErrorStateContainer" name="联网失败状态的容器">
129
+ <!-- 联网失败状态的提示 -->
130
+ </oneStateContentContainer>
131
+ </multiStateContainer>
132
+ \`\`\`
133
+
134
+ ## 五、图标与图片的规则
135
+ - 当需要icon图标时必须使用FontAwesome图标,比如:\`<i name="微信Icon" vtype="icon" id="wxIcon" class="fab fa-weixin"></i>\`,并且注意图标的颜色,比如微信图标一般使用绿色系,QQ图标一般使用蓝色系,微博图标一般使用红色系,支付宝图标一般使用浅蓝色系等等
136
+ - 绝对不能使用 emoji 表情符号,不得使用任何 emoji 表情符号,请使用FontAwesome字体图标来代替。
137
+ - LOGO图片和引导页的引导图片必须使用\`doc/res/svgMap.json\`文件中json对象正确字段的https链接值,禁止使用本地图片路径\`doc/res/logo.svg\`文件,而是使用类似:\`https://editor.bytefungo.com/dfile/img/xxxxx.svg\`这样的图片链接地址,比如闪屏页、登录页、注册页用到的LOGO图片,引导页的引导图片等。
138
+ - jpg、jpeg类型图片必须使用图片地址:\`https://oss.bytefungo.com/f1/showImg1.jpg\`),其中结尾的’showImg1'可以换为从 1 到 30 的数字,1~30 的数字必须随机挑选,不得每个页面每个图片都使用同一个数字。写法比如:\`<img src="https://oss.bytefungo.com/f1/showImg17.jpg" alt="xxx" class="xxx" nodeType="image">\`
139
+
140
+ ## 六、必须理解并遵守以下禁止的多个UI设计代码写法
141
+ - 禁止使用任何前端框架,只使用 html+类选择器样式+js 来实现。
142
+ - 禁止使用js代码来拼接html字符串,必须在body标签里面直接写html代码。
143
+ - 禁止使用js代码来声明任何页面显示所需的数据,所有数据都必须在html代码中直接写死。
144
+ - 禁止使用文本渐变色,必须使用纯色文本,也就是禁止使用\`-webkit-text-fill-color\`属性。
145
+ - 禁止给页面添加\`手机顶部状态栏\`、\`手机底部指示器栏\`两个非页面内容的元素节点,这是手机硬件自带的元素,不能在页面中添加。
146
+ - 禁止使用\`:before\`、\`:after\`伪元素,必须使用其他标签来实现。
147
+ - 禁止使用\`backdrop-filter\`等玻璃效果,必须删除掉所有使用到玻璃效果的代码。
148
+ - 禁止使用多个p标签或多个其他标签来显示一个从网络或其他地方拉取回来的长文本,必须只能使用一个标签来显示,比如:div、span等,因为网络拉取回来的长文本是一个文本,无法使用多个标签来显示一个文本,必须只能使用一个标签来显示。
149
+ - loading节点的实现禁止使用div标签与边框属性实现,必须使用图标icon的i标签来实现loading的节点
150
+ - 禁止为html标签节点添加动画或过渡效果,页面设计不需要任何动画和过渡效果,比如禁止:@keyframes、transition、animation 等。
151
+ - 按钮、卡片、item项等元素必须要有hover与点击反馈,点击反馈必须使用浅色的背景色background来反馈就行,严禁使用transform效果
152
+ - ❌ 错误的用法:
153
+ \`\`\` css
154
+ .hot-sales-item:hover {
155
+ transform: translateX(...px);
156
+ }
157
+ \`\`\`
158
+ - ✅ 正确的用法:
159
+ \`\`\` css
160
+ .hot-sales-item:hover {
161
+ background: ...;
162
+ }
163
+ \`\`\`
164
+ - 禁止使用div标签来实现image图片,必须要使用img标签来实现图片节点,img标签的src属性必须设置为:\`https://oss.bytefungo.com/f1/showImg1.jpg\`,其中里面的\`showImg1\`可以改为1~30的任意一个数字,比如:\`showImg5\`。
165
+ - ❌错误的写法:
166
+ \`\`\` html
167
+ <div class="bestseller-cover" id="bestsellerCover1" name="畅销书籍封面1" nodeType="image">
168
+ </div>
169
+ \`\`\`
170
+ - ✅ 正确的写法:
171
+ \`\`\` html
172
+ <img class="bestseller-cover" id="bestsellerCover1" name="畅销书籍封面1" nodeType="image" src="https://oss.bytefungo.com/f1/showImg7.jpg">
173
+ \`\`\`
174
+ - 禁止 id 属性不规范,id 必须唯一,且只能由字母和数字组成(不能以数字开头),建议使用驼峰命名。
175
+ - 禁止使用行内 style 属性,必须通过 class 和 CSS 文件来定义样式。
176
+ - 禁止 radial-gradient 样式不规范,径向渐变必须显式声明为 circle,且一个 DOM 节点只能包含一个 radial-gradient。
177
+
178
+ ## 七、首页主体页与子页面的规则
179
+ - 首页主体页嵌套了多个子页面,每一个子页面都不需要填充内容,空白就行,后面会有专门的任务来设计具体的子页面。
180
+ - 任何子页面都必须禁止添加底部导航栏节点到页面,因为子页面是嵌套在首页主体页中的,父页面已经有底部导航栏了,子页面不需要再添加底部导航栏,也不得添加二级页面的标题栏到子页面中,因为子页面是嵌套在首页主体页中的,首页主体页和它的子页面都是一级页面,因此不得添加二级页面的标题栏到子页面中。
181
+
182
+ ## 八、如果用户没有明确说明该页面设计需求,那就按照以下页面默认规则设计
183
+ - 闪屏页:禁止使用全屏图片,一般使用主题相关的渐变色,然后带有一些额外的背景元素增强界面层次感,比如:梦幻圆圈泡泡、玻璃效果的圆形径向渐变等等元素
184
+ - 引导页:尽量不使用全屏图片,一般每一页引导页背景色也可以渐变,然后每一页功能说明一般有非全屏图片、标题、副标题等等,你可以带入其他元素,让页面更加美观,并且引导页的引导图片需要自己绘制svg图片,并存放在\`doc/res\`文件夹下面,并在html中使用
185
+ - 背景色为了增强层次感,添加的梦幻泡泡或者圆形径向渐变元素的div,必须只能声明为\`circle\`,并且一个div的\`background:\`只能声明一个\`radial-gradient\`,比如正确的写法:background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);,如果需要多个\`radial-gradient\`径向渐变背景,每个径向渐变背景都必须声明为一个div节点,每个div的\`background:\`只能声明一个\`radial-gradient\`。
186
+ `;
187
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlEZXNpZ25NdWxTdGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3VpRGVzaWduTXVsU3RhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0F5THJDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdWlEZXNpZ25Qcm9tcHRUZW1wbGF0ZSA9IGAjIFVJ6K6+6K6h6KeE5YiZ77yM54m55Yir5rOo5oSP5b+F6aG75L2/55SoVUnop4TojINcXGAuYnl0ZWZ1bi9VSeiuvuiuoeinhOiMgy5tZFxcYOmHjOmdoum7mOiupOeahOS4u+mimOearuiCpOadpeiuvuiuoe+8jOS4jeW+l+S9v+eUqOWFtuS7luS4u+mimOearuiCpOOAglxuXG4jIyDkuIDjgIHmoLflvI/op4TliJlcbi0g5qC35byP5Luj56CB5b+F6aG75L2/55So57G76YCJ5oup5Zmo5qC35byPQ2xhc3MtYmFzZWQgU3R5bGUgLyBDbGFzcyBTZWxlY3RvciBTdHlsZeaWueW8j++8jOS4jeW+l+S9v+eUqOihjOWGheagt+W8j0lubGluZSBTdHlsZeaIluWklumDqOaWh+S7tuOAglxuLSDpgbXlvqrmiYvmnLrlsLrlr7jop4TmoLwo5a695bqmIDM5M3B4IOmrmOW6piA4MDhweClcbi0g6aaW6aG1L+aOqOiNkHRhYueahOWIhuexuy/lip/og73lkITkuKrlhaXlj6PnmoTlm77moIfkuIDoiKzpnIDopoHkvb/nlKjkuI3kuIDmoLfnmoTpopzoibLvvIzlvojlsJHkvJrnu5/kuIDlhajpg6jkvb/nlKjlk4HniYzkuLvpopjoibJcbi0g5omA5pyJcmFkaW/jgIFjaGVja0JveOmDveW/hemhu+S9v+eUqGnmoIfnrb7orr7nva5Gb250QXdlc29tZeWbvuagh+adpeWunueOsO+8jOS4jeW+l+S9v+eUqOezu+e7n+eahGlucHV05qCH562+5a6e546w44CCXG4tIOWmgueUqOaIt+ayoeacieaYjuehruaPj+i/sOivtOaYjumhtemdouiDjOaZr+iJsu+8jOWPquaciemXquWxj+mhtemdoueahOiDjOaZr+iJsuWFgeiuuOiuvue9ruWTgeeJjOS4u+iJsuaIluWTgeeJjOS4u+iJsuS4juWTgeeJjOasoeiJsueahOa4kOWPmOiJsu+8jOWFtuS7lumhtemdouW/hemhu+S9v+eUqOmdniDlk4HniYzkuLvoibIg5LiO6Z2eIOWTgeeJjOasoeiJsiDnmoTnuq/oibLlgZrpobXpnaLog4zmma/oibLvvIzmr5TlpoLkuIDoiKzkvb/nlKjnmb3oibLns7vvvIzlpoLmnpzmmK/mmpfpu5Hpo47pgqPlsLHmmK/pu5HoibLns7vjgIJcbi0g6L6T5YWl5qGGXFxgaW5wdXRcXGDlpoLmnpzpnIDopoHlsZXnpLrmloflrZcgbGFiZWzvvIzlsL3ph4/kvb/nlKggaWNvbiDku6Pmm7/mloflrZcgbGFiZWzvvIzlubbkuJQgaWNvbiDph43lj6DlnKjovpPlhaXmoYbnmoTlt6bkvqfvvIzov5nmoLfmlbTkuKrpobXpnaLnmoTnqbrpl7TliKnnlKjnjofpq5jjgIJcbi0g5aaC5p6c5Li76aKY6aOO5qC85piv5pqX6buR6aOO5qC855qE6K+d77yM6buY6K6k5Y+v5Lul57uZ5q+P5Liq6aG16Z2i5re75Yqg5aSa5Liq546755KD5pWI5p6c55qE5ZyG5b2i5b6E5ZCR5riQ5Y+Y6IOM5pmv77yM57G75Ly86L+Z5qC377yaXFxgYmFja2dyb3VuZDogcmFkaWFsLWdyYWRpZW50KGNpcmNsZSwgcmdiYSgwLCAyNDIsIDI1NSwgMC4xKSAwJSwgcmdiYSgwLCAwLCAwLCAwKSA3MCUpO1xcYO+8jOmHjOmdoueahOminOiJsuWSjOa4kOWPmOiMg+WbtOWPr+S7peagueaNruWunumZheaDheWGteiwg+aVtOOAglxuLSDog4zmma/oibLkuLrkuoblop7lvLrlsYLmrKHmhJ/vvIzmt7vliqDnmoTmoqblubvms6Hms6HmiJbogIXlnIblvaLlvoTlkJHmuJDlj5jlhYPntKDnmoRkaXbvvIzlv4Xpobvlj6rog73lo7DmmI7kuLpcXGBjaXJjbGVcXGDvvIzlubbkuJTkuIDkuKpkaXbnmoRcXGBiYWNrZ3JvdW5kOlxcYOWPquiDveWjsOaYjuS4gOS4qlxcYHJhZGlhbC1ncmFkaWVudFxcYO+8jOavlOWmguato+ehrueahOWGmeazle+8mmJhY2tncm91bmQ6IHJhZGlhbC1ncmFkaWVudChjaXJjbGUsIHJnYmEoMCwgMjI5LCAyNTUsIDAuMTUpIDAlLCByZ2JhKDAsIDAsIDAsIDApIDcwJSk777yM5aaC5p6c6ZyA6KaB5aSa5LiqXFxgcmFkaWFsLWdyYWRpZW50XFxg5b6E5ZCR5riQ5Y+Y6IOM5pmv77yM5q+P5Liq5b6E5ZCR5riQ5Y+Y6IOM5pmv6YO95b+F6aG75aOw5piO5Li65LiA5LiqZGl26IqC54K577yM5q+P5LiqZGl255qEXFxgYmFja2dyb3VuZDpcXGDlj6rog73lo7DmmI7kuIDkuKpcXGByYWRpYWwtZ3JhZGllbnRcXGDjgIJcbi0g5oyJ6ZKu44CB5Y2h54mH44CBaXRlbemhueetieWFg+e0oOW/hemhu+imgeacieS4gOS4qmhvdmVy5ZCO5pS55Y+Y6IOM5pmv6Imy55qE5Y+N6aaI5pWI5p6c77yM5LiN6IO95L2/55SodHJhbnNmb3Jt5pWI5p6c77yM5Y+q6IO95L2/55So6IOM5pmv6Imy5pWI5p6c44CCXG4tIGNzc+agt+W8j+mHjOmdoueahFxcYGJhY2tncm91bmQtaW1hZ2VcXGDlsZ7mgKfnmoTlgLzlv4XpobvmmK/ov5znqIvlm77niYfvvIzkuI3og73orr7nva7kuI3mmK/ov5znqIvlm77niYfnmoTku7vkvZXlgLzvvIzmr5TlpoLkuI3og73orr7nva4nYmFzZTY0J+OAgea4kOWPmCdyYWRpYWwtZ3JhZGllbnQn562J44CCXG5cbiMjIOS6jOOAgeW/hemhu+e7meavj+S4gOS4quiKgueCuea3u+WKoGlk44CBbmFtZeOAgW5vZGVUeXBl5bGe5oCnXG4tIOeJueWIq+azqOaEj++8jFxcYGlcXGDlkoxcXGBkaXZcXGDnrYnmoIfnrb7kuZ/lv4Xpobvmt7vliqAgaWTjgIFuYW1l44CBbm9kZVR5cGUg5bGe5oCn77yM5q+P5LiA5Liq6IqC54K56YO96ZyA6KaB5re75Yqg6L+Z5LiJ5Liq5bGe5oCn77yM5Y2D5LiH5Yir5ryP5o6J5LqG77yM6L+Z5piv5b+F6KaB5p2h5Lu2XG4tIGlkIOWxnuaAp+W/hemhu+WPquiDveS9v+eUqOiLseaWh+aIluaVsOWtl+e7hOaIkO+8jOS4lOS4jeiDveS7peaVsOWtl+W8gOWktO+8jOW5tuS4lOaVtOS4qumhtemdoiBpZCDlsZ7mgKfnmoTlgLzlv4XpobvllK/kuIDvvIzkvb/nlKjpqbzls7DnmoTlkb3lkI3mlrnlvI9cbi0gbmFtZSDlsZ7mgKflv4XpobvmmK/kuK3mlofmiJbmlbDlrZfvvIzlubbkuJTkuI3og73ljIXlkKvnibnmrorlrZfnrKZcbi0g5aaC5p6c5piv6YCa6L+H54K55Ye7aXRlbemhueWIh+aNouWxleekuuWGheWuueeahO+8jOmCo+S5iGl0ZW3pobnnmoRub2RlVHlwZeW/hemhu+aYr1xcYHRhYk1lbnVCYXJJdGVtXFxg77yMdGFiIHBhbmVs55qEbm9kZVR5cGXlv4XpobvmmK9cXGB0YWJQYW5lbFxcYO+8jFxcYHRhYk1lbnVCYXJJdGVtXFxg55qE54i25Lqy5a655Zmo5pivXFxgdGFiTWVudUJhclxcYO+8jOS4jeW+l+S9v+eUqFxcYGhvcml6b250YWxMaXN0Vmlld1xcYOadpeS7o+abv1xcYHRhYk1lbnVCYXJcXGBcbi0g6aG16Z2i55qEaGVhZGVy5qCH6aKY5qCPbm9kZVR5cGXlv4XpobvmmK9cXGB0aXRsZUJhclxcYOaIluiAhVxcYHRvcE5hdmlnYXRlQmFyXFxg77yM6ICM5LiN5pivXFxgY29udGFpbmVyXFxgXG4tIG5vZGVUeXBlIOWxnuaAp+eahOWAvOW/hemhu+aYr1xcYOe7hOS7tuexu+Wei+aemuS4viAobm9kZVR5cGUp5p6a5Li+XFxgIOS4reeahOS4gOS4qu+8jOS4gOS6m+W4g+WxgOWuueWZqOmcgOimgemBteWuiOS7peS4i+ivtOaYjuadpemAieaLqeato+ehrueahG5vZGVUeXBl77yaXG4gIC0g5byA5YWz57uE5Lu277yaXFxgc3dpdGNoXFxg77yM55So5LqO5Lik5Liq54q25oCB5YiH5o2i55qE5Zy65pmv77yM5q+U5aaC77ya5omT5byAL+WFs+mXreOAgeaYvuekui/pmpDol4/jgIHlkIzmhI8v5ouS57ud562J562J77yM5YW35L2T5Zy65pmv5q+U5aaC77ya6K6+572u5Lit55qE5byA5YWz5Yqf6IO944CB5ZCM5oSPL+aLkue7neWNj+iuruOAgeWvhueggeaYvuekuuS4jumakOiXj+Wbvuagh+W8gOWFs+etie+8jOavlOWmgu+8mlxuICBcXGBcXGBcXGAgaHRtbFxuICAgIDxkaXZcbiAgICAgIGlkPVwicGFzc3dvcmRTaG93SGlkZUNoZWNrYm94XCJcbiAgICAgIG5hbWU9XCLlr4bnoIHmmL7npLrpmpDol4/liIfmjaLlvIDlhbNcIlxuICAgICAgbm9kZVR5cGU9XCJzd2l0Y2hcIlxuICAgICAgY2xhc3M9XCJwYXNzd29yZC1zaG93LWhpZGUtY2hlY2tib3hcIlxuICAgICAgb25jbGljaz1cInRvZ2dsZVBhc3N3b3JkU2hvd0hpZGUoKVwiXG4gICAgPlxuICAgICAgPGlcbiAgICAgICAgaWQ9XCJwYXNzd29yZFNob3dIaWRlSWNvblwiXG4gICAgICAgIG5hbWU9XCLlr4bnoIHmmL7npLrpmpDol4/liIfmjaLlm77moIdcIlxuICAgICAgICBub2RlVHlwZT1cImljb25cIlxuICAgICAgICBjbGFzcz1cImZhciBmYS1leWVcIlxuICAgICAgICBjaGVja2VkQ2xhc3M9XCJmYXIgZmEtZXllLXNsYXNoXCJcbiAgICAgID48L2k+XG4gICAgPC9kaXY+XG4gIFxcYFxcYFxcYFxuICAtIOiEseemu+aWh+aho+a1geeahOW8ueeqly9Ub2FzdOeql+WPo+WuueWZqO+8mlxcYGRpYWxvZ092ZXJsYXlcXGDjgIFcXGBkaWFsb2dcXGDjgIFcXGB0b2FzdFxcYO+8jOeUqOS6juWxleekuuW8ueeqly9Ub2FzdOexu+WIq+eahGxvYWRpbmfvvIzkuI3lvpfkvb/nlKhcXGBvbmVTdGF0ZUNvbnRlbnRDb250YWluZXJcXGDvvIzlupTor6VUb2FzdOexu+WIq+S9v+eUqFxcYHRvYXN0XFxg77yM5by556qX57G75Yir5L2/55SoXFxgZGlhbG9nT3ZlcmxheVxcYOWMheWQqzHkuKpcXGBkaWFsb2dcXGDvvIxcXGBkaWFsb2dcXGDmmK/lr7nor53moYbnmoTlhoXlrrnlrrnlmajvvIzkuIDoiKzlsY/luZXlsYXkuK3mmL7npLrjgIJcbiAgLSDliJfooajlrrnlmajvvJpcXGB2ZXJ0aWNhbExpc3RWaWV3XFxg44CBXFxgaG9yaXpvbnRhbExpc3RWaWV3XFxg44CBXFxgbGlzdEl0ZW1DYXJkXFxg77yM55So5LqO5biD5bGA5aSa5Liq5YiX6KGo6aG577yM5q+U5aaC77ya5ZWG5ZOB5YiX6KGo44CB5YiG57G75YiX6KGo44CB5qCH562+5YiX6KGo562J77yM5Y+v5Lul5pSv5oyB5aSa6KGM5aSa5YiX55qE5YiX6KGo5biD5bGAXG4gIC0g5YiX6KGo6aG16ISa5a655Zmo77yaXFxgbGlzdEZvb3RlckNvbnRhaW5lclxcYO+8jOeUqOS6juW4g+WxgOWIl+ihqOeahOmhteiEmu+8jOavlOWmgu+8muWKoOi9veabtOWkmuOAgeayoeacieabtOWkmuS6huetiVxuICAtIHRhYumAiemhueWNoe+8mlxcYHRhYlBhbmVsRmF0aGVyXFxg5LiOXFxgdGFiTWVudUJhclxcYOe7hOWQiOWunueOsHRhYumAiemhueWNoe+8jOazqOaEj3RhYk1lbnVCYXLmlK/mjIHmqKrlkJHlkoznq5blkJHnmoR0YWLpgInpobnljaHvvIzmr5TlpoLliIbnsbvnq5blkJHnmoR0YWLpgInpobnljaHoj5zljZXmoI/vvIzkuIDoiKzliIbnsbvpg73kvb/nlKh0YWLpgInpobnljaHmnaXlrp7njrDvvIznpoHmraLkvb/nlKhcXGB2ZXJ0aWNhbExpc3RWaWV3XFxg5ZKMXFxgaG9yaXpvbnRhbExpc3RWaWV3XFxg5YiX6KGo5p2l5Luj5pu/dGFi6YCJ6aG55Y2h44CCXG4gIC0g572R5qC85a655Zmo77yaZ3JpZENvbnRhaW5lcueUqOS6juW4g+WxgOWkmuS4que9keagvOmhue+8jOmHjOmdouWMheWQq07kuKpncmlkSXRlbe+8jOavlOWmgu+8muWIhuexu+e9keagvOWFpeWPo1xuICAtIOa1geW8j+WuueWZqO+8mueUqOS6juW4g+WxgOWkmuS4quWtkOmhue+8jOWtkOmhueWPr+S7peWcqOS4gOihjOaYvuekuu+8jOW9k+S9jee9ruS4jeWkn+aXtuWwseaNouihjOaYvuekuu+8jOavlOWmgu+8muS4gOe7hOagh+etvnRhZ+eahOaOkueJiOW4g+WxgFxuICAtIOWkmueKtuaAgeWuueWZqO+8mlxcYG11bHRpU3RhdGVDb250YWluZXJcXGAsIFxcYG9uZVN0YXRlQ29udGVudENvbnRhaW5lclxcYO+8jOeUqOS6juS4jeaYr+mAmui/h+S6pOS6ku+8jOiAjOaYr+mAmui/h+mAu+i+keeKtuaAgeWPmOmHj+WPmOWMluiAjOaYvuekuuS4jeWQjOeKtuaAgeeahOWGheWuueWuueWZqO+8jOavlOWmgu+8mueZu+W9leeKtuaAgeWSjOacqueZu+W9leeKtuaAgeWIhuWIq+aYvuekuuS4jeWQjOeahOWGheWuueOAgeWKoOi9veS4rS/liqDovb3lpLHotKUv5Yqg6L295oiQ5Yqf5pyJ5pWw5o2uL+ayoeacieaVsOaNruetieeKtuaAgeWIh+aNouOAgeS4jeWQjOadg+mZkC/nrYnnuqcv5pe25pyf562J562J5pi+56S65LiN5ZCM55qE5Yqf6IO977yM562J562J6L+Z5Lqb6YCa6L+H6YC76L6R54q25oCB5Y+Y6YeP5Y+Y5YyW6ICM5pi+56S65LiN5ZCM54q25oCB55qE5YaF5a655a655Zmo77yM6YO95b+F6aG75L2/55SoXFxgbXVsdGlTdGF0ZUNvbnRhaW5lclxcYOWSjFxcYG9uZVN0YXRlQ29udGVudENvbnRhaW5lclxcYOadpeWunueOsO+8jOeJueWIq+azqOaEj+iEseemu+aWh+aho+a1geeahOW8ueeqly9Ub2FzdOeql+WPo+WuueWZqOexu+WIq+eahGxvYWRpbmfvvIzkuI3lvpfkvb/nlKhcXGBvbmVTdGF0ZUNvbnRlbnRDb250YWluZXJcXGDvvIzlupTor6Xkvb/nlKhcXGBkaWFsb2dPdmVybGF5L2RpYWxvZ1xcYOaIluiAhVxcYHRvYXN0XFxg44CCXG4tIOmrmOe6p+e7hOS7tuiKgueCueeahG5vZGVUeXBl57uT5p6E6KeE5YiZ77yaXG4gIC0g5a+56K+d5qGG77yaXFxgZGlhbG9nT3ZlcmxheVxcYOaYr+W8ueeqly9Ub2FzdOeql+WPo+WuueWZqOeahOmBrue9qeWxgu+8jFxcYGRpYWxvZ1xcYOaYr+WvueivneahhueahOWGheWuueWuueWZqO+8jFxcYGRpYWxvZ092ZXJsYXlcXGDljIXlkKvkuIDkuKpcXGBkaWFsb2dcXGDvvIxcXGBkaWFsb2dcXGDkuIDoiKzlsY/luZXlsYXkuK3mmL7npLpcbiAgLSB0YWIg6YCJ6aG55Y2h77yaXFxgdGFiTWVudUJhclxcYOaYr3RhYumAiemhueWNoeiPnOWNleagj++8jOmHjOmdouWMheWQq07kuKpcXGB0YWJNZW51QmFySXRlbVxcYO+8jFxcYHRhYlBhbmVsRmF0aGVyXFxg5pivdGFi6YCJ6aG55Y2h5YaF5a655a655Zmo77yM6YeM6Z2i5YyF5ZCrTuS4qlxcYHRhYlBhbmVsXFxg77yMXFxgdGFiTWVudUJhclxcYOWSjFxcYHRhYlBhbmVsRmF0aGVyXFxg5b+F6aG75ZCM5pe25a2Y5Zyo77yMXFxgdGFiUGFuZWxcXGDnmoTmlbDph4/lv4XpobvlkoxcXGB0YWJNZW51QmFySXRlbVxcYOeahOaVsOmHj+ebuOWQjO+8jOazqOaEj3RhYk1lbnVCYXLmlK/mjIHmqKrlkJHlkoznq5blkJHnmoR0YWLpgInpobnljaHvvIzmr5TlpoLliIbnsbvnq5blkJHnmoR0YWLpgInpobnljaHoj5zljZXmoI/vvIzkuIDoiKzliIbnsbvpg73kvb/nlKh0YWLpgInpobnljaHmnaXlrp7njrDvvIznpoHmraLkvb/nlKhcXGB2ZXJ0aWNhbExpc3RWaWV3XFxg5ZKMXFxgaG9yaXpvbnRhbExpc3RWaWV3XFxg5YiX6KGo5p2l5Luj5pu/dGFi6YCJ6aG55Y2h44CCXG4gIC0gdmlld1BhZ2VyIOi9ruaSre+8mlxcYHZpZXdQYWdlclxcYOaYr+i9ruaSreWuueWZqO+8jOmHjOmdouWMheWQq07kuKpcXGB2aWV3UGFnZXJJdGVtXFxg77yMXFxgdmlld1BhZ2VySW5kaWNhdG9yQ29udGFpbmVyXFxg5piv6L2u5pKt5oyH56S65Zmo5a655Zmo77yMXFxgdmlld1BhZ2VyXFxg5LiOXFxgdmlld1BhZ2VySW5kaWNhdG9yQ29udGFpbmVyXFxg5b+F6aG75ZCM5pe25a2Y5ZyoXG4gIC0g5LiA6KGM5LiN5aSf5L2N572u5pi+56S65bCx5o2i6KGM55qE5a655Zmo77yaXFxgaW5saW5lQmxvY2tBbmRXcmFwXFxg77yM6YeM6Z2i5YyF5ZCrTuS4qlxcYGJsb2NrSXRlbVxcYO+8jFxcYGJsb2NrSXRlbVxcYOaYr+Wug+eahOWtkOmhuVxuICAtIOWkmueKtuaAgeWuueWZqO+8muS4gOS4qlxcYG11bHRpU3RhdGVDb250YWluZXJcXGDlpJrnirbmgIHlrrnlmajljIXlkKvlpJrkuKpcXGBvbmVTdGF0ZUNvbnRlbnRDb250YWluZXJcXGBcblxuLSDnu4Tku7bnsbvlnovmnprkuL4gKG5vZGVUeXBlKeaemuS4vu+8mlxuXG4gIC0g5b2i54q277yaXFxgcmVjdFxcYCwgXFxgY2lyY2xlXFxgLCBcXGBsaW5lXFxgXG4gIC0g5Z+656GA57uE5Lu277yaXFxgdGV4dFxcYOOAgVxcYGJ1dHRvblxcYOOAgVxcYGlucHV0XFxg44CBXFxgaWNvblxcYOOAgVxcYGltYWdlXFxgXG4gIC0g5Z+656GA5a655Zmo77yaXFxgY29udGFpbmVyXFxgXG4gIC0g572R5qC85a655Zmo77yaXFxgZ3JpZENvbnRhaW5lclxcYOOAgVxcYGdyaWRJdGVtXFxgXG4gIC0g5rWB5byP5a655Zmo77yaXFxgaW5saW5lQmxvY2tBbmRXcmFwXFxg44CBXFxgYmxvY2tJdGVtXFxgXG4gIC0g5byA5YWz77yaXFxgc3dpdGNoXFxgXG4gIC0g5Y2V6YCJ77yaXFxgcmFkaW9Hcm91cFxcYOOAgVxcYHJhZGlvXFxgXG4gIC0g5aSa6YCJ77yaXFxgY2hlY2tCb3hHcm91cFxcYOOAgVxcYGNoZWNrQm94XFxgXG4gIC0g6aG26YOo5a+86Iiq5qCP77yaXFxgdGl0bGVCYXJcXGDjgIFcXGB0b3BOYXZpZ2F0ZUJhclxcYFxuICAtIOW6lemDqOaTjeS9nOagj++8mlxcYGJvdHRvbU9wZXJhdGVCYXJcXGBcbiAgLSDlpJrnirbmgIHlrrnlmajvvJpcXGBtdWx0aVN0YXRlQ29udGFpbmVyXFxgLCBcXGBvbmVTdGF0ZUNvbnRlbnRDb250YWluZXJcXGBcbiAgLSDliJfooajvvJpcXGB2ZXJ0aWNhbExpc3RWaWV3XFxgLCBcXGBob3Jpem9udGFsTGlzdFZpZXdcXGAsIFxcYGxpc3RJdGVtQ2FyZFxcYOOAgVxcYGxpc3RGb290ZXJDb250YWluZXJcXGBcbiAgLSDova7mkq3vvJpcXGB2aWV3UGFnZXJcXGAsIFxcYHZpZXdQYWdlckl0ZW1cXGAsIFxcYHZpZXdQYWdlckluZGljYXRvckNvbnRhaW5lclxcYFxuICAtIHRhYiDpgInpobnljaHvvJpcXGB0YWJQYW5lbEZhdGhlclxcYCwgXFxgdGFiUGFuZWxcXGAsIFxcYHRhYk1lbnVCYXJcXGAsIFxcYHRhYk1lbnVCYXJJdGVtXFxgXG4gIC0g5bqV6YOo5a+86IiqOiBcXGBib3R0b21UYWJDb250ZW50Q29udGFpbmVyXFxgLCBcXGBzdWJQYWdlXFxgLCBcXGBib3R0b21UYWJOYXZpZ2F0ZUJhclxcYCwgXFxgYm90dG9tVGFiTmF2aWdhdGVCYXJJdGVtXFxgXG4gIC0g5a+56K+d5qGG77yaXFxgZGlhbG9nT3ZlcmxheVxcYCwgXFxgZGlhbG9nQ29udGVudFxcYFxuICAtIHRvYXN0IOaPkOekuu+8mlxcYHRvYXN0XFxgXG4gIC0g5LiL5ouJ6I+c5Y2V77yaXFxgZHJvcERvd25NZW51XFxgXG4gIC0g5L6n5ruR6Z2i5p2/77yaXFxgc2lkZVNsaWRlUGFuZWxcXGBcbiAgLSDmiYvmnLrnoazku7blhYPntKDvvJpcXGBwaG9uZVRvcFN0YXR1c0JhclxcYOOAgVxcYHBob25lQm90dG9tSW5kaWNhdG9yQmFyXFxg77yM6L+Z5Lik5Liq5YWD57Sg5piv5omL5py656Gs5Lu26Ieq5bim55qE5YWD57Sg77yM5LiN6IO95Zyo6aG16Z2i5Lit5re75Yqg44CCXG5cbiMjIOS4ieOAgei9ruaSreS4jlRhYnPnu4Tku7bnmoTop4TliJlcbi0g6L2u5pKt55qE5q+P5LiA5LiqU2xpZGXlkoxUYWJz6YCJ6aG55Y2h57uE5Lu25q+P5LiA5LiqVGFiIFBhbmVs6YO95b+F6aG75L2/55SoXFxgZGlzcGxheTogbm9uZVxcYOWSjFxcYGRpc3BsYXk6IGJsb2NrL2ZsZXhcXGDmnaXlrp7njrDpmpDol4/lkozmmL7npLrnmoTkupLmlqXliIfmjaJcbi0g6L2u5pKt55qE5q+P5LiA5LiqU2xpZGXlv4XpobvmnIlodG1s5Luj56CB5a6e546w77yM5LiN5b6X5Y+q5YaZ56ysMeS4qlNsaWRl55qE5YW35L2T5YaF5a6555qEaHRtbOS7o+egge+8jOWFtuS7llNsaWRl55qE5YW35L2T5YaF5a6555qEaHRtbOS7o+eggeS5n+W/hemhu+imgeWGme+8jOe7neWvueemgeatouaVt+ihjeWcsOS9v+eUqFxcYFBsYWNlaG9sZGVyIGNvbnRlbnQv5b6F5byA5Y+RL+W8gOWPkeS4rS/ljbPlsIbkuIrnur9cXGDnrYnnrYnmnaXmlbfooY3lnLDlsZXnpLrova7mkq3nmoTmr4/kuIDkuKpTbGlkZe+8jOW/hemhu+avj+S4gOS4qlNsaWRl6YO95pyJ5YW35L2T55yf5a6e55qE5YaF5a655bGV56S65a6e546w44CCXG4tIFRhYnPpgInpobnljaHnu4Tku7bpnIDopoHmt7vliqDngrnlh7vliIfmjaJUYWIgUGFuZWznmoTlip/og73vvIzkuI3lvpflj6rlhpnnrKwx5LiqVGFiIFBhbmVs55qEaHRtbOS7o+egge+8jOWFtuS7llRhYiBQYW5lbOeahOWFt+S9k+WGheWuueeahGh0bWzku6PnoIHkuZ/lv4XpobvopoHlhpnvvIznu53lr7nnpoHmraLmlbfooY3lnLDkvb/nlKhcXGBQbGFjZWhvbGRlciBjb250ZW50L+W+heW8gOWPkS/lvIDlj5HkuK0v5Y2z5bCG5LiK57q/XFxg562J562J5p2l5pW36KGN5Zyw5bGV56S6VGFic+mAiemhueWNoee7hOS7tueahOavj+S4gOS4qlRhYiBQYW5lbO+8jOW/hemhu+avj+S4gOS4qlRhYiBQYW5lbOmDveacieWFt+S9k+ecn+WunueahOWGheWuueWxleekuuWunueOsOOAglxuLSDkvovlrZDvvJpcblxcYFxcYFxcYGh0bWxcbjx0YWJQYW5lbEZhdGhlciBub2RlVHlwZT1cInRhYlBhbmVsRmF0aGVyXCIgaWQ9XCJ0YWJQYW5lbEZhdGhlclwiIG5hbWU9XCJUYWJz6YCJ6aG55Y2h5YaF5a655a655ZmoXCI+XG4gIDwhLS0gVGFiIFBhbmVsIDEgLS0+XG4gIDx0YWJQYW5lbCBub2RlVHlwZT1cInRhYlBhbmVsXCIgaWQ9XCJ0YWJQYW5lbDFcIiBuYW1lPVwiVGFic+mAiemhueWNoTFcIj5cbiAgICA8dGV4dCBub2RlVHlwZT1cInRleHRcIiBpZD1cInRhYlBhbmVsMVRleHRcIiBuYW1lPVwiVGFic+mAiemhueWNoTHnmoTmlofmnKxcIj5UYWJz6YCJ6aG55Y2hMeeahOWGheWuuTwvdGV4dD5cbiAgICAuLi5cbiAgICA8ZGl2IG5vZGVUeXBlPVwiZGl2XCIgaWQ9XCJ0YWJQYW5lbDFEaXZcIiBuYW1lPVwiVGFic+mAiemhueWNoTHnmoRkaXblrrnlmahcIj5cbiAgICAgIC4uLlxuICAgIDwvZGl2PlxuICA8L3RhYlBhbmVsPlxuICA8IS0tIFRhYiBQYW5lbCAyIC0tPlxuICA8dGFiUGFuZWwgbm9kZVR5cGU9XCJ0YWJQYW5lbFwiIGlkPVwidGFiUGFuZWwyXCIgbmFtZT1cIlRhYnPpgInpobnljaEyXCI+XG4gICAgPHRleHQgbm9kZVR5cGU9XCJ0ZXh0XCIgaWQ9XCJ0YWJQYW5lbDJUZXh0XCIgbmFtZT1cIlRhYnPpgInpobnljaEy55qE5paH5pysXCI+VGFic+mAiemhueWNoTLnmoTlhoXlrrk8L3RleHQ+XG4gICAgLi4uXG4gICAgPGRpdiBub2RlVHlwZT1cImRpdlwiIGlkPVwidGFiUGFuZWwyRGl2XCIgbmFtZT1cIlRhYnPpgInpobnljaEy55qEZGl25a655ZmoXCI+XG4gICAgICAuLi5cbiAgICA8L2Rpdj5cbiAgPC90YWJQYW5lbD5cbiAgPCEtLSDmm7TlpJpUYWIgUGFuZWzlkozlhbfkvZPlhoXlrrkuLi4gLS0+XG48L3RhYlBhbmVsRmF0aGVyPlxuXFxgXFxgXFxgXG5cbiMjIOWbm+OAgeWIl+ihqOe7hOS7tuinhOWImVxuLSDlpoLmnpzor6XliJfooajnmoTmlbDmja7mmK/ku47nvZHnu5zmjqXlj6Pmi4nlj5bnmoTvvIzpgqPkuYjlv4Xpobvkvb/nlKjlpJrnirbmgIHlrrnlmahcXGBtdWx0aVN0YXRlQ29udGFpbmVyXFxg5bCGbG9hZGluZ+OAgeiBlOe9keWksei0peOAgeayoeacieaVsOaNruOAgeacieaVsOaNrueahOWbm+S4queKtuaAgeS9v+eUqFxcYG9uZVN0YXRlQ29udGVudENvbnRhaW5lclxcYOWMhei1t+adpeW5tuWxleekuuWHuuadpe+8jOWFtuS4reacieaVsOaNrueKtuaAgeeahFxcYG9uZVN0YXRlQ29udGVudENvbnRhaW5lclxcYOWMheWQq+eahOWwseaYr+ivpeWIl+ihqOe7hOS7tuOAglxuLSDlpoLmnpzliJfooajmlbDmja7lj6rmmK/nvZHnu5zogZrlkIjkuJrliqHmjqXlj6PnmoTkuIDpg6jliIbvvIzpgqPkuYjor6XliJfooajkuI3pnIDopoFsb2FkaW5n5ZKM6IGU572R5aSx6LSl54q25oCB77yM5Y+q6ZyA6KaB5pyJ5pWw5o2u54q25oCB5ZKM5rKh5pyJ5pWw5o2u54q25oCB77yM5q+U5aaC6aaW6aG155qE5o6o6I2Q5YiX6KGo44CB5YiG57G75YiX6KGo44CB5pyA5paw5Yqo5oCB5YiX6KGo562J6L+Z5Lqb5piv6aaW6aG15Lia5Yqh6IGa5ZCI5o6l5Y+j6I635Y+W55qE77yM6L+Z5Lqb5YiX6KGo5pWw5o2u5Y+q5piv5Lia5Yqh5o6l5Y+j55qE5LiA6YOo5YiG77yM5LiN5piv54us56uL55qE5o6l5Y+j77yM5omA5Lul5LiN6ZyA6KaBbG9hZGluZ+WSjOiBlOe9keWksei0peeKtuaAgeOAglxuLSDkvovlrZDvvJpcblxcYFxcYFxcYGh0bWxcbjxtdWx0aVN0YXRlQ29udGFpbmVyIG5vZGVUeXBlPVwibXVsdGlTdGF0ZUNvbnRhaW5lclwiIGlkPVwibGlzdE11bHRpU3RhdGVDb250YWluZXJcIiBuYW1lPVwi5YiX6KGo5aSa54q25oCB5a655ZmoXCI+XG48IS0tIOacieaVsOaNrueKtuaAgeeahG9uZVN0YXRlQ29udGVudENvbnRhaW5lciAtLT5cbiAgPG9uZVN0YXRlQ29udGVudENvbnRhaW5lciBub2RlVHlwZT1cIm9uZVN0YXRlQ29udGVudENvbnRhaW5lclwiIGlkPVwiaGFzRGF0YVN0YXRlQ29udGFpbmVyXCIgbmFtZT1cIuacieaVsOaNrueKtuaAgeeahOWuueWZqFwiPlxuICAgIDwhLS0g5YiX6KGo57uE5Lu2IC0tPlxuICAgIDx2ZXJ0aWNhbExpc3RWaWV3IG5vZGVUeXBlPVwidmVydGljYWxMaXN0Vmlld1wiIGlkPVwibGlzdFZpZXdcIiBmcm9tQXBpT3JDYWNoZURhdGE9XCJ0cnVlXCIgbmFtZT1cIuWIl+ihqOe7hOS7tlwiPlxuICAgICAgPCEtLSDliJfooajpobkgLS0+XG4gICAgICA8bGlzdEl0ZW1DYXJkIG5vZGVUeXBlPVwibGlzdEl0ZW1DYXJkXCIgaWQ9XCJsaXN0SXRlbTFcIiBuYW1lPVwi5YiX6KGo6aG5MVwiPlxuICAgICAgICA8IS0tIOWIl+ihqOmhueWGheWuuSAtLT5cbiAgICAgICAgPHRleHQgbm9kZVR5cGU9XCJ0ZXh0XCIgaWQ9XCJsaXN0SXRlbTFUZXh0XCIgbmFtZT1cIuWIl+ihqOmhuTHnmoTmlofmnKxcIj7liJfooajpobkxPC90ZXh0PlxuICAgICAgPC9saXN0SXRlbUNhcmQ+XG4gICAgICA8IS0tIOabtOWkmuWIl+ihqOmhuS4uLiAtLT5cbiAgICA8L3ZlcnRpY2FsTGlzdFZpZXc+XG4gIDwvb25lU3RhdGVDb250ZW50Q29udGFpbmVyPlxuICA8b25lU3RhdGVDb250ZW50Q29udGFpbmVyIG5vZGVUeXBlPVwib25lU3RhdGVDb250ZW50Q29udGFpbmVyXCIgaWQ9XCJub0RhdGFTdGF0ZUNvbnRhaW5lclwiIG5hbWU9XCLmsqHmnInmlbDmja7nirbmgIHnmoTlrrnlmahcIj5cbiAgICA8IS0tIOayoeacieaVsOaNrueKtuaAgeeahOaPkOekuiAtLT5cbiAgPC9vbmVTdGF0ZUNvbnRlbnRDb250YWluZXI+XG4gIDxvbmVTdGF0ZUNvbnRlbnRDb250YWluZXIgbm9kZVR5cGU9XCJvbmVTdGF0ZUNvbnRlbnRDb250YWluZXJcIiBpZD1cImxvYWRpbmdTdGF0ZUNvbnRhaW5lclwiIG5hbWU9XCJsb2FkaW5n54q25oCB55qE5a655ZmoXCI+XG4gICAgPCEtLSBsb2FkaW5n54q25oCB55qE5o+Q56S6IC0tPlxuICA8L29uZVN0YXRlQ29udGVudENvbnRhaW5lcj5cbiAgPG9uZVN0YXRlQ29udGVudENvbnRhaW5lciBub2RlVHlwZT1cIm9uZVN0YXRlQ29udGVudENvbnRhaW5lclwiIGlkPVwibmV0d29ya0Vycm9yU3RhdGVDb250YWluZXJcIiBuYW1lPVwi6IGU572R5aSx6LSl54q25oCB55qE5a655ZmoXCI+XG4gICAgPCEtLSDogZTnvZHlpLHotKXnirbmgIHnmoTmj5DnpLogLS0+XG4gIDwvb25lU3RhdGVDb250ZW50Q29udGFpbmVyPlxuPC9tdWx0aVN0YXRlQ29udGFpbmVyPlxuXFxgXFxgXFxgXG5cbiMjIOS6lOOAgeWbvuagh+S4juWbvueJh+eahOinhOWImVxuLSDlvZPpnIDopoFpY29u5Zu+5qCH5pe25b+F6aG75L2/55SoRm9udEF3ZXNvbWXlm77moIfvvIzmr5TlpoLvvJpcXGA8aSBuYW1lPVwi5b6u5L+hSWNvblwiIHZ0eXBlPVwiaWNvblwiIGlkPVwid3hJY29uXCIgY2xhc3M9XCJmYWIgZmEtd2VpeGluXCI+PC9pPlxcYO+8jOW5tuS4lOazqOaEj+Wbvuagh+eahOminOiJsu+8jOavlOWmguW+ruS/oeWbvuagh+S4gOiIrOS9v+eUqOe7v+iJsuezu++8jFFR5Zu+5qCH5LiA6Iis5L2/55So6JOd6Imy57O777yM5b6u5Y2a5Zu+5qCH5LiA6Iis5L2/55So57qi6Imy57O777yM5pSv5LuY5a6d5Zu+5qCH5LiA6Iis5L2/55So5rWF6JOd6Imy57O7562J562JXG4tIOe7neWvueS4jeiDveS9v+eUqCBlbW9qaSDooajmg4XnrKblj7fvvIzkuI3lvpfkvb/nlKjku7vkvZUgZW1vamkg6KGo5oOF56ym5Y+377yM6K+35L2/55SoRm9udEF3ZXNvbWXlrZfkvZPlm77moIfmnaXku6Pmm7/jgIJcbi0gTE9HT+WbvueJh+WSjOW8leWvvOmhteeahOW8leWvvOWbvueJh+W/hemhu+S9v+eUqFxcYGRvYy9yZXMvc3ZnTWFwLmpzb25cXGDmlofku7bkuK1qc29u5a+56LGh5q2j56Gu5a2X5q6155qEaHR0cHPpk77mjqXlgLzvvIznpoHmraLkvb/nlKjmnKzlnLDlm77niYfot6/lvoRcXGBkb2MvcmVzL2xvZ28uc3ZnXFxg5paH5Lu277yM6ICM5piv5L2/55So57G75Ly877yaXFxgaHR0cHM6Ly9lZGl0b3IuYnl0ZWZ1bmdvLmNvbS9kZmlsZS9pbWcveHh4eHguc3ZnXFxg6L+Z5qC355qE5Zu+54mH6ZO+5o6l5Zyw5Z2A77yM5q+U5aaC6Zeq5bGP6aG144CB55m75b2V6aG144CB5rOo5YaM6aG155So5Yiw55qETE9HT+WbvueJh++8jOW8leWvvOmhteeahOW8leWvvOWbvueJh+etieOAglxuLSBqcGfjgIFqcGVn57G75Z6L5Zu+54mH5b+F6aG75L2/55So5Zu+54mH5Zyw5Z2A77yaXFxgaHR0cHM6Ly9vc3MuYnl0ZWZ1bmdvLmNvbS9mMS9zaG93SW1nMS5qcGdcXGAp77yM5YW25Lit57uT5bC+55qE4oCZc2hvd0ltZzEn5Y+v5Lul5o2i5Li65LuOIDEg5YiwIDMwIOeahOaVsOWtl++8jDF+MzAg55qE5pWw5a2X5b+F6aG76ZqP5py65oyR6YCJ77yM5LiN5b6X5q+P5Liq6aG16Z2i5q+P5Liq5Zu+54mH6YO95L2/55So5ZCM5LiA5Liq5pWw5a2X44CC5YaZ5rOV5q+U5aaC77yaXFxgPGltZyBzcmM9XCJodHRwczovL29zcy5ieXRlZnVuZ28uY29tL2YxL3Nob3dJbWcxNy5qcGdcIiBhbHQ9XCJ4eHhcIiBjbGFzcz1cInh4eFwiIG5vZGVUeXBlPVwiaW1hZ2VcIj5cXGBcblxuIyMg5YWt44CB5b+F6aG755CG6Kej5bm26YG15a6I5Lul5LiL56aB5q2i55qE5aSa5LiqVUnorr7orqHku6PnoIHlhpnms5Vcbi0g56aB5q2i5L2/55So5Lu75L2V5YmN56uv5qGG5p6277yM5Y+q5L2/55SoIGh0bWwr57G76YCJ5oup5Zmo5qC35byPK2pzIOadpeWunueOsOOAglxuLSDnpoHmraLkvb/nlKhqc+S7o+eggeadpeaLvOaOpWh0bWzlrZfnrKbkuLLvvIzlv4XpobvlnKhib2R55qCH562+6YeM6Z2i55u05o6l5YaZaHRtbOS7o+eggeOAglxuLSDnpoHmraLkvb/nlKhqc+S7o+eggeadpeWjsOaYjuS7u+S9lemhtemdouaYvuekuuaJgOmcgOeahOaVsOaNru+8jOaJgOacieaVsOaNrumDveW/hemhu+WcqGh0bWzku6PnoIHkuK3nm7TmjqXlhpnmrbvjgIJcbi0g56aB5q2i5L2/55So5paH5pys5riQ5Y+Y6Imy77yM5b+F6aG75L2/55So57qv6Imy5paH5pys77yM5Lmf5bCx5piv56aB5q2i5L2/55SoXFxgLXdlYmtpdC10ZXh0LWZpbGwtY29sb3JcXGDlsZ7mgKfjgIJcbi0g56aB5q2i57uZ6aG16Z2i5re75YqgXFxg5omL5py66aG26YOo54q25oCB5qCPXFxg44CBXFxg5omL5py65bqV6YOo5oyH56S65Zmo5qCPXFxg5Lik5Liq6Z2e6aG16Z2i5YaF5a6555qE5YWD57Sg6IqC54K577yM6L+Z5piv5omL5py656Gs5Lu26Ieq5bim55qE5YWD57Sg77yM5LiN6IO95Zyo6aG16Z2i5Lit5re75Yqg44CCXG4tIOemgeatouS9v+eUqFxcYDpiZWZvcmVcXGDjgIFcXGA6YWZ0ZXJcXGDkvKrlhYPntKDvvIzlv4Xpobvkvb/nlKjlhbbku5bmoIfnrb7mnaXlrp7njrDjgIJcbi0g56aB5q2i5L2/55SoXFxgYmFja2Ryb3AtZmlsdGVyXFxg562J546755KD5pWI5p6c77yM5b+F6aG75Yig6Zmk5o6J5omA5pyJ5L2/55So5Yiw546755KD5pWI5p6c55qE5Luj56CB44CCXG4tIOemgeatouS9v+eUqOWkmuS4qnDmoIfnrb7miJblpJrkuKrlhbbku5bmoIfnrb7mnaXmmL7npLrkuIDkuKrku47nvZHnu5zmiJblhbbku5blnLDmlrnmi4nlj5blm57mnaXnmoTplb/mlofmnKzvvIzlv4Xpobvlj6rog73kvb/nlKjkuIDkuKrmoIfnrb7mnaXmmL7npLrvvIzmr5TlpoLvvJpkaXbjgIFzcGFu562J77yM5Zug5Li6572R57uc5ouJ5Y+W5Zue5p2l55qE6ZW/5paH5pys5piv5LiA5Liq5paH5pys77yM5peg5rOV5L2/55So5aSa5Liq5qCH562+5p2l5pi+56S65LiA5Liq5paH5pys77yM5b+F6aG75Y+q6IO95L2/55So5LiA5Liq5qCH562+5p2l5pi+56S644CCXG4tIGxvYWRpbmfoioLngrnnmoTlrp7njrDnpoHmraLkvb/nlKhkaXbmoIfnrb7kuI7ovrnmoYblsZ7mgKflrp7njrDvvIzlv4Xpobvkvb/nlKjlm77moIdpY29u55qEaeagh+etvuadpeWunueOsGxvYWRpbmfnmoToioLngrlcbi0g56aB5q2i5Li6aHRtbOagh+etvuiKgueCuea3u+WKoOWKqOeUu+aIlui/h+a4oeaViOaenO+8jOmhtemdouiuvuiuoeS4jemcgOimgeS7u+S9leWKqOeUu+WSjOi/h+a4oeaViOaenO+8jOavlOWmguemgeatou+8mkBrZXlmcmFtZXPjgIF0cmFuc2l0aW9u44CBYW5pbWF0aW9uIOetieOAglxuLSDmjInpkq7jgIHljaHniYfjgIFpdGVt6aG5562J5YWD57Sg5b+F6aG76KaB5pyJaG92ZXLkuI7ngrnlh7vlj43ppojvvIzngrnlh7vlj43ppojlv4Xpobvkvb/nlKjmtYXoibLnmoTog4zmma/oibJiYWNrZ3JvdW5k5p2l5Y+N6aaI5bCx6KGM77yM5Lil56aB5L2/55SodHJhbnNmb3Jt5pWI5p6cXG4gICAgLSDinYwg6ZSZ6K+v55qE55So5rOV77yaIFxuICAgIFxcYFxcYFxcYCBjc3NcbiAgICAuaG90LXNhbGVzLWl0ZW06aG92ZXIge1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLi4ucHgpO1xuICAgIH1cbiAgICBcXGBcXGBcXGBcbiAgICAtIOKchSDmraPnoa7nmoTnlKjms5XvvJpcbiAgICBcXGBcXGBcXGAgY3NzXG4gICAgLmhvdC1zYWxlcy1pdGVtOmhvdmVyIHtcbiAgICAgICAgYmFja2dyb3VuZDogLi4uO1xuICAgIH1cbiAgICBcXGBcXGBcXGBcbi0g56aB5q2i5L2/55SoZGl25qCH562+5p2l5a6e546waW1hZ2Xlm77niYfvvIzlv4XpobvopoHkvb/nlKhpbWfmoIfnrb7mnaXlrp7njrDlm77niYfoioLngrnvvIxpbWfmoIfnrb7nmoRzcmPlsZ7mgKflv4Xpobvorr7nva7kuLrvvJpcXGBodHRwczovL29zcy5ieXRlZnVuZ28uY29tL2YxL3Nob3dJbWcxLmpwZ1xcYO+8jOWFtuS4remHjOmdoueahFxcYHNob3dJbWcxXFxg5Y+v5Lul5pS55Li6MX4zMOeahOS7u+aEj+S4gOS4quaVsOWtl++8jOavlOWmgu+8mlxcYHNob3dJbWc1XFxg44CCXG4gIC0g4p2M6ZSZ6K+v55qE5YaZ5rOV77yaXG4gICAgXFxgXFxgXFxgIGh0bWxcbiAgICA8ZGl2IGNsYXNzPVwiYmVzdHNlbGxlci1jb3ZlclwiIGlkPVwiYmVzdHNlbGxlckNvdmVyMVwiIG5hbWU9XCLnlYXplIDkuabnsY3lsIHpnaIxXCIgbm9kZVR5cGU9XCJpbWFnZVwiPlxuICAgIDwvZGl2PlxuICAgIFxcYFxcYFxcYFxuICAtIOKchSDmraPnoa7nmoTlhpnms5XvvJpcbiAgICBcXGBcXGBcXGAgaHRtbFxuICAgIDxpbWcgY2xhc3M9XCJiZXN0c2VsbGVyLWNvdmVyXCIgaWQ9XCJiZXN0c2VsbGVyQ292ZXIxXCIgbmFtZT1cIueVhemUgOS5puexjeWwgemdojFcIiBub2RlVHlwZT1cImltYWdlXCIgc3JjPVwiaHR0cHM6Ly9vc3MuYnl0ZWZ1bmdvLmNvbS9mMS9zaG93SW1nNy5qcGdcIj4gIFxuICAgIFxcYFxcYFxcYFxuLSDnpoHmraIgaWQg5bGe5oCn5LiN6KeE6IyD77yMaWQg5b+F6aG75ZSv5LiA77yM5LiU5Y+q6IO955Sx5a2X5q+N5ZKM5pWw5a2X57uE5oiQ77yI5LiN6IO95Lul5pWw5a2X5byA5aS077yJ77yM5bu66K6u5L2/55So6am85bOw5ZG95ZCN44CCXG4tIOemgeatouS9v+eUqOihjOWGhSBzdHlsZSDlsZ7mgKfvvIzlv4XpobvpgJrov4cgY2xhc3Mg5ZKMIENTUyDmlofku7bmnaXlrprkuYnmoLflvI/jgIJcbi0g56aB5q2iIHJhZGlhbC1ncmFkaWVudCDmoLflvI/kuI3op4TojIPvvIzlvoTlkJHmuJDlj5jlv4XpobvmmL7lvI/lo7DmmI7kuLogY2lyY2xl77yM5LiU5LiA5LiqIERPTSDoioLngrnlj6rog73ljIXlkKvkuIDkuKogcmFkaWFsLWdyYWRpZW5044CCXG5cbiMjIOS4g+OAgemmlumhteS4u+S9k+mhteS4juWtkOmhtemdoueahOinhOWImVxuLSDpppbpobXkuLvkvZPpobXltYzlpZfkuoblpJrkuKrlrZDpobXpnaLvvIzmr4/kuIDkuKrlrZDpobXpnaLpg73kuI3pnIDopoHloavlhYXlhoXlrrnvvIznqbrnmb3lsLHooYzvvIzlkI7pnaLkvJrmnInkuJPpl6jnmoTku7vliqHmnaXorr7orqHlhbfkvZPnmoTlrZDpobXpnaLjgIJcbi0g5Lu75L2V5a2Q6aG16Z2i6YO95b+F6aG756aB5q2i5re75Yqg5bqV6YOo5a+86Iiq5qCP6IqC54K55Yiw6aG16Z2i77yM5Zug5Li65a2Q6aG16Z2i5piv5bWM5aWX5Zyo6aaW6aG15Li75L2T6aG15Lit55qE77yM54i26aG16Z2i5bey57uP5pyJ5bqV6YOo5a+86Iiq5qCP5LqG77yM5a2Q6aG16Z2i5LiN6ZyA6KaB5YaN5re75Yqg5bqV6YOo5a+86Iiq5qCP77yM5Lmf5LiN5b6X5re75Yqg5LqM57qn6aG16Z2i55qE5qCH6aKY5qCP5Yiw5a2Q6aG16Z2i5Lit77yM5Zug5Li65a2Q6aG16Z2i5piv5bWM5aWX5Zyo6aaW6aG15Li75L2T6aG15Lit55qE77yM6aaW6aG15Li75L2T6aG15ZKM5a6D55qE5a2Q6aG16Z2i6YO95piv5LiA57qn6aG16Z2i77yM5Zug5q2k5LiN5b6X5re75Yqg5LqM57qn6aG16Z2i55qE5qCH6aKY5qCP5Yiw5a2Q6aG16Z2i5Lit44CCXG5cbiMjIOWFq+OAgeWmguaenOeUqOaIt+ayoeacieaYjuehruivtOaYjuivpemhtemdouiuvuiuoemcgOaxgu+8jOmCo+WwseaMieeFp+S7peS4i+mhtemdoum7mOiupOinhOWImeiuvuiuoVxuLSDpl6rlsY/pobXvvJrnpoHmraLkvb/nlKjlhajlsY/lm77niYfvvIzkuIDoiKzkvb/nlKjkuLvpopjnm7jlhbPnmoTmuJDlj5joibLvvIznhLblkI7luKbmnInkuIDkupvpop3lpJbnmoTog4zmma/lhYPntKDlop7lvLrnlYzpnaLlsYLmrKHmhJ/vvIzmr5TlpoLvvJrmoqblubvlnIblnIjms6Hms6HjgIHnjrvnkoPmlYjmnpznmoTlnIblvaLlvoTlkJHmuJDlj5jnrYnnrYnlhYPntKBcbi0g5byV5a+86aG177ya5bC96YeP5LiN5L2/55So5YWo5bGP5Zu+54mH77yM5LiA6Iis5q+P5LiA6aG15byV5a+86aG16IOM5pmv6Imy5Lmf5Y+v5Lul5riQ5Y+Y77yM54S25ZCO5q+P5LiA6aG15Yqf6IO96K+05piO5LiA6Iis5pyJ6Z2e5YWo5bGP5Zu+54mH44CB5qCH6aKY44CB5Ymv5qCH6aKY562J562J77yM5L2g5Y+v5Lul5bim5YWl5YW25LuW5YWD57Sg77yM6K6p6aG16Z2i5pu05Yqg576O6KeC77yM5bm25LiU5byV5a+86aG155qE5byV5a+85Zu+54mH6ZyA6KaB6Ieq5bex57uY5Yi2c3Zn5Zu+54mH77yM5bm25a2Y5pS+5ZyoXFxgZG9jL3Jlc1xcYOaWh+S7tuWkueS4i+mdou+8jOW5tuWcqGh0bWzkuK3kvb/nlKhcbi0g6IOM5pmv6Imy5Li65LqG5aKe5by65bGC5qyh5oSf77yM5re75Yqg55qE5qKm5bm75rOh5rOh5oiW6ICF5ZyG5b2i5b6E5ZCR5riQ5Y+Y5YWD57Sg55qEZGl277yM5b+F6aG75Y+q6IO95aOw5piO5Li6XFxgY2lyY2xlXFxg77yM5bm25LiU5LiA5LiqZGl255qEXFxgYmFja2dyb3VuZDpcXGDlj6rog73lo7DmmI7kuIDkuKpcXGByYWRpYWwtZ3JhZGllbnRcXGDvvIzmr5TlpoLmraPnoa7nmoTlhpnms5XvvJpiYWNrZ3JvdW5kOiByYWRpYWwtZ3JhZGllbnQoY2lyY2xlLCByZ2JhKDAsIDIyOSwgMjU1LCAwLjE1KSAwJSwgcmdiYSgwLCAwLCAwLCAwKSA3MCUpO++8jOWmguaenOmcgOimgeWkmuS4qlxcYHJhZGlhbC1ncmFkaWVudFxcYOW+hOWQkea4kOWPmOiDjOaZr++8jOavj+S4quW+hOWQkea4kOWPmOiDjOaZr+mDveW/hemhu+WjsOaYjuS4uuS4gOS4qmRpduiKgueCue+8jOavj+S4qmRpdueahFxcYGJhY2tncm91bmQ6XFxg5Y+q6IO95aOw5piO5LiA5LiqXFxgcmFkaWFsLWdyYWRpZW50XFxg44CCXG5gIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bytefun-ai-mcp",
3
- "version": "1.14.43",
3
+ "version": "1.14.45",
4
4
  "description": "ByteFun AI MCP服务 - 打通产品设计、UI设计、代码开发的服务平台,支持设计稿转代码和跨平台原生代码开发",
5
5
  "main": "build/index.js",
6
6
  "type": "module",