{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# VAE Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import lightning as L\n",
    "from torch.utils.data import DataLoader\n",
    "from vae import gauss_cb_VAE, gauss_beta_VAE, gauss_ks_VAE, ks_cb_VAE, ks_beta_VAE, ks_ks_VAE, beta_cb_VAE, beta_beta_VAE, beta_ks_VAE\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torchvision.utils as vutils\n",
    "from torchvision.utils import make_grid\n",
    "from einops import rearrange\n",
    "\n",
    "from sklearn.manifold import TSNE\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "from sklearn.metrics import accuracy_score\n",
    "\n",
    "from scipy.stats import truncnorm\n",
    "\n",
    "from kumaraswamy import KumaraswamyStable\n",
    "from vae import MNISTDataModule, CIFAR10DataModule\n",
    "\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "from config import DATA_DIR, PROJECT_ROOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load pytorch lightning model\n",
    "variational_posterior = 'ks' # 'gaussian' 'ks'\n",
    "likelihood = 'ks' # 'cb' 'beta' 'ks'\n",
    "dataset = 'mnist' #'cifar10' 'mnist'\n",
    "\n",
    "\n",
    "path_to_project = PROJECT_ROOT + '/experiments/vae/'\n",
    "path_to_models = path_to_project + 'trained_models/'\n",
    "\n",
    "def load_model(variational_posterior, likelihood, dataset, path_to_models):\n",
    "    model_path = path_to_models + f\"{dataset}_{variational_posterior}_{likelihood}.ckpt\"\n",
    "    print(f\"Loading: {model_path}\")\n",
    "\n",
    "    if variational_posterior == 'gaussian':\n",
    "        if likelihood == 'cb':\n",
    "            model_class = gauss_cb_VAE\n",
    "        elif likelihood == 'beta':\n",
    "            model_class = gauss_beta_VAE\n",
    "        elif likelihood == 'ks':\n",
    "            model_class = gauss_ks_VAE\n",
    "    elif variational_posterior == 'ks':\n",
    "        if likelihood == 'cb':\n",
    "            model_class = ks_cb_VAE\n",
    "        elif likelihood == 'beta':\n",
    "            model_class = ks_beta_VAE\n",
    "        elif likelihood == 'ks':\n",
    "            model_class = ks_ks_VAE\n",
    "    elif variational_posterior == 'beta':\n",
    "        if likelihood == 'cb':\n",
    "            model_class = beta_cb_VAE\n",
    "        elif likelihood == 'beta':\n",
    "            model_class = beta_beta_VAE\n",
    "        elif likelihood == 'ks':\n",
    "            model_class = beta_ks_VAE\n",
    "\n",
    "    model = model_class.load_from_checkpoint(model_path)\n",
    "    return model\n",
    "\n",
    "model = load_model(variational_posterior, likelihood, dataset, path_to_models)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\"dataset\":       mnist\n",
      "\"hidden_dim\":    500\n",
      "\"keep_prob\":     0.9\n",
      "\"latent_dim\":    20\n",
      "\"learning_rate\": 0.001 \n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "model.eval()\n",
    "print(model.hparams, '\\n\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(DATA_DIR)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "if dataset == 'mnist':\n",
    "    dm_class = MNISTDataModule\n",
    "elif dataset == 'cifar10':\n",
    "    dm_class = CIFAR10DataModule\n",
    "\n",
    "dm = dm_class(batch_size=100, \n",
    "              clamp_extreme_pixels=(likelihood in ['beta', 'ks']), \n",
    "              data_dir=DATA_DIR, \n",
    "              num_workers=0) # must be 0 in jupyter notebook\n",
    "\n",
    "# setup\n",
    "dm.prepare_data()\n",
    "dm.setup('fit')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_dataloader = dm.train_dataloader()\n",
    "val_dataloader = dm.val_dataloader()\n",
    "test_dataloader = dm.test_dataloader()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def likelihood_mean(likelihood_params, likelihood):\n",
    "    if likelihood == 'cb':\n",
    "        lambda_logit = likelihood_params\n",
    "        x_hat_mean = torch.distributions.ContinuousBernoulli(lambda_logit).mean\n",
    "    elif likelihood == 'beta':\n",
    "        alpha, beta = likelihood_params\n",
    "        x_hat_mean = torch.distributions.Beta(alpha, beta).mean\n",
    "    elif likelihood == 'ks':\n",
    "        log_a, log_b = likelihood_params\n",
    "        x_hat_mean = KumaraswamyStable(log_a, log_b).sample((100,)).mean(dim=0) # mean function numerically unstable\n",
    "    \n",
    "    return x_hat_mean"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Objective Evaluation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Compute the test elbo, test KL divergence, and test reconstruction loss\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_outputs, test_outputs = [], []\n",
    "\n",
    "for batch in train_dataloader:\n",
    "    model.shared_step(batch, None, 'train', train_outputs)\n",
    "\n",
    "for batch_idx, batch in enumerate(test_dataloader):\n",
    "    model.shared_step(batch, batch_idx, 'test', test_outputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: mnist, Variational Posterior: ks, Likelihood: ks\n",
      "** Train: ks **\n",
      "\tELBO:  3374.66455078125  pm  206.57672119140625\n",
      "\tlog prob data:  3407.094482421875  pm  202.35958862304688\n",
      "\tKL:  32.43021011352539  pm  4.862762928009033\n",
      "** Test: ks **\n",
      "\tELBO:  -37863.86328125  pm  4122279.75\n",
      "\tlog prob data:  3399.646484375  pm  251.93714904785156\n",
      "\tKL:  41263.515625  pm  4122159.75\n"
     ]
    }
   ],
   "source": [
    "#elbo = [output['elbo'] for output in train_outputs]\n",
    "#log_prob_data = [output['log_prob_data'] for output in train_outputs]\n",
    "#kl = [output['kl'] for output in train_outputs]\n",
    "\n",
    "def print_metrics(outputs, split):\n",
    "    elbo = [output['elbo'] for output in outputs]\n",
    "    log_prob_data = [output['log_prob_data'] for output in outputs]\n",
    "    kl = [output['kl'] for output in outputs]\n",
    "    print(f\"** {split}: {likelihood} **\")\n",
    "    print('\\tELBO: ', torch.stack(elbo).mean().item(), ' pm ', torch.stack(elbo).std().item())\n",
    "    print('\\tlog prob data: ', torch.stack(log_prob_data).mean().item(), ' pm ', torch.stack(log_prob_data).std().item())\n",
    "    print('\\tKL: ', torch.stack(kl).mean().item(), ' pm ', torch.stack(kl).std().item())\n",
    "\n",
    "print(f\"Dataset: {dataset}, Variational Posterior: {variational_posterior}, Likelihood: {likelihood}\")\n",
    "print_metrics(train_outputs, 'Train')\n",
    "print_metrics(test_outputs, 'Test')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### KNN Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_latent_gaussian_representations(model, variational_posterior, dataloader):\n",
    "    model.eval()\n",
    "    latents = []\n",
    "    labels = []\n",
    "    with torch.no_grad():\n",
    "        for x, y in dataloader:\n",
    "            x = x.view(x.size(0), -1)\n",
    "            if variational_posterior == 'gaussian':\n",
    "                mu, log_var = model.encode(x)\n",
    "                latents.append(mu)\n",
    "            elif variational_posterior == 'ks':\n",
    "                log_a, log_b = model.encode(x)\n",
    "                latents.append(KumaraswamyStable(log_a, log_b).sample((1000,)).mean(dim=0))\n",
    "            else:\n",
    "                raise ValueError(f\"Variational posterior {variational_posterior} not supported\")\n",
    "            labels.append(y)\n",
    "    latents = torch.cat(latents).cpu().numpy()\n",
    "    labels = torch.cat(labels).cpu().numpy()\n",
    "    return latents, labels\n",
    "\n",
    "\n",
    "def compute_knn_accuracy(model, variational_posterior, train_dataloader, test_dataloader, k=15):\n",
    "    L.seed_everything(0)\n",
    "    train_latents, train_labels = extract_latent_gaussian_representations(model, variational_posterior, train_dataloader)\n",
    "    test_latents, test_labels = extract_latent_gaussian_representations(model, variational_posterior, test_dataloader)\n",
    "    \n",
    "    knn = KNeighborsClassifier(n_neighbors=k)\n",
    "    knn.fit(train_latents, train_labels)\n",
    "    test_preds = knn.predict(test_latents)\n",
    "    \n",
    "    accuracy = accuracy_score(test_labels, test_preds)\n",
    "    return accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "knn_accuracy = compute_knn_accuracy(model, variational_posterior, train_dataloader, test_dataloader)\n",
    "print(f'KNN {likelihood} Accuracy: {knn_accuracy}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Subjective Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_latent_grid(model, latent_size: int, grid_size: int, dim1: int, dim2: int, fixed_value: float = 0.0, max_z: float = 3.0) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    Generate a grid of latent vectors by varying two specified dimensions and fixing the rest.\n",
    "    \"\"\"\n",
    "    arr = []\n",
    "    for i in range(grid_size):\n",
    "        z1 = (((i / (grid_size - 1)) * max_z) * 2) - max_z\n",
    "        for j in range(grid_size):\n",
    "            z2 = (((j / (grid_size - 1)) * max_z) * 2) - max_z\n",
    "            z = torch.tensor([fixed_value] * latent_size, device=model.device, dtype=torch.float32)\n",
    "            z[dim1] = z1\n",
    "            z[dim2] = z2\n",
    "            likelihood_params = model.decode(z.view(1, -1))\n",
    "            x_hat_mean = likelihood_mean(likelihood_params, likelihood)\n",
    "        \n",
    "            decoded = x_hat_mean.view(1, 1, 28, 28)\n",
    "            arr.append(decoded)\n",
    "    return torch.cat(arr)\n",
    "\n",
    "def plot_latent_grid(latent_grid: torch.Tensor, grid_size: int):\n",
    "    \"\"\"\n",
    "    Plot a grid of images from the latent space.\n",
    "    \"\"\"\n",
    "    imgs = rearrange(make_grid(latent_grid, grid_size), \"c h w -> h w c\")\n",
    "    imgs = imgs.cpu().detach().numpy()\n",
    "    plt.imshow(imgs)\n",
    "    plt.axis(\"off\")\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "# Parameters\n",
    "latent_size = 20  # The latent dimension of your VAE\n",
    "grid_size = int(5)     # The number of images per row/column in the grid\n",
    "max_z = 4   # The range of latent space\n",
    "fixed_value = 0.0\n",
    "\n",
    "# Generate and plot the grid\n",
    "latent_grid = generate_latent_grid(model, latent_size, grid_size, 0, 10, fixed_value, max_z) #grid_size, max_z)\n",
    "plot_latent_grid(latent_grid, grid_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_from_gaussian_latent_space(self, num_samples=5, seed=0):\n",
    "    L.seed_everything(seed)\n",
    "    self.eval()\n",
    "    \n",
    "    # Define the range for the truncated normal distribution\n",
    "    lower, upper = -2, 2\n",
    "    mean, std = 0, 1\n",
    "    \n",
    "    # Sample from the truncated normal distribution\n",
    "    z = truncnorm.rvs(lower, upper, loc=mean, scale=std, size=(num_samples, self.hparams.latent_dim))\n",
    "    z = torch.tensor(z, dtype=torch.float32).to(self.device)\n",
    "    #z = torch.randn(num_samples, self.hparams.latent_dim).to(self.device)\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        likelihood_params = self.decode(z)\n",
    "        x_hat_mean = likelihood_mean(likelihood_params, likelihood)\n",
    "\n",
    "    samples = x_hat_mean.view(-1, 1, 28, 28).cpu()\n",
    "    grid = vutils.make_grid(samples, nrow=num_samples, padding=2, normalize=True, value_range=(0, 1))\n",
    "    plt.figure(figsize=(num_samples, 2))\n",
    "    plt.imshow(np.transpose(grid, (1, 2, 0)))\n",
    "    plt.axis('off')\n",
    "    plt.show()\n",
    "\n",
    "def sample_from_unit_cube_latent_space(self, num_samples, seed):\n",
    "    L.seed_everything(seed)\n",
    "    self.eval()\n",
    "\n",
    "    # sample from unit cube in R^{self.hparams.latent_dim}\n",
    "    z = torch.rand(num_samples, self.hparams.latent_dim).to(self.device)\n",
    "    z = torch.tensor(z, dtype=torch.float32).to(self.device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        likelihood_params = self.decode(z)\n",
    "        x_hat_mean = likelihood_mean(likelihood_params, likelihood)\n",
    "    \n",
    "    samples = x_hat_mean.view(-1, 1, 28, 28).cpu()\n",
    "    grid = vutils.make_grid(samples, nrow=num_samples, padding=2, normalize=True, value_range=(0, 1))\n",
    "    plt.figure(figsize=(num_samples, 2))\n",
    "    plt.imshow(np.transpose(grid, (1, 2, 0)))\n",
    "    plt.axis('off')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "sample_from_gaussian_latent_space(model, num_samples=7, seed=10)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Viz. Latent Space in the plane"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_loader = DataLoader(mnist_test, batch_size=500, num_workers=0)\n",
    "latents = []\n",
    "labels = []\n",
    "\n",
    "for batch in test_loader:\n",
    "    x, y = batch\n",
    "    x = x.view(x.size(0), -1).to(model.device)\n",
    "    with torch.no_grad():\n",
    "        mu, _ = model.encode(x)\n",
    "        latents.append(mu.cpu().numpy())\n",
    "        labels.append(y.numpy())\n",
    "    \n",
    "latents = np.concatenate(latents, axis=0)\n",
    "labels = np.concatenate(labels, axis=0)\n",
    "\n",
    "print('latent shape: ', latents.shape, '. labels: ', labels.shape)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tsne = TSNE(n_components=2)\n",
    "latents_2d = tsne.fit_transform(latents)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10, 10))\n",
    "scatter = plt.scatter(latents_2d[:, 0], latents_2d[:, 1], c=labels[:len(latents_2d)], cmap='tab10')\n",
    "plt.colorbar(scatter)\n",
    "plt.title('Latent Space Visualization')\n",
    "plt.xlabel('t-SNE Component 1')\n",
    "plt.ylabel('t-SNE Component 2')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Create Unified Figure Comparing reconstruction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "dm = MNISTDataModule(batch_size=100, \n",
    "                     clamp_extreme_pixels=(likelihood in ['beta', 'ks']), \n",
    "                     data_dir=DATA_DIR, \n",
    "                     num_workers=0) # must be 0 in jupyter notebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# setup\n",
    "dm.prepare_data()\n",
    "dm.setup('fit')\n",
    "test_dataloader = dm.test_dataloader()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1000 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# iterate through test data loader and find the first instance of each digit\n",
    "first_instance = {}\n",
    "for batch in test_dataloader:\n",
    "    x, y = batch\n",
    "    for i in range(len(y)):\n",
    "        if y[i].item() not in first_instance:\n",
    "            first_instance[y[i].item()] = x[i]\n",
    "            if len(first_instance) == 10:\n",
    "                break\n",
    "    if len(first_instance) == 10:\n",
    "        break\n",
    "\n",
    "# create batch of images and labels\n",
    "images = torch.stack(list(first_instance.values()))\n",
    "labels = torch.tensor(list(first_instance.keys()))\n",
    "\n",
    "# sort labels by digit\n",
    "_, indices = torch.sort(labels)\n",
    "images = images[indices]\n",
    "labels = labels[indices]\n",
    "\n",
    "first_instance_batch = (images, labels)\n",
    "\n",
    "\n",
    "# plot the first instance of each digit\n",
    "plt.figure(figsize=(10, 10))\n",
    "for i in range(10):\n",
    "    plt.subplot(1, 10, i + 1)\n",
    "    plt.imshow(first_instance[i].view(1, 28, 28).squeeze().cpu().numpy(), cmap='gray')\n",
    "    plt.axis('off')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each model, reconstruct the first instance of each digit\n",
    "variational_posteriors = ['gaussian', 'ks']\n",
    "likelihoods = ['ks', 'cb', 'beta']\n",
    "images = {f'{var_post}-{likelihood}': None for var_post in variational_posteriors for likelihood in likelihoods}\n",
    "\n",
    "for likelihood in likelihoods:\n",
    "    for variational_posterior in variational_posteriors:\n",
    "        model = load_model(variational_posterior, likelihood, dataset, path_to_models)\n",
    "        model.eval()\n",
    "        with torch.no_grad():\n",
    "            x, y = first_instance_batch\n",
    "            x = x.view(x.size(0), -1).to(model.device)\n",
    "\n",
    "            clamp_pixel_values = likelihood in ['beta', 'ks']\n",
    "            if clamp_pixel_values: \n",
    "                x = torch.clamp(x, .5 * (1/255), 1 - (.5 * (1/255)))\n",
    "\n",
    "            likelihood_params, _, _ = model(x)\n",
    "            x_hat_mean = likelihood_mean(likelihood_params, likelihood)\n",
    "            x_hat_mean = x_hat_mean.view(len(x), 28, 28)\n",
    "            images[f'{variational_posterior}_{likelihood}'] = x_hat_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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CQkJGI1GzGbzqLjF8ePH861vfYv4+Hg+//xziouLL/qsTCZj3bp1xMXFSZr04RyoPj4+XH/99dx2221ERETw0Ucf8eGHH46prkCEVqvFx8dHWqufffYZcJap0Ov1TJ8+nTfeeIOwsDBcLhfNzc2cOXMGg8HA+PHjSUtL49prr+Wzzz4bsf25IAh0dnZK+3agZYlMJuNb3/oW0dHRNDU18eWXX46YCwbo6+ujpqYGu92OSqVizZo1vPjii4PWilwuR6PREB0dzX333ce1116LUqmUOP/hICAggLi4OFwuF5988gl33nknOp2OtWvX8vTTT5OUlERgYCDPP/88999/PydPnvSYWGLMibAod62trWXGjBmS/eYDDzzAjTfeyIQJE0hISGD69OnSb9asWcNbb71FZmYma9euJTo6mhdeeAGFQoHL5eK///u/R0SA4f8WrdFoBMBisfD5559z//33n8eVNTU18dprrxEREUFGRgbLli2jra2NY8eOSRzPaCGTyZgwYQIAL730kkfkwRdCaGgor7/+OgsWLEAQBDZs2MCvfvUrj4g+ysrKaGlpITAwkOTkZNLT0/nP//xPlEoly5cvv+Bv1qxZQ01NDZ988gnV1dVYrdYRceNpaWlkZ2fT1NR0Hnd4LqKjo1mxYgUhISG8++677N+/f1gHwNSpU/nud79Lamoq//jHP3jmmWe+MjvyzMxMFi5ciMPh4ODBg8DZtRwdHc29997Lf/7nf+J2u2loaODDDz/kH//4B0VFRdhsNm655RZ++tOfEhoaSmBgoEecgM5FUFAQjz32GGlpafz9739n165do7ox1tbW8uqrrxIbG8ttt93GY489xp49e8jLywPO7pvExETuvPNObr/9dulWW1VVxcaNG3nllVeG1Z5CoUCj0dDc3CzpFPr7+9mwYQO33XYbCQkJKBQKLBYLNpvNszbKwhjizjvvFP7yl7+MZRMXBHDREhAQIPzsZz8TnE6n0NXVJWzevFmIjIy86PNhYWHCSy+9JDQ3Nwsul0vYsGGDEBYWdsk2hlpkMpkwY8YMob29XThx4oQQFBTkkXrPLSqVSsjOzhba2toEl8slNDc3CwkJCR6rX6fTCXPmzBGysrKEoKAg4e677xZ6enoEt9t92WK1WoUXX3xRyMzMFNRq9bDa1Wq1wpNPPim0t7cLH3/88WWff+yxx4T6+nqhqqpKWLNmzbDH+dBDDwkFBQVCQUGB8OCDD47Ju7pYWb16tZCTkyPk5uYKt9xyiwAIer1eePnllwW32y24XC5hx44dQlZWlqBSqQb99pprrhG2b98ufPnll0J6evqY9O/RRx8VGhoahJ6eHuGnP/2pEBwcPOo6FQqFkJaWJhw5ckRwu93CyZMnBZ1OJ8TFxQnLli0TCgsLBbvdLrjdbqGtrU3YunWr8J3vfEfQarXDbmvZsmXCwYMHhebmZuHXv/619LlMJhNaWloEl8slCIIgvPjii5ekF+eWoeDf0k54rCGTyZDL5RQWFrJq1aohPSuWqVOncsstt/CHP/xh1P2Qy+UsWbKEgIAAtm/fPmZcVVJSEn/7298kbfLbb79NeXm5x+rv7+9n//790t9bt27F6XSybNkyQkJCWLp06UV/q1arefDBB1mzZg0bN27kD3/4g2SGdDmoVCr8/f1pa2tj3759l30+JiYGjUZDaWnpiMwA586dS1xcHEqlkjvuuANBENi9ezclJSXDrmu48PX1xWQySRyYSqUiNTWVm266CYBXXnmFRx999KLcZ1tbG83NzZcU14wU06dP59FHHyUsLIwnnniCN9980yP2yy6Xi6KiIm688Ua2bdvGpEmTOHHiBOHh4fj6+gLQ1dXFxx9/zKuvvsqxY8dGfLMrKytj7969ZGRkkJWVRVpaGhMmTOD6668nICCArq4uTCYTt9xyCzt27GDHjh0esx0eUyL8xhtvjGX1I0JWVhZz5szB7XYP6UoxZ84cZsyYQUBAAG63m2PHjvHuu+96pC8ymYyJEycC8PHHH3vc9AXOiiGWLVtGeno6TqeTPXv28Mtf/tLj7QxES0sLGzZsYOPGjSgUCmnDhISEIAgCbW1tCILAvffey5133kl8fDwhISGsXbsWQRB46aWXLmuLCmeVuTU1NVgsFknG3NPTc8FnAwMDWblyJQEBARQWFo5IaWQ0GiUl9PTp08nOzqaxsZGNGzeSm5tLREQEFRUVkiljSkoKZ86coba2dtTvVq1Wo9VqpYPa19eX++67D6PRyMaNG/ne9753UX2CRqNBrVbjcDg8qssQsWTJEoxGI8eOHSMnJ8ejSklRDi+ayyUnJyOTyWhubuapp55ix44dNDc3S7bZI0V9fT3Hjx9HEAQWL14sKVvlcjm7d+/mkUce4a233iI9PZ1bb72VkpISj5msXnWcsCizvBwCAgKIj4/noYcekkxxLBYLXV1dHnE0kMlkhIaGMnv2bEpLS9myZYvHibBGo2HSpEnccccdqFQqrFYrZ86cGTO5swiVSkVQUBDBwcGcOXOGtrY2ACk2hbhZXnjhBXbs2CEZx0dFRfHtb38bp9PJT3/608u243A4aG1txel0smbNGvz8/HjvvfcGPZOWlkZcXBzR0dEEBQVJ1jAjkelt3bqVuLg40tPTkclkKJVKIiMj+eEPf4jT6UQul+N2uyViqFAoaG1t5dixYzz33HOcOXNm2G0OxEAio1AoCA8PB87aD1+MAPv6+jJ79mwmTpzIsWPHRtX+haDRaFi4cCFKpZJXX32VoqKiUctLIyIiWLJkCWvXrmX+/PloNBo0Gg0ymUyyrnr99df517/+RXt7u0esiWw2G3v37uX//b//xzPPPIPBYMDlcvH3v/+dn/3sZ3R2dvLJJ58QHx/P9OnTycjIoLq62jPcsOclslceXEJG84Mf/EBobGwUnE6ncODAgYs+98QTTwhFRUVCX1+f4HA4hLa2NuHll18WpkyZIsjl8lHLuzQajfDII48ITqdT2Lhxo6BQKDwup8vMzBRee+01wWazCX19fcIHH3wwLHnWSEpkZKTw0EMPCUeOHBGOHj0qLFiw4JLPq1QqITw8XHj22WeFtrY2wWq1Cjk5OcK0adOG1F5UVJTw0EMPCQcPHhQ6OjqEpqamQaWsrEyorKwUenp6BKfTKbhcrhHLDY1GozB9+nThpZdeEqqrqyVZ4aVk3k6nU+jp6RH+8pe/CGlpaSOe13vvvVcoKyuTZMIqlUrIysoSWltbBbPZLHzve98TAgICBJlMNuh33//+94X8/Hxh06ZNQmZmpsff9/e//33BbDYLBw4cEDIyMka8N/z8/IRVq1YJr732mlBQUCC0trYKFotFsFgswhdffCE8++yzwne+8x2huLhYcLlcQktLi5CRkeHRfSOXy4Xw8HDh3nvvFd59913h5ZdfFqKioqQ5DQkJETZs2CDpIGbMmHHZOoeCq44THgpeeOEF5syZQ0xMDGq1GjjrgXbkyBHy8/M9ohlVKBSSxnWs/P/T09NZuXIlKpWKlpYWfv3rX4+JZnwgtFot0dHRpKeno1Ao+P3vf8+dd94pabXPhcPhoKmpiXfffZeQkBDuuecekpKSWLduHUeOHLlse+JvDx8+zIQJEwgNDR30/eeff44gCPz85z9n+fLl6PV6enp6RiQ77Onp4eTJk9TV1fE///M/BAYGkpaWhslk4vbbbyclJeW838jlcnx8fMjIyCAkJGREQYwMBgNBQUEYDAZJ5utwOMjPz2fdunX84Q9/4Kc//alk197R0cGkSZO44YYbWLVqFe3t7WzatInCwsJht30pzJ49mx/96EcoFAreeOMN6urqRrQ3HnroIZYuXUpKSgrh4eHo9Xra2tr49NNP+fjjjykvL8dsNjNjxgxCQkKQyWQEBQURHR1NeXm5x+z23W43zc3NfPDBB+zYsQOXy0VDQ4PEabe2trJt2zZmz57N5MmTSUxM5MSJE6O+GV+VRFi81hiNRrKystBqtTzwwAOS3EkM8ahWq6Xrz0cffcS2bds8ZhOqVCqZM2cOgiBw4MCBMXHQGBg72O12Yzab8fHxGfSMxWLB5XIhl8vRarWSqU5ycjKTJk2SnrNarWzYsOGyC66xsZEdO3aQlpbGqlWrSEhIuKgTjghBEKTxi/M9VCLpdDrp6Oigu7ubioqKQY5D8H/OE/n5+SxevBg4e303GAwjukra7Xbq6+upr69HpVKRl5eHv78/MTExpKSk4HK52LFjB59//jnf+ta3mDt3LlqtFo1GMyIXaTg7F52dnfT09ODr60tycrIkXtq7dy/3338/S5Ys4cyZM2i1Wu666y6+/e1vk5KSQkVFBW+//bZH1y6clY//9Kc/JTo6mv3797Nnz56LyuMvB7VaTVpaGomJicjlcnp6eigqKuLEiROEhYWRlJREdHQ0s2fPlkxLzWazJIryJMR9ciHFrSAI7Nixg0WLFrF8+XLmzZvHmTNnRi1muuqIcFVVFSUlJQQHBxMZGclzzz2HQqFg5syZ6PV6AEm2JyI3N1cKUOQJKJVKkpKSSExMBM5y2WNBhAciICCA3/zmN+dxDUeOHKG9vR0fHx8mTJiAv7+/FChmYFAji8VCa2srn3zyySXbsVgsnDx5ko0bN5Kenk5UVBT33nsvKSkpbNu27TyFWGZmJjNnzmTatGnMmDEDmUyGy+UatkeS0+m8pMWDOG6ZTIbFYvGIXN/hcNDe3k5/fz979+7lgQceQCaTERcXR3h4OFFRURLh7evrG3GbTqeTnJwc0tLSWLNmDStXrqS7u5vdu3fT3d1NY2MjHR0dZGdns3btWiZOnEhAQAAHDx7kgw8+YO/evR69balUKh5//HEWLFhAR0cHr7/+OnV1dSN2NPr888+Ji4tj1apVkgWL6EJsNBoxGAz4+/sTGBgInCXAv/nNb6ioqBgTReOl0NzczIcffsjEiRNZsmQJBQUFVFZWjvgAgquQCBcUFHDkyBGysrLw9fXlmmuukQiuSAgFQaCvr4/29nZ2797N3r17PRq8R6fTMXfuXPR6PY2NjVRXV48JEe7q6qKhoYGYmBh8fHy44YYbznsmOzubnp4eNBoN48aNw2AwSPPR29tLZWUlra2t2Gy287joi6G7u5t9+/bxt7/9jSeeeIJVq1aRlZXFlClTzlOkpKamMmnSJKKiotDr9VitVsrKyjwW5/dcCIJAT0+PR6O42Ww2Tp48SX5+Punp6aSkpEhiGblcTlVVFTt27BhVlpGSkhI2bNiARqNhzZo1PPTQQ0ybNo2+vj7JcSEuLo6IiAiKiop48803+fzzzzl9+jRdXV0eG6sYN/mee+7BaDTy9ttvjzrCWFFREW+88QZlZWVkZ2cTExNDQEAASUlJ0jMOh4PGxkYKCgrYtWsX//jHPzCbzWPOvFwIBw8eZPv27axbt47Fixdz+vRp9u7dO+JD6KojwvX19ezZs4fExETpCnQhHDp0iN27d/PRRx9RW1vr0TB2RqORhQsXAnDgwAEqKys9VvdA5Ofns2HDBhYvXixd82UyGf7+/iQkJABnzajKy8vp6uqiqKiIlpYWWlpasFgs0rWwqakJl8s1ZNtit9tNY2Mjb775JoGBgWRlZTF+/HjuvvtutFrtoKBJomhIJPhFRUVs3bp1SHa/w4EY42As3MJdLhd1dXW8+uqrPPLIIwQHBxMXFyfFzRDdm4cbO3gg7HY7J0+e5JVXXsHhcDBp0iTS09NJSkqiuLgYQRDo6Ojg8OHD7Ny5k61bt0rvzVMQA0CtW7eO8PBwDh06xN/+9jdaWlpGrSc5ffo0JSUl7N69m3Hjxkk31YFtC4LAiRMn+PLLL69oTsSOjg4+/vhj0tPTmThxIosWLeLkyZMjDkF71RHh/v5+cnJyMJvNzJkzhxtuuIHIyEiCg4NpamqipqYGuVzOP/7xDzZt2uTxly2TydDpdMTHx9PQ0MAHH3wwZqd5QUEBf/3rXzlx4sSgYEcxMTHMnTtX+nv//v3SdbKsrIyysrJRm7EJgiDZci5YsIA5c+aQnJxMSEgI0dHRdHV1odPpcDqd9PT0UF1dzZkzZzh27BhHjx71eJCkcePGAVBaWjomJnp9fX28+eab+Pr6smDBAmJjYzl06BA7d+7kX//6l0fCrzocDk6dOsVzzz1HdnY2kZGRLFiwgB07dkjP7N69e8xyI2o0GqZNm8Zjjz0GwMsvv8yZM2c85sLb399PQUHBmGdg8QTy8vLYtm0bcXFxTJs2jZSUlBHf3mTCleDnxxhDzc9mMBiYPn06K1asYPr06ezbt0+KP1BdXU1zc/OY5LEKCwvj2Wefpa2tjV/84hdfSQCYfwcEBASg1+tZsWIFxcXFREZG0tPTQ0VFBXV1dfT09IxZAKOTJ0/idDp56623PJZE9WK49tprSU9P56233qK1tfUbkQtNzBzy7LPPcttttyEIAtOmTZMcHK5G+Pr68tOf/pQbb7yRd999l+eee+48MdeQ5sZTtrn/TsDDtpDe8vUvf/rTn4SlS5cKPj4+V7wvX8fi6+sr3HbbbUJfX58gCIJgt9uFKVOmnGeXfLWVNWvWCPv27RO2bdsmJCYmnvf9UHDViSO8uDrxwx/+8Ep34WsNHx8fJk2ahF6vx+FwkJubS3d391XLBYvYunUrer2elStXEhQUNCR3+3PhJcJeeOHFkOB0OrFYLJw6dYqVK1eOOiP4NwF2u50NGzawYcOGEddxVcuEvfDCCy/GEkMhr99ITvgbeK544YUX31DIr3QHvPDCCy+uZniJsBdeeOHFFYSXCHvhhRdeXEF8I2XCXsWcF1548e+Aq1Yx54UX31TIZDIUCgV6vZ6AgACsViv9/f1YrdZRp/jx4srAS4T/FwMD3IjBQr6O7qZyuRxBEFAoFJhMJhISEsjOzmbWrFno9XoptGJbWxtHjhzh+PHjlJSU0NPTg9vtHvUmHngL8RKEC0Oco+HOj0wmQ6/Xk5iYyKJFi5g4cSKBgYFS4Jvc3FwaGxtxOp3euf8awUuEOZvlIiwsjEWLFhEeHo7VaqW0tJQjR47Q3d39lSxqtVpNTEwMN910E52dnezZs4fKysphx5UQBAGlUklQUBATJ05k+vTpxMXFERAQgL+/PyqVirCwMLq7uwkMDMRoNGKxWKioqBhx0BylUillAw4KCiIiIoLAwEBUKhU6nY6mpiYaGhqoqqqipaUFu93uEYJ/IYicolarxWq1npdPTsyeDUjB5D3Vj4E50AYS2oHcq4+PD0ajkaCgIHx8fCgtLaWxsXHIc69QKPDz8yMmJoa0tDS6uroIDg7GZrPR29s7ZvP674SBjNI3YaxXPREWuYupU6eyZs0aTCYTjY2NGI1GGhoaKCkp+UoCR8tkMubMmcOUKVOoqKjg0KFDI15ggiCgVqvx9/cnODhYIogymQyVSiVt5NTUVHp6emhubqa5uRmr1Toi7iwyMpIpU6aQlpZGSEiIFK5SpVJhMpmoq6ujpaWFiIgIcnNzqaiokEKDepIA+vj4EBMTI3H85eXlWCyWQck3VSoVPj4+BAQEoFAoaGtrG1WQHZGoK5VKiQBqNBrpe61Wi9FoxNfXl8jISJKSkggKCpKyJxsMBlpbWyWicjkolUr8/PwICgqir6+Puro6Tp06hdlsxul0DiJQ3ySImV/ENa3Vaunt7cXpdNLe3k5PTw8Oh2NMDlbx0AbG5JDzCBGWyWT09PRcNo3NxbBgwQJ+8pOfsHLlSk90Z8gQUxwtXLiQm2++maysLORyuZTe/siRI9TW1mK328csupfIMWk0GqZPn05gYCDHjx+XuJrhQlwgKpUKlUqFxWKhubkZnU7HwYMHJQIpBgCPjo4mOzubw4cPYzabh92mWq1m/PjxzJ49m6SkJDQaDQ6HA5fLhcViQRAEVCqVFLEuODgYp9NJZWWlRwOrKxQKfH19iYqKIjAwkM7OTtRqNTabbdDGUalUhISEEBERgUwmkzbxcMctcrcqlQq9Xi9lZRED38vlckwmk8T9mkwmoqKiiIuLw2Qy4Xa7aW9vHxZHp1QqCQsLk8QQra2tFBcXc+rUKTo6OgaFKx0tzlVuX6x/Y03wxXmcMmUKs2fPJigoCF9fX2w2G83NzfT09FBSUkJTUxNWq5Xe3l7a29slAj3Uvonjlcvl6HQ64uLiCA4OZtq0aVgsFnJzc+ns7KS6utpjojsRVzUnrNPpSE1NZe3atcyaNYvg4GAEQUCn09Hf309GRgaNjY3YbDb6+/vHVEbs7+/PuHHj0Gg0VFVV0dXVNeL2BEHAarXS1NSEUqlEEARsNhslJSXSVT0+Pp4FCxaQmppKcHAwer0euVw+7E1lMBhITU0lPT2dwMBAent76enpoa2tjebmZmw2G3K5HI1GQ2hoKFlZWbS2ttLZ2UlbW5tHDjfxNhMTE8OUKVPQarXk5+djtVpxOBw4HA7cbre00UJDQ4mNjZUOKJVKNazbjlwul24akZGRhIaGSnUYjUYcDgcGgwGZTIZWq0WpVEocLJzNeCKG8CwrKxvyYWQymUhNTSUlJQWZTEZNTQ2nTp2ioqKC3t5eXC7XIHHISIiEmJjU19cXg8Eg5cYT6xPH09vbKzFfbrcbp9OJy+WSDuGOjg56e3tHRagUCgXBwcEsW7aMG2+8kcmTJ6NQKLDZbJjNZukW4+/vT0tLC1arFbPZTGVlJZWVlcNeX+JBPnnyZBYtWsTkyZMZP348XV1dHDlyRCLE4u3KU/AoERYEgSeeeIKioiI2btzIrl27+NnPfoZcLsfpdPKrX/2K66+//pJ1fPDBBzz33HN8+OGHuN1u7rrrLokrvP7663nuuec80le1Wk1UVBTXXHMNM2fOJCAgQLrKKZVKIiMjmT9/Pm63m5ycHEpLS6UF5ykM3DDx8fGEh4fT0tJCbW3tiDlhOPseOjs7KSkpkcQMPT099PX14Xa7CQgIkBIqCv+bymmkXKmPjw+hoaHodDocDgednZ0UFRVRUFBAU1MT/f39+Pn5ERERga+vL8HBwaSkpHDixAnpoBktR6FSqQgPD2fatGlMnjyZ+vp6ent76e/vl7jygUQpKCiIxMREWlpaKC4uHpZJo1wuR6/XExkZSUZGhnT49Pf309XVhcVikQiZ+B5FRanIdff19VFfX09tbS2VlZU4HI4htStmdw4JCaGxsZHy8nKKi4tpa2vD7XajUCik9SuXy5HL5bhcLokjHMo8y+VyfH19GTduHOPGjSM0NBRfX1+JEAcFBaHVaunu7kapVNLW1iYRY6vViq+vL52dnRw7dozc3NwR515TKBQEBQWxePFivvvd7zJt2jTsdjslJSXU19djtVqx2Wx0dnZKa1qpVEr6CIVCQW9v75BzFYoc8Lhx41i1ahULFy4kKiqK/v5+DAYDM2bMwO12Dwqg7yl4jAhbrVbuueceQkJC2LRpE3K5nKeeeor169cza9Ys3G73ZTMa/P73v2fz5s188cUXBAQE8MMf/pAVK1bwn//5nwAeyU4ASCKHmTNnct111xETEzMoAaTdbketVpOQkIBWq5UWYUFBgUS4PAGxHqVSyfz58wkLC+PAgQM0NzeP6qrudruxWq00NzdLV21xE4qZLMTEiUqlUrpijYQrFbPTVldX43a7qaio4NixYxQXF9PZ2SnJhjs7O4mPjycgIICgoCB0Op1ENEY7n0ajkfHjxzNlyhSMRiPNzc3k5eWdR9xE0YiYxNTpdKJUKoc81yJnGxUVxYwZM5g1axZhYWFSFhFAGnN7ezu1tbXSQSNylEqlkr6+Ppqamujs7KS/v39I41epVNLcuVwuqqqqKC8vp7W1VZKFKhQKlEolRqMRnU6HRqPBarXS19cnmbFd7h2L60SUv8bExBAWFibJtkNDQ4Gza1bkSjUaDWazGZvNhsFgoKOjA7VaTXNz84i5YZ1OR0pKCmvWrGHChAmYzWaOHTvGtm3bqKqqkhTQLpcLtVpNXFwcMTExBAUFSaZ71dXVkkjsUhDXaEhICJmZmUycOJGQkBBKS0tpbm4mIyMDk8lEZGQkQUFBkojSU/AYEV6+fDk33HADTz75pPTZ4sWLeeSRR7jxxhtZtmwZmZmZF/39L37xCyIiIti+fbuk2Jg3bx6PPfYYfX19zJ8/nyVLlnikr6IYYvXq1UyYMAGlUinJmNrb24Gzix7+L6WL3W7HarVSVFSEzWbzqBxMr9dz7bXXolAoOHbsGB0dHaPmuN1uNzabDbvdLikXBEHAYDAwbtw4kpOTSUhIwGazkZubO2LNel9fH7m5uSgUClwuF7m5ueTm5krEX0zn5OvrS0REBBMmTODMmTP4+vpKfRoNxCurKFYRN19bW9sgEYNopeDj48O4cePw8/OTuMShzrVcLic8PJzs7GxmzJhBbGws/f39dHR0UF9fT319PZ2dnbS2tkrXY7EPIqfqdrvp6+uT5nuobRsMBgIDAxEEgerqakkeLBJxuVyOQqEgMjKS1NRUTCYTarWanp4eent7aW1tpaKigs7OzkvKSgVBkBLEigdGZ2cnAQEBBAcHS6IUrVYr3TCMRiNOpxOtVktoaKiUrXuoiWEvNM9Go1E6tBsaGjh+/DgbN27k4MGD0piVSiU+Pj6Eh4cTHh4uiVHsdjsRERGYTCbq6+sv255MJsNgMJCcnExmZiYymYz6+npyc3MpLi7Gx8eHlJQU4uLiSExMpKioaERK7IvBY0R48eLFbN++nYcffhij0QjACy+8QH5+Prt37+bOO+9k3bp1rFy5kltvvRWA2bNn8z//8z8AzJw5k88//5zKykpSUlIAuOGGG5g1axY7duzgr3/9K3/84x/59NNPR9VPpVJJVFQUixYtYuHChSgUCmnRHTx4kObmZjQaDcHBwQQEBOByudDr9WRkZNDS0kJnZ+eo0nsPhHgNHjduHElJSTQ3N1NUVDSk0/tyOPf3onY5IyOD+fPnM3nyZIKDgzlx4oSUTXkk6O7uJjc3F61WC0BDQ4PEccLZAy86OpqFCxcyefJkwsLCOH78uHQwjJYT1mg0REdHk5GRgcFgYP/+/Rw9evSijgtBQUHShu3v76e3t3fIbfn4+DB58mTmz59PYmIiMpmMpqYmCgoKKC8vJzc3l46ODolLEgmFVqtFEAQcDgd2u53+/v5hrR9R5h0WFkZgYCCNjY3U1NRIDIMoQkhNTeW6664jPT1dEkt0d3djt9tpa2vjwIED5OTk0NzcfNH23W43FouFsrIyqqurJUsSk8mEw+Ggv78fvV6PQqHAarUik8lQq9X4+Phw4403kpiYiMvlwmw2j0omLN5M8/PzcbvdfPzxxxw8eHBQwl3x8ImOjiYxMZGQkBAp6LxCocDhcAxpfYnKv/HjxzN+/Hjcbjd79uzh1KlTUoLVsLAw9Ho9Go1GsjT6tyPCP//5z3nllVdYunQp27Ztw9/fn6KiItLT00lPT0epVLJ9+3Yef/xxTp06dd7vr7nmGm666SZWrlzJBx98QGZmJqWlpcTHx3PHHXcwbdo0Zs2aNep+Go1GJk2axKxZs1Cr1XR1dZGbm8vmzZv5/PPPsVgsaDQaIiIiyM7OZuLEiYSGhkoKF7PZLGlfR4qBNqRKpZJ58+ahUCgoLS31+FUH/k+RFBkZyfTp04mJiSEmJgar1crJkyeprKwc8cnucrmkORRN4fz8/PDz80OtVhMSEsLChQtZsmQJ6enp2Gw2goODgf+z4BAVZ8OFKKNMTk4mMDCQuro6Dh06RE1NzQWJjFwuJyoqisjISHQ6naRNH0rbYqr3yMhIAgMD0ev1tLS0sGfPHo4ePUpjYyPd3d2D2hWvy+INQ1ReuVyuYc21QqHAx8cHtVqNXC7HYDBQW1uL0+mUTO7mzp3LXXfdxZw5c+jq6sLpdErr1WazERISgk6no6uri46Ojks6IwmCIInl+vr6JLmv2GdRZCHqUMS5EQlUd3e3JG4ZCURuPD8/H5fLhc1mo7KycpC5mDgPWVlZrFmzhtTUVOx2Ow6HA6vVKsnahyoHNxgMEvdeX1/PsWPHKC0tRRAEsrKyaG9vx8/PT1JWyuVyj+mHPKqYe/TRRzEYDCxatIjPPvuMJ598kpKSEtRqNXq9npdeeumSv583bx4bN27khhtu4O2332b37t1s2LABtVqNIAisX79+VP0TlRvp6ekkJyfjdDopLS3lo48+YuPGjXR3dyOTyXC5XNTW1tLZ2SnJj6OiosjIyKCpqYnc3FzKy8tHRLTO9ZbS6XTccsstaDQajh075nHln9imRqMhNjaWlJQUQkJC6OrqorCwkKqqqlFfrfr7+zGbzWg0GsLCwkhJSSExMZHo6GiMRiOpqanExsaiVqulvmRkZEip4js6OrBYLCMiTiEhIQQFBWGxWGhqaqKysvI8AizOuV6vZ+7cuYSGhlJbWys5jwwFMpmMxMREEhISCA8PB6C4uJiSkhJqa2uxWCzSNV8kFj4+PoOUgoIgSER5OFCpVAQGBuLv7093dzc1NTUIgoDRaMTlcnH99dezdu1apk6ditVqpbW1ldraWkkpJcpJg4ODSUhI4NixY8M66AdalgDnEWO5XE5cXBxpaWno9XpOnDjB8ePH6erqGtY4B9ZvtVqpr69Ho9Ewbtw4JkyYINkGi2KhRYsWsXjxYoKCgiRnlebmZk6cOMGOHTvo7OwcMhEGsNlsdHR0cOLECZqamrBYLPj7+0t+AyqVCqVSiUqlGmQ7PFp4hAgPHOh9993HfffdB8CmTZuG9Ps9e/ZI/586dSrl5eXAWRGFqJTzBESZWWxsLIIgUFtbywcffMDbb7+N2WyWFpTIJTQ3N0vKOq1Wi1wulxZyRUXFiBwbzv1/SEgIaWlp9PX1sXfv3iFrc4cKUQwRFRXFggULiIqKQqvV0tHRgc1mo7y8fNSct3iFdTgchIeHM3XqVOnqHBkZib+/PzKZDJvNRm1tLQEBAWRlZZGZmcmZM2fIzc2ltraWtra2YcmmfXx8iI6OJiYmBrfbTWlpKe3t7YN+K86zQqFg/vz5ZGVlodPpOH78OAUFBUOyTICzhHD69OlkZGTg6+srcb16vf48wqpQKFCr1ajVajQaDRaL5Tx75eFAdAaRyWQSt+fn54fT6SQ8PJwVK1YQHx9PRUUF+/fvp7y8nNOnT0uc/5QpU6TbqGiKONx+iIfLub8TZcL33HMP0dHRkiy1oaFhVMyEyI13dXVhNBpZunQpOp1Okj1HR0cTGxuLVqulubmZuro6KioqKCgo4PDhw7S0tAzZ7FBUZHd2dtLe3o5OpyM2Npa4uDgAxo8fT09PD3a7Hb1ej1ar9ZhSGa4yO2FRVqlSqbBarRQXF/P5558PSlgonvoulwuFQkFjYyN2u126aolX7eFGarsQJ6FSqVixYgW+vr4cOHCA8vJyyevp3GdHCoVCQWhoKPPnzychIYGYmBh6e3s5c+YMe/bsoaysbMga+otBXMTt7e2Ulpai1WpxOp2S9lyUGYpii97eXvz8/NBqtZLJVU1NDWVlZZJ951BsMV0uF1qtloCAANRqtWQdIEK8KqtUKmJjY7nmmmtITk6WjO6HyinB2RuL6Imn0Wgkt+ETJ07g7+8vXf9FJ45x48YRExODwWCgtLSUhoYGSe4+nM0rPut0OiVOWzTFMplMkuXA9u3bOXPmDIcPH6aurg65XI7D4aC9vZ3AwEBCQkIk2fBI5f8XIsAajYaVK1eydOlSDAYDr732Grt27Rq1JZNo297V1YXVaiUwMJCkpCTcbjdRUVGSo0xVVRWnTp2ioKCA3Nxc8vLyaGpqGpajhkKhQKPR4O/vT2ZmJunp6ZSUlNDX10dYWJhk3202mwkLCyMmJkaygfcS4WFCJG5Op5Ouri7J4+bc2ALidXJgERVNNpuNlpaWYZ/yF1rAYpZWp9PJtm3bJFndhZ4fCUQuZfz48ZJ212q1cvjwYd577z2Kioo8ZqvrdrslG2GbzYbVaqWhoQGn00lMTAw9PT1UVVVRUFBAS0uLJLbw9/dHq9USGBiIj48PcXFxkheYxWK5ZJsD3YXdbjexsbEsWrSIvXv3YrfbJfGTVqtl0aJFLFu2DKPRyMmTJykpKRmWzNJut2OxWDCZTGg0Gux2O3FxcaxduxZ/f3+6urpoaWkhMDAQjUZDUFAQMTExOBwOQkNDOXToEA6HY8TeVkajkaioKEJCQujp6ZFEO1FRUZJ8uqSkhOrqaok4iJYpogy7ra2NoqKiER265x4c4h4JDQ3l0UcfJSwsjKqqKvbs2UNVVdWIPBAHulyLBF5cF93d3fT392Mymeju7katVlNZWUl+fj6HDh3i+PHjNDY2Sjbvwx2faILncDhQq9VMnToVgMjISFpbW1EoFJIZYkJCAuXl5fT09Iz4QBuIq4oIi8bromdNY2PjIC8jQDIjUiqVxMTEkJ6eTkJCAr6+vtTW1lJSUiLZKY4GKpWK1NRUsrKysFqtHD9+3OOhCDUaDePHj2f16tUkJyej0Wioq6vjX//6l2TzLMphL8fZDyXyl2gBINqj2mw2nE4nxcXFVFZWUlpaKtnGtrW1UVVVhclkIiYmhnHjxpGQkEBWVhbjx4+noaGBmpqaS27m/v5+GhsbaW1tJT09ndmzZxMZGcnq1aulg1OlUtHb24tCoZBkufn5+ZJia6iw2+0cPXqUgIAAJkyYQEREBAEBASxcuJCFCxdKm9FsNmOxWCQuyuVyUVNTQ2RkJHv37uXMmTO0trYO2YFC5HzVavUgzzUx4M/p06cxGo2StYRocicq88LDw4mKipLMB8vKykZk2XOhfiqVSr71rW8xbtw4bDYbr776KkVFRcOuXyaTERgYKLlziyI50YvUz8+Pvr4+iouLJUuNlpYWGhoaqKiooLCwkMbGxkHxI4YLl8tFT08PjY2NBAUFUVlZiclkor29nbKyMpRKJfHx8aSmpmI0GhEEgc2bN1NXVzfqPXtVEWHRrlAULZhMJulvkXNSKBQSBzV37lyWLVtGfHw8CoWC9vZ2ampqaG1tHVU/xFP+2muvxc/Pj7y8PE6dOuXRQEEymYzQ0FCmTp1Kenq6JAfetGkTR44cGUTwLxT0RbwBiNd5jUZzWc86UfEkau1DQ0MlhZVouC8q4EQRRnd3NxaLBaPRKMWeEG1da2pqLjlGl8tFYWEhhw8fltyHw8PDiY+Px+l0otFoaGhokGxeRceU4uJiSQcwVLhcLo4ePUpXVxfl5eVMnDiRpKQkEhISAKT61Wo1RqNRUkaLB51oM2u1WiUmYKjti6nme3p6JBl0b2+v5LEmOpyIDhtutxuDwUBmZiYzZ87E39+fmpoaiXvz1EEfGRnJXXfdhcFg4Pjx4+zevZu2trZh1+Pr60t2djYTJkzA6XRSV1cniaxCQkIIDg6WDmNRvl5cXIzdbqepqYnu7m7pwB8JRP3P4cOH6e/vl5yYxP3e19eHzWZj8eLFTJw4ET8/P+Lj44mIiJDMO0czp1cVEQYku00fHx9iY2OZMWOGJHtyOp2S18y0adNYvHgxiYmJ+Pj4UF1dzY4dO9i3b9+IQz4OhI+PD9OnT8fpdPLFF18MEkV4AiInNPD6XFVVxa5du+jr65NklwqFQlJ4uN1u6SDS6XSEhYWRmJgoKXR2795NVVXVJdsVvcoiIiLIzMyUzIVEscFArbJIsEWbVh8fH/z8/Ojq6iIkJOSyY3S73bS1tZGTk0N/fz8JCQkEBQVJcRTKy8slB4prr70Wm81GX18fHR0dg+xNhwJBEDCbzZw5c4aGhgby8vJISkoiKSlJivGr1+slhxhfX18ASRGp0+kICgoaFNFuOG2LB1twcDDt7e2SjL2zs5Pu7m7JWUan0xEeHs6ECROYOnUq8fHx9Pf3k5eXR1FRkccOeplMJukZ7HY77777LtXV1cOuX1QeTpw4kbS0NFQqFYmJiXR1dUmMQUBAALGxsZLzS1dXFzabDYVCQWdnp6Q0G6pr9rlwOp10dHRw6tQpysvL0Wg0EtMhehsCUqhWlUqFv78/cXFxNDY20tjYOGQF74VwVRFh8aojyum0Wi3Lli0jPDyczs5OyZFj6tSpJCYmEhwcjFqtpqWlhZ07d7Jr1y7q6upGbUImmlYlJibS19fH559/PqqXeLE2dDodOp0Ot9uNWq3GYrFIQYoAyb3VaDRit9tRqVQYjUYp+pcYQ8DtdmO32/Hx8eGvf/3rJdsViXBoaCgRERHYbDYsFgtpaWnI5XKampqw2WzYbDbJuiApKUlSYvn7+59nEnUp2O12Scl25MgR9Ho9fn5+UphKMaZwZmYm3d3dkhPBSIiR0+mUbgPd3d3U1tZy4sQJfHx8SE5OJiYmhtjYWHx8fAgLC5MIhWjCJxKK4XjKie2azWaJ2IoMhCgC6e3txWQyYTQaB82n0Wikvr6eI0eOkJOTM6qgUAMhhi9du3Yter2eL7/8kl27dg37diHC39+fhIQEEhISUKvV9Pb2SoFyurq6MJlMaLVaNBoNCoUCi8WCXq+XxCtms3nY5o0D4Xa76e/vl2JRiLoGUbQhiiwLCgokG3d/f3/i4+Oprq6mt7d3VLqVq4oIu1wuuru76evrQ6vV4ufnJ3kaWa1WNBoNvr6+hIWFodPppOvurl272Lx5M/n5+R5xpNDr9SxcuJCAgABaWlooLCz0KBcM/ycacLlcyOVy/P39mThxInfccYdkiC8Gdhc9A8VYw/B/ohuTyYTdbqe3t3dIYxdl7qKnluhxlZ2djY+PDy0tLWi1Wkm5mZCQwJQpUwgPD5esTtra2qisrBzSnIha9La2Ntrb2yUxihgwB85aNogBjMSAMiO18xTl3mKwnpaWFoxGo0TY/fz8UCqV6HQ6VCqV5N7b399Pc3MzTU1NkifZUN+5yPFXV1eTmZlJfHw8QUFB0qZ3u934+/tjt9ul4Ey9vb1UV1dz9OhRcnJyqK2t9Vg4Vo1Gw5o1a5g+fTptbW28/vrrVFVVjYiREARBCrYkCAK+vr6So48oVxeJsHhbs1qtVFRUcPLkSSmE5WjN4cR5FEVz5+pnZDIZ1dXVnD59Gh8fHxITEyU3/N7eXkkZPRJCfFURYbfbTU9PD/X19TQ3N0sTKZ5u4vVcLpfT19fHyZMn2bZtGzt27JBSAI0WcrkcPz8/pk+fjlwup6KiArPZPOp6z4W4WMWrm7+/PwEBAURHR0uLrKOjA61WK8XdFaOs9fX1YbFYJEWQqNU/duzYZdt1uVy0tLRw/PhxYmNjiY6ORqPRkJKSQmBgIG63W5JPi2ILk8kkyTXr6+s5c+YMxcXFw1rMAzcSDDYJFJVaorXFSK+tA9tyu90SpyQGyrFYLBgMBmJjY4mIiJAOJDGsZ25u7oi8E91uN11dXVRWVlJXVydlSxFNKX19fVGr1djtdpxOJ3l5eRw+fJiTJ0+Sm5tLfX29R7T4cPZwTktL4+abbyYgIIDXXnuNL7/88rKWLBeDIAjU19dz/PhxVCoVSUlJGI1GKWeeKOJxuVySSO3IkSMcOXKEmpoaKcSsJ5mYgR6BA9Hb20t5eTlRUVH4+fkRHh5OcnIybW1tdHd3jzjw1lVHhNvb2yksLOTUqVPI5XIiIiIkLxjxGTEU33vvvUdOTg41NTXDliFeDAqFQiKGFotlWA4Dw4EgCHR3d1NaWsrp06dRqVTExcVJHJPoeCJu0N7eXjo6OnA4HPT29tLd3S15fdntdmpra9m1a9dl23W5XHR2dkrX9NTUVJKSkqSwiCJHIyqxbDYbPT09dHV1SZvxyJEjo1Z+DlQ6iqmFRFtbkdvxBGQymUQEXC4X/v7+UjhF0cW9sLCQAwcOcPr06RFl8RAdFyorK9m7dy9qtZoJEyagUCgwGAwSl11RUUFFRQW5ubkcP36cqqqqUYVEvdBYfX19WbNmDZmZmVgsFjZt2jTqgFMdHR3k5OTQ2toqBb0fGKBelKN3d3dTWFjIwYMHaWxsHDUHfDEM9HoEpDbEG0lzc7PkHRgREUFSUpLktj4S64yrjgiLAniVSkVNTQ0pKSkEBATg5+eHIAhYLBbKy8v58MMPOXjwIJ2dnR7NqiE6fDgcDhoaGjh58uSIzWouBXGsx48fx2w2c+TIESZNmkRgYKAUE8But0t2vU6nE7vdLkXdEq/yonVER0fHkDXfTqdTkqNXVFQwefJkKbKVaIvp4+NDW1sbTU1NtLe309DQQEFBAWfOnPFIgKRzYx2Izgs9PT2DDt2RYiDnLdbb398vBXny8fGRHAm2bdvG8ePHaW5uHrFiTLwl7Nmzh4aGBjIyMoCzHpcOh4OWlhby8/OpqqqSLE48nQ1GrVYTHx/PypUr0Wg0nDhxgjNnzoxa2edyuSQu32AwSBZL4oFtMpmAs8S6q6trVOmoLodzOWDxPYufi4TY4XCg1WoxmUzExsYSHh5OXV3diG7LVxURBnA4HJSXl9PU1MTRo0cJCQkhNDRUSpYoRjKrq6sbs9xyFouFLVu2EBQURE5OzpikThL972tqaqipqZFOdtGzTOQIxaAy4m/Efy/kYi3aWQ+lbbvdTnt7O2azmcLCQvLy8qRIVyLnb7FYaGhooLa2lqamJkl55ekNplQqaWhokOxLRXHAaN1ORe5XvBIXFxezdetWLBYLarWawsJCDh06RGlp6aiTcIqy78bGRpqbm6V1Ix4wwJgRJvi/SG3z588nKCgIs9nMJ598Qmtrq0cYCHHNdHR0SN52A0OwigFzRitKGmpfgEFrfeAeEMOXOp1OSYFtNBol8d1wcdURYfg/ZUBZWRllZWVfadsWi4Vjx45x/PjxIRM1T2AgwRjq8xf6/3AgWgE4HA5ycnLIycm5aBuexsADpampiS1btlBZWUlzczPFxcX09fWNuv2Byk+n00lFRQW1tbV88cUXUlol8TlPjvVc64qxJL4ilEqlFBfEbrdTU1PDRx99NKZJcMX5ha9mjANxodAB4mc+Pj5SqEwx9ZmYUWUk/bwqifC/AwYusKsBY829XAput5u8vDwKCgoGyXA9CZHQiuZ33ySIwfATEhLQaDS0t7dz+vRpKXb0NwkX4mQHOnGJ7su1tbVERkZKsvimpiaam5u9RNgLLy6Fr5qb+qZAVNDGx8fj7+9PW1sbLS0t30gm4kKHykCrG9GK6KOPPmLLli2SE9JoMrLLhG/aUcaFTzMvvPBi5BCtTAbK0r+JRHi4uFzEw6GQ128kJ/wNPFe88MKLbyg8Fx7eCy+88MKLYcNLhL3wwgsvriC8RNgLL7zw4grCS4S98MILL64gvpGKOa91hBdeePHvgKvWOsKL8yGaGImpbwa6gHqtSb6+kMlkqNVqKVuJ1xb66wcvEf4GQi6X8+ijj/Lwww8DUFdXx/vvv8/3vvc9qqur+eCDD2htbaWzs5Py8nIp+LmXGH99EBMTw7Zt29i7dy/Z2dn8/Oc/5/jx41gsFini31h4BnrheXiJ8P9CLpczf/58fvjDH/Lf//3fZGZm8vbbb+NwOKQ4rWMF0fh9/vz55OXlIZPJRpXJVRAEKcyeQqGQMk34+/uj0+lYu3YtCoWC48ePc/r0aXbt2oXL5RpVNDe5XM59993HypUrpTCUmzZtws/PD6PRyPbt2wkNDeXEiRNSrAWxr98kiKFKOzo6pLRSU6ZMQalUUldXx/Lly1m6dClWq5WUlBQaGhq4/vrrh1y/Xq8nPj6epUuXkpycjMlk4sUXX2T69Ons27dPCuqjUChQKpWDAjR9EyCOScRQEtD+u2NYRFgkDgaDYUSNLViwgJ/85CesXLlyWL/74x//yK233jqkvGPDhUwmw9/fnxdeeIGEhAQCAwP59a9/zalTp3juuefYu3cv+/fvH7Ff+FAgZhS44447MJlMPPPMMxQWFo6qPrPZTH19Pb6+vlJEM4vFwvjx4wkPD6empoZx48ZRVlZGeno6BQUFUrbe4UKlUnHrrbfy3e9+l7S0NBwOB2azmb6+PkJDQ0lKSiIzM5Nt27axePFijh49Snd3txT8xhPzKpfLpSDx8+fPZ+7cufziF7+guroatVqNw+FAqVTi7+/PnDlzKC4uprCw0CMEShQJiGEYfX19mTZtGrm5uQQEBBAXF8eECRPo6OiQsvrOnTuXsLAw6urqhtVWSEgICxcuJCIiggMHDpCWlkZycjIffPAB48aNo6KiAo1GI0XL6+/v/9rfcsQchAaDAZ1Ox6pVq9i5cyfXXnutFEz++PHjUg49Mct2X1/fkN/vpfRIA6MKeiL63rn4WnDCf/zjH1myZInHibBCoSAyMpKnn36aBQsW4O/vT3t7O2lpaTidTsaNG0dSUhL19fW0tbWNCREWEzQ6HA4qKytZt24dWq121G2dOHGCDRs2EBUVhcFgQBAE1Go19fX1AFIM2rS0NPz9/aWEicPN1aVUKgkKCmLKlCnExMRIXK7RaGTevHlotVrkcjnz5s2jsrKSoqKiQbm5xDCQo4Ver2f69Ol873vfIzIykrq6OqZOnUpNTY2UtsZoNDJx4kTcbjdJSUm43e4Rp5YaGBrUZDIxfvx4nE4n6enp5OTkYDAYCAkJISMjg/DwcHp6eoiLi0Mul6NSqVCr1XR3d3Pq1KlhtRkUFMSyZcuIjIxEJpOxbds2KisrOXbsGAqFYlCewPb2dmluPUWIRWI0MH3UwM89TezFuBXJycksWrSIffv2ER0dzYQJE8jMzESn03H06FEmTJhAcHAwlZWVaLVagoOD2bt37yXHoVAopAD/KpUKX19foqOj8ff3Jzw8HJfLhclkoqysjDNnzkj7pLe3l76+Po/djkdEhAVB4IknnqCoqIiNGzeya9cufvaznyGXy3E6nfzqV7+66BVr586d/O53v6O+vp7Vq1fz29/+FplMRlNTEz/4wQ+oqqrCarWyevVqnnnmGZ555hkaGhq48cYb0Wq1vPHGG7S3t/PUU09htVpxOBz8+Mc/5u677x72ODQaDfHx8UybNg29Xs/JkydJTk6WJlmpVDJ16lTmzZtHbW0tdXV1Hl1k4okqBhxva2ujrKzMI2EWi4uLUSqVUipxsX69Xk97eztBQUH09fURFxdHYGAgxcXF1NbWDjuTtFar5aabbmLGjBnI5XIpO4fBYKC7u5uCggKioqJwuVxER0fT2dkpEYrS0lKam5tHlaQRzs5jbGws3/nOd0hKSqK8vJy6ujpqa2sHhQtVq9XMnDlTSkgp5qQbLjcsJoIUCa2vry/BwcFERkZSX19PRESElG3CZrOh1+spLy/HYDCg1+upra3l9OnTGI1GDhw4MKxxBgQEkJycLM3tjh07OHXqlJTVQcwUnJaWRnFxsXS4DjczjEKhYNy4cQQFBSGXy4mMjJTSzE+YMIHNmzfj6+srMS5xcXHExsZSVlZGe3u7lNNvNBCTxqanp3PHHXdw6NAh1qxZg9PpRBAEampqpASu4i2nu7t7yLF9tVqttP98fX1JTk5m3rx5+Pr6IggCQUFBJCQk8MEHHxAcHIxKpcLpdFJYWEhRURE9PT0eoQfDJsJWq5V77rmHkJAQNm3ahFwu56mnnmL9+vXMmjULt9tNd3f3RX8vLhyHw8G8efN4//33+fa3v82dd97Jz372M+bNm4fT6WTlypVs2rSJp59+mtdee40PPvhAyibQ2dnJ/v37USgUdHR0MGXKFJYvX054ePiQxyG+4PDwcNrb20lOTsZms3H8+HFMJhNFRUUkJCRgNpuZN28ezc3NfPbZZzQ2Ng53yi4J8XqTlpbG9OnTaWlpwWKxjPra09/fL53anZ2dlJWV0dXVRVxcHGVlZURFRREREYGPjw/h4eGDssoOlxOeN28eISEhVFdXS0q+/v5+jh49SnV1NbfddhstLS0UFBQQEhKCRqNh/PjxNDY20traOuq4ynK5XBIFnDp1il27dhEaGsrp06cHJW90uVy0trYyZ84cFAoFPT09FBUVDfuWI6Y8j4yMJCQkBIVCQW9vLykpKeTn50sposS8cA6Hg8DAQCkMZFtbG2q1mqCgIBoaGobcrlarRSaTcerUKUpKSsjJycFisVBWVia9N7fbjUqlwmazMXXqVEwmE3l5eRw4cGBYREOUbScnJ+Pn50dycjLp6em43W6uvfZafH192b59O3fddRcFBQXMmjULpVJJS0sLvb29HDx4kEOHDo3qgFUqlYSEhDBz5kzWrl1Lbm6uJO+uq6tDq9VKRDc0NJSOjg5MJhOBgYESR9zb23tevWIQfDEgkbh+IiIiiI6Olgh8cHAwnZ2dVFVVMWPGDFQqFUFBQTQ3Nw9KvzRaDJsIL1++nBtuuIEnn3xS+mzx4sU88sgj3HjjjSxbtozMzMyL/v7OO++UZDa33XYbO3fuZMWKFXzxxRc0NzdLz/X29lJUVHTBOtrb27nnnnsoKSlBqVTS1tZGfn7+sIiwXq8nLi6OhIQEIiMjAUhOTuZXv/oVwcHB+Pn50dPTw4kTJ8jOzmbNmjU0NjbS1NQ0Jtzwvffey4IFC9i4caOUeXY0UKlUyOVyKRNDXV0dAQEBCIJAT08PjY2NhIaGEhkZSX9/PzU1NSPiwF0uFyUlJej1eqxWK83NzZSUlFBaWkphYSGBgYEUFBRgNps5ffo048aNY+rUqYPM5EQiOdIx+/j4oNPpqKqqQhAEamtrycvLQ6lU0t/fL107nU4nW7ZsYc6cOWRnZ9PY2MixY8fo7OwcMhEWue5p06YRHR0tBTgXxx4eHs6mTZsICAjAbrfT2dlJbW0tq1atIiIiArVaLSWxbG5uHlaapeDgYPz9/dm3bx/l5eWSqEVME69QKIiKiiI1NZX6+npWrlzJsmXLOHz4ME6nk6NHj9LV1TWktrRaLRaLBYfDQVBQEACTJk0iKCgIpVLJfffdR2FhIddffz3Tp08nKSmJTz/9lIULFxIeHo5cLuf06dMXJIJDgVqtJiQkhJSUFGbOnIkgCNxxxx3cfvvtTJ06FbPZTHNzMwcPHuSmm25i3rx52O12WltbCQgIoLGxkYqKCo4cOXJe3eJaE28OPj4+GI1GiWhXV1ej1WopLS3F4XDgdDppb29n9uzZ0vsbCcNyMQybCC9evJjt27fz8MMPYzQaAXjhhRfIz89n9+7d3Hnnnaxbt46VK1dy6623AjB79mz+53/+54L1iUG2ZTIZR48eHdKifPDBB7nuuuv48MMPkclkTJkyZVjXLZETu+WWW5g8eTIxMTGYzWY2b95Me3s7//rXv/j+978vpSbv7+9n3LhxJCcns2fPHo8l/RRtdPV6vZS99ssvvxy0UUbyokVZpZhdWszrplAoaGtrw263c80110gadDHZ50gX1N69e4mKiiIrKwulUkl+fr7EWRuNRo4ePYrFYmHFihUcOHCA0NBQent7iY2Npb29XSKCI2lfoVCQlJTELbfcwqxZs3jllVcwm82cOnUKt9stcdkilxgfH4/b7aa6uprq6upL3touBKVSyeLFi3nwwQfR6/VUVVXxxhtv0N/fz+uvv05LSwsADQ0N6HQ6AgMDSU1NRaFQYDabsVgs9Pb2SorLoRIppVJJUlISq1evxu12U1RUhFqtpry8HIvFglarRaFQsHDhQmbOnEl1dTW+vr7YbDaysrK44447kMlkfPnll0PKCGwymUhKSiI7O5s5c+YQGBjIl19+iVKpZMOGDchkMhYtWsTOnTulG2NoaCg6nQ6r1YpcLkev14+ICKvVauLi4pg9ezYxMTGMHz+eL7/8kn/+8584HA4++ugjiWiGh4dLSWrFtvv7+yXiffTo0QuuK3Ff6XQ6wsLCiIiIwNfXF7fbTW5uLgkJCbS3t2MymVi1ahWnTp0iICAAm81GWFgYWq121OIWEcMmwj//+c955ZVXWLp0Kdu2bcPf35+ioiLS09NJT09HqVSyfft2Hn/88QsqHd566y1uvvlmHA4H77zzDo899hhGo5G5c+fym9/8hp///OfA2UXsdruJiorC19d3EGHq7OwkNjYWmUzG3r17OX369JD7L5PJCA4OZtmyZdx3331SFt7e3l5eeeUVnE4ncrmc1157jWXLlrFkyRJJvpSUlERycjL5+fkeNfsJCAiQiGNpaanECY/0pJXL5fT29tLU1CRllF6wYAFVVVWEhYURGhrKwoULaW1tpbGxcVSct1arpaysjMLCQqKiorBarahUKqKioggICMBsNjN16lQaGhqYOnUqp06doqamhuXLl9Pe3k5jYyO9vb0jnk9/f3+WLFnCzTffjNVqZerUqWzcuHGQE4p4/QwICODmm28mPT2d+vp6Ojo6hq2wio6OJi0tjaioKOx2O2q1moiICHJzcyW5rFwulw7CRYsWsXTpUolz6+npQa1W43Q6cTgcREVFDSnFVkBAAJmZmUydOpXOzk6+853vsH79epRKJUqlEpPJRHR0NOPGjeOaa65BpVJRXFxMe3s7BoOBadOmIZPJpPyJlxuzXq9Hq9WiUqkk0Y0YzDwvL4/i4mICAgKkRJzPP/88CQkJBAUFSTcDHx+fYa8rUe49e/Zs7rjjDik/4I4dO9i1a5ekDLNYLKSnp3PNNdcQFBSESqWSGI7w8HDMZjM7duy44B4a6LgkjlVMZqvX6xk/fjxNTU2kpKTgdrsZN24cBQUFNDY2kpSUNCjxpye44REp5h599FEMBgOLFi3is88+48knn6SkpAS1Wo1er+ell1666G+nTJnCkiVLJMXcjTfeCMCGDRv40Y9+xIQJEwAwGAysX7+eqKgofvCDH3D33Xej1+t54403+M1vfsN//Md/8Jvf/EaSpQ4VoixYrVbT1dWFTCajq6uL4uJiWlpa6O7ulpIOnjp1iurqapYtW0ZzczOTJk3iscce40c/+tGoU7IP7I+fnx9arZbt27cPOl1H+nLF1O79/f309fXR3d1NTEwM06ZNQ6vVMmXKFCk7gt1uJycnh97e3hG5e5vNZrq7u8nPz8dqtVJfX09NTQ0AkZGR3HDDDTQ0NBAbG8s///lPSQxisViorq7G39+foKAgmpqaRsQNZ2RkkJycTFFREYWFhTz//PPSDWagxl6hUBAWFsbOnTuJjIzk888/58yZM/j6+g75XcpkMtatW8fq1atxuVycOHGCd999lwMHDtDf34/D4ZBudhqNhkmTJrFgwQLKysrQ6XTs27eP5ORk4uPjefHFF2lqahqSIlQul5OYmIher+e9996jqqqKuro6QkNDpeSYfn5+REVFMWPGDDQaDfv27UMQBD777DOysrJYuXKlJBNWKpVS/ruLobOzk8LCQsrLy1m/fj2dnZ2YzWYp0SVAS0sLMpmM/v5+Nm/eTHx8PMuXL6eiooL+/n4CAgKoqKgY0twOnGOn00lubi6/+tWvJEuSgIAASbwkHjrz58/n6NGjzJ07l3379pGRkcH06dP55z//yc6dOykvL7+gmGmgnFpMNutyuQgKCpJoQlJSEjk5OaSkpPDqq6/S0dFBdnY2Bw4coKOjA5VKJWXV+EqJ8MDG7rvvPu677z7grFH+ULBnz56LfhcWFsY777xzwe/uvfde7r333kGflZaWDqnNcxEaGsrtt9/OT37yE6xWK319fTQ2NnL48GF6enqw2+3S5n399ddZvXo1sbGxZGdn43Q6CQ4O5oEHHuC5554bUfsiRBMnmUzGE088gb+/PwcOHJDsHj0BQRAkY32tVotWq+Xmm2+mo6ODoqIiHA4H6enpvPvuu9LmHK4ixeFw4OvrS319PZGRkaxYsQKZTMbu3bsxmUx0dXVx5513UlBQQGlpKVOmTGHatGnU19cTHR3N/Pnz2b59O5s3bx7RwZaZmcmKFSuwWCzs2LGDxsZGySZYtEEW7XgTEhJYunQpU6ZMAaCoqIgzZ84MebyBgYEEBgZKcyuXy2lubpYOMIPBIHH0YWFhrFu3joCAAPr6+ggKCiIuLo7t27fT1dVFX1/fkN2M5XI54eHhLFiwAIPBwNtvv43b7SYiIoK1a9fyySefEB8fz8SJE5kwYQJ2ux29Xk9oaChLlizB19cXrVZLVlYWKSkpksjkUujp6ZFEOe3t7YMOtIFzK64xUeyRkJCAw+Hgww8/5NixY0Oa14HQaDSSfqGsrAyn00lUVBR6vV7i+o1GI9/97neZOnUqEyZMkJTMJSUlnDhxAoVCQUFBwUXFLqKoTLTm0mq1pKSkEBUVJd0MT58+zbe//W3sdjubNm3C19cXq9VKRUUFWq2W6OhoXC4XbW1twx7jufha2Al7CnK5nIyMDFJSUujq6sJkMtHQ0MDHH3/MX//6Vym9tpiwMSAgAF9fX3JycoiLi5NMrNrb20fch4HXF7fbTUhICJMmTaKmpoaPP/4Ym83mUWNw0S5VNMczm834+Pjw3nvvsWrVKo4ePUp2djbFxcWYzWZJ6zsca4He3l5KSkrIyMjg1KlTFBUVsXbtWo4cOUJ/f79EoEUuTVz01dXVFBYWMm3aNDQaDZs2baKxsXHIYxe5pvb2drRaLdOnT5fEAFarVXLSgLMc8+OPP46fnx//+Mc/+OKLLygoKBjWOF9++WXS0tJob2+XDrJJkybR2NiI2+2mt7eX5ORklEolFouF7OxsDAYDZrOZF198kfz8fLq7u+np6Rmyd6Iot9fr9ZLTkOjsFBkZSV9fH//5n//Jm2++yfHjx1mxYgUGg4G6ujr+8pe/oFQqmTVrFoGBgTQ1NXHy5MkhtWuz2WhtbZXmZ2DKeVG/IHoEGgwGfvCDH5CYmEhNTQ0vv/wyu3btGvK8ipDJZNjtdhoaGrBYLCQkJNDV1YUgCBw4cIDU1FSam5vp6urioYceIjg4mJqaGl588UXOnDlDe3s7dXV1tLS0DGmM4j4X9SJtbW3MmDGD/fv3I5fLaWlpkQ6yuXPnUllZSUhICDU1NaSmphIeHi6J10Zj635VEWGVSsW8efNYvXo1crkcq9UqLZre3l5Jlid+Jxq822w2adIDAwOZNm3aJUUuF4PITQwksoIgMH78eOrq6iTOyFMEWCaTodPpiI+PZ/z48Rw+fBhfX19qa2u56aabOHr0KGazmezsbMlmciSyLrHfJpOJWbNmkZiYSFJSElarlf379xMdHU1HRwfx8fGo1Wr27dvH/Pnzcblc7N27l+joaFavXs0jjzzC7t27eeCBB4YWfep/07AnJyfjcDjo6uoiMjKSkpISAIkDnDlzJidPnsRgMCCTyWhtbZU048MZp9VqpaGhAR8fH2JiYrDb7SiVSnx9faXDTbQMWrBgAV988QULFizg9OnTVFdXY7VaJW7Obrdftl1xvej1epKTk7ntttukNOu+vr7s37+foKAgAgMDmTVrFgaDge3btzNr1iz279/P8ePHmTt3LtnZ2aSlpdHa2opKpRqS2Ensm7gWzg34JN6Y/P39MRgMBAQE0NPTw3PPPceOHTtGrLQSnX8yMjIYP368JKIT7ZPT0tK4++67aWlpwdfXl7y8PM6cOSMdbMOx8BHHYTabpXUUGxsLnFU2m0wm6uvrueaaa1Cr1dTV1TF+/Hja29vZu3cvVVVVw1bsXnDMo67hawSj0YjRaJS4FvHqL2pzB5qdqFQqPvvsM5YvX05oaCi+vr5YLBa2bdvG73//+xG1P1BOCWcXXFZWFm63m5/85Cce9cIBpCuyaBqVnZ1NXV0dXV1dtLe3YzabMRgMbNiwAUEQ8PPzw2KxYLPZhqRBHwiLxYLZbKajo4PGxkZ8fX3RaDQsXbqUU6dOoVAoaG1tpaenR5Jt+vj44HA4SE1NpaKigrfeeovGxkYiIiIkz75LQVSuiHJvHx8fXnrpJX7xi1/Q1dUl2Q5bLBbmzZtHdXU148ePR6fT0dDQMCyueyDcbjddXV2cOXOGvLw80tPTyc/Px2g00tfXR0hICJWVlXR0dHDq1ClMJhNKpVJyIx6OQ4xSqZRMOltaWjhy5Ijknl1ZWUl3dzdvv/02mZmZ1NfX09TUxFNPPUVsbKz03JkzZ9iyZQuVlZVDtoIRLUuAQQzDQIWxIAhYrVZuvfVWnE4nNTU11NbWjsrZyGg0otPpJFHEvffey9tvv01WVhZ5eXlMmjSJ48ePU1JSQldXF9OnT6e/v5+6urpB1ibDYSB6e3uxWq0YDAaUSiUajYabbrqJxsZGEhMTycvLw+l0EhcXR25uLi6XC19fX0JCQnC73aMWSVw1RFg01j969CiTJ09mypQpFBcX89577wGDCaToQbNkyRLi4+OJj4/Hx8eHHTt28Morr1BZWTnifojtyOVyAgMD+fOf/4xcLuf48eOS/NJT7qVBQUGkp6cTGhpKfX09ISEhGAwGdu/ejY+PDzKZjLCwMG644QbMZjNOp5PTp0+Tm5srXePP5Ywv1bf9+/cTGxvLsmXLyMnJkcx6zpw5Q11dnRR8JTo6Wtps119/PUajkcLCQvr6+tDpdERHR+N0OgfZjV8INpuNTZs2ERkZyTXXXEN1dTVyuZwnnniCoKAg3nzzTWJiYujo6CA1NZWYmBiUSiVz5szh8OHDVFVVDWtOn376aRYvXkx8fDzjxo0jNTWVY8eO4Xa7mTFjhuSNOG7cOMnssaOjQ9Lkt7S0SGIf8R1daj5FDtThcPD2229js9lYsGABmzZtkmK4BAcHU1hYKNlqx8bGotPp0Gq1zJgxg6VLl/Lll1+yadMmibnQ6XSXVcwB0nqEwetgYN9DQkJYtmwZLpeLV155hYqKimGv4YF1dnd3k5aWxpQpUzh69Cjt7e3Mnz+flJQUWltbCQ8PJyYmBqvVyunTpzlx4gQ+Pj5ERUVRU1MzImsMjUZDXFwciYmJdHZ2SjE/Ojo6+Oijj8jKyqK9vZ3IyEh8fHxIT09nzpw5fPzxx2zfvv28oELDxVVDhMUFM3XqVMnP3+Vy0dXVJcnnFAoFBoOBnp4eAgMDeeihh8jMzMThcFBaWkpVVZVHAs6ISh2TyURERARyuZy2tjZJqTNaQixaXCxcuJBbb71V4vxqa2vZt28foaGh+Pn5sWvXLkJCQnA6nUyaNInS0lKcTqckgxRvBuL8XMqMTCaT0dvbS3l5OampqYwbNw6AY8eO0d7ejr+/v3Sd7+7ulmS4Bw4coKuri+DgYKZNmyaZJB44cIA///nPl53HoqIiduzYgUaj4fDhwyQlJREbG4tSqWT16tUEBwezfPlybr/9dkmxVVNTM0jeOVSIHn6i+Kauro7w8HCio6MJDg5Gp9NhMBiIjo7mzTffJCQkhLS0NEJDQzlw4ADbt2/H5XKh0+mw2WxDMssThLPBnWbMmEFMTIzkoBQbG0tbWxuNjY3Mnz+fxMREfvKTn5CcnMyUKVNYsWIFbW1t5OXlYbPZmDdvHm1tbeTm5g7ZYUNs/9y4ECITodPp0Ov1koWJqNQa7ryKCuqoqChmzpxJWlqadKPw8/Nj2rRpqNVqJk+eTGRkJD/5yU8IDQ1l5syZZGZm8vLLL5Obmztii6Xu7m5KSkqIj48nLi4OhUJBTk6O5OnY0NDAiRMnmDRpEikpKYSEhODj40NaWhrV1dWcPn1asqoayd69aogwIF1bqqurJUXbihUr2LFjBy6XS7LfTElJ4fe//z3p6enYbDY6Ozupq6vjzJkzlJSUjDjEpAjRTlGn06HRaHjkkUcGXf9HywmLJk3Tp08nLi4OvV5PZGQkwcHB7Ny5k7i4OEpKSiT7yuDgYHJzcyktLcVqtUpXWVGGGRoaypw5c5g9ezazZs26YJuiJ15RUZEUbCUkJESy+tBoNDQ1NUmmcy6Xi0OHDuF2uzEYDGRnZ7N06VLUajVGoxEfH5/LEmE4+053795NaWkpCoWC2tpaVCoVFRUVUsCV9vZ2yfTxo48+ksy8hgMxyEtFRQWbN28mODiYgIAAwsPDmThxIiqVik2bNjF79mw++ugj+vv7CQsLw+FwcPjwYU6cOCFZknR1dQ1JJOF2uyUuq6CgAKvVSkJCgqRcbmho4MknnyQ+Pp4///nPuFwuSct/4MABmpub8ff3Z+LEibS2trJ161ZsNtuQuOCBGEh8z8XPfvYzQkND+cUvfkFhYeGI9obRaOT222+XXIR7enqIjo5m7ty5LFy4ELlczgsvvMA999zDb3/7W6xWK3FxcTQ3N/OnP/1JGutIudH+/n4KCgpwOBxMnz4dPz8/wsPDOXbsGImJieTn56NQKGhsbESv17N7924CAgKwWCzSuz906NCI7e2vKiLc29srySXFq57VamXBggXcfvvt/PGPf2TBggXMmzdPiqTW1NREW1sbX375JQcPHvRYNDWRyDQ2NvLhhx9KXJGnRBF6vR6NRiO11dvbS0hICE888QTV1dWEhITQ3NyMwWCgtraWsrIyNBoN06dPJzAwUOLsCgsLMZvN3Hbbbfj7+1+0TVHTXFVVJVk85ObmkpiYyO9//3vef/99mpqaJPm70+mko6MDtVpNeno6sbGxhIaGYjQaaWhoGHJMBUEQaG1tpaurC6VSSXl5OYDkxmuz2dBqtZw+fZro6Gg++OCDERML0SbXZrNhNpsZP348er2eo0ePEhoayqpVq9i2bRstLS3ExsaSm5sLQG1treQU0tfXN+zNKt4gNBoN48aNkzZ9dHQ0L7zwAp999hlBQUHExsZKB0VXVxdhYWFER0dLLs7+/v6YzeYRr1+R0xNjLmRkZDBlyhTeeecdcnJy6OrqGlHd4nqYM2eOJPsODQ2lvb2dDRs2EBgYyO23387GjRtpaGggNTWVgwcPUltbS0VFBR0dHSMmwOINr7u7m8LCQimuh9VqRSaTkZubS3t7O3a7HbvdjsPhoLq6mmuvvZakpCT6+vro6+uT5ngkuOqIsBhLQKlUotPpmDhxIrGxscyaNQudTkdMTAyxsbGShURhYSH79+9nz5491NbWekRxJooLZsyYIZnGeNIsTRAEfHx8JAN3uVyOn58fZrOZqKgo3G43FRUVjB8/flAcXjEqWHh4OMHBwajVaiZMmEBbWxthYWGXVdaJbtJ5eXkSkRDdbRctWiSZFxmNRsxmM/39/SQlJbF48WImTZpEQEAAer2e1tbWYUUXc7lcEmcpKmYUCoXUX9HrSXRvFW1EhzunIhEWFboBAQHA/+kQXC4XgYGBmM1mGhsbJc88h8OBVqulurpasswYztjEAwWQHKL8/PwIDAwkPj4ep9NJQ0ODNH+NjY2SJr+qqopDhw7R2tpKX1/fqG9xcHZuAwMDueuuuyRxUGtr64i9HsU+1dbWYjQaCQsLw+VyUVpaSmtrK0uWLCEiIoK0tDTUarXklnz8+HE6OztH7b0qurSLB6RoqqrT6ejs7JT2vCjCFMVPiYmJ6HQ6LBYLX3755WV1JhfDVUWE7XY7BQUFkmwuIyOD9PR06aq5cOFCyfTG5XJx8uRJtm7dSk5OjhRfwRMQr/ii15VoS+opuN1uGhsbOXPmDDqdDrfbjV6vx263S8FHwsLC6Ovrw8fHR7IjNplM6PV6TCYTAQEBUuwDkQBcboGJhvvV1dVs27aNpUuXSh6KRqORm266iS+//FKKNdDT08OMGTOYOnUq8fHxGAwGKf1STk7OqOdAhNPpJCgoSCLG1dXV9PT0jKhOi8Uy6DDq6+sjISGBvr4+2tvb6e7uRqfTUVtbKwXU7+npobi4WAqSNNw2bTYbvb291NfXc+LECbRaLdOmTSM4OBhBEEhMTCQ6Opre3l7JmaS5uVk6DEUPtuEEKroU9Ho969atY+HChfz+97+noqJi2CKOgbDb7QQEBEhiGo1GQ2VlJe3t7YSGhmIwGLDZbPT396PT6Th58iSpqalS0HZPMC8Dze9Ec7y+vj6J6xdvAKLeSIzWZjAYyMjIYOrUqSNW2F9VRBigpKSEjRs3Ul9fz9q1a1mwYAEajUYivHa7nfLycgoKCti2bRv79+8fpDTzBHQ6HdOmTcPpdGK329HpdB4lwoIgUFpaitvtprW1lcmTJ5OcnExjYyNKpZLGxkYCAwMpLS3FaDTS29uLWq3Gz88Pf39/KRVSYmIiDoeDgwcPSnNzOYgmP7m5uVgsFpYsWSJp40Xtc2xsrGTSlpmZSXx8PBqNBofDQXl5OS+//PKozH4GbkrRW050khi40UYKUaFrsVgk0yWz2YxGo8HpdNLX14dWq6WtrY2Ojg7q6+vJz88f0ZjEsfT391NVVUVbWxtms1mKBy1y4bW1tdTX12MwGMjLy6O0tJTS0lLa2tokGfxo17CY4SI5OZk77rgDhULBgQMHpPjMo6lXlK86HA4qKiqk+BPiAXfixAnq6+uprKykrKyMysrKUYlWLoZzxzEwFKpMJpNEUaJVhUwmw9fXl5iYmBG3edURYYfDQUNDA9u3b8ftdjNnzhw0Gg2NjY2Sv/zevXvZvXs3NTU1w7aXHQqMRiNr166lr6+PmJiYYQdSHwr6+/slO9KCggKmTp1KdXU1CoVCupaKwWa6u7vx8/OTMgkIgiAF03a5XPzud78bknOBCFE+XFdXx+nTp5HJZISGhlJbWyvJ0UQDf9FqoqOjg87OTg4dOjTqQ+9cBZIYaEaMcdHZ2TlioiHW7Xa7sdvtksuyyWTizJkzJCUlUVZWRkxMDJ2dnZw6dYrDhw+P2qhfvGWIEeLEeAo9PT1Mnz6drVu3ShxbcXGxdECca+M7GiiVSiIiIli5ciURERF8+umn1NfXD2pnJBBjJMfHxxMYGCh554kRywIDA3n33XeZOHEihw8flgI+jcXePBfiuESbdKfTSUhICFqtFvg/fYuYG9IrjhgCRNlee3s7eXl5HDt2DK1Wy7Fjx9i3bx+5ubnU1dWNemFdDOK1RqlU8sUXX/Dhhx8O28B8KBDls2J81IMHDw6y9b2U15TYjw8//HDE7YuG/GVlZTQ2NmK1Wpk4cSI2m43i4mKSkpKYOHEihYWFNDY2YjabOXnyJNu2bfMIxyZCoVBI13YfHx/g7PV3pG0MJGai7FDcoC0tLVIaHJfLxZkzZ6RMMaN9twPbNZvN7Ny5U/r8k08+GfSsJ/ULA+vUaDRMnDiRVatWUVNTw3vvvUdvb++ouVGbzcaxY8fIy8ujv78fo9EomYFlZGRgs9loaWnh73//O/39/TidzjHNJD3Q1ExcS+J6sdlsREdHS9y7n5+fZEE1MDLbcBv8xgHwlqu8yOVyQS6XCz4+PsKyZcuEL774QrjlllsEPz+/K963r2ORyWSCyWQSbrvtNqG6ulr4r//6L+H6668XVCrVFenLV9GGTCYTFAqFoFAoBLVaLajVasHPz09YvHixcNNNNwkffPCB0NXVJWzfvl2YPXv2Bfs1FMj+l2h9ozCSkIxeeOHFxSE612zZsoXDhw/z9ttvs3Hjxq9EJHClMNCTD87efETLEJPJxHe+8x3WrFlDREQEn3/+OevWrTuPOx8SeR1DhvSKgX8DzsFbvOWbVHx9fYV169YJ/f39QlFRkeDj4/OVcKT/bkUc8zvvvCN0d3cLTz31lKBQKC76/FDg5YS98MILL8YIQyGv30jF3DfwXPHCCy++oRie25AXXnjhhRcehZcIe+GFF15cQXiJsBdeeOHFFcQ3UibsVcx54YUX/w4Yin7Kywl74YUXXlxBfCM5YS/OR3R0NHv37j3v80mTJnkkWaEXXy38/Pz44Q9/yN133w0gZTLx4muIsXOZuHJgBEbYKpVKOHbsmFSMRuMVMQZ/7LHHhMjISI/VN2fOHOHYsWNCbm7uBefq5MmTQnh4+BU3gveW4ZWYmBihubl5VGveW8a+DAVeThgwGAy8//77ZGVlSZ99+OGH3HbbbbS0tHylfbnxxhv5/PPPh5Rt+HJYvnw5zz777KBxnYvMzEw2bNjA/fffT1lZ2Yjb+sEPfsA111wz6LO+vj42b97M22+/PeJ6h4uwsDBeffVVHA4Hq1ev/sravRT++Mc/kpSUdN7nxcXF/OhHPxp2fcnJybz88stSfsBVq1Z5opteXCF4hAjLZDIp+6sncdddd5Gdnc3DDz/s0XoHQqfTcc0117B8+fJBny9duhS9Xj9m7V4If/rTn0hLS0OlUnmkvtjYWLKzs+nt7eXQoUP885//HPT9yy+/jEKhYOHChfj5+Y24nR/84Af8x3/8B+PHjx/0ud1uJykpiQULFiAIAvfdd9+I2xgK4uLieP755/nWt751RWMavPLKK4OUw9dffz1BQUHnPXehz4YCk8nEggUL6O3t5Qc/+AHbtm0bcV+/bjh3bkW88cYb7N+/32Pt+Pj48MILL/D+++9LEevGClc9J+zn53dRIv/oo4/y/PPPDznf2Whxxx13cOrUqWFlw70Ujh49yv/7f/+P/v5+zpw5w+effz7o+5deeknKmjEaXHPNNecRYDibiiczM5PMzEwAGhoaeOaZZzwaIH8gQkJC+Pa3v01/fz/PPvvsJZ9dtWoVXV1dfPnll6NqMzg4mLVr1xIRESF9du+995733Ntvv41cLmfWrFnExcWNuL3x48dz//33A2cPuddff33EdV0MEydOZNasWYSHhwNns0zv3LlzVDelkcLf359HHnlE+vtCcwtnYx339vZy6tQpj7T55JNPct999xEbG/v1IsKCIPDEE09QVFTExo0b2bVrFz/72c+kRH6/+tWvuP7668/7XX19PT/84Q8pKSkBznIO4iY6ffo0ixcvpr6+nhkzZvDyyy9LCSxHi+DgYO655x4WLFhwwe9/8IMf0Nvby8svvzziJH5Dxb333otGo+GVV17xmAjkxIkTnDhx4rLPvfPOOyNOF34hVFdX89lnnwFnN0dqaiqzZs3i6aefpqmpiVdffdXjnGpsbCxr1qwBzga0//Wvf33RZ5cvX85jjz3Gjh07RkyEU1JSmD9/PmFhYdx9993Exsae98wbb7whpcT661//Cpy9YYkH1nAzPsNZUcQ999xDT08P//jHP0bU98tBq9Wydu1ali5dCpzN/ZaWlkZ+fv6Q6zh69OiQ1t6lEBwczP3338/TTz896PO///3v5x3kra2taLVa6b3A2VT2GzduHFGbjz32GHCWwXjggQd45ZVXPJ7FQ4IH9GACILS2tgrf/va3hYcfflhwuVyCIAjCxIkThZycHEEQBMHlcgmdnZ0X/P2CBQuE3/72t9LfLS0tgiAIwp133ilMmDBB6OnpEZxOp3DdddcJzz///JD6c7liNBqFW265ZUjju+eee8ZcUWe32wVBEIS4uLivRGFw3XXXCQ6HwyNt/uMf/xD6+vqEoqIiYfPmzcJTTz0lfadSqYRVq1YJx44dk+bTZDKNyXgEQRD6+vqEDRs2XPLZrVu3CoIgCE8//fSI2ho/frzwP//zP4PWiN1uFzZv3jyo+Pj4jNk4y8vLx3R9PPzww8LmzZuF06dPD2mPnIv//u//HlXsZr1eL6xZs0aqz+VySfOqVCov+BuTySQ8+eST0m9GMkfTpk274HhGGjd5KPAYJ7x8+XJuuOEGnnzySemzxYsX88gjj3DjjTeybNky6Vo6EL29vRw4cIAdO3ZInwUHB0v/v/nmmyVZ83e/+11efPFFHn/88VH3V+QoLoSjR4+SkJCAyWRCLpezatUq8vPzOXTo0KjbvRS6u7vH7rT9X8hkMtLS0ti8eTNwllsebQLT7du3YzAY+PTTT3n11VcHfedwONi6dSvp6emSgjArK4t9+/Z5jBsWM/T29vayY8cO1q1b55F6LwStVsvdd9/Nf/zHfwBn129BQQHd3d1jriALDg4mOTmZ3t5eTp8+fdHnJk2adMHbYkdHx5BFCn/961/561//ypo1a3jiiSeG3Mfx48fj5+dHUFAQYWFhIxatxcfHc8sttwBns1ocPHjwsvM7depU6VbrcDhoamoaVpsmk4n09HTpb0EQOHr0KHB2zbrdbk6dOuV5fcOIjrlzAAiPP/64sGDBAqG7u3vQd3l5ecJf/vIXYeLEicLzzz8v5OfnC5MmTRImTZok/Md//IfQ09MjqNVqiSsbiDvvvFN47rnnpL83bdokLFu2bEj9uVQxGo3Cfffdd97vysvLhfLyckGlUgl/+tOfhPz8fMFmswmCIAhPPPHEmHBwYrHb7cJbb70lBAYGjimHo1KphDNnzkhjHqsxKRQKITAwUIiPjxdSUlLOm2tPcvxLly4VDhw4IBw+fPiyz0ZGRgq7d+8WLBaL8Pjjjw+7renTpwsfffSRIAhnue6PPvpoTN/XwPLAAw8IgiBcdJxxcXFCfHy8UFtbe8F9sXPnTiEiImJM+zjaW4ZYFi9eLNTX1wuCIAjt7e2XfT4oKEj485//LI21qqpKuOOOO4bVpnjLEISznHdhYaH0nXhTnTdvnqBWq4dc51DgMSLc09MjvPDCC8L06dOFjo4OQRAEobCwUHrmpZdeGnS9GIhFixZdVBwxadIkobe3V3A6ncKqVasGPXep/gxlMYtwu91CY2PjBZ8deI3+9a9/Lej1eo8v3ICAAMFut48pkYezAanDwsKk8XR0dHg83Y9GoxECAgKE9PR0Yf369Rd9R5mZmZcMhj3UIpfLhYceekgQhIsTpwu9z48//liYN2/esNv7+9//Lo1h8+bNY/q+zi2XIsLiGhIEQXA4HILZbBba29uF9vZ2ob+/X+rzUOZopMXX11fYvn274HQ6hZ/97Gejri87O1uwWCyXJMK+vr5CQECA8NZbb0ljtNvtwo4dO4bdnkiE3W630NDQMOg7cW4FQRCysrKGXOdQ4FG35UcffZR77rmHRYsW0dzczJNPPkl6ejqTJ0/mrbfe4he/+MUFf/fWW29x6NAh0tPTmTRpkqTEAJg3bx6rV68mPT0df39/vv/973uyywA0NzdLmuBzYbfbJRHBE088wQsvvODx9tvb2z1mlnYp+Pv709jYKP0dGhrqMUsMEXfddZeURPWBBx646HMnT55k6tSpqNVq5PKRL8P4+HhSU1Ol7MdDxZYtWy7oQXgpKJXKUfV1NBCTwwr/m6h2IDQajbSG7HY7e/bsITs7m8DAQAIDA/n1r3+N0+kc8z5+8cUXLF26lFOnTlFcXDzq+qqrq/nVr36FTCZDrVYPsuRRq9Wo1Wp2795Ne3s7t912m5SBecuWLZJScagQE/AC5yk91Wr1qMdySQyJVH/NwBA5CkEQhLKysss+L16xBEEQ1q9f73EOQsRYc8KBgYGD5mkskjTef//9w35f995774jb++UvfykIwtC5UpETvueee4bd1sB1MJw2PVHEce7cuXOQh6NGoxnUp4utocuJMjxRRjO3Fyvx8fGCIAiC0+kU/uu//ktKL3QhJf/Pf/7zEbeTnZ0tvPvuu4IgCEJ3d7fwu9/9ToCzt8dz8W/NCX/dcOTIERITE690NwA4fPjwmHIr8fHxtLW1SX/L5XIcDofH2/nb3/5GdHQ0v/zlLwGwWq08++yzyGQyqZjN5kG/eeWVV9i8eTNz5szxeH/GEikpKTz44INfaZsWi0W6zQQEBGC1WqXvNBrNeXP7VaGyspKsrCxeeuklcnJyPF6/QqHgySeflFLdm0wm6buVK1cik8kuaxt+KUyZMoVvf/vbwFlF749//GMEQRhzRTkwRFL9NQOXOZ2GwxUcPHhQcLvdUt2e5ITVarUkaxoLWbNYsrOzpXZsNttXkqZcLpcLKpVKUKlU58l+xc+PHz8uzavb7RYcDsewFV3D4YRLSkoEt9strFq1SpDL5cMek1KpFF577bVBa83pdAp2u11oamoa0/m80DgDAgKkflxOWfTAAw8IW7Zsuah512jKwBgWK1eu9GjdIid8McyYMcMjCUflcvlFdVbnwuFwCMuXLx9SvUPBVc0JDwUqlUpykywrKxuWwfpQ6wfGhCuFs6aDX3zxBSqVis7OTkJDQ8esrYFwu904HA4cDsd5hvXi5wsWLMDf35+33noLmUyGUqlk5cqVI/JQWr58+SV/V1lZSUJCAjKZDIfDMSIOx+l0nvc7hUKBSqUiJCSEzs7OC5YLmWZ6AhaLhR/96Ef4+/tfUh7+5JNP8oc//AFBEMbktiXKTBctWiQ56XwVmDRpEkePHvVITkm3233Jufntb38rmXIqlUref/99br/99lG3CwyRVH/NwCVOphUrVgh79uwRBOHynPC+ffskEzVBEITnn3/eo04barVaqnusuNOBZjdDMfW5EiUwMFD405/+JPVzOHLLgQb6NptNqKysvGARHYgEQRCuvfZaj/V1KGhoaBAWLlw4qjm6GMd/ufX4m9/8RjCbzcKGDRuEkJAQj7+7kpISaW6HIyu9WJk2bZrwyCOPCI8//riwbt06QalUCnFxcVIZCE87Nul0OiEuLk6YN2+etJ7Edk0mkxAbGzvI/G8osu+h4Kojwk888YTQ19cnCMKlN/sXX3wxiAALwuhtH88tY02E16xZI5SWlgqCIAi1tbVCZmamx9u4UBHDZ3788cdD/o1IZAThLNH6yU9+MuTfBgUFCVlZWcI111wjvPHGG4PeWXZ2tpCVlTXIfn00RBgQIiIihKysLOHRRx8d8posLS0Vrr/++hG3OVwFJCD88Y9/FFpbW4X169cLMTExY/KuRTHXddddN2qR2lNPPSUUFRUJDQ0NQmNjo/Dpp5+e98xAjJV3qVqtFrKysoQpU6ac911GRoZQUFAgCMJZW+TLKZWHgquOCN99991CSUmJIAiCYDabhVdffXXQ91u2bBG2bt16nvPIn/70JyExMdFjL9pgMAjbtm0TBEEQVqxY4RG51rlloBWIxWIR/vnPfw7pd+vWrRO2bt0qlffee09Yt27dkNsVuW+LxSJs3bp1SMR4IBG22+3CwYMHhz1ejUYjjB8/Xrj22mulIn731ltvCRaLRRCE0RNhsYSEhEjtrFmzRvjwww8vuS5HYzUgzs+pU6eEVatWXfLZBQsWCK+//rrQ0tLi8XU7sGzZskXSl4yWIK5YsUIKcSBi4P5UKpXnWad8VS7+55aBvgOXY8yGgqsuitru3bvJyMjgRz/6EX5+ftx0002DZEorV6487zd//vOfefHFFz0aRUqtVkvhM7du3eqxei8GnU7H6tWr+fvf/37ZZ6dMmcLkyZOlvxsaGvjNb34zoja/9a1v4Xa7eeWVV3jrrbfYt2/feTK8O++8k+uuu27Y9Z8Lm81GcXHxBW1U//SnP7F48WJ0Ot2o2xHR0tIihZFUKBQ0Nzezdu1aj9U/EP/6178YN24cq1ev5sknn2TmzJmDQgQArF+/HqVSSUJCAtnZ2bz22mseX7dwVia6fv16aa/88Ic/HGR5MxKUl5fT0dEx6LOB+1Mul/Otb31L+s4TbY4Uzz77LM8++ywTJkzwTIVDItVfM3CZk+xcj7lLYf369WPCSQzUbHu6brHcdNNNQnV19ajmsra2Vvj+978/rHaTk5OFp59+WvjDH/4wqK4tW7YIzzzzjPDLX/5yUDlx4sSg56qqqobFeQ+lzJs3T2hqahIEwXOc8LlFoVAITz/99AXncdeuXcL8+fNHVf/AddvZ2XnePIqy2T179gjPP//8mHHAA8Vov/zlLwWtVuuReq+77jpJX3MpeLLNkZahumcPBVcdJwyQn5/P559/fl4miHPxzjvv8F//9V8eD2OpUCgGxZ8dK+Tm5vLXv/6VhIQEfH19pYAol8LevXspLCyU/q6qquIvf/nLsNotKSnhmWeeISgoCJPJxI033ojBYGDlypUXvGkMRHV1NevXr2fDhg3DavNyePjhh/H19fVonefC5XLxzDPPSDbSA/H+++9fMujOUJCfny9l1FizZs1FQzx++umn7N69m56enlG1dyFoNJpBMX2fe+45j1nbbNmyBYCioqJLPjeWMamHim3bthEfH09kZCSxsbFUV1ePuK6rkgjv37+fp59+Grvdjl6vZ/HixYO+/+STTxAEgUcffXRM0hspFAqCgoJwu9188sknHq9fRFFRkbSgQ0NDh5T55C9/+cugiHajQVtbGw8//DCCIJyXRWLJkiWSaOD06dPSQXfkyJERiT4uh6VLl6LT6di3b59HYydfCCIxCQ0Npa2tDZfLxbFjx0btSLF//372799PYmIiSuX5W/ehhx4ac/dkHx8fKazAli1bPGIeNhBbtmyR5u/fGeIcZGdnM3Xq1FER4atSHDGwRERECIcPHx5UxsKg/dzi6+sr7Nu374peqa5k+fjjj6X5vpyiyRNl586dgs1m84gZ1VDLnDlzrvi12ZNFo9EIS5YsGdE++6aWhQsXXnL9DgWy/53MbxQulIPKCy++/PJLvve975GXl3elu/K1RHx8POXl5dLf3n12eQyFvF6V4ggvrk6IaW+8GD3OtWTwYuTwEmEvvPBiSBDDhdpsNgIDA690d74x8IojvPDCCy/GCFetOOIbeK544YUX31B4o6h54YUXXlxBeImwF1544cUVhJcIe+GFF15cQXwjZcJexZwXXnjx74CrVjHnhRffZCgUCrRaLX5+fphMJuRyObW1tfT29l7xmApeDB9eIvy/OJd7/jpbWMhkMuRyOT4+PsTExJCSkkJwcDAmk4mQkBDJ0L6oqIiSkhKqq6ulDfx1HvfXAeK7EdfbcOdcqVTi7+9Peno6kydPJi0tjfz8fPbv309xcTF9fX1fTXJKLzyGq54Iy+VyDAYDqampzJs3D51Oh0aj4cCBAxw4cIDu7u4x5y4UCgWJiYnMnz8fX19fDh06RG5uLt3d3SMiigqFAj8/P1JTU5k+fTpJSUn4+/sTEBCAv78//f39BAYGUlhYyLFjx9i2bRslJSX09/ePqP8ymQyDwYCvry8GgwGj0UhgYCBOpxO5XE5nZydtbW2YzWb6+vpwOp1jSuzFrM6XIkZy+Vl1iHA2scGY9UXsj4+PjzQ/AQEBhIWFodFoyM/Pp6ioaMjEWHy3KSkpTJ48mb6+PmQyGXa7HYfDcdUcot8kpukrI8LFxcVcf/31LFy4kJdeeumravaykMlk6PV6kpOTmTFjBj4+PphMJvR6PfX19RJxGsuXrFKpCA4OZvLkychkMvLy8pDJZCNuUxAEdDqdFDXNZrNht9tpb29Hr9ej0WgwGo2kpqaiVqtpaWmhs7OTxsbGYW9kmUxGaGgoiYmJpKenExkZicFgwM/PT0qSqlAoaG1t5ciRI+Tl5dHR0UFTU5PHibFSqcRoNKLX63G5XHR2dkrjEQlzUFAQgYGBBAcH43A4qKmpoaGhwaPco5i0VKlUSgdUWloaUVFR+Pv7ExkZSUREhERAm5qa6OjouOxciLeb2NhY0tPTMZlMFBYWUlVVNebR0640xBuEWq2WDnzhfxOX9vX1YbFYpKSynlxTIrEX/x2LQ3tMiPBnn30mZY0QsXnzZj788EP2798/6HOZTEZPT8+Qwix6GnK5HF9fXyZPnsySJUtITU1Fp9OhUCiYNGkSM2bMwGq1UlNTM6aEWBAEifi73W7pRY+UEAuCgN1ux2w2SwSms7OTnp4e6uvrUalUTJs2Db1eT3BwMOPH///2zju+rer8/29t2ZItS957O05sx9mQsDJJAgESaNmB8mV10AJtoS2FlFnobqHfAgHSlhFaCoWEkR3IdPZwhvfetmzJsi1LsqX7+yPfe352pocCLdHn9bqvxFf3nnXPec5znjmG4uJiHA7HsDl/rVbLRRddxKWXXsqYMWMwmUz4fD60Wq2QXfb39xMREYHRaCQ1NZVDhw7h9XqxWq1+4940Gg0Wi4Xs7GySkpKorKykpqaGjo4OPB6PGOOUlBQSExNJSEjAarVitVr9osiVN5uQkBCio6OJiorCbDajVCoJCwsjJiaG2NhYDAYDGo0GvV6P1+vFbDafNizlmfoYFxfHjBkzSEtLo7m5mcrKSkpKSnA4HIJQyRvKaMd1IOE5H88PBfIcioyMJCcnh9TUVBISErBYLLjdbhwOB7W1tbS2ttLW1kZzczN2u53u7m7cbvew2yJ/R51Oh0ajEZmkPR4PPT09Ym34lXnwW0n/B0mSuPvuuykpKRGEtaenh9jYWHJycsjJyfF3lSOCfEQcN24cixcv5tJLLxUxb71eLwkJCcyaNQuv18vWrVupra3F5XL5nRDLEzcpKYmIiAgaGhro7OwcVaBsSZLo6uqirq4Ol8tFY2MjCoWC3t5egoODMZlMhIaGEh0dTUREhJjUQUFBgybaUBAaGsqUKVO47LLLxPs9PT04HA56e3tRKpVoNBokSSImJobg4GDcbjdWqxWn00lXV5fYeEYKlUqFxWJh0qRJXHTRRZjNZqxWKwaDgfb2drGpyW1JSUkhIiICm8121lTxQ4FSqSQoKIj4+Hji4+MFsQgJCSEkJIS+vj7B8avVakE4HA4HjY2NlJaW4nQ6z9l/hUKByWQiMzOTjIwMvF4v5eXllJSU0NzcLObLwA1lJJu4SqVCrVaj1+sJCQkRG4ROpxN19PX1oVQqkSQJn8+HWq3GaDSi1+sBsNvttLW1iW87Umi1WmJjY5kyZQr5+fmMHz+e5ORkLBYLAC6XC6fTSX19PS0tLYII19TUUFpaSllZ2ZDXkUKhQKPRYDabSU1NJTs7W/Tf5XJRXV1NVVUVjY2NOJ1Ov3LcfifCJSUltLe3s3LlSu677z4ANm7cyLx58876niRJ/PSnP6W4uJh3330XhULBt771LY4cOYJGoyE6Opr169f7rZ06nY7k5GSuueYa5s6dS1xcHEqlkt7eXvr7+9HpdOTn5wMnjvMul4uGhga/Dr68YDQaDWPHjiUmJoZDhw5htVoF9zYSSJKEy+WitbUVh8OBWq2mr69P7PIJCQk0NzcTFRWFx+NBoVDgdrtHxJUmJyeTlJREaGgo3d3dNDY20tLSQn19PW1tbfT39xMbG0t4eDixsbG43W6CgoIIDQ1Fq9UO4txGCqPRSG5uLvPnzyc9PZ3a2lo6OjrEZiaX73K56O3txWw2YzAY8Pl8I94AFAoFer2eqKgo0tLSmDZtGrGxsZhMJqKioujq6sLj8dDb20tTUxMAvb29YuNpa2ujtrZWbEbnglarJSUlhUmTJmE0GqmurubIkSPU1tbS09MjnpOJo6z883q9Q+6jLEaJiYkhOTmZxMREDAYDSqUSs9lMf38/arUan89Hf38/Xq8XnU6HWq3GZDKJIP0NDQ1s376dQ4cO0d3dPeyxhROipaioKK688kqWLFkiiKIkSXR0dNDR0UF3d7eY0xaLhejoaMaNG0d1dTUmk4nm5mZsNtuQNjiVSoXZbGbKlCnMmzePadOmER4ejtPpxOl0sn//fnbv3o3H46G1tZXe3l6/6Yr8ToQLCgp49tln+fOf/yyIcEtLC9HR0Wd8x+VycffddxMVFcWHH36IUqnkww8/xGazcfz4ccC/ofNUKhWRkZFcdtllXHvttSQmJqJQKOju7qa1tRWn0ynkpuPHj8ftdtPZ2Ulvby8dHR1+kb8N5Fi0Wi2pqamEhoaKnXa0hF6SJPr6+gTxletTqVQi00VaWhq1tbUcP36c2tpaHA7HsPqmUCiIj49HrVZjs9mw2+00NTVRXFzMsWPH6OjoQKFQ0NTUREZGBlqtlp6eHpqamrDb7ULkMhqo1WoSExO57LLLmDZtGi6Xi6NHjw5KHCmPpUxE5KMmMCIirFKpCA8PZ+zYsUydOpW8vDxiYmLo6Oigr6+PAwcO0NnZSXt7Ox0dHdhsNjQajeCCbTabGGuPx3POjV2hUIj6xo4di16vp6GhgaNHj9Ld3U1fXx8qlUpw+iEhIWKDk+WlMjd+rno0Gg0xMTHk5+eTkZGByWQiODiY8PBwtFotwcHBKJVKoWcIDQ0Vp4mgoCA0Gg12ux2v10t1dfWIibBerycjI4Mrr7ySvLw8JEmiurqampoaioqKxPjKisqMjAxyc3MxGo3ixPHFF19gs9mGVJ9arSYyMpKLL76Y2bNnk5ycTFBQEFarle7ubtLT06mvrycmJkaIOkZ7ghN1j7qEk1BbW8sTTzzB8uXLWbduHXPnzhUT/kxYsGABN9xww6Dssfn5+RQXF/Pd736XK664YlCm1dFAoVAI4rp48WISExNRKpU4HA5KSko4cOAASqWSjIwMIiMjsVgsTJw4kc7OThwOB/v27aO7u9svgy+XERoaSmJiIl6vl7q6OpxOp18VRXI98iJLTExkxowZREZGUlpaytatW0eklIMTG2xjYyMajQaHw0FLSwvNzc00NTWJ42p3d7cQg8hcYHt7+6ANYqTjKVu2TJ48Gb1ez5EjR9iwYYMQQ8iQ+x4XFye4OvmbDgcypzhz5kyuv/568vPzUalU7Ny5k6KiIurr6zl48CD9/f3Y7Xbcbrfoo0x0h2vJoFQqiYqKIjExEY1Gg9frxeFwiBMTnNhMQkJCSE5OJiEhgeDgYCRJorGxkaamJmw2myDYZ4IkSahUKrq6urDZbLS3t6NUKtHr9djtdgwGAz09PbhcLlQqFb29vdTV1dHV1YUkSUJmK3POwcHBI/q2srI8NjaW4OBgqqurqa6uZuvWrRw4cECcSGWGIT09nYSEBCIjIwkODsbpdAoR2FChUqkwGo1ERkYSFRWF1+ulsbERq9VKSUmJ2OBiY2NpbGwcNsNyNviVCLvdbjQaDUqlkmXLlvHYY4+h0+m49NJLAXjzzTf5/e9/D5xIWX3XXXcBMGfOHNavX88DDzxASEgIcCKK//Hjx9m8eTMbN27k0Ucf5dChQ5jN5lG1UZYJzps3j6lTpxIcHIzL5eLYsWNs2rSJnTt3AjBu3DgmT55MVlYWJpOJnJwcKioqqKmpoaenxy9KD7mMsWPHEh8fL47x/pY9y0RAo9GQnZ3NkiVLSEtLw+v1UlVVRUVFBd3d3cMm/DJ3sm/fPsG9t7S04HQ6SUhIEEfj7OxssrOzAYiKisJkMmE2m+ns7Bw1NxEVFcWYMWOIjo6mtbWV1atXU11dfdoyg4ODycjIwGKx0NTURE9Pz7CUNwqFgpiYGK655hpuvfVWJkyYgNPp5MCBA3z44YccPnyYxsZGwSUBgkNVKpWCcAy3z7KlRVBQEGFhYdTW1lJQUCC4TIVCQWhoKJMnT+aOO+4gPj4eAJvNRnl5OVVVVZSWlnLs2DHa29vPeIyWJInu7m4h4igtLSU6Ohqz2YxCoaCnpwelUklbW5sQCzgcDlwuFzExMXzve98jOjoar9crLBVGAnm+yptNQ0OD2Fzr6+vxer3iGYPBQExMDAkJCYSGhuJ2u2lvbx/2OtJqtZjNZkwmE3a7nePHj4uTeHV1NVOnTiU0NBS9Xo9OpxMmjv6AX4iwPCEOHz7MTTfdBMDtt9/O22+/za9//Ws+++wzAO644w7uuOOOU95/4okneO2115g3bx5r1qzBbDZTX1+P2Wzm2muvZcGCBXz00UfU1dWNmgibTCamTJnCFVdcQUhICD6fj+bmZj766CNWrVpFS0sL/f391NbW4na7MZlMGI1GIZeOjY2lvr5+1AodeXIolUouv/xyjEYje/bsEUc5f0OpVGKxWLjpppu46qqr0Gq1NDU1sWvXLmw224g5b6vVyu7du/F6vUI0kZCQgMlkQq/XYzabycvLIzMzU2iyJ0yYgNvtxmaz0dvbi8/nG1Gf1Wo1cXFxJCcno1AoaG1t5ciRI2fkUIKDgzGbzYSHh1NbW0tnZ+ewuJmgoCDmzJnDokWLSE9Px+PxsG/fPv7+97+zbt06sZENNGsaKHce6YYjK8tUKhV2u509e/ZQWVkp6tHpdMyZM4fHH3+crKwsnE4n7e3tuN1uEhMTMZvNxMXFYTKZ2Lx5s+BcTwev10t3d7dQeGk0GmFqKIs0ZMXcycpAhUKBVqulra2NpqamIZndnQ1KpRKPx0NJSQkFBQW0trbS398v6jMajUyYMIFvfOMbXHzxxahUKqqqqti2bRuffvop7e3twxpjnU5Hb28vBw4c4MiRI+zatYve3l50Oh1tbW1EREQI8ZHc3/8YcUR5eTkPPvggzz33HOnp6eL+8uXL+fe//z2kMh5++GGMRiOzZ89m7dq1HDlyhJ/+9Kdi8i5dupTx48ePqp0KhYLU1FQuuugikpOTUSqVtLe3s379elauXElra6uQmzU0NLBt2zaSkpIwm80YjUays7MFRzFaIiy3R6lUMmfOHDQaDfv27aOjo8OvRFhWOoSFhXHVVVdx5ZVXotPpsFqt/O1vf2P37t2jOlZ5vV7a2tooLCzEarWSkpJCTk4OGRkZREVFERISQlZWFr29vXR1dWEymUhKSqKpqQm9Xk9RUREVFRXY7fZht0Ov15OUlERSUhI9PT2C0zvTOMTHxzNmzBhUKhXNzc3DEkUoFAqys7MZO3YssbGxBAUFUV9fz/r169mxY8dpCZtSqUSn0wnCNVIbU6VSiclkQqFQUFNTI5x4ZOVgVlYWDzzwAOPHjxcbXWVlJR6PB71eLxxoenp6KCwsHJIFjLwpe71eIVKR236ymEe2fMnIyCA4OJi6ujoqKytHLA+WOfKDBw/icrno6uoSOgTZciM8PJzFixezZMkS8vLy0Gq1HDt2jDVr1rBq1SoqKiqGtY58Ph+dnZ1UV1cTFhYmFMsAkZGRGI1G7Ha7YMrkU54/4BcivHTpUpYuXXrK/aSkJB566KGzvjuwI/feey/33nsvAAsXLmThwoX+aJ6AWq0mPj6etLQ0IYYoKSlh06ZNg0yZFAoFfX19dHV1CeWKTqfDZDIRERFBUFAQnZ2do/oIcj3h4eFkZGTgcDioqanB7XYD/ttl4cRRa8yYMdx4440kJSXR3t5OSUkJu3fvHqTlHUmdkiTR29tLS0sLISEhwiNMrVYTHR1NQkICLpeL/v5+goKCsNlswlxx4sSJzJw5k8OHD7Nt2zaKi4uHJeoxmUyEh4ejUqmorKxk27ZtYvxOhsFgYOLEicTHx6PRaFCpVMPqr1arJSkpiYyMDGEJ0tTURE1NDXa7/ZSyZLMt2TRwNGIXpVJJSEgIoaGh9Pf3C5GGXq9n3Lhx3HPPPeTm5lJTU8OaNWs4evQotbW1aDQaMjMzyc3NJSgoaMSK0IHE93Seanq9nrvuuousrCxcLhcHDx6ktLR0VGaW8unI5/MRFhaG2+1Gr9ej1WqZPn06N998M0lJScTGxmK321m7di2ffPIJW7Zsoa6ubkSMjOwI4na7hfmqQqEgMzOT0NBQlEqlsMkejR3/ybig3JbDwsJIS0sjISEBgNbWVr744gt27twpJvZAyO6gssG9vBhk85fRQq1Ws2TJEsxmM4cPH+bAgQN+dwqRxQNLlixh7NixNDY2olQq2bp1K42NjYM479GYxMlH4KqqKiwWC1FRUcJWtLu7m4aGBhoaGnA4HOh0OlJTUwW3PH78eHJzc9m4cSNbtmyhpaVlSItINsXq7u6mubkZn8+HSqU6xdpAduS4/vrrycnJ4fjx4xQXF9PQ0DDkPstiK1lOGhERQUdHB263m7CwMFQqlZAFyx6DsueefIweqcjHYrFgsViEkrO/v5+QkBDi4+O57bbbmDhxIkePHmXbtm1s2rSJmpoarFYrWq2W5uZmtFot48aNIygoaEQODMBpuWA4sUamTJnCokWLCA8PZ8eOHezfv1+Y5Y0GsjdcamoqEyZMIC8vD7PZTFJSEhaLBaVSSWVlJaWlpaxdu5bPP/9cKO2GA9mrMS4uTugycnNzBfNgsViw2+2UlJSg1WqxWCx0d3fj8Xj8okC/oIiwbFiu0+nEhLZarYMUKTJUKpUwvo+KiiIoKAifz4dOpxtklzlSyEfJq6++GkmSOHbsGHa73W/eTnCCg4qMjOSKK65g9uzZhIaG0tXVxfvvv09RURE1NTVCBDCQwxkJN9zf309TU5NwLfX5fCQmJtLV1cX+/fspLS2lp6cHvV6PwWBgwoQJwInjrnykViqVBAcHs337dioqKs4pnlCr1cIhICcnh5qaGmw2m7BP9vl8REVFERYWxg033MD48eMFIerp6RmWhUJ/fz8lJSXs2LGDkJAQkpKSsNvt5ObmioXb2tqKSqUSyqLu7m46Ojo4cuTIiF2LFQoFOp1OcIXx8fE4HA4qKirIy8vDYDBw9OhRWltbWbVqFeXl5cJ6R5ZH+3w+YZUyUiJ8unbJcVcee+wx4Ya9detWSkpKzngiORdkK4SwsDDhAJOfn09+fj6JiYnExMTQ1dWFw+Ggp6eHgoICIRJqbGwcsShPni8Wi4WsrCxhXdLS0sKxY8cICwsjISGB3t5eYXygUCj84vBzwRBhhUKB2WwWdo3d3d3CFKe7u1vIeNRqNZIkERoaSnp6OlOmTCE5ORmDwYDVaqWtrW1UjhQyVCoVWVlZTJ06FZfLxfvvvy+4Un9xwjqdjrS0NObMmUNmZiZdXV2CwFmtVnp7ewe5mp5MiE/395naJss95cXe2tqKwWDg+PHjHDx4UBAh2UqjpqaG4uJiYYFisVgIDw9n5syZhISE8NZbb51TsdLT00NXVxcul4u0tDRuu+02ZsyYgcPhEBurSqUSFjGysX91dTWtra3DWjySJOFwODh8+DBBQUFMnDgRs9nM+PHjiYuLQ6PR0NLSQkJCAn19feJEIwdF6urqEiZqw5UNy7FFUlJSCAoKwul0kpubi91uZ9u2bSQnJwuTOzkanky8ZTdfj8dDc3PziIM0nQyZWH7jG99gypQpqFQqNm3axCeffEJtbe2wy5OZEovFQmpqqpC9x8fHk5CQINamLGqw2WwcPHiQAwcOsHfvXlpbW0fMlcrWJdHR0ej1esLCwoT8vaCggJaWFsxmM7W1tRiNRvLz84mNjaW0tJTCwsIRiz9kXDBEeKDzgs/nw+12C6cMs9lMR0cHPp9PGKuPGTOGuXPnkpWVRWhoKH19fbS2tlJfX09XV9eo26PValmwYAEWi0U4N4yUezgdZC44Ly+P5ORkXC4XNpuN1tZWurq6BBGSJ668CclHfKVSiVqtHrQ5yUb/Z6tzoOlOa2srwcHBdHZ2Cg5M1rI3NTXR2dlJRUUFY8eOFc4WERERtLa2Eh4efk4i3N3dTUlJCXFxcXi9XkwmEwkJCbS3t2Oz2YiJiaGsrAy73S7sc2VC2tzcPOzNzufz0drayo4dO2hubmbixInk5eXR3t6OVqtFr9fT2toqoqWFh4cjSRK33HILRqORnTt3UltbO2yFlWy62Nvbi16vp7e3l5CQEKHMrK+vF7blcp80Gg1paWlMnjyZ+Ph4Dh06RGVlpd/MHyVJIjIykm9961sYDAaKiop46623KC0tHTbHr1QqSUxMFA4XOTk5REVFAf8/doRer8dms9HR0UFQUBDd3d0UFxezb98+2traRhWDRJIkbDYbhYWFWCwW9Ho9SqWSw4cPU1lZydGjR4UnbUREBGPGjCEqKko44PT09NDe3j7iTeCCIcIAnZ2dWK1Wenp6CA4OFgFdUlJS8Pl8hIaGEhERQW5uLlOnTuXiiy8mKioKtVpNa2srhw4dorCwcNTEUvbYmz17NgqFgkOHDgmZpr+4YJVKRXBwsIga5vF4sFqtaDQaXC7XoEhfKpUKQHiSBQcHExYWhsViITg4GIfDQXt7O2VlZWdcYHJ5ISEhJCQkkJaWhkqloqKigpCQEKxW66B3B7pWR0RE0NvbK2JNREREEB8fT1lZ2VnHo6+vj/LycpxOJxUVFeTk5BAZGSlsSTdt2kR1dbVwmXY4HCLozUg2Unkjt9lsVFVVoVKpBFELCQnBYrGI6F7Z2dliQWdlZXH55ZcLB4jhEGFJOhGMSXYskd29ZTvZnp4eYerX19cnrDHGjRvHNddcQ25uLk6nk4aGhiHL2s8Fmcu++eabhTLu7bffFo5Mw0VYWBizZ89m+vTpJCYmEh4ejkajoaOjg5qaGgwGA16vd1AUtebmZhEvQv4GoyXC+/fvx263U1VVRXd3N/X19SIgkMvlQqPREB8fT1BQEKmpqUI0IovBRtqGC4oIezweWlpaaG9vJzExkcjISJKSkpg5cybTp0/HYDCQmJhIdnY2qampREZGolKp6Ozs5MCBAxQUFIgFPhrodDomTJhAdnY2Xq+Xzz//HJfL5adenoAsr5Mjs7lcLsHZZmdn43Q6yc7OFhyEHIBF1kZHRERgMBgICQkRXlFKpZJDhw6dtU7ZNjg5ORm9Xo/D4SA7OxuXyyW0ynLsAdlLKTExkZSUFKKiotDr9Xg8HrExnA2yXL+qqor29naKi4sxGAzCckUOIiSLDS666CIqKipoamoa8UY6UOwy0HMrLCwMs9lMdHQ0kZGRBAUFodVqMZlMdHd3CyN/ObzlcBarbN7X0dEhGAU5AmBTUxNBQUHU1dWRlZVFdnY2JpOJyy67jHHjxglrhQMHDgwpjsJQER8fz5IlS9BoNKxfv55PP/2Utra2YXODCoWC2NhYpk6dytixYwkJCRExKHw+Hw0NDQQFBQm7c4VCQUdHB0VFReJUMRqlJwzeXIuKimhubsbr9YqTk9frFSIevV4v9AlGo5H09HSqq6tpa2sTNv7D/b4XFBHu7++nsbGR8vJy0tLSMBqNTJ48meTkZAARMi88PJzg4GD6+/uFvfCGDRs4dOjQqJVysqXFxRdfLOwRS0pK/B4HdaCYwev1iqA5qampJCYmCs81eWIbDAb0er2QjxsMBqFgCwsLo7q6msTExDMSYVk5J3Mlsgtofn4+FouF+Ph47Ha7iC0sK+kyMzOZPn06GRkZGI1GoYQaqvWJLFqyWq3YbDZUKtUgBwlZvAKI+CDnEqsMBbJiqq+vTzgzyKEpZS/LsLAwdDqdkMV2dHSc1VHiTOjv76eqqooDBw4Ibiw+Pp7w8HCysrKEqEg275PDefb09LBhwwY+//xzysrK/GbbHhQUxMyZMxkzZgxWq5X333+fmpqaEZmkyZYJwcHBghGQuXw5ZoVGoxFil5aWFhoaGti7d6+IEugPCwVJkoSjiuyW7fP5Bo2ZHHa3p6cHu91OeHg4FouFzMxMkV5qoJnrUL/zBUeEa2tr2b17N3FxcULAHhERIXY5eRL09vZSXl7O1q1bWbt2LUePHqWtrW3UXLBGoyEiIoL8/Hw8Ho9wMPAnAQaEW2lpaSlZWVmkp6cTGRkplFM5OTki3oAsK/d6vfT29gqvII/Hg9PppK2tjbKyMhoaGs5aZ39/Pw6Hg7q6Oqqrq4VtbUpKCvn5+YO8j2TilZCQQExMjOCOZQ+8xsbGYY2JvAnIyj/5XdmLy2QyASeUeaNVrMqLTKvVEhERQVRUlPBIy8nJIS0tDTjh0eX1eoV500hd3iVJorm5mYMHD6LVaunv7ycmJgaj0YjBYCAoKEjYAcsmczKhWrt2LceOHRsR8T8dNBoNWVlZXH/99Wi1WjZv3syuXbtGfJKTJInOzk4qKyuFCEx2C3a5XCIUaG1tLWVlZTQ3N1NbW0tDQwM2m82viQEGntJkoizfl9Hf34/b7cZut2O324UuQI5DLm/uAU74DPD5fLS1tXHw4EFx9M3OzhbyYfkI7HA4OHLkCBs3bmTTpk0UFRXR1dU1agIsy9Jk07fOzk4KCwuHHURmKJD7WlBQgF6vx2q1MmnSJGH4Lh+TnU6nCDQjH3sdDgednZ1i1z969CiVlZXntP2URQDFxcVotVoaGxsZN24cubm5ZGRkiCO5fGSTib3s79/Y2MiRI0f49NNPRzUmJ3t0GY1GYVUgK1BGE0JTltPK1iUREREiiIwc71aWb7e2trJv3z62bNkyIhtWub6+vj4aGhrYvXs3drudtLQ04uLihNOGPLfkTbOqqorCwkIRB8IfhEr2vFy4cCFTpkyhvr6ef/7zn6OWNTc2NrJ582ZqamqIjo4mPDwcnU4n5qTX66WmpobKykocDocIY+kPK6UzYaB+Rt7UB4ZElUOSBgcHi41i4IlrOHPrgiLCcCLIUF1dHVu3bhWLPzY2ltTUVMHJ1dbWsnr1avbs2UN1dbXwePIH5OwLsoLm8OHDflskA+Hz+ejp6REa8aKiIgoLCwkNDRVyUtlUbyDBk83wurq6RLjC5ubmIR3hZU6srq4Oh8NBWVkZhw4dYvr06YwbN460tDQhFpEnsmwiWFFRwb59+zh06JAQz4wG8sKRibAkSdjtdmFXPNoALHK6qKqqKhGQyGKx0NnZKWSInZ2dFBQUsHLlSo4fPz6q6Huy/LuyspL29nZqa2uJiYmht7cXl8slTPJkRd3AdD/+gCweyMnJYf78+Wg0GjZs2MDevXtHnYDA4XCwe/duDh8+TFhYGCaTSWQgkfskh+SUrRRcLtd5TUx7JucUOTqebHEjBxyTJEkwccOlFRccEZY1oQcOHKCmpoYDBw6QmJjIpEmTcLlcHD9+nIqKCo4cOeL3aGYykSotLWXDhg24XC4OHTrkt6PiyfD5fDgcDrq7uykvL2fjxo309/eL0KJqtVponWU30dNpeE/mCM7Vx76+PhFUvbKyksLCQmJjYxk3bpzwpuvo6BABWqxWK8XFxVRUVIgTx2jG42T7ZtkkTj59jDalklymw+EQtshy3jw5G4O8uW3bto3q6mq/KV77+vpob2/H4XBw7NixQWMlf5/zMZdki55Zs2YRHh5OU1MT7733nt/sjmWRmGyVoFQqUalU4ogv92sgR3o+cLbyZRFFR0cHDQ0NJCUlodPpRCAoORXScMdfIZ2vreQrxGgDhX8ZGGiXG8D5hclkYuLEiaSmplJYWEhZWdmIQneeCaeLiXw+CeJXgaCgIPLy8rjrrrtIS0ujurqaZ599lvr6+q9NH4cC+WSVnJxMWloa4eHh2O12SktLRbKCgfNqKGNzwXHC/yk4n7t5AIPR2dnJ9u3b2bFjxyB3Xn/hbKeHrwNkc8eUlBQRR2HDhg0icP+FBlkUJeuRZBv3kcaSCBDhAC4IfN1Twp9PyHqM5ORkkXOtuLj4giTAcGIudXd3U1NTQ0tLixC/jVTkFBBHBBBAAOeEHJdahr9PE/+tOFfgqwtWHPE13FcCCCCAryn8lygpgAACCCCAYSNAhAMIIIAAvkIEiHAAAQQQwFeIr6VMOKCYCyCAAP4TMBT9VIATDiCAAAL4ChEgwhcIZK+uk08Jp7sXwOjwZY6nnDVarjPwLf/7ECDCXzPIcW5VKhVqtZrs7Gzuvfdepk2bxq5duygtLeWDDz7g6quv5rnnniMxMZFvfetbpKSkiIwNAYwM8tjL/5f/lm1sVSqV+Hs00Gg0TJgwgeLiYoqKinj66acJCQkRMUEC3/C/C36XCZeUlHDdddcxa9YsXn75ZX8Xf14QHBzMNddcw49+9CP6+vqoq6vj8ccfp6qqyq8ph84EOc5AXFwcra2t3HzzzezZs4fy8vJhG8TLkcMiIiKIiYnBYrFgNBp57rnnREDsGTNmkJKSgt1up7Kyks7OTvR6PVqtVmT1HW6f5SwZmZmZ5OfnExoaisPhQKFQUFVVxcKFCzl06BC7du2ioaFBZLb4Ohj8D+RC5ewlclDw/v5+kUAyOzubsLAw7Ha7yNj861//eshjLZefnJzMbbfdRllZGdXV1UyaNImxY8dSXFwsosQF8N+DURHhtWvXsmDBgkH3Vq9ezQcffMD27dsH3Zej0huNxmHV8eSTT/LYY4+JCEX+htls5rvf/S4TJkwgPT2d7u5uenp6+PWvf82jjz5KfX29SJ9yvia3vAi/853viIhuP/zhDykvLx9WOTIxUKlUaLVaJk6cyLXXXktiYiKJiYm0tbXR1NRET0+PSHR62223cfjwYZRKJTabbURhNZVKJd/+9re54oorMBgMxMXFYTAYcLvd9Pf3U1lZSVJSEu3t7ZSWloog5XLyT39tcgqFgvj4eH7961/zxRdf8PrrrwOITB9Op5PU1FSmTJkiEjg6nc5R1ylzuvIGplQqCQoKYsGCBVRVVXH77beTmpoq2gEnNh+j0Uh5eTkffPDBkOpSqVTEx8dzzTXXcO211+Lz+Th06BDr1q2jvr5e5EGTo8R9nYIIyaeKkJAQvF4v1157LVu3buWKK64gJiaGkpIS+vv76erqYs+ePfh8PtRqtd/Thp0PjJgIS5LE3XffTUlJiZhYPT09xMbGkpOTQ05Ojl8a+NRTT/HjH//4vBBhOTBJWloaWVlZIjdZdHQ0EyZMYMaMGWzfvp3m5uYv5WOmpKSQlJTEqlWrqKysHPHikRefSqUiOjqauLg49u7dS2VlJX19fRQXF9PR0YHJZOLiiy9Gq9WKRJEj4YDDw8PJzMxk7NixaDQaoqOjCQ4Opru7m/b2drKysujr6yMjI4Oenh5qamro7Oz0S7qdgUhOTuapp55i+vTpHDlyRBBGQASShxMxkz0ej+j3aMZZLlMmenKOvfnz57NgwQI2btyI2WwmLCwMpVKJ2+0mODiYhIQEmpqazplReiBUKhWZmZnccsstREdHU1hYSEVFBTt37sRqtQ6KkzyQO/+yiPD5qEulUqHRaAgKCsJgMIiTwNy5c9FqtWRmZmIwGDCZTLS2tqJWq8nJyeHdd98d1gYrE3m9Xi9Sc4WHh+P1emlsbKS7u5u+vj4RvtSf/RwxES4pKaG9vZ2VK1dy3333AbBx40bmzZt3xnd++9vfsmHDBtra2njqqae45ZZbANi7dy8/+clPRAd//vOfc8MNN/Dtb38bgBkzZqBUKlm/fj0//OEPKS4uxuPxkJSUxIoVK0R67OFCrVaLjLjyIjEYDCJV+e23305KSgpbtmyhsLAQm802onqGAo1GQ0pKCuHh4axZs4a6uroRpcEZyP3o9Xq8Xi/bt2/niy++4Pjx48TExNDT00NiYiIKhYLOzk7CwsJEsOzhQq1WM2fOHMaMGQMgcq1VVVVx+PBhrFYrqampWK1Wxo0bR1hYGFu2bKGiogKn0+m3wNxyiMHMzEy2bdvG1q1bxUbU399PX1+fGJtx48ZRW1tLS0uLCFY/mlOOLH4wGo3k5uaycOFCMjIyBEPS2dmJzWbD4XBQXl5OZGQkTqdTpB4aKsLDw8nNzcVkMrFhwwa2b9/OoUOHqKurQ61Wi0wTAzeHkfbruuuuY/z48fT29lJRUcGuXbtQqVT09PSg1WrRarXEx8dz8OBB0ffe3l70ej29vb04nc5Rc+FKpRKdTkdERASZmZkkJSWRmZmJRqMhMTGRW265ReSDO3r0KK2treTm5jJjxgw+++yzc2bUHhj4X85OHhMTQ15eHjk5OQQHB9PR0UFISAiNjY0cOHCAo0ePirx2/iLEIybCBQUFPPvss/z5z38WRLilpYXo6OgzvqNQKNixYweVlZVMmzaNSy+9lJCQEO6//34+/fRTYmNjsVqtTJ48mUsuuYRXXnmFV199lZ07dwpu+49//CMREREAvPDCCzz99NP8+c9/Hnb71Wo1kZGRTJkyhTFjxmAymcQx0uFwoFKpuPzyy0lKSkKlUtHc3HxeiLDMucycOZOkpCSR8Xg0qXcGJr9sbGzE4XBQVVVFc3MzSqWSnp4ecnJy6O/vJzQ0FIPBIAK7D5ebCQoKIjk5GbVaLcL59ff309raypo1a0T6pM7OTiZPnsyxY8eIi4sjMzNTiCT8gaSkJBYtWkR7e7vIcSfHbFYoFCJLQ1BQENnZ2SQkJNDV1UVhYeEpMWCHAjmdUGhoKEqlkoiICCZOnEhGRgaXX3652LS7urrweDy4XC6qq6upr68nJiaGqqoq1qxZM6wMH2q1Gr1ej9vtZvfu3ezbt4/m5mb6+/sxGo24XC60Wq2wmABE3r3hEsTU1FQWL16MxWKhpqaGvLw8IeMPCQlBpVKRnZ3N2rVrgRNJcquqqkR6eDlDS19f34jm8sBM3LNmzWLSpEmYzWby8/M5dOgQ/f396PV61Go1ra2tgjGLjY0lLCyMnJwcXC4XbW1tpy1/IAGWk5eOHTuWBQsWkJGRQXJyMl6vF5vNRm5uLseOHcNoNNLe3k59fb3f5i2MggjX1tbyxBNPsHz5ctatW8fcuXOFdvZMuOeeewBIS0vj0ksvZdu2bYSFhVFZWcnChQvFc5IkUVJSQkxMzCllvPPOO7z11lsi/9TpnhkK5MW4ePFixowZg0ajoauri7a2NhwOB2q1mpiYGGJiYpgyZQrHjx+no6PjjB91ODh5AigUCr797W/j8/lobGwcdUYPOSXMjh078Pl8zJ07l+7ubhQKhUiO6HA4iI2NxWAwiJxdI+GEtVotR44cISIigry8PNRqNV1dXXR2doqcdEePHsXr9VJcXMyhQ4dITk4mIiICg8Hgl+OdTqdj0qRJfO9736OtrY2ioiKRd03mgGWrBEmSOHLkCDNmzGD+/Pm4XC72798/rISRcrr5uLg4kd4+MTGRhIQE7HY7//znPzl69CharZaOjg6MRiM+n4++vj4MBoOIR2u329Hr9UOuU6vVEhQUhE6nw2w2D8puLRMFlUpFQkICcIIwmkwmXC4XtbW1tLa2Djnd0dq1a4mMjGTevHmEhISwcOFCXC6XEDO2t7cTHx/P9OnT6enpobe3l6KiIvbs2UNISAgNDQ1s3bqVmpqaERFhjUZDTEwM8+fP57bbbsPn87Fv3z46OzspKioCwG63o9PpKCwsJDg4mLlz5zJ58mQ8Hg8TJ06kvr7+jOt14LeWRWpXXHEF9913nzgVejweMa5ms5mJEycKCcBXToTdbjcajQalUsmyZct47LHH0Ol0XHrppQC8+eab/P73vwfgwQcf5K677jptOfKiGD9+PFu3bj1nvdu3b+fPf/4zO3fuJDIyktWrV/P0008Pu/3yoE+dOpXp06ej0+nEsWvDhg0EBwej0Wi44oorSEpK4rLLLkOr1eJ0Ovn0009HraAbmL/K6/USHBxMdnY2ERERlJWViaPcaCBnLv7ss8/4/PPPhfxbTu/T09PDhAkTcDgcNDc343A4RpSPTCai8fHxZGRk4HK5hLLJ4XAQGRlJbW0tdrudzz//nPj4eGpqauju7kav16PRaEZskSEjJiaGpKQkYemxatUqqqurhRxYkiR6enowGo243W7S0tKIjY0VIqCDBw8OuS6Za5owYQIXX3wxNpsNnU6Hw+HgN7/5DU6nUxBMOJFxWaPRoNPpCAoKoq+vD7fbTWNj47AsGbRaLVdccQVLliyhtLQUu91Oc3Oz0GP4fD5hujZnzhxcLhfJycnk5+fjcDh4//33+eijj4Ysg7bb7SJha0NDAw0NDcyaNQtApPfJyclBo9FgNBrR6XRMnDiRhIQELBYLJSUlIjPycKFSqdDr9URHR3PFFVegVqtZsWIFb775JmazGafTKURq3d3dxMbGMn/+fObMmUNCQgItLS1YLJYhyYTlbxUXF0dqaqqYMy6Xi8LCQt5//32+/e1vk5WVRWtrKzk5ORw4cECMuz8wLCJcUFAgklPedNNNANx+++28/fbb/PrXv+azzz4D4I477uCOO+445f0VK1bwxBNPUF1dzfbt23nppZcwGo2UlZWxefNmZs+eDcChQ4cYN24cWq2WkJAQOjs7MRqN2Gw2QkNDsVgseDweXn311RF12mAwcNFFF/Gtb30LnU4nJvHBgwdZtWoVpaWlPPbYY5SWlqLT6UhMTCQ/P5+JEyeyc+fOYSlThoLExESRMPD555+nrq5u1GXKySbl465Go8HtdhMeHk5kZCS33norcXFxREdH89lnn+FwOEY8qcaMGUNkZCRer5e2tjYaGxuJiorCYDCg1WqJiorC7XaTnp5OaWkpN910Ezt37hRExOfziczLw4VKpSI1NZXLL78cnU7Hhg0bOHTo0GlTzMj50CZPnkx8fDwbN24UCV+H2vfg4GASExOZPn06V111FQcOHGDt2rXs2bNnkGWJbKng8XhQKpW0t7cLGTj8f6XeUPssZwRXq08s2crKSjo6OsQmI5/cPvzwQyRJoqqqiri4OJHdure3l/LycgoKCoakEO3s7OTDDz/ko48+QqlU4vV62bJlC2FhYfh8PnQ6HUlJSVRVVfHNb34Ts9nMpZdeyqRJk+jr62Pz5s1UVFSMKAmonJE8Ozsbm82GJEmUl5eLnIhyfkKr1YpGo+Eb3/gGOTk5uN1u3G43SUlJzJs3j1deeeW05Q9UpsqKv9DQUMLDw+nv76exsZGWlhbq6+tpb28Xp7rMzEzghAVYU1OT3xSRwyLC5eXlPPjggzz33HOkp6eL+8uXL+ff//73Od/X6XRccskltLW18dJLL5GYmAjAxx9/zCOPPMLDDz9MX18fSUlJfPTRRwD86Ec/Yvbs2QQFBbF+/XoyMjKETG/GjBmsW7duOF1ArVYLcUhsbKwgwr29vTz22GP09PTQ39/PsmXLSE1NZdmyZZjNZsLDw1m6dCmdnZ28+OKLflMmSZLEpEmTMJlMrF69muPHj486eeJA+Z+sWZZNoh566CGcTicpKSloNBpWrVrFxx9/TFtb24j65PF4eOutt+jo6GD+/PkkJCQwffp00tPT0ev19PT0MH/+fIqLi8XYHz58mMjISBYuXIjb7aakpERshMNtg8ViYdq0aVxyySWUlZUJOfTJkNOQq1QqXC6XEMXIcs6hQK1Wk5iYyIMPPsjixYupqqqitraWXbt20dnZKZ6T+yArHR0Oxymy0eH0VaFQkJ+fLzi97u5uscnJG1hKSgo///nPqa2tJSwsDIvFIuSmer2e8PBwxowZQ3V1NTU1NeesU56DSqUStVqNWq2mo6ODjo4O4MRJSxYLPPfcc5jNZp544gliYmIICQmhvr5+2CaWcGKMZWVcVFQUW7duZebMmcydO5dNmzaJzOBarRadTifSLl1yySVCXi6L287Uz4Ep6b1eLwaDgZycHCZOnIgkSdTX17N+/XoyMzPp6emhvLwcu92OwWCgtLR0kMLPH4R4WER46dKlLF269JT7SUlJPPTQQ2d9V27oo48+espvU6ZM4fPPPz/te7/4xS/4xS9+If7+5z//Oej355577lzNHgSFQkF2draw4vB6vTQ0NPC73/2Ozs5OlEolSqWSvr4+ent7hTyvs7NTGNjrdDq/mKxJkoRSqeTJJ5/EaDTyyCOPDOJu/AFZyRcaGkpmZiYZGRk0NTVhMpnw+XwsX74cm802SLs+3PL7+vqIjIwUR9G+vj7B/ckTNy0tDYPBQFtbm1BkabVaioqKaG5uFhrq4YpizGYziYmJaLVaqquraWhoOOV9eTx1Oh3PPvsskydPZtu2bezYsWNYIoG0tDSef/55Zs6cSXNzM/v37+e9994THPDAetVqNZIkERkZSXd3NzabbcSp4bVaLePGjSM3N1dkji4uLsbtdmMwGBgzZgwffPABERERrFmzhpycHHw+H3/5y184cuQIs2bN4sorr+Tiiy9m+/btqNXqIcv/5e8rn6wGYqAFhrymIiMjeeGFF3j77bdHJLaTdSWyeNBqtbJixQohCtFqteTl5VFcXMzvfvc7Jk6ciM/no66ujtDQUHQ6HSUlJbz77rtnPGWcfEqSRSparVaMS2FhISUlJej1ejIzM2ltbaWgoIC6ujpxwhzJye10+FpGUTsT5MUYFhZGamoqADabjS1btvD222+j0+lwu93CSqC5uRmn04larUar1eJ2u0lNTWXOnDl8+umno26PUqlkxowZxMXFUVlZidvtFookf0Gr1ZKamsq8efOIi4sjLCyMiRMn0tnZyb333ktLSwvt7e2jMhXr7u5my5YtuN1uLrroIuLj4ykuLsZoNNLV1YXJZMJkMlFbW8sXX3xBWloa9fX1TJgwgf/5n/9h0qRJ2O122trahNnVUBawbB53zTXXCG5t4MJQqVSDUphHRUURERFBcHAwNTU1w84U/Ic//IGFCxfS3d09SA4rY6DjBpwQIVit1lGlaZe95GSOVxY9hIaGiqy/b7zxBqGhofzxj3+ks7OThx9+mOTkZJGKvb6+Ho/HQ3x8PE6nc0RtOdlyRh5bmZGYOXOmsLKpr6+nubl5RH2VJAmLxcL48eMxGo1UVVURGRmJSqXit7/9LeXl5axbt46XX36Z2tpaUlNTiY2Npbm5mRdffJGVK1cKLn4o31Y+Bff29uL1emltbcVmsxEeHo5SqRROMZ9//jl6vZ5vfetbAGzdunXEm+rJuOCIcHh4OGazGZfLhVqtpq2tjffff1/s+ANjL2g0GjQaDf39/ajValQqFXV1dRw5csQv7VGpVBgMBoKDg9m7d6/4qP40BJeTEnq9Xi699FIhG/7b3/6G1WrFZrMJI/+RmKjBiQVaXFwsvJlkpw+j0UhGRgYOh4NNmzZRV1dHWFgYhw4doqamhrKyMiIjI8UYmEwment7hZnZuYiF0WgkLi4Om83G6tWrWb9+vSAK8kYWHByMx+MhIyODqVOnEh8fj81mo6mpSRDToaKvrw+73U5RURHvvfceH3zwAT09PYNiRmi1WkJDQ4mPj+eKK65gzZo11NfXi7GFoX9fmahLkkRHRwfbtm3D6/Vit9upqakhMjKSsWPHolQqOX78OJmZmdhsNvG37EHo8Xj45JNPqKurG5FzyulOFj6fT8QamTRpEjfccAORkZF89NFHo1ofCoWC2tpa3n//fWEXbLFYmD59OpmZmXi9Xu666y4yMjLYtGkTkiRRWFjI22+/zfr168VJaqgbjSRJeDweDhw4wIcffkhKSgp1dXXMnDmT8PBwNm3axA9/+EPuvPNO3n//fd59911hK/2VyIT/myET1sWLF3PXXXeh0+koLS1l2bJlIpaBzA3KC8pkMvHOO+8QHx8v4iGYTCa/ZO6Vvat+/OMf09DQwD/+8Y/z4pUnWx/s2LGDxYsX09XVxaZNm3jppZdEkB/ZxEmeUCOZXC6Xi4aGBsLCwtDr9dTV1WG1WsnLy2Pnzp2Ul5eza9cuLBaLsApZtWoVubm54ho7dizjx49nypQp/PjHPz6nsT0gYjIEBQVRV1fHunXrMJlMou92u505c+ZgsViYNGkSVVVVWK1W9uzZQ0tLy7D6KEkS7e3t1NbWYjabmTNnDjt27MDpdGI2m8XYORwOlixZQkVFhcjCKxOF4Y6rTOC1Wi3p6ekYjUZWr15NdXU11113Hd3d3fz+97/nnXfe4ZlnnuHDDz+ku7tbyI2nTJnCVVddhUajYePGjURHR9Pa2jrsNgycG/K/fX19aDQaHnjgAeLj49m/fz+vv/46R44cGVY/BwY7UqlUxMbGCi/LgwcP8txzzwkl4/PPP8/999/Pq6++yjvvvCNOGp2dnYNESzJTMRR4PB5h7y6fgMeOHYtCoeD73/8+ra2txMfHM378ePLy8vjkk0+EktVut3+5MuH/doSHh5OWlkZERAR9fX0EBQUxbdo0Nm7cKCaaTLS0Wi0/+9nPmDp1Kunp6Xg8Htra2gQ3MVoolUqSk5PJzc0lNDSUTZs2+d2NV6lUEhUVxezZszEYDNTU1BASEsLy5cvJzMykoqKC4OBgwb0O5NaAQQvvXDIwWdMvexilpqaiVCrFMW7Tpk0olUqqq6uBE8TT5XJx+PBh6urqcLvdJCQkkJycTHR0NE8++SQ/+tGPztq/rq4uamtrqaurQ6lUsmDBAhITE5EkiSuvvJI//elPfP/73+e1114jPDycWbNmER8fLzTtw7X1VCgUhIWFkZycLI7bubm5TJo0CYPBwMUXX8zLL7/MfffdR0VFBQaDgaioKLq7u/F4PKe12DgXJEkiKiqK3NxcjEYj1dXVqNVqkpKSKC8v55FHHuEHP/gBf/rTn1i7di3V1dXCey0tLY3k5GSUSiW9vb10d3dTVVU17E124LMyk+Lz+YiJicHn85GWloZarebdd9+lsLBwRMyERqMhJCQEk8lEREQECoWCmJgYvve975GRkUFiYiJFRUU8+uij/PSnP+XQoUPCcgoQYkS5jcPpnxxoqb+/n8jISObPn090dDTt7e3s2rWLq6++mrq6OhISEsjMzOR//ud/sFgsdHZ2ilPmwG873PG9YIiwz+cTTgmyHK+2tpaVK1cOOorL5jc/+tGPuPrqq4mMjEStVtPX18euXbtYs2YNPT09o26PUqnEYrFgsVhYt26dX42/AXFMvOWWWwgKCmLPnj10d3cLn3pZthgdHU1HRwd6vR6bzSZ+O5kYDxRZnA79/f309PQIE67q6mo8Hg/p6em89957whlCtsP0eDxiXHt6eqitraWjo4OEhARcLpfwijwbvF4vK1eupLu7m6VLlwozrSlTptDX18ePfvQjdu3ahdlsRqfTERISgtvtpqOjQ5iODUc++sADD3DZZZeRlpaGXq8nIyODmpoaurq6mD17NuXl5dx8880EBQURHh5OYmIiMTExFBUVcezYMaxW67DM4eTnmpqaqKioYPbs2SQlJbFnzx46OjpITU3l+eefx+fz8dJLL6FUKhk7diw6nY7U1FTBQJSXl3P06FHhzThayGNmtVr5y1/+QmJiIk6nk7q6umGLeABhdtfb20tKSgqLFi1i+vTp1NTUcOzYMSZPnsxbb72FWq3m4MGDqNVqJkyYQExMDP39/ZSUlIxIqSzD4/GwY8cOioqKCAsLw2w2M2HCBLKysujt7eWll15i3LhxFBYWEhMTw9ixY7nxxhspKyujoaFBjKtM/Ifd/xG1+r8UsqKourqaqKgofD4fBoMBnU4nZMA33HAD8+bNY8yYMURHRwviLHMRtbW1fpnIOp2O733ve6jVapxOJ7GxscNWFJ0NMjeakpKC0+kkOTmZPXv24HQ6CQ4OFnaYR44cQa/X09HRQXBwsBAXyGMj23F3dXWdtW1KpZLu7m5qa2sxGAwkJiaSnZ2NxWIhKipKRPkaGNuir69PmCQlJycTHh5Oe3s7YWFhwuvrXOjo6OCzzz6jqKgInU6HTqejoKCABQsWsHr1auF5WVVVxfXXX8/u3btZsWIFBw8eHLaCqrm5mW3btlFYWEhSUhIpKSnCZtxut7NgwQKcTifx8fE0NTWxYsUKxo4dS3NzM+np6SiVStra2gTXNdT6FQoFR48eZfPmzeTn5xMfH09UVBQVFRWirI6ODvLy8mhsbOSmm24Sc8psNpOWlkZJSQkFBQV+iwSoVCq5+eabmT17NgqFgr/+9a8cPnx4RKfE6Ohobr/9dpxOJ7W1tbjdbhFWwOl0UlVVRVpaGk1NTcycOZO8vDxeeuklcQrq6uoalaWCz+eju7ub3t5eWlpa0Ov1VFRUEBoaKiKzbdiwga6uLubNm8e+ffsICwsjIiKC2NhYYUs8HLvvgbigiLC8Wzc1NZGQkEBGRgY/+MEPMBqNOBwO3G43l1xyieBklEolHo+Hrq4uPvjgAz777DOhyBoNFAoFBoOBmTNn4nQ6ee2112hvb/erQi4kJITY2FgsFgter5eIiAgmTZpEYWEh1dXVxMTEsHPnTmJjY/F6vRiNRtLT0xk7dixOp1OEHbXZbCQnJ7N582b++te/snjx4tPWJ2vve3p60Gg05OXlMW7cOFJSUsjOzuYPf/iDkJ/KmnWFQkFwcDBjx45l6tSppKSk0NLSwocffkhZWdmQ+ilJElarVSwCjUZDdXU1hYWFHD9+XGw6N998M263m+PHj1NWVjYi5xSv14vVaqWrq4vIyEjGjRvHZZddxu7du4Xbvhzg5b333iMpKYmIiAjGjRsnPBh7e3tFPImh9s/j8VBeXk5xcTGXX345l1xyCV6vl6ysLPbs2cPbb79NVlYWZWVlTJ8+nZiYGOGmbrVaKSgoYPPmzbS2tg7LPft0kEVTkZGR/OAHPyAoKIj9+/fzwQcf0NLSMqK1kZmZiVqtxmQyYTabMRgMJCQk4HA4OHr0KOnp6fh8PkwmEzExMSxfvpyoqCj27NmD3W4fNVMkj4e8oXk8HpxOJy0tLYPs19VqNS+++CJ5eXlkZWWRnJzM5MmT2b17t/A4HcnYXlBE2OPxUFFRQUFBASEhIaSnpzN37lwRa9bn8xESEoLH40GlUonJv3r1atasWUNZWZlf5LYajYbU1FQRrMcfcW0HQnatdbvdlJaWEhISQk5ODmazGYVCQUpKiojZIcsanU4n6enpJCYmDlJutLW1YTKZWLx48aD4HidDFjXYbDZqamqYMGECUVFRmM1mxo4dy3XXXUdubi5btmyht7eXiIgIurq6SE9PZ+bMmSJAi9Vq5eDBg0MmwsAgG1a3201tba0IsiJJEl1dXcIGeffu3YJYjEQ2Knv2VVRU8Nlnn5GVlcXkyZNFAJvw8HD27t1LWFiYCO7T0dGB1WodccQ2WQFUUFBAVFQU1157LVdffTXh4eGYTCYSEhIIDg7m+PHjTJw4kZSUFKqrq2lvb6esrIwtW7ZQVVUliMRIibBMgC0WC/feey+ZmZl0dHTw6quvjmptNDY2Ul9fLwLySJJEWVkZOp2Oiy66SIjC0tPTcTgcREVF8cUXX1BRUeE3ZfbAMTnTOEmSRFFRERaLhbS0NLKzs+nr66O0tJTm5uYRc+MXFBGWvWHKy8uZOXMmarWa4OBg4ATnKMsog4KC8Hg8HDx4kA8//JCPP/6Y+vp6v4VdlAPAyPafISEhtLS0+NVJw+l0ChmvTqcjODgYtVpNVlYWHo8Hk8lER0eHCNknx7mV29DQ0CAi2tntdm655ZZzTjKv10tXVxclJSVs3bqVqKgoVCoVZrOZuXPnMmvWLMaPH4/L5UKv1+PxeDCbzcTHx2M2m2lpaWH//v20tbUNyavrdJAjyMmQbYfz8/PF2MqczUjGWnZ+aWxsxGq1UltbS15eHocPH8bn8xEdHY1Op2PatGl4PB5KS0spLS2lpqZGyISHy7nJopuqqirWrVtHSkoKS5YsQZIkxowZQ15eHk6nk4kTJ6LX62lra6OhoYGioiKOHj1KXV3dqDi1gdBoNMyZM4c77rgDvV7Prl272LVr16iU1bK1SUREBCaTSZiFulwuYdMu6wjkqHyyjN1fDhMnY6CSemB8bp/PR1RUFKGhoTQ1NWGz2dDr9cOKhncyLigiDCcCztTW1tLY2EhWVhZGoxGv1ysyEsCJkJyyLejatWtpaWnxixxYhhxsXavV8vrrr9Pf3z/IJtQfsNlsVFZWEhMTQ1dXl4j3q9FoqKioEHa8skegWq2mtraWnp4eurq62LlzpyBef//73xk7duyQxsDn82G329m1axf9/f00Nzdz7bXXAidkf7Nnzxa2uwqFArfbLdx629vbKSoqory8XERgGwkGjqHs7CCHzvR6vYMcDYYL+RvJduXt7e1s375dyLGPHj1KdnY2drtdcPY1NTW0tLQIG92RmKlJkiTiGmzdupVLLrkEhUJBbGwspaWlwmHBaDRSWlrK1q1bOXDgAO3t7cLyZTRBkhQKBVqtFovFwh133EFCQgJWq5W333571Ke4/v5+ysrK6O7uJj4+nurqajFWY8eOpaysDLfbzRdffIFWqx2V6GM4OFlBDSdsxTs7O8XpRqvVkp2dLeyyR4ILjgjLx/933nkHg8HA5MmThbeVy+WipKSEvXv3snHjRg4cODCiWLPngk6nE1GZfvvb357W1XY0kDmn4uJiGhoayMrKIjIyUnBDu3fvJikpiaamJnJzc4XsWz7eyX73ycnJrF27lpUrV9LR0THkcZBN1bZs2cLRo0dxOBwolUqmTJlCREQEiYmJwqtMkiSRYaK1tZWWlhZqamr8tunJ8RPa2tooKCigpKTELyaGMlG02WyCCIeFhaFSqbDZbDQ0NBAfH09DQwMtLS0i5ORIvrNMDGSPru3bt7Nq1Sq8Xi9xcXFs3ryZnJwcdu3aRVRUFF6vl4KCAvG9RyuGgBOnN5PJxCWXXMLFF1+My+Vi3bp1fP7556OyTJD7J68zeQ22traSkpJCVFQUn3/+OeHh4fz1r38lODhYRO77snLpyX2TLXoKCgpE+NSpU6dy/Phx1q5dK8zVhguF5M/V/x+Cc+1IcuyCGTNmiEA+brcbnU7Hiy++yNGjRwe5Pvp7iEJCQrj++uuZMmUKn376qQiMfT5x8piczC2eqY/D9fI6GXIAGDlU4EUXXURaWhput5vExEQ6OjrYuXMne/bsoba2Viwwf0A+PhoMBrZv384vfvELiouLqaur86sMXnYjVqvVzJgxQ7jthoWF0dDQgNPpHHFw8zPhbN/T35AD2I8ZM4bHH3+c2bNno9VqWbRoEdu2bRt1v+Sj/Ml26nJ26oGmX/5OLXQunDzOsu39zJkz+f73v09WVhYbNmzglVdeYdeuXaeYmg6prdLXEEDgusAvhUIhaTQaSa1WS0ajUfrJT34iXX755ZLBYPjK2/bfdqlUKikhIUG69957pZUrV0pWq1WqqKiQ4uLiJIVC8ZW373xeSqVy0KXRaKTw8HBp+fLlUnt7u+T1eqX+/n7p448/lpRK5SnvDwUXnDgigAsD0v+JZOBEgKFf/epXX3GL/nsh/Z95Vm5uLosWLaKmpobHH3/8nLbjXwdI0v/P2yh7jTocDoKCgoRCThbhjXgszhs7+hWC/4AdNHAFrq/TpdPppMmTJ0sbNmyQkpKSpJCQEEmhUHztOWFA9HFgXzUajbR8+XLJ7XZL//u//3vGd4eCC1ImHEAAAQTwZWAo5PVrKY74Gu4rAQQQwNcUI7cwDiCAAAIIYNQIEOEAAggggK8QASIcQAABBPAV4mspEw4o5gIIIID/BAxFPxXghAMIIIAAvkJ8LTnhAE4Pk8nEoUOHBt3Lz8/H4XB8NQ0KYMRITExk69ateDweEZwpgP9SnD+Xia8OjMAgW6PRSPv27RNXSEjIV2IYvnr1aik7O9tv5SUmJko/+9nPpH379kkHDx48ZawOHjwoxcbG+rW+hx56SPr444+lq6+++is3tP86Xjk5OdKRI0ckSZIkt9v9lbcncJ35Ggq+NE64pKSE6667jlmzZvHyyy9/WdUOCUajkX/9619MnjxZ3JOjfH2Z+Oc//8ncuXMxGAx+KW/BggX89Kc/JTU1laSkpNM+M2HCBHQ63ajr+sEPfsD8+fMxGAwkJSURExNDYmIiS5cu5eabbx51+f6GnLy1rq7uS6nvySefZOrUqYPulZSU8MMf/nDYZRkMBnJzc+nu7uab3/ymv5oYwFeE80KE165dy4IFCwbdW716NR988AHbt28fUhkKhUKk2Dnf0Gq1p7T3xRdf5OGHHxY5xL4MXHnllQQFBfmtvOTkZK644grgRFLGn/70p4N+f/XVV1GpVLzwwgv85Cc/GXEg9WnTprFo0SLmzZs36H5+fj7Z2dm8/PLLfOc73xlZJ4aBlJQUHn/8cbq7u3nooYfO+uy1116L1WrlrbfeOi9teeWVV0QCSzjxbRMTEwc9M5RkpicjPz+fn//851itVh5++OEvJQLfVw2dTsedd97JtGnTzvjM3/72tyHTlv80+J0IS5LE3XffTUlJiSCgPT09xMbGkpOTQ05Ojr+rHBXMZvMpxAlg6dKlLFu27Eslwv7G3r17+cUvfgGcCPL+xhtvDPr95ZdfRqVScdNNN/Gb3/xmxET4+uuvJy8vb9A9OTFqXl4e9957L62traIt5wNjxozhkUce4e6776ajo+OsRPi2225j6dKlfPTRR35tg0qlYtmyZQDce++9o8q2cCYkJSVx7bXXUllZydtvv+338gdi1qxZzJw5E4CGhgaWL19+Xus7HcxmM48++iiLFi0iNzf3jM9FRUUNYgJG016z2XzK/Hn66afPWxYPvxPhkpIS2tvbWblyJffddx8AGzduPIVLklFQUMCjjz4qohA988wzXHfddQD89re/ZcOGDbS1tfHUU09xyy23+LWtkZGR3HfffTzyyCOn/f2WW27hX//6FzU1NSIi1/nCPffcg06nY+XKlbS1tfmlzAMHDnDgwIFzPjfaOvPy8oiJiQGgqKiIrVu30tXVRXFxMZdddhl33nkny5Yto7Gxkddee+28BOPOysri7rvvpquri7///e9nffbWW29l4sSJoybCZrOZSZMmkZGRAZyIKywTYRkrV66kq6tr0L1x48aRlJTEhx9+OKz6srOzTzmxnS9cfvnl/PCHP2TRokUAVFdXD8v0c+/evUOae2eDvD5PZpJef/310xLEqVOnkp+fT1xcHHv27BkREZbrPPk7Njc388Ybb/glx+Qp8J867ARWrFgh/eY3v5Hy8vLEvVdfffW0z7a3t0vR0dHSjh07JEmSJK/XK7W3t0uSdEK59uSTT0qSJEkVFRVSeHi4VFtbO6Q2MESh+bRp085Z1u9+9zvppptukpKSks6rAN/j8UiSJEkpKSlfisLgmmuukfr6+kZdZ25urrRz504xXq+88sqg341Go/Txxx+L35csWSJpNBq/9iU5OVl65plnxFw51/OffvqpJEmStGzZshHVN2bMGOmaa66RHnjgAWnbtm2Sy+WSduzYIa1evfqUKyoq6pT358+fLz3++OPDrvf++++XJEmSbDabtHz58vM6Px544AFp9erV0uHDh4e05k63biwWy4jr1+v10tVXXy3K83q9YkzVavVp37nlllukwsJCSZIk6dixY9KECROGXe/ZaMLFF1887Lk7FPidCD/55JOS1+uVMjMzpbVr10r9/f3SihUrTvvsJ598Is2aNev0DQOpvr5e/H3ddddJ77zzzpDaMJTBCQsLk+66667Tvt/S0iK1trZKXq9X3PvBD34g6fX68zbpvywi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UqmUsrKyJEmSzmjl8sILL0h2u13661//OkhZ56+rtLRUKK6HIys9U1urqqrEJZsSngn+NucMCgqSrrvuOlG+1+uV/vWvf4l6goKChE18S0vLkL7nUBCIJ3waFBQUoNFoyMvLQ6vVivt2u91vsSRCQ0P5/PPPgbNzMaOtIyoqCoD6+nquueYav9dxujplLiEnJ4f77rvvnO6j7e3tg0Qxubm5fPTRRyxevPic9dntdl577TXWr19/zmc//vhjYmNjz/nc2dDe3s7evXupqanh1VdfFfdDQ0PZvHnzad/RaDTExMTwq1/9ipCQEF5//fVh1+t2u+nt7SU7O5vvfOc7rFmzBp/PR1lZGVOmTKGzs/OUd/74xz9y22238Y9//INf/vKX9PT0DLvecyElJQWlUsm1115LUVHRiMuR2zqSoEb+Qm9vLxs2bGDKlCniXnt7O9XV1eL3119/nQceeICoqCi/BRe7oInwmDFjeOONN7j77rtRq9WsWrUKgIsuuugUEcSLL77IypUr/Va3Wq1m0qRJACxfvvy8BQeRERoayq233npKUPfT4bbbbuPWW28ddK+rq2tISoo1a9bw9NNPs2zZMkwmEz/+8Y+56qqrhkRQZfT29lJRUTHk561WK1ar9ZzPud3uIZd5Nng8Hurr66mvrxf3NBoNV111lfh79erVg6KowQl9RFxc3KjqDgoKIjo6WvwtSRL79+8f9MyKFSuIjo5m6tSprFy5kpdeeona2tpR1Xs6fPzxx6jVal577TV27NiB0+kccVmZmZlfKQGW4XQ6TxnPgfjb3/7GjTfeSFRUFA8++CBOp5N33313VHVecER41apVpKamsnTpUkwmE9/85jeRJAmlUjloEQ3Eiy++yF/+8pdTLAz8hS8jpq3RaOSOO+7AYrGc89lJkyYxceLEQfc6OjqGVE9tbS1vvPEGarWaxx57jMzMTNLT0wX3d//995+y4dx5552DuPSmpia/a9j/9Kc/nddFrtVqueGGG8Tfp4ugVl5ePipiuGXLFv785z9z00038dJLL7Fr1y6sVuspMYW/+c1vYjQaz/u8lYP7vP7666cEKTrfePDBB4e08fobdXV1YjPPy8sjMzNz9IUOWbD1XwTOIac52VnjbHjllVekjIwMv8vSLBbLkNs70ms4/TwT6urqpGXLlg3bAyouLu60jjrPPPOM9NRTTw26Dhw4IH4vLi72q52pfA20Kx2NTHgo3/NMeOmll6SsrKxR1XPRRRdJBQUFktvtlvbu3Stt2LDhtHWdr3kLJ7wiZd3KU0895ZeYKrfccov05ptvShUVFUOal+fbsels1z333CNCMZzLPXsouOA4YYBjx46xbt065s+ff9bnVq5cyS9/+Uu/H+VCQkK48847/Vrm6XDs2DEhtwwNDR1SKNC2tjYOHTpEZWUlcCKE4QsvvDDsuhsbG3nuuecICgpCpVJxzz33APD444+f8Z2ioiJeeuml82pn+u9///u8nDxcLhevv/666OfJWLt2Lf/4xz8oLS0dVT0VFRX84Q9/YOHCheTn5zN37lzx28AQj+dj3soYGDf52Wef9Yu1zbvvvsvhw4eZN28eY8eOPeV3hUJBXFwcycnJ7Nq1y2+ipZHg9ddfZ8mSJf7hgrkAxREA27dvZ9myZajVasaMGTPI3KS8vJzi4mIkSeLhhx+mtbXV7/WHhoaydOlSfD4fn3zyid/Ll7F9+3aRbSA6OnpIioTS0lLef/99du3aNer6rVYr3/72t1Gr1UKOuWjRolPk7YcPH6a2tpY1a9ac99RXv/zlLzl69Kjfy3U6nXznO985pZ+bNm3C6XTy9NNPs2/fvlHXY7Vaee+99/j0009ZsmQJN954o/jtO9/5Dv39/aOu42zQaDRcffXVwAmZsORHe/Pjx49z/Pjx0/6mUCgYP348U6dOZcWKFV+6PfLJ2L17NyEhITQ2No66LIXkz1H8D8FQ7XpjY2P57ne/y5VXXinuvfnmm7z88svn9SPr9XpmzpzJz3/+cy677LLzVs9/IrZt2zbI4gTgueeeO+/eZzabjbCwMKZMmXJWxYu/IPdz8eLFNDU1nff6vgzodDouu+wyYQt8Pu3n/xuQnZ2Ny+US1hOnw1DI6wVNhAO4cHDw4EFCQ0O57rrrzgsnfCEgLS1NWK24XC6/5kP8umIo5PWCFEcEcOHhZGuPAEYOn893RpvoAIaPABEOIIAAhgSfz4fH48Htdgu5cACjR0AcEUAAAQRwnnDBiiO+hvtKAAEE8DXFBRdFLYAAAgjgPwkBIhxAAAEE8BUiQIQDCCCAAL5CBIhwAAEEEMBXiAARDiCAAAL4ChEgwgEEEEAAXyECRDiAAAII4CtEgAgHEEAAAXyFCBDhAAIIIICvEAEiHEAAAQTwFSJAhAMIIIAAvkL8PwLePBASROCeAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 333x233.3 with 77 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "\n",
    "\n",
    "# Define the plot with GridSpec\n",
    "fig = plt.figure(figsize=(3.33, 2.333))#(10, 7))\n",
    "gs = gridspec.GridSpec(7, 10, wspace=0.0, hspace=0.0)\n",
    "\n",
    "# Titles and labels for rows\n",
    "row_titles = [\n",
    "    \"Inputs\",\n",
    "    \"ks-ks\", \"ks-beta\", \"ks-cb\",\n",
    "    r\"$\\mathcal{N}$-ks\", r\"$\\mathcal{N}$-beta\", r\"$\\mathcal{N}$-cb\"\n",
    "]\n",
    "\n",
    "# Add row titles\n",
    "for i, title in enumerate(row_titles):\n",
    "    ax = fig.add_subplot(gs[i, 0])\n",
    "    ax.set_ylabel(title, rotation=0, fontsize=8, labelpad=16) # size='medium')\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.spines['bottom'].set_visible(False)\n",
    "    ax.spines['left'].set_visible(False)\n",
    "\n",
    "# Plot images\n",
    "for row in range(7):\n",
    "    for col in range(10):\n",
    "        ax = fig.add_subplot(gs[row, col])\n",
    "        ax.set_xticks([])\n",
    "        ax.set_yticks([])\n",
    "        ax.spines['top'].set_visible(False)\n",
    "        ax.spines['right'].set_visible(False)\n",
    "        ax.spines['bottom'].set_visible(False)\n",
    "        ax.spines['left'].set_visible(False)\n",
    "        if row == 0:\n",
    "            ax.imshow(first_instance_batch[0][col].cpu().numpy().reshape(28, 28), cmap='gray')\n",
    "        else:\n",
    "            key = row_titles[row].replace(\"-\", \"_\").replace(r\"$\\mathcal{N}$\", \"gaussian\").lower()\n",
    "            ax.imshow(images[key][col].cpu().numpy(), cmap='gray')\n",
    "\n",
    "plt.tight_layout(pad=0.0, w_pad=0.0, h_pad=0.0)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "kumar",
   "language": "python",
   "name": "python3"
  },
  "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
