{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib as mpl\n",
    "\n",
    "from sklearn.cluster import KMeans \n",
    "from sklearn.cluster import SpectralClustering\n",
    "from sklearn.cluster import AgglomerativeClustering\n",
    "from pathlib import Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "sys.path.append('../../src')\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from base_exp_gen import generate_experiment as GEN_EXP\n",
    "from clustering_algos import agglomerative_clustering, kmeans_clustering, box_clustering, optimal_clustering\n",
    "from sklearn.model_selection import train_test_split as datasplit\n",
    "from sklearn.ensemble import GradientBoostingRegressor as GDBR\n",
    "from evaluations import computeATT_per_cluster as ATTC, predict_cf, calculate_ite, get_homogeneity, generate_paths\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set random seed for consistency across runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(seed = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set parameters for plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "fonts = {'family': 'cmr10','weight': 'normal',\n",
    "            'size': 20}    \n",
    "div = 1\n",
    "\n",
    "l1 = 22/div\n",
    "l2 = 20/div\n",
    "l3 = 13/(div-0.2)\n",
    "\n",
    "mpl.rcParams['xtick.labelsize'] = l2\n",
    "mpl.rcParams['ytick.labelsize'] = l2\n",
    "mpl.rcParams['axes.labelsize'] = l1\n",
    "mpl.rcParams['font.serif'] = 'Times New Roman'\n",
    "mpl.rcParams['font.weight'] = 'normal'\n",
    "mpl.rcParams['font.size'] = 20\n",
    "mpl.rcParams['legend.fontsize'] = l3"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pandas parameters for dataframe display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option(\"display.max_columns\", None)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Directory to save figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 444 µs, sys: 379 µs, total: 823 µs\n",
      "Wall time: 12.2 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "path_figs = './figs/2M/'\n",
    "save = True\n",
    "Path(path_figs).mkdir(exist_ok = True, parents = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Generate Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of Clusters:1369, Number of Points:2000000\n"
     ]
    }
   ],
   "source": [
    "N,D = 2*10**6, 2\n",
    "x = int((N)**(1/4))\n",
    "clusters = x**2\n",
    "print(\"Number of Clusters:{}, Number of Points:{}\".format(clusters, N))\n",
    "kw_generate =  {'N':N, 'D':D,'f_gen_name': 'uniform_gen','low':0, 'high': 1}\n",
    "centers = [[0.5,0.5],[0.5,0.5]]\n",
    "r_small = [0, 0.325735]\n",
    "r_big = [0.325735,0.46065886]\n",
    "eligibilities = [2,1]\n",
    "kw_cluster =  {'f_class_name':'circle_class4', 'centers': centers,\n",
    "               'eligibilities':eligibilities,'r_small': r_small, 'r_big':r_big}\n",
    "kw_treatment = {'f_treat_name' :'uniform_treat','choices':[0,1], 'probabilities':[0.5,0.5]}\n",
    "\n",
    "std = 5\n",
    "stats = np.array([[1, std], [0, std], [0, std], [1, std],[1, std],\n",
    "                  [2, std]])\n",
    "kw_outcome = {'f_outcome_name': 'outcome1','treatment':'Treatment', 'cls':'C', 'stats':stats}\n",
    "\n",
    "data = GEN_EXP(kw_generate, kw_cluster, kw_treatment, kw_outcome).dat\n",
    "data = calculate_ite(data.copy(), treatment = 'Treatment',\n",
    "                     counterfactual = 'Ycf', outcome = 'Y', ite_name = 'ITE')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot generated experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.scatter(data['x0'].values, data['x1'].values, c=data['C'].values, cmap = 'Greys', s=0.1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path_figs+'data.jpeg',bbox_inches='tight', pad_inches = 0)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/statsmodels/compat/pandas.py:49: FutureWarning: The Panel class is removed from pandas. Accessing it from the top-level namespace will also be removed in the next version\n",
      "  data_klasses = (pandas.Series, pandas.DataFrame, pandas.Panel)\n"
     ]
    }
   ],
   "source": [
    "from econml.metalearners import XLearner as XL\n",
    "from sklearn.ensemble import RandomForestClassifier as RF"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " ### Estimate ITE with Gradient Boosting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 1h 7min 5s, sys: 2.14 s, total: 1h 7min 7s\n",
      "Wall time: 1h 7min 8s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "f1_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "f2_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "\n",
    "data, models = predict_cf(data.copy(), col_select = ['x0', 'x1'], f1 = GDBR,\n",
    "                          f2 = GDBR, cf_name = 'Ycf-GDBR', f1_kwargs=f1_kwargs, \n",
    "                          f2_kwargs=f2_kwargs, ite_name ='ITE-GDBR')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model performance (GDBR) Train and Test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Y</th>\n",
       "      <th>Ycf</th>\n",
       "      <th>Ycf-GDBR</th>\n",
       "      <th>ITE</th>\n",
       "      <th>ITE-GDBR</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Treatment</th>\n",
       "      <th>C</th>\n",
       "      <th>IS_TEST</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">0</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0</th>\n",
       "      <th>0</th>\n",
       "      <td>0.981341</td>\n",
       "      <td>1.008926</td>\n",
       "      <td>0.993484</td>\n",
       "      <td>0.027585</td>\n",
       "      <td>0.012143</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.044385</td>\n",
       "      <td>1.036434</td>\n",
       "      <td>0.987491</td>\n",
       "      <td>-0.007950</td>\n",
       "      <td>-0.056894</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">1</th>\n",
       "      <th>0</th>\n",
       "      <td>0.004829</td>\n",
       "      <td>1.008538</td>\n",
       "      <td>1.028823</td>\n",
       "      <td>1.003709</td>\n",
       "      <td>1.023994</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.006390</td>\n",
       "      <td>1.007373</td>\n",
       "      <td>1.028903</td>\n",
       "      <td>1.000982</td>\n",
       "      <td>1.022512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">2</th>\n",
       "      <th>0</th>\n",
       "      <td>-0.007826</td>\n",
       "      <td>2.000617</td>\n",
       "      <td>1.981560</td>\n",
       "      <td>2.008443</td>\n",
       "      <td>1.989386</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-0.001260</td>\n",
       "      <td>2.026991</td>\n",
       "      <td>1.983800</td>\n",
       "      <td>2.028251</td>\n",
       "      <td>1.985060</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0</th>\n",
       "      <th>0</th>\n",
       "      <td>0.989184</td>\n",
       "      <td>0.997210</td>\n",
       "      <td>0.943759</td>\n",
       "      <td>-0.008025</td>\n",
       "      <td>0.045426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.010891</td>\n",
       "      <td>1.033520</td>\n",
       "      <td>0.943119</td>\n",
       "      <td>-0.022630</td>\n",
       "      <td>0.067772</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">1</th>\n",
       "      <th>0</th>\n",
       "      <td>1.003812</td>\n",
       "      <td>0.003512</td>\n",
       "      <td>0.044573</td>\n",
       "      <td>1.000300</td>\n",
       "      <td>0.959239</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.994443</td>\n",
       "      <td>0.007608</td>\n",
       "      <td>0.040794</td>\n",
       "      <td>0.986834</td>\n",
       "      <td>0.953649</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">2</th>\n",
       "      <th>0</th>\n",
       "      <td>2.010384</td>\n",
       "      <td>0.001865</td>\n",
       "      <td>-0.011194</td>\n",
       "      <td>2.008519</td>\n",
       "      <td>2.021577</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.988376</td>\n",
       "      <td>0.042260</td>\n",
       "      <td>-0.013048</td>\n",
       "      <td>1.946116</td>\n",
       "      <td>2.001424</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                            Y       Ycf  Ycf-GDBR       ITE  ITE-GDBR\n",
       "Treatment C IS_TEST                                                  \n",
       "0         0 0        0.981341  1.008926  0.993484  0.027585  0.012143\n",
       "            1        1.044385  1.036434  0.987491 -0.007950 -0.056894\n",
       "          1 0        0.004829  1.008538  1.028823  1.003709  1.023994\n",
       "            1        0.006390  1.007373  1.028903  1.000982  1.022512\n",
       "          2 0       -0.007826  2.000617  1.981560  2.008443  1.989386\n",
       "            1       -0.001260  2.026991  1.983800  2.028251  1.985060\n",
       "1         0 0        0.989184  0.997210  0.943759 -0.008025  0.045426\n",
       "            1        1.010891  1.033520  0.943119 -0.022630  0.067772\n",
       "          1 0        1.003812  0.003512  0.044573  1.000300  0.959239\n",
       "            1        0.994443  0.007608  0.040794  0.986834  0.953649\n",
       "          2 0        2.010384  0.001865 -0.011194  2.008519  2.021577\n",
       "            1        1.988376  0.042260 -0.013048  1.946116  2.001424"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filt = (data['Treatment'] == 1) & (data['C'] == 1) & (data['IS_TEST'] ==0)\n",
    "data.groupby(['Treatment', 'C', 'IS_TEST'])[['Y', 'Ycf', 'Ycf-GDBR','ITE', 'ITE-GDBR']].mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Apply clustering Box and Kmeans"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 20h 16min 29s, sys: 1h 39min 47s, total: 21h 56min 16s\n",
      "Wall time: 1h 52min 22s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "col_select = ['x0', 'x1']\n",
    "data,_ = box_clustering(data.copy(), clusters = clusters, col_select = col_select )\n",
    "data,_ = kmeans_clustering(data.copy(), clusters = clusters, col_select = col_select )\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ATT per Cluster with Estimated Counterfactual from GDBR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "ite_name = 'ITE-GDBR'\n",
    "box2 = ATTC(data.copy(), cluster_name = 'Box-Cluster', ATT_CLUST_name='Box-ATT',\n",
    "           points_name='Box-points', weight_names='Box-Weights', ITE_name = ite_name,\n",
    "            hom_name = 'Box-Hom', att = False)\n",
    "\n",
    "kmeans2 = ATTC(data.copy(), cluster_name = 'Kmeans-Cluster', ATT_CLUST_name='Kmeans-ATT',\n",
    "           points_name='Kmeans-points', weight_names='Kmeans-Weights',ITE_name = ite_name,\n",
    "               hom_name = 'Kmeans-Hom', att = False)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Appendix B. Histograms (column: BOX, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path2 = path_figs+'histograms/'\n",
    "Path(path2).mkdir(exist_ok = True)\n",
    "\n",
    "\n",
    "kde = False\n",
    "bins = 20\n",
    "fig, ax = plt.subplots(1,1)\n",
    "ax = sns.distplot(box2['Box-ATT'],bins = bins, kde = kde,ax = ax )\n",
    "ax.set_xlabel('ATE')\n",
    "#ax.set_ylabel('weight')\n",
    "#ax.set_xlim(-0.5,2.5)\n",
    "if save:\n",
    "    fig.savefig(path2+'Box2hist.pdf', bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Appendix B. Histograms (column: KMEANS, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1)\n",
    "ax = sns.distplot(kmeans2['Kmeans-ATT'], \n",
    "             bins = bins, kde = kde, ax = ax)\n",
    "ax.set_xlabel('ATE')\n",
    "#ax.set_ylabel('weight')\n",
    "#ax.set_xlim(-1,2.5)\n",
    "if save:\n",
    "\n",
    "    fig.savefig(path2+'KM2hist.pdf', bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Appendix A.2 ITE Histograms (column:ITE, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1)\n",
    "bins = 400\n",
    "ax = sns.distplot(data['ITE-GDBR'],bins = bins, kde = kde, ax = ax)\n",
    "\n",
    "ax.set_xlabel('ITE')\n",
    "#ax.set_ylabel('weight')\n",
    "ax.set_xlim(-15,15)\n",
    "if save:\n",
    "\n",
    "    fig.savefig(path2+'ITE2hist.pdf', bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Optimal 3-Clustering\n",
    "#### Cluster the ATTs for the 2 methods \n",
    "1. Box with estimated Ites\n",
    "2. Kmeans with estimated Ites"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Did not pick 3, it picked: 0\n",
      "CPU times: user 1.06 s, sys: 146 ms, total: 1.2 s\n",
      "Wall time: 1.77 s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "all_data = [box2, kmeans2]\n",
    "\n",
    "\n",
    "names_to_give = ['Box2-Cl2', 'Kmeans2-Cl2']\n",
    "names_to_find= ['Box-ATT', 'Kmeans-ATT']\n",
    "\n",
    "weights = ['Box-Weights', 'Kmeans-Weights']\n",
    "\n",
    "clusts = 3\n",
    "for i, (dd, name, name2,w) in enumerate(zip(all_data, names_to_give, names_to_find,weights)):\n",
    "    all_data[i], _ = optimal_clustering(dd, max_clusters = clusts, col_select = name2, \n",
    "                      cluster_name = name, N=N )\n",
    "    \n",
    "\n",
    "data2 = data.copy()\n",
    "data2.head(2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Bayes Optimal 3 Clustering in the ITEs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "cluster_name2 = 'ITE-2CGDBR'\n",
    "col2 = 'ITE-GDBR'\n",
    "filt12 = data2[col2] <= 0.5\n",
    "filt22 = data2[col2] >= 0.5\n",
    "filt32 = data2[col2] >= 1.5\n",
    "\n",
    "data2[cluster_name2] = 0\n",
    "data2.loc[filt12,cluster_name2] = 0\n",
    "data2.loc[filt22, cluster_name2] = 1\n",
    "data2.loc[filt32, cluster_name2] = 2\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Merge 3 Clustering with initial data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "merge_names = ['Box-Cluster', 'Kmeans-Cluster']\n",
    "class_names = ['Box2-Cl2', 'Kmeans2-Cl2']\n",
    "\n",
    "for dd, merge_name, class_name in zip(all_data, merge_names, class_names):\n",
    "    dd2 = dd[[merge_name, class_name]]\n",
    "\n",
    "\n",
    "    data2 = data2.merge(dd2, on = merge_name, how = 'left' )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  Appendix B. Reconstruction (column: BOX, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 1min 37s, sys: 2.71 s, total: 1min 40s\n",
      "Wall time: 1min 37s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "class_names2 = ['Box2-Cl2', 'Kmeans2-Cl2', 'ITE-2CGDBR']\n",
    "\n",
    "#path to save\n",
    "name = class_names2[0]\n",
    "path3 = path_figs+'reconstruction/'\n",
    "\n",
    "\n",
    "Path(path3).mkdir(exist_ok = True, parents = True)\n",
    "fig, ax = plt.subplots()\n",
    "sc = ax.scatter(data2['x0'].values, data2['x1'].values, c=data2[name].values, cmap = 'Greys', s = 1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path3+'{}.jpeg'.format(name), bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  Appendix B. Reconstruction (column: KMEANS, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAASEAAAEBCAYAAAA3sRMtAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nO2deXiU1dn/P/csWchCFhKCSVgCSABBlrCJylaQqrxgxe3nj4rWWqv+bK3bW2sX+7ZaL33V6mtbaa0WF3wVq+CCIoqyKEsQuMKWsIVAwhISsm+TmfP7YxazkslkZp5Jcj7XletJnuXcZ/LMfOd+zjn3fYtSCo1GozEKk9Ed0Gg0vRstQhqNxlC0CGk0GkPRIqTRaAxFi5BGozEUi9EdCCb9+vVTgwcPNrobGk2PZceOHWeVUkmduaZXidDgwYPJzs42uhsaTY9FRI519hr9OKbRaAxFi5BGozEULUIajcZQvBYhEVksIi+IyEYRqRARJSKv+2JURNJE5J8iUiQi9SKSLyLPiUj8ea4ZJSJvi8gZEakTkVwReUxEIn3pg0ajCQ06MzD9KHAxUAWcADJ9MSgiQ4GvgWRgFXAAmAz8DJgvItOVUiUtrpkCfAFYgZXAcWA28BtgjojMUUrV+9IfjUZjLJ15HLsPuBCIBX7aBZt/wSlA9yqlFiml/lMpNRt4FhgB/LHpySJiBl4B+gCLlVL/Ryn1MDAFeBeY7uqbRqPphngtQkqp9Uqpg6oLYfcikgHMA/KBF1sc/i1QDSwRkagm+2cAI4ENSqnVTfrjAB5y/XmniIiv/dJoNMYR7IHp2a7tWpeIeFBKVQKbcXo8U9u45pOWjSmljgB5wCAgw++91Wg0ASfYIjTCtc1r5/hB1/bCLl6j0Wi6CcEWob6ubXk7x93747p4jQcRuUNEskUku7i42OuOajSa4BBq64Tc4zqdGXc67zVKqWVKqSylVFZSUqdCWjQaTRAItgi5vZa+7RyPbXGer9doNJpuQrBFKNe1bW/8Zrhr23T8x5drNBpNNyHYIrTetZ0nIs1si0gMzjU/tcCWJoe+cG3nt2zMNeV/IXAMOOL33mo0moATEBESEauIZLpWR3tQSh0G1gKDgbtbXPYYEAUsV0pVN9n/FbAfuFxE/qOJDRPwpOvPv3Vl/ZImOLhvkb5VmqZ4HbYhIouARa4/U1zbaSLyquv3s0qpB1y/p+IUjmM4Bacpd+EM23heROa4zpsCzML5SPWrpicrpewicitOj2iliKwECoA5QBbOtUXPevs6NMbgcDjIzc1l+PDh2O12wsLC0OtLNdA5T2gccIvr5wrXvowm+xZ704jLG8oCXsUpPvcDQ4HngWkt48Zc12wFJuGMNZuHM0yjL/B7YK6OGwttlFKYTCY2bNjAsmXLqKurayVASim2bt1KaWmpQb3UGIX0Jtc4KytL6cyK/kMpxbZt24iOjiYzM5PGxkYsFgtms7nZeYWFhWzevJmzZ88CMGDAABYuXAiAyWRiy5YtHDx4kMrKSgCWLl2K1WrFbDYjIuf1mJo+4n3yySdYLBbmzZvX7PjOnTsZP368px2bzUZVVRUlJSX069ePuLg2l5hpfEBEdiilsjpzTa9K76rxLw6Hgx07dnDRRRdhNpv58MMPcTgcLFq0yPOBr6+vZ+/evR4BAjh58iTr1q1j3rx5VFZWkpOTg81m8xzft28fANXV1TgcDgYOHMjQoUM9Nk0mk2erlOLNN9+kvr4em81GWFgYNpsNq9VKbm4uO3fupH///ogISikcDgf/+7//S0VFBQDR0dHccMMNhIeHB+vfpmmB9oQ0PrFv3z42btyI3W4H8AgDwOzZs4mLi2PVqlXccsst5Ofn88UXX7RqIzMzk2PHjlFbW9uhveTkZEaOHElhYSGRkZGUl5dTXl6OzWajpqbGc57VasVutxMdHe0RGrPZTFZWFhMnTuT48eN88MEHzdqOi4vjxhtvxGQKtbW73Q9fPCEtQhqfeOedd/AmDGbgwIEUFhZ6xMpI+vbtS3V1NY2NjZ590dHRpKWlMXPmTC1CfsAXEdL/dY1PLFiwgIiIiA7PKygoCAkBAigvL28mQAB1dXVceumlXguQUkovMfAzWoQ07XK+D1tERARXXXUVqampQeyR/2lsbGTFihXNXmtT0Wy6Py8vj61bt2oh8jNahDQe7HY7H374IWvWrGH//v0UFBSc9/z+/fuzcOHCbr/ep6amhrNnz3oG2l999VWOHz+Ow+FARNi3bx91dXVs2LCBb7/9ls8//5ySkhLPGJima+gxIQ0Ahw8f5tNPP22132KxcNNNNxETE9PqWHV1NR988EGPWduzaNEi3n//fc/fffr0IS4ujqKiolbnDhs2jJkzZxIWFuaZqaurq/PqEbUno6foNT5jsbT9VmhsbGTlypXcfPPNmM1mzGYzSilEhCNHjvQYAQJYtWpVs79ramqazbw15dChQ5SXlzN+/Hh27txJRUUFIsLcuXNJT08PRnd7DNoT6mVUVVVhMpno06dPq/3Lly9v9zqTyYTVamXixIkUFBTQp08fDh06pB9JWpCYmMiiRYs86456m3ekPSFNu1RVVXHw4EEOHDhAdHQ0CxYsoKamhoiICEwmEyUlraJlmuFwOKivr+frr78OUo+7JyUlJWzevJlJkybRp08fNmzYQF1dHVdeeWW73mZvR/9XegmnTp3im2++Ab4TpM8++4z09HRSU1PZvn27wT3sORw4cICioiJmzZrF4cOHUUrxzjvvcNNNNxndtZBEi1APpr6+nvDwcOx2O2lpaZ79NpuNzz77DIDjx49z/Phxo7rYY6moqGg2xhQb60wA6h5P03yHFqEeiju4dOrUqfzrX/9qFVSqCS4tF0lqvkOLUA/D/U0rIpSVlfH3v//d6C5pgKKiIvbv34/FYmHYsGHaG2qCXqzYg6irq6O4uJiioiJycnLaXN+iMQalFOvXr8dut2sBaoH2hHoASik+/vhjTp8+TV1dndHd0ZyH9evXk5aWRnR0tNFdCRm0J9QDEBEKCwu1AHUDlFKsXr06ZIJ6QwEtQj0ApRSzZs3Sbn43oaysjJdeeondu3cb3ZWQQItQN8Nms7Fx48ZmUdxKKb755hsd2d3N0EsjnOgxoW6Ce9bLPds1ZMgQIiIi6NevHyaTifDwcKqqqgzupaYzFBQU9LqwjrbQnlA3QUSora31rPdZvXo1a9eupbi4mF27dnUYdqEJTXJzczs+qYejRagbERkZ2awyRFlZGe+88063iOdyJ5l3/96VdnoSx44d8/yulPJUHOlNaBEKIRwOB0opdu/ezbffftvqeE5OTrf0eNyPklVVVezYsYPHH3+ckpISrwXFfd7p06f597//7dm/Z88eCgsLm1Xq6G6MHTvW83tBQQErVqzgH//4Bx999JGBvQouekwohDCZTJw7d87j2UyYMAFwLkI0mUxs3LjRyO75hN1ux2w2k5+fz5tvvsmZM2ew2WyUlpaSkJDgVRuVlZVs2LCBNWvWEBkZyZgxY7DZbPz1r38lLCyMadOmcdVVV2G1WrFard1qljAvL4/U1FQsFgs5OTme8I5jx46xc+dOxo0b161ejy9oEQoRSktLKSkpYcOGDZ5v/o0bNzJw4EDWrVtHfX33LDIrItx9992t9m/atImBAwd68u64vaW2Ajyjo6M9Uf61tbX8+c9/9hxraGjgq6++4quvvgLgqaeeIjIystt8cAsLC9sNrektwa5ahEKEU6dO8eWXXzbbl5OTQ05OjjEd8hMmk4n09PRW09GjRo3iwIEDREREEB4ezgsvvMDw4cMZPHgwqampFBQUcNVVVwFOofH2w1hVVdUqYVtHnD17FrPZTHx8fKeu8wfnq7l29OhRxowZg9VqDWKPgo8WoRAhMTHR6C4EBKUUAwYMaCVC7777LtXV1YSFhdHQ0AC0Ft0+ffqwb98+Dh486PW4z5NPPsnjjz/udUVVh8PB73//e0wmE1OmTOH6668PmYwDxcXFHgHqyV6RHpgOESIjI43ugs+48zC3Nfv1+eefs23btlbXVFdXA3gEqC1WrlzJvn37OjXw7HA4OHXqFA6Hg8bGRhwOB2+//Xa7HmV2djYigs1mY9OmTeTl5XltK9C4g15PnDjRYwUItCcUMsTGxnLXXXdRXV1NdnY2e/fuNbpLXvPKK69QUFCA1WrloYceYseOHVitVsaMGcPq1auD2peGhgYsFgsmkwmTycSjjz5KZWUlc+fObXXuyZMn+de//uX522KxMGjQoGB297wopdi/fz/79+8nOTmZxYsXG92lgKBFKMSIiopi1KhR7N+/v1skka+treXEiROe1dq//OUvAeeA9LvvvmtIoObjjz9OREQEffr04dy5c0RGRhIbG9vMQ9u9ezdvvvlms+uioqJC1uMoKyvzlBbqafS8V9TNsdvt2Gy2Tg+uGkVhYSEVFRWt9iulzvuoFWjq6uo85Yhqa2v57W9/y7Zt26irq0NE2LBhg+eR0E18fDxhYWEhuSCyoaHBI0AHDx7k4MGDBvfIf2hPKMQwm81ERER0mziw7jJ7d+7cOZYvX46IEB8f32a9tKSkpHYHpd0rvo0ctP70008xm83k5eWxcOFCw/rhb7QnFGJUVVXxwQcfGN0Nr+moVHSooZRqt2BjS8+o6TXvv/8+69evD2TXOuTw4cOegfP169eza9cuQ/vjL7QIhRifffZZux8Go7Db7eTk5PDMM89QXFwMOD+Y+fn5ITWb1FXcK9Ttdrvnkcz92tetW8d7770XMonjKioq2Lp1KydOnDC6K12mUyIkImki8k8RKRKRehHJF5HnRMSrVV4iMlNElBc/6S2uO9+5WzrzGkKVoqIili1b5vmQG0lNTQ02m42ioiLPh3HMmDEcOXKExx57jEcffZS6urpmwZc9gbfeeotvv/2WU6dOISIcPXqURx99lJdeeslzTtNAXKOx2+1tjsd1N7wuAy0iQ4GvgWRgFXAAmAzMAnKB6Uqp80ZXishgYGk7h8cAPwD2KqUuanGdAo4Br7Zx3Qml1D+8eQ2hXAb61VdfbbfueTApKyvj17/+teeD9tRTT5GXl8e2bdt6RSZA95hPWFhYm6uZzWYz4eHh/OlPfzJ0fGju3LkMGjQo5GLlAl0G+i84BehepdQLTYw+A9wH/BG483wNKKXygd+1dUxEVrh+XdbO5flKqTav7QkYVZdKKUVdXZ1nseSZM2eafdP/6le/MnSWK9i4lxS0F05ht9upra01fKp88ODBPSacw6v/pIhkAPOAfODFFod/C1QDS0QkypdOiEgicA1QC7zmSxvdgZKSEvLy8tqcAg72t5lSiurqau6//34eeughPv74Y44dO8bzzz/f7LzeJEDeopTiySef9KReMYJ//etf7b6XuhveekKzXdu1SqlmD8RKqUoR2YxTpKYCn/vQj6VAOLBcKXWunXPiROQ2IAUoB3YopbrVeNDKlSux2+2cPXuWzMxMtm/fTkZGBsXFxUGLkldKoZTi3Llz/PGPf/TY/eijj3pVDpuucvz4ccrKyrxOR+JvGhoaWLduHeHh4QwaNMgjRqH0aOYt3orQCNe2vamQgzhF6EJ8E6HbXduXznPOxcDLTXeIyG5giVIq5BerOBwOj6u/a9cuz/Tq4cOHg9oPEaG+vp7f/OY3QbXbE/nnP//JAw88YGgf8vLyGDRoEGvWrAGc4nT11VdjsXSfJYDe9rSva1veznH3/rh2jreLiMwAMnEOSLeXp/QZ4F2cIljnOv9hYDHwhYiMU0oVttP+HcAdAAMHDuxs9/xGYWGb3Qs6DQ0NPcKFDwWOHj1qdBc4ePAgjY2NHD9+3PMlZ7PZupUI+Wt0ze0D+vLuvsO1bdcLUkrdr5T6Wil1VilVpZTKVkpdh1OY+gHtfh0ppZYppbKUUllJSUk+dM8/9O3bNyRc5draWrZu3dqt3qShSp8+ffjd737Hz3/+c086XvejbjA5evSoR4AyMzO7XUYGb9+Jbk+nbzvHY1uc5xUikgBci+8D0n9zXX+5D9cGldjYWPr06YPVaqWsrCwoNlvmoKmtrfUsBTBqNq4nUVNT41lW8fLLL7Nz507279/PgAEDiIqKori4mEceeSSoU/kHDhxg+vTpXudTCgW89YTcdUkubOf4cNe2s8tnb8E5IP22UsqXT6Z7ZZ9Ps3LB5uabb+a6665rltw8UNjtdl5//fVma48iIyOJjIzslsnyuwPffvsttbW1HDlyhJycHE6dOmXIivKXX365W81qeitC7qCZeSLS7BoRiQGm4/RmOjtb9WPXtr21QR0x1bU94uP1QcVisWCxWEhPT+/45C6glOKNN95gy5YtPPzww3z44YcopWhsbKSiouK8KUU1/kNEOHjwoCFjcG+99VZILH71Bq9ESCl1GFgLDAZaZi1/DKcnslwp5Ql6EpFMEclsr00RuQwYCew5z4A0IjKhrfVHIjIW5wJJgNe9eR3BxP3Ga2hooLGxEZvNRkVFBSLCli2BW1ngcDjYtGkTW7du9fy9Zs0a7rnnHn72s5+FxGBqb0EpxaeffmpIkYKqqio++eSToNv1hc6MTt6FM2zjeRGZA+wHpuAM28gDftXi/P2ubXujse4B6Y68oHuBH4jIF8BxoB7n7Nh8wAz8HVjR/uXGYbPZWLFiBWazmdraWiIiIkhMTAzo45CIEBYWFrD2NZ3n5MmTDBkyJOh2T506RW5uLiNGjOj4ZAPxenbM5Q1l4YzfmgLcDwwFngemdRQ31hRXwOtivBuQfh9YB1yEcwzpXmAisAZYqJS6Q4XonLPNZqO6upqKigpsNhuVlZXk5+cH1Ob777/P8uXLA2pD0zmefvppzp49ywcffBDUgFMRaVaxN1Tp1DytUuo4cKuX57Y7H+1aFe3VPKJS6n2cQtStaGhoCPoAcENDA/v27QuqTY13PPHEE9TV1REVFcXs2bM7vsAPmM1m+vfvHxRbXUEvFgkQGzduDPrMiMPhoKioKKg2Nd7hFqDBgwcHzaZSiry8PC68sL1J7dBAJzXzMzabjTfffDPoAqSU4rnnnguqTU3nqK2tDWo6XLvdTm5ubscnGoz2hPxMZWVl0BYjNiVEh8U0OMtY33rrrURGRpKWlhY0uyaTicsuuyzkCydqT8jPGHWz8/Pz9aNYiJKUlERmZibJyclBXT3tcDhYt24dZWVlni+pUPyy0iLkR8rLy3n33XcNsZ2dnW1IjS9Nxxw9epRly5YZcn/OnDnDihUr+Otf/8qnn34adPveoEXITzgcDt544w1DlssXFRV1q4qtvZExY8YQHR1taB+OHj0akvXKtAj5CZPJRGpqatCLFlZUVPA///M/nD17Nqh2NZ1j9erVhifIdzgcJCYmGtqHttAi5CeUUlx99dVMnz49qHbXrl1LeXmnkhdoDCAxMZFz586xadMmQ8Vo48aNITcupGfH/ITdbqegoIDPPvssqHa3bdsWVHsa3zh69CiPPfYYdrudzZs38+CDD7J+/XouuOACRowYEbTE+UVFRYZXkm2JFiE/sX379qBXxGxsbOw2kdKa7yp5nDp1ioKCAv79739jNpuJjIxk6NCh3HHHHR204BtWq5XExETmz5+PiISUAIEWoS6jlOLgwYPs3Lkz6Haff/75kHOtNR3T0NDAU089BTiFqaqqit27d5Ofn+/3FdVms5klS5YQHh4esmuF9JiQjyilsNls7NmzByMKKh4/fjzoSfI1gWX16tUBaTc7OzvkSos3RXtCPrJr1y6++eYbw+ynp6djtVqx2WyG9UHjXwJRiMFut1NeXm748oDzoT0hH9i5c6ehAgTOldk///nPDe2Dxr9cfPHFAWm3srKSc+fOceSIMwFpqD3CaxHygaSkpJCoVpGamhryEdIa74mKCkyq9NLSUlasWMEnn3xCUVFRyI0NaRHygbS0NJYsWWJoHTNwrhEyIpG6xr/069eP8ePHB6Wa66pVq4JekqgjtAj5SGRkpKHjMWVlZXz88ceG2df4j9TUVG6//fageNdKqZBLfGf8M0U3QynFZ599xqlTp6iqqjKsH3FxcURFRYX0rIfGO4Id2HrixAnWr1/P+PHjQyL9q/aEOon7edpIAXITqIFMTXDZs2cPr7/uLBjT9H0VqAHkkpIS9u/fz4cffhgSX2LaE+okjY2NnDlzxjD7JSUlvPfee4wbN87wGTqN//jmm284cOAAZWVlPPXUU4SHh2Oz2QJaSbWiooI1a9awePHigNnwBi1CnUREgpau49y5c5w5c4aTJ0+ycuVKLr30UoYNG8bOnTs5efJkyE21arqGe8D4wQcfZPLkySxZsiTgNkeNGoXD4Qha7FpbaBHygeuuuw6lFCtWrAjY87xSijNnzvD888979m3cuJHt27cDzvgjTc9EKcWQIUMCPpUuImRkZBgqQKDHhDqN2WwmJiYGi8US0AHFkpKSNgNi6+rqAmZTEzqsWrUq4Ol6lVLk5+dTXFxMaWmpYeOc2hPykT59+hAdHR2QG6eU4u2339bZEnsxtbW17N27lwEDBgTUI/riiy88v8+YMYPRo0cHzFZ7aE/IR+rr60lOTg5I2yJCYWFhQNrWdB9iYmKCurr52LFjQbPVFO0J+UBNTQ2vv/46jY2NAbOxaNEicnNzOXz4sKGzcRrjCPbEw4ABA4Jqz40WIR/YsmVLQAUIYNKkSUyaNIn6+npWr17N119/bUgSfY0x/PCHP2TSpElBtblt2zbGjRsX9NgyLUKdRCnliUYOBuHh4SxYsIAvv/wyaDY1xjNs2LCgiEFERATh4eGMHj2auLg4Q4JbtQh1EhFhxowZQc0lbfQUqia4hIWFER8fHxRBuPHGG4NeIaYl+t3tA8OHD2fEiBFBs1dRUUF8fHzQ7GmMo3///jz22GNB++Kpr683fNGrFiEf6du3b1DsNDY28s4774Rc+gVNYLj++uuJjY0Nmr233nrL8PxCWoR8ZOLEicyaNSugNpRSvPvuu+zZsyegdjShQ7CT1CmlOH36dFBttkSLUCdwrzCtrq7m5MmTFBcXB9SeiATN49KEBr/+9a+pra0Niq34+HgyMzODZq899MC0lyilEBEOHz7Mjh07OHfuXMCnzB0OBydOnAioDU1oUVVVRWFhIcOGDQu4rVmzZpGSkhLw5SYd0SlPSETSROSfIlIkIvUiki8iz4mI16OmIvKliKjz/ES0c90oEXlbRM6ISJ2I5IrIYyIS2ZnX4CsiQl5eHgcPHuT06dMBF6Di4mIef/zxoNcz0xhLY2MjgwcPDspgcXJyMkopw/Ole21dRIYCXwPJwCrgADAZ+BkwX0SmK6VKOmH7sXb2t5JlEZkCfAFYgZXAcWA28BtgjojMUUrVd8J2p1BKUVNTwxdffBHwOuLutAr5+fmcPHkSk8lkaO1yTfA5efIk6enpAbfz4YcfkpCQwKWXXhpwW+ejMxL4F5wCdK9S6gX3ThF5BrgP+CNwp7eNKaV+5815ImIGXgH6AAuVUqtd+03A28C1Lvt/8ta2L+Tn5wdFDE6dOsUrr7xCaWkpgBagXkZERERQBAictevGjx8fFFvnw6vHMRHJAOYB+cCLLQ7/FqgGlohIIGqWzABGAhvcAgSglHIAD7n+vFMCOM8oIowePToob46SkhKKiop0yo5eSl1dHffccw8FBQUBt1VeXk5ZWZnh4UDeekKzXdu1rg+/B6VUpYhsxilSU4HPvWlQRG4AhgANwH7gi3Yeqdy2P2l5QCl1RETygAuBDCBgdZGVUkFJSB7MkBBNaKKUCmhaVzf79u1j3759mM1mvve97wGQkZERsrFj7uXB7RW5OohThC7ESxEC3mrx9xkRuVsptdIH2xe6fgIiQhUVFZw6dSrgSaYiIyOJiIggIiJCe0K9HKvVGrS0q3a7nbVr16KUYvbs2WRmZgbcZlO8fYXuxSrl7Rx37/emfsgqYAGQBkQCmcATrmv/V0S+70/bInKHiGSLSLav63pWr17NunXrfLrWW2688UaWLl3qKU73hz/8IaD2NKHNxo0bA74OrSnu2bjBgwcHzaYbf8ms23/rcF5RKfWsUupDpVShUqpOKZWrlHoEuN/Vn8f9aVsptUwplaWUykpKSupk004CXVqnX79+JCQkeNzgiIgIlixZEhSXXBOabNq0KWBJ886HEbnLvRUht7fR3vLd2Bbn+cI/cE7PjxORmCDbPi9jxoxh8uTJAXtW7tOnT6tZsH79+hk+YKgxjsTExOCPzVgsFBUVBb0Yo7djQrmubXuBLcNdW58Loyul6kSkEogHooDKYNn2BqvVGpAFZCkpKcydO7fZs39FRQVLliwxPLpZYxzBKPcTHR1NYmIiw4YNY9OmTSxatIjExMSA222JtyK03rWdJyKmpjNkLq9lOlALbPG1IyIyAqcAVQJnmxz6AvgVMB/n2FHTazJwitMxIKDTSmlpaQEZMD516hSHDh1qlmB8zZo1rF69+jxXaXo6u3fvxmKx0L9//4DZGDVqFFlZWYAzcFZEPF98wfTCvHocU0odBtYCg4G7Wxx+DKfnslwp5akpKyKZItJsmF1EMkQktWX7ItIP54JEgLeUUk1XTX+Fcwr/chH5jybXmIAnXX/+TQXYbUhMTGThwoWYTCa/zFgMHz6cYcOGMXny5GaR0w6Hg9mzZ5/nSk1v4KOPPqKkpCSg3vD+/fs9v7tFR0SC/hgo3r7INsI29gNTgFk4H4UuaRq2ISIKQCklTfYtxTn28xXO6fRSYCBwJc4xn2xgrlKqrIXtlmEbBcAcIAvYDHgVtpGVlaWys7O9er3tYbPZ2L17N9u2bfO5DRHh9ttvx2KxNLvhBQUFfPjhhwCcPn2aV155hePHj3epv5ruyzXXXMOcOXMCJgpjxozhsssuO+857mUC7gDujhCRHUqprM70w+uvdJc3lAW8ilN87geGAs8D07yMG9sBvI5TyK51tTEfyAHuBaa3FCCX7a3AJJziNw9nmEZf4Pc4RStgcWMtsVqtZGVl8aMf/YjISN9iZ9PT0zGbzc1u6vHjxz0CBM4Mew8++CA//vGPu9xnTfektLQ0oF5JWVmrjxrgLP1TWVlJQ0MD69c7R2JsNvmk3KEAAB8oSURBVFvA+tGp8Fml1HHgVi/PbfXfU0rlAEs7Y7PJtfuA63y5NhCEhYXRt29fn3KxFBQUsGbNGq688spm0/ItiymazWbGjRtHv379OHv2bHvNaXoogU5w1tbi202bNpGbm0tDQwMmk4lRo0axefNmdu/ezV133RWQfuh8Qj5QU1PD22+/TUREm1lHOsRqtXLixAlycnIYM2YMIkJCQgJhYWGtzlVKERUVpUWoF9G/f3+uv/76gOcxbxm86nA4KCoqor7e+WBht9vJyckJaB9AZ1b0icbGRmpra9t1ZzvCZrNht9vZtGmT59vo9OnTnsj5lsyYMSOoeYc1xjFo0CDuuece+vXrF/AB4pZVfh0OB1FRgYhBPz9ahHygsrISs9nslzQbq1evZv369Xz11VdtHrfb7SQkJFBRUdFlW5rQ59ixY7z99tv069cvoHaioqKYP39+s31KKerq6oIuRPpxzAdSU1O54oorWLduncd19RWlVLOp0pZYLBaSk5NJSUmhtLRUr6Lu4WRmZnoi2n3BZrPx7LPPMnbsWObOnevZbzabm503a9asVhMrJpOJa6+91vM+i4iIoLa2luLiYnbt2uVznzpCe0I+MmjQoKDVHqupqTE8+50mONTV1TF06FCfr6+treXYsWOsW7eO//qv/+LFF1/EbDa3mt1qKyDbLVSxsbGkpKQQFxfHgAEDGDt2LDfddJPPfeoILUJdICsrKygLuw4fPszKlSu1F9QLOHHihM+P3kopYmNjmTVrlseDyc3N5emnn2b58uXNzrXb7e0muG8r53Qg81BrEeoigY7vstvtHD582Oc1SZruRWNjI08//bRP14oI5eXlfP311832Hz16lNTU5oEKNputU8tLAvllq0WoC4SHhzN69GjS0tKa7U9PT2fkyJF+sWE2m8nLyzO8NpQmOJjNZk8VjM5SV1fHI4880uY4ZdNIgbi4OG699VbDa9C70SLUBUSEGTNmsGDBAs8NTUxMZNasWcyaNYsf/ehHTJgwoct2HnjggYDPlmhCA7vdTmRkpE8iZLVaW30hRkREEBsby4ABAzz7wsLCiIyMDFq9+44IjV50c0SEG264gWnTpnHttdcSERFBY2Mj4eHhpKWldfl5Oj4+nl/96ldYrVY/9VgTylitVp8ef8xmM9OnT/f8HR8fz9NPP83jjz/OD3/4Q8/+M2fOsGzZsqDnDWoPPUXvJyIjIxk3blyrN09qaioDBw7scgJ7u91OYmKiIZnvNMFlyZIlPo/BTJkyhdOnT1NZWcnAgQM97bT8AmtsbGTfvn2MHTu2y/3tKlqE/EBdXR3FxcVtlgTas2ePXypoREZGdnlNkqZ7kJOT43NK4fDwcK677vwhlhaLhcbGRmJiYs57XrDQj2NdQClFeXk5ERERKKV4+eWXPQPI5eXlHDhwoMs2KioqWLVqFSdOnKCmpqbL7WlCn9OnTwOBmXk1mUw0NjYybdo0hgwZ4vf2fUF7Qj7iXuJ+5MgRLBYLR44cob6+nr1793L8+HEaGhooKSnpcma8yMhISktLeeKJJzo+WdMjaJpl09/07duXWbNmUVxcjN1ub7WS2gi0CPlIy/w/bpomOxMRz7ear1itVsaMGUNXk7Fpug95eXkkJycHZCLi3Llz/Pvf/8ZsNpOZmalFqDuzY8eODs/xhzvd2NjIG2+80eV2NKFPv379PDGCgZ4JveiiiwK6Croz6DEhH7n88suJi/Om1qPvuFNq6nCN3kFVVRU//elPWbRoUcBt7d69m3PnzoVERRctQj6SkJDgcz4hbxERTCYTd955JzNmzAioLY3xuFfZB+MRKS0tjdjY2KAntW+L0PDHuiEiwiWXXNIqTicQdsaMGcPgwYPbzTmk6Z7069eP2tpaqqurefrppwMWHzh16lQyMjIoLy/no48+AiAjIyNkHsdCoxfdlHHjxnHixAkKCgoCbismJoY//OEPvPjii5w8eTLg9jSB54EHHiAmJoZ9+/YFTIAsFgtDhw6lb9++xMXF8eMf/5jdu3eTmZnZ8cVBQj+OdZHvfe97pKSkBMVWfHw8o0aNCpmYH03XCA8PB5xFCAPF4sWLm6UGtlqtTJw4MWS8INAi1GUiIiKYN29e0Oz94Ac/4Ne//jVTpkxBRPje977HsGHDgmZf0z7uEsrejuncd999fPvttwHrj9lsbjMOLRTGgZqiRaiLuIMAg1W5UilFcnIyl112GUOHDuWaa67h2muvDbhdTcf89Kc/5a677mL48OFMnjzZq2sCmTY1JSUlZEIzzkfo+GTdFLPZTFRUFHfccQdKKT777DOOHj0aMHtuoRsyZAj33XcfDoeDgwcPMmXKFKZOncqf//zngNnWtM/AgQNJSUlhwIAB1NbWMmHCBPr27cv69eubZTB013sfPnw4CQkJAfWii4qK+Oqrr7jssstC+hFei5AfcE+liwjJyckBFaGWmEwm5syZw5kzZ6isrCQsLEyvKzKA6667zvMFkZXlrII8f/58NmzY0EqEHnnkEfr37x/wqXilFHv37qVPnz5MmjQpoLa6QujKYzfDnVoz0GuH2iM5OZmhQ4e2GcmvCSwWi4W1a9c2y89z6NAh7r///laZDy655BIuuOCCoHomoZ6VU4uQH9mxYwcHDx40ZOCvuLiY5557jnPnzgXddm+nsbGRnJwctm/fTkVFBUqpNkssA+zdu5dTp04F9T2yZ88eTpw4ETR7nUU/jvmRo0eP+qUgoi+8+OKLFBcXG2K7t2O1WrFarbz22mskJiZSU1PTrvdx//33G1JNNzs7u1Xq11BBe0J+ZO7cuaSkpBiShvW2224Luk2NE5vN5sn1VFJS0kqABgwYwN13382SJUuIi4sLeuR6WloaI0aMMOwLsiO0CPmRgQMHsmDBAgYNGhT0R7L09HSuv/56kpKSgmpXc37S09N5+OGHGTVqlGdtV7A5ceIEQ4YMCbn1QW60CPmZ06dPc+jQoaBHJ4sIl19+Ob/5zW+CalfTPiaTiaVLl3o+/EaKQChEy7eHHhPyM2azGZPJhMPh8KwJCRYiQmFhYdDsaVqTmppKQ0MDZWVlzJ8/P2ghPecjPj6eiIiIkPWEtAj5mZSUFH7yk59QU1NDnz59eOutt4I6Y7V69eqg2dI0Jysri+zsbAYNGsRvfvObkFggmJKSwjXXXBOyAgRahPyO+2ZHRUUBcM0117B69WrOnj0bFPvXXXcds2fPJiEhgd///vch7Yb3JESEqVOnsnTpUs/foUBpaanHIw+VPrXEeKnu4URERHDVVVcFzV5SUhKZmZkkJyc3CwkIDw9n5syZWK3WkIqg7ikopSgrKwtaDGFLpk2bRkZGRqv9jY2NNDY2hvSXUafejSKSBvwemA8kAieB94HHlFIdPnOISBSwCLgKmACkAw4gF1gBvKCUahVzICLn+w9uVUpN7czrCDZWq5Urr7ySuLg4vv76ayIiIvxSDqgjFixYwOjRo1m2bBkPP/wwVquVL7/8kri4OCoqKkJ2yrY7YrVaGT9+fFBtjho1imHDhmGxWDxjT6+99hqVlZWecxwOB6WlpSQnJwe1b53BaxESkaHA10AysAo4AEwGfgbMF5HpSqmSDpq5DHgdKAXW4xSwBGAB8DTwAxGZo5Sqa+PaY8CrbewP3aWgLsLCwjzVML///e+3WaUjEIgIGRkZ/OlPf/J8Oz/yyCNUVFTw6quvMmHCBDZs2BCUvvR0hg8f7qk/FwxPKCIigssuu6zZmiOHw0F6ejr79u1rdm6olHtuj854Qn/BKUD3KqVecO8UkWeA+4A/And20MYp4P8C7zT1eEQkBvgSuAS4G/jvNq7NV0r9rhP9DSmaDlLGx8dz/PjxoNhtqyx1SkoKTz75JEopLr/8cv7whz8EpS89mQMHDnhmRINBXV0dubm5zRKimUwmMjMzOXr0KElJScycOZOGhoZmAbShiFdjQiKSAcwD8oEXWxz+LVANLHE9brWLUmqXUuqNlo9cSqlKvhOemd70qTszbNgwQwcJ3d+eIsKAAQO4/fbbDetLTyEyMtKTSSHQWCwWBgwYwKBBg1odS0lJYenSpUydOpXo6Gji4uJISEgIeJ+6gree0GzXdq1SqtlAglKqUkQ24xSpqcDnPvbF5tq2J9txInIbkAKUAzuUUlt8tGUoKSkpDB48OKgpP87HuHHjCA8P17XufcRisTBjxgwcDkdAp+WzsrIYMmQIMTExREREtHueiNCvXz/A6R2FwlKB8+GtCI1wbfPaOX4QpwhdiO8i5A5++qSd4xcDLzfdISK7gSVKqZz2GhWRO4A7wBlWYTTuMYMLLrggZESotrZWC5CPiAh2u50rr7wyoF6Q2WwmKysr5AXFF7x9RX1d2/J2jrv3+1QNUETuwTnjtgv4ZxunPANMB5KAGGASsBKnMH0hIqntta2UWqaUylJKZRkdV6WUQinF9u3b2bp1q6F9aUoo9aU7YTKZmDhxIrfcckvAbd144409UoDAf4sV3V8BnV6MICI/AJ7DOWh9rVLK1vIcpdT9LXZlA9eJyErgWuABnIPjIY37mzIsLCxkBguVUiHTl1CnT58+nmj5+Ph4br75ZkaMGBGUtUHuxa89EW+l1e3p9G3neGyL87xCRBYBbwFngJlKqSOduR74m2t7eSevM4za2tqQSjBls9nYuXOn0d0IeX7605/yi1/8wlMfLCIigiFDhgRtMPqNN95g3bp1vPTSS1RVVQXcXjDx1hPKdW0vbOf4cNe2vTGjVojIdcCbOD2g2Uqpg95e2wR3Fq9u8zWRn5/P+PHjOXbsmNFdAZxe2UMPPUR5eTlbtmzh008/5cc//jEmk4mEhASeeOKJXjte5A5Evummmxg9ejQiwrx589i1axe/+MUvgrryvLq6mrw858fr9OnTREdHB812oBFvlnO7FioewjlFP7TpDJlrjc9JnF5VklKq2ov2/g+wHCgEZvngAbnb+QlOb2iNUurKjs7PyspS2dnZvpjyG3a7HbPZTEFBQdAWLXaGhoYGwsLCPGteHA4H9957b7NzTCYTl1xyCZs2bTKol8Hjyiuv5Pvf/75nPMZutwfN+2mPn/zkJ0FPjOYtIrJDKZXVmWu8ehxTSh0G1gKDcS4mbMpjOD2R5U0FSEQyRaRVrVkRuQV4DSgALu9IgERkQlvrj0RkLM4FkuBchd0tcL95UlNTGTNmDOPGjTO4R80JCwsD8HzQzGYzAwYMAJwZ+q644goWLFjA4sWLPft7KiLSatbLbDYbKkAXXHCBYbYDRWf8ybtwhm08LyJzgP3AFGAWzsewX7U4f79r67ljIjIL5+yXCWfYxq1t3NAypdRzTf6+F2c4xxfAcaAeyMQ5m2YG/o4z7qxbYTabmT59Onv27PG4/aHK5MmTOXToELfffrtHpLZt29Yjk+qbzWZPmENiYmLIRZ7PmDEjZL0gX/Hqccxzskg67QewlrY4VwEopZqK0FLglQ7MHFNKDW5yzSLgh8BYnGEjEUAJzhmyvyulvE6gEwqPYy1RSrF8+XLq6+uZMGECZWVlnmf/UMZut6OU4sEHH+z2dc4mT57MlVdeyaZNm8jIyCA8PJwhQ4awdetWwsPDmTx5ckiIkYiwcOFCUlJSQna63pfHsU6JUHcnFEUIoKqqyjPQqJSiurqa5cuXG9yrjnFXnM3OzsbhcFBWVkZ9fb0hXl3//v0xmUycPHmy0xkt//u///u8K5BDjYkTJzJlyhSju9EmvoiQTiwTAjSd6RARoqKimDVrFhs3bgz5NTyXXHIJc+fO9awc3rVrF2+99RYiQnV1h3MUfuOhhx4iPDyc//zP/2TIkCHk5LS7iL4ZP//5zz2PmN2B6OjokC3d4ytahEIQEWHEiBGUlpaye/duo7vTLiJCdHS0x+swm82MGzeOCRMmAE5PKS8vj7/97W/YbK3WoPqVmpoaIiIiePLJJ6mqquLhhx9udnzIkCHNwmTGjx/PpZdeytChQ0P20aYlJpOJmpqakHg09Cfd47/fC6mqqmqVFyZUaTl75N4nImRmZnLbbbcxevRo0tPTERGSkpK46aab/GI7MjKSCRMmEB8f79m3ffv2ZjN3I0aMYM6cOQwaNIif/OQn9O/fn6VLl5KZmdltBAicK7bvuOMO+vfvb3RX/Ir2hEKQ2tpa3nvvvYB7D4GiZYmbsWPHMmbMGAoLC3n11VdJS0vjoosuIioqigkTJtDY2Mg333wDOAsFnj171uvXXltbS1paWjMhnDlzJpMmTeLUqVPU1dUxaNAgYmJiPJkPx44dG9LpTsPCwsjMzKSmpobp06cTFhbG3//+92YeZ09CD0yHIJWVlbz22mtGdyMguBdBNhWN+vp6XnnlFW6//XbPKuR//OMf7N69G4fDwS9/+UsKCwspLi5mzZo1zdozm808++yzPeqDOXPmTEaNGuUJeDaZTNhsNpRSIT9+pQemewgxMTGMGzeOXbt2Gd0Vv9PW409dXR133tk8KecNN9zAbbfdhsPhwGKxkJqaSl1dnUeELBYLdrs95FOXdhaTyURqqjMphFuslVKGlBYPFlqEQpQpU6aQl5fHiBEjOHbsGKWlpR1f1E3p27d1XHR0dDQi4hEtESEyMpJx48Zx1VVXMWDAAGw2G0eOHOlW4zodMWfOHGJjY5vt62kD0S3Rj2MhTEVFBbGxsdhsNvbt20d+fj4lJSXU1bVVB0DTEwgPD+eGG27otgGqAYsd0xhDbGysxxW/+OKLWbhwIQsXLjS6Wxo/03J8rLy8Uxlxuj36cSzEafoGVUphsViIioryLARsmmhL0z254YYbACgvLyc1NTXkB5/9jRahbkbfvn1ZsGABe/fu5eKLLyY6OpqcnBw2b95sdNc0PhIWFkZ0dDTx8fE9fvynLfTjWDfC/QZNSEjgsssuIyYmBhHh4osvBpzjCZrug8lkYvTo0Z64td4oQKA9oW6N+03b0NDAj370I+rr6/nss884ffq0wT3TeIPVamXq1Kk9anbPF3r3q+8hhIWFER4eTmxsLFdffbXR3dF4SX19PZ9//nmv9YDcaBHqYYSHh2N0aSNN+4SHhzNy5Ejmzp0LwKRJk3q9COnHsR7IkCFDqKysJDY2lqFDh7Jt27Yet7K4uxEWFsbYsWOpqKggKyuLmJgYBg4c2OtmwtpCi1APJCsri6ys79aLjRo1iqNHj7Jjx45etwYlVJg6dSoXXXRRs8BZPZHgRD+O9QLCw8OJj4/3xCRpgsu8efM8AanBKJTY3dAi1EuIi4tj5syZxMTEGN2VXkX//v09idO0+LSNfhzrJaxfvx6r1UplZaXRXelV6OUSHaNFqJdgt9s5csSnGpMaH5k1axaRkZHaA+oALUK9AKUU/fv3D5nS072B9PR0Ro4caXQ3ugVahHoBIsKFF17Itm3bjO5KjycqKop58+b1uDzQgUSLUC+hrUj75ORkzGYzJ0+eNKBHoU1ERAR1dXVccMEFxMfHs3fv3mbVWUWEiRMnUllZySWXXEJFRQXvvvsuffv27fHlsf2NTmrWS3DXBNu2bZtnrcodd9yBxWLhL3/5S7NzLRYL4eHhQa0bZiQJCQmUlZVhsVgYP348Z8+epbq6mpEjRzJy5EhPfufc3Fw2btyIiDBlyhQmTJjgmXZXSlFZWUlUVFSPynfdWXSOaU27mM1mJk6cSEpKClVVVZw7dw6LxUJ5eTmLFy/mk08+oaqqCoCLLrqo2+W3Hj9+PCNHjuSDDz7o1AxgVFQUN954o0dA3EnlHQ6HZzGhO79zSkoKCQkJDBkyxFNbrWllkZZpWTXeoUWol9FywaI7v3NqaipnzpzBbDaTlZXF6NGjeeONN4zoYqdJSEhg4MCBxMXFsWTJErKzs70e/6qpqcFutzdbP9VeUvmkpCRuvPHGkC4X1B3RIqQBnAnWm2K1Whk0aBAZGRlYLBbWr1/fqZLUI0eO5MSJEwFflzRjxgxGjx7tEQa73d6px6H4+PhOp9LQU+7+RYuQpk1EhKuuusrzoU5KSmLFihWtvACTyYTFYqGhocHz4bz55puJjY2ltLSUQ4cOsWvXLlJTUxk/fjzbt2+nrKzMM94kIgwfPpxDhw7hcDi86pt7gDg9Pd2TEN5t22w2t1u5dtSoUdjtdnJzc7FYLEyZMoWxY8dqUTEYLUKa8+L2KuLi4rjlllt49dVXPccGDhzI/PnzOX78OGvWrCEpKQmr1ep5tImPjyclJYXGxkZiYmJISEhg4cKFbN++nR07dnhEZ8qUKcyYMQObzcbHH3/MgAEDSEpK4vPPP28letOmTWPcuHGeLAFtMXHiRLZs2dJsRvDCCy9k5syZFBcXk5uby+WXX05mZqY//1UaH9GzYxqvaWho4PPPP+fo0aOMHTuWSy65BJPJhFKK8vJyoqOjMZvNHs/CPXN0+PBh0tPTm6WtKC0tJTw8nIiIiFZxVTabDavVSk1NDe+9916zyP8rrriCoUOHdtjX/fv3c+TIEU6dOkVqairz588HnNVtCwsLGTFihPaAAoAvs2NahDSdwuFwcODAATIyMjy5kTuLUgq73e4Rn/OJQUNDA++++y5ZWVlkZGQ0K4ioCT30FL0m4JhMJkaNGtWlNkTEU3O+I8LCwrjuuuu8Pl/T/dBfKZqQRwtQz6ZTIiQiaSLyTxEpEpF6EckXkedEJL6T7SS4rst3tVPkajct0LY1Gk3nqaioCFjbXn/FiMhQ4GsgGVgFHAAmAz8D5ovIdKVUiRftJLrauRD4AngLyARuBa4SkWlKqSMtrvGLbY1G0zE2m40tW7ZgtVrp168f586do6ioKGAlyDvj5/4Fpwjcq5R6wb1TRJ4B7gP+CNzpRTuP4xSgZ5VSv2jSzr3An1125gfItkajOQ9KKb755hv27NkTNJtePY6JSAYwD8gHXmxx+LdANbBERKI6aCcKWOI6/7ctDv+Pq/0rXPb8aluj0XhHsLNBejsmNNu1XauUarasVSlVCWwG+gBTO2hnGhAJbHZd17QdB7DW9eesANjWaDQdICJERkYG1aa3IjTCtc1r5/hB1/bCALTTJdsicoeIZItIdnFxcQfd02g07QXwBgpvRaiva9te0Sr3/rgAtNMl20qpZUqpLKVUlq5MqtGcH4fDgc1ma7U/kKlq/bUAw73ktavLr31px1+2NZpej8lk4uqrrw6uTS/Pc3sbfds5HtviPH+24y/bGo0mBPFWhHJd2/bGfIa7tu2N23SlHX/Z1mg0IYi3IrTetZ0nIs2uEZEYYDpQC2zpoJ0trvOmu65r2o4J51R8U3v+tK3RaEIQr0RIKXUY5/T5YODuFocfA6KA5UopT2Z0EckUkWYJW5RSVcBrrvN/16Kde1ztf9p0xbQvtjUaTffB61QebYRO7Aem4FzTkwdc0jR0QkQUgFJKWrTTMmxjGzASWAiccbVzuCu220On8tBoAosvqTy8DmB1CUMW8CpOAbgfGAo8D0zzNnbLdd4013XDXO1MAV4BJrYUIH/a1mg0oYdOaqbRaPxGQD0hjUajCQS9yhMSkWLgmBen9gPOBrg7Gu/Q9yI08PY+DFJKdSo0oVeJkLeISHZnXUpNYND3IjQI5H3Qj2MajcZQtAhpNBpD0SLUNsuM7oDGg74XoUHA7oMeE9JoNIaiPSGNRmMoWoQ0Go2haBHSaDSG0itEyMiijZrv8Md9EJEvRUSd5ycikK+huyMii0XkBRHZKCIVrv/Z6z625ZfPVY+vr2tk0UbNdwSggOVj7exv7FJHez6PAhcDVcAJnO/hTuPX+6mU6tE/wKc480//vxb7n3Ht/5uX7bzkOv+ZFvvvde3/xOjXGso/frwPXzrftsa/pu74gzP9zXCcudlnuv73rxt1P5VSPXuK3lU48TDOwolDVZO6Za6sjCdx3oxkdZ6kaK7CisWAAxigmtRMc2V7PIwz6dpQpb2hVvjrPrjO/xKYoVrkqdJ0HhGZiTNz6RtKqf/biev8dj+h548JGVm0UfMdfi9gKSI3iMh/isgvROT7IhLuv+5qOsCv97Oni5CRRRs13xGI/99bwBPAfwMfAwUisti37mk6iV/vZ08XISOLNmq+w5//v1XAAiANp3eaiVOM4oD/FZHvd6GfGu/w6+ehx8+OdYCRRRs13+H1/08p9WyLXbnAIyJSBLwAPA6s8W/3NJ2kU5+Hnu4JGVm0UfMdwfj//QPn9Py4luWkNH7Hr/ezp4uQkUUbNd8R8P+fUqoOcE8aRPnajsYr/Ho/e7oIGVm0UfMdAS9gKSIjgHicQqTTwQYWv97PHi1CysCijZrv8Nd9EJEMEUlt2b6I9MNZMgrgLaWUXjXtB0TE6roPQ5vu9+V+ntdOT16sCMYWbdR8hz/ug4gsxTn28xXOxXKlwEDgSpzjE9nAXKVUWeBfUfdERBYBi1x/pgBXAEeAja59Z5VSD7jOHQwcBY4ppQa3aMcvBUmBnh+24RLZdJzflCeBBpwVN/4MJLRxrqKdsAAgwXXdMVc7J4F/AmlGv8bu8NPV+wCMwVkAMwcoAWw4hWgj8P+AMKNfY6j/4PTk1Xl+8pucO7jlPl/v5/l+erwnpNFoQpsePSak0WhCHy1CGo3GULQIaTQaQ9EipNFoDEWLkEajMRQtQhqNxlC0CGk0GkPRIqTRaAxFi5BGozGU/w+ajs5SwWv/PAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "name = class_names2[1]\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "sc = ax.scatter(data2['x0'].values, data2['x1'].values, c=data2[name].values, cmap = 'Greys', s = 1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path3+'{}.jpeg'.format(name), bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  Appendix A.1  (column: Bayes Optimal, row:2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAASEAAAEBCAYAAAA3sRMtAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nOydd1iV17buxwLFiqLYsBKxIGKMJWqMJaImBmMsqNl2o8beYou9Yi+ouIgFFVSsUcGGHcECARtIEwUBRQQB6X2t3/0D19zJvmcfs/fZ++accxnPs56Y71tfXXO+c4x3vGOgAaTUSq3USu3PMqM/+wZKrdRK7f9vKwWhUiu1UvtTrRSESq3USu1PtVIQKrVSK7U/1UpBqNRKrdT+VCvzZ9/A/0urUaMGlpaWf/ZtlFqp/a+1Bw8epAA1/5Fj/r8CIUtLS7l///6ffRulVmr/a02j0cT9o8eUhmOlVmql9qdaKQiVWqmV2p9qpSBUaqVWan+q/WEQ0mg0gzUajbNGo7mt0WgyNRoNGo3myD9zUY1GU1+j0RzQaDSvNRpNgUajidVoNNs1Gk21/+QYG41Gc1Kj0SRrNJp8jUbzVKPRrNJoNBX+mXsotVIrtf8e9o8Q00tFpLWIZIvIKxGx/mcuqNForETknojUEhEvEYkUkQ4iMktE+mg0ms+B1L85pqOI3BSRsiLyi4i8FBE7EVkuIj01Gk1PoOCfuZ9SK7VS+3PtHwnHfhSRZiJSRUSm/Beu6SIlADQTGAAsBOxExElEmovI2t9+WaPRGIvIQRGpKCKDgeHATyLSUUROi8jn7++t1Eqt1P4H2h8GIcAHeMZ/oexeo9E0FpEvRSRWRLR/s3uFiOSIyCiNRlPpN9u7i0gLEfEDzv3mfvQisuD9/07WaDSaf/a+Sq3USu3Ps//XOiG79/+9+h5ElAFZGo3mrpSAVCcRufE3x1z+25MBMRqNJkpKPLTGIhL9X73BoqIiOXv2rDx9+lSqV68uRUVFYmdnJ9evX5du3bpJuXLl5NGjR5KamipZWVlStmxZ+fLLL0Wv18uLFy/EzMxMwsPDJSUlRWrWrCmNGzeWqKgoefXqlTRv3lxyc3OlZs2a8vz5c6lbt65UqlRJXr9+LQkJCdKhQwfJycmRkJAQsbCwkJCQEOncubMkJSVJtWrVpEmTJpKfny+xsbHSrVs3qVOnjqSnp0tAQIBYWVmJp6enpKSkiKOjo8THx8vbt2+lXr16Ym1tLTdu3JCHDx/Kp59+Kh999JGUKVNGoqKiJDo6WhISEuSTTz6RatWqyevXr0Wv1wsglpaWYmlpKYmJiZKVlSXGxsaSmJgo6enpUqtWLRkyZIjcv39fQkJCpHnz5uLn5ycfffSRtG/fXumxQkJC5JtvvpGUlBTp3r27XLp0SapUqSI5OTmi0+mkdevWYmZmJsnJyXLnzh1p0KCBfPrppxIfHy8RERGi0WgkLi5OhgwZIgUFBfLrr79KkyZNRK/Xy6tXr6R+/fpiamoqNWvWlJs3b4qlpaVcuHBBpk+fLgUFBbJnzx5p06aNNG7cWPLz86Vt27aSnJwscXFxotfrpUyZMmJiYiJXrlwRGxsbqVu3rly4cEEqV64sVatWlYEDB0p8fLxUqlRJkpKSpFatWlJUVCSxsbFiZGQk+fn50qpVK2nbtq0kJibK+fPnpVOnTuLj4yOWlpbSuXNnSUtLk+DgYMnMzBQzMzPJycmR4uJiMTExkYoVK0q1atWkcePGUlhYKKamppKfny+PHz8WvV4v0dHR4uDgIFWqVJGbN2+Kubm5VKxYUYqKiuTVq1dSXFwsFhYWUqtWLcnOzhYvLy/p3LmzNG/eXIyNjSUpKUnKlSsnKSkpAsjDhw9l0KBBEhsbK6ampnLt2jVJTk6Wv/zlLxIfHy8mJiZiY2MjOp1O6tSpIwcOHJCuXbvKsGHDxMjo35THAv7hj4h8ISKIyJF/8LjN74+b+3f273q/f8pvtp16v83h7xxz4f3+rz90/Xbt2vEh27RpE2/evEGn0xEUFEReXh55eXmYmprSsWNHAPR6Pf369WPw4MEEBwczYcIECgoKePHiBRqNBhHBzMyMN2/eUFxcTG5uLgB79uxBRHj16hWFhYU8fvyY+fPnU69ePfz8/Dh69ChHjx5l9erVxMbGsnfvXoYNG4aJiQlGRka8ffuW+Ph4Fi1axODBgxk2bBhNmzbl4cOHdOnShYYNG3Lp0iV8fHyYMmUKs2bN4uzZs+rZHj58iJOTE2PHjuXhw4eMGzcOjUaDkZERNWvWZM+ePezfv599+/axZcsWunXrhrGxMcXFxeh0OvR6PS9fviQzMxO9Xs/ly5eZO3cuOTk5ZGZmMnXqVObOncvs2bOpUKECIoKlpSUXLlzg9u3bAAwcOBBLS0vOnDlDeno66enpLF++nLFjxyIirFmzhilTpuDn50deXp66d8O/9Xo9b9++ZcOGDTg5OREcHMy4cePIzMwkNzeXjh07IiJ06tQJNzc3XF1dOXToEFlZWeTm5uLn56eeJTU1FVdXV7Zv3052djZ9+vTB2tqa9PR0fvnlF+rWrYuHhwdarRZjY2NWrVpFu3bt2L17NwMHDmThwoWYmpoyfvx4cnNzCQsLw8PDg4SEBDIzM/nkk0+ws7MjPDycVatWISI0bNiQqVOnIiL89NNPREREYGRkRK1atfD19WXdunUcP36cGzducObMGczNzYmNjeXly5cYGRlRrVo1OnbsyM6dO2nRogUnT54EYOHChSxcuJBdu3YREhKi3tvVq1d5+PAhtWrVonr16ogI33//PVqtlhMnTjBw4EBsbW0pV64cGo2Gxo0bo9PpWLZsGSLCmTNniIyMZNq0aR+cO5RMyPsfmof/1xz+Rw/gvwZCe98fN+Hv7F/7fv+i32y7+n5br79zjMf7/cP+zv6JInJfRO43bNjwgy9x8+bNrFy5krVr11JYWEhycjIFBQXUr1+fPn36UFxcTGFhIdOnT2fbtm0AaLVaiouL2bVrF7Vr18bGxgYRwcfHR503MTGRRYsW8eDBAwB0Oh0A6enplClThufPn7NkyRLs7e0REbp06YKzszMiQrly5ahdu7Y6BqCoqIjy5csTGhpKdHQ0pqamvH8PrFmzhtzcXEQEc3Nzbt68ycCBAxUYZmVlASWg9Pr1a/R6Pfv27QPgxYsX6jzVq1dn9erVZGVlkZeXh7+/P8HBwej1egBCQkJYt24dgDq3YbvhHIbz3r9/n5cvX9K8eXNEhI0bN6rvFxYWEh8fj52dHdevX6dSpUpUr16dCRMmUFhYiE6n48KFC+Tn5wNw8OBB6tWrR2BgIDk5Ody6dQudTseQIUNo1qwZ9evXZ86cOQC8evUKvV5PYWEhv/76K8XFxej1evR6PfPmzePKlSu8evVK3cvq1auZN28es2fPZu/evSQkJLB7925MTEy4ffs25cqVo0yZMogImzZt4tSpU/j5+dGrVy9SU1MBKC4uJjExEWNjY6ysrHBycuLmzZt06NCBzZs3Ex0dTdu2bfH29iY2NhZzc3Nq167NqlWrOHToEFqtlqSkJAAcHBxwdHRk586ddOnSRY2tDRs2ICIMHjyYuLg4Dhw4QEFBAYGBgeTn5xMYGEhERASDBw+mcePG6vcQEZYvX86vv/7Kjz/+iLe3N9u2bSMwMBAbGxuGDx/O2bNn+fHHH6lRowa+vr54eXmxfv36D84d+N8BQuve71/4m20fAqGj7/f/5UPX/yOe0Ny5c2ncuDF79uxR2woKCkhOTub+/fvUrl0bc3Nzvv/+exYvXsz48eMBOHDgAJGRkQCcPn0aESE0NJS3b99SXFwMwLlz54C/ApC3tzfz5s1Dq9Vy69Yt5s+fj4hQo0YNdu3aRUFBgVqh+vXrR3x8PDk5OaSlpfHu3TumTZtGUVERAHfv3qVcuXKICJ07d8bPz49Dhw5x9uxZRo8e/TsP7MGDB/Tv359Ro0aRmJiIXq8nMDCQnj170qtXL8qWLUvlypU5fvw4gJr8xcXF+Pn5MXv2bGJiYoiLiyM8PJzQ0FCgBEzu3LnDrVu3sLe3x8zMjMOHDyuASk1NpUePHogItra2xMfHU1hYSGxsrHrXP/zwg5poIsLixYuBEuC5fv06c+bMQUQwMjLi6NGj6HQ6zpw5Q1JSEtOmTePatWtUqlSJ58+f06FDB3r27Mnr16/x9vbm8uXLQIk3deLECRo3bkxYWBhfffUVXbt2BcDX11f9Pj179mT9+vW8fv2afv360a5dOyIjI3Fzc6Nr165kZWWxZs0aHj16xOrVq9WEnT17NqNGjSIrK4vo6Gi+/fZbCgsLSUlJ4fTp0wDEx8dTVFREZmYmJ0+eJDc3l/DwcFJTU9m7dy+DBg2icePGGBsbM2XKFKZPn86hQ4fIyMjg+fPnrF+/npYtWzJt2jR1v3q9nsTERO7evcvkyZOZMGECderUQUTw8PBQ4Onh4UFKSgorV65k48aNaLVaUlNT8fLyYtu2bTg7O1OpUiWioqIAOHToEBUrVvzg3IH/GSD03z4c02q1ZGdnA5CSkkJSUhI6nY7i4mKys7PV5LCzs0Or1bJ27VoqVKjA48ePgRKA6dy5M/b29mpQFBYWEhUVhZeXF1AyAH18fDh16hQFBQU8efIENzc3goKC8PPz482bN2q17tatGyJC8+bNycnJAUq8KoCVK1eSlpamwgsHBwc0Gg3169dn586dCvzevXvHjRs31DkBunbtipWVlZrkT58+xczMDK1Wy8yZMxk/fjyXL1/m3bt3ALx584aioiI1qNesWcOCBQuAEtANDAzkxx9/JDg4WD3juHHj0Gq1XLhwgatXr/Ly5Utu375NhQoVaN68Obt27WLUqFHMmzdPvfP8/HwOHTqkAPXkyZO8e/eOly9f0rt3bzZu3Ei1atUQEfbv38+kSZOoUKECM2bMIDw8HAB/f390Oh3Lly/nzJkz7Nq1iwkTJnD37l0SExO5c+cOPj4++Pn5AdCkSRM0Gg2XL1/m6dOnHDlyhOfPn2Nra4uI0KhRI2xtbTE1NcXPzw+9Xo+3tzc6nY709HTy8vLQ6/Xk5eVx/PhxfvjhBypWrEhYWJgCzU6dOjFixAjCwsLUWJsyZQpGRkbY29uTl5dHRkYGer2ezMxM2rZti0ajwcTEhGPHjqlj4uLi1L/btWuHiHDlyhXy8/OZM2cOrq6urF+/nrS0NOzs7BARHB0dCQoKok2bNowZM0Z547m5uSxdupTAwEDc3d0ZNmwYvXv3ZsqUKb/zYo8fP86QIUM+OHfgfwYITXh/3J6/s//K+/09f7PN8W9DtL855un7/VYfuv4fAaEdO3YAJeHOyJEjgZIV3mDr169n6tSpXLt2jfPnz3P+/Hnq1atHYWEhL168oG7dukRGRvLrr78C8OzZM7Zv305WVhY7duwgICBAeRYGUPjuu++U56TT6ZR3o9PpWLduHUZGRmqwTZw4kYkTJ/Ls2TMOHjzIpUuXuHr1KkVFRYwfP159d8uWLUCJF/dbPuXRo0dkZGTQpUsXWrRowcSJEzlw4AD+/v5kZGTg7u7O119/jYhQXFzMzz//TFZWlvJWTp48yYgRIzh37hzt27fHzs6OFStW0KdPH0SE3bt34+HhgaenJ7/88gsFBQXodDpWrFjBu3fvOHr0KCLCjz/+yObNm6latSoioianXq+nuLiYUaNGMW3aNHr06EHv3r1Zv369mszwV45o6NChtGnTRr0vA8gagPr169csWbIEEeG7774jJycHnU6n3o9Op8Pa2hoRYdmyZWzduhWA27dvq3C2adOmREZGUr16dVJSUtDr9Rw9ehSA2NhY4uPj0ev1xMbG0q5dO8zMzFizZg1ffPEFTZo0ISwsjMGDByseKCsri+LiYuzt7dFoNNjb2+Pq6qrGgyEE3bp1qwrxBg0aRI8ePcjNzSUhIYGnT59SrVo1mjZtqsL+S5cuMWTIEFq2bMn48ePRarWMHDmSnTt3YmtrS5cuXRgzZgyrVq3is88+45dffsHDw4O7d++i1WrZuXMnUMJdNmzYUI3TDh06qHf8IfufAEJW7497ISJGf7PPVEqEkLkiUuk32+3eH+P7H5yv8ft9sSKi+dD1/wgIubm5ASggyMnJwcvLi2vXruHn58f27dvRaDQYGxsrcEpLSyMnJ4eMjAyCg4OJjo7m1KlTzJw5U3lO3bp147PPPmPixIlASWiSn5+Pr68vy5Yto2HDhixevBg/Pz8CAwN5+vQpgCKDAwICWLJkCf379+fgwYM8fvwYT09PDh48SOfOnbl//z67d+/G3d0dDw8PxftotVpcXFx4/vw5UMIHFRYWcuvWLXX+goIC5YkALFq0CAcHB168eEGvXr0ICgrixYsX+Pn5sWnTJk6ePMnZs2dJSEjg4MGDrF69Gk9PT5ycnJgxY8bvgLSwsJBvvvkGY2Njunfvjo2NDfHx8cybNw8RUQS2YfIbFoGTJ08iIlSpUkW9wzJlymBqaopOpyMvL4/Y2FiKi4sJDg7G09OT77//Xv0W+fn5/Pjjj8yfP5/g4GB69eqFp6cnFStWpHPnzjRr1gwnJycyMzPJysoiJCSEvLw82rdvz8cff8ysWbOoX78+/v7+eHh40Lt3b0aMGEHr1q2pXr06rVu3ZuHChYgIe/bsoaCggMTEREaOHKk8OBMTE2rUqIFWq+Xw4cN88cUXvH37lpycHAICAqhYsSLm5uZq8gNcv36dLVu2cO/ePUJDQ/n1118ZPnw4derUoXLlyjx//hytVsu6desQEVasWAGgPOr+/fuzZcsWatSowcKFC/H19eX8+fO8fftW/f56vR4LCwtFPEMJGOfn5/Pu3TsmT57MyJEjFZA/fPhQcX8fsv82ICQlymbr/8g7+Y23M+Nvtm97v33332w3FpHw9/u+/c12o9+Eagv/yH3/ERA6f/68+rdhVcrKysLV1ZW4uDhatGiBiNCnTx8Vi+fm5vL111/z7t07cnNz+eabb/j444+pWLGiyj795S9/AeDChQvExsYSGBhIUFAQhw8fJiEhgeXLlyMitG/fnvz8fNLS0gBUSKXX63n27JlatQ2T1TAR6tSpw/z587l48SJBQUFkZWWRn5/Pli1b8Pb2BlCrKpSsdpGRkSQnJwMoLywmJgYoCb8MAFGmTBnFd2i1WmbNmoVGo2Hz5s3ExMTQsmVLRIQ2bdqQlJREQEAAqamp/PzzzwwYMEDdX5MmTRARBgwYQOXKlTEyMmL69OkMGDCACRMm8NlnnxEUFMSNGzfQ6XS8efOGzMxMDh8+TJs2bdixYweff/65eu+HDh2ioKAAHx8fOnTogIjg5OSkPBPD9c6dO8egQYOYNGkSw4YN49NPP2Xs2LE4OjrStGlTbG1t6dChA0+fPuXevXs0btwYU1NTKlWqREBAAHFxcer5RAQTExN27tzJ8ePHqVKlCnPmzGHv3r0AHD58mKZNm2Jubo6joyMRERG4ubnh7u7OwoULmTFjBn5+fpw7d079tnXq1GHQoEFcunRJgUOPHj3Q6XSMGjUKEaFv375kZWURFhZGw4YN+ctf/sL06dMV0Q4wYcIE5H1CpF+/fogIP/zwA1WrVsXX15cTJ07w9u1bdDod3bt3R0SYPn06cXFxCoDatm2LiODs7Aygsm9Lliz54NyBfzMIicgAEXF7/7n8fvJH/2bblt9819LgofwH57ESkaT3+z1FZL2UlGTwPrQy/w+O6SglQsZCKSGiN4hI0Ptj7ohIuT/yDH8EhJYuXUp2djaFhYVER0fz5Zdf4uzsrDyFzp07s2PHDlavXq2OiY6ORkQwNjamRo0auLq6kpaWhouLC05OTpw7d44GDRpw+fJlZsyYoYhRMzMzRo8eTXZ2NlWqVOHTTz/l888/V15EQUGBuoZh4o0aNYqePXvi4+NDfn4+zZs3V8B06NAhFi1ahIiwcOFCJk+ejIhw8+ZNANzd3bl37x6BgYEcPnwYgOzsbF6+fMn8+fOpWrUqAwcOxN/fn5SUFBYvXoyZmRmtWrUCSjJ5Bw8eZMyYMYp/cXJyUp5K9+7d8fb2prCwkMDAQBwcHDh58iRHjhzh/PnzuLu7Y25ujouLCyEhIdy7dw83Nzdu377NxIkTqVy5Mvv27UOr1TJjxgw1wXJycnjz5g1QQsDb2dnRqlUrNcnu3bvHwYMHlXd36dIlAHbt2sUnn3yiQjzDM2i1WrRaLfv27aNSpUrUqFGDAwcOqHfdq1cvNm7cyK+//oq7uzvdunUjLy+PrKwsbt++TWxsLP3790ej0dCrVy/WrVtH165def78OUOGDOHixYsAtGnThsjISCIjIylTpgyTJ09WvE9xcTHFxcWkpKRQs2ZNRITY2Fj0ej2fffYZCQkJ3Lp1S73befPm4e/vr0CpS5cu1KxZU4Vwffv2pXXr1tSsWRMvLy+2bNmCtbU1V69e5erVq6Snp2NiYoKtra0aI2XKlGHp0qUkJSWptL6vry/BwcE4ODhgaWlJmzZt0Ol0ipr4kP27QWil4YX8nU/sb777d0Ho/f4GUlKKkfgeWOJEZIeIVP9Prm/z3vNJEZECEYkSkVUiUuGPPsMfASF3d3cqV65M8+bN6dWrF2lpaSq7M2TIEJYuXYper2fnzp2KJ0lLS+PevXvs3LmTU6dOkZubi06nY8+ePbi4uHD37l3s7e3Ztm2bitOrV6+Oqakp5ubmPH78GBcXFypWrIiIcOvWLR4+fMi8efMoKipSA02n03H69GmMjY25cuUKqampKjV///599Ho9165do1mzZoiIWhm7dOlCSkoKDx48IDc3l/z8fO7cuUNMTAzjxo3j2rVr9OzZE5GStPzdu3cB2L9/P7dv3yYsLIyEhAQVYlhaWipQvn79OuPHj8fU1BQbGxssLCzo3r07UMLb/BZI4a/8mk6nIysrS3kwIsKCBQuYOXMmO3fuZPz48VSsWBEzMzN8fX3V8QUFBdStWxd7e3tiYmKYMmUKBQUFFBUVqbDy1KlTQMni4O7uTlpaGnl5eYSEhPDixQuCg4PZsWMHu3btwsfHh/v375OYmIhOpyMgIICtW7eSkpKirrly5UqgJCwxPNdXX32lsk0iwq5du4ASndm1a9dISEhAr9fz5s0bHBwcEBH69eunzpmZmcmTJ09o0aIF9evXZ8eOHeo3XrduHVu3blUc2MGDB9U+Nzc3NBoNe/fuZfDgwQqoq1SpgoWFBY8ePeLs2bNMmjQJnU6Hi4sLWq2WZ8+e4e3tjZ2dHVWqVKFu3bqYmpri7OzMpk2bOH/+PJmZmWRmZgIliYXTp08TFRVFUVGR8sw/ZP9WEPrf8Pmj2bHWrVtjb29PREQEz58/Vyu4gfR9+vQpr1+/RqfTcfv2bTIyMhSHk5WVxYULFwC4ceMG+fn5pKamkpGRAcC1a9eIiIggLS2NI0eOKDf+zp07HDt2jI4dO/Ltt98qQDCYYSXPyMjA0tKSLl26sHbtWh49esSDBw/Iy8vj5s2bfPnll6xevRoHBwfGjx+PnZ0d9vb2NGvWDG9vb4qKiigsLGTixInI+ywfwJYtW6hSpYpKyxr4AMN18/Ly+Pnnn6levbryNAwTfvPmzZQrV46AgAC8vLxYsmQJS5cuBUoyjC9fvlTfN1hSUhKbN29GRFi7di2nT58mJSWFnJwcpk2bxuLFiwkLC1M6JigBsIcPH2JpaamyNZmZmRQVFf1OQxUcHKxIVUOCYdasWURFRaHX63n69CnNmjWjffv2zJ49GwAfHx/1G+n1ejIyMggPD1fvYdasWVy7do3Lly9Tr149RISqVatiZGTErFmzANi+fTtr164FSohtnU5HWFgY27dvZ/PmzXz11VcqzDGA85AhQxARHBwcAFi+fDkjR45UYZnBC50yZQpfffUV+/bto2/fvrx79478/HxmzZrFd999x40bNwgJCaF27dqKg4QSnZSfnx9DhgyhqKiI69evU61aNaysrHj16pWSCQA8evRIZedmzpypCHQoAfQ/YqUg9C8AoYSEBD7++GOys7N5+/Ytvr6+KlskIowZMwZzc3PWr1/PokWLFIeUlJRE79696dy5M8OHDyc5OZlNmzYxadIkzMzMGD9+PGfOnOHly5dqgmzdupWvvvqKnTt3Eh0djV6vJyEhgWHDhiFSoq6FkhS4s7Mzbdu2ZejQody+fRutVounpyfGxsZUqFABOzs7Xr169bsVvEaNGogIp06dYtWqVcydOxe9Xk92djbu7u7Y2tpy69YtRWIb0s7Z2dls2rSJ4uJiJWiEkkEKEBgYSGZmpgJeA0l69epVnj59SkxMDO3bt2f//v0EBAQwZMgQ+vbtq7I4Dx8+VPzK559/zsuXL9HpdHh4eHDt2jXmzp3LokWLKCoq4uXLlzg5OTFnzhwuXrxIZGQk8j5tfvHiRZydnalTpw41a9ZUWSWD53To0CF69+6tUvoTJ06kuLiY3bt38/z5c0RKlO0GsWJmZqZSyBsWCl9fX5ycnDAyMlLvoWvXroobKleuHD169GDgwIFUqlSJpk2b8ujRI1asWKHCakPoJSKMGDFCAaajoyPGxsZcvHiRwsJC6tWrh5GRER999JEab+XKlePGjRt0795dqbYN3mRRURFubm6Ym5szdepUAE6dOkX58uXp06cP8fHxajzMmTOHKVOmKO3Xzp07CQ0NVQAPJZzhzJkz6d+/P1qtlrlz53L8+HEuXryogOpDVgpC/wIQKioqYuXKlcydO5dKlSqp1fvy5cvcvXuX1atXK1KvW7dudOvWjdevX3PixAlCQkJITU3lxIkTeHl5qexOlSpV+Pbbb3FyclLCMIC2bdtSpkwZevfujYgwatQoIiMjiYiIoFGjRixduhQ3Nzf8/PxU6Hfz5k2+++47tFqtmshlypRBo9GQl5dHTk4O3t7eaqL36tWLcePGAfwu4xYSEsKNGzfUM2dnZ9OrVy9evHjB8+fPmTt3LlAiMTAc5+/vj6+vL23btmXnzp0MGTKEjRs3KrLeoGd5/vw5mZmZarW/fPky8+fP59atW/j7+zN16lR+/vlnhg4diru7uyJbraysOHDgANnZ2SrMKCwsRERISEjgwYMHzCX3DgIAACAASURBVJo1i6dPn5KcnMydO3fo1KkTFStWpGbNmixdupSUlBRev35NWFiY4sSGDx9Oq1atePHiBdeuXWPEiBEUFxezaNEizp07h06nU5MsKyuLZs2aKSnA6NGjmTFjBo6OjvTo0YPIyEgKCws5deoU0dHRDBkyhMGDB9OuXTvKli1LzZo1adGiBcbGxmRmZv7OQ1u5ciXr1q1j/fr1xMTEEB4ejpWVlXpntWrVwsLCAhMTEwVy1tbW7Ny5k5CQEN6+fYuxsTHDhg1TEhCAxYsXs3r1amJiYhg0aBAiwrBhw2jXrh0XL15kxowZVKxYkTJlyjB//nygxBMzhK1hYWGKcli/fj2ffvopM2bMwMLCAo1Gw8mTJ9m/f/8H5w6UgtC/BITevHnDvXv38PDwYP/+/TRq1IhDhw6p/VevXmX48OHUrVuXfv360bJlS9zd3QkKCsLOzo7hw4cjIpw/fx4PDw8aNmzI8OHDKSoq4tKlSxw9elSJ4gyDafXq1aqup3v37nTo0IEOHTrQqVMnRIShQ4cCJQMnNTWV8+fPs3z5cu7fv8+SJUsICAhQ97to0SI8PT3x9PRk2rRpdO/eHWtra7y9vQkLC1Op2J07d2Jubs6WLVt4+/YtVlZW9OzZ83c8TWhoqPLIDKt5fn4+gwcPVjVav/zyCzExMfj4+CgPxM/PjzNnzjB06FAOHDhAamoqBQUFmJiYUKVKFe7fv09hYSF169Zl7dq1v1v5e/bsyciRIzl//jxubm4MGTKEPn36KJ2QiCi5wdmzZxkzZgzXrl0jNzeX8+fPM3r0aLZu3ap0RFZWVjRt2pTQ0FBev37NihUr2LRpE4MHD6ZBgwbs27ePffv24ejoyKtXrxTJX7ZsWfr06cOSJUuwsrKiuLiYL774glWrVhEQEKDKQpYtW0ZERASLFy9Gq9USEhJCy5YtKVu2LMOGDcPf31+JTKOjo8nMzFQesV6vJz8/H09PT6DEwzSINDUaDQ0aNODJkye0atWKhIQEJSHo27cvVlZWjBo1imPHjvHy5Utev36Nq6sr4eHhKozS6XT89NNPDB06FEdHR+VBPn/+HAsLC1q1asW2bdu4ffs2+/fvZ/jw4Rw/fpzy5cvTqFEjJkyYQNmyZbG1tVXZ3Q/ZPwNCpe1d/8YyMjJk5MiRcvHiRbG2tpalS5fK3Llz5aeffpInT57IjBkz5Ntvv5Xw8HDx9PSU0NBQqV+/vgQGBkq7du2kT58+MmrUKLG1tZUNGzZIfHy8HD16VCwsLKR69eoyePBgqVixoty9e1esrKykSZMmMnnyZNm+fbu0bt1aFi9eLE+ePJHAwEAJCAiQxo0by8CBAyUqKkomTZok1tbW0q9fPzly5Ig8ffpUli1bJnXr1pWMjAzx9/eX9evXy5s3byQlJUVycnLE19dXrK2t5euvvxZ3d3cxMjISb29vMTIykmHDhklSUpJERUVJp06dZMOGDXL48GGJiYkREZGrV6/KiBEjxNbWVoyNjcXY2FjGjRsnq1atkuPHj8uZM2fEwcFBLC0tpXv37tKlSxe5ceOGeHl5yaBBg+TkyZOydOlScXBwkCZNmoiRkZE0bdpU2rVrJ7NmzZLo6Gjp2bOnzJs3T+zt7cXS0lIyMzOlXLlyUr58ecnJyZHatWuLt7e31K9fX0REVq1aJW5ubrJo0SJJSUkRa2tr6d27t8yZM0cKCwulefPmMnfuXLG3t5fx48dLdHS0FBQUSMuWLaVWrVqyfPlyqVu3rhgbG0vZsmWluLhYZsyYIUuXLhUfHx85evSoeHt7y0cffSRVq1aVunXrypo1a0Sj0ciECRNk8eLF0qBBA6lRo4Z88sknEh8fL/7+/hIdXdLAYdy4cVJUVCQiIseOHZNhw4bJnDlzpEmTJhIfHy8dOnSQwYMHi7u7u2g0Gjl16pRs375dXr16JYmJiTJp0iQRERk4cKA8fvxYjI2NxdbWViwsLMTExESMjIykTJkysmXLFklNTZW+fftK+fLl5fXr1zJ48GBp0aKFTJkyRR4/fiyxsbGyceNGCQ0NlTZt2sjYsWMlLi5OfvjhB0lMTJT8/HypVKmSFBcXS5s2bSQhIUHCw8PlwIED8uzZM6lSpYoUFRVJo0aNxNjY+N836f5dXsd/x88f8YSCg4N/R9gaUsHlypUjIiKCRYsWsXTpUsLCwggLC+Pw4cPY2trSo0cPtm3bRsuWLUlNTcXNzQ1TU1N69uzJiBEjEBFFfEJJFkXek7I//fQTIkL//v159uwZkydPpnPnztSoUYOTJ0+i1Wo5f/48oaGhTJs2DRFRaV1DdfTVq1fx8vLCy8sLGxsbPvroIyIjI5k6dSpnz55l3LhxzJs3j8LCQlJTUwkPD8fLy0uFavfv3wdKXPtKlSohInz55ZcAqu4pJydHpfbj4+Pp2rUrx44dw8vLS5UTGHiQzZs3Ex4erurSRISAgADS09OJjY3l0qVL6HQ6EhIScHZ2Jj09nVatWqHRaFi0aBEbN25kxowZJCUlERUVRbdu3WjYsCE5OTlEREQwadIkduzYwYIFC2jQoAHnzp3j7t27REVF0bRpU8LCwigoKODp06eqDCY9PZ3o6GgWLFigvKrZs2fz7NkzqlSpgkaj4cGDB7i7uyttjsHrgpKkwMyZM6lfvz5arRYAZ2dnPv74YxwdHUlMTCQpKYmxY8fi4ODA6tWrERFVtOvi4sLs2bM5f/48r1+/Zvfu3Zw9exatVsvp06dxc3OjfPnyNGnShD179hAaGkpWVhbdunUjJCSE8PBwBg4cyNWrV4GS5EFRUZEit6dOncqzZ8+YOHEiPj4+7NixA1NTU65fv45Wq2X8+PHUqlWLMWPGsHr1ahWOpaenAyXkvEGe8u7dO7p3746JiQkVK1ZUItsPmZSGY/91ENqzZw87d+7k0qVL+Pn5sW7dOsqXL8+UKVOAv6aYc3NzqV69Og0bNkREVJsPQ0uJtWvX8umnn1KuXDmVRp8xY4YibpOSkhg/fjyff/45Fy5coGzZsgwePBgoKTWoUqUKW7Zs4dmzZ1y8eJGjR4+qsPDVq1fMmzcPGxsb6tWrR61atTAzMyMjI4OQkBCaNWvGjh07yMrK4smTJ5w7d47WrVvj6+tLcXExO3bsYPr06SxduhSdTsfNmzepU6cOdnZ2XLlyhfDwcJYtW4arq6t6Ly9evODly5fk5uaSk5ND586d1UTeunUr33zzDQ8ePOD27dv4+fmxZcsWRXhDCddi4EcePHigwr1JkyZx/Phx3r59i6WlJZaWlop/MGTyPD09MTMzo0yZMkyfPp28vDwqVKiAk5MTZmZmiAhFRUXExcWpJMInn3xCcHAwfn5+HD9+nNOnT9OlSxdVY2Yo1G3fvj3z5s3D3t6eIUOG0Lt3bxo0aIDIX2unfisI1Ol0zJ8/n3Xr1pGbm8upU6cwNjamdu3auLq64uLiQqVKlRRRfOfOHe7du6eI8adPnyqVeoUKFThx4gTnzp3D3d0drVaLubk51tbWrFixAjMzM5WqN2S7DKn/zMxMbt++zZo1a+jTpw9NmzbF19eXNWvWIFJSFmMIc9etW8fJkycZOXIkKSkpODo6YmVlxYsXL9TzGRYPKAn7CwsLlRp96NChv9v/n1kpCP0LQOi3q6RBwNW+fXusrKwIDQ0lMTGR4uJigoKCMDExoUmTJtSoUQONRqMyEXq9nqSkJFq2bEmLFi346KOPVHp/8eLFuLq6EhERQWFhoUrHOzs74+vrS1ZWFg8fPlSE4NWrVxERrK2t2b9/P+np6YrYXr9+PR06dCA+Pp4ZM2YAJSC4YcMGlfno1q0b9+7d4/bt22ogrVu3jl9++YWrV6+Sm5tLSkoKgwYNUvdu6Jc0dOhQfvzxR7Zu3UqPHj0UkQ0l5Sz9+/fn0aNHnDlzhmrVqtGwYUPi4+O5cOECWq2Wdu3aYWpqquqdgoODefz4MWfOnGHy5Mn079+frVu34unpSVZWFjdv3iQ5OZn8/HySkpLYsmULLi4uuLi4sH79eipXrsycOXNUHVa3bt0ICAhg5MiRREdHU1xcTE5OjkqfA5w5cwatVqtU3ZMnT2bZsmWEh4eTnJyMSEl9WEREBHfv3lW/vZeX1+/IdYNUQK/XY2Njw8iRIxWZvXHjRkRK2pOsXr0af39/IiMjKSgowN/fn4iICIKDg7GxsWHYsGEUFxdjbm6urvX9998TFRVFdnY2qampVK5cmQULFuDu7g6U1KcZEiQGMAwMDESr1eLn58cXX3zBnDlzVJ+imTNncvjwYcUvTZgwAYCqVauyfPlyCgoKmDp1Ks2aNePixYuqbMTwPA8ePMDDwwMokVU0b978d0T4f2alIPQvAKHQ0FA+/vhjPD09+fzzzxk8eDDu7u7o9XrCw8PRarW4u7vj6urKvHnzcHZ25rvvvmPixImEhYXRtm1bFi1aRPny5enVq5cSG/br14+PPvqIGjVq8ODBA1VEaWxsjKmpKQ8fPlQkZm5urhpsycnJjBw5UimI79y5w5MnT1S6fMWKFbRp04Y9e/bQv39/JkyYwOnTp0lMTOTnn39m+PDhAAQFBbF06VLq1q2LiFC3bl18fX2JjY3l+fPnqvlaTEwMb968oXLlyogIWq2WTZs2sWPHjt/1DAKUQHDs2LEcOHCAY8eOMWjQIAYMGED16tVVjd0PP/zApk2bVCraoNWJiIhQ5zpz5gzLli1TIWvXrl1p06YNu3fvZu/evbi5uWFvb68EmN27dyclJUWFJAEBAZw+fZqHDx8SFBTEF198wcWLF9m9ezfDhg0jLCyMq1evkpSUxLlz57h27RpHjhyhV69e7Nq1i4yMDFxcXLCwsOC7777j6tWrxMfHAyihYEBAAPv27UOkpOZt0KBBPH78mL179/6OVP/ss88QEdXjx8PDg2rVquHk5ETHjh1xdnamRYsWmJiYMHLkSNV3KCUlhaysLBUCGsIiKOkuoNfr1W+Un5/Po0ePSE1NJSgoiI0bN7Jy5UqOHj2qfqfKlStTp04djhw5QnZ2Ns7OztjY2GBpaakyvGXLlkVEiImJ4dmzZ8TGxuLg4EDnzp3Zu3cvPXv25IcffvjvVzv2P/XzR0Do6NGjZGRkoNPpyMnJYejQobi4uFBUVMTp06dV6CPvNUMNGzakVq1ajB07Vg1Gw6pbrVo14K+r19q1axERWrdujZGREU5OTgBERUXh6Oj4f6mLf/31V/r376+ALCUlRWlJ4uLiiI+PV713hg4dqmqlbty4gYuLCz169MDe3h5ra2ul7q1fvz5WVlaIiCo5GD58OOHh4YiUVLMbUvhBQUHs37+f2rVr89VXX9G0aVPc3Nx+NyBjY2MRKekPZFDm5ubmMnr0aMqUKaM8rNGjR9OnTx8uX75M3759iYiIUO1Pjh07xieffIJISduJgwcPMnXqVKZNm4azszObN2/G0dGRoUOHYmVlRb169UhNTf1doeyNGzdUGHb79m0OHTrExIkTldgvOTmZjRs38vjxYzIyMjh37hyPHj0iJyeHfv360aVLF+zt7bGysmLnzp2UL1+eESNG0KJFC9q2bUt6ejrdu3dn2rRpVKhQAU9PT/VsQUFBjB49mnv37nH9+nV69+5NzZo1ef36tQIEQx+hXbt24ezsrDJiixYtQqvVMmfOHKUC/+2YMSiVDU3ODNcD8PT0JDw8XHkpFy9eZNasWezfv5/i4mJmz56NjY2N4nzy8vIICwtT/JGhC2jlypVZu3atSvX36dMHMzMz6tevj8hfezf9ESsFoX8BCK1fvx4TExMcHR0BOHLkiHKb5b12Q0Ro1qwZR48epUqVKpQtWxaNRkP16tUZOXIkRUVFREVFERoaSm5ururGCCXE9+jRo6latSpxcXGkpqayYsUK7t69q0Do+vXrXL9+nbCwMLKzs3/X9Gvy5Ml07NhR8Stubm6ULVuWBQsWoNVqefPmDXl5eezevRsoEaB5eHjQtm1b5syZQ3BwMBs2bKBhw4aMGTNGFSy2adOGTz/9FA8PD7X6vnz5Ei8vL96+fYter1dEq4ioXjwPHjzAyMiI+vXrk5ycrNppfPnll4gIK1euJCgoiBMnTjB+/HiGDh2qPJnz58+TkZGBkZER1atX56uvvsLPz09NjqlTp5KZmUmXLl2YOHEio0aNonLlyowaNQoo0TDl5+eTkpLC/v37+fzzzzE2NsbGxgaAiIgIdu/eTUpKCiNHjlRV6Pfv36ddu3aqr05hYaHqd/TTTz/Rrl07NBoNffv2Zfny5QwfPhw7Ozu2bdvGmjVr2LVrF6mpqaxZs4bQ0FCKiopITk6mqKiIPXv2sGnTJuLi4tDr9RQVFbF3717y8vIIDg5m7dq11KxZU/0+d+/eJTg4mMLCQrZv3w6UEOCvX7/Gzc2NESNGkJSUxPPnzxX47Nu3jwkTJihZxxdffEFMTAw3btzgwIEDHDp0CJ1OR3x8PB07dsTa2hoHBweWLVtGTk4OTk5O7Nmzh27duqHRaJSYc9OmTdjb23PixAk2bdqEo6Oj0i3duXPng3MHSkHoXwJCa9asUZ0MT506Ra1atdTE69SpE4cPH2by5MnAX9tgtG/fXn3HUG2cn5+vtDXffPMNAwYMYOzYsRQVFaneMTqdji+//JIuXbqg1Wq5ePEiGRkZ/PLLL7i4uAAlROiNGzc4fPgwTk5OPHr0iLy8PN69e0deXh6vXr2iUaNGDBo0iHv37rFmzRpq166tVlqDStkQ7+v1ek6dOsWpU6dUWDFnzhwFlosXL2b37t20a9eOWrVqqaxXXFwc/fv3R6SkwttQUJqZmcmFCxcYNmwYhYWFeHh4kJ+fj4+PDzExMezdu1dl2QzeVqVKlWjevDnt27dHp9PRsWNHzMzMiIiIUDyN4RMUFMSRI0f4+uuvFWgEBgZSr149Bg4cSFJSEjExMTg5OSmy/MmTJxw4cIC6devSqFEjHBwcGDt2LLt27VKtNkREhTgAV65cYd68eUrNrtPpuHfvHsnJySoT+e7dO96+fcvr169Zu3Yty5YtU+/VUN5w7NgxtUj9+OOPyus01I2lpKSwYMECqlevzuPHj2nbti0uLi5kZmbSoEEDRXqvW7dOgfG+ffvUQpabm8vEiRMZN26c6ipZrVo1Jbg09PKOiYkhNDQUrVbL0aNHadq0KdOmTSM5ORl/f3+2bduGvBe69u7dm6+//hp3d3cCAgLUODF4mSEhIaoc5UNWCkL/AhDavXu3ClmePHnC+vXrGTBgAHXr1sXT0xM/Pz+mTp2qPJvk5GSlzK1atSrjx49n5syZjBo1inbt2hEREcHKlSvVYFy8eDGrVq1SNWM5OTlMnjwZa2tr1Z6juLiYgwcPMnv2bFq1asX169cZMWIEbdu2pbi4mOjoaHx8fBRnASXtZQ1hooWFBUZGRjRt2pSaNWsyZcoUPvroI/R6PStWrODEiRO4uroiIjRo0EA9B5TUPDk7O2Nubk61atXQ6/U8efJENdsfPnw4aWlpapAawoTWrVtTuXJlleo3DOB79+7RoUMHrl+/rkh4Q4+gXr16odPpmDt3LuXLl2fRokXcuXMHGxsbatWqRZkyZXjy5AnLly/n2LFjREREKNBo2bIl5ubm+Pv7k5eXx7Fjx2jWrBkLFiwgMTGRvn37IiKYmppSq1YtVQXu4uKiQMje3h4omWRLliyhTp06KhkRGRlJo0aN+Oabb5g9ezadOnVSbWIB7O3tycjIID09nTZt2lC5cmW+/vprLCwscHR0ZOnSpVSvXh07OzvKli3LiRMnAJTEQa/Xc/78eYyMjKhUqRKrVq2iXLlyVKpUiYoVK6rwsly5coSEhKDX67l48SJVq1bF1tZW9TfPysqiVq1adOjQgX379iml+C+//EJaWhpeXl6kpaVhZGT0uxat/v7+qtVugwYNePTokSLLDR0FflvSYeia8CErBaF/AQjNmjULCwsL9f+3bt363Y8xePBgbGxs8PT0pLCwkIMHDxIUFESTJk3o168f6enpTJkyRdVtiQjly5fH1dUVT09POnbsSFJSEvXr16dLly4cO3aMmTNnYmtrS/ny5blw4QK//vorN27cYMyYMSre1+v1vHjxgnfv3inewJDSh5IWrj179sTe3p6vv/6asmXL0qxZM4yMjEhMTFT9qaOjo3F0dFT8lUhJlX3Xrl2VyjgwMJBPPvmEU6dO8eTJE6VN0mg06PV6jh07xuLFi9m+fTuurq5UqVKFUaNGsXnzZry8vMjPz2fv3r00bdqUYcOGkZycTGRkJLa2tnh7e+Pt7U1ubq6q2UpLSyMpKUn19XZ3d2f79u0q/Fi/fj27d+/G1dWVCxcuqL9cIVLSZtagozIA8MmTJwkNDcXCwkIpu8uVK8f8+fNp1KgRQ4YMoWHDhhgZGTFlyhTKly9Pu3bt0Gq1agI+efKETZs20b17d6pVq6a8kpkzZyqCOzExEa1Wq8puDN8xtHuNjIxk3LhxjBs3jg0bNgAlqulLly79Tk+1f/9+pU1q3bo1nTt3VkmIuLg4ZsyYwe3btzlx4gS1atWifPnyLFy4kAMHDrBhwwZu3bpFUVERAwYMYMCAAZiamqoiaoOdOnUKV1dXjh8/zp49e8jLy+OLL77g008/VfKRH374QWVqoQR4cnJyOHDgwL9VMf2nA8P/y88fAaF169ZRUFBATk4OiYmJxMXFqYxNVlYWTk5OFBYWKpGZj48PxcXFqjUDoDQzCQkJPH78GAcHB+rXr8/WrVsJDw/n+fPnREVFsX//fo4cOcK3337LmzdvVI1W//791SrVunVrIiMjycjIwMvLi8OHD3Ps2DHGjBnD8OHDVW/jRo0aqYlpmAx/+ctfaN++PQ8ePODmzZs0a9aMK1eu0KRJE7Zt20ZxcTGenp7Mnj1bcWBQwknY2try/fffKwGhiNChQwfu3LmjSGQLCwtVCT9jxgySk5PR6/VMnToVT09PJk+ezL179zhz5gwTJ05UPNaVK1eAEuL97t27JCUlKUHls2fPSElJYdOmTapLo7+/v2p0f/jwYZXhM3gzLi4uREVFUb58eQyarcOHD+Pq6kpubi7Z2dmMGjWKn3/+Wf3ZJEOxpuE8H3/8MU5OTkRERPDgwQMmTpyItbU1z54948SJE0yfPl2JOEeOHEmXLl2YMmUKV69eJSAggKioKJo3b07Hjh25e/eu6hll4GyMjIy4dOkS9+/fp3LlysybN0/pj6ysrPD39+fRo0c4Ozsrr7R9+/aYmJgQFxenio4vXLjAhAkTsLS0VKGVAfQAVcKzbds2li1bRmxsLCNGjKBq1aoqVMvNzSUqKgoRUTo3Gxsb6tatq4D/7du3pKWl8ebNG6Kjo5WH+yErBaF/AQgZtBmBgYH4+flhbGzM6NGjKSgoYMeOHQQFBZGRkYG3tzdOTk74+PiQnJxMYWEhY8eOVenZbdu2qYFhaEienp5OYWEh8+fPZ8+ePUqxmpSUxP3799HpdMTGxvLDDz9w/fp15s6dq5S5mZmZ2NjYcPfuXRXaffXVVwQFBanwxlBIaggNDepXQ88aAwFtYWGhFOFpaWls27aNXbt20adPH7VCG8IJkZKuiHl5eTx48IDo6GguX76slOQGXkmkpGPinTt3mDhxIhMmTFBiPyipGC8sLFRN4H18fPD392fMmDGK5DZ0F9TpdDRo0IDNmzcDf22FC6hm+QbRYVxcHDk5OXzyySdoNBpatWrFwYMHuXjxIrVr11a/58KFC9W9xMbGUqFCBbZs2aIA1ZBiB/Dy8lKdCXft2sWJEyc4deoU8+fPx9ramrJlyzJq1Ci8vb3JyMggMzOTMWPGMGnSJMaOHcuzZ88AlEBy/PjxtGvXjt69e6uG8i9evFDZwZiYGOzs7HBycmLbtm1cuHCBe/fuASV/feTNmzc4OjrStm1bpY5etWqV+pNQM2fOVCLEZcuWcfPmTXx8fKhXrx5nz55lz549eHp6smTJEl6+fElWVhYeHh4UFRXh7+9PnTp1ePv27e8kAe/evWPOnDmYmJjg6+urOgh8yEpB6F8AQj179iQtLY1y5cphbGysPtnZ2eh0Onbv3k1MzP9h7z2josq2NdBZ5IwERVBRQARJJsyNBFHERsSGNmFAUERFEW1MIMGIKAIKKqKogAkTtoABFAygiBgwIFkRiYLkWMX3fpS1jpx3zm373tP3vTtG7zH2aJuqvWtX7bXmnmvOL5SwmkhDQwN+/fVXODk5sdRW0KZ/8uQJsrKykJSUhNjYWBgaGkJHRwfDhw8HwA90mpqabEILdJZXrFiBZ8+eISQkBJaWlmhra2O1l6KiIpw7dw5TpkzBgQMH8PHjR3h6eiIpKYkVRSUlJRnpFfgH4ldNTQ3m5uZQVVWF4Ld48+YNTp48ia6uLjx8+JDVHwTyHD/99BO2bduGjo4OpKSkoK6ujslgfL+PGTMGwcHBLCAREfNKS09Px+LFi6Grq8t0jEJCQlhm1NHRgebmZkyfPh36+vpoamrChQsXsH//flRXV2Px4sUwNjZGYGBgL3EtATzAxMQEmZmZaGxsxKZNm/Dbb7/B3NwcDx8+xIgRI+Dn5wdnZ2fk5eWxYCYo2M+bNw8cDgepqal49+4dysvLERYWBkNDQ5w+fZphoQTFaUF3NDExEUlJSTh79iwLRgAf0dzZ2Ynw8HC8e/cOgYGBEBMTY0YAM2fOZFnF0qVLWXHc09MTwsLCvdQWqqurYWdn16uYbmJiAmFhYRw6dAhEBCkpKYwePRrOzs4g4lNtbt68iYyMDNZdXblyJRITE/HgwQPo6OgA+EfNTjCOo6KiWAPA2dkZK1euRHV1NVpbW5Gfn9/LiPK/2v4OQv+BIPTbb7+hqKiIadgYGhpCS0uLwepNTEwwevRozJ49m6FKAb4cggDuL9gNDAxQ+s2VVVhYmP3d0NAQN27cYFKdvr6+TCaiPxl4CQAAIABJREFUsLAQ/fr1Q1paGuv2PHz4EC9fvkR+fj4rjH5PJQD4g+njx49QV1dHVFQUXr16xTo2bW1taGtrY8JUcXFxrPu2bt06dq6mpib2HoFWsoKCAsLCwti5YmNjsW3bNggJCTGgpbq6OnuqDxw4EJ6ensjIyEBubi7y8vLg6enJ2vU1NTW4e/duL4ufqKgo9OvXD5KSknBwcEBYWBjs7OzYtaSkpEBERASioqL4+vUrPn/+DCcnJ1hbW8PY2Bhr1qyBjY0Nzp49CyJiHc34+HhISkoiOTkZkZGRTNK1u7sbSUlJePPmDQwNDSEiIoIPHz7A0tISO3fuBMAv0I8cORLBwcEIDQ3FoEGDsHLlSqxbtw6Kioo4dOgQtm/fjoSEBBZMX716BU1NTQgJCSEsLAz6+vpITExkwUdJSQnx8fHst7x16xbi4+Ph7e2NQYMGYcCAATA1NUVWVhYKCwsZNOLu3btYtmwZLly4wDqUgrExcOBAZGVlYcmSJdi0aRMOHTqE6upqdHR0oLy8nNE4REVF0adPHygpKbF2+/e6RIMHD8aAAQOwe/durF27FrGxsaipqWEsgL+VFf8Xg9DDhw9RUlLCblBAQAB27NgBDQ0NBAcHw8LCApcuXcKaNWugp6fH3EMFOi7i4uLo378/REVF8eTJE2azc/PmTbi5uWHo0KF4/vw5SktLMXToUFy+fBnV1dXIzMxkHQ9PT08UFBSgqKgIT548QUREBLPlXbZsGSNmvnjxArW1taiqqkJOTg6rU0VGRmLdunU4efIkampqUFhYCB6Ph48fP6K9vR3r16/HrVu30NTUBBMTE5w4cYLJUNTV1cHS0hLv3r1j2RARMbAdACgqKiIzM5NlBSIiIlBVVYWVlRUUFBQwaNAgFBYW4tixYxAVFUVZWRl8fHwwe/ZsRiYF+MuQZ8+eISgoCOXl5SguLsbYsWOxc+dOiIqKYvny5QzK0L9/fyQlJUFGRobJbQha30ZGRjAzM0NjYyO2bNmC7OxsfPr0CbW1tTA1NcWuXbtw79495Obmoquri+n8fPnyBRkZGViwYEGvdv2nT5/w8uVLVgsT7G5ubkhKSsL69evh7OwMCwsLeHl5gcfjMfS3iooKpKSkYGlpCTMzM3h4eKCiooL5x12+fBkFBQWQkZGBtrY2tmzZwlQUx40bxx4ygrpQd3c3fv/9d4ZsHj58OCwsLBAdHQ15eXkICwszDlh8fDx4PB5z1hB0I5ctW4bAwEBG5QgNDe2lDyQQ2hMcJ5AYaW9vx969exEaGopp06b94dwB/ntBSIT+3npt/fr1o/79+5OoqCjduXOHFBUVSUhIiMzMzEhRUZHCwsLI0dGReDwekz3o7Oyk0tJScnFxIQsLC9q/fz+tXbuWwsLCKDs7myoqKig9PZ3CwsJITEyMOjs7SVxcnPLy8ojD4ZCwsDCVlpZSbGws9enTh+Li4khBQYGio6PJ2dmZurq6KCYmhoiIrly5QlZWVvT161eSlJSkESNGUE9PD50/f54WLlxIOTk5pKmpSUuXLiV3d3datGgRiYuLU1NTE61atYr27dtH2traNGjQIJKVlaV9+/aRqqoqmZqaUt++fUldXZ3U1NTIwMCAJk2aRPr6+pSXl0c1NTVERJSVlUXa2tr05MkTmj17Nl26dIkUFBSovLycfH19qaSkhMTFxUlGRoZWrlxJ58+fp5CQEOrp6SElJSVSV1cnY2NjcnBwoAsXLpCkpCTJycnRr7/+ShUVFdTc3Exnz56lwMBA0tDQoObmZsrNzaVjx46RhYUF1dfX09OnT+ny5cuko6NDCxcuJDk5OVq4cCEJCQnR8uXLadCgQcTj8aizs5Pq6upIRESEgoODycvLi5qbm+ncuXO0YsUK+vDhA40YMYK2bNlC4uLixOVyKSQkhIYOHUp2dnaUlJREO3fupKysLOrp6aHbt28Tl8uliooK8vPzIzk5OQoMDKT09HTKz8+n3NxcIiJqa2ujNWvWUN++fcnQ0JAmTpxIbW1ttGXLFnJwcCAJCQnq7u6mFStWkJeXF5mbm9PChQvJxMSEPn/+TK9evSIjIyN2rqamJiYPkpeXR+7u7jRq1ChasmQJxcTEUHx8PJWXl9OkSZOIw+GQsrIyzZw5k968eUMLFy4kRUVF2rNnDy1atIiePn1KCQkJVFVVRURETU1NdPDgQSZhoqysTBUVFRQYGEgGBga0bt06GjVqFLW1tf1lc+7vIPRPm0D3pqGhgcrKysjJyYkkJCRISUmJ6urqqL6+nnJzc2nx4sVkYmJCP//8MyUmJtLs2bPp+fPn9OzZM7p//z7Nnj2b2tvbacmSJVRfX0+ZmZlkZGREbW1tJCwsTJ2dnVRbW0syMjIkIiJC8vLypK6uThkZGbRixQry8fHhPyVEREhaWpqys7MpJiaGli5dSt3d3XTu3DkaMmQIC2Lr16+n33//nYyMjEhcXJwAkIuLC505c4bmz59PMjIyJCkpSZ6enjRx4kTS0NCg1tZWUlBQoCFDhtCRI0fIxsaGJCUladeuXWRvb0+fPn0iDodDWVlZ5ObmRsXFxZSTk0OOjo60c+dOkpeXpzt37hCXy6WEhARqb2+n+/fv05o1ayggIICcnZ3pp59+on379hGXyyVlZWXq6uoiGRkZqqyspKysLKqoqCBlZWUSExMjDQ0NGjduHD1//pzGjBlDJ0+epM+fP5Ouri5NnDiRenp6qLGxkZYtW0bnz5+nMWPGUEVFBdXV1VFwcDA1NzeTmZkZTZkyhezt7enatWv05s0bunHjBtXX15OVlRWpqKiQj48P0+nhcDikr69PXC6XYmNjSUREhBQVFam7u5vGjh1LgwcPpurqatLV1aW7d+/SiRMniIjI2NiYjI2NycDAgG7fvk0LFiwgFRUVsrOzoz59+hCXy6WMjAwiIgoKCqL8/Hz67bff6JdffqGxY8eSp6cniYqK0uvXr4mI6P79+3T//n0SFRWlqKgo8vX1JVFRUTp//jxFRUWx8cnhcKilpYUyMzPp0KFDNHfuXCoqKqKnT5+So6Mj/fzzz1RWVkalpaVUU1NDV69epTlz5pCcnBwdOXKExo0bR1wul1asWEFRUVH05s0bampqopqaGnr06BHp6OhQQEAARUVFkYODAzk5OZGdnR0NHz78r5t0fzZ1+r+8/8hy7OLFi2z9GxcXx1J0LpeLtLQ0RqA0NjZGVVUVs/kdPXo0wsLCcP78ebx48QIjR47EokWLmDa0wH00ICAAJ0+eRFpaGvOIF9RnMjIykJCQgJMnTzJemZ6eHmPNFxcXM4LozZs3mfxpcnIyXr58CVlZWYiLi2PTpk24dOkSAgMDERkZifHjx0NPTw9mZmasXiIo0I4ePRrp6emMZiHAg1y4cAEXL15ETEwM5s2bh8TERJiamuLq1atYt24dpk6d2su0D+DTKBobGxEYGIiwsDDExsbC2toau3btwr59+zBu3DjExsYyj3gBTSU7Oxu1tbWora2Ft7c3vLy82O88bNgwHDx4EDdu3MDo0aMREBAAISEhyMvL49y5c/D29kZERATy8/ORkJDAlk59+/aFn58f6+4UFRVBW1sbJiYmsLS0BBHBx8cHixYtQmNjI9ra2hiQ0tHREbq6uti+fTu6urpw4cIFrFy5EkQEa2tr7N27l31nAYPe2NgYAF9Cd+fOnfD09ISYmBiT3QUAa2trZuvD4/FQUVGBNWvWID4+Hm5ubnBzc0NERATCw8Nx+vRpxvnav38/Xrx4gUePHvXCn7W2trLxGRgYiP79++P333/HqVOnEB4eDj8/P9A3gGx4eDhCQ0PR09ODCxcu4NOnT8jNzUVFRQXKyspYDRPga4mPHz8eW7ZsQVJSElpaWljX7I82+rsm9D8PQsnJyRg5ciROnTqFzs5ONlkBsDa3mZkZw4w4ODhg4MCBjMA5duxY9OnTBx8+fEB7ezsuXbrEQIUvX75EZ2cnw2ucPHkS0tLS8PLywqhRo3Dnzh1kZGSwWktOTg7ev3/fy9543LhxSElJwdevX9Hd3Y27d+8iMTGR1W8EkiECk7+DBw+irKyMdUWeP38OFRUV7N+/H9HR0awWoampiVWrVsHZ2Rn19fWsPd7e3o6ysjIMHDiQWRoLJoGEhAS8vLzw7NkzVsCMiIiAlZUVhIWFmXMH8A8RNPpWW6FvnZ5z584xXzR3d3eGLD5//jy2bNmCNWvWQFZWlhWkk5OTQcT3eNPX10dERAQuX76Me/fuoW/fvjAyMoK9vT22bt0KKysriIqK4sWLF6x43NPTA3d3dxDxjf8yMzPh6uqKzs5OjB8/HlZWVoiIiGCwh+LiYhw/fhyXLl2CtLQ0xo8fz7hhjx8/xsaNG+Hq6ora2lrG37tx4wZ6enowevRo6OnpoaqqCtnZ2QgKCkJpaSkKCwsRGBgIV1dX9O3bF7dv30ZhYSEGDhyIgIAAHDhwgPHq8vPzERoayh6MQUFB+P3333H58mVWw3n48CEDGnp5eaG4uBjFxcV4//49vn79io8fP6K7uxuZmZn48uUL0tLSMHfuXGhoaMDQ0BCJiYmYNGkSjhw5gq6uLpw+fRrr16/H7t27GSpfQNP5o+2/E4T+Xo7909bY2EgrVqwgERH+T2Nubk5v374lAwMDmjp1KpWUlFB8fDw1NDTQrl276MyZM1RbW0uHDx+m1atX0+rVq6mkpIQAUFVVFTk4ONDly5fp06dPlJ+fT4aGhpSenk5SUlJUXFxMS5cuJWlpaXrx4gXNnTuXGhoayNzcnExNTUlXV5ckJCSIiJ+Gd3d305o1a6impob69OlDREQTJ06kr1+/kqioKK1bt46UlZWpvr6eQkNDSVxcnCwtLenRo0c0ZMgQ4nK5JCYmRo2NjeTj40P79u0jCwsLunfvHj179ozGjBlDfn5+VFRURKamplRfX08yMjI0YMAAcnd3Jz8/Pzp8+DANHTqUvn79SuLi4vT8+XMSEREhKysrevHiBTU3N5OkpCQpKSnR5cuXydjYmKSlpenixYv0+PFjEhERoTNnzhARUU1NDSkqKpKhoSGlpqZSUFAQnT17lvT09Oj69es0d+5c4nK5pKWlRfn5+aShocFqE5qamvT27Vu6ffs2nT59mhQUFGjfvn20du1aJpH65s0b6tevH7m6ulJKSgrJysqSkJAQ7d27l2RlZalfv34UGhpKgwYNomfPnlFRURFt27aNZs6cSU1NTXT48GEaNmwY8Xg8EhMTo+7ubsrKyiJDQ0NSVVWl7u5umjBhAn369Inq6upIVFSUhIWFqaSkhJSUlEhRUZGKioqIiKhPnz4kKipKQ4YMoa6uLnJxcSETExPq6ekhKysrkpKSoitXrtCkSZPozZs3NH78eCIiunv3Lj158oS8vb3Jw8OD/P39SVRUlIiIrK2t2dJx1apV5ObmRllZWVRYWEhWVlb09u1bOnfuHE2cOJHKy8tp8uTJNG/ePHJxcSFTU1NSU1MjZWVlSklJITk5OVq1ahU1NzeTk5MTycnJUVNTE1VUVNCyZctITk6OVFRU/ppJ92ej1v/l/Ucyoe3bt2PAgAGQkJDoRW3Q0dFBcXExIiIicPPmTXh5eWHWrFmYM2cOEhIS0Nrail27diE/P5+5knp5eeHGjRvo168fHBwcsHbtWpw+fboXOO7AgQPMNYO+ZReHDx9mUqBaWlq4dOkS6urq0N3dDSK+9EJhYSGys7NRU1MDCQkJXL58Gfv374ekpCSTCV2wYAGqq6vh4+PDcEEdHR1oaGhAc3MzQ2irqqriy5cvaGtrg6ysLPT19QHwbYVXr14Nb29vTJ06FREREUhNTcXNmzcxe/ZsREZGYvr06VBUVGRMbAkJCUhISDBJUwFQU0JCAsbGxpgzZw77rt9nSqWlpbCxsYGmpiZ73djYmMEGAgICAPAJoBYWFsz+WkJCAuvXr8fnz58xbtw4tLa24u3bt5g8eTLi4+Mxd+5cyMnJMb6bq6srjh49itjYWJYtVFVVITAwkH1uamoqCgsLsWzZMhBRry6ZgoIC8yjr7u6GkZERdu7ciVu3bjEA6Pv37yEkJAQJCQk4OTnB1NQUM2bMwLFjx5CTk/P/WjqKi4tDSEgIv//+OwC+smFPTw/u3LmDGTNmMLGyRYsW4cmTJ1i2bBkOHDgAd3d3/PLLL3B3d4e4uDhcXV2ZlpWVlRVr9bu7u+P169cYMWIEYmNj8ebNG1y9ehUNDQ1M9XHw4MFob28Hj8eDn58fUxIYNWoU+vfvjzVr1vzh3AH+e5nQ/+eB4X9z/5Eg9D1r3tvbGw4ODvDw8MDLly9RUVGB7OxsJrMA8AdMW1sbfvvtN6SnpzMQmbm5OQMPysrKMolXQRt60aJFDIVaXV3N+ElCQkLQ09PDzJkzsXXrVowZM4Zp51y8eJFp0QhQrgCwbNkycLlclJaWYuPGjUxX6OjRo8jIyMCXL18YKvl7A8L29nY8f/4ca9aswfDhw2FkZMQm9vbt2+Hn54c9e/Zg6NChkJeXR1RUFJ49ewZfX18AfOyIIJi2t7fjwYMHMDIyQkREBLZt24aEhAScO3cOe/fuRUBAAI4ePYrw8HAcOHAAV69eZUGQy+Uyka309HTcunULysrKEBERgYiICMLDwyEqKgpLS0sAfIa7oGakqKiIefPmQUZGBoMGDUJ1dTVjiAvgB+Hh4ejq6sK8efOgqqqKHTt2oKysjKlorlq1Ch8/fsTSpUthYGCA7OxshIeHIyQkBK6urnj27BnU1dVhaWmJcePGQUxMjHH6hg4diitXrmDHjh24d+8e/P394eLigqVLl0JISAgPHz7E0aNHGR1CINkhLCwMaWlpREVFoby8HJGRkTA1NYW0tDSr9ezduxcNDQ3o7u5mOk8Af6nav39/jBgxAp8/f2alATc3NzQ1NTEKz4QJE5CYmIhNmzbh6tWr4PF44HK5uHjxIkNknzt3DmvXrkViYiLmzJnDZEDq6+vR1dWF3NxcDBo0iJlZ/tH2dxD6DwShkSNHQkpKCrdu3UJAQAC4XC576hIRK8YKpD6bmprQ1dXFUKWhoaEMydrT08MsgMaMGYPx48fj+PHjePLkCZNeEEh+nDp1Cl1dXejo6GBUAnNzc0aV6OzsRGNjI7P9Wb9+PRNb4/F4GD16NBQVFTF8+HCYmprCw8MDAwcOxOjRowGA2fUAfF5QQEAAZGVlWX1EsFtZWbEsT1FREWJiYtixYweKiop6AQxDQ0NZppCUlMR82p2cnLB7924cO3aMTfI1a9bA19cX1tbWiIiIYI6sgutqaWnB48ePsWHDBrx58wYfP36Eu7s702/evn07E2UbPXo0qqursWbNGkyePBm7d+/GnDlzGG9MoAgpeP+8efOwdetWfPjwAQ8fPsT8+fMZBkxwX42MjHD8+HGEhITgwIEDOHHiBFatWoWnT58yTR91dXXIyckhJiYGHA4HHA4Hb9++xZMnT3Dr1i0Q8VUBli1bBhEREaSkpKCoqAg8Hg/FxcUQFRVFZ2cnzpw5AxUVFSgqKuL27dtsHOzduxeLFy+GmJgY/Pz8EBISgmXLljGnX4FpAMCvrwnE2gBgxowZDCibk5OD4OBgSEhI9EKvq6ur49ixY2hvb2fGmV++fMH9+/dZvaykpARfv37FhAkTmEa2ABR56tSpP5w7wN9B6D8ShNLT0xnn6dGjRzhx4gRWrFiB4cOHo2/fvli0aBGio6NhZWUFFRUVXL16FePHj2eSnB0dHZCVlYWOjg40NTUxadIkHDt2DLm5uTA3NweHw8GjR4/w8OFDjB49Gj/99BOmTp3KOE4Cv/nBgwdj69atmDp1KjgcDo4ePYqjR48yuH1RURFiYmIwe/ZsjB8/HkuXLoWlpSXU1dVha2uL4OBgVqS+fv06SkpK0NraiqqqKtja2jLw29ChQxEQEABbW1tER0dDT0+PBZvIyEiG8P5n1ceYmBjm5uHi4sIKygKwI8DnH4mIiMDe3p5RWq5fv86UIgXfV7BVVFSwLE5XVxfe3t7Q09PrhTZXU1Nj19K/f39ER0f38rOXlpaGqakpWwYKXps8eTL69evHlDNDQkIQEBAADofDlj+PHz+GiooKzM3NGapY0P2Ul5eHtLQ0fv31V4wdO5ahnGVkZBiJl4jv6BoeHo6SkhJ0d3dj2LBhkJWVxZgxY1BVVYWtW7cyLezvt6lTp7KgWV5ezrSqBJuA5Pv27VtcuXIFRkZG+PLlC0pKSuDv7w8bGxvs378fN27cwKpVq3ot9fT19SEkJMRkSkJDQ6Gurs60ogD+Q1UwxoSFhbFv3z4GmFy+fDmjFP3R9ncQ+g8Foe/pEIIajkBqQV5eHtHR0TAyMoKysjJGjBgBImJC893d3UhPTwcALFq0CFFRUaxDUVtbiy1btqCgoIC154kIt2/fRk9PD2pra9lkVVBQgKmpKRYsWAB5eXns2bMHFy5cQHd3N96/f4+cnJxe5Mthw4YB4HdKLCwssHnzZrZUMDMzw86dOzFlyhQICwszYuq2bdsAgImkA3z9n8OHD+PDhw+wtrZGnz590LdvX3z8+BEJCQlob29novwAP3AUFRWhuLgYBQUFWLNmDUxMTPD69WukpKSwYPf9vmDBAib+duvWLfa07+rqQkREBPr06dMr8KioqKC5uRknTpxgXbtjx46BiDBt2jT89NNPIOLr4kRGRiIyMhJXrlyBg4MD9u/fj927d7OJef78eSQkJCAjIwPp6emIi4vD7du32YS7e/cuMjMzmf30sGHDQETMf97KygqTJ08GAEyfPh1qampMx0lRUZGRYPPz8/Hx40esXr0atra24HK5OHjwIGxsbNDd3c26VYItNDQUenp62LdvHxt/7969g5+fH549ewYNDQ0YGBggNjYWp06dwvbt29m5ampq2IMjLCwMHz58QGdnJ5KSkpjUiaBTyuPx2Lixs7Njny9QK8jMzOwl5crlcnH79m3mNvNH299B6D8QhJ4+fQqAXwDt7OxEbW0tYmNj8fjxY9jY2GDJkiXgcrlobm7G+/fvAQBqamqwt7fH+vXrER4ezs51/fp1AHwtl5SUFHR1daGwsBCtra24d+8erl27xmQYurq68PTpU9TW1iI6Ohrt7e2Ijo7G169f4erqioiICOzfvx8aGhqQlpaGkJAQ42SZmpqyTKq0tBTCwsKws7NDamoqDhw4ACI+x8jExIQVWcPCwrB9+3bk5+dj8uTJMDAwQHBwMIMhCPzIBU/5/v37Q1tbG6GhoVBUVMTEiRPR1dWFzMxMFBYW4vTp0xATE4O0tDRcXV2xYcMGTJ48mTk+bNq0CaampowISkS9nFc3b97MRNIEjhnfB6GGhgYsX74cSkpK8PLygqqqKgtESkpKmDZtGpM5+Z7xLRCml5KSAhEf5yPAYBUWFjIlwT179uD9+/dMyxsAnJycmAsuETEaztixYxEcHIyYmBhISEhAWFgYEyZMwN69e+Hl5YVt27bB3d0dS5YsAcDPDmtraxEUFMSExb5+/YqAgABEREQgNDQUxsbGSEtLw4ULF8Dj8XDt2jV4eHgw7ah58+bh+PHjqKurQ2trK1t+CcTua2tr8fnzZwwaNIhhegRLwfXr10NVVZVl+EFBQRAXF0dcXBwePHiARYsWYe/evfj8+TOmTJmCESNGIDQ0FK6urpgzZw7i4uKQkZHxh3MH+DsI/UeC0P3793Hnzh2IiIjAwsICWVlZOHLkCLy8vJCXl4fm5mb4+PjAw8MD3t7ezHAvNTUVoqKiUFZWxtevX5GXl4dZs2YhJSUFa9euBRHfd+rz588A+MDEW7dugcfjwdXVFVwul0l7ZGZmory8nA2a/Px83L17F2FhYQyHY21tjfHjx8PJyQmWlpbYsmULVq9ezQS2BB5dlZWVcHFxwePHjwHwJ0RmZiYCAwPR1taG+fPng4iY9rMg29uxYwfu37+PxsZGbNy4ERkZGZCUlASHw2HB48SJE4iNjcW0adPQr18/BAQEsA6Pjo4OK5guXrwYXC4XGzZswNGjR0HEl6JYvXo1pKWlYWdnBzExMURGRjJMlKDbpqKiwpZZgu81fPhwNjnj4+PRr18/bN68GV+/fkVXVxcUFRWhra2N1tZWFBQUwNDQEEJCQtDR0cHy5ctRWFiI8+fPM8nSjo4ODBs2DPX19WhtbcWzZ896LUXXrl0LJSUlbN68GYGBgaisrMT58+dZ/UlQzBf8m8PhYOXKlUhNTUVkZCTrvHl4eCAmJgZpaWnMMOC3337D3r17MWTIEBARnJ2dcebMGSQnJyMzM5M1FIqLi7F9+3Y0NzcjPT0ddXV1ePXqFdrb21n9sq2tjTVDpk2bBktLS4iLi2Pr1q349OkTqz9FRUWx7LOpqYk9pHg8HiOuPn78GLq6uqwm9CNzB/g7CP1HglB2djZzVlBWVu61nBBIsr548QJ2dnYsRU9NTQUAODs7w8HBAW1tbdDU1ISXlxcAflo9efJk9jTR0dHBnDlzMGPGDFYDsbCwwKhRoyArKwtNTU0cOHCAyXcI7GYEaFqBg0NZWRmqqqqwbt06hhp+9eoVpKSkWMazceNGEPGte0pLS/HLL79g+PDhrEjd1taGmzdvYsWKFWxZMWTIEJw6dQrV1dWoqqpirG+BXk5rays+ffqEc+fO4f3797h9+zZiY2OZMqG/vz9rfYuKimLw4MFwcnKCmJgYTp06hZEjRwLgi6dZWlpCRkaGZSQAHxgXHByMuLg4xMTEwMTEhIFIb9++jYyMDERGRiI5ORk6Ojrw8fHBnDlzmCIhwBdOu3nzJvbv3487d+7g5MmTuHfvHpKSkgAAFhYWmDZtGqqrqxEfHw93d3eEhYXBycmJMdUFzrhGRkb4/fffWRH/+vXrKCgogJqaGmbNmoXff/8dixYtgry8PMaNG8ekN+zs7NDT08PGT2VlJYj4LH9ZWVm48fNrAAAgAElEQVSIiIjA1NQUERERbBxs27aN3XfBsjk+Ph4WFhZMnTE/Px8pKSl4/PgxI7i+ePECXC4Xrq6uWL16NevIysnJITMzE/n5+azG9ObNG/ZbV1ZWwtbWFoqKinj16hU6OjpQUlKClJQUxMfHIyAgAE5OTux3+6PtvxOE/gYr/tPG4XBIXl6e0tPTaeDAgdTd3U0zZswgGxsbamhoIAA0bNgw+umnnyghIYGWLFlCampqRETk5eVF5eXlFBkZSUlJSfT06VPq7OwkMTExOnnyJHl7e1NzczMVFhbS+/fvqa2tjR49ekQAqLa2loYOHUoTJ04kaWlpEhISoi1bttCGDRsoLy+P6uvrSV1dnerq6pgv+KBBg6ijo4NMTExoxowZ9ODBA1JUVKS2tjYSEREhLpdLeXl5pKGhQerq6uTs7ExpaWnE4XAoKSmJjIyMiMvlkqysLK1bt46IiD58+ECjRo2i8vJyCggIIH19fVJTU6ORI0fSx48fycnJiXp6eig3N5cWLlxIjx49ounTp1NBQQE1NTWRnp4e+fr6UlVVFSkoKJCDgwMVFBTQpUuXaOLEiVRUVEQ1NTW0b98+evr0KaWmppKNjQ2NHz+ePn36RGvXrqUnT55QdXU1aWpqUklJCeXl5ZGuri5dunSJHj16RGVlZRQZGUnp6elkbGxMO3fuZHyzAQMG0IcPH2jAgAHk5OREeXl5tGHDBurfvz8VFxdTeno6TZo0ibS0tOjMmTOkoqJC48aNo+7ubnr16hX16dOH7Ozs6ObNm+To6EiKiop06dIl2rRpE3l7e1NhYSGNGTOG1NTUqKCggO7evUuzZs0iMTEx8vb2JlFRUVJWVqZnz57R0aNHqaCggKZPn07a2trUt29fcnFxYZ/v6elJtbW11NDQQFJSUnT+/Hn65ZdfSExMjLZt20bd3d2kra1NPj4+VFpaSmlpadTZ2Unr1q2j169fU0FBAaWlpZG/vz9lZGQQj8cjf39/UlVVJW1tbVJTU6OrV69SUlISDRs2jIYNG0aVlZX04MED0tDQoJaWFjp9+jQ5OjrS5s2bycjIiEpKSigzM5MMDQ3J0tKSABCHw6Hg4GCaOXPmXzPp/mzU+r+8/0gm9OLFCzQ2NuLatWu9isdxcXFobGzEzp07ce/ePejq6kJaWhonTpxAWVlZr2L2rl270NLSwlqkqampTMph2LBh6N+/P+zt7TFz5kyoqamhp6eHPcFNTEzg7e0NZ2dnhISEMPO8srIylr00NTWBy+XC0tISs2bNYrWpc+fO4fDhwxATE4OqqirGjh3LrquqqgqRkZEwMDCAjY0NlJWVWfdMoGvUr18/BAcH4/LlywD44vmnT59mnRwbGxsICwszDZt169YhPz+fFdonTZoEOzs7XLt2DWpqagywZ2pqyigb9K3zNXLkSJibm+Ply5doamrCxYsX4ejoiFmzZjHfNnV1dYwfPx4NDQ24du0aw78YGBiAy+UiKCiILe18fHwQGBgIUVFR2NnZMYVLwXnOnTsHOzs7lskIAIAcDodRNAS7IPtdunQpAL5nmkDs7NWrV+w+l5aWYsyYMUzzR9Dpi4uLg52dHd6+fcvULqWlpfHq1SvWdWtvb8fNmzfZMQIcUUZGBs6cOYOOjo5ey2XBLrjHDx8+ZBAJXV1dlo0DYKJ02dnZzLxSQkICZmZmjCIj+FwBRUhHRwdLlixh0rljxoxhYxLgc+R+ZKO/l2P/8yDk5uaGCxcuoKurC+3t7RgwYAB0dHTA4/EYgtrLywvV1dW4efMmW77k5ubi/fv3SExMxN69e5mljrq6Onx9fZkKoKioKLZv3w4ZGRnMmTMHtra2bNJv3LgR8+bNQ3x8PIgIWlpacHBwwJUrV8Dj8ZCYmMjIrAIuT0tLC/z9/TFx4kS0trbi5cuXyMrKQk9PD44cOYKysjI0NjZi3LhxMDAwwPz589nAO3jwIGbNmsXIq0SEa9euYeHChSgqKmLE2sDAQBw9ehRXrlxhLW9hYWH06dMH8vLyICIsXLiQ6WLr6OiwgvT3u4iICGRkZHoJZB0+fBgNDQ04efIkI5MuWLCABYaUlBT89ttvvc6jr6+PoUOHYs+ePdi9ezdkZGQQHx+P3Nxc9h6BDKqioiJu3LiBu3fvwsTEBFOmTIGVlRWI+JijwMBAVm8SBAwREREYGBiAiHDp0iWsW7cOQkJCmDBhAiorK9HS0oKenh6Ul5eD6B/YJCMjI9y+fRuSkpKsCN2/f3+MGzeOKW0CfLBhS0sLPn36hKqqKty6dYupOgqW9ACfa5icnMxApKqqqigrK2OaUWVlZRg0aBCEhISwbNkyvHv3DpcvX4abmxtbWiUmJmLw4MEMwb5y5UoUFxfD19cXM2fOhKioKIMhCJZ/UlJSkJWVhZmZGVpbW7F9+3YoKyv/4dwB/heCEBENJKJoIqogok4i+kBEoUSk8IPHm/3zwPw3+6B/Ou6/eu+TH73+HwlCpqamUFRUxIIFC1BRUcGwFD09PaipqcH+/ftRXl6OL1++sMFsbGyMlpYW2NjYYPTo0XB1dYWYmBj2798PHx8fEFEvuoKjoyNiYmKYIysRn70uJCSElStXIi4uDp6ensjKyoKLiws4HA5u377Nnpbv3r1DU1MTy3J0dXUxZ84crFixAgMGDGDGeo8fP2aCWWfPnsXVq1fR2dmJ8+fP96JBCAaywBZn165d7AmrrKzMiq4lJSWYO3cuY+t/fx9GjRrVCy/j4uICFxcXTJkyBUOGDIG1tTVmz54NTU3NXuBHgYfbnTt3AIAJdGVkZDDYQ319PYNCvH37lt2rCxcuICwsDAEBAZgwYQL69u0LbW1t1gkj4uNk5s2bh4ULF/bypFdTU4OhoSErvCooKGD27NkQEhKCpaUlnJycwOFwIC0tjZaWFigrK2P58uXo7OxEUVER7t+/j71797LJLSwsjE2bNiEvLw+2trZQUVGBsbExNDU12fVMnToV8+fPZ6L/gsz2e6UGQbYnwKWdPXuWCeZv3rwZAB8acPToUXR1dUFPTw9KSkpwdHTE4sWLmZOsAEIBgOGatmzZwsi4Q4YMYWqVRIQtW7bgxo0bvXTKBYBPwVj4ke0vDUJEpEVE1d8uKoGIAono3rf/f09ESj9wjiFE5P9v9ivfzvXmXxyHbwHvXx23/Ee/w48EIYGDpcDls7q6mhUKv/eIB/iGgHp6evDz82PcqtOnT+Pz5884cOAAxMTEoKKigs2bN+P8+fO4fv06Xrx4wdDWFRUVLJP4HhcjGIQ9PT1oaWnB58+f0dPTg/v37yM6OhoFBQUoLCzE3bt3mZC9l5cXfHx84Ovri40bN8Le3h5WVla4cOECGhsbmbsnwHcNAfhPZICP9dmwYQPExcVhYGDA6BKCa1m0aBHOnj3ba4kjCEL29va4e/cuNDU18enTJ9adk5KSQnd3N/Ly8lhWd+vWLQCAv78/3NzcMHz4cHh6emLMmDHQ0dHBjh07MGXKFLx58wbx8fEwMTFh1+zo6Ij+/fsD4E/aqqoqDB06lOkxCwrwo0aN6nWdq1atYg0EOTk5yMjIQENDA7NmzWLBYMOGDdDV1cWAAQMwYsQICAsLs0xMQ0MDc+fOhb6+PmxsbNDc3IyvX7/C2toaN2/eRHBwMKSkpODg4MDcbLW1tREeHo6enh6muGhtbQ1JSUnW9XN1dcVvv/3GEO+CpU92djYMDAwwfvx4HDhwAEuXLmV2RioqKnB1dcW6detw8+ZNXL16FcnJyWhubmbfkYjw9OlTFBcXo7S0FGVlZXB1dQXAhwWsXr0aVlZWTDpFYA91584d5Obmwt3dHXJychASEmL3koiQnJz8h3MH+OuD0O1vF7T2n/5+8Nvfj/3ZD/+n85z/dp51/+I1EFH6/+T8+MEgdPfuXYYVOnHiBOPQfI9eFegpt7e3s1Te3NwcsbGxDBsE8Nv906dPR1hYGI4cOQIej4fk5GRmpfLLL79g7ty58Pf3x/bt2zFt2jQICwuzp6u5uTk0NDRw5swZhv0QLJ0EKfRPP/2EqKgohgeSkZFh+jWC4FVWVobnz58D4FM2BB7sOTk5+PjxI3bt2sXOJyDTGhkZYeDAgUwiQpBBDBkyhEnZcjgc5ooqoKdYW1uzgSskJAQbGxscOnQIZmZmWLFiBbKzs5nJ3uDBgxEXF4f169fjypUr4HA40NLSAo/HY8LwY8eOxalTp5CQkMAeDACYdImjoyP69u0LPT09EPG7gGFhYRAWFoaGhgbc3NwQFRWFX3/9Febm5vD09MTr16+RmpqK2bNno7q6Gtu2bcOaNWtw6NAhaGtrQ01NjT0ciPgYKSJiy2Yul8t+47i4OGzatAmOjo7s/WJiYggJCUFCQgLmzJmDtrY2mJmZQU5OjkEhvL29sWTJEnZOgJ/hCoitkpKSDNrxz/vQoUPR1NTE3F8BsJqjtrY2iPga1MePH2eZZWJiIoSFheHn59drvFdWVkJVVRW3b9/Gzp07oampCTMzM9TU1OD8+fMYMmQIfH19mfb2H21/WRAiIs1vP0ApEQn902uyRNRCRK1EJP1nL+DbOZSIqIOI2uhfLO3+N4OQoI2enZ3dq2388eNHZtZXUlLCsqOgoCDo6upiyZIl2LJlC7hcLsrLy8HlclFVVcUE85WUlJCZmYkFCxbA1tYWAFjdyNzcHK2treju7kZzczP8/f2hrq4OBwcHEBFbqnR0dEBYWBiDBg1CcnIyw7AMHDgQoqKiWLhwIRYvXowPHz6wwmNRUREiIiJw4MABbNu2DdevX0dERARKSkrQ0dEBAwMDCAsLw9/fH6mpqcyHioigrKyMuLg4FnAMDQ0hLS0NGRkZCAkJYcmSJaz2sH37dqiqqvYCIxIRpkyZAoAvzBUREYGRI0f20ogePXo0oqOj0dXVBTs7O4bcjomJgZWVFQ4fPoywsDDWwha0qYODg6GgoMAySEVFRXh4eGDBggU4dOgQfH19sXjxYqioqEBfXx/Ozs44evQoIiIi0NPTg5SUFOjp6UFKSgqSkpK4ceMGoqOjmZ2Si4sL5s6di4aGBjx9+hQWFhZYunQpGhsb0drairCwMHR3dzMeWlZWFoqKihgfTeAcIiIiwpaSgqCalpbGlBaEhIRw//591NfXIy4uDtHR0fDw8ICpqSmSkpIgJyfXi8WvoqKCJ0+ewN7eHvr6+gyXFRAQwILlxIkTkZOTg3fv3mH//v2Ij4/HkSNHICQkhM2bNyMnJ4cVyL28vNh5v79vjY2NMDc3R0hICG7dugU9Pb0/nDvAXxuEln+7uMh/87ogS5r6Zy/g2/Ebvx1/5t+8DiJ6SUTORLSNiNYQ0YQ/+zk/EoRaWlqQmZmJuro6VFZWsqCUk5MDCQkJLFu2DAAY9F5WVhYcDgevXr1CS0sLLl68iM7OTty6dQt79+5FSkoKAD6FQ7BOnz9/PkJCQuDv7w89PT3o6+sznIdgudfW1gYfHx90dnaCx+Ph4MGD0NHRgbKyMnbt2oWLFy9i5cqVOHbsGH799VeoqKhAVVUVKSkpiIiIYF2QkpISHDp0CB4eHuByuTA2Noa7uzsrDp84cQLJyckoKCjAvXv3sGPHDmRkZGDDhg1sWaOpqcmK2f3794ekpCT09fVZgAH4Wd/u3btZTWP79u2YPHkyiAh79uzB8OHDMXfuXERERGD27NmQl5eHmJgY9u3bh7i4uF6yHgBffL2goAA7duyAqKgoPD09cenSJWhoaKCyspJxw4gINjY2uHr1KgB+cf+nn35ixd13797hw4cPAPji8dHR0Thy5AimTZsGf39/tlS8ceMGAPQKwt/bIQuMLS9dusQy4ezsbFy9ehUpKSnMa/7p06c4ceIEysvLISYmxoJkUlIS+vbtC2dnZ3R1dSEhIYEteQ0MDGBlZYVDhw7B3t4eN2/eRENDA5KSkjBnzhyIiIhAWVkZ4uLijMNVWFiI4uJihISEoKenB0JCQggODoauri7c3NzQ0tKCZ8+e4fDhw+DxeKiqqsKlS5dYh1CwvBLUtQTZt6SkJFavXo2srCxYWlri/fv3uHv3LqP4/NH2Vwah/d9uzMZ/83r4t9dX/dkL+HZ83rfjJ/2b1/9lWvotMBn+6Of8SBASsKbb2trQ2trKllcCHpSlpSXOnj2Lhw8fYt++fRg4cCCsra2RlZWFN2/eYPLkyfD390dXVxc+fvyItrY2REdHY8eOHexGXr9+nXnKR0REYOHChZCRkcGZM2d6FZwrKysZhWDSpEmMxS3YBLIhAQEB2LdvH2bNmoXk5GRER0ez5RfAXz5MmzYN+fn5IOLTHAQdqNevX6OhoQF1dXVwcnJiEwwAgyg4ODhg7ty5WL9+PQwNDWFkZIRffvkF8+bNw8mTJ/Hp0yfU19dDWlqaoalHjhyJ2NhYCAsLQ0xMDJqamhg9ejR27NgBMzMzdg8FSGENDQ14eHigra0Nr1+/RlpaGm7dusW6VALZj+nTp6OkpITVVu7evcuaB11dXQgPD4eWlhakpaVx48YNJrlRXFyMmJgYtoSrq6vD8uXLYW1tzQJFXl4ezp07x1wqtLS0mBNva2srcnNzsWDBAixatAgGBgZs4oaHh0NISAiamppsKX/x4kXIy8vDysqKId8F3SqBsubTp0/h4eGBV69eMccTSUlJHDp0CFevXoWHhweUlZWxePFiGBgY4Ndff0VUVBSTcAH4tBQLCwtoaWlh1qxZMDExwebNm3H06FEYGxuDiC8f/PPPP4OIGBAzKysLLS0tKC0tZQ+O5ORkxMbGsi6ZAFHe2dn5/wtlRflv/238N68L/t7nB8/HNg6HY0pEukT0FkDmv3nbQeIXrguIv2zTJaLNRORARPc4HM5IAJ//zfldiciViEhdXf0Pr2fgwIEUHR1NYmJitHDhQho3bhx5eHiQn58fNTU1EY/HIx6PR7q6ulRZWUnXrl2j2bNnU3d3N4mJiVFQUBD16dOHSkpK6MGDB6Svr09tbW2kpaVFkyZNos7OTrK1taXc3FwaOHAgKSkp0bNnz8jT05OmTJlCsrKyVF9fTwoKClRTU0NmZma0ZMkSqq6uptjYWLK1taXa2lpycnKiAQMGkIuLCxPbT0pKovHjx1NtbS09fvyYvLy8SENDg0RERGj69OmkpaVFO3fuJGFhYdq+fTvxeDyyt7cnX19funr1KllYWFBpaSl9+fKFFBUV6eXLl0REpK+vT2JiYrRx40bi8XgkLS1NTU1N9OHDB1JVVaXCwkJavHgx/fzzz1RcXEylpaUkLCxMEydOJHl5eVq9ejW5ubnR48eP6cyZMyQiIkJLly4lcXFxunDhAhERdXZ2UlNTE7W0tNCsWbPo0aNHJC0tTU+fPqUDBw6QmpoaPXjwgNzc3EhDQ4OMjIzo8+fPpKysTBMmTCAvLy+aMGECrV69mjZv3kwdHR307t07WrVqFV2+fJmuXLlC3t7edPToUXJzc6NHjx5RdnY2rVixgvr06UPXrl2j9PR0cnZ2Jj8/PyIi0tDQIF1dXeZUkZ+fT6NGjSJRUVGKi4ujIUOGEBGRsrIySUlJ0dq1a2ns2LEUHx9PixYtInV1dWpqaqIXL17QsWPHyMnJiWxsbEhKSoo+fvxIdXV19PnzZ8rMzCR9fX2qqqqie/fuUWNjI23atIm2bNlCw4YNo5qaGnr37h0pKCgw55Vhw4ZRU1MTPX78mL58+UL9+vWjxMREAkASEhIkJiZGLi4uNGzYMLK2tqY7d+6Qi4sLffr0iZqbm0lGRoYePHhAOTk5ZG5uTk1NTSQmJkaLFy9mc6Gqqoq4XC6JioqSpKTkH86d//b2I5GKiI4T/8n1LztRRLTn2+tb/mwUJKKz9C8K3j947OVvx4b8yPt/JBMSZB7t7e2YMWMG7O3t2ZNMQDS9f/8+1NTUcObMGXR1dYHL5eL9+/csxW1oaEBERATq6upYQVpAteByucjIyMDXr19RVVWFpKQkJi6WlpaGefPmITU1FVu2bMH69etBRIiJiWFFyJqaGnauY8eOISIiAgEBAYxiIMgQtLS0kJ2djfr6erS0tODDhw9ITU2Fra0tNm7cyCgagj0xMRFVVVV48OABZGVlMXHiRNja2mL58uUsO7tw4QL27NkDdXV17Nq1CzY2Nrhz504vwfoFCxawc545c4aJtff09LAn85QpU5CQkMBoKMuWLWPazMA/3FEBfiF9wYIFiIiIwPXr10HEJ986OjqyuobA1VVPTw88Hg87duzAiBEjEBUVhSVLlsDMzAyzZ88Gl8tlDqnz5s2DiIgIOjo6WFFZIHXx+fNnZGdns6WZgPFfWFiIGzdusKK1kZERfH19kZWVhVOnTmH+/PlobGxkAvMCV9bq6mqWUUdGRmLfvn3MI27kyJFwdHRESUkJDA0NISUlBS8vL0yePBnp6ek4evQoeDweEhISoKuri2HDhmH37t0se+vbty9cXFywZ88eeHl5ITAwkGWXnZ2dqKysBI/HQ3NzM/bs2QMhISGsX78eL1++ZC1/LpeLyspK1NTUYNmyZdi1axcT1O/bty+SkpKwYsWKP5w7wP/B5RgRKdI/CtJ9/vTFE1l++9ycH3n/jwShmJgYVkPo6elBfn4+7t27xwrRPT09OHv2LPz8/JCWlobXr1+jvLwcqamp0NbWRmJiIiIiIiAsLAxxcXEcPny4V1v/y5cvCAkJQVdXF27cuMEC2cGDB5liYXx8PJycnDBkyBDmQgrwg9u9e/dQWlqKoqIinDx5EkuXLsWvv/6KvLw8JgMiKOIePHgQIiIikJOTY/bBHA6HMbBnzpzJgHaTJ09mCO/vJVYF9s4A4O3tDUdHRwwdOhQjRozAihUrcO3aNXz9+hUJCQlYs2YNDAwMsGfPHvj4+EBJSQnr168Hj8dDQEAAiPiM/8jISMbifvPmDXx9fXH9+nUkJSXh4MGDuHjxIrq6ulBVVYWff/4ZEyZMYEvgUaNGIScnB5aWllBWVkZkZCRUVFTA4XAQEREBgF+vE9SzJCQkICIiwmRrf/nlF3C5XNy4cQMODg44deoUgoKC8OHDBzQ1NWH27Nn48uULcnNzsXz5cowePRpRUVEICwtjQSUqKgoZGRkYP348C4QqKiqwtbXF2bNnsXTpUiQkJPTqXgnGwJUrV7BkyRK0tLTA3d0dwsLCTEmBiA9uTUtLw+bNmyEuLg5fX1/s2bMH8+fPZ3UwgTW5tLQ0Ro4cCUNDQ6xatYqBGmNjY7F7927cuXOH3VvB1q9fP3A4HGzatAnNzc2IiorC1q1bweFwMHLkSLS2tqKtrQ3Hjh1jSHoOhwMPD48/nDvAXxuE/pLCNBF5fjvu9J+98G/Hj/h2/Psfef+PBKGtW7dCVFQUfn5+eP36NXp6ehjSF+C3ZL28vDBgwABcuXIF2dnZTHiMvhVhuVwum9C5ublITk6Guro6FBUVIScnBxEREbx+/Rr19fXIy8vDkydPMHjwYJw+fRqTJk1i3bOXL1+iu7sboaGh2L17N4KDg1FTU4OOjg42wISEhJhV8/Hjx2FjY4NXr15h69atmDJlCmRlZZkvvYuLC6sJKSsrs2Db1NSE2NhYFngEGCAOh4OBAwfCzMwM7u7ukJeXR1BQEE6dOoWQkBAsWbKEvXfHjh2QlJRkT+hRo0YxOx57e3sQ8TV5AgMDISkpCTk5Odjb2yMiIgL+/v6QkZGBuro6cwV58+YNJCQkGLVEUVER4uLiCAoKYrCBQYMGISMjg3V4vL29GZTh+fPnrLZDxKdNCO7roUOHsHLlSvbZgkzIzc0NSkpKkJWVZfgcAfZn3LhxDLckwPSkp6fjzJkziIqKgq2tLbsu+lZfamlpQVxcHABg2rRpvXA3Hh4eOH36NGbMmIGEhARUVFSAiE+dAfj1QMFvuXXrVgBAUlISk8H9/j6tXbsWurq62LhxI7y8vHD8+HHY2tqioKAA2traCAgIAI/HQ3V1Nc6ePYsrV64gIiICt27dQmdnJxoaGqClpQUFBQUEBgaygNnT04PKykps2LCBjf8/2v7KIKT17YuX0r9v0bfRn2zRE9E7+i8K0j9w/Mpvxyf/yPt/JAgJJEm1tLSwcuVKNDQ0YOPGjVBQUEBsbCwrCr548YLJPRDxEacPHz5kk+DatWtwd3dHR0dHr46LIHD0798fMTExkJeXx+DBg3thkZYvX47GxkYMGjQILi4uvXSvtbW1wePx0NDQgEePHkFaWhoiIiLIzc1FWFgYszNeu3YtJkyYwFqyra2tmDNnDszNzRkCuqioiE0ogQSEYOBHRkYyS+K0tDRISUlBQ0MDzc3NuHjxIvr168e6XxMmTEBqaip27tyJSZMmsSd1eHg4PD09oaGhwdj0x48fZ9211atXw8fHB1paWszXXlFREc7OzlBTU4OwsDCkpKTQr1+/XrIZmzZtQlBQEOzt7eHi4oLBgwdDREQEt2/fxtOnT3H+/HmUl5cjJycHVlZWyMnJwbp160D0Dylac3NzBAUF4f9h783jck77/++jHS3aSAqhDaHFkn0bNPYyGCOhsSXL2MmEESNbkk6ExiRClsaSbWyXIhRjzRAlIaUirdqe9x/n9TkufX/Xfc3c92++j/v3+91zPB6fP5Czz3men+N9vJfXsm7dOmbNmkXjxo1xcXGRU8ARI0ZIq+wBAwYwffp0TE1NGT16tMxc7ty5Q1JSEjNnzpSQACHUkAtLS0u6du1Kamoq7969IyMjg9zcXJycnFizZo0sqcvLyxkwYAADBw6UhgHBwcFcv36dxYsXU6dOHelJX1NTI/Wmu3Xrhq2tLTo6Opiamsoga2dnh42NDY6Ojri7u3P79m1mzZpFZGRkrRLO39+fNm3aEBwczIoVK6R427Bhwzh06JAUmQOkf9yfWf9tQYja2c6fAisKdfPY8T+8Xo9//r8Hf/B7Xf9dcBNCtBNC5P3zNb75M+/hz2BKzdMAACAASURBVPqOKVlGYGAgV69epX79+hJ6f/v2baqrq0lOTmbbtm3yi1W+sKKiIg4ePMj27ds5cuQIBQUFdO7cmebNm8vsKCEhgaysLLZu3Urjxo1lunz69Glu3bpFRUWF5Es1a9aMpKQkNm/eTIMGDUhKSuLDhw+yPLx586YkTz5+/Ji7d+9SUlJCcXExb968kVKnw4cPJzc3l507d9K/f39sbW1p1aqVBKHt3r1bkkxbt27NmDFjaN68Oa9evSImJgY/Pz8CAgIIDg6WD+wvv/zC+fPnady4Ma9fv2bHjh0MHTqUhg0b0qRJE7S0tLC1tSUzM5PIyEiE+Bc5tH79+mzcuJFLly4xbNgwmjZtypUrVyS+STEoFEJNsdDR0UFLS4v27duzb98+VCoVCxYsQEdHh7p16/Lbb7/JgKEEeg0NDSIiIrh48SK7d+9m7dq1VFZWUr9+ffnvQqj5ct9//70MzjNnzvwfngVHR0dOnTqFjY0Nz549486dO2zZsoUNGzZIIqmXlxddunTB3d2dZs2asX79eiIjIzl16pR8vtauXcvOnTtp0aIFixYtYt68eZSXl3PixAmsrKywtrZGU1MTT09PJk2ahJ6eHrt27eLmzZskJCRw+/ZtYmJiEEKNB7p16xYqlYqwsDDWrl1LnTp1pFGjcniZmJjIbFTJcPX09GjUqBGjRo2SWCQ7OzuWLFmCSqUiJyeHS5cukZ6eTmlpqRTN+6P13x2E/ittY634F23jifgvtA3lDf+H14v+d0Ht3/zcz0KIj//8nVuFEBuFEKeEEFX//P87hRAaf+Y9/JkgtHDhQgwMDNDT02PQoEHyixs2bBjp6emcOHGC0tJSFi5cyNKlSxFCjU7t3r07jo6OxMbG0qxZM4KCgvjpp5/YsGGD5Oi0atWKyMhIampqyMrKQqVSUV5eTmJiIidOnJDj7d9++42RI0eio6PDli1bZF/om2++AZBaPsqot7q6mq1bt6KhocHo0aNJSEjg7du3cuzbs2dP2VzPzs5m6tSpvHr1ipcvX7J161aioqK4efMmM2fOxM3NjZ49e2JtbY2enh6lpaWyB6OgpseOHUtxcTGfPn2iR48emJubS/Z1+/btSUhIkE36KVOmoK+vLzMM5TIwMKC4uFj2sbS1tUlISCA3N5fff/8dKysrDA0NycvL4/r162hra0srokePHlFeXi6R21999RU//PADZmZmfPXVV7Wa7lpaWsyYMUOWXgEBAXTv3h0DAwMMDQ3p27cv8fHxlJaW4unpiaGhIbGxseTm5jJu3Dh5L0IImU19TmnR19dn0aJFcvStvE8l+9XS0uKbb76hurqaEydOSENE5XtxdnamqKiI3377jZ07d7Jv3z5MTEwkLklx8FVKwaKiIhITE2nTpg1nzpyRGevJkydRqVTY2Niwdu1aOnToQPv27fH09CQ3N5eKigr27dsnXWltbGx4+vQpXbt2ZeXKlTx+/JiamhouXbrE48ePefnyJRcuXGDs2LGUlpb+r6OsKIRoIoTYI4TIFkJUCCEyhRBbhBCm/+Zn/2+DkBDCRAhRJv5EQ1oIMUIIcUwI8eyfwajin7//pBBi2P+T+/8zQSgqKkoqHcbHx0taxtq1a/n48aMstwYNGsSdO3dwcHCQfQshhHzgFRY+IKH0c+bMkbIYL168IDAwkH79+vHVV19x7do13N3dpfTo06dPuXv3Lj///DNGRkbY2dkxc+ZMunTpgrGxMRUVFVIMXWHYi3/2RYQQ0i01NTVVSkrExcVJfWHl50aOHCnf++vXr2UJ9fXXX5ORkUFqaipDhgyRGdLy5ctlMNXV1UVPTw9zc3M6dOiAlpYW7dq1o6amhrS0ND5+/FhLLK158+ayZBH/LI0uXLjAoUOHsLKy4sKFC9IHS7lu3LjBvn37aNWqFefOnWPTpk0YGxszYsQIGjRoQNOmTdHS0pL32KxZM8nrUpj0ffr0YcuWLZLqMXPmTA4cOIBKpZKNWIB69erh6enJtm3bWLt2LaNGjeLnn3/m3LlzUoJl0KBB9O3bVwbSoUOHEhkZydq1axFCrcT4eZASQo2ZcnNzo0WLFnzzzTc0b96cdevWSaXFFStWcOLECRo2bIixsbHMckENWg0NDWX//v2yFJs+fbp020hJSeHYsWMyeH333XcA3L9/n+3bt+Pu7s6hQ4ekwsCyZcuk6JqSbffs2ZPKykr5DLVu3Rp9fX3atWtHy5YtgdqGBP9p/bcHof/drz8ThNzd3Vm6dCkvX74kJiaGdevWMXz4cIqLi1m/fj35+fkSCdu1a1f69OmDnp6eTMkXL17MvXv3eP36Nc+fP+f9+/fs2LGDKVOm0Lp1ay5cuEBhYSFVVVXS9z0jIwMXFxciIiIICQnh3r17tGvXjnr16kl/LTMzM+Bfvmjbt28nMTGRgwcPEhUVxfnz54mNjSUoKEjaIBsYGBAaGkpZWZncJBoaGrRo0YLg4GDq169P7969KS0t5eHDhzRp0oSVK1fWsjNWft/ChQslfeTEiRNyg7Vu3RobGxuqqqooLCxk4MCBDB48mEmTJsneSUlJCQYGBhI4OHDgQNLT00lKSqJZs2ZSBhfUapHKdG7ChAnU1NQwe/ZsoqOjJW1G0X2uV68et2/fZubMmdStW5eGDRvi5eUlJWJXr17NhQsXePjwIaWlpQwdOlSWHYGBgcyfP5/g4GBUKhXTpk2jWbNm2NvbExMTQ3R0NHfv3kWlUnH16lWZ6f7www906tSJuLg4MjMzef78OU+ePOH7779n5syZZGZmMmbMGNnfEkLtwOHv748Q6uZ8SkoKYWFhbNy4EUAOCBT1hZycHB4/foyXlxfdunVj3759MtPZu3cvjx49om/fvly/fh1jY2NMTExo164durq6vHz5UmY9Hz58kJniihUr8PHxkQ3p9u3bs3fvXtLT04mIiACQrYcpU6YwdepU6tWrh4WFBYCUJf6j9XcQ+guCkIWFBcXFxWRnZ2Nubs7+/fspLy+XVjuVlZV4eHgwatQoMjIyePXqFZMmTeLx48c0a9ZMQv2PHTuGq6srJiYmUit40aJFeHh4cOfOHTk9efnyJREREXTu3BlQp9uf84VMTEzo1q2blOd49uyZfLhnzZpFeHi4LAvNzMxkVubi4kLbtm1ladC5c2fZK9HS0iImJoa4uDj27dtHdXW1lBVp3rw5lZWV3Lx5k48fPxIbG4ubm5v0JL9w4YIsgz7P/n788UcmTJhAZmYmVVVVBAYGAnDv3j1sbGzQ19fn7t27XLx4kQULFhAaGkr9+vVZtmwZGzZsIDw8nGfPnpGXl0d1dTUxMTG0bt2aY8eOERsbC8CDBw+4ePEihoaGaGlpYW5uLu166tSpIxvpSoN/3Lhx3L9/n+LiYjp06MDy5ct5+/Yt79+/l+WSMtZW+nY6OjqsWbOGQYMGYWhoyKpVq1CpVGRmZpKcnEyXLl3kZwHIMmz06NFyhL969Wqys7OpqakhJSUFHx8ffvzxR6ysrDh58iS//PILubm5REdHU1hYKHFGoaGhhIWF8eTJEykxMnPmTCoqKkhOTmb+/PmMHTuW9PR0+vXrx8SJExHiXwRbIQS7du2S/LUZM2YwZcoU2a8EdaAxMTHBw8ODgwcPAmpqi5Khb9iwgcDAQA4cOEB2djajRo0iKipK0mD+aP0dhP6CILRnzx5Wr15NQkICu3fvpmXLlpSWlpKTk8OVK1eYMWMGAQEBPHjwgPz8fF68eEFERARv3ryhQ4cOmJqayk2jbNYffviBmJgY5syZgxDqCVdFRQW+vr6SGFhQUMDevXtr2UQnJCQwZcoUVCqVPC3v3r1bKwBERkby6dMnmjZtKoGKAwcOlCWBpqamHDMrl4mJiWwum5qaoqmpSb9+/bCwsCA1NZXXr19LYXxFX+brr7+WD/fn5adyKUDEkydPUlVVRVVVVS3gXKtWrQA1CPTzjbJ48WJmzJjBvHnzKCoqoqioiDt37jBgwAB0dXWZMWMGc+fOZeTIkZiZmdWakk2YMIHY2Fip1RQYGMjChQuJj49HV1eX7du3k5qaipaWFnZ2drx//57Lly/z6dMn+vXrxxdffIG2tjZmZmZoaWkxbtw4Ll26hIeHh/wsO3XqxIoVKygtLeX69es0b96cgoICqqqqJMHY0NBQYnvCw8Pp3bs3p0+fljbTjx49koDH169fS95eamoqoD7YAgICOHLkiARsKpnrtGnT6N69O+3bt8fMzAx7e3vCw8PR0NDA0tKSq1evcuPGDdq1a0fdunU5cuQIFy9epHv37iQkJODo6Ch5eefOncPKygpLS0upLNmgQQNqamp49OiRPIhWrVol7/Hw4cNUV1fL+/+j9XcQ+guCUP/+/YF/naavXr1i7NixBAQEEBISwvv379m0aZN0Qfjtt9/o2bMnKSkplJWVSeHy1atX8+jRI8LDw9m7dy9OTk615CG+/vprkpKSyM3Npbq6WgqJKSx0LS0tXr16RWZmJpcvX+bKlSssWLCAxo0bExMTI6VNw8LCqKyspGXLlhgbG+Pm5kZaWhqenp5YWFjg6uoqRbGU7KpJkya4uLjg6urK999/j4uLi5Ti6NKlCw0bNpQysxs2bJDTLk1NTezs7Pjuu+/kJElfXx9DQ0NCQ0MJDAykpqaG/Px8Tpw4IWVBXF1d6dSpE9OmTWPKlCnSG+zTp0+kpaUhhJpD9u7dOx48eEBQUJC8X6X/IYSgd+/eskenBLYdO3bQs2dPOdIXQsgpZJ06dTh37hwtW7akXr16EoEeHBzMr7/+SkxMDM7OzrW0eIKDg9HW1pY+7EZGRiQnJ8vPUFtbW/ZsFAeS6upqNm3aJL835bUUUmuvXr04f/68LJVADXtQNvrNmzf57bffAKRl1KFDhxgwYACgxiMpfZy8vDw8PDzYtGkTrq6u1K9fH1AfYgraX4GRvHv3junTp3P27Fk54t+4cSOampqsX78ee3t7rK2tpc/Yhw8f2Lp1K+Hh4UyfPp0tW7bg7OzMvn37JJD2j9bfQegvCELR0dHExcURGxvLixcvOHLkCEKonTEHDhxIZWUlqampJCQkUFZWxqdPn/D29ubw4cOkpqYSHBzM2rVrJWFQ0duZPHkyDg4ONGzYkPbt2/P48WPZ5AZYsWIF9evXx9vbm/j4eElU/dwz3cjISE7XPgfiff7gW1tbs2zZMr799lt0dHRwdnZm0aJFLFiwgCFDhsh+izIq//LLL2WpaW5uzrBhw6T1kKKBExYWhkqlYvv27VhYWKClpYWnpyempqb89NNPHDhwgNmzZ/Prr78SGRkpAXpJSUmMHDlSIqyV9yCEeor25MkTSZ6Mjo6mQYMGaGpqoqmpiZmZmWyiK5M3pRmsNFNNTEzQ0dHhzp075OXlydJq+fLldOjQgS+++IKOHTtKCdPNmzczaNAgVq5cKftTycnJ3Lt3Twaimzdvyua4hoYGvXv3Jj4+nm3btsmsbt++fRQXF0siruKeqigMKPfq5OQEqCdcoBYVS01NlVlOjx49uH37Nrq6upiamsrpY7du3cjKymL+/PmyxMvNzcXf35+jR49Sr149nJ2dJbl3zJgxBAQEkJeXx2+//VbLGePYsWNMmjRJPmsfPnzgwYMHJCQk1FKpVDJtxa578uTJgDpz09PTY9SoUX+4d+DvIPSXBKHk5GTKy8uJjY0lNTWVqKgoxo8fz4MHD3jz5g2//fYbZ86ckcHl8/XNN9/QpEkTevfuzdixYzE0NKRXr17S68vT05MRI0agUqno3r07GRkZpKSkEBgYyIwZM3B1daVRo0aUlZWRl5cneTxKIFQyGVtbW9kzUFL20NBQ+W8WFhZERkZSVFTEhAkTmDBhAmfOnGHlypWyh7Fo0SJ0dHSkNMmTJ09kMDpw4ABv374lMjKSa9euyXtQSkFjY2Oio6MZNWoU9evXZ8mSJYSHhxMeHo5KpaKoqIiQkBC8vLyIioqiW7du6Ojo0K1bN9zd3dHW1mbPnj3k5+cTExPD/PnzqaysJDg4mNjYWKysrHB3d5dlX/v27Wuhp11dXfHx8cHb2xs9PT0OHjzIpk2bsLe3x9PTkw4dOnDlyhV0dHQoKCjg5s2bsqkLMGrUKEpKSigrK6NBgwYYGhpSp04dunXrxtmzZ/nxxx9lkPby8pL9uPz8fAwMDGjcuLFk0Cs6PO7u7ly5coW8vDw5pm/QoAFlZWUEBgbi7+/PmDFjEEJIPaXPM+N27doRFBREZWWlzJIHDhzI06dPCQsL4/jx46Smpkr81Lp16yguLiYmJoasrCz53SktAkU6VqVSERwczMiRI7l3754sAUEt86KYKZaXl3Pjxg1MTU0laj0vL48HDx5Qt25dBg8e/Id7B/4OQn9JELpz5448feLi4iQqOCgoiGPHjvHkyRNmzZpFx44dAWSaW1VVJcfS2trazJs3D1B/0Xl5eXI07enpWUss/nOlu127dsmafdCgQWRlZUliqhBq3ZyOHTvi6uoqp2Pbt2+X91FWVsb69evZvXu3fM1Vq1Zx9OhRWQYcPnxYSjQom6B+/fpER0dTVFTEpUuX8PHxIT09ncmTJ/PTTz/x+PFjnJ2dqaioICcnR2JYAEJCQti/fz9eXl5MmjSJY8eOSXlbxaFh7969hIWFSc7aypUrGT9+PEuXLiU1NZV58+aRk5NDRUUFHz58QEtLS2YFn1+GhoaMGDGCKVOm4O/vL7OXvXv3Ehsby61bt/D19UUIwY4dO/Dz8+PBgwekpqZSv3599PT0+PjxI0lJSSQmJnLu3Dn69+/P7du3JV8KkIJjVlZW6Orq4uDgwKNHj2pRWxTwn5OTE4WFhfj7+3Pz5k0yMjKIjo5mx44dvHv3joULF2JtbS0Dj5OTExYWFtSpU4fU1FS+++47WrVqRbNmzSSeqKqqih07djBmzBgA5s6di0qlknrlurq6dOrUCR8fH548eUJVVRXV1dXcuXOHjIwMHjx4wP79+wkNDaVx48akpKQQFRVFYWEhHz58ICoqihUrVrBmzRpu3LjBqlWrJGRh5cqV1NTUEBMTwxdffIGvry/Hjx+Xo/o/Wn8Hob8gCM2bN4/3799LXMThw4eZOnUq169fR6VSyZMkJiaGkydPkpCQILWn8/LyePXqFTNmzCAjI4Pi4mKp5zx//nzOnTtHaWkpZ8+elQ+zwutSsCru7u60aNGCqqoqnj59KpX+NDU1ZUq9YcMGfH19AfXJ9zkiNz8/n8OHDxMZGcmwYcMYP34869at4/Xr19y9e5fdu3czfvx4LC0tcXJykjrFbm5uzJ49m3r16qGrq8v79++5e/cuBQUFlJaWoqWlJa2FFMXJz6cuDx8+JDk5mRcvXrBr1y6cnJz49ddfpVOoMqL+/FIyO0V4y9nZGR8fHzp37oyNjQ16eno4ODhw6NAhhg8fLks5X19fie62t7dn1qxZMrDm5OSgUqno0KGDfP25c+fKCd27d+8kn6+kpAQ7Ozuio6NrWUcroEQnJyd0dXUJCwsD1Fmy0rNT5Ge7du0KqMv4z8fZiv73lStXEEINJ9ixYweHDx9m27Zt5ObmSsrMhw8f0NbWpk6dOqSnp1NSUoKjoyOdO3emV69e9OzZk+7du2NnZyf5h7q6utja2nLmzBmOHj0KqEuqAwcO8PLlS3R1ddHU1MTX11dObKuqqti/f78sHYVQ61EbGxuzadMmoqKiiIuLIz09neXLl9OkSRN0dXVxcXGhb9++f7h34O8g9JcEoeTkZKqrq0lKSpIs6OTkZJ49e8azZ88kuc/Z2RltbW0sLCykSFlNTQ0fPnyQmxXUk4+SkhKSk5OJjo7m4MGDlJWVyV6IEOoJVUREBFVVVZw5c4bhw4eTmprKzZs3mTVrlpx0zZ8/X5623bt35+jRo/z0009ERUVJT3h7e3tatWqFra0tGzdupEWLFrKpePbsWVQqlWRju7m5SQuhTp06yb5NnTp1qK6u5tixY5SUlJCRkSE3f01NDQkJCTL7e/r0KXFxcXJsHRgYiDKpAuRneP78eebOncuFCxdYvHix7GMZGxuTmppKZWWl3Bh79+4lKCiIHTt2EB0dXYvCofRSdu/ejRBqu2Nl3J6VlYW3t7ck3urp6XHu3DnCw8MRQj1N+/nnn9m2bRsqlYo3b95w9OhRhFCPs/Pz8ykoKCAgIEDil0Bty63IrQghalFw2rZty+rVq+nRowc//fQT3377LR4eHtL2+vPeEsDjx4/Jysrizp07hISESGWEqqoqKisrZZ9LwRCdPHmStm3bEh8fX0ugbdCgQRKSUF5ezvv37ykrK6OiooL09HSEUPMfr1y5QmhoKN9++y3Hjx9n4cKFODs7s379eoKCgqSLS1ZWFqBWSlBUGDQ0NKhbty4DBw7EysrqD/cO/B2E/pIgdOnSJaqrq4mLi+PIkSNkZWVJOsWFCxekg4TSBF21ahVPnz6lpKSEY8eOMW3aNFasWEFmZiY3b96kRYsW7Ny5Ezc3NzQ1Nbl69Sr37t1DpVJJJLHCMQL1aFZLS4tJkyYxefJkXr9+zZs3b2jYsCHm5uYyoPzwww9s2bJFnqampqasXLkSHx8fmQEsWrSIZs2aYWtry4QJE7h8+TLDhw8nOTmZrVu3IoTaL6y8vBwbGxvpH29nZ8fz58+JjIzk8uXLNG3aFD09PXR0dAB1YBk3bhypqaksW7ZM6u80b95ccuw+1yTOyMhg165d7N+/H1Dz1BQRfw8PD0C9kczMzNDT05NypEozfM+ePbRp04Z169bRtm1blixZQkhIiAxK0dHRxMfH8/btWzQ0NOjevTvTp0/nzZs35OXl0bZtW4yNjblz5460xLl9+zY1NTV069aNoKAgXFxc+PHHH4mPjyctLY1Lly6xfft2OYVUGuLTpk0DYMuWLWhra5OWliaD57x582Qgv3nzJvHx8bi6usqysUOHDuTn58veWp8+fXB0dGTatGmUlJTg5eWFqakpWlpatYYWpaWlVFRUkJGRQWRkJDt27JBOKcuXL5flsZKZVldXS+Ci8ue0tDR69+5Ns2bNePHiBampqfj5+UmtqqlTp7J3717q1auHj48Pvr6+5ObmUlxcTHx8/P/3Uh7/p1x/JggpfKzCwkLKysowNTWlfv36fPPNN0RERHD+/Hmpv6KrqyvdEpYsWYKOjg4WFhbMnTsXUKfH+vr6DB8+nJkzZ9KsWTOmTp0qH0qFqX379m1GjRqFm5sbnTp1khtYoX0o6fSgQYPQ1taWkzFLS0sqKip4+PChPKnevXsnyzcF5VpSUiIh+cpGOnLkCAEBARw6dIjY2Fj5npSfadu2rfTqmjBhAkKoR/vHjx9n69atBAYG0qZNG6ysrJg2bRqrV6/Gz89P/n9jY2PCwsL45ptvGDx4MCEhIbi4uGBgYMC8efMoLS2Vfl7JycmMHz8eLS0tyRGztLSkfv369OvXj5UrV/Lzzz9jbW2Nu7s7+fn5FBcX4+XlRZMmTWTprCgBODo6cuDAAeLj4yXep27durLMatCgAU+fPuXly5eynFLKECXbUKRglYzN3t4ec3NzVq1axf79+zlx4gQ2NjZMmTIFPT09jIyMiIqK4tixY4wePZp3795JG6LPS89Hjx6RlZWFlZUVKpWKefPmsWLFCjkwaN26NRUVFVy7do3Zs2cTGxtLdXW1bDwfOnSIkydP0rlzZ3bt2oUQatyZAhv48OEDTZo0QVtbGz8/P65du8bHjx+5ceMGv/32G7m5ufK5UgwbCgsL2bBhA9bW1tja2rJ06VIsLS1lpgVqd5M/s/4OQn9BEIqLiwOQnlGmpqa1PLuUTV+3bl3ZL4iOjsbAwICkpCSioqKYOXMmPXr0wN/fX05PTpw4QUFBAc7OzpKDdfHiRQmCs7e3R0NDg0uXLkkrGlCXc3v37uXMmTNkZGTU0kRu2bIl9+/fp7KykmHDhjFs2DBCQ0MZN24c//jHP+RG/PXXX2WDXQjBwYMHpYGhhoYGhw8floHG1NSUXr16yYxr6dKlqFQqrK2tCQ4OlqXP53Y0Wlpa1K9fnxMnTtQCE+rp6cnxeuPGjcnMzJQCaU+ePJHYGiGEFCGbN2+eDLKXL18mICBAjpytra0RQs16d3V1lSDF8PBwCgsLefHiBcHBwXKS8+LFC9q0aSMzzqZNm7JkyRIJeWjevDkaGhoyKCq4pi+++AIrKyvJyNfV1ZWI4djYWHk/iplAu3btaNKkiSTYKox+5bBRmtL6+vpMmTKF58+f4+HhIW2KFF0gS0tLHBwceP/+PYcPH8bExIStW7dSXFyMi4sLHTp0IDw8nOTkZNq2bcuWLVs4c+YMgYGBpKWlkZiYSFpamiwVzc3NCQ4OljpMNTU1JCYmkpiYWMvW+dChQwAEBQVRUlLCqlWrZHNfWYp42x+tv4PQXxCETp48SVZWFlVVVbi7u+Pn58eTJ08k3ys2NpbBgweTmprK3r17ycjIoEOHDjRr1oyysjKePXsGIEetypRFaVB//PiR5s2bM3jwYAoKCrhw4YJ0Bg0ICJBi6KAOhB8/fmTEiBHSueP+/fv4+PjQpUsXnjx5QkFBAdXV1WzZsoWVK1eyfPlyad+8evVqxo4dy5gxY9i4cSPe3t7o6+tTUVHBrFmzmDFjhgQaZmdnY2ZmxpdffolKpcLf35/8/HwmTJiAjY0N/v7+tWyfz507R1xcHHPnzqV3794yIzxy5Ajjxo1j/vz57Nmzh+zsbFatWsWhQ4fo2rUrNjY2REdHS4yNtrY29erVIzExkerqaoqLiwFwc3MjJSUFc3NzGjRowIABA7h9+zYnT57k2bNn6Ovr07ZtWw4ePEhJSYlUGEhMTMTExIQXL15w5coV+Rl6eHjIaZQSkObMmUNSUpKk5UyfPl02kYVQj8H79u2Ljo4O1tbWGBsbo6uri4+PD+Hh4YSGhsqDSltbm+bNm5OTcwN28wAAIABJREFUk8O5c+fYu3cvlpaWmJqaytdVBMlmzJjBrFmz5GdpaWlJfHw8iYmJCCEIDQ2lQ4cOckqqlIS2traA+iAsLy8nKyuLZs2a4ebmhomJCcbGxpSVlXH69GmEENKoce3atfL7WbduHU5OTsyfP19KFaelpbFmzRppJlBZWUl2djbHjx/n7t27nDt3TvYO/2j9HYT+giCkyIqCWkVRX1+fsrIy6egAEBoaKmVLnZycZKodEhLCxo0befv2Lbm5uYB63Ovv78+jR4/kxMzU1BRzc3Pev3/PmzdvuHTpEn5+fmzdupVp06ZRp04d2rVrx9OnTwkMDJT6Np+7oDZp0oSLFy9Khcb09HRADYps06YNa9euBZCqfKC2LZo3bx62trYsW7aMly9foqOjI0sQRf3xq6++YsSIEZLRX15ejp+fn7SLUfpYhw8fliWYwkP6fKWnp8tTVTnxlca5gvn5XETt+PHjbN68WWZqw4YNIzw8XOpWHzhwgMrKSoYOHYoQgmPHjlFdXc2KFSvo3bs3CxcuZMiQIXTt2pXWrVujpaXFhw8f2LJlCwYGBkyfPp2qqio5Jgc1Daa4uJj8/PxaqoXGxsYyM1IubW1tmR0oQfT27dssXLiQuXPnYmhoyJAhQ9DS0iIrKws9PT2mTp1KcnIyKpVK8vfs7e2ldrQiuaupqSlLOUXeRFdXlyFDhvDkyROio6OZOXOmhIQoz6EQat2gV69e4erqyosXL/j5559p2LChpIAoKyQkRNJlFK7ivn37GDduHAMHDkSlUpGRkSFfv7KykpMnT3Lp0iXat2//h3sH/g5Cf0kQUqD1paWlJCcn4+npSXp6umwAf/r0iRs3blBVVcWHDx/o1KkTRkZGGBsbM3z4cFnWbNu2jVevXsmSQSlTTE1NKS4upqSkhJKSEjk9unz5Mr1798ba2lrKi4K6Kbl8+XK2b9+OnZ2dZNcrD58SMLdv386tW7fYtm2bRMJ++vSJBQsWkJ6eTkxMDPPmzSMlJYX9+/fj6OjIrl27eP36NUVFRWzbto1NmzZx79493rx5Q5MmTeRYdvv27fIktLKykoFDW1tbBg9lGqYspYfxuUypYgU9fvx4mSVqaGjg4ODAnTt3qFu3LiUlJVJvWfE/T0tLo169eri7uwPqMbyZmRkFBQWkpaVhYWGBjo4OR48e5fz581y9elVisdavX1+rdHRwcOD58+cSjGlra4uWlhZRUVG0b9+eCxcu8MMPP3Do0CE6d+7MwoULqaioYNCgQezYsYPKykrS09PlBEnRAtfS0qK0tJR+/foRERFBWVkZXl5eLFq0iJSUFFQqldT0njFjBkFBQVLiRbmSkpKIjo5m4sSJ+Pv7M2DAAInxCg0N5d69e7x//56ioiJ8fX1p3749+vr61K9fn4cPHxIWFsbTp0+xsbFBU1OToqIiysvLqaqqIisriwULFgDqcnHo0KEyECkmDZ/71Sl9NoXY+rm8yH9afwehvyAIJScn4+7uzsmTJ2udOvAvbeH09HRZXoWHh0tdFuXy8/OjrKyMcePGSQF0d3d3tLS0MDMzkxrSNTU1XLt2jTFjxpCZmSknPopURZs2bWjTpg1ffvkl3t7euLi4SPEphUVeWlpKSkoKrVu3xsvLi8jISIYPHy4nI1u2bEFHRwdtbW06dOjAhg0bGDJkCJqamiQnJ0u/e0Umo6CggOvXrzNhwgRmzpwpOWMK3H/p0qWy19G4cWNp6Lhr1y4iIiLIzs6ulTU+evRINoZfvHiBra1tLXhC9+7d6d27t0SAz5kzh5ycHAIDA1mzZg0TJkyQm1VPT4+1a9dK//eRI0cSFxcnJSouXryIp6cnHh4ehISESCkRgDFjxtC+fXs2btwo709BGt+/f1/qTCuSLErfSFdXl9evX3Pv3j127tzJiRMnpIxLq1atWLZsGf7+/nTs2FEG/0GDBpGXlye/R3t7e3R0dCTvLTQ0lOrqat6/f4+rq6sM0g8fPpTBbfXq1YBaV0rhjUVERHDt2jXZQ5o3b55E4y9cuJCrV69KO/Bt27aRlJTE/v37aw0lFB1yIQT+/v4kJydz/vx5srKyJF3FyMgIZ2dnrl+/zoMHD3jx4oXs5f3R+jsI/QVBSOF8bdq0ieDgYPr06cPz589lr+LRo0eyRxEREYGnpydPnz6lf//+UmJDQUEr2cOnT59qiXm1a9eOc+fOUV1djZ2dHV26dGHDhg1cuHABAwMDdHV1JTBPmebAv4JfTk4OxsbGsll44sQJoqKiuH37di39n8jISPr06cPkyZPR09PDxMSEiooKunfvjhCC77//np07dxIWFsa2bdt48OABubm5zJ07VzaBldJEycCOHj3K1atX8fT0RENDA1dXV0ANGVDu59GjR7i6urJ7927i4+PlRAygS5cu7Ny5kxEjRmBra8vFixdJS0sjNTWVbdu2cfnyZY4dO4ZKpSIgIKAWL27AgAFoa2szffp0evXqhYmJCY0bN5ao8erqasrKyjAyMpI9kIcPH8pTvaqqisOHDzN06FCSkpKkUWFmZiaFhYUMGTJEjsnd3NxwcXEhMTGR4OBgrl69Khv0igKBkskp39WoUaPIz8+nU6dODBgwQP69omKgGBsWFhby9u1bjh49yo8//kinTp3w8PDg3bt3ODg40LJlSxwcHDh9+jRDhgxh3759tG7dWgZvBRLQokULqU3+9ddfY2dnh4aGBubm5owaNYpevXoRGhoqjTkzMjK4evUqe/bsYeHChaSlpfHp0ydmzpxJTk4OXbt2ZfDgwRgYGEjhvOzsbMrLy/8e0f9V158JQrt370ZLSwsLCwuJD/rpp5+YMGEC6enpxMXF0apVKzZu3EiPHj2kto22tjZz586lY8eOhIWF8fbtW86cOcPHjx8JCQlhx44dZGZmSva54i+mIIm7du0qTzjlMjc3x8jIiDZt2lBZWcnEiRN5+/YtW7ZsoU2bNlRVVVFaWkrfvn1JSEggNjYWlUrF9evXuX379v+g8NewYUOys7MZMWIE2traBAQEEBAQgJeXF0FBQejq6tKwYUM6d+4saRMdO3aUYl8NGzbku+++kyhuLS0tLC0t6dixI0eOHKG8vJxnz55haWmJkZERQ4YMkVSA0NBQbG1t6d+/PzU1Nfj7+3Pt2jWqq6uJjY3lzJkzBAUFUVRUxNatW5k8eTJxcXFERkYyZ84cGjVqxP379xk8eDBfffVVLT7dsmXLePLkCZmZmeTk5NCmTRtWrlzJw4cPyc7OBmDjxo2MGjWKkJAQTE1Nsba2prKyUjLZATmVa9u2LXv27JH9n4CAAOLi4ggODqZDhw7k5ubi7OyMnp4e1tbWkmemHF7e3t507NgRTU1Nvv32WxnQFS3xhIQEzp8/L1HX/fr1o6ioSAYXJWNSjBT09PRkhmRqaoqLiwurV69m8eLFEmSo9HWUXpuDg4PMIK2trbl+/Tr/+Mc/UKlUEoYCyMM1ISGBXbt2cefOHXlfCn2ppqamlobSf1r/b4LQn3Vg/f/NKi4uFrt27RIzZswQOTk5IjQ0VLx7905ERUWJunXriurqajFz5kxRXl4uEhMTBSC0tLSEi4uL2Lx5s8jKyhLW1tZi1qxZoqSkRDg6OoqSkhLh4uIimjZtKlJSUsSSJUuEt7e36Nevn3B2dhZFRUUiJiZGaGurvw5TU1NRUFAg8vLyhI2Njejbt69o1aqVsLS0FBYWFuKrr74SJSUlIj8/Xzx9+lR4e3uLVq1aidzcXKGnpye0tbXF6NGjxeTJk8W5c+dERkaGEEIIb29voampKYYMGSLCwsLEy5cvRbdu3URxcbEwNDQUQgjRqFEj8erVK/Hx40dRp04dMWDAAPH48WNx48YNoampKSIjI4WlpaWoU6eO0NLSEtnZ2aJLly4iJydHeHt7i6KiIlFYWChWrVolHjx4IIqLi0VxcbEwNzcXdnZ2Ijk5WTRr1kzk5uaKFStWiLy8PLFz507h6ekpLl68KBITE8Xs2bNFt27dhIuLi6ioqBC6urri1KlTwt/fXyQkJAgHBwexb98+oa2tLaqqqkTr1q2Frq6u6NevnzAzMxPPnj0ThoaG4ubNm+L48eOipqZGnDp1SgghxNmzZ4WdnZ2oqqoSFhYWwtvbW2zZskU8evRIPHjwQOzcuVPo6OiIZcuWiU2bNgkbGxuRmZkpVq1aJZYtWyZMTExEdXW1uHv3rjAwMBDh4eGiRYsWwsfHRzx+/Fj8/PPPwtnZWSQnJwsHBwexe/dusW7dOrFkyRKRn58vPD09RU1NjTh+/LgoKSkRZ8+eFc7OziI7O1u8fftW1KtXT8TExAhdXV2hoaEhWrVqJSIiIsS1a9fE0qVLRUFBgSgoKBC6urrCx8dHnD59Wjx+/Fjs379fhIeHi0mTJgk/Pz/x5MkTYWBgIPT09ERVVZXo2rWrqFOnjrhx44ZYuHCh8PX1FQ8ePBCamprCy8tLbN26VcTGxgpjY2Ph6ekpjIyMRGZmpnBychKFhYXCwMDgv23P/R2E/stat26dOHbsmOjWrZu4deuWWL9+vZg9e7YYMmSImDFjhmjbtq149+6d+OWXX5TsStjb2wtTU1Px8uVLUV1dLWpqasT8+fPFqVOnxOvXr8XatWtFixYtxIABA4ShoaFo06aNePDggTh16pSYMWOGWLZsmejevbsoLCwUa9euFfHx8aJ9+/Zi7Nix4ty5c2Lz5s3CyspKJCYmijt37ghXV1fRsWNHsWXLFqGtrS06deokrl+/LkaOHCmsra3F8OHDhZGRkVi3bp20WRZCCHd3d9G5c2fRokULMXnyZDFy5Ejh4uIi8vPzxdSpU0VmZqY4cuSIuHXrlsjIyBCTJ08WxsbGom/fvuLXX38VpaWlYuXKlcLU1FRERkaK58+fCy8vL/Hx40dRVFQkcnJyREpKisjKyhJ6enpi79694tOnT+Knn34STk5OIjExUdTU1AghhNDQ0BC5ubnCxMREpKeni8ePH4usrCyxePFikZaWJgYNGiRCQkLEiRMnhI6Ojnj+/Ll4/vy56NGjh3BxcRGampri+vXr4s2bN0JbW1ucPHlSPH/+XDx79kwIIURYWJjIyckREydOFJqammLatGkiIiJCzJo1S3h7e4v27duLyspKkZSUJLKysoSTk5MQQsh7KigoEBMmTBA1NTWiQYMGok+fPqKkpES0bt1arFy5UgghRP/+/cWePXuEh4eH+PLLL0WPHj3E1q1bRcuWLYWGhobQ19cXycnJIj8/X2hra4vZs2eLcePGibFjx4rhw4eLL7/8UqxYsULo6uoKe3t7IYQQkydPFgsWLBBpaWmiS5cuws7OTvTo0UM8fvxY7Nu3T5w4cUJcvnxZZGdni5CQEJGeni5UKpX4xz/+IYYMGSKKiork52tlZSWKi4uFpaWlKC8vFyUlJeKXX34Rv/76q7C1tRWDBg2Sn0VKSopwc3MT5eXlYu7cuWLfvn3C0tJSaGhoCGNjY/H06VNhYmLy37Pp/mdLnP+drj9TjjVu3BgNDQ2pIRMcHIympiYqlUqmrsq6fv0669evx83NjR49enDy5Elpzfz06VOSkpLYsWOHTNU1NTXlqLOoqIh3795RWFjIo0ePUKlUqFQqfH19JW/o4MGDCKF2Sl22bBlxcXG8ePECLy8vVq5cybFjxwC18NqNGzdwcXFh/PjxzJ49m5YtW/Ls2TM8PDwwNDRER0eHRo0aoaOjw+TJk2XjVQiBt7c3X3/9tdQarq6uJi8vDyHUkrHx8fHcvn2boKAgnJ2dmTp1qiwx2rZtKx05mjVrJsfTnp6eDBw4UI6y27Rpw/Tp0yWcITIykrFjx9KgQQP27Nkj72XXrl2YmJjg6+uLqakpI0aMoLKykvj4eM6fP8+HDx8oKipi2rRpZGVl8eHDB+7cucPWrVsxNjaWpYxS9ipyteXl5UydOpUGDRpgamoqfdBCQ0P5/fffZRmzfPlyNmzYIDE8+vr6bN68WaLP09LS5L8pqgBK41gBCXp4ePDdd9/JBrTyDChUi8uXL8vnQXmGDAwMWLx4MW3btpXflwKKLC0tZenSpfz4449SQ6hjx474+voyaNAgCbFQhghhYWESOnLt2jV+/fVXaQEu/tls79OnDyqVioiICL7++mvatGnD5s2bcXJywtjYGE1NzVpTVkV07Y+W+Lsn9D8fhNasWcPatWtlIPj999+ZMGEC48aNo1u3bhQVFcnJxsqVKxFCDT5zcnJCW1ub7t27s2/fPmpqaggODpaby9TUlLFjxwJIdwT4l8Rnbm4uW7Zs4fTp01RXV/P69WvZB1B0jQMDA+VDuGTJEiorKyWjvbi4mGnTphEVFSXxLcrGsrGxYfXq1RQXFzNlyhTs7e1JSUmhTp06GBgYyJ8bP348oNagEf/sKwQGBnL06NFazdimTZtKGdzjx49LztLw4cMl0jo9PR1NTU3Mzc1lw/7EiRMkJCRgZ2eHnp4egYGB+Pj4SCCggYEBp0+frmXZc/bsWeBfSpfK6N/JyQlDQ0NcXV05deoU4eHh8n107NgRCwsLzMzM8PX15auvvqK4uJgXL17UanTr6urSokULGjZsyJgxYxg6dCgTJ04E1LAE5eeEUAMNU1JSJEO+rKyMGzduEBwczMOHDyV2SQg1az85ORkrKytpjTRkyBBMTEzw8vKqZYZ5/PhxvLy8cHV1xcjICC0tLVJSUrh06RLl5eW8fv2ayspK7t27J4NZ3bp1uXLlCmFhYcyZM4e6devSoEEDtLW1GTFiBKAeDiiSu8ozdubMGcaNG8fcuXNp1KgR48aNY9CgQQwcOJD27dvz448/Ymdnx7Jly6QmVnBwMF999VUt9PR/Wn8Hob8gCA0cOFA+yA8fPuTkyZPcunVLAs2io6MBdbZw+PBhZs+ezbVr16Q7pqJ4V1hYyN69e3F1daVevXpYWVmxfft2iouL6d+/P46OjowfP55u3bqRmZnJx48fa8EB3rx5I8fGiqqdn58fu3btwtvbGwcHBw4ePMiFCxd4+/Yto0ePRgi1lbGiSDh69GgWLVpESUmJ5BkpzW8HBwdMTU0l5kgINbL74MGDmJubU7duXS5dusTy5cvR0tJCU1OTQYMGoa+vj6+vL8eOHSMpKQlvb2+0tLSYOnUq5ubmCKH2aPP396dXr17cuHGD48ePExERwZ49e3jz5g1mZmYIIXj69ClVVVX4+/vLJqqSZWhoaGBoaMiVK1eIi4uja9euVFdXc+vWLY4ePcqqVasoLy/n6tWr+Pj40KdPH4RQY5cU7tThw4clgv27776Tr62lpSWbyZs2bSI6OppPnz5JLMwvv/yCr69vLWE1Nzc3DAwMMDc3l1w+JSCWlZXx6tUrdu7cyYoVK/D19eXLL7/EyMiI+/fvA2ou4udBTQi11ndNTQ1t2rTByMiISZMm4eTkxKhRo+TEb9euXXz99dd8+PCBefPmsXr1atatW4cQgitXrvDx40d8fX0JDw/n0KFD3Lp1i+zsbK5duyYNI+Pj48nLy2PgwIEyA3ZyciIyMrIWmFS5vvjiC5ydndHU1MTNzY3u3bv/WzDqv1t/B6G/IAjZ2NgwYMAAAgICMDAwwMPDg5YtW7Jo0SJ69epFTk4O5eXllJSUoFKpCAoKolWrVjKAKBB78c9RfcOGDTE1NZX+XmvWrGHmzJlyTG5gYCDF7BUB9eXLl+Po6Mi9e/ckyFE51T4PGh4eHtI/zN7enokTJ+Lr68vIkSMlf+r58+fo6+szZ84cmQVoaGiwePFi6tWrh42NjURhK9KvYWFhMhjPmjWLrVu3SqcQZUMWFxfLgKarq0tAQACAdCxVfk9gYKDEy7i6uko+1tixY9m0aZNM848fP06fPn2IiIiQZY5S8iiSppMmTSI+Pp4bN27w8uVLampqZClUWFiInp4eTZo0kUG4Xbt2kqypZHIGBgZyurdt2zaMjIxYtWoVhYWF5Obm8vHjRxYuXIifnx8DBw5kzpw5bNiwgefPn3Pz5k2EUCs9LliwAEdHR3bs2MHq1at58eIFmZmZGBkZceHCBerVq4empiYODg6EhYVJiowQ/xqxt2rVip07dyKEqOVOomTOkZGRkjMI6gkYqINe//79pda5IlmyePFi+X5BbQ+lkKqHDx+Ovb097dq1Y86cOcTFxbFu3TqeP38ugZ2bN2+moKCAyMhIqSXUq1cviouLayky/qf1dxD6C4LQoEGDADWqVNncAwcOpEuXLkRFRWFtbY2RkRGJiYn0798fS0tLbG1t2bNnD8ePH+fSpUusW7eORo0aERsby6FDhzA2Nmbv3r106tSJYcOGkZiYyO+//y4xSe7u7kRERHDy5Emqq6tZv3697Afs37+fli1bYm9vj6GhYS3p0BkzZlBWVoafnx92dnb88ssvnD17Fm1tbQwNDXnw4AF+fn6yV/M5BEChRvTq1Ytx48ZhY2NDy5YtCQsLIzs7m7Fjx6KpqUlgYCD79++Xmj4TJ07k+vXrVFVVMW7cOPr168f+/fsJCgoiPz+fOXPmYGtrS/fu3WndujVpaWl07doVKysrGjZsKAmtTZo0kWqHly9flv2HuLg4EhMTZW+nQ4cOZGRkcOjQIfLz8yVoTslIlT5MQEAAaWlptG7dmo0bN9KuXTvatm1Lu3btcHd3x8TEhNu3b/PmzRvi4uIoLy/H29tbZkRWVlaUlZVx+/ZtzM3NZSmsiMSDeowdEhLCli1bZJnbokULWrduzZ49ewA1+/7x48d07tyZgwcPSpXGJk2aEBkZib29vZSGNTU1ZfHixXh4eLBr1y4OHjxIVVUV69atY/To0dKqWsGOCaFGgJeUlMiSH9SGnVFRUcTExLBo0SLpHqJ8NvHx8eTk5NCrVy8sLS25du0axcXFlJaWsmzZMs6fP4++vn4t1vyNGzfQ0NBgxowZfPr06X8NG+j/E64/E4Tmz59PTEwMv//+u7RHBrXe7tixY2VZFhYWxrfffoutra10SFiwYAEfP36sJb2gpL+Ojo44ODjw8OFDQI292Llzp8TyKKXCmjVrWLZsGUOGDGH58uVMmTIFCwsLdHV1qamp4dSpUxgaGmJkZIStrS1hYWGEhISwevVqmforJ5unpyd79uzh8uXLMgNp1KgRGhoaDBkyRBJWFZSwoi2srC+++EICLwcMGECjRo349OkTCQkJODg4yKxsw4YNHD58mKVLl8rfvWjRIoYNG8b3339P37598fT0pGvXrqSlpeHr60t2drbkQ4WEhDB48GDu37+Pk5NTLca/Eoxat25Nly5dMDU1Ze3atWzbto309HTc3d3p2LEjhYWFsmcyatQoqqqqOHnyJJ06dZKbUVGxHDp0KDdu3KhVggQHB3P8+HH09fXR0NBg4sSJMnOMiYmR1t2rVq2Sf79u3TpOnTqFSqWSDhcHDx6kQYMGaGhoUFlZSUVFBbdv38bPzw9Q8/ciIiJYvny5BHyeO3eOa9euYWZmhoWFBY6OjixYsEDi1D6/1q9fT9OmTdHW1ub169dSYG7RokXs2bNHiuh//tldunSJiooK+efP0c99+/alT58+bN++nVOnTnH37l3Onj3Ll19+ib6+PmlpacTHx8tn64/W30HoLwhCO3bsIDg4mLy8PCorK/n999/5+PEjoaGhLFu2DC8vL7Zu3So324EDBzh27Bj3799nxowZEtj15MkTZs6cSVhYGFFRUezdu5eUlJRav+vcuXO4uLigo6PDhAkTcHJy4vLly+Tk5LB//34mTZpEXl6eBMWBehJmYWHBkiVLcHR0rAW2S0tLA9QNSEdHR7755hsWLVpE06ZNa3mFWVpayv9z48YNPnz4QHh4OEVFRdJv7OHDh1KLRzmNhRAMHjyYXr16UV5ezp49e3B0dOT58+eUlpbWEt8XQq2A+I9//ENq5bRr1w5QU10cHR1JTk4mLi5O0giUPsn69eulR5ti96NcSkagpaWFt7c3a9askcjn6upq6tevj6OjIw8fPuT58+dcvnyZtm3bYmBgwODBg/npp5/Q0NCgQYMGtG/fHjc3NwwNDQE1P0pfX5+GDRuye/dumjdvTteuXRk2bJg8PBYtWsSUKVPQ1NSUtBCFw/Z5f6VDhw4sXryY/Px8ysvLuX//PuvWreP3339nwIABcmpoamoKwIgRI9DQ0OD+/fuSFKxMEn/44QemTp2Kr68vhoaGWFlZYWZmJoNUXFwcZ86cobq6Gi8vLxYvXsyRI0cwMDBAT0+PjRs3ykmrUpqfPn2a4cOHY2pqir6+PqdPn2b16tXUr19ffuabN2+WQTYkJOQP9w78HYT+kiB09+5dPn36JBX/CgoK6NatG+PGjePp06cIoZYUXb16NS4uLrUU8BSEac+ePTEwMKBnz54EBQXx9OlT9u/fz+7du9m1axeXLl0iJSUFPz8/fHx8yMnJkf2Wu3fvsmvXLolQ/eWXX3B3d2fkyJHExsbi6+tLhw4dJCEyMTGRT58+kZeXJ+2NFf2jvn371irBlA3cpEkTiZpV2P41NTVcvXoVGxsbtm/fLnsolpaWCCFk41cIteB+fn4+ERERuLq6cuvWLSkC1qRJE9n7UMwAfvnlFzQ0NKhTpw7l5eX88MMPCKGmjfj5+XHy5ElatGghHWUfP34MwOjRo4mKisLHxwd9fX309fU5duwYFy9epHnz5vj7+xMaGsrAgQMZP3482dnZtRwslH6REEL2VebOnSv1gXR1dfnhhx9o2LAhPj4+tfzHhFBPFxUftdWrV7Nz504yMjKYOHEiDRo0oGfPnpI7p8jaKperqyvGxsa8ePFCHhSfPn2iffv2jBgxAhcXF5YvX05GRgb16tXD3NwcMzMzefidP3+enTt3Sr7b571AReUyMDCQgQMH8vbtW8nta9mypezPvXv3jrKyMgoLC2W2q9gTOTo6EhERgYaGBhoaGri5uREVFYX6sQ7LAAAgAElEQVS2tjbe3t4MHTqUkJAQevfuzYEDB+TU8I/W30HoLwhCylSiVatWuLi4kJOTI/FBOTk53LhxQ/YCdHV1CQoKorS0lDVr1nD48GHev3/P3Llz5YZUqVT069ePSZMmyYAByB5IUlISs2bNIiwsDDs7Ox4+fMilS/8Xe28eTtX+vo8/e5vnMUKTDA1SaZCSNOlUGmieZ506JwoNhEpFGpBhp0gUKdKENFGkUamknIhMiSREChv374/dep2c631OvT+/cz6/3/d7nXVd61J7sdbaa3hez+t+7vt+biA1NRUvX77E+vXrsWLFCpw4cQILFiwAj8fD5MmTMXLkSFY1AUTtfbkplaKiIrZt28bK7wcPHsSyZctw5coVVuK3sbHBb7/9hqysLNTV1bFRfevWrSzLIxLxeaqqqjBq1CjWUXbo0KFobm7G0qVLsXbtWjbKcoDzt11iv3z5AjU1NSgrK0NNTQ0yMjLo1asX09JJSEhg+vTp0NDQwKhRoyAQCBAdHY2ioiIUFhZiyJAhKCsrY50uDh8+jNmzZ7P9//zzz+zfnLZKWloaWVlZ8PX1hbe3N/bs2YM7d+6wDHH9+vX4+PEj8xbiwGEu2+PxeMxEnvOW5vyWJ0yYAFNTU4wZMwbe3t5YuXIl85L+dlVVVcW8efMAgLXfqa2tZS4LPj4+AMBoHlw3i5qaGhw4cADXr19HVVUVtm7digkTJiA8PBwJCQnYtWsX+vbtC2NjYwQGBsLV1RXr1q1DcHAwAgICOth3cKLk6upqFBUVYc2aNfDx8YGdnR3u3r2LJUuWwMHBAZqamhg1ahS8vLzQ0tKCgoICnD17Fs+ePUN+fj5qamrYdPN7y79B6G8IQvHx8bh+/ToD7lasWIGCggK0tbUxVf3p06fB5/PZSN3c3AwDAwPmoshlH1JSUrC3t4ekpCRkZGTw6dMnlJWVoby8HPn5+Whvb2dALVeinzZtGhQVFbF7924cPXqUmVcBInJk586dcejQIbi5uSEsLAyA6EHmSH5cFY3j5khJScHc3BxDhgzBokWLIC4uzryGuJ7vUlJSEAqF+PTpE1avXg0iUalbSkoKdXV1ePv2LYhEplq7du2CtLQ0eDwe4460tLSASASW29raQiAQYO7cuRg2bBjev38PY2NjLFu2jNmrciOxmpoa7O3tAYiA5qFDh0JXVxdbt27FgwcP0K9fP0hJSeHKlStIS0vD48ePUVlZCTs7OxCJiJRctsPj8XDixAl0794dT548QVxcHIgIs2bNYoFfIBBg7NixLIjNnTuXTXmmTJnCzMd++eUXNDY2smaHWlpaGD9+PAQCAXr16oWMjAy8fv0aNTU1cHJyYuC2oqIiLl68CFVVVejo6GDo0KFITEyEtLQ05syZwzA8VVVVTJw4ETdu3MCBAwfQqVMnPH78GCkpKVBSUmJZH5FI7+fp6YktW7Zgw4YNyM7OBiDqCsMFv61bt+LOnTsAgOXLlyMiIgLPnz/HunXrkJ6ejszMTAQFBaFfv35wc3PDmTNnmO4wPz8fISEhGD58OObMmYPa2lqcPXsWAoEAJSUliI2Nxb179zrQR/5q+TcI/Q1BqKSkBKmpqTh79ixCQkIgEAhw7do1fPjwAe3t7WhoaEBlZSUzFw8NDUXXrl0xbNgwzJ49GyNHjoSkpCTzSiYibNy4EW/fvsXr168hLi4OGRkZ3L59Gx8+fMChQ4dgZ2fHAhxnaLVx40aYmZnh+fPnOHLkCFRUVKCqqorq6mp8+PCBAdp9+/ZlTOjS0lJWvft2VOZK7xxj1tXVlbUYAkTCTWtrazx8+BCDBw+GoaEh9uzZg7CwMISHh+Pjx484cOAAeDwelJSUoKKiwkq9Dx8+xMKFC6GiosJeHDc3NwwfPhz37t1Dbm4uVq1aBSJRo8CxY8eyqZ64uDi0tbUhEAjQs2dPlsn8+uuviI+Px+TJkzF37lwGBGdmZqKpqYm1KOLxeDA0NGQZDGegD4iyDz8/P7x48QKurq5Ys2YNAOD69euQlZWFmpoaXrx4wbCZIUOGgM/ns+C9detWNiWTkJBgU8Ty8nJ8+fKFdVfhsilu/eP/Fy9eDHd3dxw8eBCxsbFYvnw5Xr58CQUFBcjJyaF79+4IDw+HnZ1dB58oe3t7WFlZgYgYb0hJSQm+vr6oqKhAZGQkysrKsGDBAoY1uru7Q11dHeLi4khISMDatWsxceJELFiwgN0bPp8PRUVF8Pl86Orq4uPHj2hra4OEhAS0tLQwaNAg7Ny5E6GhofD398e7d+/w+fNnls19b/k3CP0NQcjW1pZhJ7a2tjh48CCuXbuGLVu2oLKyknkKBQUFoby8nIF4nBp+wIABGDhwIFJSUvDq1SuIiYlBT08Pfn5+CAkJgZqaGuTl5VFRUYGysjLExsaiZ8+eSEpKYrwaZWVllrZv2rSJAZA8Hg+PHz9GQ0MDNDU1oaCgAD6fz14kExMT1uE1Pj4e9vb2OHbsGFJTU5GSkoLm5mYkJydjzZo1mD17NjZu3Ijly5djxowZzJkxIyMDRkZGKCwsRFFREeOdVFVVQUZGBuLi4qxiePbsWYYVcVM/jljJWcy2tbWxpn3S0tJYsmQJZs6cyUzgsrOzO6jQueve1NQEd3d3xq/avHkzc5Nsb29n9hh9+vSBuro6I00SidTqXAn/y5cvkJeXh4aGBtLT02FpaQk+n48JEyZAKBSirq4OZ8+eZcZnysrKGDNmDGbNmoXo6Gg2FVu+fDnCw8Nx4cIFZGVloba2Fp8+fcL+/fvZeVtZWeHFixesy+yoUaMgJyfHpszA737OdnZ2GD16NBYtWsTaiUtJSTHs5lsMjhvwbt26BQ8PD4wcORIjR45EVVUVamtrER0dDU9PT4iJibEB59y5cyygcT+nTJmC6dOnY/To0eDz+R2ye26q3L9/f1y8eBGlpaXo3r07NDU14e/vj7i4uO++O8C/QehvCUJcRYjLNOTl5XHmzBnEx8ejvr4ezc3NePr0KSOcjRw5Etu2bYONjQ2srKzYiHPu3Dm0t7czp8SRI0diyJAhjLKfmZmJwsJCppvasGEDJCQkEBYWBj8/P8yZMwfHjh1jdqzbt2/H58+fWSPAPn364N27dyguLkZVVRULUn379oVAIIC9vT2uXbuG4uJiCAQCbNy4Ea6uriAimJqawtjYmJWu9fT0GFv41atXIBK1Px4+fDgiIiJQW1uLzMxM8Hg8NuW8f/8+1q5di8DAQMb4DQ4OhpOTExITE8Hn8/Hrr7+yETwhIQE9e/ZEeXk5a6E9d+5cfPnyBXPnzu3Qw33lypVIT09nNIeGhga4ubkhJCQET548QW1tLaMccFkfh1cREWNu+/r6Mp0Wd43Xrl2LK1euQCgUIiIigrUhevfuHbZv346uXbt2aCc0duxY9ixwjQ8jIiLYFI8LhtyqqKjIKnsyMjKwtLTEjBkzcOjQIdy+fZvJdbjnRElJCc3NzWhqamLfmWs5RCSqAvbo0YMFJVNTUzx9+hSxsbEICAhASUkJoqOj0adPH9TX1yMyMhJ1dXXIzMxETEwM8vPz4eXlha5du6K0tBStra2or69HSUkJ61d26dIlGBsbY+nSpViyZAkbTMvLy9He3o7du3cz7dz3ln+D0N8QhH799VfMnz8fiYmJ6NSpE7p3747Y2FjWZbWwsBB9+vTB8OHDsXPnTly7dg2fP39GdHQ0exBtbGwwb948KCgoQEFBAYaGhrh+/Tr8/PwgEAgYIzg/Px8AsGjRIhw9epRJF74dXbdu3YqgoCAmoA0NDWWdOQoKCnD16tUOwKiMjAw0NDSYNujDhw/w8PBglZ/u3bvj6NGjOHPmDGJiYljmUVhYiDdv3qCiooKJP7/dp62tLaSkpDBmzBiIiYlBX18flpaWkJKSwvz58yEpKYnNmzdj5syZkJOTg6ysLMaNG4dJkyaBSMTu3rRpE7Zt28bM3hwcHDBo0CAEBQV14MTIyspiwYIFaGhowKVLl7B3714EBQVh165dAESWsdzvurq6wsXFBWFhYeDz+R1A9W9pCUSiHnE+Pj5obm5GeXk5LC0t2blwvKEZM2YgNjYWJ0+exMWLF0EkAvvPnj3LBqi1a9fi5s2bcHBwwNSpU8Hj8Tpo0tzc3PDhwwcMHDiQXWMxMTEAooyyqakJc+bMYZU8WVlZjB07FjIyMtDR0cHz58+xbds2ODo6dmCPc9/Hzc0NUVFRLEvdtGkTiES9znbu3AknJyfWyWPHjh2Qk5PD1KlTsXv3bsZha21thY2NDSQlJZGQkIA9e/agsbERLS0trBDy4cMHCIVCnDx5ktErvrf8G4T+hiDk6enJnPi6d++ORYsWAfhdJwQA6enpePnyJeNP/PTTT5g2bRpkZGQwbtw4+Pj4sCoUEbH2Kg8ePEBERAQDPNesWYMRI0ZAVlYW3t7ejIi2fft2dOnSBXw+H3FxcXj16hXi4uLw5MkTODs7w87ODjU1Ndi0aRN7+KWkpLBgwQKkpKRg165dSEtLg5qaGgYMGIBjx47B3t4eRkZGWL58ORwdHVFXV8d6lBERQkJCYGpqCklJSdZnXUFBAY6OjvDw8GBta/T09MDn89GlSxdMmDAB1tbWeP/+PebNm4ecnBw0NDRg8ODBDEP4NqvU0tLC4cOHYWtri3PnzsHBwYFJRjjuTlZWFu7evYtBgwahtbUVvXr1grKyMjvuxYsX2ZRFTk4Ovr6+uH37Nvz8/BAREcF6s4mJiUFWVhZSUlIMW9HQ0MDVq1cBiCpVXPWqubkZubm50NHRgbW1Nfr27cswMxMTE1y8eBGACE86cOAA3rx5g759+0JSUrJDwOayuUOHDuH06dPIyMhAc3Mz9PT0MGDAAJw+fZqZrDU0NOC3335jhQktLS0sWrQI0tLS+Pnnn7FhwwYIhUJUVlYyZj13/TmskrOn5QoD+vr6yMvLg6KiIqZPnw53d3dkZWVh5cqVrImlrKwswsPD0dTUhDFjxkBZWRnHjh1jHYePHDmCBw8e4OXLlxg/fjzTKJqamn733fl6v//ZIEREXYjoGBG9JaJmIiomooNEpPJf7CPt29HpP6zSf/J3fYkojoiqiKiJiPKIyJOIZH702D8ShDhxIiDiWVy6dImVJ/Py8nDnzh1EREQwXo+9vT0WLFgAIhEbubKyknlO83g8jB8/HlpaWuzl79y5M7p06YLy8nLcunULw4cPx+DBgyEUCiEUCrFz504cPXoUgYGBGDRoEHR1dfHzzz9jy5YtAES9rmJiYlBUVIT09HSkp6djyJAh6N27NwQCAaKiolBQUMBK19ra2nBwcAAg4kABvwdUNzc32NvbY9myZUy5Li8vj8zMTNy4cQN5eXloa2tDaGgolJWVYW1tjW7dumHmzJloaWnB+PHjGRDMZRjA7+bosbGxDJT+drrVrVs3fPnyBSkpKVizZg0kJCRgbGyMdevW4fr165g2bRoEAgFKS0uRn5+PESNGYOLEiThy5AiTTHAWFhcuXAAgCvDfqu+5fxcXF+POnTuQk5ODhIQEevfujdraWuZ9vW7dOkRGRqK1tRUHDx5E586dISYmhq1bt2LHjh0wMjJCSEgIgoKCGP9p586dkJeXx6RJk5if9/379yEtLQ1dXV3cv38fy5cvZxKg3NxclkU9fPiQ3YNvlfrcwERECAgIwIEDB5jpfFhYGIyMjCAmJgZDQ0M0NjZi6tSp2LBhA44fP45ffvmF/W1GRgamTJkCAwMDmJmZgcfjoX///hg5ciQ8PDxYZiomJobm5mbU1NSASMRr2rFjB4KCguDo6MgaDvTo0QNXrlzp0Nr8r5Z/NAgRkR4Rvfv6ZS8QkQ8R3fj6/5dEpPaD++GC0I4/WcX/w98MI6JGImohohgi2ktED7/u5zYRSf3Isf+bIOTl5YWQkBAkJyejuroab968gZKSErp164bCwkL2UI0YMQIvXrzAzz//jJ07d8LCwgIBAQEMGORWrizu4eEBMTExZGZmoqysDGfPngXwO9GRY+YuW7YMRKL+74CohzlnmcHZW5w7dw6RkZFYvXo1evfujYSEBJai//zzz5CSkkJubi7Gjh2L5uZmNDY2YseOHYiLi2PHa25uRltbGzvPfv364eLFi/jw4QN69OgBQJT5EYmqNBwGk5qaCgMDA1y9ehVCoZDxXqqrq+Hp6YmEhARER0fj/fv3CAwMhK2tLRv1OZawUCjEzZs3WZk9ODiYfe9OnTohJiYGnp6eCA4ORs+ePeHt7c3KxZ8/f2aN/Z48eYLAwEAMHz6cTVl++eUXlnVcuXIFVlZWCA8PR1hYGLp27YqysjJUV1czsmZbWxtycnKYwp/L3riBpHfv3rCwsICKigoLrGZmZliyZAmWLFnCvlu/fv0QERGBTp06QUtLC4mJifD09ISJiQl69+6NEydOwMvLCxkZGSxD69SpE6Kjo1mVT19fH8rKyjA2Nsbt27c7dMb19PTEmjVroKamBn19fVy/fh0FBQWoqKhAdHQ0mpubkZiYCIFAwAKvpKQkxMTEEBUVhaysLCaetrKyYhhQ9+7dUVNTw/hbT58+RUNDA4yNjREaGsq6wnxv+aeD0NWvF8L+D5/7ff388A/uJ42I8F8cV4yIcr8eY9o3n/OJKP7r5y4/sq8fCUIbN25ETEwMhg8fju3bt7O039bWFgsWLIC0tDQMDQ0hIyMDKSkpuLm54ebNm6xfODfKDB8+HJ06dWIZAKfEHjVqFBYtWsRUyTk5Obh58yZWrlyJ0NBQrFy5EiYmJvDx8UFycjLT7Fy+fJmZc/Xo0QPr1q2Dvr4+Zs+eDR6Ph1OnTjEuR1tbG27cuAEej8d4Q7q6uqziRvQ7We7ChQuYOHEi1NXVsXv3bsTHxzOx4k8//YQuXbowXMLHxwfl5eXIzMxEe3s7Tpw4gQMHDjCsCxB5dHt7e0MgELCsJSEhAU1NTawMHBkZCeD3jKyqqgrTp09HQUEBHj58CC8vLxQXF3c4361bt6KoqAjx8fFob2/H+fPnO9iSEIkkJYsXL0a/fv0QEhKC0NBQLFmyBBkZGXj8+DHrLDJw4EAAooytqKgIe/fuxebNm3H37l3o6OgwWYSYmBicnJxw9+5dXL58GQEBAejUqRPTtnGVKPqK1/B4PJYxcJlyly5dMGbMGPa73LlyP3k8HtTU1PDy5UskJSWxKisHtJubm+PGjRvM2aClpQWxsbGwsbHBuHHjAIh4Wu3t7di3bx9r0Kmqqor79+9DIBAgLS0N3t7euHXrFgICApCWloZVq1YxDZm1tTW6dOmCuro6XL16FUlJSVBXV2eVyZaWFhQXF3/33QH+wSBERD2/XuwiIuL/YZsCEX36mqnI/cC+/tsgNPbrsdP/4ryKiYj3vX39KCZERJg0aRJevnzJeDvcSC0rK8tGyfLychQWFjKF+Z07d3D37l2EhYWxEnFeXh4CAwMhFAqhp6cHHo8HFxcX2NjYYO/evbh69SoEAgE2bNjAqjpEIklDc3MzJk+eDD8/P8yePZt1P+DwptGjR6Nz586Mj3Tr1i2GIXHApLW1NQsiXPbGrQoKCgzUNDExgbi4OCQkJGBpaYnLly8zTde6deswa9YsLF26lFXc6uvrkZWVxaYo27Ztw/HjxyEpKQldXV3WL51IxE+aN28e+Hw+5OXlkZKSgpqaGgiFQoSFheHMmTN49+4dM1OTl5dn24h+l5usXLkSkZGR0NTUhLy8PFRVVWFtbY2UlBT4+/tjxYoVTP0+dOhQlp2EhISgpaUFjx8/hre3NzZu3Ah3d3ckJCQgICCA6ba4ipuqqioj7QUHBzPXS04cGhgYCGdnZ1Yt+3b18/NDY2MjjIyMwOfzISYmBoFAgKNHj6JLly44d+4c9uzZwxpeenl5oaKiAgkJCfD392ecnCdPnrDuJe3t7WhtbYWVlRXa2trw5s0bmJubQ0tLCxMmTIC7uzu2bduGbt26sSBGJDIzCw8PR3Z2NoKDg5GcnMyqXBcuXMCRI0dY48yHDx9i6dKl6Ny5M44dOwZZWVmYm5sjKysLjo6O0NXV/YEQ9D8LQj/qMT32689rANq/3QCggcfj3SGiCURkRkSpP7JDHo83l4h0STTF+o2IbgBo/otjX/njBgCveTxePhEZkiggFf7Isf9qUVdXp169epGKigr16tWL9u3bR8HBwZSamkqBgYEkLy9PixYtIgMDA9LW1qbm5mbma1xTU0OGhoYUFBREjo6OVFxcTK2trSQuLk4CgYBaWlpIT0+PYmNjqaioiG7dukXa2tpERNTS0kIaGhrk4OBAo0aNIktLSzp//jwlJydTYWEhPXjwgCorK6mqqorExcWJx+NRcXExVVZW0sCBA6m0tJSam5spLCyMUlJSaMOGDVRUVESXLl0icXFx0tXVpfr6ehowYABlZ2cTEVFDQwPNmDGDHj9+TBISEjRq1CiqqqqiuLg48vPzo/79+1NKSgpVV1eTtrY2GRoa0rNnz6hfv35kbm5OfD6fJkyYQJcvX6ZXr17RmzdvaM2aNVRbW0tTpkwhIqLp06fT4MGDSVNTk1JTU0lPT4/y8vLoy5cvJCEhQbNmzaKMjAxSVFSklStXkqurKzU2NpKrqyvt27ePxMTESFNTk44ePUqxsbH09OlTqqmpIaFQSK9evSI+n089e/akrl270uLFi6l///7E4/Ho4cOHJC0tTYWFhaStrU2//fYbDRs2jIRCIZWUlFBFRQUdPXqU4uLiaPny5QSArl27xu5jVFQUlZeXk7m5OZWVlVFcXBy9f/+e7O3t6cCBA1RaWso8l/l8PvXq1Yt+++03unXrFr1//55WrFhB6enplJ2dTTwej1pbW8nX15dCQ0NJW1ubXF1dydnZmaKioujcuXPk7+9PjY2NJCMjQ42NjdS9e3dSUVEhANTU1ERSUlI0duxY6tSpEzU3N9OAAQOooqKC3r9/T9OmTaOzZ89STU0Nff78mXr27EmvX7+mgwcPkpWVFfXv35/u3LlDP/30E/H5fLpy5Qr5+PiwZgEtLS1UXFxM5ubm1NDQQObm5vTu3Tt6+/YtM9BftmzZ/9tX68+XH8xG9pMoujr/yfbgr9vX/sC+0ug/A9LviGjWf/j9M1+3z/yT/SV93T7pe8f+kUzo+vXrUFVVhYuLC3JycuDk5MRGanl5eXTq1AkvX77Ep0+f8ODBA+Tl5bEM4+3bt2hpaYG8vDyGDBmCW7duoa6uDr/++isCAwMhEAjw4MEDzJgxA5cuXcKSJUugpKQEHo+HwMBATJkyBQEBAWz+zampTU1N4enpicWLFzMuEOd2SF9xggkTJkBZWRmqqqqQkpLqgCN8uwYGBuLmzZuQk5ODiYkJqxC9evWKjdgCgQADBgzAy5cvmbbs/PnzOHXqFBoaGpCWloaJEycyDMPLywv19fUoKCgAkcjMjRMCDx48GA8fPkROTg7DWlauXAlNTU14e3ujsrKS8Wq4THHlypWYPXs25syZw6pkaWlp7PuGhIQw47KrV68yrKyxsRElJSU4cuQIYmJi0K9fP7i4uCAhIQFmZmbw9vbGwIEDUVVVhfz8fFYFTEhIQGRkJDp37owTJ07Aw8ODEShPnTqFN2/ewNnZGfQVQObz+R2qn3w+H+PGjYO6ujojPZqamjJW9ZMnT+Dh4YGGhga0trZixowZUFdXZ1NlzpJ1ypQpUFRUxKlTpzB48GAUFBSgtbUVmzdvBiDCK4mI0S0GDRqE/fv3o6mpCZ8+fWIFFH9/f+aL7ejoCOD3qa9QKGTZPmdh/PnzZ1bl46bKtbW1WLBgAfr27Yv37993KNj81UL/4HQs9OsFX/Un272+bnf9gX05EtEUItIhImki6kVE3iSqtrX9MZgQ0bWv+x7/J/s7+XX7/D/ZvpqIHhHRo27dun33Ir59+xYDBgzA/PnzsWrVKjx+/Jh17IyJiYGhoSFu376NyspKhISEsCDE5/PR2NgIBwcHhIWF4cCBA0hNTUVubi6zI42Li0N6ejq6dOmCpKQk1NbWMlxAR0cHrq6uGD58OHr37o3bt28zpjGRqLr08OFDlJaW4siRI1BUVISUlBRUVVVx6NAhZkY+aNAgqKurs5eof//+DJvQ0NBgxlVtbW3Izc2Fj48PUlNTkZGRAYFAgMOHD2P9+vVQUFDA3Llz4ebmhgsXLkAgEODkyZN49uwZC4ZEIuD8ypUrOHDgAPT19TFw4ECYmppix44dqK+vR2lpKWN9c3/DnZOTkxMiIyNBREhOTkZNTQ1kZWXZFI++Ar2DBg2CvLw8+vXrB21tbRw8eJDtixP0CgQC5OXldbiXnMaMm+aamJjA2dkZQqEQjx49QmtrKyMr1tfXs17sbW1tWLFiBczNzVlJ/9atW3B2dkbfvn3B5/NhY2PDmOo8Hg/jxo3D6dOnMWbMGPTv359VxhobGzF58mQWwJqamph7ooaGBgYNGgRxcXFs374d79+/x+XLl9HU1ITly5dDVVUVK1asQFlZGS5cuIDExERERETA398fY8aMYY6cOTk5KCoqwqVLl5CZmYkvX76goaEBFRUVaGlpYcEwICAAt2/fRlFREaZOncpE1K6urrh37x5sbGwQFxeHfv36ITs7G+Xl5cw22M3N7bvvDvD/bRDypv8CIP6Tfaz7uo8nf/j8e0Eo5uv2ed87xo9kQk+ePMHixYuxevVq6OvrQygUIi0tDRkZGTA1NYVAIICysjJsbGxAJGLInjhxAi9evEBbWxtOnjyJc+fOISMjA+bm5hAIBNi2bRtr3xwTEwMTExOcPHkSt27dgo2NDdTV1TFhwgQAokqOhIQE3N3dUVdXB1dXV0hLSzNiW/fu3fH8+XMoKSl1YOu6u7tDTEwMFhYW7MWQl5eHs7MzUlNTsXv3bhARsyjJzs7GwIEDMWjQIKxbtw5XrlzBuXPn4OjoiD179jB/661bt0JVVRVbt2y8CZcAACAASURBVG6Frq4u+vTpA4FAgC1btmDIkCFMY8VZfnCVFz6fDy0tLZYldu7cGTdu3GBcGE1NTSgrK6Nr167w9vZGY2Mjamtr0bdvX2ZdIi4ujsmTJyMuLo4FHUNDww44naSkJAQCATw8PFBVVYUnT57g5s2bWLduHWMl//LLLyxDMTQ0hLW1Nas6AkBpaSm8vb0xbtw4lnXs378f8vLyuHz5Mp4+fYrKykpcvHgRRUVF2LRpE0pKStDc3My0ZqtWrYJQKMSBAweYN3VZWRkzx+vUqRNzSBQXF8f69euhra3NdHwcUZBjSnNtozkjNgBYvXo14uLimDr++fPnyMzMZAx0AHj27BkqKysRExODEydOoK2tDU1NTcyB4dGjR8jNzWV2svX19aisrERtbS3S09OZgPnMmTO4c+cOu6+zZs367rsD/M+C0I9iQh+//lT6k+2Kf/i9/8lylIj8iWggj8dTANDwv3hsthw7dowaGxvpxIkTlJCQQLt37yZPT08iIlqzZg1169aN6urqSEJCglRUVKi2tpaKi4tp4sSJdPPmTbK0tCQtLS2aOHEivXz5kurq6khdXZ1qa2uJx+ORhYUFzZs3j548eUInT54kHo9HgwYNovnz59ONGzfo8+fPZGNjQw0NDTRnzhzS1tamsrIykpeXJxsbG3ry5AmFh4fTx48fqaGhgaSkpKhPnz4UGhpKampqpKioSEZGRiQnJ0fm5uZUV1dHY8eOpczMTFJSUqK0tDTy9PSks2fPkoSEBGVmZlJ6ejqNHSuC3u7du0eurq5kbm5ORETBwcHk7u5OJSUl1NDQQEVFRVRUVERtbW1kaWlJAoGANUGUlpam27dvs6aEFRUVJC8vT+7u7tS7d28aM2YM9evXj758+UJmZmZkZGREmzdvpi9fvhCRaEDMzs6m1tZWqqmpoTdv3pCamhrNmTOHJCUlSVxcnO7du0fS0tIkLy9PAKi9vZ3evXtHGhoapKGhQSYmJvTkyRMSFxcnKSkpWrBgAW3ZsoW+fPlCysrKZG9vT3Z2dlRYWEjTpk2jpUuXkoGBAdXW1lJaWhrduHGDdu/eTe3t7dSrVy/y9PSk1atX09GjR+nu3bskJiZGM2bMoKSkJJo1axZVVVVRjx49yMHBgc6cOUMNDQ30+fNnkpCQoM6dO5NQKKQbN26Qp6cnXbx4kfLy8qixsZH27t1LRkZGtGbNGkpLS6NZs2aRtLQ0BQcHk62tLV28eJHc3d3p+PHjtHr1anr48CHp6elR7969WT+xkpISamtro5iYGDIyMqItW7aQsbExERH99NNP1KNHD1qyZAm5uLjQ48ePSUVFheTl5enGjRtkZmZGREQ+Pj60ZMkS6t27NxERycjI0Lhx48jCwoIOHTpEzc3NJCEhwfb7jyw/EqmIaBWJRp4jf7KdK9+P+2+j4B/2U/N1P52/+Ww3/cVUj0SkRRCR3vf2/yOZ0MKFCyEpKYmsrCw8evQI7e3tuHfvHjZs2ABA1NbGyMgI27ZtQ35+Pi5duoRbt27h7t27qK6uxsePH1FaWoqcnBxMnjwZ9fX1OHz4MGRkZCAnJ4f+/ftDKBSyKgXHeP348SMiIyOhqqqK3bt3w9nZGZKSkhg9ejQr+3Im8gMGDGCZAHdenAlaS0sLcnNzcfPmTbx8+RLdu3eHk5MTFi5ciICAAGzevBmhoaEoLi5GYmIi7t69i8rKSiQnJwMQCXP19PRgbGwMMTExWFpawt/fHwcPHsTMmTMxYMAAdOrUCUpKSli6dCn69+8Pe3t7iImJQVVVlfFMuJXH4zE8oaysDPPnz2eK9JMnT6KxsbGD3ejnz5+RlJTE8JLFixdj8uTJ6NmzJzp37oyWlhZGsOvTpw/y8/PR0tKC169fQ05ODqtWrYKtrS3evn3LmO8xMTFM1/f8+XMYGhqybJS7D01NTRg+fDhu3ryJt2/f4tatWyzT9PHxgb29PZPEWFhYYO/evTh37hyqqqqwfv16REdHY+nSpfDz88PBgwcRHR2N+/fvM1kIp0czNTXF5MmTkZiYiKdPn6Jr164QExNDS0sLCgsLsXnzZggEAlbZ8/LywqhRo9j1XLlyJWJjY+Hn5wd1dXVGfpwwYQJu3rzJnqnc3FwIBAKYm5uz6qKzszNaWlqgoKDALE+0tLRgYWEBNTU1Nm0kEnmQb9y4kWWgSkpK3313gH92Oqb39eSK6M9L9J/pB0r0f3GMXl+PUU/fEBbpf7lEHx4ejqKiIrS3t6Oqqopxbz59+oTMzEx2kwYOHIjnz5+jra0Ntra2UFFRYfvgHv6ysjLweDyGSXD8m82bN0NVVZUxi3fv3o2hQ4dCIBBg+PDh7GHQ0dFhAcjb2xvTp0+HjY0NZs2aheTkZOjr6zMVNiB62UaNGsWwEK4flr6+PpycnGBjYwMnJyeYmpqiuroa+fn5uHDhAgIDA3Hv3j2kpKRAUlIS1dXVGDNmDLp164ba2loUFhay781JIjiPY0CkpicScV++1dCtXr0aFy9ehIeHByZOnIghQ4YgKysL8fHx2L9/P3r16oUdO3YAEJWhExMT8f79ezg7O2P//v0wMTFhL3FFRQWcnZ3RvXt39OvXDxoaGti3bx8SEhLg6enJbEq46UZmZibKy8uZowB9xYY4x0NNTU28ffsWBQUFeP/+PebPn4+srCy4u7sjLy8Pzc3NSE9Px4wZM5Cfn4/OnTszagY3leGY5NevX2f3/tGjR7CwsGD348GDB0yewgUDIsLly5dRVlaG5ORkKCkpYe7cuUhMTMT9+/dRWFjIvs8fA7pAIMDBgwfh5+cHZ2dnVFdXMx+qixcvoqqqCsnJyZg9ezYuXbrEApeWlhZ69OiB/fv3Y/DgwbC3t4eLiwtUVFRYL72srCwMHjwYlpaW8PHxwbhx46CgoABdXV2sW7fuu+8O8A8GIXTMdn6IrEhEvYmo9x8+60lEOv9h3+pEdPfrfkL/sO2vyIpc5exvIysOHjyYBYeioiKMHj2aBaKcnJwOeqHGxkZWaRg7diyeP38Oa2trhIWFMd0PJwNYsmQJ439oa2tDTEwM69atg1AoxNatW/H8+XP88ssvkJKSwuTJkxkhzsfHh9mHNDQ0MAyGa8nTuXNn7Nq1CxUVFUwJv2PHDkhKSsLLywtnz55Fc3Mz3rx5g4CAAMydO5c90CoqKrCysmKVO47vxJm9E4n4NnFxcejTpw94PB60tbXB5/NhYWGB5uZmfPr0CU5OTliyZAmKi4vRo0cPiImJQUNDg3WjXbJkCSMeduvWDXFxcYwDJCcnxzyCuOs4depUVFZWMklGTEwMABERkkhkiMZZhty7dw9nzpxh7gRLly6Fg4MDXrx4AX9/f3Tr1g2TJk1CXl4eTp8+jYMHD2Lr1q2ora1FWVkZw7HmzZsHLy8vpKSkAAAuXboEJSUldmwnJydm2zJz5kyEhYVh2LBhePfuHcaOHYtff/0Vz549Y9fwxYsXOH/+PIKCghg29e3PtrY2TJkyBSNGjMDKlSshEAjQ2tqKtrY2REVFsevfo0cPJo9RUlKCjo4OJk+eDFVVVeTl5aGpqQmxsbEYMGAAs3VtampCWFgYUlJSICUlhdjY2A4G+FwX4OTkZHh5ebGgeefOHYZxRUREdMAcOefH7y3/dBD6o2xjD/0u28ijP8g2uJP/w2fLiKiVRFyiUBJJP2KIqO7r7z8kIuX/cOw/yjZ86B+SbcydOxeqqqqsasItxcXFMDU1RVZWFiIiIiArK4tjx47hl19+Qffu3fH06VMUFhYyf+cjR44gOzsbNTU1WLRoEWOcpqSksBuroaHBiGiAqALT3NyMM2fOYM6cObC2tkZwcDCSkpLw6NEjbNmyBXJycli4cCF8fHzQrVs3SEtLs4eR84apq6tDVFQU3r9/j4qKCrS2tuLMmTPw8PCAtbU1+Hw+pKSkcOnSJejp6aFnz56ws7PDnDlzGNEwLy8PFhYW0NbWxq5du1hZeNq0adDT04O+vj7u3LmDq1evgohw/fp1CIVCzJ8/H5aWljAyMoJAIEB4eHiHkXzQoEF49uwZZs6ciYyMDGzevBlz5sxBfn4+Zs+ezTIAMzMzaGpqwsbGBgYGBqirq2MiWs78iwvU39qvcFVBFxcXbN68GQoKCujXrx9jiJeUlGD37t0YMmQIMjMzkZSUhI8fP0JHRwc8Hg8xMTFobW1l8g15eXnExsairKwMERERDLC3tLTsoNgnInz48AFz587F+PHjcfLkSRw6dAhv3rzBsmXLMH36dHh6ekJGRgYLFixAbm4ujh07huTkZAQFBeHDhw8so+UCma6uLvOwrq2tZVVDSUlJnDlzhnU54Y5vaGiIFStWwN3dHUKhEPX19bh8+TLa29vZVJ8LbCoqKpg6dSp27NgBNTU15vjg7OyM4uJifP78GW1tbeyacyzz7y3/aBD6Ggy6ElEEEVV8DQglRBRARKr/4Xf/UxAyJqJIIsohog9EJCQRDpRBRPZEJPkXx+77NfOpJlE5P5/+AQHrvn37OnSwaG9vx8ePHzFr1iwQiTRTgAiDSU9Px7Vr1+Dr64sjR46gvLwc+/fvBwBm08GxgN3d3ZlXNaeP6tevHwCRfovjunz69AkJCQnw8PBAcXExbt68idzcXFRXV7OR+NixYx3K987Ozrhx4wZqamowbNgwHD16FCoqKuxc3rx506HsTSTSDZWXlzOWMFe9+bZdEadwnzx5MtOMJSYmYtOmTZCRkelgvt67d28sW7YMUVFRWLhwIcTFxbFx40YkJydj/fr1TNbw/Plzdh1qa2vh6+uL+Ph4AMC6devw9OlTJCcnY9KkSVixYgU0NTWZMHfXrl1QUlLC4MGDWRYoIyODYcOGwcXFBQcPHmTnY2FhgV27duHRo0coKSkBkcg9kRPcpqamQkFBAT179mT4C7dynkn6+voQExNjWr1t27ZBUVERo0ePxtmzZzFgwACIi4tDUlISI0eORGFhIbKzs7Fnzx4IBAKWUXOBmWsCKS4ujqlTp+LEiRMAREHHw8ODTZEjIyNZJrRo0SKWEXK8JiLC7t27sWDBAjQ3NzMbFM5RoXfv3sjLy4OHhwdzM+CmkhYWFkwvZm1tjVOnTuHXX3/F0KFDMXLkSMYM596B3NxcnDp1CteuXfvuuwP8LwSh/9PXHwlCP//8MwCwoNDW1oaKigq4uLjAwMAAy5YtQ2pqKvz9/ZGRkcGMwoyMjBAYGAgxMTG4ubmhuroaZ8+ehb6+PoyMjPD69WuUlJSwtHj06NHYt28fFixYgPb2dqSmpqKoqIg98C9evEB6ejp4PB4OHTqE4cOHM5e86dOnM7IeNzImJyczVTYn01BXV8e8efPYqMl9pqOjw9oD3bhxA1u2bGE4Unh4OLy8vFBeXo6cnJwOHSiMjY3x6NEjlm1wdqxEop5eHH7z6dMntLW1MaEnp6MaM2YMjh8/jlevXqG2thY5OTmora2FmZkZDAwM0LdvX6xZswYXLlyAnZ0dXFxcUF9fj7dv3wIQqfKjo6MRHR2NV69e4c6dO1i2bBl0dXUhJSUFAwMDdm7cC5WTk4P29nYcP34cGhoarInl+fPnWbbBXddvryeRiJtVWlqKN2/e4OPHjygoKMCwYcMwb948zJkzh/0dlxE5OjqitbUVp0+fZubxPj4+GD16NJKTk1m5m0jE21JSUsLkyZNhY2ODnTt3or29HfHx8Yy86ejoCGNjY8yfPx+FhYXIy8tjth6jRo1izwqXORkZGUFcXBzdu3eHv78/vLy8sH//fjx69AjLly+HlpYWIiIikJmZiRcvXiA+Ph7+/v7McWHo0KFYu3YtZGRkcPr0abx79w45OTk4fPgwEzx/b/k3CP0NQcjAwIBZWb5+/ZqNAOXl5VixYgX27t3LQM1Lly7B29sbsrKyzG7i/v37yMzMxLx589jN5YiMgCiz+vXXX9Hc3Ax7e3tMmDABu3btQlJSEnJyctDS0oKmpiaG7xgbGzMchxNsamhoYM6cOfD390dAQAA79/LychCJuEuysrLQ0dGBt7c3ZsyYAUVFRUhLSzNj+aysLLS1teHu3bsYPnw41NTUMGTIECgrK8PX1xd5eXms/TKfz2dTHgMDAwQHB7NeYkSEx48fw9/fHwoKCszKtKWlBefOncOMGTOQmpoKV1dXHD9+HEePHgUgYv/6+vpi4MCB6NOnD4yMjAAASUlJIBKR4wIDA+Ho6MgIdxzRctOmTeDz+Zg6dSoCAgJgZWWFAQMGQExMDCYmJuy8Ro8ejbKyMixbtowVBwwMDMDn87Fv3z5kZWWx7IpIxM2ZOHEiJCUlMW7cOGzbto1VPktKSnD9+nWGZXHrTz/9hLS0NMyfPx9EhKioKJSXl0NVVZVlHwoKCrCwsGDe2tz3U1RUxJo1a5iYub6+HrNnz0bfvn1x/fp17Ny5k3XPsLOzw7Zt20AkKgAkJSUhMzOTBXg5OTlWGT1z5gzevn2LhIQEtLe3w8nJCampqeCe/7y8POZWmZSUhHXr1uH8+fPo1KkTBg4cCFVVVVy8eBEKCgqwtbUFgH89pv+u9UeC0LdVgMrKSoSGhqK1tZU5zMXExMDAwABCoZDR6LnsZtSoUfj06VOHfuyWlpYIDw/v4LVTWFiIc+fOYdWqVSwDkZWVhYeHB7PejIuLw6NHjyAvL4+YmBioqqpi+PDh8PPzY3KJJUuWQEJCAosWLcLOnTthZWUFKSkpqKmp4e3btygpKcH58+cBAImJicz3uaioCEKhkDXmS01NhY6ODuTk5DBv3jyWycyYMQN8Ph98Ph+rVq3CzJkzsXPnTkRHRyM7OxurVq2Cq6srRo0ahSFDhuDChQtYtWoVli5dCnV1dXTt2hXnzp1DdXU1amtrkZubi7y8PKa4T0pKgrKyMsaNG4eePXsiMzMTe/fuhaSkJIqLi7F+/XrMnDmTVRu5adzDhw+RmpqKkSNHIigoCLW1tVBTU4OamhprwKikpIRRo0YxF4NFixbhypUrkJOTg4GBAUaPHg1JSUlGmCQiNj3auHEjnj59iuvXr0NZWbnD9JyTjnAmbNOnT8fhw4fh4uKCrl27sqLEpUuX2BS4a9euAMDwMU586+3tjZqaGggEAqxfv56V4jmRs7q6OkaMGMHIlGPGjIG4uDi8vb1ZhvdtGf3UqVN4/fo1DA0NIS4uzs6Ze/aSkpKwYMECdv3z8vLY1DYrK4tZqvD5fFy/fh1WVlbYu3cvQkJC/m3583etPxKETExMUFpaisLCQuTn58PFxQVjxoxBVFQU7Ozs8PTpUxQUFHSoXn3+/Jk9bG5ubjh+/Dh72Pbs2QMbGxu4urrCzMwMM2bMgEAggJWVFXJychAREQEFBQVoaGiAx+Ph9OnTzIto6tSpGD9+PHbu3Akej4dhw4YBAOPNcC/PyJEjWVuXAQMGoKSkBA8ePMDGjRuZGXpFRQW0tLTg6emJT58+oaGhAQBQV1eHR48eISMjA1JSUli0aBE0NTVhYmLCRu7FixczX5oePXpAWVkZ+fn5SEtLQ2xsLIiIVWYAQEdHBw4ODggODoaPjw8MDQ0xbdo0hjft3LkThYWFAESatba2Nty6dYv1aOMqMRyGEh8fj4CAAIwePRpfvnzBmjVrYGVlBXV1dVaB+9bQ7NuskUhksM/xadauXQt1dXVMmjSJsbV79erFJBJaWlowMTGBUChERkYGiEQAeHNzM+Lj4zFhwgQoKipCWVkZfD4fysrKEAgErF0Qp8WLjIxk2ZG0tDSOHz/OggORiH6xdetWtLe3IyUlBW/evOmA+YwYMQKDBw/G69evcevWLZibm8POzg5VVVVIT0/H/PnzERkZicDAQBw8eBARERHsuBYWFujVqxccHByQnJzMuupyi5eXF65cuYLs7GyUlpYiPj4eQqGQGb0pKytj5MiRSEhIYHjT/y9K9P83rD8ShDj/GW7x9fUFESEoKAgBAQHsZp89e5a1Hz506BBkZGQwffp0VjpfvHgxmpubmScRN89XUVHB3Llz2YPx7t07JCUlMVmBoqIi6x2/YsUKtLe3M/xHX18fmzZtwqNHjzBt2jSGAXHTFOB30iKXpq9YsQI9e/aEo6MjeDweRo4cCQDMh3jkyJFQVFRkwURVVRXLly/H8ePHWaWtoqICenp67AXh+mZx4LCYmBhCQkKQmpoKHx8fhIWFYefOnewl5MDez58/w93dHUVFRQgJCcG5c+eYiVtQUBDk5eUZSDxv3jxkZGRg6dKliIqKgq+vL/T19bF//354enpi/Pjx+Omnn9g0iwOTuQDk6uoKTU1NODk5obGxEXZ2dqisrGT2Itra2kwm4ePjg6ioKOZQqKurizVr1uDFixdQVlaGvLw8zMzMMGfOHJw4cQJKSko4duwY1q9fzyQT3HlwWjOuCslZi/yxDRM3rVq7di2rijk6OrI21IMHD2bWwtHR0TAzM8P58+fx8eNH1u11ypQp2LNnD2RlZbF27VqUl5ejqakJenp6GDVqFGvho6+vzwijbW1tiIyMRK9evWBtbQ2BQAAFBQV8+PCBAfiKiorIzc3F+fPncfv2bURFRTE44XvLv0HobwhC6enp7MV4//49evfujUGDBmHDhg0IDQ2FtbU1du3aBVlZWdbL6tGjRxAXF2dGVDweDxoaGkhMTGRYQmpqKmJjY+Hp6Qk7OztkZGSwKtT+/fsxe/ZsyMjIYNWqVQBE2FFxcTH69u3L+tU7OTmhuroagIi8SCTibygoKGDFihUsG/ny5QtOnjyJU6dOoa2tjYkera2tYWZmxvyHuO6sRCJtkJOTEwus8fHxDLwGRGb8XCPCiRMnYty4cZg6dSo2bdoEHo/HiHFc9TA2NhZ8Pp+BvBzuwY2oycnJ2LhxI5YuXYr379/D09MTOjo6yMjIwIABA7BhwwbcuHEDaWlp0NTUZDygcePGQSgUwtfXF7a2tkxMmpOTg5qaGuzduxf79+9HcHAw1NTUMHjwYMTExIDH40FRURHHjh1DTk4O7t+/j+rqaiZ6zc7ORnFxMR48eIC0tLQOxvVEhGvXrmHz5s2sTRIg4hK5u7vjt99+Y5mXmpoaFi5ciJkzZ6Jbt24s83FwcGBcKXFxcUyaNIkFXK6MLhQKce/ePYwYMQK2trYQFxfHiRMn8OzZM1hYWODNmzdob2/H+/fvERQUhMDAQAaKc+4KnHZPVVUVs2fPxtixY0FEGD9+PABRwUMgEMDX1xdLly5lU/u9e/fi1atXsLa2ZmZp3HMI/D4V/t7ybxD6G4KQvb09swU9cuQIgoKCGJB36NAhSEtLY/fu3bhz5w7Gjx+P1tZWZGdnQyAQwMLCAsbGxtDV1WUjYnt7OwoKClBfX49nz54hNjYWtbW1MDU1xZUrV9DY2IigoCCGNVRVVeH06dMAROSxb6s1gYGBCAkJQa9evRgOwBmOEYn4H5yZGle58/b2Zt7StbW1KCgoQFNTE3Jzc+Hn59ehPD1t2jSMHz8ehw8fZlO/V69eYdeuXeDxeBg9ejR7qDneCCdx2LVrF5YsWYLAwECUlpbi9evXOHjwIMLDw1nn1oqKCpSWlqK6uhr+/v7sms+ePRslJSWoq6vDkydPQCSqxHH9tqysrCArK4v4+HiEhoYiLCwMvr6++OmnnzBkyBAAIlA3OTkZV69eZRhSWloacnNz0d7ejkmTJsHV1RUfP37Eo0ePMH78eBw6dAhBQUEARBwtbW1tFky/XeXl5XHv3j0GMk+cOBGRkZHo378/hgwZwqgTq1atQnh4OPh8PqZNm8aCsISEBFJSUtgUnkjkIz1jxgxISkoiMzOT4Y6NjY2sP9yQIUNQVFSEmpoaVFVVwc3NDWvXrgUgwnOCg4Oxfft2dO7cGXp6ekhMTGQBaNy4cVBTU0OPHj2wbds2rF+/Hnfu3EFLSwtu3ryJ27dvM3dHIkJFRQVevXqF8ePHsyIBIBLJurm5dZhu/9XybxD6G4LQy5cvmTH4hg0bcOLECRw6dAgtLS04ffo0A3oBsEzhxYsXOHLkCC5cuAA3NzcUFxczcBcQVdk42wSu6pWVlcUAz2HDhsHPz4+9EHV1ddDS0kJsbCwEAgGWLVsGOzs7bNiwAZcvX0b//v1Ztaq2thYAWBcFQNRSmXP9i46ORmNjI+rq6rBr1y7mErhv3z4AwPr166GiosKmE3w+H9LS0hg6dCiKiooAgLWGIRI1Y9ywYQOUlZURFRWFu3fvAgADsidPngxlZWUoKSlBS0uLtUpOSkpi2iZfX1/w+XyUlJSgtbUVffr0ASACnDksae3atRg2bBimTJkCPT092Nra4vLlyxAIBDh06BBevHjBcKuYmBgcPnwYEyZMgEAgQHp6OpviFBQUIDo6Gq2trezlc3FxYYF03rx5zEje3t6euQ0QEZYtWwZra2ssXLgQiYmJkJeXZ06URCLtWmhoKMvSuGDPlf053yQu+9HR0YGioiKmTp2K8vJy5knEyUAqKyshIyOD7t27s+sEiOQ/zc3NcHJygqGhIV69eoVFixahoKAA6enpWL9+Pb58+YJt27ax3m75+fmsQKKpqYmVK1fi6NGjOHnyJMuExcXFwePxMG/ePPZ8Njc348WLF2hsbGQVsaKiIuY3/r3l3yD0NwQhb29vODo64vnz5ygoKMDt27eRlJTEOBwnT55kKWpjYyMqKytx5coVNDU1ITw8nDGjhUIh7OzsWFn06tWrmDt3LlauXIkHDx4wD+QXL17g3bt3iIiIwLVr13DkyBEIBAJWmTt16hTKysrQ3t7OHh7uwebxeJg5cyYqKytRXl6Os2fPYvny5bC0tGSWDKampjh27BgEAgGEQiE8PDywf/9+mJqaIjAwENu3b0dgYCArcRMRLly4AEdHR1RWVgIAunbtyqYVHGeH65HWu3dvhISEMGD225XP56OyspLhVMePH8fSpUtZJsdVe/h8Pg4cxsBBNgAAIABJREFUOIApU6awLq/f7uf+/fsARF0nBg4cyFrwcMxfLiAoKSlhy5YtmDJlCoKDg1lGu3fvXqSmprJrpqioCDMzM5SVlQEQ4Wd79uxBjx49GNivoKAAQET0HDhwICZPngwpKSnGUv/2/EaMGIE1a9agc+fOGDNmTAdDuW+xqqlTp8LX1xeOjo6sitezZ09cvXoV9fX1zD7YysoKX758QWpqKk6cOMGsO549e4b29nY4ODiASGRm5+7uDgUFBcjLy8Pb2xs8Hg8GBgZYv349ayPE4YnZ2dl48OABIiMjUVFRATs7O6b/KywsREFBAeLj45GUlARDQ0NmHmdoaMg0ft9b/g1Cf0MQioiIgLGxMZKTk+Hg4ID6+nqcPHkSDx8+RHR0NCIjI9HW1oa2tjbm3TNz5kzMnj0bRKKSPJcBTZkyBVOnTkV2djYSExMhFAqRmJjIuDTt7e3sdw8fPowZM2Zg0qRJHdrLcEEhLy+vA/BqZmYGAAgJCcGCBQuQk5ODI0eO4JdffkFqaipqa2sZoD1o0CCkp6cjPj4ee/bsQVBQELp06QJxcXEUFBRASkoK+vr6SE5OhoqKCgNT9+3bh+zsbAwaNAgDBw6EpaUlVq1axdjanNRh4cKFWLFiBeOxrFixAps3b4a8vDy2bt2K8PBwhISEQEdHB926desAcnOg/7fky2/XdevWMRY7J1GwtbVl5EsVFRVoa2sjKioKnz59gpqaGpvaOjg4oKGhAWVlZdiwYQMLboGBgYiOjsaVK1ewd+9edOnSBS4uLvD29gYARrKcP38+TExMYG5uzoIGEcHf3x9EIhqAt7c328Z1oSUSVZi2bdvG9GJExHzCY2NjsXjxYmhqaiIlJYX5IPn6+kJGRgYu/w97bx5O1d7/D783W+Z5SJk1D6KSUppokkacimiQU6TSoFknmToqoeyo0ECalKFBg4hSKgnRXE5IRSEybezX88dufe667/v7dO7fde7vc/2u56zrWtc52fay9l7r817v4TVs2oT29nZGTJWUlMSNGzeQnZ2Nzs5Ohj+bMGECFi5cCD6fD01NTQwbNgxDhw7FihUrGCqfGyBwImsAWOZ1/vx5FBYWQiQSMSvqyMhI7Nu3Dzo6OlBRUWFASC4o/2z7Owj9BUFIV1cXHh4eOHnyJJPH7N+/P9rb25Gdnc24Xps2bUK/fv1gbm6OxsZG1NTUsBtu5syZeP36NVxcXLBixQr0798fGRkZyM3NhZ+fH6qrq1FbW8usazjbH5FIhKamJowaNQrKysr/Yj8sLy8PCQkJLF++HNu3b0d0dDSD4I8YMQIHDx6Er68vGhoaUFBQwFJuRUVF3L9/Hzk5OcjKysKePXvQq1cvaGlpwdnZGTNnzmREzcrKSmhoaKC1tZVlPZz6oba2NtTV1TFnzpwfhPk5gODevXtx5swZPH78GOPGjcOSJUtARBAIBOjatSsUFRUxduxYdr6jRo1ifLePHz/C1dUVsrKysLOzQ2VlJWbMmIFjx44xFvz+/fuhrKwMVVVVLF++HN26dYOEhAQSEhLYlGrPnj3Q1dUFkRiVzB2fA3zu3LkTubm5iIuLY4t50aJFCAkJwfHjx1FWVgY3NzdIS0tjxYoVOHjwIMrLy1FbWwsnJydGE+Gmc99nPaGhoaynZWZmhoSEBCQlJTG8Vbdu3ZCfnw9XV1ekp6dj27ZteP/+PaqqqlBZWckUCPz8/FBRUYHRo0cjPT0dR44cYdZEgHiyqaysDHV1dXz8+BFtbW1YuHAhZGRkMGnSJKYC8ejRIygqKsLBwQECgYChnjU1NaGiooK6ujrY2NhAJBKhra0NIpGIqSpwn0lTUxN9+/Zl7rc/2/4OQn9BEDp79izOnz+P8+fPM3DZoEGD8O7dOwwbNozhWzizOkVFRTx79gx1dXU/lBGcQl9NTQ2amprYk3PDhg2wsLBAamoq0tPTWaZiZWXF+kWAuNFaW1vL2OWjRo3Cb7/9hpCQEEZE5HAl39sDW1lZYe7cuSzbcHZ2hoeHB5YuXYq8vDw4OjoiNzcXgLi8GThwINLT01FbW4uWlhaUlJSAz+ejuroaaWlpyM/PZ/70RP9QTuSespx31vLly9HZ2cnIuN7e3vDx8cGZM2fQq1cv1lPKyclhjdnIyEhcunQJgBjyoK2tjUWLFqG5uRlv375FTk4Ojh8/jitXrkBCQgI+Pj6oqanBxYsXGbCP+86XL1+OoKAgBAUFMZwVZ/oYFBQEgUDA4BMDBw7EyJEjkZeXh82bN6Nfv34gIlZmcZy4sWPHMlwYIIY/cHgkXV1dFsS43dDQEPfv34ezszOUlJRgYGDAuHZc34hTXRg/fjw7H478W1RUhD179kAoFEIoFEJVVRWFhYWorq5GS0sL8vLyoKqqytjtc+fOBSAmV3PnYGFhAXd3d5w7dw5r165lk66CggK4uLhASUmJwUY8PT2RkZHBaC2TJ09moETOrWX27NkQCATsu/zZ9ncQ+guCUFZWFgYPHowuXbrg6tWriIuLw+HDh/Ho0SNMnjwZtra2qKysxMWLF1naHhUVxUoFDQ0NzJgxA+/fv2cjeJFIhEOHDmH//v0ICwvD4sWLwePxMHnyZEhJSeGXX37BzZs3AYAt5Hfv3iErKwvr169n2QPXPOSmLIqKiujbty+srKxY7yE8PBwxMTHQ19eHhoYGS+u5XlVMTAwWL16M06dPw8vLC7t370ZwcDBcXFxw+fJljBkzBq6urjA0NISvry9evXqF5ORkFuiSk5NhY2PDpG7379/Pnt6AuBF8/fp1jBgxgiGQ37x5g2XLliEgIACPHj2CgYEBevbsid69ezMayYkTJ0Ak9pYHxFOZ/v37Y926dfjll1/g7OyM0tJS8Pl8hoLu2bMn44u9ffsW1tbWTCv78OHD2LZtG5ydnZkzLhcAuYD99etXiEQilh1yJcz32efq1ashEAhYVqeoqIiNGzdi5MiRjJT7fSAaP348RCIRIiMj0adPH0al4fP5CAgIwNSpU6GlpYVz585h8+bN6N27N0pKShAeHs4C1dy5c/Hp06cfSKN3795lXL3ly5dDUlKSmVpu3boVRGL+3r59+3Dr1i3Y2tpCSUmJycZGRkbCysoKo0aNwtatW6Gmpoa1a9ey43NWQa6urgDEEAsXFxeEh4cjOzv7Bznc/7ft7yD0FwShAwcOQFFRkfGJvleW4wiIZWVlePPmDSQkJLB06VIA4sbznDlzUFlZidbWVjx9+hTHjh1jT7WzZ8/+S8PVzMwMDx48wNu3bxEUFAQfHx+mF+Pl5YXp06fDxcUF+vr6mDx5Mg4cOIC4uDgmFE8k5pFxo9YuXbqwgEUkZkxzsgzR0dHw9PTEzZs3UVBQwD7XxIkTGZOeW0QcUvbevXsAxK6qjo6OyMnJASCeIF69ehVOTk7YuHEjpKWlMWPGDHz48AFfvnyBlJQUdHR04OXlhfz8fADAvHnzWEnh4OCAdevWQUdHBzt27MD9+/dZT2jz5s1obGxEfn4+tLW1AYg5cVeuXMGTJ08wevRoNqHi8XgwMzODk5MT3rx5g/j4eDx69IipRH758oXpUQ8fPhz+/v7Q1tZmzWwtLS3MmDEDu3btwi+//IIPHz78kA0dOnQIqampTAmBSKylPX36dAwZMgTy8vLQ19dn2CuOPHvgwAHk5uayYKmkpAQtLS0cP34cL168YKBLgUDAVCYLCgqgpKQEHo/H9Jy9vLzg6OiIoKAgmJqaomfPnpg7d+4Pk08AWLduHRYuXIjY2Fi4urqyLMbNzY31HM+ePYumpib4+/tDIBBg7dq16Nq1K7OV7uzsxNevXxEbG4tff/0VL168wLx589honmsZ/Gz7Owj9BUFo586d8PT0xOjRo6GmpgYJCQm4ublh6NChMDQ0ZL7z06ZNg4KCAmRkZJCRkQFra2tYWlri5s2bGDRoEKMc7Ny5k2VEnFMDl+obGxsjOTkZ9fX1OHXqFO7duwcigqWl5b9o5mzatIktIiLxVOqfzQyJ6Afcj6enJ0JDQ1nAsbe3ByDOtoKDg3Hq1CnExcUhNjYWGhoaUFVVxW+//QbgH1Ikfn5+kJKSYrwzQNy8P3r0KPr27cswTY8fP0Z6ejpqamrQvXt3Jqg/fPhwqKiowMDAAEKhEMnJySgqKgIgFm4XCATw8vKCq6sr1NTUMHnyZAQFBQEA0tLSMHHiRMbkNzExgZaWFtMw+n7ftGkT1q9fj0uXLkFSUhJTp07FzJkzMXToUNja2kJVVZVJxnLXgCP/ckF8x44dePr0KQwMDGBhYYGVK1cyiMSePXsQFhaG+vp6hIWFwcXFBampqXj8+DFmzpzJQH9EhICAgB+kVojE/by3b9+ipaUFUlJSCA0NZVO/iooKVmITEYqLi5keUF1dHfbv3w+RSISGhga0trbiw4cP2LZtG5PG9fDwQI8ePRAaGgp7e3vweDxs374d9fX1WLx4MZycnKCkpIS8vDwsWrQI79+/R0NDAw4cOIDCwkKWLQNivaWxY8cCEFsH8fl8LFu2DL/++utP1w7wdxD6S4IQ5ykGgGFp8vPzERISgkWLFrEbeOHChfj06RPc3d2RkpKCixcvory8HGvXrmW1+bBhwxiCWCQSITU1ld1oBQUFbNTMbR0dHfDx8UHPnj0xefJkljkNHjwYBw8exLFjx7B582ZMmDCBPWXXrVsHPp8PeXl5GBkZ/TCNcXR0ZKJUVlZWTB0A+IcELecawiF+R44cCRsbG8THx+PixYtYvnw5bGxscPHiRbS0tODjx4/Mo8zb2xtfvnxBZ2cnKxU4lrmioiIEAgEb+zs5OQEAwsPDcfz4cezevRsyMjIICQlBeno60tLSWL9l3759+Pr1K1NS/H6XkZGBiYkJFBQUfuCHcfv3i5krg7hpH5fR8vl8dOvWDVFRUSgqKsKaNWsYT05JSQmenp6MdqGnp8cyK653k5CQwGAHnZ2dTFuJz+czXaNTp07hwoUL7BpKSEjA19cXnZ2dSE1NxZo1a+Dr6wtAHNSJCJMmTUJUVBSuXbv2A2udo/h0dHTgy5cvqKqqwsiRIyEQCJieEZelycjIwNvbm8ETunXrBllZWXh5eaGwsBBubm7Q0tJiyGw1NTXm9lFTU4Pk5GS8fPkSzc3NKC0txfbt2yElJQVpaemfrh3g7yD0lwQhDqC3e/duyMvLIyQkBFVVVaycuHTpEng8Hk6fPg1ADCzU0tKCgoICAEBaWhoaGhoICQmBjo4ORowYgZiYGERFRbEFEhAQgOzsbERFRSE1NRUtLS1ob29nWBsOvHfjxg3weDwmktXS0oLc3FwoKytDS0sLhYWFjHbBZR4HDhxgtjKqqqro1q0bxo0bBwC4d+8evL29sXHjRpSXlyM9PR3KysqwsrJiwVVCQgKDBw9mHLnr169DIBDg2rVrEIlEyMvLQ0lJCRwdHTF27FikpKSwBj6nef3PgUFaWhpLly5FUFAQEhISUFdXh/v372PgwIEwMTHBsGHDkJWVhd9//x2amppQUlLC5cuX0dTUhBkzZmDv3r04dOgQVq9eDUlJSWYYEBUVBR6PBz6fD0tLS+jp6SEtLY017Hk8Hm7fvs2QxDY2Nuyc/Pz8IBAIsHDhQja9416bMWMGDh06xJQg3759C5FIhLq6OgwaNAi2trbQ1dXFjBkzMH78eObNZWZmhpycHJw6dQoVFRVoaGhgVB4iYuRiLuiEhobiypUrmDhxIszNzdnovLS0lIFdXV1dMWDAAJSXl+PChQt48OABA1tyu4aGBsOG7d+/H/X19Xj69CkKCwuZzfX58+eRnJzMHjqKioowNzdHt27dkJycjNzcXEZk/X57+/YtsrKyftDR/n/b/g5Cf0EQunr1KkQiEbp16wYej4cTJ04gKiqKTZTa2tpgbGwMT09PvHnzBoB4cXt5eWHAgAFMwMrX1xdmZmaQlJSEnJwcy1BkZGQwffp08Pl8rFq1Cj4+Prh69eoPPaPZs2ejtrYWsbGxqK2thbOzM3PL5BaUi4sL+vbti3v37kFRUREfP35EY2PjD0FAVVUVxsbGmDhxImpqapijq6KiIivbLCwsmJzD1KlTISEhgUWLFuHQoUMoKSnB+fPnkZiYCBUVFfTs2RMCgQBnzpzBqVOncObMGQgEAtajkZWV/cGx4fsdAFuQ3JO9R48erBTiROm55jAn8A+IwYQ3btxg2CbumNwo3tTUFAKBgCkQCoVC6OvrQ0lJCSkpKXjw4AFkZWWxYcMGFsQ4ze0xY8ZgxYoVrBe0YcMGxMXFse952bJlzBSRE/T/3oPeysoK8+fPh5ycHAQCAUQiEXx9faGhoQEHBwc4ODjA19cXgwYNYvdATk4OunbtypDpUlJS6OzsZM67HI4MEAuWcVxGjgrEUUu43mB4eDjevn3L+lfTpk1j09nKykqcPHkStra2aGxsRPfu3ZlZQVVVFVpaWtCjRw/U1dXh7du3jE7T0dGBq1evwsjICDIyMqx0/Nn2dxD6C4JQcHAwSkpKUFFRwSZKnZ2dePfuHaqrq9HY2AhFRUVYWlqylHnlypVQVVWFvLw8evbsiWXLlmHjxo0wMTHBjBkz2FRm0qRJuHv3Lry8vBASEoKsrCzo6emhoqIC9fX1jGldUVEBY2NjyMrK4s2bN9DS0sKKFSsgEong5uYGU1NTvHnzBjt27EDPnj3x4MEDtLa2QldXlyGGObkKKSkpHDt2DEVFRTA0NMTSpUuhr6+PnTt34ubNm1iyZAnc3d1hbm6OUaNGYc+ePZCSkkJkZCTrc8yaNQsyMjKQlJREeHg43r17h0OHDmHAgAH48OED6uvrwePxMHPmTCQkJDBHWhUVFQwdOhTh4eHIyMjAmDFj0L17d6aYmJmZiaysLBgZGWH48OHw9fWFubk5lJSUIC8vj3HjxuHx48fw9fWFvb09jh8/DqFQiKFDh7Kei66uLp4/fw5PT0/cu3ePueVy7qhqamqIiorCzZs3sXr1ambgmJ6ejh07diAsLAxZWVkgEgMMW1paIBKJWB9t5syZuHbtGlpaWjB+/HjMnj0bs2bNYpOsjRs3sjLS3d2daVmnpaUBEJtpCgQCZGZmIiYmBsOHD8eKFSt+KBG5/hSXcXFW5C4uLrh16xaio6MZj661tRXe3t5wcnJCU1MTCgoK2D0qEonYg8TExARNTU0ss3n27BkjER87dgxmZmaYP38+Dh06BH9/fwBgJFrueM3NzRg3bhx4PB6GDRv207UD/B2E/pIgVFlZiUmTJmHIkCGYMmUKzp07h9OnT+PMmTO4fPkyWlpacPjwYTZZ4UTvuSfkjRs3GH/q3bt3OHr0KJSUlMDn839gJ3NbZ2cnXr58ialTpzLh8uXLl0NBQQHDhg1DXV0d1q1bBzU1NQDA5MmT0b17d4waNQqBgYFQUVFBeHg4Wltbcf78eQD/wI2oqalh2rRp7HMdPHiQTc/Gjx+PGzdu4PDhw8zyRUFBARoaGti/fz927doFOTk5lkF8n8mZm5tjxowZaG9vR2pqKlJSUjBy5EgEBARg586duHXrFhOEV1FRgbe3N1uodXV1jPvE9auIxC4bXKbE4WD69evH0OJ79uxBaGgoqqqqkJiYiPr6enTt2pVJk3BuJRyYNDY2FioqKti3bx8D2j1//hwDBgyAmpoay3w4iYuUlBTY2tpi9uzZmD17NjsvHo8HfX19hoq2sbHBunXrkJGRgWXLlqGyspJRQbhzTk1NRUxMDPN+u3r1Ki5dugR/f382Qdu6dSvrbcnKymLfvn04d+4cLCwsGLDS09MT7e3trFeVkZGB1tZW7NmzB0lJSQyIyW05OTkYPHgwFBUVcfDgQTx79gxLlizBjh07EBERgXPnzuHdu3dMsbK5uRmA+CH68OFDpuIIiPtQ9+7dY6J7SkpKP107wN9B6C8JQlw5wePxUFZWhtLSUvTp0wdTpkzB5s2bmRiUrq4uVq9eDR8fH3DTj6tXr+LQoUPw8fHBiBEj0NraylJ4IsLixYvRs2dP3L17F69evcKIESNw48YNnDlzhhEEObBfQEAAKisrGX/re9+r8PBweHl5Yc6cOazx29jYyFDDHz9+/IEhzdnYAGJzQR8fH/ZUzM7OZlKhXF/j8uXLEAgEjI39PWXExMQEnp6eKC4uBiAGArq7u0MgEPxQit28eZM1hblswcLCAi9fvkRhYeEP+BqusXr+/HkEBQXB29sbnz9/RmJiIiv/OOePiRMnQlFREUePHsWAAQOQl5eH7OxsHD58GPX19Xjy5AlWr16NxYsXQ1lZGQcOHEBkZCT8/Pzg6OgIMzMzyMjIMEjA0qVLmdjao0ePMH/+fAwZMgTS0tKYNGkS65XZ2tpi3rx5IPqHLMno0aPh7OyMiooKdHR0YMaMGaxsb2pqgrW1NV6/fv1DsFVUVMSYMWOQlJTE1BN//fVXzJs3DwKBAOfOnUNnZycqKyvR3t6OK1euQFZWFqNGjcLDhw/B5/PZQ8/Z2Rnr16+Hl5cX08Bqa2vDxYsXGQXl999/Z9nSvn37kJmZiZUrVzK4hIeHB5NvAcSjeM7hg0NSBwcHQ1NT86drB/g/C0J/1gb6/zebjY0NJSYm0uHDh4nP55OsrCxpamrS6dOn6cuXLyQvL09qamrk6+tLBgYGVFBQQEREvXr1okmTJlF8fDzp6enRqlWr6NmzZ2RpaUlz5syha9euUW1tLZWXl9PKlSvJ2tqaAFBFRQVJSkrSL7/8QiNHjqSAgAD69OkT2dvbU5cuXSgrK4umTJlC06ZNo5iYGJKUlCQ/Pz8aNGgQmZub0/79++njx48UFhZGaWlpdPLkSVJWVqZnz56Ro6Mj9e3bl54/f07V1dXU3NxMixYtoh07dlBtbS0tXbqUPn36RL/99hvx+eJboUePHsTn8yk6Opra2troxo0bNGzYMEpKSmL2z8bGxtSlSxciIho0aBDdunWLdHV16fnz58Tj8UhKSookJCQoPj6edHR06N27d1RfX0/6+vrUu3dvsrGxodzcXHJxcaHp06fT0qVL6f379zRx4kR6+vQpnT17lkpLSykpKYkmT55Mtra2tGjRIho5ciSNGjWK5syZQ+/fvydDQ0OqrKykvLw8CgoKIikpKSotLaXw8HCSl5enpqYmKisrY+c+Y8YMOnLkCNXU1NCWLVuIiMjIyIhEIhE9ePCA3N3dKSoqivr27UvGxsa0f/9+6tOnDxERpaWlEZ/PJ39/f2poaKBevXrRq1eviIho4MCBtGrVKnJ1daWMjAyqqqqic+fOkbq6Oo0dO5YA0NatW2nAgAFEROTk5ER5eXl09+5d+vTpEyUkJNDUqVOptbWVLC0tSUJCgjQ1NYnP51NRURG1tLRQbm4uubq6kqysLDU2NhKfzycvLy8aNmwYHT58mB4+fEhWVlbU0tJCcnJypKioSFOnTqWwsDDq3bs3vX79mlavXk39+/enkpISmjx5Mo0YMYK6detGL1++pGHDhlFnZydJSUmRnJwcvXjxgnr27El8Pp/mz59PGRkZ/71F959Grf+b9z+TCXFyDJzU5enTpxEfH4/GxkZ0dHQwaoO7uzvLHrinRHNzM0JDQxEZGYlr166x+vrixYvo1asXXF1d8fbtW1RVVcHDw4NlNhcuXICzszNkZWVx9+5dxMTEYNSoUYwaoqmpidjYWKbO6OLigqSkJHR0dCAkJARJSUmslKqurkZVVRXrLQDikk9SUpJNqTgnEa7nc+LECXz48AH29vZsMnf37l0sWLCAjXj37duH/Px85OXlsfEvB2LkwHFEhO3bt2Pp0qWoqanB69ev0d7ejqqqKsyePZuRcrmmKSd6n5eXh6qqKqipqaF///4wNDSEv78/G8Gbm5uzETh9a2KXl5cz8KRQKER7eztmzZqFcePGQVZWFr///jtOnTqF7Oxs2NrasvP7448/cOLECTg7O8PAwABnzpxBe3s7KwW1tbWZIiSH4tbU1GSW4J2dnUhMTPxhMmVoaIhx48Zh2LBhGDt2LFasWAGBQIA3b95AUVERGhoa6OzsREZGBubMmYMTJ04gKSkJ9fX1DEy5detWAOKez6VLl2BnZ4eVK1eisLAQCQkJMDAwYCWfpaUlzp07h69fv+LJkyfw9vZG3759kZ6ejoSEBDQ2NuLt27fIzs7G8uXLcfPmTfTo0QNbt25l6gecG/D27dsRExODzMxM+Pn5ISIiAoaGhpgzZw5GjBgBGRkZdOnSBUuWLPnp2gH+zzKh/88Dw//m/meCEKfPc+XKFbi7u+P69etsMTc3N+Pp06fsBly2bBn69esHdXV1tLW1oaOjA8nJyRAIBIxjlpmZierqaiQnJ0NNTQ0hISGMu0PfJjucTCt9a1DSt3LQxsYG0tLSbMTONXfv3LmDP/74A5mZmex3ufeXlZWhqqqKBcTy8nIUFhayXoS5uTmKi4vx6NEjBAYGMnzRrVu3UFlZicrKStYH4PP5bOG7urrCwMCAQRg6OjoY1J9IPNofMmQIPn78iE2bNmHjxo1sYRUXFyMgIABbtmyBvr4+nJyccOHCBSxfvhzJyckMl2VtbQ0ej4e0tDQcPXoUe/bsQbdu3RjkQUFBAQ4ODigpKUFbWxtcXFyYHRKfz2d6yGfPnmWB8ntXECsrK1hbW0NJSQkLFizAhQsXUFVVhf3792PNmjWsj8aVahISEhg5ciSTpq2vr0dqaioOHz6Mbt26MQY/JwmSmZmJyMhIjB07Frq6ugDEqG3OmLK2thZqampM+B4AVq9ezegUFy5cwMGDB/Hq1StISkoy0CYg1lqaOHEijI2NkZ+fj4aGBly9epWZGDY3NzN0Ond9OPmSoUOHQklJCRoaGli6dCkGDx6M0tJS7N69G6NHj2bTNwA4deoUPD09cevWLURFRSExMRFjx45lKO6fbX8Hob8gCHEEvq9fv+L27dsAxJghoVDIrHo2P2ziAAAgAElEQVQ5moOMjAx69eoFHo8HPz8/JCYm4u7du+jRowfu3buHtrY2lJSUQCgUIiIiAsOHD4eRkRFKS0uxd+9exMfHIyIiAleuXEHfvn2hoKCAlJQUWFhYMJvjsrIy3L9/H0lJSViyZAnjlSkoKKBXr16swWptbY179+79i+bQ9xkUkZiOYGJigvb2djg4OLDpEgDW6NyzZw9OnDjBGuqmpqYYNWoU+vfvj23btjEQ565du5hn/evXr5Gens6kI1RUVACI+yYcC3/q1Kn48uUL1q9fDyMjI4wfPx729vawtLRkAU1dXR2PHj2CqqoqFBUVcfPmTTa65kTRcnJysH37digrKzPsUJcuXRAeHo5evXrB19eXaSJ7enr+kKlZWloy2RUnJyfo6+sjODgYrq6u0NbWxv3799l3KCMjw6Aa1tbWWLt2LcPZzJgxA+7u7pg+fToAMFXEL1++wNXVFTweD2fPnmXXMCMjA8HBwQz97evri99++4352RGJ7Yi4LJGjS7S3tzNg6fnz51FWVoZ3797h5MmTP0zXrKysEBQUhLdv32L79u0oLS1Fe3s7Dhw4gH379rFm95kzZ9DR0YGBAweynp+7uztqa2vR0dGBZcuWwcvLiwVdQBxIOdDtz7a/g9BfEIQ43WEHBweEh4fj+vXrWLp0KUvFuRJJR0cHy5cv/wEzUlpayux/Dh8+DEDMJj906BCqq6shEomYGmNLSwuePn2KsLAwfPz4EYsWLUJubi674biyEBCXG926dcPy5csBiD3pjY2NMW3aNPz222/Ytm0bPn/+jNraWpw8eRJ6enpQVlZmYmHc+fH5fGzZsgVpaWlYsGABhgwZAjk5OZw9e5aNZ4uKipiJYWZmJlvMHH2EKwl0dXWRmZmJ5uZm6OnpwcrKCjY2NrCzs4OSkhLjv/F4POjq6jLFRk7+9enTp4wJLyUlhd27d2PVqlUwMTFhKHAiMZXCwsIC9+7dY9eAa8BfuHCB2WovWbIEIpEISkpKkJSURGZmJtrb22FkZISdO3eyBr6ysjKWLl0KFRUVplpQU1OD2NhYPHz4EF+/fmUZFZ/PR0dHB1asWAEiMRhzzZo1DBQoEAgQEREBkUgEoVAIMzMzyMnJISEhAa6urigqKmJN7H8WQiOif9Gx5lQq79y5A3t7e0yZMoXxwwAwo00zMzP20Po+C7a3t2dSLC9evGD3Un5+PrZv386wVxwSnc/no7GxEaWlpZg7dy4uXbqEZ8+eMR3z+Ph49iD+Gyf0vxiEHjx4gIqKCowZMwZqampQV1dHXV0dm1p5enrCyMgI1tbWOHfuHBwcHFg/ZsmSJWhvb8f9+/exfft2XLhwAXp6eggPD4eBgQE2bdqEtLQ0PHr0CHv27MGYMWNgbW3NkLx9+vSBnp4ek+2srq7G8+fPERcXB3Nzc/D5fERGRuL06dPw8PCAsrIyQkNDoaSkxLSWOS93rkxbsmQJxowZw1j7AoEAWVlZ8Pf3Z2N3DQ0NtLS0wNPTEwKBAGPHjkX37t2hqqqKw4cPIz8/H5aWlujduzfTEOJAbRcuXICpqSnKy8vR2Nj4gz98ly5doKGhwfh23/cWHjx4wJwv+vfvj8DAQKSmpqK8vJzZDmlrazPw5ZYtW9DR0cHGyoB4ElRYWAhTU1NoaGiwqRGfz0dERAQaGhowcuRIjBgxgolzERELMlzJNmjQIEhKSrJSPCgoCKqqqnBzc8OzZ8+Ql5cHIrHPW0pKCgQCAfz9/XH//n0EBgbiypUrjGjMPaQmT56M2tpaNDQ04OvXr+y75ug2nC61pKQkPDw8oKCgwFQHvn79imPHjrEgZWxs/IMTLpFY95rDKs2ePRvt7e3s87x58wYeHh5wcnKCUChkjjGOjo54//49mpubceTIEdYyuHPnDsvuuI3TReKms1wZ/rPt/yQI/T0d+6dt165dFBYWRrt27aL379+TnZ0dSUlJUXNzM8nIyJCKigpt3ryZampqyN7enmxtbam4uJhkZGSoX79+xOfz6dq1a9S/f3+aNm0arV69mjo6Oqi8vJx69epFI0aMoHv37tH+/ftJJBJRRUUFKSsrExFReXk5tbS00Pv376mxsZFGjRpFXbt2pZSUFLKzs6OpU6dScHAwSUtL08OHD8nExIRWrFhBRkZG1NLSQllZWbR06VK6desW1dXVEQASCoU0d+5ckpOTo4cPH9KmTZvI2NiYnj9/Tt27d6eXL1+SpKQkWVtbU0VFBXV0dFBeXh61tbWRpKQk/frrr6SoqEgNDQ00depUevHiBcnJyVFzczM1NDRQfX09DR06lFRUVCg6Oppyc3Np/vz5RER06dIlcnZ2pn379pG6ujp9/vyZUlJSqLm5mW7fvk1GRkbUu3dv2rVrF717946UlJRIT0+P5s2bR8ePH6cbN26Qm5sbWVlZkZ6eHp08eZIsLS3pyZMnNGDAAOLxeFRWVkYODg6krq5O48ePpyFDhlBrayu1tLSQt7c3ycjIUGZmJvH5fMrLy6P79+/TrFmzqLOzk2JiYmjLli3k5uZGDg4O5OfnRwAoNzeXBg8eTNbW1pSVlUXFxcUkISFBcXFxRETk7+9PCQkJVFBQQCkpKcTj8QgAOTk5sWttaGhI3bt3p65du9KLFy+osLCQTpw4QeXl5dTW1kZKSkr0+PFj0tbWpujoaOrXrx/Z2tpSWVkZ9e7dm+Tk5EgkEhGPx6MVK1ZQZGQku0elpKTI1dWVoqKiaOjQoWRjY0MSEhJ07NgxcnBwIDc3NxIKhWRoaEhSUlKkq6tLPXv2pKSkJJo5cyZNnz6dNDU16cqVK9TY2EiVlZWUmJhI1tbW1NraSuHh4ZSYmEjJycnUtWtXIiL6/PkzGRoa/lfWnMR/5aj/F28WFhako6NDDQ0NNGXKFLp58yZpaWnRly9fiMfjUWpqKi1cuJAWLFhAnZ2d1KVLFxo+fDjJysqShIT46/zll19o586dNGjQIFqwYAHZ2dlRZ2cnTZ06lTQ1NcnOzo7evn1LFRUVJC8vT1OmTCELCwuaMmUKNTQ0UEdHB+no6JCcnBytX7+e1NXVSUtLi4YPH051dXWkr69PV69eJQcHB7K1taXr16/T/PnzSVtbm+zs7Ki2tpYWLFhARER5eXlUVFRExcXF9OnTJxo/fjylpKSQuro6KSsrU58+fWjJkiVkZWVFlZWVFBMTQ0FBQeTm5saCY2NjI/Xu3ZuN8YVCIbW2tpKtrS3V1taShYUFrVy5kh4/fkxERNnZ2XT+/Hmqr6+n5uZm6tOnD/Xr148UFRXJ0dGRZs2aRe/evaOcnBxSUlKiadOm0efPn+n06dP06dMnkpeXp46ODqqvr6e5c+eSkpISrVmzhq5fv049evQgXV1dqqiooIsXL9LcuXNJRUWFAJCKigq1tbWRtLQ0PXv2jMzNzcnX15eEQiFt2bKFVq9eTR8+fKDS0lIyNDSkxMREiouLI5FIRLq6uvTp0ycqLi4mFRUVyszMpMrKSurs7CR9fX2aP38+BQUFUWBgIGlqatKSJUsoJSWFZGRkyMjIiLp06UInT56k4uJiCgkJITc3N+rRowcJhUK6e/cuGRkZ0fbt2ykmJoZ+//13On78OHXt2pV27NhBc+fOpStXrlBhYSGDP2hra9ORI0coMTGRBg4cSNOmTaPAwEAaOnQozZ49m8LDw8nb25vWrVtHWlpaDLoxcOBAunXrFnV2dpKsrCz5+PjQnDlzqKCggGJiYsjFxYWkpKTIx8eHCgsLSSQSUWRkJAUHB1NnZyfJyMhQdXU1PX/+nMzNzen58+cUGRlJa9eu/e8tuv80dfq/ef8z5Rg3qQkODsb9+/fh4+OD2bNnQ05ODhs3bmQyFFFRUUwVkJNpFQqFqKmpYY3ekydPAgAbiXMprZWVFaSlpRkQjugf6npnzpzBwYMHmY6xtrY2Ll68iJycnH9xGTUxMWHyFAsWLEBBQQFEIhGbtklKSjKOWN++fbFx40aEhYXB1dUV06ZNA5GYdhAVFYU//vgDRUVFzMpHJBLh4MGDjH7x/d8lEnPOOC4Xj8fDgQMH8PTpU/j5+bF+joKCAuLj45GYmIh169bBzMwMEyZMQHh4+L+oEhKJ2fMAWE8qICAAdnZ24PF4MDU1hZaWFsaOHQtJSUkMGjSICb4PHDgQfD6f9V1iY2PRrVs3rF+/HmPGjEGfPn0wZ84c1gxXV1eHm5sbiMRUGo446unpiXHjxiEhIQGTJk3C6dOnkZmZCT6fj6KiIhARu6bFxcVYs2YNLl26xMpAIjHaWyAQMAshIoKHhwezM6qqqsL69euhrKwMd3d3uLi4MKT758+fsXPnTlaqcSL0JSUlWL9+PesrciVScnIyMjMzIS8vz2RdlJSUGBRi4MCBP9iYNzU1ITIyEvPnz2e/z/XI5OTkcOTIETb9lZWVhYKCApM7+VtP6H8xCF2/fh0tLS3MMobbfH198ebNGwiFQnz48IFNgLy8vFBWVsZuQi0tLZw4cQI5OTl4/Pgx62G0trairq4Oc+bMYYxvPz8/9j4DAwNUV1dj/vz58Pb2xv379yEnJwcejwd1dXU2MlZVVYWUlBT69u0LeXl5TJo0CaampiguLoa5uTni4uJw4sQJhkLmdj8/P8arys7OxrVr1+Dj44OZM2eivLycqQJUVlaioqICly9fxsSJE3/QLHJ0dERaWhrzvnr16hV7TVlZGeXl5ewG5hDAgHhMrq6uDh6PB0lJSaaFzH0ubufE3F+/fo0xY8Zg5cqVjMLxPcudgxtwgYSIMGbMGBw9ehTLly/H3r172c+/fx93zb7/t5mZGWxtbfHo0SPY2NhAVlYWDx48QGhoKF6/fo3GxkaYmpri6tWrMDAwQL9+/dDc3Aw+nw9lZWU2DeSCLpFY0wkQ6wTFxMQwjmFVVRUTuufz+XBxcWGUj0uXLuHkyZPYtWsX+w5jYmJQUFCAtWvX4uPHj+z6cQoALi4uePDgAcaPH/8vAf17SRfOTVckEsHZ2RnXr1/HokWLICkpCQUFBebm8f3UzNzcHB0dHXj58iU+f/6MBQsW/HTtAH8Hob8kCHFi4Bwnp7W1FadPn4aPjw/U1dUxbNgwdtEtLS1RVFSE8PBwSEpKQkpKinmROzo6ok+fPigvL0dlZSXu3r2LtrY2dHZ2Ijk5GUFBQeyJxS1KQKwtw+n+cEC27xfeq1ev4OzszDKg/v37o6ysDM+ePUNxcTHs7OwAiEe7ly9fxrx58xAeHo62tjY0NzcjLi4OFhYWePbsGUJDQzFv3jwMGjQIKioqsLS0RGlpKZqbm7Fp0yZIS0tj/vz5mDVrFng8HnsyNzY24s6dOywT4bzMFi1axBZsWloali1bhqysLOTk5MDX1xeTJ0+Guro6C5Ddu3eHt7c3kzjR09ODpKQkI58SEY4fP87Y4pMnT2Z6P1lZWWhoaEBaWhoCAwMhJSXFAsO0adNY05vLoJycnDB37lz88ssvzNaHvjXvtbW1ERYWhpCQEKxatQovX75EQkICZGVlmQ6Sq6sriMSSKc+ePcP69ethYWEBf39/GBoawtHRESYmJrC3t8fChQvR2tqKjx8/wtjYGM+fP8ecOXMgJSUFZWVl6OjoQFVVFa2trTA1NcWMGTPQ2NiI69evIyoqCidPnsTt27cZ2HXEiBE4cuQISkpKUF9fj0+fPjEOoLOzMwCwxvX3ciXf75cvX8aCBQtw9+5dXL9+nUm77t27FwEBARCJRHj37h0bbKiqqrK/LxQKGZn7Z9vfQegvCEIcChcQB6INGzYgKysLhw4dgpSUFLy9vRESEgIDAwMEBATgjz/+wNmzZxm+6M6dO2hoaICuri60tLSwcuVKKCgoYPfu3QgPD0dTUxN27NgBFRUVxMbGwsjIiE2cOJ5VSUkJli5dyoLd6tWrISsrC01NTZw4cQKA+Clrb2+PM2fOoKCgAMrKyvD09IS8vDwAMXcpPT2duWi0t7ejtrYWhoaGUFRUZABMLv02MzODvr4+unfvji5dumDx4sUss4uJiYG9vT0CAwPR0dGB9+/fsyxGSkoKT58+xcWLF9nU6dSpU6isrGSi+G/evEFGRgZ0dHSYfTWH3YmOjkZwcDB69+4NLS0tWFhYoKysDGfPnoWenh7evXuHhoYGqKmpoampiZkpxsfH48yZMyAitgDDwsLQtWtX8Pl8XLp0CTIyMuDxeIy7xcnzcmNtHo/HRO6HDRuGkJAQREdH/1Amc2P8hIQESElJITY2FhkZGbCwsMCgQYMgEAgYLMPQ0BCDBg2CmZkZSkpKmP1PSEgI2traEBYWhpaWFoSHh8PMzAzNzc1sjA6IF/v8+fNZUG9sbERdXR2GDBmCfv36QUNDAwUFBTh06BBkZWWhpKSEKVOmIDU1FVZWVpCTk/sBMsLtU6dOZUE5PT0dQqEQCQkJyM7OZsGsqakJAQEBICL8+uuvyMzMhFAoZA9jDhv2s+3vIPQXBKGgoCC8e/eOeYvp6emhtbUVHR0dqK6uxoABA1BdXY2Ojg4IhUKWIpubm0NeXp7Z34waNQojRoz44anLLerJkyezrCI3Nxfbt2+Hk5MT1qxZw3oxly9fRltbG1xdXSEUCpGUlMQwO4WFhUhPT2cGh99jRbp3744JEyYwtDX3cy6lf/36NVuMgYGBWLFiBXbv3o3c3Fz06NEDERER2L59O0xMTGBiYgI9PT1IS0tDWVkZZ8+ehaKiIuTl5eHu7o5Fixbh9u3bePHiBY4dO8Z6QQ4ODhg9ejRGjx6NUaNGobKykgEEo6Oj4e7ujtGjR0NbWxtxcXHYsGEDxo4dizlz5jAZ0ZCQEEbCbGhogLy8PBoaGvD48WPIy8uzvlHPnj3RtWtXpKam4vPnz+z737FjB3x8fDBr1iyEhYUxTzRDQ0NG4+Ass9+8eYOYmBgcOXIEwcHB8Pb2xqpVqxjUwtPTExMmTMDDhw8ZVklbWxsRERH4/fffERERAQ0NDWa/xJVD8+fPx4gRI1gf8fbt2+js7ERJSckPnnOA2JFXR0cHhoaGjPWek5ODyspKSElJYezYsew6c9+zqqoqtLS0mKdYYWEh60/Z2Nhg0qRJcHR0xMGDB1FUVISgoCDweDwMHjyY/V1OCfTw4cMICQnB0qVL8ezZM7S3tyM/Px/Xrl3D+fPn2X3+s+3vIPQXBKHZs2cjPDwcgNiWl2tUf/36FeXl5azcqaurQ11dHYRCId69ewcNDQ1IS0tj1apVsLa2ZjU5J7ylrKwMDw8PxMbGMtBYQUEB5OXlsX//fqZk+OHDBwgEAnh4eDB8x+7du3+QbADE/uwGBgbMgNHa2hp2dnaIjo7G77//jubmZqSlpSE+Ph5du3bF2LFjWZ/r1q1bGDBgAKZMmcJ4TlxGYGpqynobXAAdPHgwBAIBHBwcmDsGRz3hrIkGDhyIO3fuYMyYMUhJScHdu3dhbGyMI0eOoLm5GUePHkVcXNwPJQaX5QFglsVdunRhiHRVVVXExMQwnJGUlBSzCrK3t8fMmTPZwkxKSsLWrVuZA4aysjIEAgFOnz4NKSkp8Hg8bNq0CdHR0di1axdiYmJw4cIFvHz5EhEREaivr4dIJGJl19ChQ9GjRw9s27aNZZ81NTX4+vUrU1IsKyvDrl27YGtri9raWiQlJUFZWZllHePHj8ft27dx+fJlREdHIzw8nDXPPT09kZ2djezsbOTn57NhAic74ubmhq1bt+Lly5fo06cPPDw80LVr1x+yNFlZWVbiXblyBQ8ePGDZTEhICAQCAUaPHg1VVVU4OjqiqakJpqam0NTUxL1795CcnMwE6RwdHeHl5QUVFRWUlZWhvr4ebW1tAMQVAdem+Nn2dxD6C4KQs7MzE3nnpl7cE+vTp08M4MUtaJFIhNzcXPTq1Qtfv35FTU0NK3nU1NTw4cMHBAUFgYjw+PFjNjmpqKhAt27doKSkhC9fvuDhw4doaGjAtWvX0L9/fyQkJKC4uBiDBg3C5cuX4e/vj0mTJuHVq1fw9vYGj8cDj8fD9evX0dbWhvPnz7PFAohlOcvKypCbm8uejKGhoWhsbIS/vz969+6NxYsXw83NjTVvraysWHm4detWtmCmTZsGgUAABQUFpvpoZWUFZWVlAGAgxSdPnjC1SQA4c+YMk5goKytjwlsikQjPnz/HvHnzsHfvXty7dw+BgYEwNjYGEUFfXx+mpqaQlZVFQEAAgoOD2bnMmjWLZTUcmI/H40FVVRWXLl2CsbExc0rZtm0b/P392YLdsWMHKisrmXttVVUV7ty5g8bGRlhaWqJr164/2P4QEYKDg5GUlITU1FQ2GUtKSkJubi4OHz6ML1++oKKiAmVlZVi9ejV7n7m5OZtiRUZGMgrEypUroaOjg4CAABQWFkIoFDKzgXv37rFJanZ2NiQlJZGXl4cFCxbg/fv3kJOTg7S0NDM7ICKcO3cOHz9+xJ07dxAdHY2rV6+ipaUFt27dgpOTExQUFNClSxcYGhri48ePuHTpEl6/fs0CaVBQEPT09Ng9v2nTJpw9exazZ88GIO6JJicnIzQ09KdrB/hfCEJEpEtEcURURURtRPQHEYUTkeqffL88Ec0nokQiekZETUTUSET5RLSOiLr8D+/7t822b3venz3/P8uij4+Ph0gkQnV1NaSkpJgYWXNzM0NC29nZsad6REQEIiIiUFFRgc7OTjg4OEAkEqGmpgYNDQ34448/oK6uDiUlJeaFxT3RlJWV0dTUhKNHj2L48OEYMWIEDA0NceTIEYhEIhw9ehRv3rxhT/xp06YhLi4Ojx49QmxsLBNcr6qqQnl5Ob58+YIePXrAyMgItra2mDZtGnx8fHDlyhXG9n/8+DGICCKRCJWVlQgMDIS9vT27MXV0dBAVFcUmY7q6ukhISMCpU6cwevRo2NjYQEJCAhERETh58iRbuHp6eggICEBjYyOqqqogISGBuLg41NbWIjc3ly3E9evXsx5HREQE/Pz84ObmhsePH+Pu3bsIDg5m2kQcZeL7/XsKRP/+/SEtLQ1fX1/MmDGD9deGDBmC3377jQXrK1euMGF5GxsbLFy4EIB4EPHy5UsoKiqyJjV37C1btsDLy4sF1tevX+Pz589YtmwZAgMDQSRmv9vY2MDDwwNycnIwNDTE7du3sXnzZiYSdunSJQQEBODu3buYMGECOjo60NjYiNmzZ2PXrl2Ijo7G7t27AfzjwbdlyxbIyMggLCwMXl5e8PX1Re/evZk+tba2NhYsWIDMzEw0NDRAIBBg8ODBMDExYccIDAxEQ0MD46YJBALs2LEDgPiBamdnx0r42NhY3Lp1iwVFDQ0NnDx5kqHsOcrQz7b/ahAioh5E9PHbBUohot+JKPPbv58RkfqfOMaUb7//mYiSvh3jEBG9//bzXCKS+Tfvw7eA5/dvdvc/+xn+rMY0Nwn4+PEjlJWVsWDBAsTGxrKJB32ryz09PZGfn49hw4ZhzZo1+Pz5Mzo7O2Fvbw+hUMgazIcOHWILR0JCAi9fvkRmZiYMDQ1hYWGB169f49dff0VNTQ3S0tJAJLYE4hjg2trakJCQgLq6OioqKlh2tmrVKqxYsYIZ3DU0NCA+Ph5EYh1nBQUFSEhIwNLSEoaGhti+fTsSExPRtWtXaGlpMQ5WSEgIFi9ejPLycuzZswc1NTU/CLR/b8GzdetWCAQCGBkZYcOGDXj58iW8vLwQEBCAjIwMLF68mNEVeDweDh8+jPXr1wMQS4qMHj2alaoSEhJQVFTE3r17GUaosrISMTExDGPzvYSHqqoqLC0tkZqaypjuPXr0YKJtnGKjv78/Xr9+jdTUVCgrK2P8+PFMNF5aWhqysrJIT09HdXU1nj17xlxknZ2dWRDjOG9ExLzl8vLy8ODBA+Tn56OyshLr169nkzvObWTkyJGYPHkyDAwMUFtbCwAQCATM4porZzs7O5kq5PXr1xnsARBrTHPQDh0dHXR2dqK1tRUaGhr4+vUr4uLiUFNTw3iI3JaYmIhJkyZBUlISfn5+rJyaNGkSxo8fz4JhXV0d4uPjsXXrVpbVNTY2Yu/evRAKhUyob+PGjfD19cX169f/rSrov9v+20Ho6rebcuU//Xzvt59H/4ljmH3LhLr8088Viejht+Os+zfvAxHd/E8/3D/vfyYIubi4YM+ePawH872PuYuLC7y9vaGnp8cyE64RqK+vj759+2Lt2rWYP38+U1TkRrwTJkyAtbU1Ro8ezcBpgYGB7P85o8GbN2/C1tYWhw8fxu7du9n4etGiRTh48CAAcTNbTU0NFhYWrNQYOXIkdu7ciSNHjqC8vBw1NTUoLi5GXFwciMQ+7hxeJT8/H7dv34aZmRl2797NPkNsbCza29vx8eNHBpbs3r07evTogVWrVkFRURGBgYEIDQ1l/Spu3M6Z+H369Ak3btzA8ePHYWJigg0bNsDFxQUpKSm4fPkytLS0wOfzISEhAXt7e1hbWyM2NhaKiooME7Rr164fOFlckJCQkGA2SYMHD0Z8fDySkpJw/Phx7N+/HwMGDEBMTAxu3brFploxMTFM45kr9xYsWIDm5ma8f/8eWlpaLCOlb70gon9YbCsoKKC0tBQtLS2sRJ40aRJKS0tx7NgxlimOGjUKsbGxTGuIx+Ohd+/eGDZsGNLS0hAUFISoqCgAYmLw1KlToaCggOLiYqxevRp2dnZoaGiAm5sb1q5di5cvX6K9vR2//PILpkyZgqlTp2LBggU4ePAgO05RURF27NiBZcuWoa6ujsEEuPvFzMwM79+/R05ODry8vNj9kpOTw7iQIpEILS0teP78OV68eIGHDx8y6MihQ4fw4MEDAMCyZct+unaA/2IQIiLjb4GgjIgk/uk1RSL6SuLSSv4/PYHvjuP87W9c+Dev/a8FIQcHB7i6uuLcuXNobGwEIEZPc2aIISEhmD9/PkvzOQCeqakpeDweQkNDIX5FYmoAACAASURBVBAIIBQK8eTJE+Tl5aG+vh4DBw4Ekdj+xt7eHvX19fjjjz9w4cIF1NfXw8/PD+vXr8e4ceMwbtw4nDp1CvPmzUOfPn3Y2JXzA+fkRA4ePAgiYprIEyZMACAex//xxx8QCAS4ceMGtLW1GbmRY3WnpKRAU1MTkyZNgoeHB3R0dJjN9IMHDzB37lzk5eVh+/btGD58OFJTU7Fnzx48efIE0tLS0NPTQ0xMDNzd3SEhIYHExETU1NSgqqoKp0+fxsWLF0FE+O233+Do6IjXr18zIB5969doaGigX79+cHd3x5w5c2BtbQ0isR5QW1sbvnz5guHDhyMgIADy8vJITU3F9OnTMX36dFy7dg1tbW1oampCSUkJ6xNxC2jo0KFITk5mZpY3b95EWFgYa7rLy8tDKBTi/fv3OHHiBKZPn/5Dycfj8RAUFISSkhIUFRWxAKmhoQFTU1Nm3GhkZASBQMBEwgBxBp2Tk8MMJTmr6s2bN8PT05M1jwcNGgRADLdoa2tjkAMZGRn4+/uzTOf69evw8PDAhAkTIBAI4O7ujoyMDLx58wYDBgyAp6cnnJycEBgYyJQRuCwuNzcXZWVlGDx4MMaMGYN9+/axySx3rxw4cIBlTWvWrEFFRQUqKiqgp6eHAQMGoF+/fujTp89P1w7w3w1C7t8uzsH/4XUuS7L5T0/gu2P88u0Yyf/mNRBRIRG5EdEWIvIiohH/6d/4M0Ho7NmzzNhv4sSJKCsrw/PnzxEcHAw7Ozu8ePHih74Bj8eDhoYGs1fOyMhg4lJpaWnM7/zq1as/yGBw1A7uv2VlZdiyZQtu374NCwsLKCgoMIU/Q0NDbNu2DT4+PmxM//DhQ9y7dw8DBw7Ejh072IK5efMm8vLycPr0aSQlJaGgoADr1q1DbW0t/Pz8YGxszG44brLWs2dPREREQFdXF6dOnUJoaCjc3d1RWVmJ0NBQbNiwAZGRkUxzWU9PD4MHD0Z6ejrrIxGJJ13cFKW1tRXjx49novQAEBcXx8rN3r17o3///nj06BEAQF5enk3Bhg8fDmtra5Z1jhs3DvPmzcOaNWuYePzy5cthZ2eH5ORkSElJMYwSty9cuJAtQg6TVFRUBG1tbfB4PIwfPx7Nzc0sc4uPj0dISAgUFRUhLS0NdXV1JvLm4+OD/Px8qKio/DACNzExQXR0NIqKirBr1y68evUKN27cwOfPnyEUCrFx40bWNB86dOgPnl/S0tLQ0tJiGcn06dMREBCAffv2wcLCgg1DSkpKkJqaitbWVvTr1w9qamowMDDA27dv8eTJE6YVnZGRgT59+rDzk5eXR48ePaCkpAQ9PT0kJCQgLi6O/T2hUIh58+aho6MDOjo6UFdXx6+//gp3d3d0dHTg+fPnWLNmDQvakpKSP107wH83CO3+n0qlb69Hfnvd8z89ge+Okf7tGMv+zWv4H/ZCIjL5yXGXkrjxna+vr//TL/H333/HoUOHmNZNTk4Om/AAYn6Pvr4+9PX1IS0tjdGjR+PRo0cQCoV48+YN/P390dHRgRcvXsDPz4+N+DlciKurK7Zu3YoDBw5gw4YNuHTpEiorK7Fo0SL4+PiwqVt2dja+fv2KadOmITQ0FP8Pe28eVuP+to1/Ks2lwawIqS0ksqU2mYmodoQoQ+batEMalITMImkpYxOiKEQqdnNIu1mFoiilNGge1zrfP9a+r+/ueZ/3sb/vu5/j/b2/Y3+OYx17aK17Dff9ue7rOq/zOk8dHR26S3p5ecHFxQWAUAlPXV0dNjY2uHHjBng8Hq5cuUIgpI2NDQAhqNrd3Y0HDx6gvb0dnz9/RmBgIJSUlKCvr48DBw5AUVER0tLSNOPGga/nzp1DWFgYtm/fTgL/N2/eJOF4DuMZPHgwli1bRsLphYWFqK6uRlFREQYNGgQtLS2UlZVBXl6emLn29vY4cuQIVFRUqJU+e/ZsSEhIABBSIzidpH379mH9+vUYM2YM9PT0sH//fqSkpEBMTAwiIiIICQnBmDFj4OrqSto7GzduxPTp02FjY0PyFJw/GADqKDY3N9M83fjx4ylbePLkCZWA0dHRCA8P7zNu09XVRY4YY8eOxZw5czBo0CCYm5vj6dOnWLFiBW7cuAFnZ2diuXMdO05t0tPTE4MHD6aRm9GjR+Pr16/o6OigkvDu3bt4+/YtCgsLoaCggNzcXJSXlyMlJQUtLS1QU1PDzJkzsWPHDmLXi4uLE/UiKiqKCKqcgJmamhr4fD5l3IwJR2EAELYYHByM8+fPIyAg4Lt7B/jvDUKX//jR/1MQmDF29I+/u/67H+CP1+/84/U5jDHx/+Tv3oyxnxhjAxljcoyxHxljEX+85itjTOWvvM9fyYQePnxI7qnjx4+Hg4MDhg8fDk9PTyQmJiImJgaMMcTHx2PmzJl0EV+6dAm9vb149uwZDTsOHjwYLS0taGpqgq+vL7KysvDy5Uu4u7tDW1ubyh9nZ2cYGBjAzMwMx44dQ3h4OBoaGlBaWgpvb280NTXB0NCQSIMFBQX47bff+gC03N3q119/pfm14uJiCj5cOaajo4N3795BIBAgPDwc1tbW9N1TU1Nx9uxZmnmztrZGR0cHTp48CWNjY1JIHDNmDJydnSErK0tt8gEDBuDUqVMIDg7GkCFDUFFRAXd3d/Tv3x8qKioYOXIkRo8ejRMnTtBm1NPTQ1paGiZMmEACXZzdcH5+Pmpqaihr41rXgwYNQr9+/eDr6wvGhLSCoUOHQk9PD3fu3AFjDIaGhsSTcnBwgJ6eHng8Hry8vKCjo4PQ0FD09PTg7du3UFFRgb29PfGrnj17hubmZnrfgIAApKamEnlSRESElBfFxcXh5uZG2Z2srCzc3NwQHBxMWS8nBjZ79mwibvb29uLixYsAhMz2kSNHUtDz9PTEokWLUFBQgOrqamzZsgUrVqwgGdyuri58+PABDQ0N6OnpwYIFCzB79mzCbK5du4bffvsNDQ0NGDt2LFavXk3ys1w3t7q6Gt++fUNpaSn27t0LfX19SEpKwsbGBleuXMHFixcxZMgQiIuLUxb1f31s4y8EoWN//N3l3/4AjC1njPUyYYdszL/52rt/vO+5v/L8vxKEXrx4gY6ODqrHZ8+ejaqqKmzduhWVlZUQCATw8/OjAKKoqIgdO3bAzs4OtbW1CA4Oxp07dxAfH48bN27g7t27AIRs2fb2drS2tuL8+fMoKiqiiyMjIwOMsT6TzYBwcjk+Pr6PJ3v//v1x/vx5hIeH49y5c+DxeKQEuW7dOnou1/n68OEDMjMzUVNTg5MnT2Lnzp3E4E1KSoKYmBgCAwMREhICMzMzEvbfuHEjFi5ciPb2dpw+fZosg52cnEiYa9asWdi/fz8YE7bneTwekpKScOHCBQCg4c779+8jOTkZW7ZsIeyGsX/NPS1ZsoRYzDo6Orh+/TqKi4uRmpqK0aNHIzAwEPr6+nB1dYWBgQFlVFOmTEFwcDDc3NxoNGPXrl3Iz89HZ2cnGVYePnwYCQkJ2Lt3L2WTjAlb8Pfv3ycwmjFhV9HAwADTpk2Dp6cnubqam5vjp59+goiICKytrbFq1SrEx8eju7sbu3bt6mPH1NjYiBs3blBbu6SkhI7/4MED8Pl8uim8f/8e7e3tEAgEyM7OxujRoyEmJgYPDw8qnaZNm4akpCQA6NNij46OJgzM1dUVlZWV4PP5yMzMxNevX9HW1kalsKenJ7y8vIiv1dPTQ9cdN6M4bdo0FBcXw8TEBHl5eZg4cSKGDx+ODx8+UOPke+v/uXKMMfYzY6ybCXlHP/zbH56xBX+8b9Zfef5fCUKBgYEwNTVFbm4usrOzMXToUKxatQqFhYV4/fo1pcSAMGBxSoF/Hvb7c/l2/vx5dHZ24tatW6ioqEB6ejoePXoETU1NqKmp4f79+4iPj4ednR1pRl+5cgWbNm3ChQsXMGXKFMydOxeOjo44e/YsFi1aBGtra/B4PGRmZiI9PR09PT0k1XHjxg1Ko5ubm3H8+HFoamri7NmzEAgE+PDhAwICAtDZ2YnCwkJoaWlh1qxZ4PF40NDQwM2bNxETE4PJkydj06ZNEAgEKC4uxuzZs2FpaYkbN25g9uzZJNXa2NiImpoa2NraQkpKCnp6epCWloa+vj6OHj2KxYsXIzk5mTKCyMhIpKen4+vXr0Tmk5CQgISEBExMTHDixAnweDxcu3YNiYmJqK+vR2xsLG1ibhNyzOLu7m6cOHECtra2mD9/PqZOnYqzZ8+ivb0daWlpNNryZ8BaTU0NpqamePXqFX777TcKIE5OTnj//j1kZGQgIyODL1++oLOzE8ePHyduU3l5Ocm2tLW1kXLArFmzsH37drS0tGD58uUYP348ze19/foVZ8+ehYmJCWJjY0nlMTU1FXfv3iV3lISEBBqpYX/gWYCQWd/Z2YmMjAxISEigsrISjY2NuHbtGnbs2IFDhw7BwMAAx44dow6oiYkJNDU1sWbNGpSWlqKtrY3KMa7cTktLw+zZszFu3DgYGRkREff06dNwd3dHd3c3TE1N0b9/fyQkJHx37wD/vUHobwemmRCI7mGMVTDGNP7dD/7HMXT+eN83f+X5fyUIXb58mWpjzh5YREQEurq6hK/09vYSGbG0tBQ1NTXUNuUwDEB4l+PSejc3N9jZ2cHGxobAQ3FxcezatQuWlpZEXuRA7ZcvX8Lb2xvS0tJQUVGhi6u9vR2PHz9GdHQ0Vq1ahZkzZ6K2tha5ublgTMhTmTdvHgwMDPrIeRw9ehQ9PT0ICQmBiooKAJCr6OjRo2FtbQ1PT0/89NNPKC4uRmJiIsrKypCXlwcej4fW1laEhoaCz+fj2rVrVNJxGWN2djasrKwQGhpKmc2fwXU/Pz/4+flRZmhtbY3q6mqS4xg1ahSmTp2K2bNnw9jYGGZmZvDz80NUVBSeP38OIyMjKCoqQlFREffv3yc3CUC4mQYPHgwTExPqsHHnTUFBAaqqqujfvz+kpaVx7tw5GsbkSqLo6GjY2NigtbWVJvgvXbpEm5Zzr2VM6MYREhJCWQp3jejq6qK1tZXKdcb+1c3kAouDgwMB5kpKSkQZmD9/PlRVVfHixQtyyOD4XUVFRXRDSU5OBmMMdnZ22Lp1K9ra2tDe3o4FCxZg5MiRsLOzw4kTJyAQCProNS1ZsgTXr1/Hx48foaqqiiFDhsDa2hrR0dHg8Xg0QlNcXIz8/HwsWbIERkZG2Lx5MxYtWgRxcXEKUN9b/51BSP2PL1TG/tct+nb2F1v0TNiO72WMffx3S7D/cJztf3yumL/y/L8ShNLS0nDu3Dnk5uaSCBSXwjc0NKC9vR1JSUmora2lTlBGRgZUVVURHh5OwQIQTh7z+Xz09vbi/v378PHxIV3goUOHoqWlBb///jvGjh0LHx8fTJs2DY6Ojrh9+zYAIT7FaTxzrgt/BroBQEtLi8BiBQUFsjXm3CtUVFRgbm6O0aNHQyAQwMHBAfPmzQPwL/H18+fP49q1awD+5QDb09MDgUCAqqoqLF26FM7OzmBMqIMtKipKLp1mZmbYs2cPLly4gLCwMHh4eODmzZvESREXF8eaNWsgEAhI+sPIyAiMCS2TOOxkxIgRZB3NAbXPnz+HlZUV1NXVMWrUKPJv9/HxQWVlJQwMDFBRUYHU1FTacBzfh3v8/PPPffSZRUREsGrVKqSnp8PDwwMAiBj48eNHGnPw8vJCT08PXFxcSAdaW1sb27Zto3OclpaGJUuWQENDgxxp165dS2Jj3d3daGpqwowZMyAvL48PHz7AxMQEysrKSExMRE5ODnbu3Em/x6JFi7B3715s2bIF7969g4WFBU6fPo03b95g8ODBEBcXh5ycHN3Ebt++jYKCAnh5eVG5xJVfdXV1EBcXx6hRoyArK4tbt27RACsHXIeFhcHFxQXKysrQ19eHqakpFBQUcPToUQwcOBBmZmZobW1FSUkJQQffW/9tQQh9s52/RFZkjI1jjI37T46zgTHGZ4x9YIyp/YX31f3PghtjbBJjrO6P9177V77DXwlCRkZGqKqqoinizZs3gzGhZ7m1tTUJrxsaGiI1NRUHDx7EqFGjYGZmBqCvDtG9e/eoDOHz+YTX7N27l4TpX758SQqNzc3NyMnJwe3bt5GXl4fZs2eT28LQoUMhJiZGbdmUlBQUFRVh+PDhmDdvHiZNmoSqqiq0tbUhISEB48aNI6KjmZkZjhw5gvXr18PT05OcQC5cuIBp06aRqBXX/m9ubkZvby/Ky8vJp/758+dk+TN16lT4+/sTmBodHQ2BQIDXr1/D1dUVAwYMgJKSEu7evUvT/CYmJti8eTNERUVx+vRpwrdOnz4NS0tLLFu2DOXl5RgzZgw0NDRovisqKgrsD9CXk+VYt24dBg4ciMzMTLS3t/fBmTj7n7CwMFy6dAmrVq0izgz3GDZsGNLS0mBpaYnk5GQsXLgQGzZswIkTJ6CpqUnn9/379/QaDkfjAPL6+nqMHz+eAvnp06eRnJyM69ev486dO3QdcCUVlxHfvXuXhpUFAgF6e3thZ2dH5Mg1a9ZQhnb9+nUEBATA19eXcCsZGRls374dkyZNQnZ2Ntra2pCSkoLu7m5q13PvZ2RkBBkZGQQEBKC6upqE0LibA2MMjx8/hqenJyZMmAAzMzM4OzsDEJaQf/Y944Ls99b/ThD6d4Tu7RhjzxljviIiIvMZY8WMsemMsbmMsXeMMbf/8PziP/4pwv0PERGRuUw4eybKGEtkjNmIiIj8h5exbwB8/vTf9oyx5SIiIglMWLp1MWGAW8wYE2OMXWGMhf0b3+O/XG5ubiwgIIAVFxezyspK1tjYyBhjLCsri4WFhbH+/fszDw8PtnjxYvb27VtmZ2fHjI2N2YYNG5hAICCd6a6uLlZXV8cWLlzInj17xhYsWMAWLlzI9PX1WVFREQOEguppaWnM0NCQMcaYtLQ0mzx5Mps8eTKLiopiJSUlzMnJif3www9MWVmZ9e/fnxkYGDBZWVm2cuVK5ufnx7Zu3cr8/f3Z5cuXma6uLlNTU2NqamrszZs3jDHGBg0axEaMGMGePn3KPn36xCIjI5mEhATT19dngYGBLDs7m506dYo5OjoyCQkJJiYmxmRlZRljjJmbm7P09HTW1tbG9PX1mZeXFzM3N2fq6ups0KBBrL6+nq1atYrZ29uzkpISpqWlxaSlpZmysjKrrq5mU6dOZe/fvyc7aX19fZaens60tbWZrq4u27ZtGysqKmJ37txhANjWrVvZ7t272fnz59mbN2+Yj48Pk5eXZ4aGhiw1NZW7hpi+vj6rqKhgZWVlbOTIkWzZsmXsy5cvbN26dWzKlClMTU2NPX36lMnLy7Pw8HDGGGMzZ85kb968YS0tLUxNTY0NGDCAhYaGsp6eHtbU1MTKy8tZUFAQMzU1ZePHj2epqans4cOHjDHGlJSU2JUrV5i9vT1TV1dnXV1dLC0tjUVHRzNlZWWWnJzM5OXl2cyZM9msWbNYZWUlEwgELCUlhXV1dTHGGEtPT2etra1s2bJlLCYmhq63rKws1tjYyMaNG8fk5OTYly9f2OPHj9nvv//OtLS0mISEBOvt7WXTp09nWVlZ7Ny5c+zly5ds+vTp7MWLF6x///6ssbGRlZSUsHHjxjE+n8+qq6tJl7yzs5Pl5eWxUaNGMXl5eaanp8devXrF3r17xxgTJiHOzs5s2LBhzMjIiHl5eTEATFlZmd28eZMtW7aMDRgwgG3cuJFlZWX9Xdus7/p3IhZjbARjLJAJO1ndTFhOnWeMKf8nz4Xw8H3+30b2pzvS/+JR/h9e8zNjLJIxVsoYa/7jfasZY9GMMdN/5/P/lUwoODgYly5dwoMHD9DU1ERljZycHEaMGEFly9u3b/tIY3AymIAQC9q/fz80NDRgZ2eHe/fu4dmzZ9RJmj9/PrX229vbERERgebmZlRWVuLhw4dob2+HqKgo+vXrBz09PURGRpKcgoWFBXg8Hm7evIklS5ZQpnTr1i2oqalh/vz5UFdX71OOcF2qiRMnUks9MjIS+fn5kJKSwvjx4yEmJkYZ0vbt24kFvnHjRuzYsQM3b95Ebm4url27hmPHjmHYsGF0rDlz5mDx4sXw8vKi9ruPjw9++ukniImJwdnZGfHx8ZCSkkJkZCRev34NeXl5SEtLw8DAAIwJ2cObN2+GiIgINm7cCBsbG+zbtw8PHz6EhIQEJCUlISYmRmRJxhisrKwQFRVF2Ulvby/i4uIgKiqKO3fuoKqqCra2thg1ahRSU1Npyn3ZsmXQ0NBAcHAwOjo6cPnyZYSEhCAvLw/h4eFQVVXF2rVr4enpiZMnT2Lfvn1QVFSElJQUTp06hU2bNmHMmDHg8/no7u5GaWkpqqqqAACfP3+Gra0tnj9/TvODLS0tuHr1Kvz8/Og6KygoAADs3bsXenp69LudPn2axkyGDh2KvXv3wsHBAZKSkjAyMoKxsTFZer9584YGWrkBWD6fjw8fPmDnzp14+/Yt4ZPc3ziMbuTIkfD19SVIwcHBAYMGDSIhOmlpadjY2NBvy83/fW+xf6Q8/s+D0LJly8j99Pbt29iwYQP27duHXbt2QVpaGgoKCjA2NsbChQtx4MABfP36FXw+HxkZGbCzs8PJkychISEBUVFRBAYG4u3bt1i8eDEuXryIFStW4Oeff8bly5chIyND+AtXb9vZ2UFSUhJLly6FoaEhXRD79+/HoUOHwBijjZmeno6cnBzs2LEDCQkJePDgAfLz88Hn8wkXkZCQgLu7O1paWlBaWkr4lpycHFpaWmjIVEpKCtLS0uRTdvjwYejo6CAqKoo2LjcSwo0vjB8/HqNHj8aCBQvw+PFj6Ovr4/DhwwTMDh06FG1tbbh37x5+/fVXXLx4ESoqKrCwsMCoUaMo+MyaNQtycnIYNmwYPn36hAEDBuDRo0d0LtifSgf2R7klJyeHq1ev4tKlS2SxXFxcjKysLPD5fNy+fRs9PT34+vUrNDQ0MGzYMFhaWiIlJYU24MGDB8Hn86Gjo9PH2pprW3MBlnNCvXDhAmbNmoWenh40NzfD09MTM2bMAI/HozEeTU1NiIiIYMaMGQBASgwDBgyAlJQUxMTE8O7dO1RUVJCUKjcYyhEYL1++jFOnTpFAmo6ODp1PjkN15coVJCQkwNXVFS9evMDw4cPx4sULCAQCpKSkICoqijSr2traSICvqakJq1evhqqqKl6+fInFixdDREQEaWlpGDRoEAYOHIhVq1ZBXV0d9fX1KCgowMiRI7Ft27Y+AfS/Wv8Eob8hCHFMaS0tLejq6sLe3h6bNm1Ce3s7AgICMGvWLPj5+WHJkiUYMWIEGhsbYWNjAzc3N+zfvx/a2tqQkJDAhg0biNW8YMECqrW5dfToUVRUVCA2NhYvXrwAIAQ6nz17hsbGRhQVFZF974EDByAqKgoFBQWyguYCWFtbG4yNjWlg9fXr19iwYQMOHTqEDx8+oKenB/n5+WhqakJLSwvmzp0LPz8/7Nq1C8XFxbC2toaYmBgsLS2JMKilpQUrKysMHjwYNjY2MDc3x7lz52hGTUxMDBYWFjhy5AicnJwIMBcVFYWoqCiZRnIbvqSkBEFBQWTnHBQUhD179iA9PZ1AVktLS2RkZODgwYOIjY3FzZs3MWLECAwcOBAfP37Eli1bKBiNGzcOgHAQ19vbGz4+PgQ6V1dX48aNGygtLSXGN/sDfK+trYWmpiZkZGTg7++Pb9++oba2Fh0dHcjOzkZ9fT0KCwtJDH/ixInw8fFBVlYWTfWrqamhX79+uHLlCmRlZbFmzRoCzLnH5MmTkZ+fj7q6OggEAiJ1SkhIwMLCAg8ePICGhgYmTJhA3cLjx49DQkICvr6+8PT0hI+PD9avX4/Ro0dDXFwc6urqWLx4MaqqqmjUxd/fHwsXLkRJSQna2tpQWlpK2lDZ2dloaGhARUUFXV/Av0D4qqoqWFtbo3///pTJc5IfixcvRnd3NxoaGrB7924wxmj6/3vrnyD0NwShIUOGwNvbG6dOnYKfnx+ampoQHByMoqIiGkJdt24dli9fThrS3F2ira0NfD6fypq4uDi6o2lqaiI2NpYuTM43/sWLF6iurkZdXR11vn744Qfs2rULY8aMgbu7O0RERCAqKorLly9DXl4ely5dwsWLF1FRUQFXV1ekpKSgubkZoqKiEBMTw7Rp02j26NixY5g0aRIdZ8KECRg/fjz09fXpTs6BlZyjAxdoXFxcsHLlStja2v5PZbOoqCi2b98OFRUVmJmZ4erVqxAREUG/fv1IGvfLly84d+4cFi9ejPHjx9NvtHv3bty8eRN8Ph8fP36EqKgoXF1d0dHRQXdwRUVFjB49Gs7Ozpg0aRIkJSWhqqpKQPCoUaNQXV0NHx8frF69mvSAGBO20QEheNzT04NPnz5hw4YNmDx5MpUvM2fOpA4YJ90bFRWFyspKHDt2DNbW1jQOwx2zX79+kJSURL9+/SggHjx4EDk5OUhISOgDVOvp6WHQoEF9QHGOMjFz5kzqzJmbmyMqKgpaWloYO3YsKisrceDAAQKZJ02aBBkZGaioqKC9vR29vb3Iz8/H169fkZSUhNWrV5P0amdnJ65evYolS5bQ66Ojo6lE41ZLSwt4PB6B6YCQGDt58mSyiVJXVwcgBNYXLVpEnK7vrX+C0N8QhLi74PPnz1FfXw8LCwtISEhQqTR+/Hi4u7ujo6MDbW1t5BXFdT8KCgrQ2dmJrq4umoDnZqu49nxZWRmeP38OHo8HGxsbnD9/Hr29vX3ml+Tk5DBmzBgEBQWRlAXnv/UfA4KOjg4sLCyIbbtixQocOnQIV69ehYuLC3g8HmkJq6io4P379+jt7cXhw4cRFBQENzc3eHl5obq6GmVlZZCTk8OlS5dw9epVODg4YOPGjfD09ER+fj5WrFiB9evXk7Yz9xl8fX1RVFSEVWb+owAAIABJREFUTZs20dDuy5cv8eDBAzx69AgHDhxAeXk5Vq5ciVGjRmHx4sX0m/N4PDg5OWH8+PFobW0lqVPu0a9fP0yYMAF8Ph9FRUXEqdLR0cHChQuxa9cuCkCioqK4cuVKn04RhxMNGzYMPB4PDg4OCAoKIiEwDk/hiJEJCQkwMDCAmJgYDhw4gGPHjuHChQuUESgqKkJMTAxGRkbw9/dHb28v4S2cGJuKigomTpwINzc31NbWIjY2lnhBpaWlePv2LX766ScYGhpixIgRCAsLQ3NzM6ZOnQojIyMIBAI0Njbi4MGDyMzMRFlZGYmXbdq0CVOnTsWPP/6IwsJCqKqqUlBTU1ODhoYGAGG7Pi0tDfn5+YiNjUVJSQmqqqpQX1+PhIQExMXFITMzk4i2XJfR1tYWJ0+eRF5eHu7evYu6ujpq/X9v/ROE/oYgZGFhgdWrV6OzsxOBgYGYP38+lJWVcfXqVVy8eBE5OTkIDw9Hb28v7t69S8p/HHDX1dWFXbt2Yfbs2bC3t8e+ffugpKSEO3fuoKurC8HBwdDV1UVcXBx6enqIT8ONWWRkZGDu3LkoLCyku2dERATk5ORw//79PsOTf36sXbuWwHE+n4+SkhLU1taCx+Ph+vXrCA0NxZYtWwjQvXHjBhEO29vbaeTi2rVrBLC3traiqamJhNT/vJ4+fUotYy7IXr58GXp6en2mtVtbW+Ht7Y2jR4/i9u3bmDhxIqytrTF27FhipcfExIDH40FFRQWpqamIiIjAggULCIDm2NGAsCHg4eFBpMIBAwaQbhE39sJ5qt+/fx+bN2/GqFGjMGjQICxbtgyAkAMVGRmJmJgYHDlyBJMmTYKenh4CAgKQkJBA7ysuLk6cLe58HD58GBkZGRAREcH27dtRV1eH06dPQ0pKilQuDQ0NERISgq1btyIoKAgAUFtbCxcXFzAmVIu0sLAAY0LOVGFhIQoKChAXF4cBAwZAQUEBSUlJMDIyQnl5OcrLy9HV1YX6+nqcOXOGmiWMMcLgdu7cibKyMhgaGkJGRoYaKF5eXkSy5dQ6/6xX3tvbS/QDHx8fjBo1CqWlpVBWVoa1tTVlUFwJ+L31TxD6G4LQw4cPAQjxhs7OTpSXl6OjowPh4eHkzlBUVARnZ2fY2dlh7dq10NLSQl5eHnJzc1FfX4+YmBg8efKEnDzPnj2LrKws1NfX49WrV2CMkfRnfHw8rK2tMW/ePOzYsYOmmnt6erBw4UKoqKjg5s2bYIzh1q1bNKTJpfWHDx/GyZMnERYWBoFAgLKyMrS0tEBbWxuPHj1CQkICcXxWr15NxDjGhJPVaWlpSEpKIq5QR0cHHj9+jLq6OvD5fERGRuLJkye4e/cuXrx4gfb2doSFhUFXVxcODg44efIklUdycnLw8fHBkCFDaENyPJ+pU6fC3d0dvr6+ePjwIQoKCojrxH1XzrTQysoKFhYWNE5ha2sLa2trWFlZkbREcHAwJkyYAENDQ+LQ2NnZgTEhoZLrPrW0tKCrqwvNzc2ka8Qt7jmzZs2CjIwMMjMzwefzcffuXcyYMQOenp4ICAhAQ0MDVFRUICEhAVtbW/z444+IjY2l47i5uUFJSQnPnj1DSUkJUlJSEBkZCWNjY2zZsgUFBQV49OgRYmJiyGCRMaHrblNTE2xsbDB06FAAQuZ5SUkJTp06BVlZWeTm5lLnTU9PD/Pnz0dKSgo2bdqEkJAQ8Pl8UkpkTChhUlxcTEPInFXV2rVrKTjHxcUhKysLPT09ePjwIRITEwEAc+bMwZMnT7B27VpMnDgRPB6PVCs5HarvrX+C0N8QhCorK+Hv748FCxbA1dUVUVFRBFjevHkTzs7OGDp0KIKCgjBlyhSIi4vDwsKClAsrKysJF/D09ISysjJiYmIoc+DYu8OGDQPwr5kzf39/GkOorq5GV1cXXF1dMXToUDQ2NqKyshJv3ryBi4sL2trasH79ehQWFlK2Ym9vj9raWmRlZaG7uxuamprQ0tLCo0eP8OXLF3z69InIhQUFBbhz5w4mTJiAcePGQUREBLa2tmhqasLOnTuxcOFCDBgwAOPHj0dJSQm9jmPlWltbQ1pamrzWuO9raWmJyspKREdH0996e3sRFRXVx/qIk43gWsG2trYQFRWljWRlZQUHBwfw+Xw0Nzdj8eLFUFFRgaGhIc6cOQMnJyc8efKEyjIuWO3fv58yDAsLC/p9i4uLERMTA3Nzc9jY2EBDQwMSEhL0fUpLS1FbW4vbt29TU4DP5+P48eNwdHQEn8+njcv9Xg8fPoSHhweCgoJIzxsQ3sTCwsLQ09MDd3d3MMboxlZfX4/Nmzfj/PnzUFNTg6amZh/L7vXr12Pbtm3UVk9PT4eqqioKCgrQ3NxMuMzt27fBGENcXBy+fPmC169f48mTJ5CTk6ORnNbWVsTFxUEgEKCiogL+/v6Ijo5GVlYWXX+1tbUoLi7GrVu3kJmZiStXrkAgEGDjxo0QERHBxIkTYWtri2nTpuHs2bPf3TvAP0HobwlCT548IeW7P2v4vnz5kuQjDA0NkZubi5CQEKxZswZBQUG4e/cucnNzSe7Cw8MDnZ2dJAHKaREPHDgQFy5cwPnz5/8nG5/u7m40Njbi8uXLJIEqIyOD0tJSAKCOU1ZWFk6cOIFz584BELJZ58yZQzrHa9aswZkzZ3D69Gl8/vwZ7e3txGl6+vQp+Hw+ysrKMGPGDMKppKSk8ObNGxgZGeHWrVuYNGkStLW1wePxEBAQQJo6ycnJMDY2xvLly5Gbm9vHipkDa1VVVfH69WsAwixh+fLlNJLBYS3ca3R1dXHhwgXY29tDRUUFoqKi+Pnnn0mWlbubcxhPeHg49PT00NXVhdevX8PU1JT81DhNbs6Yksu0Ro0aRTeF1tZWkq7lMiGuzW9vb49169bh+vXrKCgoQHl5OX799VfU1tYiPj6ePOFsbW3pO+jo6CA2Npa6V5MmTUJ4eDj4fD5iYmJgYmJCEr6AcPB2ypQp+OWXX6Cvr49Zs2Zh+fLlcHFxQWpqKm7cuAF/f39cuHCBOnJcJgT8i9WemJhIn2ffvn1obW2lGTVzc3OEhIRg7Nix1KAICgrCyZMnIRAI8OrVKzx8+JAEzV68eIHk5GSSMLlx4waV2NyoDYebfW/9E4T+hiDEmb3du3cPv//+O4KDg7F9+3YkJSWRoqKDgwOCg4PB4/FIoL2rqwvZ2dn49u0bzWa1tLSgvb0dTk5OKCgoQFlZGXXQenp66N8B4ebW1NQks74/4z3W1tYIDQ2Fv78/rK2tERcXBwBwd3dHbm4uVq5cSVwSTsSKMUZaQxMnToSKigqWLl2K5cuXw9bWFnp6epCVlYWkpCTpGHH2Lnfu3EFeXh78/f3h6OiIxYsXk20MJ1i2YMGCPm6fAwcOxKBBgyAmJgZVVVVqtXNjEMHBwcjNzQWfz+/jnT569Gi4urpiw4YN8PDwgIGBAUpLS7Fjxw4wxkjSNCsrizIASUlJlJeX48aNG1BUVKS28+jRo3Hw4EHo6upi3759uHv3Lh4/fkyKjZytTV1dHSZPnoyJEycSj2by5MlwdHSkAVOuRDl06BA1A27fvo0lS5ZAVVUVISEhmDlzJmRlZTF58mRqaMTGxiI/Px9paWm4c+cOXF1dcfXqVRQWFiInJ4fO06lTp+Dr60vtc87iZ+DAgTh06BBCQkKwatUqmsznSIUcPsbn89He3k6ZdXNzM7q7u3Ht2jWMHz8eHR0dKC4uxsyZM+l7t7e34/nz5wCEgffFixcQExPD7du3oaCggNOnTyMyMpKwSMYYcnJyEB0dTeX699Y/QehvCEKfPn0i5bmMjAzIyMjg0KFD6OrqgrGxMaysrHD//n2kpKTAzs4ODx48QHd3N0pKSrB161asW7cObW1tOH78OF69etVHMB8QlidTp07F2rVrERgYCE9PT/zwww84ceIE3Vk5qc8NGzZg8+bNmDVrFnU8Ojs7sXTpUkRGRqKyshI2NjZQVVVFW1sb9uzZg23bttFdesuWLdQi7tevH7S1tQEIy736+npUVFRg1apVUFZWplJw9+7dJEFx5MgRjBkzBg4ODhg5ciSUlJQQFBSEgoICqKurQ1pamvANUVFRSEtLo76+HgKBAPX19fjw4QPq6urg4eEBHo+HiIgIlJeX48qVK5CTkyPZUy6D0tTURGJiIpydnXHx4kUKVNevX0dtbS0uXrwIAwMD1NTUoKGhAR4eHvDz80NERASysrKwe/du5OTkQFJSEl5eXrh+/Tr279+PU6dOQVpaGpcuXUJISAj27t2L3NxcSElJkUC/h4cHZsyYgXnz5mHq1KloampCSkoKJkyYQK6zZWVlaGpqgo+PDzo6OkiH588PU1NT/PDDD5S5cfpGqampVDZyD0VFRcybNw+JiYl9StQ/84527tyJL1++QEpKCtbW1tDQ0MCiRYtQU1ODwMBAzJw5E0lJSTRU29vbi56eHnR0dKC8vByMCbuqb9++RWhoKOkl/fbbbwTk+/v7Iy0tjVxBJk2aBDExMWhoaKC3txdNTU00y/e99U8Q+huCECdi5e7ujh9//JHY03PmzIGoqCg8PT2RkJCAKVOmUFu4paUFvb29eP78ORYtWoTOzk7qHN25cwcNDQ2U4vf09GDo0KEwMjKiEklSUhJRUVGYNWsWoqKiAAgBXa5ciIqKwqpVq9De3o6SkhK4ubkRlsR5yT9+/BhDhw7F8ePHiRjHlUaSkpLYuHEjAgIC0N7ejvr6esyZMwcACFh2c3NDXl4eqqurUVpairy8PBgYGBCQfffuXTg5OaGiogKzZ8+mLEtcXByfP3+GpKQkPnz4gK6uLuKeZGVlISYmBjo6OlTChIaGIiIiAgoKCuQM4evrS6Jmc+fOBQC6S6upqaGgoIA8snbu3AlAqL3MydlyG1ZLSwsZGRlobW2Fn58ftmzZAh6Ph/Hjx+PHH39EZ2cn5s+fD8aEYvpTp07F0aNHERgYCEdHR2zbtg3Tpk2jDFVHRwc//fQTdRi5DPbhw4cEpHMlII/Hg6SkJJYtWwZxcXH89NNP0NbWhpKSEqKjo5GcnIy0tDTSu+ZeU11djXHjxmHr1q1wcnKCjIwMioqKEB4eDklJSYSGhiIyMhKKiorYvHkzHj16hLlz50JSUhIyMjKIi4vrM9UfHR1NncnXr1/j/PnzYIzBxsYGFRUVxMx2cXGBpaUlGGOkj9XS0oLVq1fj8ePHFAy59f+JKfr/Pzz+ShDy9vbGp0+f+mQuHR0dlPbOnj0b06dPR0VFBczMzGBhYUGZEyAUhIqJicGvv/4KJycnaGpq4u7du2BMqCFz4sQJUr/77bffkJKSAmVlZWzYsAEKCgpYuXIlGhoaaGZHIBAQB4l7j3fv3pHFc2BgII1AREVFITs7G9XV1aSn/OeyzM7OjjhMYWFhiIiIAGPCqX5AiC29efMGCQkJYIyho6MDW7duhYeHB758+QJ7e3vCCg4cOABTU1O4uLiQbcynT5+QlZUFTU1N1NXVwc3NDTt27ICcnBw2btyIX375Be3t7YiLiwNjQvlbb29vvHz5Ep8/f4aOjg51fH755RcCngMDA7F7926oqqpCSUkJ27Ztg7OzM9LT05GVlQVHR0ey7rGzs8OjR49w4sQJiIqKIiQkBOPGjcOyZcsQFhaGLVu2YOTIkZg7dy6UlJTQ1tYGf39/ODk5QV5eHs7OznT3l5WVxbVr13Dv3j0UFhYiNTUVS5YsQVVVFXg8Hs6ePYuWlhY8evQIfD4f8vLyUFdXR79+/WBvbw9jY2OMGTMGPT09ePfuHa5evQo9PT3o6+uT9ZGysjJ0dHRw9+5ddHR0ICUlBZ2dnVi0aBGUlZXx5MkTMo4UCAQE3nNdQh0dHaSkpKCnpwevX79G//79sX//fkyYMAGbNm3Cq1evoK2tje3bt2PAgAF4+/YtduzYgS9fvpD10/79+/HhwwdyZ+Gy8hUrVuDz589ITEwkXPJ7658g9DcEoSdPnhAg3dzcDCsrK4waNQpbt24lvpClpSUAoa60lpYWSXZGRUVBTk4OoaGh0NDQwJEjR3Dy5ElMmjSJ7IGmTZuG8PBwsoR2cnIih4OGhgbcuXMHGhoa1FHhghAXFJ8+fYpFixbBxcUFnp6eNPbABUjGGBwdHfHt2zfaxAMHDoSBgQF+//13EtznLHX8/PzQ0NCAsrIyPHz4kNjT3HhKSEgIIiMjifjm5OSE8+fPIzY2Fnv27EFNTQ3KyspQWlqKzZs308Xa0NAAExMThIaG4tq1a1ixYgV4PB4ePHiA2tpawmX8/Pzw+PFjjB07FsOGDUO/fv0QHh6OdevW0edfsGABlShGRkbEk/nhhx8oWJuammLGjBloaWlBY2MjAGDEiBFEK+AaA1yGuGXLFhQWFuLt27coLS2l3z8vLw9XrlyhLMHV1ZUCBAA8ePAABQUFpCW+bt06LFmyBBYWFhRYXF1d4eHhQeUXl92+f/+e3FkGDhxIYy5KSkq4evUqUTFOnTpFYLq9vT14PB7evXuHs2fPIiUlBRISEpgwYQIiIiJIqbKlpYVm4ObPn49NmzYRjrN//35qakyZMgX79+8n/hMgVGHU1dVFQEAAPDw8SLy/ra0Nubm5GDp0KEnxfm/9E4T+hiBUXV0NLy8vxMXFUbt3zpw5iImJgYSEBBwdHZGSkoJXr15h4sSJfdjFACg1vnDhAiIjIzF58mS6GM+ePYvTp0/jxYsXePLkCebOnYtffvmFXsexUouLi6ktXldXR5+NG4jk6nxLS0v4+vpi8eLF2LRpE8rKyjBr1iw8e/YM3d3d1C0bMWIElixZgtTUVDJz5Lpdvb29kJGRwcCBAzF69Gjo6elBTEwMa9aswZEjR8Dj8ZCRkQE+n0++YW5ublQe+fr6gsfjERFPVlYWTk5OMDAwgKysLFpaWlBXVwcrKyuEhYXh/v37KCgooPEQWVlZAMCvv/4KBQUFciItKChARkYGdu/ejdjYWJSVleHVq1cEEquoqJC/GqcSwBjDypUrcfnyZezduxfDhw+Hl5cXAdqMCVv3x44do5bzuXPnoKamRu1sQGgqaG5ujsGDB+PSpUvw9vaGsrIy5syZA0VFRTx58gQ8Hg+fPn2i8mblypUwMzPr43DB3QAUFBSozBcIBODxeJCWlsaSJUugoKBAM3U8Hg9KSkpITExEXV0dli1bhqlTp8LHx4eyRyUlJTx8+BBPnz7Fs2fPsHz5ckRGRtJAMsfniY+Ph7u7Oy5cuEDT/nFxcYiOjqbP0tXVBS8vLzqXCxcuhEAgwL59+5CUlITy8nKSotXS0vru3gH+CUJ/SxCysrLC8OHD+wCFHJtZUVERIiIiKC4uhkAgoM6Pq6srMjIy8OXLF6xevRqRkZHo6upCQkICzp49i5UrVyI9PZ0kQi0tLXHz5k0oKCjgxYsXaGtrw7Nnzyhd/vbtG3799VfihURGRqKpqYl4HYcOHSI8ilNA/PPi/puT7eQe06dPh0AgQFRUFEaOHAlvb28UFxfD1NQUy5YtI2lWrkQrLy/HgwcPyOmhpqYG7u7uyM/Pp3awkZERgoODERkZSZKiGzZsAI/Hw9q1ayEhIQFnZ2ciL7a1tSEiIgKrVq2CgYEBecIfO3YMAQEBSE5Ohp+fH44fP47r168TXsGtPXv2YOrUqXBzc8O7d++QkpKC2bNnY//+/ZCVlYWxsTE6Ojrg6+uLkJAQMCac6J87dy6GDx9OmeO6desoY8rJycHPP/+MqqqqPt3K2NhYygbFxcUhKioKGxsb7Ny5E6dPn0ZbWxseP36M9evXIzo6uo+qo7i4OJSUlPD8+XOoqanh8OHDeP36Nbq6unDr1i3Y29ujrq4ONTU1dL44w0hOHTM7Oxtz586Fvr4+VqxYQZ+daxxwcjDnz5+Hnp4eYWxv377F9evXsXr1akyZMgWVlZXUXeNKZ25VV1fD3t4e3t7e1IZPTEzEsWPHUFBQQNnjn8mZ/9X6Jwj9DUFo8+bN6N+/P65evUpSGqKiomhoaICVlRUGDRoELy8vzJgxA1OmTIGamhpiY2Mxbtw4qqUXLFhAFxYntP7LL79AVVUVkyZNQkZGBs6cOQPGGA27lpeXQ1RUFHJycrC3t4eGhgZqamrw+fNnJCUlwd/fH3v27AEgzI4YE/qBcZPyAIiS39zcDIFAgMzMTJiammLKlClgrC/fZNGiRXjw4AFCQ0MhJycHf39/yMvLQ1RUlDSYuWyhsbERAoEApaWl2LJlC9avX4+cnBwsXrwYCxcuJAPEp0+f4uXLl7h+/Tq5Q3BdosbGRjx69AjOzs44ffo0JCQkYGRkBEAIQnO22evXr8fy5ctpM8fExKCjo4PccLu7u9Hd3U3uq1yrecaMGWCMYdCgQejq6qJgEhERgRUrVuD+/fvQ1dVFZmYmAgMD0dLSQqUb58IxY8YMRERE4MmTJ1i6dClMTU3h7e2N2tpaOj7X2VyxYgUOHDiAhIQEAqs1NDQgIiKC5cuXQ1lZGTt37kRCQgJcXFzQ0dGBpqYmPHz4EJ8+fcLx48cBgL5XUlISJCQksHjxYvj4+CA9Pb1PhsnRIbS1tXHgwAHY2dmRA66CggLmzp2L7du3Y968eXj79i3u3btH5WxXVxe6u7vpmiwvL8fvv/9ObGuBQIDU1FQ8e/YMOTk5dP4FAgGePn2KtLQ05ObmfnfvAP8Eob8lCHH+5gAQGxsLaWlpSElJ4fPnzzh58iR8fHzoDvTt2zdkZmaSIHpnZydOnTqF58+fIyQkBObm5rC2tkZeXh7OnDlDE9kuLi4kyK6lpYX09HTs3LkTY8eOxaFDh0j3x9zcHNnZ2RAIBCgsLISkpCRmzJgBgUCAmpoavHnzBrt27aLgwuEjnERFfn4+2traCA+4ceMGvn37huvXr0NPT49cO5SVlXHkyBF8+/YNHz9+xO3bt9HR0UHynq9fv8aJEycwdOhQJCYm0gV5+fJlaGhoYNWqVZg+fTrmzJkDLS0tWFhY0PQ6ANL4GTFiBNzd3bFmzRoMGzYM06dPx/Pnz/H+/XtUVFTA3Nwcjo6OCAgIwJw5c7BhwwZ0dXUhMzMTqqqqFBTr6uqQmZmJjx8/knXO5cuXMWfOHLi5ucHR0RGRkZHw9/eHvr4+iYpNmDABGzZsQFBQECZOnIiHDx+ioaEB165dA2OMOlc//vgjHBwckJaWBhMTE6ipqSEhIYEkZj99+oTMzExcu3YN+vr6iImJwYcPHxAUFISIiAg6F3/26rpy5QocHBywZcsWlJWVgTGhxU5PTw/a29vBmJAQyOfzKTAFBwdj8+bNUFNTw/r167FixQrIysrC29sbgLAbxmXn06dPB/AvBj4gxHr27NlD5gnccXfu3AltbW1oampCQkIC6urq1NGcNm0asc0FAgE8PDxw4MAB1NTUfHfvAP8Eob8lCO3cuRPh4eE4deoUPDw8iEwmEAjw/v17fPv2DZ2dnYiMjER3dzed9Hfv3hHd/tSpUzTYGhISQizq7du3Y/PmzTh27Bjd6W1tbcHj8TB37lzk5OTA0NAQgwYNgoWFBUaMGAEnJyc0NDSgqakJ1dXVMDQ0hKysLOrq6uDi4gJNTU1cuHAB7969o8FTgUCAMWPGoKioCEePHsWAAQNgbm6OXbt2EeFSV1cXKioq5LjBUfazsrLIg+z9+/fIzs4mkbHff/8dOTk5ePHiBSwtLbFjxw6oq6uTQ4mlpSVkZGRIt7qjowMfP37Eq1evsGfPHvB4PAKnAaEK4YwZM2BkZESBjSMy7t+/H6GhoRAIBFi0aBH9Xlzw5ch6TU1NEAgEMDY2xtWrV+k4paWlNDelpqYGQGgyefToURp+lZKSQldXFz59+oTu7m4UFRVh/fr1OHjwIOrr60ncX1paGj09PaisrERNTQ0aGxsxb948nDlzBmvXrsWyZcvg5+eHEydOYPbs2WhsbERhYSHs7e3h6ekJgUCAoqIiMCY0jhQIBPDy8iJheY6vExAQgMePH8PQ0JAkPgBhqcqdNzExMXh5eaG1tRXa2tqQk5ODuro6fHx86CbE5/Px6tUr6OrqIjIyEhEREejt7SXqgZeXF0RERODm5gZ7e3v4+vrCwsICgYGBGDduHEaPHk2kyMePH0NbW5uC/ffWP0HobwhCnMjYunXrwJhwzCAoKAj+/v6IjY3F58+fMXr0aKipqWHv3r1wdXUlP/nq6mo0NjYiOzsbra2tuHXrFng8HmJjY2FmZgYfHx88fvyYxPM55m9mZiZaWlowZ84cArE5yr6BgQHhIgKBAD4+PjTdzWEA8vLyWLduHaSkpPD27VsCx+Pj40kZ8ccff4SoqCi2bNkCT09PSEhI4OjRozROsWvXLnR3d+Pjx4/UZeNKjH379qGpqQmBgYEEonKUBUlJSaxduxZqampwcnLCtWvX0NzcjObmZhJ05ygK8+fPh5aWVh9MgpudcnBwwPPnz+Hs7Izjx48jPj4e0tLS1E7fuXMn4uLi0NbWRpvYyckJoaGhOHjwIKysrEim4/Dhw4SfjB07FhMnTsSjR4/w7Nkz1NbW0u8vJSWFDx8+ICkpCV+/foWjoyMROgGgqakJCxcuxKJFi+Dv74/Xr19T82DevHmQkJBAVFQUwsPDkZycjH379mH16tWIiYmhUkhUVBQfP35EUlISbGxscOjQIeTl5dF5Hjt2LCwtLWnYeO/evZg7dy50dHRw5MgRtLW1wczMDN7e3vDz84OcnByCgoJoENrc3Bzu7u7g8XhYuHAhSaRUV1eTzO/y5ctRVVUFMTExIodygZkbL1m6dGkfaRZxcXGUl5fDxsYGkZGR+Ct7B/gnCP0tQaiqqopKpeDgYFKfO3PmDKXaxsbGmDhxIszMzMiW5/Xr1+jt7UVNTQ1aWlrIj+rAgQPYtWsXDh06RMOdfn5+cHJyQn19PZKTk/sIXw0cOBBWVlZ1+UvLAAAgAElEQVS4detWH6sVTvDs5s2b8PT0pIxBXV2dJEh/+eUXqKioELD522+/obe3F/Hx8TRWwLkmcG3etrY22jBiYmLYvXs3vn37hqioKNIjHjRoEAWzM2fOABBmjCIiIpCVlcWXL1/Q0NAAT09PTJkyBampqSgvL8e7d+8QHx+PjIwM6OrqUtb19OlTVFZWoqurC7W1tVi3bh2GDBkCCQkJ4r/8GQfhskiOL+Xi4kJM7du3b1PwMTY2Rv/+/TFp0iTiRpmamkJeXp66mHp6ejh9+jR8fX2JiNra2opHjx6Bx+Nh6dKl0NXVRWJiIuLj4zFv3jxERUUhPT2dul7cwC5jrI8NN2dfxD3k5OSgr69PypOTJ0+Gh4cHZY5KSko01e/i4oJLly5BRUUFJiYmmDp1KrmwmJiYIDw8HI6OjhT4c3JyUF9fj99++w1qampobGykMn7SpEmIj4/v001rbGzEkCFDsH37dlRWVlI7XyAQICIiAqampvTd7t+/j+joaOzbtw+MCUmVY8aM+e7eAf73gpDQGuKfRautrY1ZWFiwY8eOsaKiIqavr8+6u7uZo6Mju3r1Kvv27Ruzs7Nj2tra7P79+8zExISZmZkxLS0tlpGRwYYMGcJ++OEHlpCQwKZMmcLq6urY+/fv2cGDB1lxcTEzNjZm3d3dbNKkSUxKSoolJyezyspKJi4uzpSVlVldXR0bN24cU1RUZJmZmaxfv36ss7OTPXv2jG3fvp0NHDiQbd68mW3bto3NmTOHrVixgm3dupU9efKEtbe3s9u3b7Ndu3YxRUVFVl9fz3Jzc5mKigqTl5dnY8aMYWfPnmXu7u5s9erVLDAwkAkEAiYvL8+UlZUZAFZSUsK+fv3KDA0N2fTp05mRkRFzd3dnQ4YMYXv37mU//PADKywsZG/fvmUAWFtbGzMzM2Pi4uJs3bp17ODBg2zmzJlMRUWFKSkpMU1NTbZu3TpWU1PDjIyMWF5eHisoKGCGhoZs6tSpTEFBge3Zs4fV1NSw7u5u1tvbyzgHlra2Nubt7c2mT5/ORo4cyRITE1lFRQVrbW1lqampbN++fay2tpaFhIQwHo/HYmJi2NGjR9mWLVtYbW0tExERYVlZWczJyYmNGDGC9fb2Mk1NTfbmzRu2a9cuduvWLXb//n02ffp0ZmJiwhITE1lMTAwbMWIE+/r1K/v27RszMDBg1dXV7KeffmLZ2dnMxMSEdXZ2Mn19fRYaGspUVFSYsrIyk5KSYpqamuzmzZtsypQpTFtbm7W1tbGXL18yERER1tbWxnJzc1lSUhK7cOECY4yx5cuXs6NHj7L29nZma2vLrKysWHJyMsvOzmZZWVls5cqVbNiwYWzatGnMzs6OVVVVsaNHj7J79+4xbW1tpqyszGRkZFhQUBBTVFRkc+fOZaKioiw/P59VVFSwpqYmdubMGdbb28ssLCzYoUOHWGFhIVu9ejUbOXIkEwgEbM6cOWzlypXM2NiYKSkpsc+fP7MlS5awr1+/MiUlJbZ7926Wn5/PfH19//s23b8btf5ffvyVTMjFxQX9+/enVnVUVBRZKyspKWHy5MlwdnZGcHAwmpqa0N7ejtevX5PYuoKCAh4/fkw8GK69r66ujnHjxsHW1hY3btygTgXnwOHp6YmwsDDs2bMHCxYsgLS0NIHVw4cPx759++hYAoEA3d3dePDgAXbv3o38/Hzk5eVRR+jly5e4fPkySXVynBQOw5KQkCA+UUFBAc2VMfYvA0HOJYPDcTo7O9HZ2Qkej4cLFy5g9erV2L17N3R1ddGvXz8MHjwYFRUVEAgEuHz5MmbNmkUtcB6PR6JYenp6GDZsGOrq6lBYWEguItx7V1dXU3bB/TMoKAg///wz6eFERETg2LFj2LdvH6SkpMjQT15eHkuXLsWpU6dw/fp1Iia+fPkSpqam0NDQgKSkJCQlJWFra4ve3l78/PPPYEwojpaQkIDg4GAcPHgQS5YsQVhYGLKzs6m9DQgNEpWUlHDv3j3weDw0NDSgp6cH3t7eCAsLQ21tLR48eICGhgZcuXIFXl5eCAoKQlFREd6/f4+8vDyMGjUKoqKi8PLywsiRI+Hi4oLe3l4a00lLS8OxY8dgaWmJwYMHY/PmzaiqqsLVq1f7aCUBQpeM+Ph4KsHr6+sRFxcHOzs7AMKuGyeEt2/fPtjb20NGRgZiYmLIycmBu7s7Nm3aBD8/P4iKiiIqKgpPnjxBTU0NkpOTCRP9H+1deVxOaf/+nkqpRBKKypYlxlKyC9laMDIoxjK8shQzhsFYIxTekO2pRMZaxNBCbyZFKtJCpaQSqVTaU9qeeq7fH89z7sH7zmDe/MzMe67P5/n06Tnnuc9yn/t77vu7XBfvb3ofSFiONY0RKisrw8OHD9GzZ0+UlpYiLCwM/fr1Q6tWraCkpAQTExPMnj0bAwcOxMWLF3H9+nXm2/H390dubi5zXl+/fh23b9/G0KFDMWTIEDg6OjLqiLq6OgQHB0NNTQ1LliyBSCTC5cuXsXr1amzbtg07duyAs7MzG8Dffvst0tPTceLECaYTTjLHqbe3NxoaGlBUVIQrV67g2LFjiIiIYBG13bt3IzY2FgAwe/ZsKCoqsiWepqYmiAiWlpbw8fFBfn4+Xrx4AbFYjKdPnyImJoZRmD569Ah79uyBqqoq7O3tERISgu7du+PVq1fMeTlmzBi2jIyOjkZ5eTlmzpyJrKwsbNq0iUWtxowZg23btuHGjRvYuXMnNmzYgLi4OJatbGxsjKVLlwKQpjp06dIFo0aNwvDhw+Ht7c0MV6dOnbBr1y6MGzcO+fn5zMBPnToVzZs3Z7JIhYWFePz4MYKCghAdHY0rV66gb9++mDBhAioqKthA4x3F/PJxxIgRsLGxQUBAAPbu3YvevXvj6dOnLAoaFBSEIUOGwNPTk9H2Xrp0CVVVVVi+fDmmTJnCeLdv3ryJpKQkFtE0MDCAlpYWoqKicPPmTURGRiIoKOitpWjz5s0BSP08Xbt2xYkTJ1g6xs6dOwFIOaJdXV1RWVmJjIwM6OrqonPnzjh8+DBiY2Nx+PBh1NfX4+XLl6zNr7/+Gn379oVEIoGHhweICG5ubkhKSmLXwhtggWP6/9EIvcmlq6+vDyUlJbRt2xalpaWYMWMGEhMTER4ejubNm0NJSQlEhF27drEBnpCQgB9++IHRawLA48ePmbOPiHD79m0AYB1sY2MDDQ0NaGlpsVApIM3cPX/+PG7cuIE7d+7A0tIS27dvx8WLF+Hr68uc1woKCnjy5AmePHnCnL48cRf/8IjFYly4cAH379/HiBEjcO7cOeaPWLZsGYYPH47s7Gw2m4qLi8OOHTvQv39/DBky5K2kusTERDg6OgKQMjEGBwdDIpEw0vjHjx/j+++/ByBVkThw4ABsbW0RHx/PyM6GDBkCPT09RjmxYsUK9OnTBwEBAbhw4QKsra1ZYTBfzkJEaN++Pbs/RkZGkJOTQ0ZGBhITE3H48GE8e/YMt2/fxty5c6GgoIDu3bvD29sbnp6eyMzMhEQiwZIlS5gy6qNHj3Dnzh0WwXr06BHrJ17eyMzMDAcOHMDMmTNZBnGHDh1w8OBBDBs2DJMnT2Y0ruXl5Th79iyUlJSYcsuUKVOgp6cHfX19ZvirqqrQ2NgINzc3VhN48eJFJCYmQiKRsPIZRUVFzJkzB4A0h403OoA08PDNN9/g2LFj8PLywpUrVyAnJwcvLy+cOnWKEZN5eXnhxx9/xKVLl3DmzBkMHDgQ27dvZ8/vxYsX2UyezxlavXo16uvrUVNTAwsLC9jY2Lx37ACCEWoSI5SSkoLw8HD4+vqCSFprY29vjzFjxsDW1pZlKPPZyGpqagCkUYZly5Zhzpw52LJlC6sze/jwIZte88obVlZWrMYqMzPzLYqHiIgIJCQkYM2aNSwMXl5ejqVLl2LZsmUAfk1W1NDQYLU+fK6Sr68v0tLS0Lp1awwePJglCyYlJSEuLg7e3t6YPXs2DA0N0bp1a/bG1dbWxo8//siyZRcuXMhkpLW1tRm1BU/5YW9vj+rqaoSEhDCFjNOnTyMmJga3b98Gx3EwNDTE9evXceLECbRo0QI5OTm4cuUKSktLIRKJsGXLFkaDoqamBiLCvn378NNPP2H79u0oLi5GSUkJ4uLi3pLv4Y1hWFgYTE1NWXaynZ0dJBIJunXrhmbNmuH69eu4desW00yrra1lPNs9evRAZWUl01pPSUmBu7s72rVrhzFjxmD37t0ApOKEjx49gkgkQlxcHA4ePIiuXbtCTk4Ovr6+cHFxYct0QJoIyFehjxgxAh4eHkhNTUXnzp3RuXNnlJWV4cGDB2y2HB8fj7q6Orx48QIKCgowMzNDY2MjAgMDWcW/sbExu64uXbrA2dkZ6enpUFJSYsoi/D1xdnZmqRo///wzE2U4evQoLly4AAUFBSgrKwOQChq2aNECy5cvZxnymZmZOHHiBEQiESoqKhiHtdRz834IRqgJjNC6devg7OyMU6dOvVUMOXnyZKiqqrI3OV9gaGZmxqJTrq6uTCWV9zN88cUX8PHxQUFBAdatW8eiErdv30Z1dTXq6urw4MEDTJs2DfHx8Rg6dCjk5eWhoqLCjJabmxvs7Owwbdo0DBgwAD179oSFhQXMzMzg6ekJQJoM9+WXX7Jyjvbt2yMhIYGxAJSVleH06dMsssMrP/AfngmxoKAAZmZmiI+Px9q1a9GzZ0+WvMn7xjZs2IBWrVoxnbLa2lpERUVBLBazJc2SJUvQoUMHXL58mWWZt27dmi2vYmNjYWhoCDs7O+Tm5uLbb7/FoEGDsGvXLgQGBsLMzAx1dXWoqqpCdXU1M7zffPMNEhISkJ2djczMTNy4cYPl0BBJyzESEhKYDI61tTU6deoEJycnnDhxAjNmzICOjg527drFljT8jNTZ2RnOzs6wtraGuro6Dh48CJFIhJSUFNTX1yMkJASdOnXCF198waKEiYmJbDY6adIkJCUlQSwWIzAwEE+ePMH69euxZs0alJSU4MWLF4iJicGNGzcQHx+Prl27Qk1NDaNHj8bAgQPRo0cPjBo1ij2LPCVM27ZtUV5ejg4dOjCuqFevXrFykvPnz2P16tWoqqqCmpoaKioq8Pr1aygpKWHr1q2sPYlEwu6Ht7c3TE1N0a5dO+zatQu3b99GVVUVTp06hZMnT+LFixfIy8tjWnOamprvHTuAYISaxAjxtKJOTk7YuXMn3NzckJycjE6dOkFFRQX79+9HVVUV1q1bByKpwkRoaChOnjzJZjd8KJWX7+nbty/2798PRUVF2NjY4O7du6irq8P169eRmJiIDRs2wMPDg6Xo9+jRA2vWrMHz58/h4uKCgwcPoqKiAr169YK6ujomTZrEsnH5cgAAGDlyJJNJ9vf3ZwMRkL7R3d3dERYWBnNzc2zevBnDhg2DoqIiVFRUYG9v/5ZWGQB2jT/88AOuXbsGPT29f6tH09TUxMaNG3HhwgX4+fnh2LFjEIvFyMvLY6UZRFJeo6+++gqLFi0CIE0mvHXrFi5dugQrKyu4u7vD29sbPj4+LLTepk0bpKam4tmzZ0hOTkb//v2Zryk9PZ3NFPjwe1paGkxNTTFkyJC3JJgAaU3go0ePMGnSJPTv3x8ikYgNNABMJICf8QQEBGDWrFk4ePAgAgICIBaLERkZCSJihPvPnj3D2rVrYW5ujoyMDBgaGrJnYOrUqRg5ciREIhFTs2hoaMDChQtZzk1ERARUVFQAgM1eCgsLYWtri6ysLEgkEqxatQoRERFYuHAhzM3NERQUBGdnZ8TGxuLx48coLy9nBbwxMTGYO3cuvL29kZCQgKFDhzKO6pqaGtTU1ODRo0dMJ2/79u345z//iVevXrFE2/j4eDg4OGDgwIGIi4tDTk4OQkND31I8+T38ESMkv23bto+Ipf214enpuW3JkiW/u094eDjNmTOHVFVVad68eRQTE0N79uwhAHTt2jU6e/Ysqaurk5WVFW3fvp169OhBvXv3purqarpx4wbl5OTQxo0bKSoqipYuXUrKyso0a9YsCggIoJSUFMrMzCQDAwMyNDSkx48fU3JyMs2fP59MTU3p3LlzZGZmRkuXLqVBgwZRVVUVNWvWjBYsWEBqamp08eJFMjIyotDQUFJUVKSGhgbau3cvTZw4kQoKCkhbW5vOnz9PK1eupJCQEBo1ahQpKCgQEVF6ejopKyuTubk5denShb755htatGgRAaCQkBBKS0ujFi1akI6ODo0YMYJ27txJpaWllJmZSfv27aNRo0bR3bt36fr162RkZES6urpUXl5Oz58/p/z8fOrfvz8tWLCAAgICqKysjHr27Eljx46lEydOUKtWrcjKyoqioqLowIEDFBAQQHp6ejRw4EAyMDCgWbNmka+vL0VFRVFcXByVlZWRjo4O+fj40KlTp2jBggWUnZ1NM2fOpPbt21NKSgqVlZWRsbExVVdX0/jx42nSpEnUp08fcnJyotLSUurXrx9FRUVRcHAw1dTUUGNjI6mqqpKDgwONHj2aamtrydjYmJo1a0ZFRUWkpKRE9fX1ZGRkRDo6OtS7d2/Kzs6mwsJCIiIqLi6mr776iurq6qioqIjWr19PHMdRTk4OqaurU15eHrVq1YoCAgKouLiYlJWV6dGjR9StWzfS09MjbW1tEovF1L59e0pOTiZLS0s6d+4c3bp1i5SUlEhZWZlUVVXpxo0bdPLkSZYeMmTIEOrbty+1a9eOFBQUaPr06aSurk6bN28me3t74jiOBgwYQN27d6fx48eTjo4O+2tlZUVbtmyhsrIymj17Nj18+JCysrIoJyeHfHx8KDIykgwNDUlfX5+WL19O3t7e9P3331NNTQ1paGiQtbU1+fn5kZWVFWloaFC7du3eO8YcHR3zt23b5vlRA/NjrdZf+fMhMyFLS0sEBQUhMjISp06dYnzO9fX1MDc3R1VVFV69eoUOHTqguLiY0aryFdSGhoZQVlbG3LlzAYAR3VtbW0NPT4/x2pibmyMmJgZnz55FWloa+vfvj4ULFyIpKQk5OTlM6mXr1q2oqqpCeHg4ysrKEB4ejoKCAhgZGeH06dOMo5lnTJwwYQIaGhrg7e0NNzc3Rv7l7OyMJ0+eQCQSwdraGlpaWlixYgVGjx4NLy8v+Pn5YfPmzSwNYM2aNfjuu+/g5OQEPz8/lnHMCwQCYAW7vXv3hp+fH0s0lJeXZ2qhvPOzVatWzM/CL9n4t/OdO3cYQbxYLGZcx7xckJaWFtasWYOIiAicO3cOnTp1gpGREU6cOMHKZnJycuDg4IBWrVpBQ0MDgwYNwsqVK6GtrY2XL1+yrPPy8nKsWbMGXbp0gbGxMQYOHAgPDw+cOnWKLc9ev34NOzs7pi/PJ0ROnjyZnauzszOKi4uxa9cuFpw4cOAAOI6Drq4usrOzMXbsWEydOhUZGRlITU3FhQsXmOiAu7s7fvrpJyZZBEjZEkQiEavxcnFxgYmJCWbOnImZM2eiR48emDp1KvLz85Gbm4v6+npERERAWVkZBgYGKCwshEQiQVFREfMRbd68GWPGjIG2tja2b98OJycn3L17Fzk5OSCSZrFnZGTg2rVrTI3Xz88PP/74I6vMDw4OZhHG94GE5dh/b4TCwsIgEong5uaGPXv2MFY9QFrrlJ+fj4KCAhw/fhyrVq3CiBEjoKCggFmzZsHDwwP6+vrQ09PDpEmTWEq/ra0tKisrcevWLXz99ddo27YtM26NjY0oKSmBs7MzG5x8CHfAgAE4fPgwioqK0NDQgLy8PBQUFCA6OhoGBgZISEhAfHw8oyjls5o5jmN+qgsXLgCQLl+ePXuGS5cusUiTo6MjqzMikhKZ8aF4LS0ttGzZEmFhYQCk0bJnz56xQX/37l388MMPUFNTYzIzOTk5ePjwIXr16oXp06dj+vTpbNmmrq7Ocln4otSoqChMnz4d+/btg6KiIhwcHFBdXY3q6mokJSXh8OHDmDt37luaV8HBwYwDecKECXj8+DEjauOzwlu3bg11dXV88cUX6N+/P7KyshAaGorc3Fz4+PiwvJmpU6dCIpEgOzubRfP4SNWECRPQoUMH1k8jR45knFFvLnMdHR1hb2+P0NBQ+Pj4sCjSlStX2PKW/82OHTtQU1ODwsJCRp365MkTaGlpMb7ya9euMb6pJUuW4Pjx48znRESMqP7p06fw9/eHSCRiOW2bN28GAMycOZNJavNkZN7e3jA3N8f06dPZEvTcuXOIjY1l9LUikQirVq1izwv/LPH39EMgGKEmMELnz59Hx44dMWDAAEycOJFRn1ZWVqKxsRGFhYXs4fLw8MCKFSuYDIuvry/Onz+PHTt2sIGTkpICFxcXxMXFobq6mvkVBg0ahKVLl+KXX35BY2Mje/izsrLYg9bQ0MAIp/g3FT8Q3tQWv3z5MpycnDB27Fhs27YNkydPRnJyMsRiMUaPHo2LFy8iKCgI58+fR35+PiZMmABXV1dcvXoVqampcHNzww8//IDIyEh2bbzv5fjx48wxzRfR2traYtKkSZgyZQq2bNmCn3/+mf2Gd9SSzFfDO/CJfpXY8fHxgUgkeov/pr6+HsXFxQgODoZYLEZVVRXq6+uZkoarqytGjRqFoKAgplwLSB3p8fHxiIyMRL9+/aClpYUlS5YwVRB9fX20bNkSOjo6CAwMZH3Vr18/GBsbIz09nUk2PX36FBKJBLm5uaiurn4rQW/UqFHo0KEDvLy8cPjwYVRWViIuLg729vbYsmULDA0N0bNnT8ycORO7d+/G/PnzGeVIWVkZS4q0sbFhzJ01NTWMimTnzp2orq5GbW0tHj58CA8PDxQXF8Pf3x/6+vr4xz/+AWtra9TV1SEyMhK6urpspqWvrw8TExOYmJigurqazYL42XFjYyPat2/PfIchISEoKirC999/j4ULF2LWrFmMMgUA5s+fj5MnT7IQv46ODuMkfx8EI9QERoiveCeSVri7ubmhrq4Ozs7OkEgkqK2tZSHUESNGMFVWPkcGAJSVld9SrvTz8wORlEXQx8cHJiYmLN/jTS6ghoYGKCoqolevXqivr0djYyM2btwIdXV15ObmIjIyEl9//TWSk5Oxbt06bNq0CVevXmVh9mXLlmHlypXMGR4YGIjGxkbk5OTg8ePHGDVqFOOPdnNzQ0JCArp37w5NTc23iNH4mV9dXR1bSlVXV+Px48essPeLL76AWCzG2bNnMWXKFHh4eEAkEsHOzg76+vpQUFDAmjVrmILD+vXrsX79ekyZMgUikQibNm1iS7XExETk5eUxRzNfENynTx/MmzcPW7ZsYYW2hw8fxqtXr7B3715mUFq2bAldXV3Mnj2b5UWFh4fj8uXL6NevH3r16sWct5s2bUJOTg5bUq5atQru7u7w8/NDdnY2cx5bW1sjPz8fKioqMDc3h6GhIW7fvo01a9YwA9fQ0AA1NTVoa2tj1apV2Lt3L9Nxa926NTw9PZlcUVBQEKstMzU1RWZmJitQ5Zdh9+/fh7+/Pw4dOoSKigokJCSwSBjP5igSiQBI86zMzc1x9+5dNDQ0oKysDGfPnoWnpycaGxtRUFAAFxcXnD17FoWFhRgwYAB7JmtqaqCnp8eKkAcNGoQ7d+4gIyMDx48fx48//siKknlK4n/961/vHTuAYISaxAjt2LEDurq62L59O2MKvHDhAktf59/SnTp1wpkzZ5CTk4Py8nI8ePAAYWFhcHR0RJ8+fdCvXz+mXcVXpcvLy8PFxYVFJ96UA+KXKnwYduvWrZCTk4OJiQkCAwNZmJqnsdi3bx80NTXRpk0brFu3DmvXrgUg1RPfuXMnIiIiEB0dDUBqWE1NTeHl5YXz58+zMDkgzTniuYjLy8tx9epVTJs2DcCvPh9NTU3cuHEDIpEIgYGBmDdvHpMlAn4truULf93c3AAAX331FaNZNTAwQHBwMGbMmAFXV1eMHTuWJQVaWFgw/4+6ujq2b9/OmC15CttFixZBUVERXbp0gZWVFQAwEnZeeoe/3zwaGxuRkZHBhB6JpERw1tbWLNnS0dERQ4YMgb6+PqZMmcJ8eBoaGti/fz+UlJRgY2OD+/fvY9y4cejQoQNUVVUxc+ZMVFdXs2N269aN8RLZ2dlh7969uHPnDkJDQ1maR2JiIiwsLDB//nyWAxYSEoKAgABERkZCIpGwJSxvzExMTHD37l34+PjAycmJRRe///57vH79GoWFhW/phTk7O+PChQtsefX69Wvk5ORg2bJl6N69O4YMGcJmvDwrpJOTE1auXIkRI0ZAJBLB09MTBw8eBCB1T+Tm5rIX7PsgGKEmMEJ8+PzMmTO4d+8eysvL2TKGx/r16zF37lzY2dmxN+zUqVMBAEeOHIGzszNatmyJrVu3IiQkBBs3boSBgQGsra3x/PlzhIWFvWWA7ty5Az09PVy/fh01NTUsXFtZWYmDBw++deykpCT2sGtrazMWyPv378PPzw8JCQkoLCxEVlYWXrx4gdevX7MByBslnqeGN3z8NNzMzAyjRo1CUVERpk2bhp07d+LOnTtwc3NDy5Yt8d1338Hd3R2pqak4fvw4Xr9+jYyMDBYOz8jIgI+PDx48eICKigro6+vD0tIS2traaNWqFQICAlieFG+wTE1NcejQIfj7+2Pt2rV49eoVrly5grFjx7Kq9cuXL8Pf35/NUFVUVFBcXIz6+nrGWKClpYW1a9eitLQUJSUlKCgoQENDA3bs2AF1dXWmFQdI/Vuenp5oaGhAdHQ086nwZRpEhKNHjyIxMRHy8vKYNWsW0tLS0LZtW1Zas3z5cubIfvjwIbS1tWFvbw8VFRWsX78eenp6b/mOeK7wkpISmJiY4OXLlyycn5KSwvyNPHdSnz59WKY6T/uqqqqKzp074+LFi7CwsEBaWhpKSkrg7++P2bNnQ1VVFRMnTmTPsYWFBUJDQ1k1PMxo4/sAABfgSURBVMlSJfjnjt+P11xzcnKCr68vgH+vFeNnne+DYISawAjdvHkTz549g5GREdzd3QGATb+BX52S/DKKr7kZOXIk+55XgwgNDUVYWBhevHgBiUTCnJwnT55EbGwsiouLkZSUBF9fX4wePRr79+9HUlISFi5cyEoqeBFGsViMX375BVu2bMGoUaPQpk0bSCQS5nTl33zz5s3Dvn37cO/ePXb+NTU1zGHKn3d4eDg0NTWxe/duBAcHIy4uDm3atIGamhoOHDiAadOmMYMBgJWITJo0iS359u7di6dPn8Lb25v5hSQSCSorK3Hs2DFMmTIFEyZMeMu/wi+X7ty5gw4dOkBBQQHdunXDzZs3ERsby2heBwwYADs7O+jo6EBDQwPBwcE4efIkNm3ahAMHDuDgwYPsfoaFhaFly5ZQU1PDvn372IBr27Yt82eVlpYiPDwcFRUV+PLLL2FpackSRr28vHDgwAFcvHgRBgYGWL58OUpKShAQEAAiwsSJExEYGIjExER2HZs2bWID2dTUFBzHYffu3RCJRFi8eDHz/0RGRqK6uhqLFi1iv339+jWqqqogkUjYdYjFYhQVFbEZs7+/P06dOoWBAwfCzs6O5WuRLNH0woULmDNnDtq0aYN58+YhNjYWt2/fxurVq/Hs2TNERkZCVVUVgYGBcHR0xOjRo9G+fXvMmjWLZdFXVVWxGVSLFi2QmZmJtLQ0NjNPTU2FlZUVlJSU2AzsffjkRoiIdIjoBBHlEVEdEWUR0QEiav2R7WjIfpclaydP1q7Opzz2h8pAi8VizJ49G506dYKtrS172AHgxo0bqK2txatXr5hD2dDQEKNHj2YPWWVlJStl4JUtc3Jy4Obmhri4OFy6dAlHjhyBiooKgoKCUFZWhoyMDIhEIlae0LNnTxQUFLD1fU1NzVv1akTS2qaRI0ciOzsbtra22LNnD5o1a4bOnTujvr4e+/btQ319Pdzd3dlbNyEhgXFQZ2dnY8OGDRCJRFBXV4eKigqSk5NZ9IRnKYyKikLLli2hqqoKBwcHpKWlYeHChWjWrBmUlZUREhKCPn36oKysDM+fP2f1b7z/4s2o36pVq7B582YoKytDVVUVVlZWjDv7xYsX+Pbbb9n18Xpq/PXwCXWHDh2Cn58foqOjUVFRAXl5eRbFsbGxgY6ODsaPHw8bGxs4OTkhOTmZOWWHDx+O5s2bQ1NTky2lLCws0LFjR9TU1LClpUQiwYkTJ7B//37k5eXBx8cHJSUluH//PhvEy5cvx8CBA7FgwQLo6OjA1dUVrq6u6NmzJ3r16sWuISsrizEQAFK6XG9vb4jFYiQkJODw4cNo0aIFEhISMHr0aKxcuRLjxo2DnJwcevXqhadPn8LPzw/5+fnQ19cHx3GoqKhgDAZE9NYzytO58pHN0NBQyMnJQUlJiQkLAL/6MVu0aAFfX19YWFgwtwMAFjXlXwofgk9qhIioGxG9lJ2UHxHtJqIw2f+PiajNB7bThojSZL8LlbXjJ/v/JRF1/VTH/hAj5O7uzmqmHB0dMWjQINja2rKH09vbm2XA5ufno7S0FLW1tQgNDcWMGTOwbds2NDQ0sELAVatWobq6GpcvX8aiRYsQGBgIZ2dndO3aFVOmTGFMgd988w0MDAzg6uoKJSUldOnSBZWVlcjPz0dMTAybqu/cuRNKSkrIycnBtWvXIBaLYWdnh0GDBgEAvLy8MG3aNJSWluLatWv4+eefsX37dtja2kIikbAlSWNjI548eYLQ0FB4eXnh2LFj+Oc//wk3NzfEx8fj+fPnOHPmDE6dOoWffvoJTk5OzD/0/fffw8LCAhMnTmQzq8zMTPTr1485yRMSEhAVFYXMzExUVVXhxo0b0NPTg56eHhYsWIDNmzfj3r177C189epVnD9/HlFRUZg4cSIrT7h06RKT++GXpT4+Pmx5UFtbC319fYwcOZItC1++fImtW7eyAcRHOOPi4iAvL88csvLy8khOToapqSnatGmD0aNH4+rVqyxIwF87v+SePHkyK4O5ceMGfvzxR/Tu3RvOzs6Mj9vT05PliO3btw8zZ86EkZERwsLCsHv3bpSUlGD06NGIiIhgzxw/+wsPD8erV69w8eJF3L9/H/b29tDS0kKzZs1Y1MvKygouLi4oLCxkM6M5c+bAxcUFjx8/fms5HxISgqVLl6JLly6YO3cufvnlFwBS4zR16lSsXr0adnZ2KCwsRFVVFSIiIqCuro7o6GjExcWhpKQENjY2IJIKIX4IPrURui7r1G/f+X6/7HuPD2znqGz//e98/53s++BPdewPMUIxMTFQUlKCvr4+EhMT4eLiAn9/f+zatYuVLHTv3p1NxcvLy1FeXo7c3FzIy8vDxMQEhYWFEIlEGDduHFRUVNgSJDs7GxoaGrC3t3/LX9DQ0AB5eXmMHTsWGRkZTE5n3rx5cHV1ZVQe+vr6sLa2xqBBg5gD8+HDh0hPT8fVq1eRkJCAdevWoba2lpGhA9IoE8nySNLT0xntakZGBi5evAiRSISHDx/iyJEjcHNzg0gkgpeXF06fPg0VFRUMGzYM+vr6mDlzJnx8fLBp0yYQERt4vCG6ffs25s+fj2nTpjHHLyAtnbh27RpCQkIQEhICOTk5lvLA+31CQkJYWgPP6seLNQLSSF1OTg7u3r0LBQUF5sx++vQpnJycMGDAAGRlZbEUg4qKCowaNQpt27Zl/Thw4EDcunULy5cvh7KyMtTV1ZGfn4/o6GgMGDAAAwYMQMeOHaGiooLw8HDExMQgOjoaeXl5mDRpEhYvXozMzEx89913WL9+Pe7fvw8vLy9MnToVurq6LIrUt29fxMbGvpUnJS8vz6hXKyoqUF5ejpcvX7JZ1YABA6ChoYHIyEhWknP37l306dMHBgYGjKupsbER4eHhuHr1Knx8fGBsbIwXL15g4cKFb+VT8eBTJAoKClBXV4eCggKWGsG/MIqKilBbW4vKykooKChgy5YtAKQz2JSUFJSVlWH+/PnvHTvAJzRCRNRVdjOfEZHcO9vUiKiKiF4Tkep72lElomrZ/mrvbJOTtY83Z0NNdWx8oBGysLDA9evXUVlZycjtXV1dkZqaykLIS5YsQVBQEBwcHDBmzBj4+vqioaGB5YV8++23bDbFcRxiY2NRV1eHOXPm4KuvvkJRUREjMRs7diz8/PygrKyM06dPAwA7zqJFi7Bv3z5kZGTgyJEjb9GHWltbo6SkBLm5udizZw9WrFiBuXPnYuvWrSgvL2ck9ZGRkXB0dESLFi0wd+7ct5YtvB9p8+bNOHLkCPLy8lBeXo68vDw4OTnBwcEBtra2bN8jR45AIpEgKSkJR48eZUWvfFGvv78/jh07hhUrVqBNmzZISkpCbm4ujh49CkA6+zp+/Dij6QgJCYFIJMLu3btRU1ODy5cv4969e6ivr0d4eDhSUlJQW1sLFxcXJgZZXV2NdevWITc3F+bm5ix6RSStNq+vr0dtbS1iYmIgEomYMeT9fMCvTtn9+/djzJgxjD/I3t6eGY43lzfNmjWDpaUl1q5dy5bLtra2SEpKwvr162FlZQUTExMQEVauXAkDAwP069cPP//8M5YtW4YtW7Zg1qxZ0NbWxs2bN5nRLi0tZcopPO+1vb09ysvLWTSKv7eGhobsGXvx4gXLE+Ppenn6jf379+PYsWNMSurSpUvo0aMHEhMTsXnzZhQWFiIvLw8qKir4+uuv4erqyjT0evXqhQcPHrCi1zed02/ej9/DpzRCtrKH/+hvbOdnKuPe08542X7Xf2M7P0ta1NTHxgcaoU6dOsHDwwOAVGlgwoQJjBQ8OTkZZ8+eZSUJgFQK+tixY+jUqRPjBAaAefPmQVNTE4sXL4a6ujo0NDQgJyeHOXPmYMKECWjevDkaGhpQW1vLquUdHBxY1EhBQQEcx8HZ2RmGhoawsrLC0qVLMXToUAwaNAhBQUHsWLW1tXj+/Dnz5fD+n7KyMjg4OEAkEiEkJITlCHEcB0tLSyxduhTDhg1jhbk8iouLWQkGb/gqKirYLKOmpgb9+/f/j2/HkSNH4ptvvkFxcTG7T/zy4OXLl2xWlpiYiHv37uHQoUMoKChA27Ztoaury97IYrGY5boQERYuXAhAOovgyfZ5PTVVVVVWSX/27Fm4u7vj6dOnOH78OBusy5cvh6OjI6Kjo5Gens6EKPnPqVOnkJCQgE2bNmHWrFls6cJrc/G+uCFDhmDNmjVYsWIFLl26hNraWoSFheH169eIjo5mZRMNDQ1stssv3x88eID58+ejpqbmLSZFQGoYeaL5adOmMUPp5OSEL7/8kimuvHz5EnFxcbh69SqKi4vx3XffobS0FHV1dZCTk2N85W+KHW7YsAFEhMWLF6Ourg4jR45kXEk2NjYsQZOP4Pn7+8PZ2RkHDhxAaGgoJk+eDGNj4/eOHeDTGiEXWWf98Bvbj8i2272nneWy/Q7/xvY1su17murYRLSEiOKIKE5PT++9N5Gv7ZoyZQorA5gzZw6uXbvGCKf4B9Pd3R0eHh5MME5LSwsrV65k+Ta8UYiPj8eCBQugqqqKrVu3QkFBAQ4ODmhsbGTRpNjYWKSlpSErKwuHDh1Ct27dMG7cODQ0NMDa2hqNjY2YMWMGjh07BisrK8yePRvz5s3D4sWLsWHDBnb+fBlIcXExFi5cCEVFRbRq1Qr/+Mc/sHHjRnTt2hVubm5MInjOnDkICwuDlpYWFixYgKlTp6K6uppppPNv/YyMDDg5OaGyspKRqGtrazMmv+fPnyM5ORndu3eHWCzGihUrMHjwYCxduhRisRjl5eW4c+cOhg4diu7du2Pw4MGYPn06q9UaOXIkxo8fj7q6Opw4cYLVT12+fBnjxo1jFBm1tbVoaGjA3bt32TKHiLBgwQI4ODgAkA72W7dusftfWVmJe/fuMSbKI0eOIDc3F1OmTAHJwtZZWVm4ffs2Tp8+jVu3bqFnz56wtLREREQEioqKoKKiAgUFBSgoKDABSz7FgQ9C1NfXIzExEV999RWePHkCNzc3FBQUMEFFZ2dnpKamori4GI2NjfD19cWTJ09w/PhxhIaGom/fvhg6dCiOHz+OxsZGiMViVrfG38O8vDzs3LkTHh4e+Pnnn2FmZoYFCxagrKwMN2/exKFDh9CzZ0/cu3cPEokEhw4dgpWVFTiOY6KGxsbGUFJSwtGjR3Hv3j2kpKQwfxoAJle1detWaGhowNDQkKV1vA9/xAhxsoH6u+A4zpOIFhPRYgDH/8N2JyLaSEQbAez6nXY2EpETETkB2Pwfti8mIk8i8gSwtCmPTURkbGyMuLi439uFHj16RKtWraLly5dTamoqtWzZkgYPHkylpaVUXV1Nr169IkVFRQoPD6e2bdvS+PHjSVVVlebOnUvz58+nO3fuUFFREa1cuZKePXvGiO579epFPXr0oJiYGGrRogX16dOHcnNzqa6ujjp06EBFRUVUW1tLw4cPp+zsbHr48CENHjyYiIiUlZVJUVGR8vLyKDExkYyMjCgqKopatmxJ6enpxHEcGRkZUV1dHVVVVVGrVq1YxXxBQQG5ubnR2LFjSUlJidq3b0+VlZVUWVlJenp69OTJE8rPzydlZWXS0dEhZWVl6tq1KxUVFZG8vDxduXKFevToQdbW1pSSkkJt2rQhRUVFunLlCsnLy1PHjh3p2bNnJJFIyNTUlIKCgkhLS4uSk5OppKSEjIyMqH379tSrVy9SU1Oj+/fvk1gsJolEQs2bN6eUlBSaNWsW9e3bl54/f07y8vKUnJxMHTt2pJycHDI0NKS2bdtSVFQUaWlp0Z49e8jS0pKGDx9Ofn5+pK6uTtXV1VRUVERmZmakq6tLZ8+epdLSUtLU1CRLS0sqKioiVVVVKi0tpYqKCtLW1qZ+/fpRWVkZBQQEkK6uLpmYmFBAQAClpaVRt27d6NWrV3Tt2jWysrKiESNGUHJyMrVq1Yri4+PJyMiIvvzyS4qJiSEdHR1KTU0ldXV1SkhIoJCQENq9ezdFRUVRXl4ezZ49m0JCQqh3796UlJTESPujo6MpODiYWrduTQCoS5cuVFNTQzY2NpSamkqGhoZ05swZateuHcXGxpKhoSF169aNtm3bRp06daK1a9dSVlYWPXr0iKZPn07y8vIUFBREioqKVF9fT3369KFmzZpRY2MjpaSk0ODBg+nevXtUWlpKwcHB1LlzZzI3N6f09HQaNmwYJSQkUMuWLamkpIRqa2tp0KBBNGHCBAoMDCQ5OTnq3LkzTZgw4XfHjmw8xgMwfu+Ob+JDLBVJDQOIyPY3tjvLtq9/TzsbZfvt/I3tS+gdR3NTHRsfuBwTIEDAHwd9QsmfCtnfVr+xveU7+zVlO011bAECBPwJ8aFGKE32t8dvbO8u+5v+CdppqmMLECDgT4gPNUI3ZX8nchz31m84jlMjohFEVENE0e9pJ1q23wjZ795sR46IJr5zvKY8tgABAv6E+CAjBCCTiH4hos4kjXC9CUeS5v+cBvCa/5LjuF4cx/V6p50qIjoj23/bO+2skLV/HcDT/+bYAgQI+Ovgg6JjREQcx3UjojtE1I6I/IkolYiGEJEpSZdCwwGUvLE/iIgAcO+000bWTg+Sll7EEJEBEU0lokJZO5n/zbF/Cx8SHRMgQMAfxx+Jjn2wFr3MMBgT0UmSGoAfSFrTdYiIhn2IEZC1U0JEw2S/05e1M4SIfiKige8aoKY8tgABAv58+OCZ0N8BwkxIgIBPi086ExIgQICAT4H/qZkQx3FFRPT8A3bVJKLiT3w6Aj4MQl/8OfCh/dAJQNuPafh/ygh9KDiOi/vYKaWATwOhL/4c+JT9ICzHBAgQ8FkhGCEBAgR8VghG6D/j47S0BXxKCH3x58An6wfBJyRAgIDPCmEmJECAgM8KwQgJECDgs0IwQgIECPis+J8wQhzH6XAcd4LjuDyO4+o4jsviOO4Ax3GtP7IdDdnvsmTt5Mna1flU5/53QlP0A8dxtziOw+98mn/Ka/irg+O4GRzHHeY4LoLjuFeye3b2D7bVJONK4Y8c/K+E/1CB/5iIBhPRSiIy5zhuxIcUwP6H6v/zRNSLiBYS0SSO44a9SUEi4G00VT+8Acff+L7hvzrRvz82E1F/kkpl5ZL0Gf5oNGl/fiwf7F/tQ59RtFH4fJJ+uCV9bD//Nf0VPySlv+lORBwRjZHd+7Ofqz+BD1Tb+KuC47iuRJRJUt36bgAkb2xTI6J8knZGO/wOKRrHcapEVEREEiLSBlD5xjY52TE6y44hzIbeQVP1g2z/W0Q0Gu/wVAn4eHAcN4akzKXnAMz9iN81WX8S/f19QmNlf39580YREckMSRQRqRDR0Pe0M4yIlIko6k0DJGtHQlLmRyLpW0bAv6Op+oGB4zgbjuPWcxy3muM4C47jlJrudAW8B03an393I9RT9ve3SPAzZH9/i0S/qdv5X8WnuH/niWgXEe0joiAiyuY4bsYfOz0BH4km7c+/uxHiZYJ+Sw6I/179/6md/1U05f3zJ6IpRKRD0tlpL5IaI3UiusBxnMV/cZ4CPgxNOh7+9tGx94D3K/y3jrGmaud/FR98/wC4vvNVGhFt5Dguj4gOk1QM819Ne3oCPhIfNR7+7jOhzynaKOBX/H/cv+MkDc8PeFdOSkCTo0n78+9uhD6naKOAX/HJ7x+AWiLigwaqf7QdAR+EJu3Pv7sR+pyijQJ+xScXsOQ4ricRtSapIRLoYD8tmrQ//9ZGCJ9RtFHAr2iqfuA4rivHcR3fbZ/jOE2SSkYREZ0HIGRNNwE4jmsm64dub37/R/rzd4/zd05WJPq8oo0CfkVT9APHcQtI6vsJJ2myXCkR6RGRJUn9E3FENAFA+ae/or8mOI6zIiIr2b9aRGRGRE+JKEL2XTGANbJ9OxPRMyJ6DqDzO+00iSApEf39yzZkRlaXpG/KfCKqJ6nixkEi0vgP+4J+oyyAiDRkv3suayefiE4Qkc7nvsa/wue/7Qci6ktSAcyHRFRCRGKSGqIIIvqWiBQ/9zX+2T8kncnjdz5Zb+zb+d3v/mh//t7nbz8TEiBAwJ8bf2ufkAABAv78EIyQAAECPisEIyRAgIDPCsEICRAg4LNCMEICBAj4rBCMkAABAj4rBCMkQICAzwrBCAkQIOCzQjBCAgQI+Kz4P5V3O04twVfmAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "name = class_names2[2]\n",
    "fig, ax = plt.subplots()\n",
    "sc = ax.scatter(data2['x0'].values, data2['x1'].values, c=data2[name].values, cmap = 'Greys', s = 1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path3+'{}.jpeg'.format(name), bbox_inches='tight',pad_inches = 0)\n",
    "\n",
    "plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "from evaluations import MAE_pd \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "ite_column = 'ITE-GDBR'\n",
    "\n",
    "for clust2 in class_names2:\n",
    "    data2 = data2.groupby(clust2).apply(lambda x: MAE_pd(x, 'C', ite_column, clust2+'-err-GDBR'))\n",
    "    \n",
    "errors = data2.describe().loc[['mean', 'std'], [col for col in data2.columns if 'err' in col]].T\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Appendix B. Error Table. (column: BOX, row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "mean    0.065\n",
       "std     0.198\n",
       "Name: Kmeans2-Cl2-err-GDBR, dtype: float64"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors.sort_values(by = 'mean').round(3).iloc[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Appendix B. Error Table. (column: KMEANS, row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "mean    0.078\n",
       "std     0.214\n",
       "Name: Box2-Cl2-err-GDBR, dtype: float64"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors.sort_values(by = 'mean').round(3).iloc[1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 1, Main text (column: Bayes Optimal/Subpopulations, row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "mean    4.020\n",
       "std     1.253\n",
       "Name: ITE-2CGDBR-err-GDBR, dtype: float64"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors.sort_values(by = 'mean').round(3).iloc[2]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 1, Main text (column: Bayes Optimal/Raw-ITE, row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mean: 4.039\n",
      "std: 3.057\n"
     ]
    }
   ],
   "source": [
    "print('mean:',round(np.mean(np.abs(data['C'] - data['ITE-GDBR'])),3)), \n",
    "print('std:',round(np.std(np.abs(data['C'] - data['ITE-GDBR'])),3))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 2, Main text (columns: Bayes Optimal, row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ITE-2CGDBR\n",
       "0   -3.414637\n",
       "1    1.000836\n",
       "2    5.414677\n",
       "Name: ITE-GDBR, dtype: float64"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data2.groupby('ITE-2CGDBR').mean()['ITE-GDBR']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "from evaluations import confusion_matrix\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Confusion matrices not depicted fro 2M in the paper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Box2-Cl2\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>C0 Pred</th>\n",
       "      <th>C1 Pred</th>\n",
       "      <th>C2 Pred</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>C0 True</th>\n",
       "      <td>0.962253</td>\n",
       "      <td>0.037747</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C1 True</th>\n",
       "      <td>0.052545</td>\n",
       "      <td>0.902869</td>\n",
       "      <td>0.044586</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C2 True</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.025710</td>\n",
       "      <td>0.974290</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          C0 Pred   C1 Pred   C2 Pred\n",
       "C0 True  0.962253  0.037747  0.000000\n",
       "C1 True  0.052545  0.902869  0.044586\n",
       "C2 True  0.000000  0.025710  0.974290"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kmeans2-Cl2\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>C0 Pred</th>\n",
       "      <th>C1 Pred</th>\n",
       "      <th>C2 Pred</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>C0 True</th>\n",
       "      <td>0.974049</td>\n",
       "      <td>0.025951</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C1 True</th>\n",
       "      <td>0.057096</td>\n",
       "      <td>0.920788</td>\n",
       "      <td>0.022117</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C2 True</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.028910</td>\n",
       "      <td>0.971090</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          C0 Pred   C1 Pred   C2 Pred\n",
       "C0 True  0.974049  0.025951  0.000000\n",
       "C1 True  0.057096  0.920788  0.022117\n",
       "C2 True  0.000000  0.028910  0.971090"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ITE-2CGDBR\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>C0 Pred</th>\n",
       "      <th>C1 Pred</th>\n",
       "      <th>C2 Pred</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>C0 True</th>\n",
       "      <td>0.537878</td>\n",
       "      <td>0.076474</td>\n",
       "      <td>0.385648</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C1 True</th>\n",
       "      <td>0.461399</td>\n",
       "      <td>0.078581</td>\n",
       "      <td>0.460020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C2 True</th>\n",
       "      <td>0.382132</td>\n",
       "      <td>0.078096</td>\n",
       "      <td>0.539771</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          C0 Pred   C1 Pred   C2 Pred\n",
       "C0 True  0.537878  0.076474  0.385648\n",
       "C1 True  0.461399  0.078581  0.460020\n",
       "C2 True  0.382132  0.078096  0.539771"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.display import display\n",
    "\n",
    "path4 = path_figs+'matrices/'\n",
    "Path(path4).mkdir(exist_ok = True)\n",
    "for name in class_names2:\n",
    "    mat = confusion_matrix(data2, 'C', name, 3, save = True, save_dir = path4)\n",
    "    print(name)\n",
    "    display(mat)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:jorje]",
   "language": "python",
   "name": "conda-env-jorje-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
