{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9db76765-2e54-438f-a159-eb3e30dddb0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch import nn\n",
    "from torch import Tensor\n",
    "from torch import optim\n",
    "import torch.nn.functional as F\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b41b1021-0dd7-4b52-b682-fe7a3d731bf7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "%pylab is deprecated, use %matplotlib inline and import the required libraries.\n",
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/ebuild/installs/software/Anaconda3/2024.02-1/lib/python3.11/site-packages/IPython/core/magics/pylab.py:162: UserWarning: pylab import has clobbered these variables: ['plt']\n",
      "`%matplotlib` prevents importing * from pylab and numpy\n",
      "  warn(\"pylab import has clobbered these variables: %s\"  % clobbered +\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib as plt\n",
    "%pylab inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "44d25799-b9ae-4433-b4ab-6cd46932738c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train X shape: torch.Size([5452, 10, 1]), y shape: torch.Size([5452, 10, 1])\n",
      "Test X shape: torch.Size([580, 10, 1]), y shape: torch.Size([580, 10, 1])\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "# Device and seed setup\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "torch.manual_seed(42)\n",
    "np.random.seed(42)\n",
    "\n",
    "# === Load dataset ===\n",
    "data = pd.read_csv(\"spatial_avg_data-ERAsinglelevel_2020-24_daily.csv\")\n",
    "\n",
    "# === Extract relevant features ===\n",
    "s_data = data[[\"asn\", \"rsn\", \"siconc\"]].values\n",
    "\n",
    "# === Train-test split ===\n",
    "train_data = s_data[:5461]\n",
    "test_data = s_data[5461:6050]\n",
    "\n",
    "# === Scale features using only training stats ===\n",
    "scaler = StandardScaler()\n",
    "train_scaled = scaler.fit_transform(train_data)\n",
    "test_scaled = scaler.transform(test_data)\n",
    "\n",
    "# === Define constants for computing snow depth proxy ===\n",
    "A, B = 600, 300\n",
    "\n",
    "def compute_snow_depth_proxy(data):\n",
    "    siconc_term = (data[:, 2] * A) / (A - B)\n",
    "    albedo_density_term = (data[:, 0] * data[:, 1]) / (A - B)\n",
    "    return (siconc_term + albedo_density_term).reshape(-1, 1)\n",
    "\n",
    "# === Compute and normalize snow depth proxy ===\n",
    "train_depth = compute_snow_depth_proxy(train_scaled)\n",
    "test_depth = compute_snow_depth_proxy(test_scaled)\n",
    "\n",
    "mean_depth, std_depth = train_depth.mean(), train_depth.std()\n",
    "train_depth_norm = (train_depth - mean_depth) / std_depth\n",
    "test_depth_norm = (test_depth - mean_depth) / std_depth\n",
    "\n",
    "# === Convert to sequences ===\n",
    "def create_sequences(inputs, targets, seq_len):\n",
    "    X, Y = [], []\n",
    "    for i in range(len(inputs) - seq_len + 1):\n",
    "        X.append(inputs[i:i+seq_len])\n",
    "        Y.append(targets[i:i+seq_len])  # supervision at end of sequence\n",
    "    return np.array(X), np.array(Y)\n",
    "\n",
    "seq_length = 10\n",
    "X_train_seq, y_train_seq = create_sequences(train_scaled[:, 1:2], train_depth_norm, seq_length)  # only snow density as input\n",
    "X_test_seq, y_test_seq = create_sequences(test_scaled[:, 1:2], test_depth_norm, seq_length)\n",
    "\n",
    "# === Convert to PyTorch tensors ===\n",
    "X_train_tensor = torch.tensor(X_train_seq, dtype=torch.float32).to(device)\n",
    "y_train_tensor = torch.tensor(y_train_seq, dtype=torch.float32).to(device)\n",
    "X_test_tensor = torch.tensor(X_test_seq, dtype=torch.float32).to(device)\n",
    "y_test_tensor = torch.tensor(y_test_seq, dtype=torch.float32).to(device)\n",
    "\n",
    "# === Confirm shapes ===\n",
    "print(f\"Train X shape: {X_train_tensor.shape}, y shape: {y_train_tensor.shape}\")\n",
    "print(f\"Test X shape: {X_test_tensor.shape}, y shape: {y_test_tensor.shape}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "dc5c1444-cdc0-45d7-acbb-f3d78baa1e6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "# === Contrastive Loss ===\n",
    "def contrastive_loss(z_i, z_j, scale=0.05):\n",
    "    batch_size = z_i.size(0)\n",
    "    z_i = F.normalize(z_i, dim=1)\n",
    "    z_j = F.normalize(z_j, dim=1)\n",
    "    combined_z = torch.cat([z_i, z_j], dim=0)\n",
    "    sim_matrix = torch.matmul(combined_z, combined_z.T) / scale\n",
    "    labels = torch.arange(batch_size, device=z_i.device)\n",
    "    combined_labels = torch.cat([labels, labels], dim=0)\n",
    "    mask = ~torch.eye(combined_labels.shape[0], device=combined_labels.device).bool()\n",
    "    sim_matrix = sim_matrix.masked_select(mask).view(combined_labels.shape[0], -1)\n",
    "    return F.cross_entropy(sim_matrix, combined_labels)\n",
    "\n",
    "# === Data Augmentation ===\n",
    "def augment_data(x, noise_std=0.01):\n",
    "    return x + torch.randn_like(x) * noise_std\n",
    "\n",
    "# === 1D ResNet Basic Block ===\n",
    "class BasicBlock1D(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, stride=1, downsample=None):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv1d(in_channels, out_channels, kernel_size=3, stride=stride, padding=1)\n",
    "        self.bn1 = nn.BatchNorm1d(out_channels)\n",
    "        self.relu = nn.ReLU(inplace=True)\n",
    "        self.conv2 = nn.Conv1d(out_channels, out_channels, kernel_size=3, padding=1)\n",
    "        self.bn2 = nn.BatchNorm1d(out_channels)\n",
    "        self.downsample = downsample\n",
    "\n",
    "    def forward(self, x):\n",
    "        identity = x\n",
    "        out = self.relu(self.bn1(self.conv1(x)))\n",
    "        out = self.bn2(self.conv2(out))\n",
    "        if self.downsample:\n",
    "            identity = self.downsample(x)\n",
    "        return self.relu(out + identity)\n",
    "\n",
    "# === ResNet1DContrastive ===\n",
    "class ResNet1DContrastive(nn.Module):\n",
    "    def __init__(self, input_dim=1, base_dim=32, blocks=[1, 1], output_dim=1):\n",
    "        super().__init__()\n",
    "        self.in_channels = base_dim\n",
    "\n",
    "        self.conv1 = nn.Conv1d(input_dim, base_dim, kernel_size=7, stride=2, padding=3)\n",
    "        self.bn1 = nn.BatchNorm1d(base_dim)\n",
    "        self.relu = nn.ReLU()\n",
    "        self.maxpool = nn.MaxPool1d(kernel_size=3, stride=2, padding=1)\n",
    "\n",
    "        self.layer1 = self._make_layer(base_dim, blocks[0])\n",
    "        self.layer2 = self._make_layer(base_dim * 2, blocks[1], stride=2)\n",
    "\n",
    "        self.global_pool = nn.AdaptiveAvgPool1d(1)\n",
    "        self.fc_depth = nn.Linear(base_dim * 2, output_dim)\n",
    "        self.fc_params = nn.Sequential(\n",
    "            nn.Linear(base_dim * 2, 64), nn.ReLU(),\n",
    "            nn.Linear(64, 32), nn.ReLU(),\n",
    "            nn.Linear(32, 3)\n",
    "        )\n",
    "\n",
    "    def _make_layer(self, out_channels, blocks, stride=1):\n",
    "        downsample = None\n",
    "        if stride != 1 or self.in_channels != out_channels:\n",
    "            downsample = nn.Sequential(\n",
    "                nn.Conv1d(self.in_channels, out_channels, kernel_size=1, stride=stride),\n",
    "                nn.BatchNorm1d(out_channels)\n",
    "            )\n",
    "        layers = [BasicBlock1D(self.in_channels, out_channels, stride, downsample)]\n",
    "        self.in_channels = out_channels\n",
    "        for _ in range(1, blocks):\n",
    "            layers.append(BasicBlock1D(out_channels, out_channels))\n",
    "        return nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, x, x_aug):\n",
    "        x = x.transpose(1, 2)\n",
    "        x_aug = x_aug.transpose(1, 2)\n",
    "\n",
    "        out_x = self.extract_features(x)\n",
    "        out_aug = self.extract_features(x_aug)\n",
    "\n",
    "        depth_pred = self.fc_depth(out_x)\n",
    "\n",
    "        params = self.fc_params(out_x)\n",
    "        w = torch.sigmoid(params[:, 0:1]) * 2 - 1\n",
    "        b = torch.exp(params[:, 1:2])\n",
    "        c = torch.tanh(params[:, 2:3]) * 10\n",
    "\n",
    "        mean_density = x[:, 0, :].mean(dim=1, keepdim=True)\n",
    "        estimated_snow_depth = w * mean_density + b * depth_pred + c\n",
    "\n",
    "        loss_contrastive = contrastive_loss(out_x, out_aug)\n",
    "\n",
    "        return depth_pred, params, estimated_snow_depth, loss_contrastive\n",
    "\n",
    "    def extract_features(self, x):\n",
    "        x = self.relu(self.bn1(self.conv1(x)))\n",
    "        x = self.maxpool(x)\n",
    "        x = self.layer1(x)\n",
    "        x = self.layer2(x)\n",
    "        return self.global_pool(x).squeeze(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8a50fe4b-53b1-486e-b546-59ea00fef10a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Let's use 2 GPUs!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/asampath/.local/lib/python3.11/site-packages/torch/nn/parallel/_functions.py:70: UserWarning: Was asked to gather along dimension 0, but all input tensors were scalars; will instead unsqueeze and return a vector.\n",
      "  warnings.warn(\n",
      "/tmp/ipykernel_1327226/818470133.py:63: DeprecationWarning: Calling np.sum(generator) is deprecated, and in the future will give a different result. Use np.sum(np.fromiter(generator)) or the python sum builtin instead.\n",
      "  l1_norm = sum(p.abs().sum() for p in model.parameters())\n",
      "/tmp/ipykernel_1327226/818470133.py:68: DeprecationWarning: Calling np.sum(generator) is deprecated, and in the future will give a different result. Use np.sum(np.fromiter(generator)) or the python sum builtin instead.\n",
      "  l2_norm = sum(p.pow(2.0).sum() for p in model.parameters())\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0/500, Loss: 5.5031\n",
      "Epoch 50/500, Loss: 3.1988\n",
      "Epoch 100/500, Loss: 2.9486\n",
      "Epoch 150/500, Loss: 2.8568\n",
      "Epoch 200/500, Loss: 2.8226\n",
      "Epoch 250/500, Loss: 2.7685\n",
      "Epoch 300/500, Loss: 2.7700\n",
      "Epoch 350/500, Loss: 2.7358\n",
      "Epoch 400/500, Loss: 2.7299\n",
      "Epoch 450/500, Loss: 2.6937\n",
      "(580,)\n",
      "(580, 10)\n",
      "Training results saved to training_results.pth\n",
      "Data successfully written to average_depths.csv\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxQAAAHqCAYAAACdhAjRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAD670lEQVR4nOzdd3xT5fcH8E92uicdQFvKKpSyWmRvBFkOhiCIMn6IooisL6KADEVQQVFREAUEEcEBioBsCghFsGXvUQgjpU1LW7rb5P7+iPc2adbNapv0vF8vX7Y3NzdP05J7z33Oc46AYRgGhBBCCCGEEGIDYVUPgBBCCCGEEOK6KKAghBBCCCGE2IwCCkIIIYQQQojNKKAghBBCCCGE2IwCCkIIIYQQQojNKKAghBBCCCGE2IwCCkIIIYQQQojNKKAghBBCCCGE2IwCCkIIIYQQQojNKKAghFQLX3zxBQQCAeLi4qp6KNXO7du3IRAI8P3331vc9/Lly3jppZdQv359yOVyBAcHIz4+HpMmTUJubq7zB+sA7M/L/ieRSBAUFIQnnngCU6dOxcWLFytlHMePH8f8+fORnZ1t8Fi9evUwcOBAm4+t+/MJBAL4+fmhe/fu2Llzpx0j5m/+/PkQCAR62+rVq4cxY8ZYdZyCggLMnz8fiYmJBo99//33EAgEuH37tu0DJYS4BAooCCHVwtq1awEAFy9exD///FPFo3FNp0+fRkJCAi5duoT33nsPu3fvxqpVqzBgwADs2bMHWVlZVT1Eq7z55ptISkrC4cOH8cMPP+C5557D9u3b0bJlS3zyySdOf/3jx49jwYIFRgMKRxg6dCiSkpJw7NgxfPXVV0hLS8PTTz9daUFFRdu2bcPcuXOtek5BQQEWLFhgNKAYMGAAkpKSEB4e7qAREkKqK3FVD4AQQv7991+cPXsWAwYMwM6dO7FmzRq0a9euUsfAMAyKiorg4eFRqa/rSMuXL4dQKERiYiJ8fHy47UOHDsX7778PhmGqcHTWi4yMRPv27bnv+/fvj2nTpmHw4MGYOXMm4uLi0K9fvyocoX1CQ0O5n69jx47o0KEDGjZsiOXLl2PAgAFGn1NaWgqBQACx2PGn79atWzv0eLVq1UKtWrUcekxCSPVEMxSEkCq3Zs0aAMCSJUvQsWNHbN68GQUFBQC0F1AhISF46aWXDJ6XnZ0NDw8PTJs2jduWm5uLGTNmIDo6GlKpFHXq1MGUKVOQn5+v91yBQIBJkyZh1apVaNq0KWQyGdavXw8AWLBgAdq1a4fAwED4+voiPj4ea9asMbggLy4uxvTp0xEWFgZPT0907doVycnJRlNH0tLS8Oqrr6Ju3bqQSqWIjo7GggULUFZWprffgwcPMGzYMPj4+MDPzw/Dhw9HWloar/cxMzMTvr6+8Pb2Nvq4bopL9+7dERcXh1OnTqFLly7w9PRE/fr1sWTJEmg0Gr3nKRQKjBo1CiEhIZDJZGjatCmWLVumt98TTzxhcBHcvHlzCAQCnDp1itu2detWCAQCnD9/ntfPVJGHhwfWrFkDiURiMEvB5z1m06k+/vhjLFq0CJGRkZDL5WjTpg0OHDjA7Td//nz873//AwBER0dzqUkV78Tv3r0b8fHx8PDwQJMmTbiZNls0aNAAtWrVwp07dwAAiYmJEAgE+OGHHzB9+nTUqVMHMpkMN27cAADs378fvXr1gq+vLzw9PdGpUye9n4G1c+dOtGrVCjKZDNHR0Vi6dKnR1zf2d5udnY3p06ejfv36kMlkCAkJQf/+/XHlyhXcvn2bCxgWLFjAvUfsMUylPK1duxYtW7aEXC5HYGAgBg0ahMuXL+vtM2bMGHh7e+PGjRvo378/vL29ERERgenTp6O4uNjat5YQ4mwMIYRUoYKCAsbPz4954oknGIZhmO+++44BwHz//ffcPlOnTmU8PDyYnJwcved+/fXXDADm3LlzDMMwTH5+PtOqVSsmODiY+fTTT5n9+/czn3/+OePn58f07NmT0Wg03HMBMHXq1GFatGjBbNq0iTl48CBz4cIFhmEYZsyYMcyaNWuYffv2Mfv27WPef/99xsPDg1mwYIHe648YMYIRCoXMrFmzmL179zLLly9nIiIiGD8/P2b06NHcfkqlkomIiGCioqKYb775htm/fz/z/vvvMzKZjBkzZozee9G0aVPGz8+P+fLLL5k9e/YwkydPZiIjIxkAzLp168y+lx988AEDgBkxYgSTmJjIFBQUmNy3W7duTFBQENOoUSNm1apVzL59+5jXX3+dAcCsX7+e2y89PZ2pU6cOU6tWLWbVqlXM7t27mUmTJjEAmIkTJ3L7zZo1i/H29mZKSkoYhmGYtLQ0BgDj4eHBLFq0iNtv4sSJTGhoqNmfIzU1lQHAfPLJJyb3ad++PSOTyZjS0lKGYfi/x+yxIyIimM6dOzO//fYb88svvzBPPPEEI5FImOPHjzMMwzB3795l3nzzTQYAs3XrViYpKYlJSkri/gajoqKYunXrMrGxscyGDRuYPXv2MM8//zwDgDl8+LDZn49htH9/b7zxht62rKwsRigUMh07dmQYhmEOHTrE/Z0OHTqU2b59O7Njxw4mMzOT+eGHHxiBQMA899xzzNatW5k///yTGThwICMSiZj9+/dzx9y/fz8jEomYzp07M1u3buV+VvZvSldUVJTe321ubi7TrFkzxsvLi1m4cCGzZ88e5rfffmPeeust5uDBg0xRURGze/duBgDzf//3f9x7dOPGDYZhGGbdunUMACY1NZU75ocffsj9je7cuZPZsGEDU79+fcbPz4+5du0at9/o0aMZqVTKNG3alFm6dCmzf/9+5r333mMEAoHBv0NCSNWjgIIQUqU2bNjAAGBWrVrFMAzDPH78mPH29ma6dOnC7XPu3DkGALN69Wq957Zt25ZJSEjgvl+8eDEjFAqZU6dO6e3366+/MgCYXbt2cdsAMH5+fkxWVpbZ8anVaqa0tJRZuHAhExQUxAUlFy9eZAAwb7/9tt7+P/30EwNA78Ls1VdfZby9vZk7d+7o7bt06VIGAHPx4kWGYRhm5cqVDADmjz/+0NvvlVde4RVQFBUVMc899xwDgAHAiEQipnXr1szs2bOZ9PR0vX27devGAGD++ecfve2xsbHMU089xX0/a9Yso/tNnDiREQgEzNWrVxmG0V64AmCOHDnCMAzDbNy4kfHx8WFef/11pkePHtzzGjVqxIwcOdLsz8EnoBg+fDgDgHn48CHDMPzfY/bYtWvXZgoLC7n9cnNzmcDAQObJJ5/ktn3yyScGF8SsqKgoRi6X671eYWEhExgYyLz66qtmfz6G0f79vf7660xpaSlTUlLCXL58menXrx8DgPnqq68YhikPKLp27ar33Pz8fCYwMJB5+umn9bar1WqmZcuWTNu2bblt7dq1M/mzWgooFi5cyABg9u3bZ/LnyMjIYAAw8+bNM3isYkDx6NEjxsPDg+nfv7/efgqFgpHJZHp/F6NHj2YAMD///LPevv3792diYmJMjocQUjUo5YkQUqXWrFkDDw8PvPDCCwAAb29vPP/88zh69CiuX78OQJs6k5CQgHXr1nHPu3z5Mk6ePIlx48Zx23bs2IG4uDi0atUKZWVl3H9PPfWU0XSVnj17IiAgwGBMBw8exJNPPgk/Pz+IRCJIJBK89957yMzMRHp6OgDg8OHDAIBhw4bpPXfo0KEG+e07duxAjx49ULt2bb1xsfn/7LEOHToEHx8fPPPMM3rPHzlyJK/3UiaTYdu2bbh06RI+++wzvPDCC8jIyMCiRYvQtGlTXL16VW//sLAwtG3bVm9bixYtuJQb9r2IjY012G/MmDFgGAYHDx4EAHTq1AlyuRz79+8HAOzbtw/du3dH3759cfz4cRQUFODu3bu4fv06nnzySV4/jzlMhfQzvu8xa/DgwZDL5dz3Pj4+ePrpp3HkyBGo1WpeY2jVqhUiIyO57+VyORo3bqz3/pnz9ddfQyKRQCqVomnTpjh+/DgWLlyI119/XW+/IUOG6H1//PhxZGVlYfTo0Xo/q0ajQd++fXHq1Cnk5+cjPz8fp06dMvmzWvLXX3+hcePGDvl9AUBSUhIKCwsN0qoiIiLQs2dPg3QtgUBgMM6Kf5+EkOqBAgpCSJW5ceMGjhw5ggEDBoBhGGRnZyM7OxtDhw4FAL189HHjxiEpKQlXrlwBAKxbtw4ymQwjRozg9nn48CHOnTsHiUSi95+Pjw8YhoFKpdJ7fWPVZ06ePIk+ffoAAL799lscO3YMp06dwuzZswEAhYWFALTrFQDtwlpdYrEYQUFBetsePnyIP//802BczZo1AwBuXJmZmQbHA7QX/tZo2rQppkyZgo0bN0KhUODTTz9FZmamQQWfiuMEtEEJ+zOyYzL2PtWuXZt7HNBeTHfq1IkLKA4cOIDevXuje/fuUKvVOHr0KPbt2wcADrlAvXPnDmQyGQIDAwHwf49Zxt7TsLAwlJSUIC8vj9cY+Lx/5gwbNgynTp3Cv//+i6tXrxr9HQGGf6cPHz4EoA1eK/68H330ERiGQVZWFh49egSNRmPyZ7UkIyMDdevW5fWz8MH+rZj6e2IfZ3l6euoFQoD2/S0qKnLYmAghjkFVngghVWbt2rVgGAa//vorfv31V4PH169fjw8++AAikQgjRozAtGnT8P3332PRokVcGVHdGYbg4GB4eHiYXBgbHBys933FOvwAsHnzZkgkEuzYsUPvYub333/X24+9mHz48CHq1KnDbS8rKzO4MAoODkaLFi2waNEio+NiL86DgoJw8uRJg8f5Lso2RiAQYOrUqVi4cCEuXLhg9fODgoKgVCoNtj948ACA/nvaq1cvvPfeezh58iTu3buH3r17w8fHB0888QT27duHBw8eoHHjxoiIiLD55wGA+/fvIzk5Gd26deNmg/i+xyxj72laWhqkUqnJRe2OVqtWLbRp08bifhX/Ttn3/Msvv9SrgqUrNDSUqwhl6mflM7579+5Z3I8v9t+Mqb+niv8+CSGugwIKQkiVUKvVWL9+PRo0aIDvvvvO4PEdO3Zg2bJl+OuvvzBw4EAEBATgueeew4YNG9ChQwekpaXppTsBwMCBA/Hhhx8iKCgI0dHRNo2LLckpEom4bYWFhfjhhx/09uvatSsAYMuWLYiPj+e2//rrrwaVmwYOHIhdu3ahQYMGRlOsWD169MDPP/+M7du366U9bdq0idfYlUql0bu/Dx48QG5uLhISEngdR1evXr2wePFipKSk6P2cGzZsgEAgQI8ePbhtTz75JN59913MnTsXdevWRZMmTbjt27dvR1pamkH6jrUKCwsxfvx4lJWVYebMmdx2vu8xa+vWrfjkk0+4oPHx48f4888/0aVLF+53L5PJuNesTjp16gR/f39cunQJkyZNMrmfVCpF27ZtTf6slvTr1w/vvfceDh48iJ49exrdx5r3qEOHDvDw8MDGjRvx/PPPc9vv3buHgwcPcjOThBDXQwEFIaRK/PXXX3jw4AE++ugjdO/e3eDxuLg4rFixAmvWrOE6Eo8bNw5btmzBpEmTULduXYPUmSlTpuC3335D165dMXXqVLRo0QIajQYKhQJ79+7F9OnTLfa3GDBgAD799FOMHDkSEyZMQGZmJpYuXcpdOLGaNWuGESNGYNmyZRCJROjZsycuXryIZcuWwc/PD0JheUbpwoULsW/fPnTs2BGTJ09GTEwMioqKcPv2bezatQurVq1C3bp18fLLL+Ozzz7Dyy+/jEWLFqFRo0bYtWsX9uzZw+s9nTBhArKzszFkyBDExcVBJBLhypUr+OyzzyAUCvH222/zOo6uqVOnYsOGDRgwYAAWLlyIqKgo7Ny5E19//TUmTpyIxo0bc/smJCQgICAAe/fuxdixY7ntTz75JN5//33ua74UCgVOnDgBjUaDnJwcnD59GmvXrsWdO3ewbNkyLjUN4P8es0QiEXr37o1p06ZBo9Hgo48+Qm5uLhYsWMDt07x5cwDA559/jtGjR0MikSAmJkavx0dV8Pb2xpdffonRo0cjKysLQ4cORUhICDIyMnD27FlkZGRg5cqVAID3338fffv2Re/evTF9+nSo1Wp89NFH8PLystjocMqUKdiyZQueffZZzJo1C23btkVhYSEOHz6MgQMHokePHvDx8UFUVBT++OMP9OrVC4GBgQgODka9evUMjufv74+5c+fi3Xffxcsvv4wRI0YgMzMTCxYsgFwux7x585zxdhFCKkNVrggnhNRczz33HCOVSg2qD+l64YUXGLFYzKSlpTEMo61iExERwQBgZs+ebfQ5eXl5zJw5c5iYmBhGKpUyfn5+TPPmzZmpU6dyx2EY42U7WWvXrmViYmIYmUzG1K9fn1m8eDGzZs0ag4o/RUVFzLRp05iQkBBGLpcz7du3Z5KSkhg/Pz9m6tSpesfMyMhgJk+ezERHRzMSiYQJDAxkEhISmNmzZzN5eXncfvfu3WOGDBnCeHt7Mz4+PsyQIUOY48eP86rytGfPHmbcuHFMbGws4+fnx4jFYiY8PJwZPHgwk5SUpLdvt27dmGbNmhkcY/To0UxUVJTetjt37jAjR45kgoKCGIlEwsTExDCffPIJo1arDZ4/aNAgBgDz448/cttKSkoYLy8vRigUMo8ePTL7MzBMeSUm6FSrCggIYBISEpgpU6ZwFZsq4vMes8f+6KOPmAULFjB169ZlpFIp07p1a2bPnj0Gx3znnXeY2rVrM0KhkAHAHDp0iGEYbUWkAQMGGOzfrVs3plu3bhZ/RnN/fyy2ytMvv/xi9PHDhw8zAwYMYAIDAxmJRMLUqVOHGTBggMH+27dvZ1q0aMFIpVImMjKSWbJkCTNv3jyLVZ4YRluZ6a233mIiIyMZiUTChISEMAMGDGCuXLnC7bN//36mdevWjEwm06twZqxsLMNoS0Oz4/Hz82OeffZZg9/p6NGjGS8vL4Of2di4CSFVT8AwLtY6lRBCqrHjx4+jU6dO+PHHH3lXZyKV5/bt24iOjsYnn3yCGTNmVPVwCCHELVDKEyGE2Gjfvn1ISkpCQkICPDw8cPbsWSxZsgSNGjXC4MGDq3p4hBBCSKWggIIQQmzk6+uLvXv3Yvny5Xj8+DGCg4PRr18/LF682KDcJSGEEOKuKOWJEEIIIYQQYjNqbEcIIYQQQgixGQUUhBBCCCGEEJtRQEEIIYQQQgixGS3KtkCj0eDBgwfw8fGBQCCo6uEQQgghhBDicAzD4PHjx6hdu7Zec1Y+KKCw4MGDB4iIiKjqYRBCCCGEEOJ0d+/eRd26da16DgUUFvj4+ADQvrm+vr5VPBpCCCGEEEIcLzc3FxEREdy1rzUooLCATXPy9fWlgIIQQgghhLg1W1L8aVE2IYQQQgghxGYUUBBCCCGEEEJsRgEFIYQQQgghxGYUUBBCCCGEEEJsRgEFIYQQQgghxGYUUBBCCCGEEEJsRgEFIYQQQgghxGYUUBBCCCGEEEJsRgEFIYQQQgghxGYUUBBCCCGEEEJsRgEFIYQQQgghxGbiqh4AIcQyRY4CqgKVyceDPYMR6RdZiSMihBBSHSlyFDiffh7ZRdlGH/eX+6N5SHM6ZxCHooCCkGpOkaNAzIoYFJUVmdxHKpIicXQiOkR0qMSREUIIqU4UOQo0/rIxitXFZveTCCXY9sI2CiyIw1BAQUg1pypQmQ0mAKBEXYIu67rgu6e/Q4uwFnqP0ewFIYTUDKoClcVgAgBKNaUYuGkg5GI5rk66SucIYjcKKAhxE2pGjbHbxxpsFwlEmNNlDhoFNwJA092EEEK0isqKoCpQ0fmA2I0CCkKqOWWe0q7nqxk1FhxZoLdNJpLh2pvX6CRCCCEuTneN3WXV5SoeDampKKAgpBpT5CgweMtghx+3WF1Md6UIIcTFJd1NQvf13VGiLqnqoZAajsrGElKNqQpUdKIghBBiQJGjoGCCVBsUUBBCCCGEuBi64USqE0p5cgNqDYMTNzNx7GYG7j8qhEAgQJ0AD3RsEIz29YMgEgqqeoiEEEIIsYJuPwlVgQqPix/rPW6qzwQhVYECimqsYqDAEggECPeXw99DihTFIxy8ko5SNWPw/K8O3YSXTIRPhrRA/xa1K3PoxE7s7/7nc6lVPRRCCCGVSJGjwIHUA5iwfQLKmLKqHg4hvFBAUU3tvqDErK3nkV1Qatdx8ovVeH3Tabxy9xFmD2jmoNERR9MNHv+9/Qhn7+WguEyDYsE9QF7VoyOEEOIMuhWaAG1Vv0GbB6FUY9+5ny+pSIpgz+BKeS3i3iigqIZ2X1DitY0pDj3mt0dvQ8MAcwdSUFGdqDUMvjxwHasO30RRmaZSX/vc3Wy0DGUMUuIqnuAqokZ5hBBiP0WOAjErYiw2LnWmrcO30uc5cQgKKKoZtYbB/O0XnXLsNX/fRvKdR/jfU01obUUVYwOJrw7dQKnGMF3N6RgJ5my7gy/27MMHz8YhLqoMqgIVlHlKDN4y2OxCP6lIisTRiegQ0aESB0wIIdWLqbRkALzWMqoKVFUaTADadRgpyvIbmOwNI3M3ltQaBooMEW6myWz6uYl7EjAMUwVXM64jNzcXfn5+yMnJga+vr9NfL+lmJkZ8e8Lpr0NrK5xPrWFwMjUL6Y+LEOIjR0JUAE6lZmHDidvYf/kh1DwmJIoEl/FQ9g4gcFwerX/xBHgx7SFmQgAAZYJ0PPR4DWUM/2ohUpEU19+8Tne2CCE1jrUzy1KRAC3r+qG2v4feBbfU4w7aftemEkbMn0ggwptPvImv/v3KfNoVI0Gd4m+484gxMrEAE7s1wJu9GgMAF3w9yC6yO+hgg7mkWyoAAnRoEEQBjAPYc81LAYUFlR1Q/HHmPt7afMbpr8N6pUs9WlthJd0PMg0D+HlIkF1Yggc6d2oeZBfi/INcFJXansZUJkjHfdmrgMCBubSMCLVK5kDEBEAEX4iZEBQITyFDtsDycytInpCM+PB4x42NEEKqud0XlJj281kUlKh5P6dMkA41cg22a4R3kS5d5sjhVaqwouWQMQ0t7icEIBQKUGZkNt7am5tqDYMVB2/gmyM3DX4HugEMBRa2seeal1KeqpkQn8pdgVuZayt0p4cdcYeisuiO+1RqFs7cyzFaVcvhr4tcXsFEUPF0SJgIqPEIpYIHYASF0CAfjyXbAUGFk55AXR48MBKEFn+IDOkim8anzFPa9DxCCHFFtqxvdMqNIRejAaAxkdprTeGYXeeUmPnbOeQVG5+xLy5jsPzADXx7NBXLhrVE37hwe4dOrEABRTXTNjoQYb4ypOUWV9prrvn7Nk7dzkT9YB+E+8sR6ClDsI8MYb5ytI0OdMjFvqmqVdWxtG1VBRC2kjAR5XeJ/htmseAGHgu2mX+ioBQ5os02p1MN3jKY0p4IqWTmyom7yk2a6srcuoHSMg0m/3wJQJDedlOzDyy14FGNDib4+vbobQACzB4Qa/Txxbsu4Zsj/Mqo55eo8drGFKwaFU9BRSWigKKaEQkFmP9MM4dXebLk3L3HOHfvscH2QC8JPng2zq6LfUt3ddg7FAPOP8AXIxJ4nQjZ9QlpOYVQ5RUjq0A/5Qjgf4I1VbK1qqkFj5z+GkWSZJufW6IugapARQEFIZXE0h1aQHuTxt9TgiWDm1fZxZQrNlvlVXFJKEEdwTd6688szj4wdJllKehi02+/PZqK1hEB6N9C/+9217kHvIMJXW//dg69Y8Oq5d+bO6K/9Gqob1w4Vo2Kd0gfCntl5ZdafbGvq6RMg+k/n+W1787zD7H34l94o4fpHEh2Mdx3f99CXjG/HNavDt2EVAQMbBGOUD8Pg7UOVT0DYezDVo1HyJB+UEUjIoRUB7rrtf6+ocKZuzm8npddUFold2jN5bcD2s/i6prnzqvikqAUauRCDG1AwSst1YEFNVwRv6CrfIH3/349i6fiyoMAtYbB/347Z9Nr5xSW4a3Np7FiJK31qwwUUFRTfePC0Ts2zGKn7OzCEigrrEdY8tdlfHvUsR2W+Vzs67K1LGqpRpsDuerwLXw6rCX6t6jNnVStqY5UUYka2Hq6+uX8OzK/ViYSoGWEP56IDkSAnxyv7HHAAAkhVYLPbIQls7aet3iH1lF9Z4yN19jNkmI18NHB61h+eC/mD2yPMe2f4PGTOJciR4HLqstWP68yZpGrMzUs//wlgjs8gq5SFAkuQg4gvySECwIUOQrM+PUoskpUgJE/YXZmw5wd55ToH6c0mPUgjkdVniyo7CpPjuKIk5EpcrGQu9g39drTfj7jkEZtYT5SZBaU8ppB4Dut6mj2vG6x4AbS5FPsev3JzX/FsBbd9FIJUpQpSFidYNdx+dgxcgcGNBrg9NchpLqojMaPi3ZesuumEPuZpMYjtImWYUS7SAiF5Y/7y/0R7h2O4rJi9NzQ0+ydeblYjquTrpr9mYzlt/O7My3CkOgFeLdPP6PvW8VCHs5Y42dtc7laRfPgyTzx3883oVrPQPgXT4AIPsiUOamSFCNGneLVJs9v2rLnswyLg5g8nhC+pcMhYxojLiwchx9NhgZmypnzKF0LAF5SEc7Nf6pazYhVV1TliRjo3yIcT8WFYcXBG1hx6LpDU3qKyjQm06Aqnlh0T2waQR7UyAUj0JltgSdEjA+E8NYrZcpKe8yvNwLfk1dgySR4MC0hZkIMxlaRqTFZ/7pihBYvhpxpqvc8NXJRJLjE6+czZ3SHaMSHB9t9HFs8s+k5bB/5O5qHNKe1FMRpqkv3dj4Xn+YuwC1dICdEBWDq5tPYeSHN5jFW/Ez6Swn89bvxfaUiqdkmlgBQVFZkdq2Uqfx2fulAavx2ew5+Wz3H4H3jc1PMEWv8rG0ulyFbhDrFq//7+apvMAEAcsb4AmeHEZTppYAB5ee2EtxGluwLQGDFjUWBBrnSnwAAh7LElt/fCilopuSXqCn1qRJQQOHC+Jxk33qyESb1bIjJm1J4n6TKBOkowR2jF9mA9kJbykRh53ngwOXd3GzFjjPaE4vuhXqGbJF1H7o6dxysufPP9+SVJfscYCQILv4fVLKP+Y2NEaNWyWyImACDh3hV8BCU4aHsHe5OjiPTnKQiKYI9qyaYAAANyjBw00CIhWIs7bMUDQMbUnBBHMrei3hH4nPxWVRWhA1nN6B1eGuEe4cjQB6EByovbDhxGwevpDt9vRbfctMALAYTrE3nN0GZpzT4t20uv93adKCisiKsPb0WDQIa4YfjqUi5mw0AEAq9uc/eijd32DV+lkqOmitZbjVBGUpwx2gKTqVgRLzv+A9rUxeqvBJsuu284Xj7XEeb/25o3c15gGPZ7zom0OJ5DD5pVwClPlUGSnmyoLqmPNlykn1/x0Ws+fu22ePynqJkRPAreRlSRELEBCDIU4zMgjLbgogKwoqWQwRfXnf+a5XMhpSJghq51qUOMULr7pyYGQPfn5XtFwHRPaRJltr/2jCdcqTIUaDRl414XzA4kkwkw7U3rxlceOh2DXdUOWLi/vim71VGo0WbUgkZEfxL/w8SJtzijKcjOCKN0pSK/7Y/338Nn+2/brCf09KBjMz2shoEe6Jv83DUDytCZLAa6QVpyCrIxp4LShy4nI5SjfbzXnfm2UsUioEJRfj03BArxyEEIOCfyuNAkxM+wBfJc3jtmzxBW8WvMtJfq4yFtCtd3jIxzs7rQ+ceMyjlqQY6n36e150y3alqtnmdqaDCqnxHgRo5snXct2kaAA7syce3ekaGbAHACOFR1tm6F3BEMPHfGPhyRh5ruLfxuy2RfpHYOnwrBm4a6PDXtKRYXcz93ZmqyuUpESKujh+eiA6s1qUkCWEpchQ4qjhq/RMFamRLV5d/rzPj6ezgwtEq/tv+5sgto/s5LR1IUIaHslmoVTLHYMb4UiZwPvEwMmQfGp47JEaOxQjgVdYHq5O9jD9udhxVU1ZcKpKiT0wrfGFFte9gz2BeqW0u678ZI0tpTwCQV1yGFQdv4K0nG1XCwGoeCihcUNLdJDy3+Tle+15WXebyixU5CsTH3Mb5zIs4eDVdbz81cpEtXVsld1yMsWq6XKBBoeSI8wbjokwFG5XF3OL8glINTt5+hJO3H1XL5obEPThq7YUiR4HGXzZGsdoBDUfZGyEA70Wl1dGKg9eNloZ1OoG6/P2z6zgM8iWuVQpv6/CtVn+uV+XNpcqSKf8Q0iJ+/47WHU/FpJ4N6QaWE7hcQPH111/jk08+gVKpRLNmzbB8+XJ06dLF6L6JiYno0aOHwfbLly+jSZMmzh6qw+ieFJV5Sjy3+TmUafjd/Rm1dRSkIilWDVyFV/98FaWa/+7cyJw1WvsV4hxypOurehjVXlWvnzDnw737ceJKLd4XSmxzQ0u50ITwlXQ3Cd3Xdzd7Z5bv2ovz6ecdE0xUxHNRqTkBHmI8KqzcxcHmZieI81gTTOieH6r65pKzaVAKqTQfGh7/RLMLSnEyNQsdGtiwfoaY5VIBxZYtWzBlyhR8/fXX6NSpE7755hv069cPly5dQmSk6RPC1atX9XLBatWqVRnDdQhrS9oZU6Iuwbg/xjlwVM6VI1tbdQveXMjW4VudughVLJCgjLFt4fhvt98GZNbfff326G0AAswe4OTqJMStKXIUFoMJQJsWelRxFF0iu3CzuBVnNNibONUNW+HoqbhwJHywr9KaoK5NSsHl1FyTsxNlgnSHVK8jxgV7BkMulpu9JpCKpEgcnWj1+WHj4I1oGqxdn3JZdRmjto6ya6yVaUqvRvh0F7/Aet+lNAoonMClAopPP/0U//d//4fx48cDAJYvX449e/Zg5cqVWLx4scnnhYSEwN/fv5JG6VjWlrRzCxRM8OKou066JxFdyjylfdPkNt59/fZoKlpHBFA1DmIzVYGKd844O4u7echmjNw6stI/b0sFd7mvLa2paFcvAC+0izLowbBkcHNM3JiCyqiw8tW5idpFsP/9u9atxqctyvFBtUmddSdysZxL0bs66apVqXx8ghC5WM4F1uxzXGntRedGtXC9BYM/z1muZvn76fuYPSCW0p4czGUCipKSEiQnJ2PWrFl62/v06YPjx4+bfW7r1q1RVFSE2NhYzJkzx2gaFCHuxpaTiC5FjsLuE4ruxRKLz0LUmb+dw1Nx5jv8EuIoJeoSDP15KDSo/MW2esUazKypeKVLPZPpgH3jwrFyVDwW/HkJd3N9rao+ZzWdRbDaQh7vVPt+DK5K92aPbpAQ6Rdp1eyDLUGIq629OKo4ipe7dcaeq5koKTY/+5BVUEqLs53AZQIKlUoFtVqN0NBQve2hoaFISzMekYaHh2P16tVISEhAcXExfvjhB/Tq1QuJiYno2rWr0ecUFxejuLg8ES8313QfhMqgzFNW6euT6kkmkllcP2HLSaTi8+09oRitbMVjISpV4yAsvoGxveuJqiKYMGBkVk8uEeLT51siLqoMKcoUk0+NjQjG32/3xMnULMz8sxh/Z7/ptAv9DNkHCCx5E1nSL2k2womaBjd1WClka4MQwLXWXkzZPQUAIBZJESpYZfGm1Wf7ryEmzBt941znZ6zuXCagYAkE+ncsGYYx2MaKiYlBTEwM932HDh1w9+5dLF261GRAsXjxYixY4IAKEg6gyFFg8JbBVT0MUoWmd5iO1uGt9bb5y/15N4+z5SSiyyknFEEprzJ/VI2DAPqB8Tf/foPVKdoSrGyNfaDyOmVXJplYgIndGuDNXo1x//Fd3n2HOjSIROLkV9F0gSdu4A0wJhqU2kWgRpZsueOPSziOCJLt5WppTwBQxpTwTrV9+7dz6B1LM+GO4jIBRXBwMEQikcFsRHp6usGshTnt27fHxo0bTT7+zjvvYNq0adz3ubm5iIiIsH7ADmBNHjBxP3KxHJPbTXa7CyUAyJAtstiMiKpxEBYbGI+PH4/VKasR4hWCYM9gbvZNVaDSq4R3Wnm6Kodrl2FP1MWwFu243ixs/wu+fYcA7fsxqVcopu/3R5kwj9alVVNioRhL+yzVCxz85f4I9w6vFkGyM9Ke2DQuZZ4Sg7cMdso1Ti1vGXIfW94vp7AMk39KwVcvunHjv0rkMgGFVCpFQkIC9u3bh0GDBnHb9+3bh2effZb3cU6fPo3wcNN3XWUyGWSyalxT1cWJIIIaNEVuycbBG02ubXALgjJed5GoGgfRJRaWn7LsrX5XXY3uEI34cO0FprVV/pR5SnRa26l8f5GzRkns5Sqf8Y6cpZaKpHo/8/U3r0NVoLK6HL4lE7pGY+lOfsfaeT4NtXdeosqCDuAyAQUATJs2DS+99BLatGmDDh06YPXq1VAoFHjttdcAaGcX7t+/jw0bNgDQVoGqV68emjVrhpKSEmzcuBG//fYbfvvtt6r8MWqs5X2Xo2FgQ5dZ5FVVKn7oViU++evO9PO/96gaB+GIhNor5DJ1mVsGE4C2XKfu19b8nNlF2S7zvkiEkvK+SDVQ0+Cm1eIz3hI+5wCxQAwIYDYgMFbKVjcl98iYI+j6fVeHBBXRYWWY+mQjfLb/Oq/9qbKgY7hUQDF8+HBkZmZi4cKFUCqViIuLw65duxAVFQUAUCqVUCgU3P4lJSWYMWMG7t+/Dw8PDzRr1gw7d+5E//79q+pHqLFkIhkGNdHOLNmbkymEEHO7zgUEwKKjixx2V6O6cHZ/CWuYWtitzFNi0OZBdl0QeEhFFhsR0eJsootNZcoqyqrikVTAiFCrZA7AABpBHkrxALnSLYDA+oXelVH7P6h4OiSMYSpvqeCu8UIKTrDthW0AtEFQRaeVp7EsyfpxJIS1gUDjgcfFgKc4ADEhddEuojH8PLR9qKQiKQBtStjj4sfILsrGw7yHYACoS32RlSdGbmEpitV5OJ39g80/mzvhW9wDgF1d6TtEdMCRMUd49Y+xZPCWwbjyxjWsPSZBTiG/cxRVFrSfSwUUAPD666/j9ddfN/rY999/r/f9zJkzMXPmzEoYlXvoVa8XAjwCIBfLEeodigi/CDQMbIjsomyrT3Kjmo9CTHAMfGQ+aBjYUG8Rsb05mdtHbseARgMAAONajzP7IVZcVowrmVf0u4QbIRFKwICpFsFJdausYWph97YXttn1e3wqNhR/ndavY2/MiiOZtDibAAAePH5Q1UMwqlbxHHgyT2i/YYBiwQ3kCn6q2kGZIWEiIGMaGmwXwcklZ/8jE8nMFpboEtkFX5780qoLyx0jd3DnBXtpU81+MXtXXiQQYU6XOWgU3Aipj1Ix99Bch7x2dcS3uIe9N8I6RHTg0qB0Wdtkr0RdgkdFmRjXqR7vWQq6eWU/lwsoiHNIRVKsfW6t0Q8Ec6UKjZGL5VjUa5HJDxd7LpilIimahzTnvufzQdchogN6RfeyePfkfPr5Kk/Hqg6VPfiyN/BpFx2EP8/cwX3Zq4DAzF0kRoL3/4rC/AHd7Ho94vpMVfSraiIEVPUQHELMhKBWyWxkyJxX6XB53+UY1GSQ2c9tWxYDO/JGjLUlt1OUKVYFFK70OV/Z7K1MqGtSz0ZYffQW8ov5rdukyoL2oYCCADCfZsMrh1IoxrcDv0WLsBZOq05hLAeTLz4fUuZOHhU5I//XVRbpOUqzOn7wlBcAsPA+Ckqx/p/zmNuvK33Q13BCgbCqh+D2pEyU02Yp5GK5xWCC1TykOe/1W864QHfkhS2LrXBUHSo4uRJb1/KJhAJ8MqQFXt/Er+obVRa0DwUU1VhlLog1d3fH3gZpxva1Zh1FdfsQZgMbmdiwGpi1U7O6XGWRnqOIhAI807I2lp21vG9RqZqmowm8JF5VPYRqSy6Ww1/ub/XzPKVC9G0WilA/Dyizi1AnoAEg34CZiSMdOj5rb5jonneUeUqjay2qS4lVvs0Xa9INI0fS/Vs4qjjKNbHjo3+L2njl7iN8e/Q2r/2psqDtKKCoxipeyHdd1xX5pflVNhZHfRBG+kUicXQi74oOjuwWag6fkwIbTHSI6ODQ165pU+BSkRTKPCVaRhcAPAIKAFh77BZNR9dwtbxqAQDiw+KRkmZdKmZleq51bay6bHk/R2Ev1vnOsi4e1BwB0hiE+MjRNjrQ4N9UirIASHTsGG25YeKMWQJncPRNN2LInr+F2QOa4UF2EXaeT7O4L1UWtB0FFNWc7j8idrr/9+G/I8JPW6GDbeJkz4KwqriY5VvRoTLH5oiTgjWzL+zMC5/jupsSdYnV61VyCmnRXE3HMAwAQCqWVp8OvoxYu5j5P//XuR4GJBRXWkBR8c43nzvlPWMaItKvTuUMsIZwleCnplDmKfW+/2JEPBKv7bG4noIWZ9uOAgoXwubstwprhSj/KG57uHe41QFFdbiYNVXRQVdlj83ek4I1iwkra+bFnXy2/xpiwrzRN656VcIilYOBNqDwEHs4vIOvrWoVz+Y6vg9oHoa5A5tZXcjCVi82fxEf9vqQ+8zSvSny4/kf8WnSp3iqwVP4sNeH3HOq4vO+ps3Akqo3eMtgXH/zOve3LhIK8EKbCKw5dtvic785cpNmw21AAYULYdODdLvF2qq6XMy6410dPosJ3eEEW1VN7xb8eQm9Y6leeE2UlqdNWTh0+xCW9llq17EcVViBrfDkJRXhixHaz1Rb/22IhWKrSlc/Ln4MVYGKuynDBguRfpFIvJ3IbbP2s97W8Y9qPgpt6rRBw8CGeuvyatoMLHEevlkAJeoSqApUen93T8aG8QooCkpozZ4tKKBwEQzDmAworF3kTJyLvUu48tRKLDm2BN3rdceyPvpNmtzhBMv+nEcVRyulGRdLmVNElThqKAHKg0gNY33TOJZcLMfBlw9CJpZBmafE4C2Dbfv8ZCRcutMnQ1tyQa7uTAHfQg1SkRTfDPgGY7eP5f3y269tx/Zr27nv5WI5rk66iki/SKg12tQOtru4NSqmf/L9GaZ2mFotblQR92VNFoBu13kAEMsZeHo8QkGh5TLPVELWehRQuAg1U573JxFJ9B6zpWY3cQ5FjoI7CWcVarv5BsoDucfdIZDQFekXyaXOOY3ORRsr/XHlzoqQ6oGtYtQqrBVqeday+kaKqYpxuqmX5+5m451t5wEAajyCRpAHIbwhYgwvQkTwhZgJwStdotG/hX4anrWzr1uHb7W7l0JRWRF3V5Y9Z4gE1gcUgHvOHhP3wPffibEgWCyQIlSwiktTNIVKyFqPAgoXoTsNbizlqbp1V66JtN1VYwzSBLZe2YqtV7YC0L+DSPRtHLyROwF4lHWAX9lwAOUXbbpCfOSVPj5S9djGdiFeIYjyj7L6RoqpVE/di+ed/16EjCksf5Axf8z/61wPswfE8h6DKdlF2UZLo9qKm6GwMaAgxB2VMSWQSPLB8LgPQTeurEMBRTWle6cbAPJLysvFnk8/jwjfCL2L0qrKZyflVAUqi++/7h1Eoq9pcFNMaT8Vy098BiHjwW1XIxdqQS73vQi+eJRP6X01EVvlia145+gbKWoNg21n7vPe/5Uu9TB7QDOHvLaj0wbZlDBbUp4IcWdD4uvg1xOW97utKnD+YNwIBRTVkKk73azOazsb3Olmc17Pp5+3mA/sDguCiXtqX6cdRAIx8iUHkS85aHwnRoI5O77HU3EjKL+1hgnzDgMA7L6x2yk3T06mZiEr3/JCbQGAL19ojYGtalvct2L5ysrCpjxRd3FC9LWMLsAfZ+8jr0htdAactfmUgtZRWIECimrI1jvd7LR9dSvFSoglbJCrKlBBzViociMohfJxBuW31kDd63XnvnZGQME3xWF0xyhewYQiR4HBWwbbOyyb9KjXAwII0KZ2G7uPxbcTNN2oIq7g5d//mw2UA2AkqFP8jdGgggqAWIcCCjdEi+lIdSWEEBpoUzGSJyRz24M9gxHhG4Go5VGmnmpg36U0+qCvYXTTdzSMBsGewZCJZChWFzvk+LdV+ZZ3AvBUM36pVqoCVZVV3+tWrxu61evmkGNRJ2hSnTi0sqWgFGrkQgzjsxR0nuGPAgpCiF34XtQJIMCbbd9EZlEm5nSZg5jgGL3HrT05/HHmAWYPiKXp6BpEN31HrVEj0i8Sh0YfQse1HS0+19IddLWGwU8nFRaPE+4nR9voQIv7Odr7Pd63uoGpI9GNKlJdVGZly7XHbqNtdCA1U+WBAgpCiF0i/SJx7c1rOJ9+3miVmrs5d7Hr2i60CG2B5f2WmzyOVCTFBz0+wJxDc3i9bmZ+CU1H1zBrT6/lvmYXHdfyqgUA8JZ64/CYwyafa+kO+snULKTlWp7peOGJyCoJYluHt7Yq7ejB4wfILMhEiFcIQr1DK2uYhFSKyqpsKQA1U+WLAgpCiN0s3b2c1XkWr+P4yf2sel2ajq5Z2FKoQPmi4+IybRAgF8vtaqrGd/1EvWBPm1/DHuHe4bg66SrG/j4WB28fxNsd38awuGF6++gGTZ8c+wTL/1mOtzu9jSVPLqmKIRPi8hjQWgq+qPwDIQ7CLlw0pyYvXGQYBqoCFfr92A8tVrbAFdUVg306RlhOXdH1x5kHUGssNAogbmNUi/LSquwMBZsqJxVJ7To23/UTVdUDJT0vHY2/bIyDt7XVzxoENkB8eLzef7pBvZfUCyFeIfCR+lTJeAlxJ9STwjKaoSDEQWjhomlqjRppeWmo+1ldbltGfgaaBDfhvs8qzMKMvTOsOi6lPdUsXlIvLu2Hna1g1+7IRDKbj1vV6yckQglKNabL1crFctTyqqW3Tkkikhj0K9I1uOlgTEiYUCM/bwhxNGqmahkFFNUQlehzXbRw0dD93Pt6gQQA7B21F3EhcXrbHhc/xqHbhywfkJFABF/uW0p7qlnYhdmOnKGo6vUTxoIJsVCM31/4HeHe4Qj2DIa31Fvv8bF/jLV43Ir9igghhmp5y5D72Pw+1EzVMkp5qobYO93JE5IxtlX5SSPYIxi9onsheUIynSSIy/CQlHe9ThqXhMTRiQjyDEJqdipSlCncfyfvn+T2q+dfD3W96wMApGUxCCqejlrF8xBWtNygZjilPdUcR+4cQUGptnttxTUUMrHtMxT7L6Xx2s/a9RN80iBNKdOUIbsom5vV1A2Ydr+4G94SbzPP1mL7FRHibtjSsfaSi+WY1ivB4n7v77xE5xkLaIaimjJ2p1tVqIIiR2HXwkNCKpu/3B+nXz2N9t+1R4e1HXg953b2be7rEvFVZIqvmmxARGlPNceZtDPc12zKU8uwlvh9+O/wknrZdEy1hsG2M/d57Wtt2oOpNMjLqssYtXWUiWeVG7V1FDfLEOpVXqmpfd32CPcJx/Ws6xaP8df1v+icQdyOvaVjNw7eiKbBTRHsGYz7Ki8A6Wb3p4XZllFAUQ3p5sVeVV3Ve6xUUwpFjoJmJ4jLEAqE0DAa+5uPmWlARAvmagaGKb9DyKY8hXiF4Nkmz9p8zJOpWcjKN71+gRXkJbVp/YS9aZDsLENd3/K0wVJNKe+Zj/R88xdKhLiq5iHNLaaHm9I0uCkXaJ9O5XdDgc4z5lFAUc0ochSIWRFj8h/I7ezbiFkRQylPhOi4rSqo6iGQSsAGEUB5ypO9+F4kPNuqdpXWoRcKhBAJRFAzaiw7vsxozxdjBAKqnU/cU8UZwL039uKo4ih23dhl1XH4zjzSwmzzaA1FNaMqUFmMtikvlriaz0987tTjbz6loPzWGoBB+e/YQ6xdm3Mj6wY2ntuII3eO2HRMvuVie8eG2XR8R5KIJACAJceWIKMgg9dzRAKRM4dESJWK9IvkyiafSz9ndTABAG2jAxHuZzlYoIXZ5lFAQQhxCkWOAjuv78SP53/E1itbnfpabH4rcW9sytOoFqPQILABAOBQ6iG8tO0lLEtaZvXxqrpcrLXYRagJ4Qmo7V2b13PYqliEuLv+jfrjlfhXIBaaT76RiWR6VTJFQgHmDmhq8fi0MNs8SnkihDicIkeBxl82tn/dhBUov9X9sSlPApSn8dT2qY3e9XujVWgrq49X1eVirSURamcoNgzagP/t/R9uZd+y+ByaoSA1xagWozCqxSg81eApDP1lKOr61sUfL/xhsJ+xflABXparxNHCbPMooCCEOJyqQFWpwQRA+a01AZvypHvXfUDjARjQeIBNx+MbhFpbLtYStuQl20ODL3aGolRdCn+5P6/n+MioUzapWXxl2j5FgR6BvCuc8f0soBtXptFcKCHELVB+q/tjU57Wn12PU/dP2X08vusnHB2ssiUvrcWuoSgqK0Itr1oAgDEtxyB5QjK3z4wOM5A8IRndoroBALcfIe6uuKwYd3Pu4rLqMgDAU+KJ1Eep+OXiLzhw6wCKyoq4ctMV0cJs+9EMBSHENTBivQ7ZFb2/8xKeigurFqkpxDl0F2Vbe3e/oqpePxHuHc5rP6lIyuV7sylP7de0x+CmgwEAfnI/vbuw+aX5iA+P52YmKOWJ1BTbrmzDiN9GcN97Sbyw/9Z+TNgxQW+/s6+dRYvQFnrb2IXZaTlFMLVKorqspaquaIaCEOISahXPNmhqp4sWZrs/dg1Fh7od0Dq8NQBgfuJ8+C3xw7sH3rXqWFW9fiLYM1hvLYgxYoEYiaMTuXzvpX2Wco/5yfwAAIWlhXrPYY/J3okVCSmgIDVDxTRAT4kn6vjWQdeornrbC0oNy4yLhALMezrW7PGfaRlON6zMoBmKaibYM9hioxa5WK5XoYCQmkCEAIv7UH6ra9Ft4mlMxcWTbMpTs1rN4CnRrmvIL8lHbnEuStWWm9Ppqqr1E6xIv0gcHXsUmYWZ3Oc+ABy/exxv/vUmAOC7Z75Dh4jy7vLPNXkOEqEEpZpSLk+8sEw/oGDXl7DBF81QEHfHfo48zHuot72orAhh3mH4YdAPmLV/Fn668BO6RXXD1YyruPnopt6+/nJ/NI9ojgldo/HNkVSjr7P6SCpaRwagbxy/2cWahgKKaqZioxYAmHNwDv668RcA4MnoJ7Hm2TXU1I4QIyi/1XVYauIJaG+e6DbxZFOeMgszkaJMAQDczb0LAMgqykKKMsVoBRdjqkPOdKfITgbb4sPjsfLflbiUccng52AYBqUabeD0ZP0nUcenDpqHNtfbh21kxzb+o7KxxJ2Z+xzZd2sf9q3eB5lIxqVIHr5zGIfvHDZ6LJlIhljhWgB+Jl9vwZ+X0DuWUmuNoYCiGor0i9Q7kejm2o5qMYqCCVIj1fKW4fFjGM1vFQAIo/xWl2JNE0/2M08u0l7cb7uyDduubNPbd+3ptVh7eq1BEGLKo3zL6U6VkTO95cIW+Mh80CiwER6XPAYA5BTlAADuZN/hAqdgz2CkPiq/c+ol8UKv+r0AgNsHADLyM6DIUVDKE6kR+HyO8K04WKwuhjI/AzITAQUDKh1rDgUULoAtFTi/23yMbjW6ikdDiGXBnsGQiWQOLR07oWs0lu0sgwCGQQUDYN7TsXTXyM31rN/T4j4VgxBj1BoG7++8bPFYcwc4929qTcoajP9zPAAY/fcydvtY7mu5WI7GgY2573tuMP5ebL64Gb9f/R1vd3obTYObolFgIyeMnJCai1JrjaOAwgWwAYW9VU0IqSyRfpG49uY1nE8/j+yibG576qNUzD001+rjycVyPNOiKRoGSDBr63lkF+jny/t7SuwdMqlBTqZmQZlj+aIgwEvq1HGsO7OO+9pS8F1UVoS6vnVxLv2cxeMWlRXhmZhneNfgJ4TwR6m1xlFypQtgA4obj27oXZwRUp1F+kViQKMBeLH5i9x/L7d8mVt8aolYoL3fEe0frZfCklNguPg2p6AUEzemYPcFpeN+AOK2qksTqx71eli1/7SO05w0EkIIoE2tNTcn6e8podRaEyigcAFsQPHzxZ8x+8DsKh4NIbZjiw4kT0jGq/GvGjz+Se9PsHnoZiRPSMamIZsAaP/+I/0iodYwWPDnJaNrKNhtC/68BLXGVBVx4urWn1nvkONUhwXZADA0digAIFDO7wKlTF3G+9gn75/Evpv7cOLuCShyLPfbIIRoU2vNnUGyC0qx71JapY3HlbhcQPH1118jOjoacrkcCQkJOHr0qNn9Dx8+jISEBMjlctSvXx+rVq2qpJE6DhtQAIBMLKvCkRBiv0i/SMSHx+N2zm297XV86mBGxxkY3mw44sPjUdunNoDyajWW0lR0F8wR95RXkueQ47BNrEzdiRTAuQuyFTkKpChTcOqBtts32wHbkgd5D3i/xsSdE9FnYx90WNsBMStiKKgghId29YPNptAKQDeuTHGpgGLLli2YMmUKZs+ejdOnT6NLly7o168fFArjH5Spqano378/unTpgtOnT+Pdd9/F5MmT8dtvv1XyyO0zqe0k3Jx8E5kzM/HpU59W9XAIsdvcg3Ox5+YevW0VU6HEQm3KU5lGe1e2uqSpkKozrNkwXvsp88ynvomEAjzTMtzsnUhnLfJny1wmrE7AK3++AgB4mP/QwrO0Pj/xuU2vyS5UJ4SYd/F+jsEaPV1048o0lwooPv30U/zf//0fxo8fj6ZNm2L58uWIiIjAypUrje6/atUqREZGYvny5WjatCnGjx+PcePGYenSpUb3r66CPINQP6A+Aj0ob4+4h4sZF/W+bxzUGDcf3USP9T2w9fJWAOXlLtnyl9UlTYU4hm4zN1MqNvGs5VWL17EHbxls9o787gtKrDbRvArQpj04q3kVnzKXpjwufuzg0RDi2oI9g/WyOOwhE8lQVubNa1+6cWXIZQKKkpISJCcno0+fPnrb+/Tpg+PHjxt9TlJSksH+Tz31FP7991+UllrXVZUQ4jhT2k/R+57t+pt4OxFJd5MAlHf4ZVOeqjpNhTiW7nqaf8b/w20/8PIBJE9IRvKEZIN+EsGewRCYXTKpVaIuMXlH3txaHNb2s8pqmdLA52cnpCaJ9IvE1uFbrXpOsEf5TYrlfZdj4+CN2DFyB669eQ3NQhvwOgbduDLkMmVjVSoV1Go1QkND9baHhoYiLc34Apm0tDSj+5eVlUGlUiE83PAOVHFxMYqLy8v35ebmOmD09jl1/xS6r++OgtICbB6yGcPjhlf1kAixS9eorvCUeKKgtAAA0KxWM/z74F8A5fnkFWcoREIB5j0di4kbUwx6UbCXWdSLwrXoNvEUC8Uo05QhJigGdXzrGN3/euZ1rlu2rfiUjK2OzavkYjki/CJwM/tmVQ+FkGpFt/mvOS1DW+Lsw7MYGDMQ41uPh0AgQEJ4gt7a1Do+DML95EjLKTL5SUOVnoxzmRkKlkCgf7HAMIzBNkv7G9vOWrx4Mfz8/Lj/IiIi7Byx/S6kX+AuvG5k3aji0RBiO3YxatLdJO5vGgCaBDfhSmhKhP8FFBVmKACgb1w4Vo6KR5if/t2hMD85Vo6Kd1qaCnGuq6qr3FoZc+lAP1/82e7XcpW1OBsHb+RmatjZmnAf+vsmxFa96/cGABSWFqJTZCd0jOhoUOiGvXFFlZ6s5zIzFMHBwRCJRAazEenp6QazEKywsDCj+4vFYgQFGb/z9M4772DatPJa37m5uVUeVDQPbc59zbcaCCHVDbsY1dgF4zsH3uG+zi/NB2A4Q8HqGxeO3rFh+OHEbczffgneMhGWPt8S7etXn7vJxDrp+enc16YCCkWOAmtOr7H7tVxlLU7T4KYGjenYYJsQYr2sIu1C6i0Xt2Bim4nwkfkA0KZS6qZW9o4Ng7+nxOTibLbSU+/YMJoR1+EyMxRSqRQJCQnYt2+f3vZ9+/ahY8eORp/ToUMHg/337t2LNm3aQCIx/sEsk8ng6+ur919Va1O7DV5s/iKA8so3hLgavotRS8q0HeF9Zb54rslzGNh4oME++y6l4etD2tSPvGI1XvzuH3T+6CA1tnNR9QPqc1+b+htRFaj0Zqts5cprcR4VParqIRDistaeXst93X19dySsTkDC6gSDssonU7Oo0pMNXCagAIBp06bhu+++w9q1a3H58mVMnToVCoUCr732GgDt7MLLL7/M7f/aa6/hzp07mDZtGi5fvoy1a9dizZo1mDFjRlX9CDZj0wHoDhVxd2KRNmiu7VMb24Zvw4ZBG/Qe331BiYkbU5D+uFhve1pOEXXLdlF1fOvgzpQ7uD/tPlqEtnDqa7EpDcZU97U493Lv2fS8itWyCHEnfCrGmVOxrLKrpEVWNy51u3v48OHIzMzEwoULoVQqERcXh127diEqKgoAoFQq9XpSREdHY9euXZg6dSq++uor1K5dG1988QWGDBlSVT+CTYrKinDr0S0ANENB3J9YYPpv3FK3bJqKdl26KQeVwc9DjOxC/c7T/p4SLB7c3KlrcdiLH3OzdRUDAEWOAqoCFVcNDdCusWCVqEuQX5yP7OJsLDq6SO/YPw7+EZ0jO1f6+0tIZWErxhmr7HY27SzGbR9n1fH4pjveVhVY3qkGcbmr09dffx2vv/660ce+//57g23dunVDSkqKk0flXH8r/uY6qlJAQdwdO0PB0i28YE237OpUoYeYl1WYhYvpF+Er80XLsJZ2H8/cHXl2hstYUPrITJqDo5i7+GHp5nSbWns0auso7mu5SI5/J/yL+gH1cfbhWfx66VfusbiQOAomiNvTrRhnr7bRgQjzlSEtt9jsfptPKTCpZ0O6efUfujp1AbpNW2hRNnF37AzFw7yHqP1pbTAMA808DQCainZXJ++fRL8f+wEAkickGyxGtsbGwRvRJbKL0YsLSz0oKmuGy5qLHz5rj4rURYhbGYcI3wgk1E7Qe4ytlkYI4UckFGBE20h8tv+62f3o5pU+l1pDUVPpBhQ0Q0HcHTtDIRQIoWE0YMBw5Z5dpUIPsY5uJa/LGZftOlbT4KYmL9atmeFyRXdz7+JG1g29uvxCAZ3mSc3FnjusVS/Yi9d+VD62HH3SuAAKKEhNws5QBHkG4cG0B3g44yH3mCtX6CGmaRgN93VsLeMLph2hJsxwXUi/AGVeeWECtvwyIYQ/vjel/jjzAGqNfc023QUFFC5AL+WJqjwRF8W3EkeAZwAA7Z3VcJ9whHiFcGsoREIBJvbyRbHgBkoEN1Cs8x/7/cRevpTT6mLYgKJD3Q5oHd7a6D7BnsEW03csVTOqCTNcnhJPtKvTjvueUp5ITWau8bE5baMDEehl+XorM7/EZWc0HY1ud7sAmqEg7sDYYtT5ifPx57U/9faLqxVn8hiKHAVe3dcVRXLTd5Bf3SdH95irtBDVhbABhbn0nEi/SAxvNhybLmzCawmv4ZWEVwz2qdigqiJ2histp8joOgoBtF3XXXmGq1NEJ/w05CeELQtDmaaMZihIjWZLVTVAe/NqUKs6WHPstsXXcOUZTUeiGQoXQAEFcReRfpGID4/n/vuy35doVqsZ93iwZzC6RHUBoO29MvmvyXhj5xsoLC0EwHOBaoWa4qT6YxvW3Xp0Cxn5GSb385Jq85q9pd7ILMhEqbpU7+/JUhDpyj0o+Np3ax+CPwnmehfRDAWpydgbWcL/Lnd3v7gbyROS0TioMQDgy35f4uok4zegnowN4/UaVD5WiwIKF6AbUET4RVThSAhxrCj/KO6DHQAKSss/mBmGwZcnv8TX/36NorIiKHIUuKyyb8EuqZ7YGQplnhKf//O5yf1CvEIAAEuTlqLPxj54ceuLVr9W37hwfDHCMK0qzE+OlaPindqDoirQDAWp6SJ8I6CB9jOmdXhrvfRJtUYNVYEKKcoU7j+2azZbPtaSdcdTaR0FKOXJJegGFLp3cwlxdYocBR7mlS+6LigtQPKDZAgEAr2Fundy7qDDmg4WZyeIa9L9XZv7HX/Q8wNkF2Xjq1NfAQBigmOsfi21hoFao309kRBYOrQlwvw80DY6sFrOTPBJ2dAlF8sR6BGIB48f4PnY5+Ep8XTyCAmp3jqt7cR9/TDvIdp+15b79zRlzxSD/eViOTdrwad8bHZBKb44cB1Tezc2u5+7o4DCBegGFKWaUrrjRNyCIkeBRl82Qom6RG97m2/bGOybnp9uVTBx/EYG4t3rRrNb4xtQAOXrLN7t/C4W9Vpk1evsvqDEgj8vcaVj1Rrg4z1Xq3Wak6VGeEuOLsEvl3/hvi8qK8KDxw+QEJ6An5//ubKGSUi1dUV1hfs6uyibd9pspF8k7/KxXxy8jphQH/RvUXNPPBRQVGOKHAVUBSoUl5V3a/zn3j/wkfkAsLwAkZDqTFWgMggmTNFoNJZ30vH54cNoVz8YIqGA/p24AN0+FJZO9myqgm4QwoepDtlpOUWYuDGlWqc7mWuEV8e3jt73AgjAgEGpxvldvwlxNdbekOVb8Y1hgNc3pWCVsPp+jjib3QFFbm4uDh48iJiYGDRt2tQRYyLQBhMxK2IMTq7d13fnvtadliPEnamhtryTjhvqxWj73WIA9O/EFfCdoZhzcA6W/7McQPlCbj7MdchmUHkdsp1BItIvbcn891Oee3gOGkZDje0I0cH2OeKrbXQg/D0kyC7kF6DP2nreJT9HHMHqT5phw4ZhxYoVAIDCwkK0adMGw4YNQ4sWLfDbb785fIA1FVWzIaSctTMUuujfSfXHN6BgF0sCwCfHP8HYP8byOr47d8g215tItFCEx8WPK3E0hFQ/ur0orJ2hEAkFGNupHu/9swtKseLgDatew11YHVAcOXIEXbpoyzpu27YNDMMgOzsbX3zxBT744AOHD5AQQqxNbyGuhW9AMbPTTMSHx3Pf38+9z+v47twhu+IMRUW05o7UdAKUBxS2NLqb1LMR/D35NxWuqVWfrA4ocnJyEBiobfqze/duDBkyBJ6enhgwYACuXze/Ep4QQmxhTXoLcT0jm4/Esj7LAJgPKOJC4tC3QV/ue92CFea4c4dsc+9Bxv8y4CH2qMTREOJ+REIBlgxuznv/7IJSl5zttJfVAUVERASSkpKQn5+P3bt3o0+fPgCAR48eQS53vQ9jQkj1p7tol7gfD4kHov2jAfBYlK1zx93S3XkW2yHb1L1JAYBwF+2QzaY81fapjXr+9fQeC/YMtumOLCFEX9+4cHw9srXJz5CKXHG2015WBxRTpkzBiy++iLp16yI8PBzdu3cHoE2Fat6cfwRHCCF8+cp8IRfTDQt3xv5+zQUUB24dwNrTa7nv+c5QuHOHbDao6hbVDalvpVbxaAipfsJ9tFWXBjUZxPV1MUculiPYM9hge/8WtfFWr0a8XrMmds+2OqB4/fXXkZSUhLVr1+LYsWMQCrWHqF+/Pq2hIITwFuwZbHZBqa4QrxBcnXQVyROSsWPkDiePjFS2w7cPY+b+mQDMBxSrU1bj/uPydRN8AwpAe4fxq5Hx8JXrV3lx9Q7Z7L+hny78hGOKY3qPvbHzjaoYEiHVSpBHEADghbgXuL4uyROSkTwhGV0itWuC53SZw20zVxXwzV6N4OdhuVLU5lOKGreOwqaysW3atEGLFi2QmpqKBg0aQCwWY8CAAY4eGyHETbE9VhZ0X4B3D74LAFjRbwX8PfwBAP5yf4R7h2PgpoFQ5imhZtRcLf4UZUoVjpw4miJHgR3XduBC+gUAQE5Rjt7vWLePCMPon6D5BqSAtg/F+zsvIbeojNsW6CXB3AFNXTaYAPSDqnVn1uk99k3yN/hqwFeVPSRCqhWxUHupW6bR/tvX7etyVHEUgLZhpm7BB1NEQgHGdYq22D2brRrXoUGQPUN3KVYHFAUFBXjzzTexfv16AMC1a9dQv359TJ48GbVr18asWbMcPsiaiJ2WM3e3ztS0HCHVmakeK5P+msR9zfaO6BTZCen56fCS8OtWagz9O6m+jP0t3Ht8DwmrE7jvdfuIVKz2xXeGwlRTu0f5pXhj02msFApcNqjQXUey5vQavceowhMhQH5pPgBtyuTI5iMBAEl3k3Dz0U2Dffjg2z1736U0CijMeeedd3D27FkkJiaib9/yahtPPvkk5s2bRwGFg7DTcubq51MHYOKKrOmx8svzv9j8OsHF0xHu1RB/vN6P/p1UU9b8LUT6RXJN21h8Agp3bmoHAG1qt8HHT36Me7n38MXJL/Qeo6Z2hAA3s7SBw9oza7HmWW3QvfLflfjh3A/cPt5Sb97H41sN7o8zDzB7gGuuzbKF1QHF77//ji1btqB9+/Z61SNiY2Nx8+ZNM88k1tKdliOkplHmKY2mN11WXeb1fDETgdzHEUjL8kZ0gKNHR6oCm/LkJ/NDTnEOr5Qna5raueLdxLiQOMSFxCGrMAt9G/ZF/039uccooCAE+L/W/4clx5boXU/FhcThyfpPIto/Gi1CW6BjREfex2sbHYhALwmy8s13z87ML3HZzxVbWB1QZGRkICQkxGB7fn4+lacjhDjM4C2DUaIusfs4NbF8n7tiU55KNdoTOZ8ZCnduaqcr0CMQ/Rr1gwACbibHmjUmhLirxU8uxuInF+ttm9lpJmZ2mmnT8URCAQa1qoM1x25b3NfVP1esYfXtiyeeeAI7d+7kvmeDiG+//RYdOnRw3MgIITWaI4IJwDWblRHj2AtldnEln4DCnZvaAdpF7N2/7w7BAgHmHJyjlxZGMxSEmFaqLsVvl37DH1f+sLrX0ZOxYbz2q0nlY62eoVi8eDH69u2LS5cuoaysDJ9//jkuXryIpKQkHD582BljJIQQq5UK7qKWtwxieRhSlHdozZEbYFOe2GCTT0DBNrVLyykyuo5CAG3pWFdsagcA/9z/B4fvaM+936Z8q/cYdZgnBFA+VkJVoEKIVwhCvUO57XkleRj6y1AAwLnXzqF5KP9eam2jAxHmK0NabrHZ/TafUmBSz4Y1Yh2F1bcvOnbsiGPHjqGgoAANGjTA3r17ERoaiqSkJCQkJFg+ACGEVIJM2TKcL5uItt+1QcLqBMSsiIEiR1HVwyJ2qFjlqWtUV4vPceemdoD+YtL0/HSEe5dXq8otzq2KIRFSrXRY0wEtVrVA2LLyWYV39r+DwI/LbyJ8dcq68soioQAj2lq+QcWuz6oJbOpD0bx5c65sLCGEuALdakHENbHpPP0a9sOcrnN4L6TsGxeOlaPiMXvbBWTml6fShfnJMe/pWJctGQsAHSM64pX4V7jZCd1ZCQFcM0gixJGMlU8uVuvPLIR6hRrsYwnf8rE1ZR0FrxmK3Nxcva/N/UcIIeawPVbM4dtfQCaSOWJIpIrw+VvQ7SPCzlAMbzbcqqosANA7NgwvttcGk2G+Mvw4vh3+frunSwcTLHZNCQCoNWqceuUUAKCub92qGhIh1cbiXtoF2d2iunHbRILyIEMmkmFBjwVWH9fd12dZi9cMRUBAAJRKJUJCQuDv72+0mhPDMBAIBFCrKWeTEGIanx4ryjwlBm4aaPFYasZYVjxxFezfwoLDC7D29Fo8F/Mc3mj7BrwkXpCJtcGisU7Ztx7dwrmH5xDpFwl/ub/F19l9QYkFf17iysem5RZjxi9nXX52gqUbUGQWZuKJb58AQI3tCAHK/33oNoHU/behu90a7Posc2WpAeBRvmMKjFR3vAKKgwcPIjBQm2t26NAhpw6IEOL+LPVYMdZ/whi1zoUUcU2RfpFcusHvV3/H71d/x66Ru9CvUT+Dfb2k2hSDhUcWYuGRhfj+2e8xutVos8c31SU7LacIEzemYOWoeJcOKm49uqXXoEuX7l1YQmoaRY4CqgIVbmTdAADkl+Rz55aM/AxuP7HQpux/iIQCzB3QFK9vOm12v/d3XsJTca7ZONMavN7Fbt26Gf2aEEKcgU2FsdRFmYHG7OOmqDUMTqZmIf1xEUJ8tBV+3P3DvjqruNj6fPp5vWosgPZv4rdhv+HHcz9i1LZRACx3t3X3LtmAtvRlRRKhBKWaUvjJ/apgRIRUPUWOAjErYvTOIUn3kpCw2rB4UHZRNsZvH4/vnvnO6tcJ8LKcduvKjTOtwSugOHfuHO8DtmjRwubBEEIIUJ4KM/zX4Thx7wQAYFjsMLzd+W2UacrQ7rt2Nh971zkl5vxxAVk609DhbrA415VlF2Xrff/2/rcN9pGL5bg66SqXqtCjXg8MiR1i9rju3iUbMEzXkIlkCPMOw52cO1g5YGUVjYqQqqUqUFm8IaUrNTvVptepKY0z+eAVULRq1QoCgYDLXzWF1lAQQhwl0i8SgR6Bet/Hh8cbvSPL19q/b2FHstJgu9JN0l9cVV5JnsV92CpdbBpPxVkNY2rCyb5iN2w1o+aCDHv+rRBSk9jaSJXvguua0OCOV0CRmmpb5EYIIfbQzQG/nnUdxWXmmwiZIxHK8HvKY4jhYfRxBq6f/uKqLN2sYi1PWo4fzmvXC/Bp2lYTqrBUrIhWpinjcsZLNRRQEMKHrecWanBXjldAERUV5exxEEKIAd1KHH9c/QOp2amo51+P9/PDipZDACDIWwpNmQ/ymQCz+7t6+our4jPbAAAXMy5yX/+t+BspyhTEh8eb3N/du2QD5ivU9FjfA8w8qoRGiCW2zlCwDe4+23/d7H414dxi29J2AJcuXYJCoUBJif4v4ZlnnrF7UIQQAhhWqckryTN5N1vAeIER5OttkzENAQCPH/N/zX2X0tz6Q78ysNVVTNEtBQvwDyjGx49H4p1E/HzxZwCWU6XYLtkTNxpWDXOHLtmAYcoTIcR6tgYUADW4Y1kdUNy6dQuDBg3C+fPn9dZVsL0paA0FIcRRKtbRzy/JN3nxKWaC4FfyJopFF/BYvANSTUObXvOPMw8we4BrX2RWJWPVVSpiF1izQcXYVmPx86WfLR67Xd12iPSL5AIKPg0Q2S7Z727TX4jvDl2yAfMzFJ899VkljoQQ11Wxc7Y1akJqJR+8OmXreuuttxAdHY2HDx/C09MTFy9exJEjR9CmTRskJiY6YYiEkJrK2AyFrh71emBE09ch1cRArmkJL01nyNWt/3vU6o83AEBmfglOpmbZ9FzCr7oKu8CaFeIdwvv4ukEm347qfePCMXdAUwBAoxBv/PRKe7fpkm1uhoI6ZRNiXph3GAD7ZijY1Epzt6D8PSUunVrJh9Vn3KSkJCxcuBC1atWCUCiEUChE586dsXjxYkyePNkZYySE1FAVGw7ll+bDS+qF52OfBwAMbjoYPwxdgXj5VygVKHBXPhKFon8AACXCa2CMZs5btu9Smn0DJ06R/CAZf179k/ueb0ABaANFAIit7YsODYLcZgZKJBRBKNCeyn99/le9x6jKE6mp2F5G5oiFYrwa/yoA+wIKNrXS3Nkmu6DU7c8rVqc8qdVqeHtrmwkFBwfjwYMHiImJQVRUFK5everwARJCaq6KKU/sDAV7AaVhNNyH+dO/qKAR5CJPvFfnGRoA1ncLprSnynVGeQZioRhlZjqfy8VyrPx3JU6nlXel5bt+QK1hcOZuNgCgtEwDtYZx+d+t7joVNg3w+L3jevt8m/ItRjQfUeljI6Sqsb2MLK3lKiorwoIjC+yqIAgAvWPD4O8pQXaB8SDeHZpoWmJ1QBEXF4dz586hfv36aNeuHT7++GNIpVKsXr0a9evXd8YYAQCPHj3C5MmTsX37dgDaxd9ffvkl/P39TT5nzJgxWL9+vd62du3a4cSJE04bJyHEcUylPLGBxsZzG1HLsxaebvwsNMJMI0dQw5aAgk17osXZlePvu3+jTFOG2OBYXFJd4rbvHbUXQZ7a30GwZzCG/TJM73l8Zih2X1BiwZ+XuAZ3uy6k4fRHB116/YSpdSqfJn2q9/2h24cqc1iEVCuRfpF6xR8qOqY4hul7pwOwb4YC0DbRNBVMAO7RRNMSqwOKOXPmID9fW0nlgw8+wMCBA9GlSxcEBQVhy5YtDh8ga+TIkbh37x52794NAJgwYQJeeukl/Pnnn2af17dvX6xbt477XirlP0VOCKlatX1qo0lwE1xRXQGgXZSdU5SDTec3AQBOPTiFkVtHmnw+A43ZvFZz3L0iR3XSLaobJEIJPCWeegFFXkkeejfozX1fcUG+pYBi9wUlJm5MMUhFSHPxRobWdgEmhOhTPlbim+Rv8M/9/1Jk7QwoakITTUusDiieeuop7uv69evj0qVLyMrKQkBAAFfpydEuX76M3bt348SJE2jXrh0A4Ntvv0WHDh1w9epVxMTEmHyuTCZDWFiYU8ZFCHGuhT0WYmGPhXjrr7fwxckvkFeSZ9Csy1vqrbdYO6T4A6TL5vz3Hb9ypMa4e0WO6mR0q9EY3Wo0MgsycfbhWe7Ouq/MV2+/imtizFU4UmsYLPjzktG8ZgY1IwWBEGLcwdSD+OHcD9z3akYNtUZtkGbLF1V6sqMPha7AQOeuXE9KSoKfnx8XTABA+/bt4efnh+PHj5sNKBITExESEgJ/f39069YNixYtQkiI6YoixcXFKC4uz6XLzc11zA9BCLHJ3pt7cerBKQDaO9a+Ml8s6rkI93LvYXqH6ajtUxu/nz+Lkds7AQINBDofa4wdAcWjfPvuWBHrBXkGoUVoCxy6fQgzO85Er/q99B6v2IPE3AzFydQsLs3JmJqQguAj9anqIRBSLbGfNa3CWiHKLwpSkdTmIh5AeaUnc585gHufV6wOKIqKivDll1/i0KFDSE9Ph0ajf8JOSTFsIGSvtLQ0o0FASEgI0tJMr5rv168fnn/+eURFRSE1NRVz585Fz549kZycDJlMZvQ5ixcvxoIFCxw2dkKIfQZuGsjNSuSX5kMqkuLdLu/q7TOsVTuM+TMIJchAmSBD5xHb++K8v/MSnoqju9fWYqurWOpDEewZzH1/Kf0S0vPTtf0pMrXFPYrVxUhRpnDHjPSLtCrliVIQgFZhrap6CIRUS30b9kXfhn0ddjyRUIC5A5ri9U2nze7nzucVqwOKcePGYd++fRg6dCjatm1rV5rT/PnzLV68nzqlvTNp7HUYhjH7+sOHD+e+jouLQ5s2bRAVFYWdO3di8ODBRp/zzjvvYNq0adz3ubm5iIiIMDtGQohzvHvgXb0UJ0WOgrvIBMovNEVCAdSCbIABMqXLdI5g+wyFu9+9dhbd6iql6lK0X9MeAJA4OhE+Mu0dc91O2YocBZqvam4QLHz+z+f4/J/PAWgDkIMvH0R+qX4n9AsPL0AsEhscE6AUBKC8GhohxNC93Hu49egWwrzD0Diosd3HC/AyfqNalzufV6wOKHbu3Ildu3ahU6dOdr/4pEmT8MILL5jdp169ejh37hwePnxo8FhGRgZCQ0N5v154eDiioqJw/fp1k/vIZDKTsxeEkMqjyFHg42Mf623bd2sf9q3eZ7Dv1PZToWYMK2wwdsxQAMCqwzcAaKez3fGOkrOw1VXUmvL3Py4kjqvYpEtVoDLZ/ZxVVFaE7uu7GyycbLemPA22YvdtNgUhLafIaCKDANpu2e7cbCq3mFJ2CTHl54s/Y/re6WhTuw2+e/o7NK3V1KreNhXV9FlRqwOKOnXqwMfHMXmZwcHBCA4Otrhfhw4dkJOTg5MnT6Jt27YAgH/++Qc5OTno2LEj79fLzMzE3bt3ER7uelU9CKlpVAUqqBl+AcFnJz7T38AIAAEDCDSwIy0Wh6+pcPiaCuF+cpcuM1pVVv27ivua7+/SFEtVWNju22xAwfYnmbjRMA2XDQ3nPe3evUZ0e3YQQsodvn2YKxn774N/0eqbVrjx5g00CGxg8zFr+qyo1fOhy5Ytw9tvv407d+44YzxGNW3aFH379sUrr7yCEydO4MSJE3jllVcwcOBAvQXZTZo0wbZt2wAAeXl5mDFjBpKSknD79m0kJibi6aefRnBwMAYNGlRpYyeEVAXtRaKpRdlhvjIEePJrigaUlxndfUHpkNHVFFmFWdzXlmYhnKFvXDhWjoqHf4XfdZif3GVLxgL8ugCzUpQp3H+KHIWTR0aIaygsK9T7Psw7zO7PKHZW1NwtinA3nhW1eoaiTZs2KCoqQv369eHp6QmJRP+DOisry8Qz7fPjjz9i8uTJ6NOnDwBtY7sVK1bo7XP16lXk5OQAAEQiEc6fP48NGzYgOzsb4eHh6NGjB7Zs2eKwGRZCSHVn/K74/Gea4VRqFtYcu83rKGyZ0fnbL8JHLoEqrxghPnJKhbJAd82DbvpTZeobFw5VXgnm/H4BcbV9MXtArMv/3ox1AVbmKTFw00CDfRNWJ3BfV0wLI6SmEgvLL38ntpmIrwd8bfcxzc2Ksp5pGe7Snz3mWB1QjBgxAvfv38eHH36I0NBQp/WeqCgwMBAbN240u49uSUEPDw/s2bPH2cMihFRHAu2dpjKooBGU34nylYvxZs+GCAlSIqIgG2WCdIgZ02WkdTEA0nKL8eJ3/3DbKBXKPN3+IPamPNkjp1C7via2tq/bLIas2AVYt1iBKRXTwgipqUSC8n4TusGFvfrGhWNC12h8cyTV6OOrj6SidWSAW54zrH4Xjx8/jqSkJLRs2dIZ4yGEEIdRecyDhinjvk8D8OZBAAe13wvkEtQu+oZ3UFGRq3dcdrbqMEMBAFn/1X4P8LJ9wSUhxH3ozu5lFWYZBOQVq8bxpdYw2H7WfGqsuzbUtDqgaNKkCQoLCy3vSAghNlLkKHBZddmuYwgg0AsmjGFQCjVyIYZtAQV1XDavOsxQqDUMrqU9BgA8LiyFWsPQ74mQGkyRo8CobaO47388/yN+PP+j3j62pgfW5IaaVi/KXrJkCaZPn47ExERkZmYiNzdX7z9CCLGHIkeBmBUxGLV1lOWdzbCn66l1r1N+giD6dAMKUwsegz2DndYvYfcFJTp/dBBHb2jvRm46eRedPzpIi+sJqcFUBSreVeOsVZNLx1r9Kd63b18kJSWhV69eCAkJQUBAAAICAuDv74+AgABnjJEQUoOoClRmuyxXJBY4Lv/VHu54grBXfok25alHvR6o5VnL6D6RfpFoX1fb/O71Nq/b/FoVu2/vvqDExI0pBncLqWIXIcRZanLpWKvPxIcOHXLGOAghxCZikRhlZeZTm8zxkYtR4oAsTnc8QdiLnaGY2WkmAjxM33Bim0lF+EbwOu7S3kvRI7qH3jbdnGe1hsGCPy8ZnaOiNDVCiLPU5IaaVgcU3bp1c8Y4CCHEJvamyzzTsjZ+PWHfGDylIrc8QdiLDSi8JF5m92MXbAuF/H6XwZ7BiA+PN/l4Tc5jJoRUHd3SsQIY9lVlAMwd0NQtb2TYdCbOzs7GsmXLMH78eLzyyiv47LPPuP4PhBBSmYQCIXxlvjY/f/gTkQaNz6xVUKLGvktpdh3DHbFVnk49OIXHxY9N7seur+AbHIZ5h5l9vCbmMeume5lSMS2MEOJ4bEPNMD/js9bv77zslimXVgcU//77Lxo0aIDPPvsMWVlZUKlU+PTTT9GgQQOkpFiug00IIY4kFAi5OuJT20+1eDe8IpFQgCWDm5vtbmoJm0Kj1lTOQnBXwc5QTN87HVczr5rcb3nf5dj30j70jO5psQO0XCxH01pNze5TE/OYdavRRPlFIXlCssF/1NSOkMrRNy4ccwfEGn3MXddxWZ3yNHXqVDzzzDP49ttvIRZrn15WVobx48djypQpOHLkiMMHSQghpix/ajnWn12PnOIcTGwzEWqNGl+c/ILXc8VCMYrLirk7Sgv+vGQ2VcYUd0+hUeQozFY80V2/wO7LMAw3K+Et9cbNrJsQCoRG67u3qd2G+/rqpKvYe3MvzqadxV83/sLNRzfxcouX8Vb7twxey5SanMcMAB4SD7MpYYQQ51JrGLy/85LRx9x1HZfVAcW///6rF0wAgFgsxsyZM9GmTRszzySEEMca02oMxrYeix7RPdD7h954ceuLaFunLQDtzIWpUqWsMk0Zem7oiauTrqJvXCR6x4bhZGoW0h8X4baqAJ/tv2bVeNwhhaZi8KDMU2LwlsFmyyyyNdsBIGZFjEGVrrySPLzw2wt6+5oKCiL9IjE+fjwAYNb+Wfjo2EcI8gxCfHg8Tt0/hbs5dxHoEQhvqbfJ8ejmMVfEnrrnPR3rNidy1sQ2E7Hy35V4uvHTVT0UQqqtYM9gyEQyFKuLTe5jb3pgTVzHZXVA4evrC4VCgSZNmuhtv3v3Lnx8fBw2MEJIzRTsGQy5WG62dKxYKEaZpoxbzFtYWogbWTcAAI+KHgHQ5uXP6DADS5OWmn09tt54pF8kREKB3od7TJg3Zm09j+yCUl5jd/UUGrYHiDVlewH9mu2Wnqv7frN+vfQrMgsy0b9Rf0T4lVd6+ujYRwCAPTf3AAAGbRmE+4/vI3lCssU78Oys06zfziO7sPz3F+Ynx7ynY92yszmb+sdWzSKEGIr0i8S1N69xn1nvHHgHe2/uxYwOMzCi+QgAtnfKZtXEdVxWBxTDhw/H//3f/2Hp0qXo2LEjBAIB/v77b/zvf//DiBEjnDFGQkgNEukXiauTrhqk2PRY3wO5xbn49flfcSbtDD44+gH23NyDo3eOwk/ux+3HBhYAUMenjl1j6RsXjt6xYTh+XYWJm5KRV2y623O4G6TQWNsDxFE+PPohTqedxu4XdyPCLwIZ+Rm4m3uXe5ydaWKbFQp4rnjpGxeOB9mFWLjjMlpF+OPtvk3QNjrQ7WYmWGyAzQYWhBDjIv0i8ceVP3A96zoUOQoAQLhPuMNSBWviOi6rP3WWLl0KgUCAl19+mav9LpFIMHHiRCxZssThAySE1DyRfpEGd4c8JZ7ILc6FQCDAB0c/AACk56fjhd9eAMMYXwxdxtjen4IlEgrQJaYWlj7fEhM3ppjsv/1My3C3vVB1tp7RPRHlH4VQ71AAwKbzmzBlzxTucTaNzdpqUAC42aW4Or5uk1pgytf/fg0AOHn/ZBWPhJDqrUxThvmH5yOrMIsrBFGmsf98waqJ67isDiikUik+//xzLF68GDdv3gTDMGjYsCE8PT2dMT5CCAFQnsaRnp+ut71pcFMcSD3Afc/MY9B1XVccVRy1uIbCGn3jwjGhazS+OZJq9PHVR1LROjLALVNpnG1pH/20NF+ZL+r61sUzjZ/BVwO+4razgaNAwD9wyyrQrv0I9HTPNCBjC+avqq4iRaldP2Jv6gYh7ii7KBtZhVkAgOYhzXHqwSkuoLCmCIUpfPpRuNs6LpvnRT09PdG8eXNHjoUQQkxiA4raPrUxs+NMnEs/h1mdZqFbvW5YcXIF3vzrTW4RnUgoAgBoNI4LKNQaBtvPmi/z525VO6rK2NZjMbb1WIPtbMqTNTMUj/K1MxSBXu4XUJha83Ir+xYSVicAsLwInpCaSCKUINw7HCKhCJPaTsKp+6eQEJ7Aax0Z339T3DouI+vw7O19VB1ZHVDk5+djyZIlOHDgANLT0w1O2Ldu3XLY4AghhMUGFL4yX3zU+yO9x1qEtgCgvXOUokxB4u1EAICaMb3mwVo1sWpHVZu1fxZK1aV4u/PbCPEK4Wac+K6hAICsfO0MRYAbBhR81rwYWwRPSE3nJ/fDg+kPuO9fbvkyACBFmeLwf1M5Rop65BSUYuLGFKwcFe82s9pWBxTjx4/H4cOH8dJLLyE8PNyqqWdCCLEVG1AYK19aqtZ+YF9RXeHuzAKODShqYtWOytJkRRPcyLqBxDGJ6BzZmdvOVnlKL0jHD4N+sDrlSa1hcO9RAQDgYW4R1BqGZo8IIQCAm1k3UaYpQ4RfBDwljk/bV2sYLPjzktE1FO7Yi8LqgOKvv/7Czp070alTJ2eMhxBCjGIDiod5D7Hq31X4+eLPOHT7EPo06INo/2ijz/EUe1osQcu33nhNrNrBl+57aOn9loqkUOYpuRx/AMgvyYeaUXOpTHtu7MG8xHnc46funwJgXcrT7gtKvUaFH+66gnXHbrttyVhCiHWe3fwsLmZcxPYXtuOJOk/AQ+zh0OPXtFltqwOKgIAABAa6z6p0QohrWDVgFQrLCpFdlI2XN73Mbb+TfQd7b+7V29dL4oX80nz4e/hj46CNOP/wPJrWaopLGZew8MhCdIrohC/6abtp8120WhOqdvDpAQIADfwb4PP+nyPcO5x7HvsesiV/zz88j3mJ83An5w6A8t4hJeoSDNw00Ohx2QX3j4oe4Z/7/3DbZ3aaCQC8U552X1AarciVllPkdmkGhBDrqTVqXMy4CACYfXA2zqefx5R2U/BSy5cc9ho1bVab/8q2/7z//vt47733UFBQ4IzxEEKIUa3DW6NjREf4y/31trMLsHWxKTFqjRr7bu3DgiMLcEV1BU2CtQ05pSIp4sPjER8ezzsPlq3aAcDgctZdui+zPUB2jNwBidD0osGb2TcxeMtgKPO0i9RVBSqkKFOQokyBqkCFYM9g1PapzQUTAL+SjLnFuQAM+yg8E/MMAH5VniylGQDaNAO1xlQBYEKIu1LkKJCiTMGZtDPcNvYGSlpeGs6lnXPYa9W0WW2rZyiWLVuGmzdvIjQ0FPXq1YNEon/SSUlJMfFMQgixX8VSsMbSX8rU2ovXpHtJYBgGLUNbQlWgQnZRNgBw/7cWW7VDN5UGAAK8JPjg2TiXv+vNlkvMLspGqcZ8d3BzMw1ysRzfDPzG6tdnf5cVAwo2uOGT8lTT0gwIIfyYquB0Pes6AGDzxc3YfHGzw17P0qw2oK325Mqz2rqsDiiee+45JwyDEELM23V9F65lXjO42DR2cVmk1p4w1p9dz207+/As9/WZtDNQ5ChsqnzTNy4cGg3wzrbzyCnUXnRn5Zfi/Z2XIRQKXDao4FMuka+isiK995svUwHFP/f/QZ8GfXilPNW0NANCCD98qqI5Ejur/dpG0zfaswtKse9SmsueN3RZHVDMmzfP8k6EEOJg686sw6+XfsWwZsP0tgsFQjQPaY7z6ed5H4sBY3Mpzd0XlHhjk/vl5zv6ZPtp0qdWP0cI4wHFm3+9iauTrvJKeapJaQZ81rzwLTpACOFHKpLy/jfVOzYM/p4Sgz4ULHeq9GRzYztCCKlMXSK7QCqSIsovSm+7SCBCXFicVQEFAFxWXTa63dwi7ZpWBrCysYFCxYCCnZm49uY1aBgNwrzDTB6jJiyeZ7FrXuzt6ksI4W/r8K28/02dTM0yGUwA7pWCaXVAoVar8dlnn+Hnn3+GQqFASYl+TfisrCyHDY4QQliT200GABxKPYTFfy/mtgsFQrMLiE0ZtXWU0e3muqBSfr5zmUp5YvuM1PapbfEYbJrBRCNpBu6yeF5XpF8kBQyEVCK2uh0fNSkF0+oqTwsWLMCnn36KYcOGIScnB9OmTcPgwYMhFAoxf/58JwyREELKGVuUbesia2PYLqjG1KSTQ1UQCk0EFBYWiFfELp73kulXAAvzk7tsShohxPXUpBRMqwOKH3/8Ed9++y1mzJgBsViMESNG4LvvvsN7772HEydOOGOMhBAChmFQoi4x6JRdUFqAbVe2VcoYatLJwdHYxoTmBHloZ3UqBhTs73z6numYsnsKrwCyb1w4BjTXBg7948Lw0yvt8ffbPSmYIIRUGjYF09x8aLibpGBaHVCkpaWhefPmAABvb2/k5OQAAAYOHIidO3c6dnSEEPKfGXtnQPaBDO8efFdvu7VrJ+xh6eQggPucHBxt6/CtSJ6QjOQJyejToA8AYHqH6UiekAxPsScAoK5vXQDadTG62JSnL05+gc//+Rz5Jfm8XpPNXe7QMBgdGgS5TZoTIcQ16PYvMuWZluFu8dlkdUBRt25dKJXaZkYNGzbE3r3aDrWnTp2CTCZz7OgIIeQ/7B3u4rLiKhuDueZ2gHYNhTvl5zuSXCznmgn6yfwAAPX86yE+PJ5bjG1yDcV/KU+zOs3CO53fgY/Mh9drsgFFoKfl2RFCiHtjq6LZw5aqaX3jwjGha7TJx1cfScXuC0q7xlUdWL0oe9CgQThw4ADatWuHt956CyNGjMCaNWugUCgwdepUZ4yREEK4gKIy64gbw+bnz9p63qB6h7+n9YvDqws+JUiN8ZZ6I68kz+J+u67vQq/oXgDArVG5m3MXAPD9c9+jVF2KEK8QAKZTnt7v+b5VY8sq0D4vwMt1fy+EEMcwVhXtsuqyyQIdusa1Goc32r5hU9U0tYbB9rPmAwZ3qA5odUCxZMkS7uuhQ4ciIiICx44dQ8OGDfHMM884dHCEEMLiZijU1s1QyEQyrHl2DVIfpWLuobkOG0+OkVKAOQWlNvWiYDtUm1IZpT8rnmz5nmgrpieZwq6PAIBDtw8BAD4+/jE+6v0RhsYO1du3llctTG0/FUVlRVj570qUacrAMIzZ/hMVqTUM0nO1wdHdrAKooxmXPlkTQuxXsSpasGcwJEKJ2cIPEqEE4+PHIz483qbXrCnVAe3uQ9GuXTu0a9fOEWMhhBCT2ICiR70eGNZsGJ7d/Cyv53lKPPFi8xeRokxxSEDh6F4UfDpUS0VSbB2+Fc1Dmjs1sNA92Z68d5LXc3KKtevoJsRPwOqU1dz2Hwb9gL8Vf6OeXz2MbDHSqnGHeYfh06c+RXZRNlb+uxKANu3pdvZtAECDgAYQCU0HMrsvKDF/+yXkFpUBAN7+7TyW77+OeU/H0qJsQggn0i8SK/qtwKs7X+W2PdP4GczrXt7E2d4bOjWlOqDVaygIIaQqsAGFmlHDR8ovh173edbsby5H1pq7TXzw6VBdoi7BwE0DEbMiBoocBa/j2uvj4x9btX9+qf5C6VEtRmHVwFWY1WWWxZPx1stbse3yNr334VDqIUQtL29iWKIuQcyKGMSsiMGjokcmj7X7ghITN6YgLVf/PWU7mbtDrjIhxHHCffRvMmy/th31A+qDYRh4SbzsvolTU6oDUkBBCHEJbGBQoi7hFu/yYW3TO0tdUKvybpO5HhmO1iiokVX7axgN2tXRzlb/8cIfVj13yM9DMPjnwcgp0s52qDVqXM28itziXG4f3cX4AhN1tizNHgHa2SO1xtgehJCaqOKaLQA4cucI2nzbBvGr47Hh7AYcv3vc5uPXlNKxFFAQQlwCG1CcuHcC47aP4/08ici6gMJSF9Sacrdpca/FlnfSoSpQcf0hPCWeSM9Px7mH5/C/vf9Dt++74fsz3xt9HsMw6BLZBZ0iOkEm1lYKTM9Px8SdE/X20107YyqgdPTsESHE/VUMKH4Y9APXQLWgtACjfx+NDWc32Hz8mlI61u41FIQQUhnYgOLB4wdWPa9D3Q4OHQd7tyktp8jonXABtB2ZXf1uk7X23drHzRx4SjyxJmWNXs+QHvV6cF93jOjI3fETCAQ4MvaI3rHEQjGkIilEAhHuTr0LqUiql7pmanF2TclVJoQ4TsWAQiqScgEFq6C0wK7XYEvHfnMk1ejjq4+konVkgEuv8bJ5hqKkpAT37t2DQqHQ+48QQpyBvaCs7VMbU9pNQcvQlljSawnXLE33vzeeeAMAMCx2GH4c8iMAfjXI+dQYrym9KGyp2c78F2I9t/k5eEo8uTKwgDaNibWg+wIAQPOQ5kaPU8urFornFKNgdgGCPIMM+k6YSnmqKbNHhBDHCfUOxbBmw7jvnRFQ8C0d68rpmFYHFNevX0eXLl3g4eGBqKgoREdHIzo6GvXq1UN0tOnGHYQQYg82oKjnXw+f9f0MZ147g7c7v801S2P/YxgG6fnpAAAPiQf3fLYsase6HQEATzV4Cp0iOgEA3u70NpInJOPqpKu8FuCxvSj8jPSdcOVeFLr6/9gfAfIAbBu2DRsHb7TquRkFGXir/Vt4OOMh3mr3FgDtYnoWu67FXKnG08rT+ODIB/j10q8AyoMVwHTKE3UyJ4RYK7ZWLLYM3YJfnv8FADBp1yQwjP6Fvb0BRU1Ix7Q6oBgzZgyEQiF27NiB5ORkpKSkICUlBadPn0ZKSoozxggAWLRoETp27AhPT0/4+/vzeg7DMJg/fz5q164NDw8PdO/eHRcvXnTaGAkhzqO7KNuUJX8vQZtv2+CXS9oTg+5FLKANKoK9tDMQe27uQaCH9sLSV+aL+PB4q6t5mOtF4erVhO7l3oMyT4nYkFhE+1t/s4g9IbN9KnRnKNjgoERdgsLSQoQuDUX4snDkl5RXijr14BTmHpqL5395HuP+GKdX3cpUypO5XGX2Ge4we0QIcTz2BpMyT2lw7rA3oKgJ6ZhWBxRnzpzBN998g379+qFVq1Zo2bKl3n/OUlJSgueffx4TJ060vPN/Pv74Y3z66adYsWIFTp06hbCwMPTu3RuPHz922jgJIc7BBhTKx0ok3k7Es5ufhcciD8xPnM/tcz3zut5zNp7biBG/jQCg7feQokzBg9zyNRiBHoEI8gjCw7yHVpVjdWQ1IVtSiypDmUbbw0EilKCkzHQQZwpbApadTdBNIeixXrue4tajW0hWJiM9Px1peWk48/AMUpQpSH2Uild3lNeFX3dmHY7eOcp9fzbtLFKUKUZ/Z+zskYdEv09FmJ/c6oaDhJCaQcNouLUUGkZjUMq7sKzQruPXhHRMqxdlx8bGQqWqnLKFuhYs0Obcfv/997z2ZxgGy5cvx+zZszF48GAAwPr16xEaGopNmzbh1VdftXAEQkh10jKsJbYO24q9N/dyF6QAcC3zGvc12+ws1CsUD/MfAtDeBTfVPG792fUAgC9OfoFVyauwdfhWhHuHW2xk5MjOp2wq1vn08xi0eZDZNCA+azwchR2HWCjWSx3j67MTn2H3jd04+/AsgPLZoopBQJd1XbivO6/tDABGA6zxf44v329d+X7G0tT6xoXj1+R72H85HcPa1MWg1nXRNjqQZiYIIQbOPzyPFqta6G1jZ0sFEIABY/cMhaViHoDrp2PyCihyc8trgX/00UeYOXMmPvzwQzRv3hwSiX6+sK+vr2NHaKPU1FSkpaWhT58+3DaZTIZu3brh+PHjJgOK4uJiFBeXlyfU/dkJIZVPkaPgei9E+UchwjdC7/HC0vI7R2x6Dat1WGt80fcLPMx/yLt5HGD6QpXl6OlrtkP1jck3cODWAb2yuMObDcfMTjMB2N+x1RrcDIVIYnXpXQC4mHERRxXlswpsyhOfPhqWfle6+6kKVEbfk+z/0tF6xIRYDOoIITWXsT4U9x7fAwB4iD1QUFaAR4WPkKIsT+u39rOYTcecuNH00gBXLx3LK6Dw9/fXy1llGAa9evXS24dhGAgEAqjV6opPrxJpaWkAgNDQUL3toaGhuHPnjsnnLV68mJsNIYRULVMzC7q2X9sORY4CkX6RBot1I/0iUce3DjdbwZe5C1XAOdPXbOBUcQaiVFMKZV75egxjF+SODjQ0jIZLUTJ2suVDdz0EYLiexdmyCrRpWgFe1nVKJ4TULI2CGiHjfxkY+8dY7Li2AwCw9NhSAEBBmXZm4v7j+0hYncA9x9JNJ2PcvXQsrzPFoUOHnPLi8+fPt3jxfurUKbRp08bm16i4eI8NfEx55513MG3aNO773NxcREREmNyfEOI8qgKVxbvVGkbDXfyzKU9sAOGsi1g+09dCAfAon9/aA3OB09bLW7H18lazz7fl5GYOOzsBWBdQSEVSeIo9kV2cjbySPL3HdBdlVwb2vQ/wpICCEGKaWChGsGcw/hzxJ2p9UguqAhXKmDKzz7F008kYvqVje8eGueRMBa8zRbdu3bivFQoFIiIijF6o371716oXnzRpEl544QWz+9SrV8+qY7LCwsIAaGcqwsPLo7309HSDWQtdMpkMMpnMptckhFStijMUO67twM5rOxHu49g7PnymrzUM8MamFKwUWl4IzCdwMseWk5s5ugGFRChBsGcwl0tsihBCJI5OxPO/PK8XUAgFQr0Zj8pQUqbBo/9Snm6p8tAwxNslT9CEkMrlIbZ+vRhfjlx7Vx1ZXeUpOjoaGRkZBtuzsrKs7kMRHByMJk2amP1PLrdtxXt0dDTCwsKwb98+bltJSQkOHz6Mjh072nRMQkj1ptvwLLaWtnzoodvOmWHtGxeOr0a2hqXrVFdsVlSqLl8YLhaKEekXiZjgGG7bvpf2caVkVw1YheQJyUidkooOER24BdX5pdqUJ7Y6V2WlPO2+oETnjw5y30/cmILOHx10+TK+hBDnyC3OxcQdE/Hqn6/aVICCL3cvHWt1QGEqZSgvL8/mi38+FAoFzpw5A4VCAbVajTNnzuDMmTPIyyufVm/SpAm2bdsGQJvqNGXKFHz44YfYtm0bLly4gDFjxsDT0xMjR4502jgJIVVH9w76E7WfAADIRM6bcQzwksFcrOCqzYr0Zij+W5DtJfHitrWp3Qb+cn8A2oXy8eHxUOQo8MS3T+Dmo5sAytdQVGZAsfuCEhM3piD9cbHe9rScIrfoDUIIcbzismKsSl6F1Smr9aoGOpq7l47lnRzLrisQCASYO3cuPD09ucfUajX++ecftGrVyuEDZL333ntYv349933r1q0BaNd3dO/eHQBw9epV5OTkcPvMnDkThYWFeP311/Ho0SO0a9cOe/fuhY+Pj9PGSQipHtiLYvaC1hnc9Y4TWzJWAAGXRqZb6UkmknHva1ZhFgpKC3An+w7+ffAvtw+b8vRE7ScQExSD9nXbO3XMlnqDCODa+cmEEOewtfCEtSytvRNA2y/HVUvH8n4XT58+DUA7Q3H+/HlIpeUnaalUipYtW2LGjBmOH+F/vv/+e4s9KCq2ShcIBJg/fz7mz5/vtHERQqqnH8//CACQiWVc8zh71ikYw/dO0m2VfTXMK5tuyViWRFj+tVQk5QKKF7e+aPQYbEDRr2E/TO84ndvOp48G39+Vbl8Od89PJoQ4R2UFFLpr7wSAXlDB3uKY93Ssy97w4P0uspWexo4di88//7za9JsghBBWxZsKgPZuOts8TlWggjJPicFbBqNEbboCE98Gcm2jAxHmK0NabrHZ/TafUmBSz4ZGTxSKHAUuqy5bfK3KxK6h0D3RhniFANCmO4mEIrMzP5OemIT9qftxRXWFq7zFivSLhK/MF7nFuWhWqxkuZlwEoH3Pj407BkAbdEQtjzJ6bAEE+HfCv9x+7EJ0d50tIoQ4V2UFFIB27d3KUfFY8OclvRsgAV4SfPBsnMuWjAVs6JS9bt067uu7d+9CIBCgbt26Dh0UIYQA4DWzIBKIuIt/Y1WI2AtftnkcAFx/8zrXz6H3ht7IKsrCT4N/QuPgxtzr8qmYJBIKMKJtJD7bf93sfqbujPPps1EVAjwCsPyp5Xrr5QI9tNPwz8Y8C0A/lSzMOwyDmw7G16e+Ru/6vTG29VhczbyKK6orKFWXIj0/HVKRlFt3wQZ+IV4hXEAhEUoQHx4PwLCbtq7nmjxn9Pfj7vnJhBDnqBhQvPnEm/jq36/MVqbje9PJmL5x4dBogJm/nUNesXY2OCu/FO/vvAyhUOCyQYXVi7LLysowd+5c+Pn5oV69eoiKioKfnx/mzJmD0tJSywcghBCe2JmF5AnJSBydaHSfMa3GcBeXbWqX96wZ2Fjb9VomNlyUHekXifjweMSHxyPQU3uhXNevLrfNmvKr9YK9LO8E43fG7S0Xy7Ln5GaMv9wfb7V/C5PbTea2eUq06+bYxda6i6zT8tLw9amvAQD7bu1DwuoE7LulrbD33envELo0FP+3/f+4/dnn3s6+DQCo518PHz35ERQ5Cuy8vhONvmxkcmzbrmxDzIoYg6CDzU82lSwgABDuwvnJhBDnqDiL+kX/L7BlyBa82PxFLOi+ABPiJwAABjUZhOQJyUiekGxX35/dF5R4Y1MKF0ywXL14hNUzFJMmTcK2bdvw8ccfo0OHDgCApKQkzJ8/HyqVCqtWrXL4IAkhNRc7s/C4+LHRx/s17Md93bt+bwDa3gdsSpOlKk++Mm36Zm5xrk3jq4w748v7LkfDwIZQ5asw5o8xAIDFPRejT8M+ABzfKdsYNg3qt8u/YfGTi42mlxnDLurW3Z9do5GanYpxrcbhqYZPoVVoK96zNcb6bpjrDeIO+cmEEOeo2L8oRZmC+oH1MaL5CGQXZUMikGB6h+lc5UAA3Ay3tZ+77lw8wuqA4qeffsLmzZvRr1/5SbxFixaIjIzECy+8QAEFIcQpdD/0/x77Nzqv6wwAeCbmGW47e+dbKBByAYKlKk8+Um3VN1MBiyV8umb7e0rsujPeJbIL4sPjMfmv8hkDX7kvlyLkaI+LH+Psw7PwknghyDMIqgIVrqiuAACuZ11HijIF7eq042YhzJnRYQbGtR6nlz6l2zV77Zm1WHtmLX4a/JPdszVsfvLkn06jRF3+2wjzk2Pe07Eum0pACHGeirOdCasTeD1PLpZbPVPhzsUjrA4o5HK50e7V9erV06v8RAghjqQ7LR3lX75gVzfPlQ0KyjRlOHHvBADjKU+67J2hYO+Mv2ama3Z2QSn2XUqz+4K2cVBj7uusQuf1triUcQld1nVBXd+6RtOy+J5wAaB1eGu9YIJhGKM9Kc48PGPzeHX1jQtHZOBV3MjIxxs9GqBzw1poGx3ocnf7CCGVg51tsFZRWRGOKo6iS2QX3kGFOxePsHoNxRtvvIH3338fxcXlVU2Ki4uxaNEiTJo0yaGDI4QQVsVpaVZOcXnvGTaPX5ellCcf2X8zFCW2zVAAQO/YMPh7Skw+zk5j29sxe1LbSZjZcSYA5wYUEpEEDQMbItQr1O5Zg8uqy0hRpnB3ASsudHyy/pMAgO9SvrPrdXRl5mvT3Z5pWQcdGgRRMEEIcYpRW0cZXdNlijsXj7B6huL06dM4cOAA6tati5YtWwIAzp49i5KSEvTq1QuDBw/m9t26davjRkoIqdFEgvIZiv/t+x/39Ud/f4RlTy0DUF6JSJellCdfqX0zFIB2Gju7wHRRCnunsXXLyrIX+Hdy7lh9HL7iw+Nx/U1tapM1sxHGjNo6CoC2ksrNyTcR5h2m9/j+W/sBAHV96yKzMNOu1wKAMrUGj/77XQR506w5IcS5jK3pMsWdm9tZHVD4+/tjyJAhetsiIiIcNiBCCDFGd4Zi84XN3Ne66TQLeizAgh4L8M+9f9B+jbYzc4BHgNnjcjMUNq6hAJw/jc1elOvadnkbdl7fiXBvbRpVZSzMtkeZpgyqAhXCvMPQp0Ef7L25l3vs7GtnUaYpszt4AYCMx9rZcwGAq2mPEVBfSjMUhJBqwZ2b29nVh4IQQiqLQCCAAAIwYDCy+UgcSj2El1q8hPnd5xvsy663iPCNsLhw2d41FIDt09j2dPBmwGDgpoHc97YsEKwKUpEUe0btQfw38Tiddho9o3ti0q5JeKrBU3Yfe/cFJeb8fgGA9kT94nf/IJwWZBNCqhFTze1cvXiETe0By8rKkJiYiJs3b2LkyJHw8fHBgwcP4OvrC29vb0ePkRBCAGhnKdSMGp/0/gS1fWobPF5cVoz7j+8jLS8NAIwu/q2Iq/JkxxoKW6exdTt467qsumx0VsIca6bdLUm8nYgpu6cgwtd5s88SkXbNyeWMy1DmKdGsVjPezzXWd2P3BSUmbkwxeP/Z2u4rR8W77ImaEFK96aal8pkt7hsXjt6xYViZeB1L915HsLcUS59vifb1Xauyky6rA4o7d+6gb9++UCgUKC4uRu/eveHj44OPP/4YRUVFVDaWEOI0IqEIarXaZAfTL09+qbe+gu13YI4jZijsmcZm+2xkFWahoLTAoQ3qbJVVmIWzD8869TUkQm1AoczTNnFalbyK12yNl8QLl964pHfCdufa7oSQ6k/3BpBUJMXW4Vu5dFRWxUBj36U0fH9cuxZOlVfi8jOqVgcUb731Ftq0aYOzZ88iKKg8kho0aBDGjx/v0MERQogudh3FzaybmHNwDk6nncbcrnMxNHYoAOBOtv5C5fT8dNzLvYe6vnUNjqXIUUBVoEJGQQZkIhnySvKQoiwv/WrtmgR7p7FXJ6/GOwfeweiWo/U6VFcFNhATC22axDYrIz8DDb5oYHRG6NdhvyK7KBuAtls3e0LOKszCmN/H4P7j+5CKpAa/F3eu7U4IcS57Uk+NKVGX6KWjsnTTUt1xRtXqs8Xff/+NY8eOGfSciIqKwv379x02MEIIqejr/l9j8d+L0X19d27b8bvHuYAi2j8aAFDHpw7uP9Z+Hl14eAHp+ekAyoMERY7CoCvzUcVRvUXBtqxJYKexR65Owj+3H6FLw2C81r0Br2ns4rJiiIViBHlU/QUv2xXbQ+Jh8UQrhBA+Mh+98r1mj60pNZleZmpNyP3c+9zv01j5YHeu7U4Ica5Iv0gEeQTh/uP7aBjQEDce3eAeax3WGqfTTjvkddi01Do+EW45o2p1QKHRaKBWG+Yl37t3Dz4+Pg4ZFCGEGDO29Vg8zH+Idw68w20T/JdUpMhRYNaBWQDAXXwCQL9N/biv2YtUY83aKrJ1TcK+S2m48ECbPnX0hgpHb6h4TWPP6z4P73V7D2WaMpxPP2/VazoaO0PhI/UxusZDmafEsz89CzWjhgYa3sEEAIR4heD34b/juS3Pmd1P9/0P9AjE9A7TsSxpmV5VL+6YblzbnRDifOw5QzeYAICzaY5P/XTXGVWrG9v17t0by5cv574XCATIy8vDvHnz0L9/f0eOjRBCDFRcP8HOOBxVHEWpxnQvCKD8ItVZ2Gns/BL9my7sNPbuC0q97YocBVKUKdx/p9NO43z6eb0FfpWh4jhuZGlPqnkleVAVqBDsGYz48Hjuv3DvcF4L3nUJIECwZzDEQjEi/Kxb7O0h8cDolqO541TELoo3dS9PACDcRWu7E0Kcb2nvpfCR+sBT4qm3XQPj6/Xs4a4zqlbPUHz22Wfo0aMHYmNjUVRUhJEjR+L69esIDg7GTz/95IwxEkIIAOBQ6iH8deMvvW3ZRdkG6UtVwdqFwcbSrqqCuXGwaWD2lKSdED8Bq1NWo1FQI7sqUDH/vbPGUp50F8VX5Oq13Qkhzje943RM7zgdP577EaO2WVdhz1ruOqNq9QxF7dq1cebMGcyYMQOvvvoqWrdujSVLluD06dMICQlxxhgJIQQAMOzXYfhb8bfetsLSwiq/KAesm8YGwCvtyhrGSqnyYU36ly2i/KMAlC/wzsjPwBf/fGHVMTSMBjuu7QBgunJX37hwfP2iYc+RMD+5Sy5wJIRUPraHkTO564yqTSU8PDw8MG7cOIwbN87R4yGEEJNahLbAwdSDetsyCjKqaDT6qmoaWywU4/cXfkfzkObVsqmdTCQDAKg12hSpjIIMrD+73urjzD44GwDwzcBvTO7TsUF5QLX0+Rao4++JttGBNDNBCDHr+zPf43rm9Up5LXftlm11QHHw4EFs3boVt2/fhkAgQP369TFkyBB07drVGeMjhBDOgZcPYEHiAsw/PJ/bVqSu+tkJoOqmsX9/4XcMaDTAocd0JKlIWxGQXXPBpzdIRUKBEEKBEBpGg44RHY3uo9Yw2HtJ29DQSybCoNZ1Xe6ETAipGmP/GKv3faRfJBZ0W4Cx28eaeIZ93LFbtlUBxWuvvYbVq1cjICAAjRs3BsMwOH78OFasWIHXX38dX375pbPGSQghAAwXZRtdtFAFbO2WbQ+pUIrmIc0ddjxnCPUOxdDYoVxPiXu592w6jkQoQbG62OjC+90XlHon5vxiNTp/dNBlT8yEEOdjexEZEyAPQC3vWg59vYppqWyZ8U0nFZj7+wUEeknw99s9XfZGCO+AYtu2bVi3bh3Wrl2L0aNHc6X7NBoNvv/+e0ycOBG9e/fGM88847TBEkII44AIgk8jI2vXJDhzGntul7l4OuZpLr935G8jcTXzKmZ3nQ1VgcroSdHaxnzO0jS4KX55/hcA2hP4oC2DeD2v4vtfrC4GAGw4uwFzus7htrtjgyhCiHNZKopx9uFZDN4ymNexAuQB2P/yfijztFX8zirPYvah2YgPi8e3z3zL7WfsM1kkFKBnTAjmAnhUUIoTtzLRvn6QSwYVvAOKdevWYdq0aRgzZozedqFQiHHjxuHq1atYs2YNBRSEEKfpub4nDt0+ZPPz2YvUSL9Ivf4KHdZ0QIm6BDtG7uDupNtyQe6saez3j76PN9q+gVDvUADgShvOS5yHeYnzjD7HnspMlgR7BkMqkqJEXWJxX91u26oCFa/nbBy8EV0iuxgd+9xDc7mAwtrKWoQQAvArRlGiLoFEKLFYjpxhGL2bHwcKDwAAgr3Kt5k6n+y+oMT87Zf+Ow7w4nf/8OpbVB3xDihSUlIwZ84ck48PGTIEgwfzi+YIIcQWihyFzc+teJEa6RfJfS0TyVCiLkFMUAwaBja0a4zsNPakH5Px18WHaBXhh/891YRXt2xzfGTljUONlU6tyNbGfHxE+kVi54id6L2xNwBgdpfZGNxU//O/+/fd8bjkMURCERiGsWpmqWlwU5PjblenHfe1uzaIIoRUD8/HPo/pHadz319Iv4DRv2t74gghxA+Df0BCeILR2Y69N/di7829AIzf4HG32VXeAYVKpUKdOnVMPl6nTh1kZmY6ZFCEEGKMsQtpuVjOK33J1B1vAJCIJACAUrX5O1F87buUhr9vaj8Pz9zNMXrXiU/alUwkQ7G6GEKBEB5iD247u9DZEWxN/2LLwQJA/YD6iA/XL9nKBhCXMi4hZkUMQr1CsevFXTaPs65vXdzLvYev+n/FbXPXBlGEkOqhdXhrvc823c9eDTSID49Hfmk+79Lb7DnIHWdXeQcUJSUlkEpNn8TEYjFKSixPZRNCiK2M1QiPC4nTS18yxlL6EnuS4JOOYwnfu066aVeHbx/GtL3TEFcrDusHlZdUZbdrGA23bg0oD4AcQXcchaWF6LyuMwDg77F/w0OiDWKMvX+6J1aJUH88GkaDgtICvf2s7axdEfsauukH7togihBSPfSM7qn3vW4n7TtT7iDcOxzn08/zOtZl1WXus9QdZ1etqvI0d+5ceHp6Gn2soKDAIQMihBBT2BmKj578CO8eeBdqRo32ddvrpS/ZwtjFqi2svevEjvtyxmUAQJhPmN7dsIGbBhp9HanQcTMUQHn6V1ZhFrct0CMQYd5hCPAIMPqcIM/yk1zFAMf7Q29oGA3a1WmH+PB4PJzxEGKhGLezb9s8RmOzSFVRWYsQUnMFeQRhVqdZ8JZ6o45PHbyx6w3eletGbR3FpT6lP+bXQM+VZld5BxRdu3bF1atXLe5DCCHOwgYU8eHxiA6Ixo2sG4ZlZG3gqBkKW+86PS55DADwlnrr7R/lH8VVDtHlyBkKXcVlxdzXsV/HYmH3hZjbba7Rfb2l3ugS2QVHFUcNZiikIikKywqxYdAGhHmHcdvtCSiuZV4DAHT9viuYedrwwV0bRBFCqoeKfXP85H5Y/ORiANrF2KuTV1u1PoxNfQrxibK8M1xrdpV3QJGYmOjEYRBCiGVst+WrqqsoKNHOil5WXTabmsOHo9ZQ2JrTn1eSBwDwkWoXXrP10YfFDsOJeyfQrFYzpChTuP3Z98HR2NKsLN3pfWPYGR3dSk4AcHPyTUhEEoMAyRnYylrv/XER6Y/Lx+/KDaIIIdXDj+d+RNs6bfW2peenY+7BuQj2DMainouQlpeGL05+YdVx3XF21epO2YQQUhUUOQpcUV0BAEz6axK3/ZU/X+G+trVUqqNmKGzN6X9crJ2h8JH6GK2PfjHjIhJWJ3DfC2G5ypMtdNdFfNL7E73qJhUxDIMT904YfSzQI5C7s5dVmIU5B+dAJBDhf53+Z7EMo7X9PwCgd2wYVHnFmPP7RXhKRPh2dBuXreVOCHE+PsUoAMNZYwA4pjiG1SmrESAPQNbbWUhRplgdULjj7CoFFIQQl6AqUFmcWra1VKqj1lBYuusEAP6eEoO7Tq3DW2Nsq7HoGNGRV310DSynedlyYV7bpzaXTmQKO3vCMOX7nU8/jwi/CADaE3WoVyjki7RB05ahW7Dy35UQC8UY23osFnRfgFXJqxDhE4F3ur7D9f1gWTvLVLFLdkGpGjN+OUuzE4QQkyr2IqpozsE5+OvGX3prxViDf9aWyH5U9MiuMZjqWxTgJcEHz8a53OcXBRSEkBrPUTMU7F2n1zammNxHVXgfK4/tRceGtbhtkX6RmNRWO+tibM2EMe92fhetw1ujfkB95BTloOcGbTWS4+OOQyaWOaVTtqnusnMPzcXcQ9q1FnKxHONbj+ceG/7rcADaXGTdWRZFjgJDfx7Ke0Zpx4gdGPjTQMTWiuW2uVsdd0JI5TFXzMNf7g/AfM8fmUiGa5nXcD/3Plfi21p948Kh0QCzfz+PRwXaG1pZ+aV4f+dlCIUCl/r8ooCCEFLjObIPRe/YMPh7SpBdYHisMkE67stexZsHS4GDxp/Pt8fEkNghiA+PhyJHAYZhIBaKUaYpw8n7J/U6tPrL/a3u/j334FwcVRzFrM6z0LdhX247n9mTorIi7E/dz+tnsGZGSS7WzniIBNrqKO5Yx50QUrVuPbqF2QdnY/OFzQCMBxS/PP8Lnv/lebSt0xZDfx6K8+nn8ePgH8GAwaito6x6vd0XlHhjk3vcFKGAghBS4zmyD8XJ1CyjwQQAqJELCMwHLdaMwdiMwZQ9U0zub2mNSeLtRPRY34P7fnTL0bzHosuRjfdYbDUvth+HO9ZxJ4RUreyibC6YAMoDCjbVEwAuPLwAQPuZxH4uFZUWoVV4K6tey91uilgdUHTq1AndunVD9+7d0alTJ3h5eTljXIQQUmkctYYCqLy64buu70KIV4jFGQNd5mYEFDkKnH+o36DpTs4drrqUNesxHN0nAwC36PHcw3MAqEs2IcTxKs5ICAVCk6mex+4e475+bedrODzmsMXUJ921be52U8TqgGLgwIE4fPgwVqxYgaKiIiQkJHABRufOneHt7fwygYQQ4kjbhm+DUCA0KH9qC3OVntQC+xbx6Zp7aC561OtheUceTJ0wFxxegAWHFwDQngh/HfYrr+OVaOyf6ako8Xai3vfUJZsQ4mhsSiVLKBDySvUs1ZRCJpZh14u70GtDL/hIfTC21Vh8cfILDGw0EAt6aD9HddNO3e2miNW1B9955x3s3r0bjx49wpEjR/Dss8/izJkzeOaZZxAUVP0jKEIIqUgmlkEiknDpNPZoGx2IQC/DxnNlgnRkSBfZfXzWE7WfQKPARg45Ft+1EdlF2byOV6Yus7yTlV5q8RKA8hM+W1HL1G9MACDcxeq4E0KqVsUZCoHJTxjjgjy018FeUi/EBMcA0J5f4sPjER8erzc77G43RWwuZn79+nWcPXsWZ8+exblz5+Dr64v+/fs7cmyEEMJh64abY0upVEcTCQUY1KqOwXbt+gl+F9oVO09XJBdpZwtebfOqTWN0NpFQZHmn/2/vzsOiKts/gH+HAYZVEBFnUDZXVHDDVDTXNHFLs9RSK3IpLbfKNzNT8TW1TG3R9C1T0MylX2lmmlsKrqWiKCohKogKhIiCgOzn9wfNkRGYBc7ADH4/1zXXxcw858wzc3Tm3Od57uc20ODmgwEA7ZTt/n2NkhW1AJT5yTfXddyJqGY9/t2lbZWn8qgvzNhY2og1LB7kPyi3bW27KGJwQDFq1CioVCr07NkTBw8eRNeuXbF3716kpaVhx44dxugjAGDRokXo2rUr7Ozs4OzsrNc2wcHBkMlkGrcuXboYrY9EZDyeTp7YP3Y/Wrq2BABM7jgZkW9EatwqU9QOAL47+x1G/zwaO//eKUlf+7ZSVmn7guICWMutMT9wIxoXr4Qy9wuNm0/RWly+qT3oqElSTB17nLruRekfePU67q6OCo22Sicbs1odhYhMQ3k5FIYoL6DIys8qt622iyJASQ7F3EEtzeaiiMHf+v/3f/8HV1dXBAcHo3fv3ujevXu15E3k5+djxIgRCAwMxLp16/TeLigoCKGhoeJ9a2vpkwWJqHp8cvwTxKTFAAAa1WmEDqoOkuz31O1T2HJxC1rVb4WhvkOrvD/1tKf07MoneecX5eObw+lQCE1R+nS5UJaKe7l38foPP+LV7tKPBGjjbOOss7qsjaWN3tMEFHKF3iNKCfcTAAA3M29qPB7kp4KLvTVGfvMnXOyt8PXoAHTycTGbH2EiMh1VCShi0mJw/+F9AEBRcRGSH5TUFKoooAAqLm6nZk71KAwOKNLT03HkyBGEh4fjo48+wqVLl9C2bVv06tULvXr1woABA4zRTyxYUJLQEhYWZtB2CoUCSmXVrhYSkWmob/eoGJyhc1u1Gdl6JFrVb4WuHl0l2Z962tO64wmS7E9NXcdCvfTs0tOS7l4nlYNKa3VZoGRq2oj/G6HX/n4e9bPeI0qHEkoKdzSq00jj8aJiASeu3S15bQcFgwkiqrTykrL1VboGRVx6HKb8XlKsVFfumbq43VubyxZENad6FAYHFM7Oznjuuefw3HPPAQCuXbuGjz/+GCtWrMCyZctQVFQkeSerIjw8HG5ubnB2dkbPnj2xaNEiuLm5Vdg+Ly8PeXmPlvzKzMysjm4SkR7ChoXBQmaB0KhQg4eitenbuC/6Nu4r2f6AkmlPUgcU+tSx0MZabl3lHBNt1WXVHv9Rroi64J4+vJ28AQB9vPuIj+29mKxxZe/KP1l4+tNDmD+klcn/+BKR6Sn9u7LzpZ1op2yn9QKKPrLyKh6hAEouiizcfbnc58ypHkWlRigiIiIQHh6O8PBwXLp0CS4uLhg6dCh695ZmCUOpDBgwACNGjICXlxfi4+Mxd+5c9OnTB5GRkVAoFOVus2TJEnE0hIhMz+MFzkyVOuFO2zrj1W37qO2VyjExlDFyKMRq5v/WCtl7MRmTN9WOCrNEZBrUSdnWcms81+I58XFdUz212ffKPq3P15Z6FAZ/69evXx+urq7o3r07Jk6ciF69esHPz69SLx4SEqLz5P306dPo2LFjpfY/atQo8W8/Pz907NgRXl5e2L17N4YPH17uNrNnz8a7774r3s/MzISHh0elXp+IpCf8ewop5ZSnW5m3cOP+DbjZu6FZPWmWYpVbyDB3UEu8tfmcJPuTQkUjAuoVtHTlRug7umGMVZ7uZN8BABxOOFzrKswSkWlQj1CoL1wBJaOypad6JmclY/i24cgv0q/ejq7R9NpSj8LggOL8+fOVDiAeN2XKFLz00kta23h7e0vyWgCgUqng5eWFuLi4CtsoFIoKRy+IqGbNPzwfG89vBGD46hvarDu7DiERIZgUMAlrBq+RbL917R99l8hRBxCsqjRlyVjUP5gf/vEhfoj+Aa+2eRXTu0zXaFO6IJMu7o7ukvfxTPIZAEBUSlStuaJHRKZF/btSWFyI789/jx5ePeDl7KUx1fNs8lm9gwl91JZ6FAYHFOpg4s6dO4iNjYVMJkPz5s1Rv359HVuW5erqClfX6lsz/u7du7h58yZUKg6DE5mjuPRHFwOknPJkLS9Z/U09nUYqpa8oWQpuaJj3DXJll3BXsVzS15GCp5MnnG2cAQBezl5VWkHr2cbPYnP0Zol6VqKBfQPx79pyRY+ITIutpS2e930eO/7egVd/eRU/vvgjvJy9qrTP9w+8j20vbkM9u/Ivbqinx6Zk5JY76ipDyVLYpl6PwuBLfNnZ2Rg3bhxUKhV69OiB7t27w93dHePHj0dOTo4x+ggASExMRFRUFBITE1FUVISoqChERUUhK+tRsouvr69YCyMrKwszZ87EyZMnkZCQgPDwcAwZMgSurq54/vnnjdZPIjKe0lNppByhUM/Pl/KqE1D2ipKl4AYroVEFrR8jWJaMakhEnylLeYUlC1Io5JUbpU3MSMTZ5LO4nn69Uttr22er+iXrtQ9sOhD38mORJ7uKPNlVFMpSK9zW1K/oEZFpcbJxwvZR2/Gfrv9B/yb9oXSo+iqhf8T/gfSH6RU+X1uKdBo8QvHuu+8iIiICu3btQrdu3QAAx44dw7Rp0/Dee+9hzRrppguUNm/ePGzYsEG83759ewDA4cOH0atXLwBAbGwsMjIyAAByuRzR0dHYuHEj7t+/D5VKhd69e2Pbtm1wdHQ0Sh+JyLhKBxFS5lCoRyikDig6+bhAWUeBlMxHK8cJyNOyxSP18+bAUtBcka5Ids/gPgS3DcbUzlP1mrKUV/RvQGFpeECRmJGIFqta6J24KJfJdQY45e1zz9U92HN1D6COFQQrNMz7RuOzMpcrekRkmpb2WyrZvmZ1nVXh6IRaRfUolE42ZrNqncEBxc8//4yffvpJPIkHgIEDB8LW1hYjR440WkARFhamswaFupIqANja2mLfPu2Z9URkXtTLkfbw6qGxAkdVWVloriAkFbmFDC938sTnBx9N1SqSZeu3Lepq3C+UpeKO9SK9X9vB2gFZ+VmwsbTRe/qSOqBQB1iGSMtJ0yuYcLV1RdrDNEzsMFFngKPXPmUFKEImLFESUJjTFT0iqt2s5dbo7t0dCfcTxOKcFV3cCfJToV8rJU7FpyP1QS7cHG3Mqq6OwQFFTk4OGjRoUOZxNzc3o055IiJSj1AENQmCT10fyfZrrClPAODtao9CWWpJDQkAhUjWvZFgVWa6U0kNikK9X3doi6EY2Xokmro01Xsb9fuv7JQnfagcVUh7mIa6tnV1N64Ec7qiR0SmJTs/G3U+qYNioRjZH2bDzsquSvvLL8rH4M2DNR6zsbRB7JTYcoMKuYXMbBeSMDigCAwMxPz587Fx40bY2JSMOT98+BALFixAYGCg5B0kIlJTBxRFgrQFNMWk7CLpV2AqtkjTqG5dLsES9fPnQC6UnGTLUafMdCdDNXJshEZ1GiG3MBdnkx9VYNU29UnMoajElCd9tXRtiejUaL2L3xnCxd4Kcwe1ZDBBRJViIbMQl4x1WOyAPWP2IKhpkKSvkVuYi7SctGqpCVSdDA4ovvzySwQFBaFRo0Zo27YtZDIZoqKiYGNjwylGRGRU6pPQ9efWY0SrEWjh2kKS/aqnPBljhKJRvULdS8XKCiEX6kIhVDyaYGtl2An4pyc+xacnPi3zuLarY03qNkF7ZXu42VctmNFG/WNtjOJ397IL8Pbmc1hjIWNQQUQGs7G0QdK7Sej8XWfczLypUY9CTZ+6PU+iSi0bGxcXh02bNuHvv/+GIAh46aWXMGbMGNja2hqjj0REAB6NUMTfj8eh+EOSBRTGWjYWgGTzXzt4OSP+VtX3o+3q2MqBK6v+AjrYW9vD3dEdTjZOku+bRe2IqCpkMhlUjirUt6+Pm5k3y11N8PFCd6W9u+9dRNyIqI6umpxKXSKytbXFxIkTpe4LEZFWpZeNrera4KUZM4dCKo3q2gESBBQAEJMWU+FzhhSwq4ymLk0RNizMaPtnUTsiqir1yERFy5OXLnR3J/sOXvy/F3Er8xamPDWFAYUhrly5gvDwcKSmpqK4WHM4aN68eZJ0jIjoceov9w+f/hADmw2UbL/GzKGQQj17a7RpZANES7O/sdvHVvictilRUrideVsjpwMwThDDonZEVBnTf5+OqJQoAPrVOwr6IUj8Tnt3/7vG7JpJMzigWLt2LSZPngxXV1colUqNarUymYwBBREZjbGSso2ZQyGFoe3c4d+wek6QcwtzsfH8RgxsNtCgE3195xX/L/J/+F/k/zQeqyiI0Wuf5ayIBbCoHRFVzqrTq8S/9QkoXGxZ7waoREDx8ccfY9GiRZg1a5Yx+kNEVCF1UnZ5iXJVYazCdlLp10qJBg7ZsLJQoKBYS2E8dRJBFc09PBdzD881aLSionnFMWkxWkdEgIrzOsrbZ1GxgPFhp5GWlQcBZVfEYlE7IqqK0is9GRJQTHlqCnb8vQO3H9w2av9MlcEBxb179zBixAhj9IWISKvuXt2x7OQyfHbiM/i7+eOVtq9Ist9ODTvh1ju3YGNpele1ne2s/i1uVA+xU2LR/6vf8CC3/HoUadafolCmR50LPeUW5iI6NVrvUYrS84qlUt4+lw51x+RNZyE81pZF7YioquQyOQpR8h0r0+MKTV2bkuW+Xe1c4WTjpDOgsLG0gauda9U7amIMDihGjBiB/fv3Y9KkScboDxFRhZ5r8RwGNB2A36/+Lum0J4WlAg3rNNTaJjEjsdxVPdQqmh5UlWk7APB6Vx/x5Dgl3QH5D71RcZUI6Ws7DN82HHFT40xqzfQgPxW+Ht0BM386j5z8R/8OWNSOiKqq9KiEthEK9W+CemT70+OfiqvXzek+B4Eegfjj+h/4/M/PMaDpAHzc52MAxl/4oqYYHFA0bdoUc+fOxZ9//gl/f39YWVlpPD9t2jTJOkdE9Djh3+vS+gxFG6qioCE5KxnDtw3XOiWqoulBpaftFBUL6P/d+3hQHAeHwn6wKW4DoOJCds52VpjS51FtCl2JxpZCAxRKtRTUv/KL8k2uCNPei8lYuPuyRjDBonZEJAV9AorEjES0WNVC40LRw8KHeJj1EACw6Ogi2FjaYE73OQAAOys7dFB1MGKva57BAcW3334LBwcHREREICJCc2ksmUzGgIKIjCYzLxM37t8AoN9QtL7OJZ/DgvAF2BW3q9L5GdrqO5SettNMKceplJuwgL3WQnYA8Mlwf42pOxUlGhfKUlGETMiEkrGLno0GYWKnl/HhHx8iMSOxUu/HVO29mFzudCcWtSMiKZRenryigCItJ03nAhS5hbm4ef8mgJJgo7YzOKCIj483Rj+IiHT6/OTnYg0FqUYoEjMSEbguEHlFWpKdJbR6yBJ8FT4Mf0RXXAjUXiHH8hFty5wYd/JxgcrJBikZueIJdaEsFbcVb2pU4464tRsRt3Ybo/s1qqhYwIJdl8sEEwCL2hGRNPSd8qSPb899CwC4n3u/SvsxB5WqQ1FaYWEhcnNz4eDgIEV/iIgqpC5AB0BjyeqqSMtJkyyY2BO3B8lZyVA5PAoEHp8vG+AegA2jA7DnQjI+2nkR6dmPplHZK+SY+LQPpj7TvNwTYrmFDPOHtMKkTY/qOBQhUyOYqM1OxacjOaPiq4IsakdEVaVeTRCQ7sLVg7wHkuzHlOkdUOzZswd3797FK688WlVl0aJFWLhwIQoLC9GnTx9s27YNdevWNUpHiYg+7P4h/oj/A4fiD0ky5SkxI1Fr1WhDzT08t8xjFeVWDGyjQn8/JU7FpyP1QS7cHG3+Xc1J+/vq10oJZzsr3M8xjyBCn6R0fVc90bdYHYvaEVFlqYOId7q8A29nb0n2aapLkktJ79Br2bJlyMzMFO+fOHEC8+bNw9y5c/Hjjz/i5s2bWLhwoVE6SUSkJgjSJGWrk+p01UioKnVuhdrOv3diQ9QG3Mq8BbmFDIFN6mFou4YIbFJPr2k6p+LTKxVMbBq+CfZW9gZvV1XqpPSBTTUrmy/usxiRb0Qi8o1IvWtd6FusjkXtiKiy1L8twe2CUd++viT7/GbwN5Lsx5Tp/Yt88eJFdO3aVbz/008/oV+/fpgzZw6GDx+O5cuXY9euXUbpJBGRmjppuqpTnvRJqjOGBRELELwzGBdTL1Zq+8pefW/p2hLvdHmnUttWlaeTZ5kf5iYuTdBB1QEdVB30XkFKnUNS0ZGXAVCxqB0RVYE6KVvKAqqOCkfJ9mWq9A4oHjx4gHr1Hs1JPXbsGPr06SPeb926NZKSkqTtHRFRKTv/3omIGyWryxlj2djqUFBcMrqgrs5tqKpcfa9M4T6pijA9frxKz1PWlzqHpDwsakdEUlB/V+2+svuJyH2Qit6/yO7u7oiJKZlrnJWVhfPnz6Nbt27i83fv3oWdnZ30PSQi+lf8/UerzEm5bGx1Us+ltbKw0tGyfLqu0lfkbPJZ7IjZAQCw0PHVby23xm+jfzNoOpIuZQIKi8oX4XOyK/vZOdtZYc3YDlwyloiqpHPDzgCAjw5/hBsZN8pto84N09dnxz+TpG+mTO+k7BdffBEzZszAhx9+iD179kCpVKJLly7i82fOnEGLFi2M0kkiIsA4q28YwtLCEoXFhVXahzqgqOwIRXkrPelj4q6J4t/FKH8o31JmiV9e/gX+bv6SF7J7/HhV5vhVVIMCAO6ZSZI6EZm2n0b+hL4b+yL9YTpsLctf3ludG3Y08aheeXg/x/wsdTdNjt4Bxfz585GUlIRp06ZBqVRi06ZNkMsf/bhv2bIFQ4YMMUoniYgAzZNQqZaN1Ye13BrbR20HAAzePLhK+yooKjnxLb0ErqFKr/QkRx1AsJJk6dhCoRD3c++LSeRSBhVVnfKkrQYFwBoURCSdg68e1NnG08kT3T2761zFTi6TY1rn2l/0We+Aws7ODt9//32Fzx8+fFiSDhERVaT0SWl7Zftqe93YKbHwdvbG2WTDRgXKU9URCkBzpSdLwQ0N874pqUcBoEB2E3cVyyu9b/XVtoqWu62sxwMIQ0coWIOCiEyNeqSi9Ep+j3u8FlFtVeXCdkRE1UU9735oi6Hwcvaqtteto6gDoOSHwcrCSkys1sfjSc3qbSubQwGUXenJUnCDJdwqvb/yqJe7leqHsFm9Zujp1VNMqjc0h4I1KIioOvQI7YG/0/7GLy/9gq4eXXW293TyfCICBl0YUBCR2VBf1ZZiOT99Cq6ppeWkwcXWBZ5Onrg67Sq+OfMNLqZeRE5BDg7GH0R7ZXtcunMJ+UX5WDtkLTqoOmi8TukfGylGKMyxzsKMLjMwo8sMtFnTBtGp0QZPeWINCiKqDukP03En5w66re+GhOkJVb54FXc3DjkFOWhZv2WVvvdNHQMKIjIb6pPQXVd2ITU7FW72lb8q//hQ9Yy9M3A08Si8nb2RcD9Bo+2xG8eQlZ8l3n+z45vwdPLEz5d/xsH4gxAgiIHCyNYjxRGN8oirPFUhh0K90lNKRm6FOQWmqkgoAmD4lKd72Xk627AGBRFV1c8jf4bv174ApLl41f6b9sguyMa1adfQuG7jKu/PVDGgICKzUfok9EzSGQxsNlBLa91KD1V7OHkAAB4WPCzTbvyu8Rr31fkFLrYlJ6+xabHic0+vfxphw8LK7MPVzhUedTzEVaKqcqVKvdLT5E1nIQPMKqiwtLCElYUVLC30//kpKhawcHeMznZzB7EGBRFVTQvXFuLotRSrCdpY2iC7ILtGCqlWJwYURGQ2Sn+5O9s4S7pvJ4UTAOCf7H90ts0tzMXk3ybjaOJRAMDDwkdBSHRqNAK+DSizjY2lDaInR4v3qzr0HeSnwpqxHbBg12Wtycqm4r8R/8WqU6vw1lNv4fyk8wZtqyshW62ufe2dTkBE1Uc9MiFFQGFrZQs8LP9iVW1icEDx1Vdflfu4TCaDjY0NmjZtih49emgsKUtEJAV1Iu8zPs/olSxnCG3TlMqz5+oeg9rnFuYiJStFvF+VpGy1ID8ViouBtzY/Wn2qZBlZS0BWtXoZUsspyMGdnDuVqjzLhGwiqi7rz60Xp6ZKNUIBgCMUj/v8889x584d5OTkoG7duhAEAffv34ednR0cHByQmpqKxo0b4/Dhw/Dw8DBGn4noCSVlUvbj1CMUxlRUXARHa0fkF+VXKYfi0f4ELNx9WeMxS8EN9fPn4I5iQZX3L6UZXWZgbJuxGite6YsJ2URUXb6N/Fb8W4p6R+rieKVHsmsjg0OvxYsX46mnnkJcXBzu3r2L9PR0XLlyBZ07d8aXX36JxMREKJVKvPPOO8boLxE9wdRJ2erEXikZOkJRGY4KR2TOzkTuR7mSrPZR0VQguVC3yvt+fLnbqlI6KOHn5ofZf8zG0K1DcTX9qt7bMiGbiKpL6VEJjlDoz+ARio8++gg///wzmjRpIj7WtGlTLFu2DC+88AKuX7+OpUuX4oUXXpC0o0RE6uX7jtw4ghM3T0g67Wlk65E4dvMYtl7cKtk+jU2KKT6bhm9CS9eWZR43VjGm/df2I+lBEub3nK9XeyZkE1F1MlZAwRyKxyQnJ6OwsOzc3MLCQqSklMwPdnd3x4MHhs+TJSLSplPDTmhVvxUu37mMvELdV60NUd++PrydvCXdp7FJMcWnpWtLjboZxhKREIHwhHD08u6FXl699A5WmJBNRNWp9DQnyZKyUftHKAz+pHr37o0333wT586dEx87d+4cJk+ejD59+gAAoqOj4ePjI10viYj+JQgli6RK8UX/uNK1JowhOSsZ/Tf1x8s/vyzJ/tT1KB4nJmabkCM3jiAkIgSO1o6YGDBR7+lUTMgmoprCKU/6M/iTWrduHVxcXBAQEACFQgGFQoGOHTvCxcUF69atAwA4ODhg+fLlkneWiJ5sxUKxmNgmRbJcaXey72DV6VUAYHAVZ31l5WVh/7X9OBR/SJL9yS1kmDuo7HQldWK2KalsQj0TsomoOskgzQhFYkYiziafFac6Xbl7BWeTz4q3xIzEKvfVlBh8CUupVOLAgQP4+++/ceXKFQiCAF9fX7Ro0UJs07t3b0k7SUQEAPuu7hOrWJf+0q+KxIxEpOWk4WbGTfGx532fx08xP0myfzUbSxu0qt8KG4dtlGSFJ7W69opyH5ciMVtK6h/m/df2Y/+1/ejm0Q321vY6t2NCNhHVlMoGFIkZiWixqoXGqMSyk8uw7OQy8b66QKoxctVqgsEBRUREBHr27AlfX1/4+voao09EROWSOlmuvC99AJIFE6UTntVJzv4N/CXZt1pFU31Kpj1ZAbKCCreVeiUnbdTH60bGDfTf1B9xU+PQ1KWp1m2YkE1ENamyvzNpOWk6pzjlFuYiLSftyQ0o+vXrB6VSidGjR2Ps2LHw8/MzRr+IiMro49MH9e3q407OHUmmPOnzpV8V/m7+aNOgjdH2D1Q81cdScEPDvG9QhEwAwJLn/dHGwxmDNw9GclYyNgzbgF7e+idHV9XjP8z6TCtjQjYRVTeFZcmob/N6zSVZ3vtJYXBAkZSUhK1bt2LLli1YunQp/Pz8MHbsWIwePRqNGjUyRh+JiAAAVnIrOCoccSfnjlGSsqV2+vZpFBY/WhUv/WE6bty/gRauLfC059OSvIY6MTslIxfCY89ZCm6whBuc7azwSsfekFvI4GDtAADwdvau1itjjx8vfY4fE7KJqLqpk6jf7/o+AwoDGPyL7OrqiilTpuD48eO4du0aRo0ahY0bN8Lb21tc5UlqCQkJGD9+PHx8fGBra4smTZpg/vz5yM/P17qdIAgICQmBu7s7bG1t0atXL1y6dMkofSSi6qFO6pUqh8KYJuyagIBvA8Rbv+/7YcKuCZi8e7JkryG3kGH+kFZlgonS7ucU4MDlkmW949LjAAA9w3pK1gd9yC3kWu+XhwnZRFTd1KOnhi4g8aSr0iU+Hx8ffPDBB/jkk0/g7++PiIgIqfql4e+//0ZxcTG++eYbXLp0CZ9//jn+97//4cMPP9S63dKlS7FixQqsWrUKp0+fhlKpRL9+/Vgjg8hMXU2/KiZlm9oIxcLeC9GyXtkVl8ql7ey/Evq1UsLZruJEbxmABbsuo6hY4hc2QGWmPDEhm4iqmzqQOJ10WlymnHSr9C/y8ePH8dZbb0GlUmH06NFo3bo1fvvtNyn7JgoKCkJoaCieffZZNG7cGM899xxmzpyJ7du3V7iNIAj44osvMGfOHAwfPhx+fn7YsGEDcnJysHnzZqP0k4iMKzU7Vfxb6mVjq2ru4bn4++7ferWVcpUnoCTX4H5OxcnXBbJUJGRexPdnDqNtg7YAgP8E/qdaly80dMoTE7KJqCY4KhwBAGvPruUohQEMzqH48MMPsWXLFiQlJaFv37744osvMGzYMNjZ2RmjfxXKyMiAi0vFV6Xi4+ORkpKCZ599VnxMoVCgZ8+eOHHiBN58883q6CYRSaj0SagpTnkS9Bx6sLSQtuicthyCQlkqbiveBGQFeP33R49/dvIzfHbyMwDVs3xhmREKHVOemJBNRDXhq6CvcPTGURQLxSZ34cqUGfyrFh4ejpkzZ2LUqFFwddVcbjAqKgrt2rWTqm8VunbtGlauXKm1eF5KSsl84QYNGmg83qBBA9y4caPC7fLy8pCX92iYPTMzs4q9JSKplJ4mY2pTngwhdUChLYegCJlal44Fqmf5QkOnPDEhm4hqQj27ekh8p2qjtq52rrCxtNG6imB1LttdHQz+VTtx4oTG/YyMDPzwww/47rvvcP78eRQVFem9r5CQECxYsEBrm9OnT6Njx47i/aSkJAQFBWHEiBGYMGGCztd4PLoUBEFrxLlkyRKdfSKimlH6pNTd0b3K+9PnS98YpJ7y1MnHBco6CqRk6s45qCmGTnliQjYRmStPJ0/ETolFWk5ahW3UtYlqi0pf4jt06BDGjh0LlUqFlStXYuDAgThz5oxB+5gyZQpiYmK03krXuUhKSkLv3r0RGBiIb7/9Vuu+lUolgEcjFWqpqallRi1Kmz17NjIyMsTbzZs3K2xLRNVLPU3G3dEdDRwq/n+sL/WX/qbhm6q8L0NYyqQdoZBbyPByJ9P+YXKxdYGXk5d4X9eUp3vZedCWGiEDE7KJSHpz/pgDv9V+CD0XWqX9eDp5ooOqQ4WjEGk5adWWw1YdDPpVu3XrFsLCwrB+/XpkZ2dj5MiRKCgowM8//4xWrVoZ/OKurq5lpk1V5Pbt2+jduzcCAgIQGhoKCwvtsZCPjw+USiUOHDiA9u3bAwDy8/MRERGBTz/9tMLtFAoFFAqF/m+CiKqN+qp2UbH+I6G6eDp5itWsq4vUIxQA4O1qL/k+pfRiqxcR1DQIjktKEh61jVDsvZiMtzef05mRMn8IE7KJSFrnUs7h0p1LGPfrOLze/vUq7SsxIxEtVrXQOfXJ2Dls1UHvEYqBAweiVatWuHz5MlauXImkpCSsXLnSmH0TJSUloVevXvDw8MCyZctw584dpKSklBl98PX1xY4dOwCUTHWaMWMGFi9ejB07duDixYsIDg6GnZ0dRo8eXS39JiJpqU9C/8n+Bw8LHtZwbyrPGPkf5jD1p3QgWFEORVGxgAW7LmsNJixkwNejOyDITyVxD4noSTet8zTJ9pWWk6ZzSq06h83c6T1CsX//fkybNg2TJ09Gs2bNjNmncl/76tWruHr1aplq3KXXCI6NjUVGRoZ4//3338fDhw/x1ltv4d69e+jcuTP2798PR0fHaus7EUmn9Eno9XvX0dqtdQ32pvL2Xd2H3XG74e/mL9lVKXXFbH1WRqoppZdgrGjKkz6rOxULXN2JiIzD19UXAGBnVb2rl5o7vS+THT16FA8ePEDHjh3RuXNnrFq1Cnfu3DFm30TBwcEQBKHcW2mCICA4OFi8L5PJEBISguTkZOTm5iIiIkIjJ4OIzEvpK/vW8uo/oZTqNYtRjMGbB6PFqhaSzZ+VW8gwd1D1Tt0yxO4ru9FtfTe82OpF3Jt1r8IRCq7uREQ1SX3hw5xXEqwJeo9QBAYGIjAwEF9++SW2bt2K9evX491330VxcTEOHDgADw8PXvknIqNSX9V2tHZEs3rSjZTqu8TfoVcPQWGpmWMVkxaDsdvHVup1pV6uta592fwvOeoAgpXWpWOrY/nCzLxMxKTFQOWogrONc4XtEtKy9dqfOUzxIiLzc+TGEQBAVn5WDffEvBi81IidnR3GjRuHcePGITY2FuvWrcMnn3yCDz74AP369cOvv/5qjH4SEYlXjKSuXlqTS/wlZyVLtq/yrtpbCm5omPdNST2Kf/2nfwv0auEm3q+O5Qv7+PTBoVcPoa5t3QrbFBULWH88Xue+uLoTERnLlotbaroLZqlKaxe2aNECS5cuxZIlS7Br1y6sX79eqn4REZUhrvIkSLfKk5qnk2eNrLIxfNtwxE2Nk+S1K7pqbym4wRKPAohAj6fQQVWvyq9niAYODWAlt8LM/TOhkCuwZvCaMm1WHYpDxsNCnft66SlPru5EREYhA79bKkOSCWJyuRzDhg3j6AQRGZU6SS63MBe3Mm/VcG+kkV+UL9kKH+rEbG0/hzV5dT8rPwuhUaEIjSq7vntRsYDQ4wl67cfblcmSRGT6pByBNnXMOCEis+Fm7wZ7q5J6C/lF+TXcG9Mjt5Bh/hDtNYGea6uqkav78ffi8cOFHxCgCsB/e/+3zPOn4tNx/2HFeR6lMX+CiIxFJpPm+zExIxEvbHtBZzuFXGH0HLbqwICCiMyK8G+FAlMZllYndJuKID8V3ujhU+Hz3x6Jx96L1X/V7MI/F/DhoQ9hJbfC+93eL/P8wcsp5WxVlrOdFfMniMjkpeWkIa8oT2e7n0f9bPZF7YAq5lAQEVU39XLRprKkX+mE7uSsZFxNv4qZ+2aiUNCdC2AMRcUCfj2vPWBYsOsy+rVSVutIhXqFrvKqnBcVC9gRdVuv/bze1Yf5E0RUa5xLPgcAktYlqgkMKIjIbNx7eA8PC0sqZEu90lNVPJ7Q3dSlKQZvHlwjfdFVGE4AkJyRi1Px6QhsUn2J2eoA8HTSaUT/Ew3/Bv7ic6fi05GerXu6k4PCElP6NDVaH4mIqnv0e+7huQAAOeT4qMdHeKrRU2YZXDCgICKzIdXcVmPzd/PXWdfCWEy1MFzpEaU+G/vgzn8eFUbVty8jOzbi6AQRGVVN/c4UoQgLjiwAAFjKLLF2yFq0UbYBUD1Le1cVAwoiMhuO1o+KZ1rJrWqwJ9qpp0EdTTxa6aJ3laVvwnJ1JzaXDiger5KtbzG7fq2UkvaJiOhxKgdVTXcBhUIhXv/1dfG+jaUNYqfEmnRQwYCCiExeYkaiuLSqBSxQjGJcSr2E1OxUAKZ59cbTyRPdPbvrVYFbyhU+1EvHpmTk/pu+XlZNJDaXDihK/11ULGDLqUSd27OYHRFVB/VvyZsBb9ZwTx7JLcxFWk6ayf3OlcaAgohMWmJGIlqsalHmpDzohyDxb1O9elMTFbjVS8dO2nS2wjb3cwpw4HIKgvyq70qcxgiFxaMRilPx6UjJ1L0SCovZEVF1UH9XmVKenjlgQEFEJi0tJ01nLoIpX72piQrc/Vop4Wxnhfs55Sc6y1D9Kz2VnuZUOrjQN3+CxeyIqDoUFJV8byY9SKrSftRLitdELl1NMI11F4mISDKn4tMrDCYAzZWeqktFORSmmvNBRE+my2mXAQC743ZXaT/qEepNwzdJ0S2Tx4CCiKiWMcWVniqa8nQvW/d0J+ZPEFF1md55OmwsbeDv5q+7sQ6eTp5o6dpSgl6ZPk55IiKqZUzxqn95SdlFxQIW7o7Rue3cQa2YP0FE1eJpz6fxcM5DyfbnaucKhVyhV9Vsc8YRCiKiWka90pO2U/DqXumpvClPuorwqdW1tzZav4iIjMnTyRNXpl7B+qHrYSmrvdfxGVAQEdUy6pWeKlo2Fni00lN1sZY/CgrUU55McWoWET3ZdsTsQO8NvbEgfIFk+/R08sTr7V7HtenX8Nvo3zC/5/wy9Xi0kXp5cWNgQEFEVAupV3qqiHqlp6JibWGHdNqr2mPf2H0AHo1WmOLULCJ6su2O243whHCERIRIvm9PJ08MajYIIb1CcPT1oxoXWspjLbfGb6N/M8ll0R9Xe8deiKhW0GfpPXO4elPdDFnpKbBJvWrpU1FxEYBHU546+bjoXN5WyYRsIqpG7ZTtquV1Aj0CETc1rlrrFBkTAwoiMmk1URyuNjDF6UTqQlHqEYoDl1N0Bj3zhzAhm4iqT5O6TQAAAaoAo79WTdQpMhYGFERk8mrTl251MbXpRPH34vHfI/+Fn5sfto/ajqJiAQt2Xda6jbOdFfq1UlZL/4iIgLIXPkg/DCiIiGoh9UpPulZRupedXy39eVj4EKdun0I923rwdPLEyWt3dfbtfk5BtU7JIqInV2JGItJy0nDkxhEAwOmk0zibfFZ8niPh2jGgICKqheQWMswd1BJvbT6ntd3C3ZfR309p9GlFjeo0wrYXt0EhVwAwzSlZRPRkSsxIRItVLcrk6gV8+2jak42ljVkkR9cUjucQEdVSde0VOtuoE7ONrY6iDnxdfXHi5gmsjVxrclOyiOjJlZaTpnXhDwDILczVmsv3pGNAQURUS5naKMDlO5ex9MRSbLm4RWfxPRkAFVd4IiIyCwwoiIhqKX2v7iek5Ri5J0B2fjai/4mGl5MXXmz1olh8rzzqIIMrPBERmQcGFEREtVQnHxco6+ie9rT1dKLRC9yl5aRh8bHFSM1OxVtPvSU+7lRO8T1nOyusGdsBQX4qo/aJiIikwYCCiKiWklvI8HIn3QmE1ZFHoV6CsUgoKW6392IyJm86W24dintaalMQEZHpYUBBRFSLebva69XuwOUUo/ZDblFSHTu/KB+pWWlYsOsyKhoTkQFYsOuy0UdNiIhIGgwoiIhqMX3zKNYfT8Dei8lG60fpIlEvbHtFaw0KAdW3+hQREVUdAwoiolpMvZqSLsYeFSgdUBQU6vcarEFBRNXB1c4VNpbavydtLG3gaudaTT0yPyxsR0RUi6lXU5q06azWdqVHBYxRmbp0QGFrVTYRuzysQUFE1cHTyROxU2K11plgpWztGFAQEdVyQX4qjO/mjXXHE3S2NdaoQOmAwsVegVwnG6Rk5JabRyEDoGQNCiKqRp5OngwYqoBTnoiIngB9Wyn1amesUYHSAYVMBtagICKqRRhQEBE9AfTNpbiXnW+U15fL5GUeYw0KIqLagQEFEdETQG4hw9xBLXW2W7jbOInZpUco/snMYw0KIqJahAEFEdEToq697qrZxlqutXRAcTkpkzUoiIhqEbMIKBISEjB+/Hj4+PjA1tYWTZo0wfz585Gfr31oPjg4GDKZTOPWpUuXauo1EZFp0Tfh2hhF7koHFLkFxRW2Yw0KIiLzYxarPP39998oLi7GN998g6ZNm+LixYuYOHEisrOzsWzZMq3bBgUFITQ0VLxvbW1t7O4SEZkkfROud0YlYc4gaZOiSwcU+mANCiIi82EWAUVQUBCCgoLE+40bN0ZsbCzWrFmjM6BQKBRQKvVb3YSIqDbr5OMCF3srpGdrz1O4m50veT0KSwtLzOsxD/898l9YwFFne9agICIyH2Yx5ak8GRkZcHHRvUZ5eHg43Nzc0Lx5c0ycOBGpqanV0DsiItMjt5Dh+XYN9Wor9QiBTCaD8G/mhL21NSoa+5ABULEGBRGRWTHLgOLatWtYuXIlJk2apLXdgAED8MMPP+DQoUNYvnw5Tp8+jT59+iAvL6/CbfLy8pCZmalxIyKqLWqyHkVRcREAoLGrQ4VJ2QBrUBARmZsaDShCQkLKJE0/fjtz5ozGNklJSQgKCsKIESMwYcIErfsfNWoUBg0aBD8/PwwZMgS///47rly5gt27d1e4zZIlS+Dk5CTePDw8JHmvRESmoCbrURxJPIJ6tiokJD5VYZs3eviwBgURkZmRCYJQY2vzpaWlIS0tTWsbb29v2NiU/PglJSWhd+/e6Ny5M8LCwmBhYXg81KxZM0yYMAGzZs0q9/m8vDyNEYzMzEx4eHggIyMDderUMfj1iIhMzZ4LSXhr8zmtbVRONjg2q4+kIwXWC61RUFyAhg/DYAnXantdIiLSLTMzE05OTpU6563RpGxXV1e4upb/o/K427dvo3fv3ggICEBoaGilgom7d+/i5s2bUKkqvvqlUCigUOheq52IyFwZUo9CysTs6R0XYf2xeFjArlpfl4iIjMssciiSkpLQq1cveHh4YNmyZbhz5w5SUlKQkqK5Vrqvry927NgBAMjKysLMmTNx8uRJJCQkIDw8HEOGDIGrqyuef/75mngbREQmoabqUdSx9IIgy0O+RYLWdlwylojIvJjFsrH79+/H1atXcfXqVTRq1EjjudIztmJjY5GRkQEAkMvliI6OxsaNG3H//n2oVCr07t0b27Ztg6Oj7iULiYhqK30TrtcfT0AnHxfJchou3D2Ie1brUadgFGyKW1W5f0REZBrMIqAIDg5GcHCwznalgwtbW1vs27fPiL0iIjJPnXxcoKyjQEpmxSveqX2wPRr9WiklyWlwsZfBCq6wEtzLfV4GQMklY4mIzI5ZTHkiIiLpyC1keLmTp15t7+cUYNWhq5K87ubobShAGhTFvmWeU4crXDKWiMj8MKAgInoCebva6932myPXUFRctQUB915MRk5+8b/3iss872xnhTVjO3DJWCIiM8SAgojoCWRInkJOflGVRimKigUs2HUZAkoK2wkoLNNGYWmBfnoW3SMiItPCgIKI6AmkzqPQV1VGKU7FpyM5IxeCLAcAkGn5c5k2KZl5OBWfXqn9ExFRzWJAQUT0BJJbyBDyXGu921dllELfZWC5XCwRkXliQEFE9IQK8lNh9ej2ercPPRFfqVGKstOryk+65nKxRETmiQEFEdETbGAbd8x4pplebe/nFFRqWlInHxeonCoOFmQAVFwulojIbJlFHQpzUFRUhIKCgpruBhHVYlZWVpDL5ZLvd+ozzfDt0evIyS/S2XbfpWQENqln0P7lFjLMH9IKA8qmTnC5WCKiWoABRRUJgoCUlBTcv3+/prtCRE8AZ2dnKJVKyGTSnXzLLWR4s0djfH4wTmfbjSdvoJN3PQxsI83yrs52Vlgy3J/LxRIRmTEGFFWkDibc3NxgZ2cn6Y88EZGaIAjIyclBamoqAEClkvYEfEqfklGK7DztoxTFAvDW5rP4n4X+NSP2XkzG5E1nAduyz93L4cguEZG5Y0BRBUVFRWIwUa+eYVMAiIgMZWtbckaempoKNzc3Sac/yS1keKmjB9YdT9Cr/YJdl9GvlVLnNKVHNShKk2n8pe++iIjINDEpuwrUORN2dnY13BMielKov2+MkbPV14DCcskZuXolaKtrUGh6FDgIBuyLiIhMEwMKCXCaExFVF2N+3+hajelxBy6n6GzDGhRERLUfAwp6oiUkJEAmkyEqKqqmu0JU49SrMenrxzO3dNalKF1bwrq4CQDAprhsQT3WoCAiMl8MKExAUbGAk9fuYmfUbZy8drdShaP0JZPJtN6Cg4ON9tqPCw4OFl/XysoKDRo0QL9+/bB+/XoUFxcb5fWGDRsm+X6JahN1sTt9xkGy8gp1Vs9WumShjuNN5MuuAkLJT06hLB15sqvIk11FkSyVNSiIiMwck7Jr2N6LyViw67LGHGOVkw3mD2lllGUUk5OTxb+3bduGefPmITY2VnxMnfSpVlBQACsrK8n7oRYUFITQ0FAUFRXhn3/+wd69ezF9+nT89NNP+PXXX2FpyX+iRNVtYBt3BCfcQ+iJBJ1tvzlyDVP6NC03oToxIxGtVvsitzAXKDUAkWG1CRlWm0ruCFZY9MxxJmQTEZkxjlDUIPVSio8nLKZk5GLyprPYezG5gi0rT6lUijcnJyfIZDLxfm5uLpydnfHjjz+iV69esLGxwaZNmxASEoJ27dpp7OeLL76At7e3xmOhoaFo2bIlbGxs4Ovri9WrV+vsj0KhgFKpRMOGDdGhQwd8+OGH2LlzJ37//XeEhYWJ7TIyMvDGG2/Azc0NderUQZ8+fXD+/HnxeXUfv/nmG3h4eMDOzg4jRowQ64OEhIRgw4YN2LlzpzgqEh4eLm5//fp19O7dG3Z2dmjbti1Onjxp6EdLVKs821q/BO2c/KIKRynSctJKggltZAXw85C+WB8REVUfBhQSEwQBOfmFOm8Pcgsw/9dLKG9yk/qxkF8v40FugV77EwTppknNmjUL06ZNQ0xMDPr376/XNmvXrsWcOXOwaNEixMTEYPHixZg7dy42bNhg8Ov36dMHbdu2xfbt2wGUfKaDBg1CSkoK9uzZg8jISHTo0AHPPPMM0tMfrQxz9epV/Pjjj9i1axf27t2LqKgovP322wCAmTNnYuTIkQgKCkJycjKSk5PRtWtXcds5c+Zg5syZiIqKQvPmzfHyyy+jsLDQ4L4T1RadfFzgbKvf6GToiXijTtUkIiLTxvkkEntYUIRW8/ZVeT8CgJTMXPiH7Ner/eX/9oedtTSHc8aMGRg+fLhB2yxcuBDLly8Xt/Px8cHly5fxzTff4LXXXjO4D76+vrhw4QIA4PDhw4iOjkZqaioUCgUAYNmyZfjll1/w008/4Y033gAA5ObmYsOGDWjUqBEAYOXKlRg0aBCWL18OpVIJW1tb5OXlQakse+V15syZGDRoEABgwYIFaN26Na5evQpfX1+D+05UG8gtZHi9m7de1bPv5xTgVHw6Apto1uPRN8hgMEJEZN44QkFldOzY0aD2d+7cwc2bNzF+/Hg4ODiIt48//hjXrl2rVB8EQRCXx4yMjERWVhbq1aunsf/4+HiN/Xt6eorBBAAEBgaiuLhYI0ekIm3atBH/VlcgVlckJnpSTenTDHbW+k1HKm8J2Uu3M/TaVt92RERkmjhCITFbKzku/1f3NKFT8ekIDj2ts13Y60/ptfqJrZV0c5Dt7e017ltYWJSZUlW6qJZ6Raa1a9eic+fOGu0qW8k3JiYGPj4+4v5VKpVGzoOas7NzhftQByT6rNtfOvFc3d4YK00RmRO5hQxv9mis1yjFzqgkzBnUSiO5Oj0nX6/X0bcdERGZJgYUEpPJZHpNPererD5UTjZIycgtN49CBkDpZIPuzerX+Oon9evXR0pKisaoQem6DQ0aNEDDhg1x/fp1jBkzpsqvd+jQIURHR+Odd94BAHTo0AEpKSmwtLQskwheWmJiIpKSkuDu7g4AOHnyJCwsLNC8eXMAgLW1NYqKiqrcP6InyZQ+zfDt0evIztP+f+dudn6ZaU8udtZ6vYa+7YiIyDRxylMNKV1A6vFwQX1//pBWNR5MAECvXr1w584dLF26FNeuXcPXX3+N33//XaNNSEgIlixZgi+//BJXrlxBdHQ0QkNDsWLFCq37zsvLQ0pKCm7fvo2zZ89i8eLFGDp0KAYPHoxXX30VANC3b18EBgZi2LBh2LdvHxISEnDixAl89NFHOHPmjLgvGxsbvPbaazh//jyOHj2KadOmYeTIkWLOhLe3Ny5cuIDY2FikpaVpjLIQUfnkFjK81NFDr7aPV7tu3dBJr+30bUdERKaJAUUNCvJTYc3YDlA6aVaIVTrZYM3YDkapQ1EZLVu2xOrVq/H111+jbdu2OHXqFGbOnKnRZsKECfjuu+8QFhYGf39/9OzZE2FhYeK0pYrs3bsXKpUK3t7eCAoKwuHDh/HVV19h586d4nQpmUyGPXv2oEePHhg3bhyaN2+Ol156CQkJCWjQoIG4r6ZNm2L48OEYOHAgnn32Wfj5+WksXTtx4kS0aNECHTt2RP369XH8+HEJPyWi2qtvK/2WkH282nUDh/qwslBo3cbKQoEGDvUr3TciIqp5MkHK9UZroczMTDg5OSEjIwN16tTReC43Nxfx8fHw8fGBjY1NBXvQrahYwKn4dKQ+yIWbY0nFWFMYmTAnISEh+OWXXzSmYhHVRlJ97xiiqFjA058eKlMz53GrR3fAwDaaF0I2njqNj38/hQe5mssw17GxxNQ+TfFcm5bwdPKUvM9ERGQYbee8ujCHwgTILWRlllskIjIVcgsZ5g5qibc2n9PabuHuy+jvpxQviOy9mIz521MhwBuPj1PkPQSa1m0DTyfTGIklIqLK45QnIiLSqa699qlLAJCckYtT8SXFJouKBSzYdbncRSeAklyxBbsuswYFEVEtwICCaoWQkBBOdyIyoscTrnW1OxWfrnWKlADNAISIiMwXAwoiItLp8YTriiSk5QAwPAAhIiLzxYCCiIh06uTjAmUd3dOeQk/Eo6hY0DsA0bcdERGZLgYURESkk9xChpc76V6N6X5OAVYduopOPi5wtrOqsJ0MgMqpZFU7IiIyb1zliYiI9OLtaq9Xu9AT8Wjm5oD7ORUXjxRgOsU7iYioajhCQUREetF3etL9nAJ8tPOi1jbOdlbop2fBPCIiMm0MKIiISC+dfFzgbFvxNKbS0rPztT5/P6eAKzwREdUSDCiojPDwcMhkMty/f98o+09ISIBMJjP5ZV5TUlLQr18/2Nvbw9nZGQAgk8nwyy+/GP21vb298cUXXxj9daqqsp9HbGwslEolHjx4IH2nzFRqairq16+P27dv13RXKiS3kOH1bt6S7Y8rPBER1Q4MKGpQYkYiziafrfCWmJFolNcNDg6GTCaDTCaDlZUVGjdujJkzZyI7O9sor/c4Dw8PJCcnw8/Pzyj7DwkJEd+fhYUF3N3dMWbMGNy8edOg/Xz++edITk5GVFQUrly5AgBITk7GgAEDjNFtg5R+j5aWlnB1dUWPHj3wxRdfIC8vzyiv165dO8n2N2fOHLz99ttwdHQE8CiIVd/q1auHPn364Pjx45K9phTCwsLE4LK00v+n1LcuXbpotMnLy8PUqVPh6uoKe3t7PPfcc7h165b4vJubG1555RXMnz/f2G+jSqb0aQZ7hVySfXGFJyKi2oFJ2TUkMSMRLVa1QG5hxVfobCxtEDslFp5OuldWMVRQUBBCQ0NRUFCAo0ePYsKECcjOzsaaNWskf63HyeVyKJXGnTvdunVrHDx4EMXFxbh27RrefvttjBw5EidPntR7H9euXUNAQACaNWsmPmbsfhui9Hu8e/cuwsPD8fHHH+P7779HeHi4eLJuam7duoVff/213BGY2NhY1KlTB3fu3MHHH3+MQYMG4cqVK3Bzc6v+jhpI/X9KzdraWuP5GTNmYNeuXdi6dSvq1auH9957D4MHD0ZkZCTk8pIT9Ndffx2dOnXCZ599hrp161Zr//Ult5DhpY4eWHc8oUr74QpPRES1B0coakhaTprWYAIAcgtzkZaTZpTXVygUUCqV8PDwwOjRozFmzJgyU1ciIyPRsWNH2NnZoWvXroiNjQVQMmXJwsICZ86c0Wi/cuVKeHl5QRAE3Lt3D2PGjEH9+vVha2uLZs2aiSdb5U15unTpEgYNGoQ6derA0dER3bt3x7Vr1wCUXL3u1KmTOPWoW7duuHHjhtb3Z2lpCaVSCXd3d3Tv3h0TJ07En3/+iczMTLHNrl27EBAQABsbGzRu3BgLFixAYWEhgJIpRz///DM2btwImUyG4OBgAJpTfNTvY/v27ejduzfs7OzQtm3bMkHLiRMn0KNHD9ja2sLDwwPTpk3TGA1KTU3FkCFDYGtrCx8fH/zwww9a31t579Hf3x9Tp05FREQELl68iE8//VRsl5+fj/fffx8NGzaEvb09OnfujPDwcPF59VX3X375Bc2bN4eNjQ369esnjuiEhYVhwYIFOH/+vHj1PSwsTNw+LS0Nzz//POzs7NCsWTP8+uuvWvv9448/om3btmjUqFGZ59zc3KBUKuHv74+PPvoIGRkZ+Ouvv8TnL1++jIEDB8LBwQENGjTAK6+8grS0R/9HfvrpJ/j7+8PW1hb16tVD3759xc86ODgYw4YNw7Jly6BSqVCvXj28/fbbKCh4tBKRts8qPDwcr7/+OjIyMsTPISQkRNxW/X9KfXNxeXSynJGRgXXr1mH58uXo27cv2rdvj02bNiE6OhoHDx4U2/n7+0OpVGLHjh1aP8Oa1leCZOq5g7jCExFRbWE2AcVzzz0HT09P2NjYQKVS4ZVXXkFSUpLWbQRBQEhICNzd3WFra4tevXrh0qVL1dLf7PxsrbeHBQ/12s/jQUd5+5KCra2txokVUDItZfny5Thz5gwsLS0xbtw4ACUn23379tW4GgsAoaGh4tSPuXPn4vLly/j9998RExODNWvWwNXVtdzXvn37Nnr06AEbGxscOnQIkZGRGDduHAoLC1FYWIhhw4ahZ8+euHDhAk6ePIk33ngDMpn+JyIpKSnYvn075HK5eCV43759GDt2LKZNm4bLly/jm2++QVhYGBYtWgQAOH36NIKCgjBy5EgkJyfjyy+/rHD/c+bMwcyZMxEVFYXmzZvj5ZdfFgOT6Oho9O/fH8OHD8eFCxewbds2HDt2DFOmTBG3Dw4ORkJCAg4dOoSffvoJq1evRmpqqt7vrzRfX18MGDAA27dvFx97/fXXcfz4cWzduhUXLlzAiBEjEBQUhLi4OLFNTk4OFi1ahA0bNuD48ePIzMzESy+9BAAYNWoU3nvvPbRu3RrJyclITk7GqFGjxG0XLFiAkSNH4sKFCxg4cCDGjBmD9PSKk22PHDmCjh07an0fOTk54r8vK6uSJODk5GT07NkT7dq1w5kzZ7B37178888/GDlypPj8yy+/jHHjxiEmJgbh4eEYPnw4BEEQ93v48GFcu3YNhw8fxoYNGxAWFqYRHGn7rLp27YovvvgCderUET+HmTNnituGh4fDzc0NzZs3x8SJEzWOYWRkJAoKCvDss8+Kj7m7u8PPzw8nTpzQeO+dOnXC0aNHtX4+Nc2Q5OyK1LW31t2IiIjMgtlMeerduzc+/PBDqFQq3L59GzNnzsSLL75Y5se4tKVLl2LFihUICwtD8+bN8fHHH6Nfv36IjY01+nQQhyUOkuxn6p6piHwzUrzv/aV3mVELYb7w+GYGOXXqFDZv3oxnnnlG4/FFixahZ8+eAIAPPvgAgwYNQm5uLmxsbDBhwgRMmjQJK1asgEKhwPnz5xEVFSWeyCYmJqJ9+/biiaO3t3eFr//111/DyckJW7duFU8emzdvDgBIT09HRkYGBg8ejCZNmgAAWrZsqfM9RUdHw8HBAcXFxXj4sCR4mzZtGuzt7cX39sEHH+C1114DADRu3BgLFy7E+++/j/nz56N+/fpQKBSwtbXVOc1p5syZGDRoEICSk+vWrVvj6tWr8PX1xWeffYbRo0djxowZAIBmzZrhq6++Qs+ePbFmzRokJibi999/x59//onOnTsDANatW6fXe6yIr68v9u/fD6Bk2taWLVtw69YtuLu7i/3du3cvQkNDsXjxYgBAQUEBVq1aJfZhw4YNaNmyJU6dOoVOnTrBwcFBHBF5XHBwMF5++WUAwOLFi7Fy5UqcOnUKQUFB5fYvISEBAQEB5T6nHrXIycmBIAgICAgQ/12uWbMGHTp0EPsMAOvXr4eHhweuXLmCrKwsFBYWYvjw4fDy8gJQcsW/tLp162LVqlWQy+Xw9fXFoEGD8Mcff2DixIl6fVZOTk6QyWRlPocBAwZgxIgR8PLyQnx8PObOnYs+ffogMjISCoUCKSkpsLa2LjONqUGDBkhJSdF4rGHDhjh37ly5n4+pUCdnf34wTnfjCjAhm4io9jCbEYp33nkHXbp0gZeXF7p27YoPPvgAf/75Z5mr6mqCIOCLL77AnDlzMHz4cPj5+WHDhg3IycnB5s2bq7n3pue3336Dg4MDbGxsEBgYiB49emDlypUabdq0aSP+rVKpAEC86jps2DBYWlqKUzPWr1+P3r17i4HD5MmTsXXrVrRr1w7vv/++1sAvKioK3bt3F4OJ0lxcXBAcHIz+/ftjyJAh+PLLL5GcnAygJGhxcHAQb6VPNFu0aIGoqCicPn0aixYtQrt27cTRB6DkivF///tfje0nTpyI5ORk5OTkGPJRav2cIiMjERYWpvE6/fv3R3FxMeLj4xETEwNLS0uNK/a+vr7lJv7qSxAEcQTn7NmzEAQBzZs31+hDRESEOKUMQIV9iImJMej929vbw9HRUesIy8OHD2FjU34y7tGjR3H27Fls2bIFXl5eCAsLE/9dREZG4vDhwxrvw9fXF0BJ4NS2bVs888wz8Pf3x4gRI7B27Vrcu3dPY/+tW7cWR6mAkuOl7qu+n1V5Ro0ahUGDBsHPzw9DhgzB77//jitXrmD37t1atyt9rNRsbW0N/jdYE6b0aaa1ErYuTMgmIqo9zGaEorT09HT88MMP6Nq1a7knoQAQHx+PlJQUjSkGCoUCPXv2xIkTJ/Dmm28atY9Zs7O0Ph+VEoWnQ5/WuZ+VAzVP8hOmJ1SlW6LevXtjzZo1sLKygru7e7mfY+nH1Cc9xcXFAEoSTl955RWEhoZi+PDh2Lx5s0aS7YABA3Djxg3s3r0bBw8exDPPPIO3334by5YtK/M6tra2WvsaGhqKadOmYe/evdi2bRs++ugjHDhwAB07dtTIwyg9Z93a2hpNmzYFUHISGRcXh8mTJ+P7778X38eCBQswfPjwMq9X0cluRbR9TsXFxXjzzTcxbdq0Mtt5enqKeSmGTOHSJSYmBj4+PuLry+VyjcRfNQcHzVG08vqgT78e/7cjk8nE918eV1fXMif6aj4+PnB2dkbz5s2Rm5uL559/HhcvXoRCoUBxcTGGDBmikR+iplKpIJfLceDAAZw4cQL79+/HypUrMWfOHPz111/i56Gtr4Z8VrqoVCp4eXmJ08qUSiXy8/Nx7949jVGK1NRUdO3aVWPb9PR01K9f36DXqwlyCxk+Ge6PSZvOGrxtPXtrJmQTEdUiZjNCAQCzZs2Cvb096tWrh8TEROzcubPCtuppBA0aNNB4vLwpBqXl5eUhMzNT41YZ9tb2Wm+2VtpPotVsLDVPbsvbV6X6Z2+Ppk2bwsvLq8KgTJcJEybg4MGDWL16NQoKCsqcnNevXx/BwcHYtGkTvvjiC3z77bfl7qdNmzY4evRohaNNANC+fXvMnj0bJ06cgJ+fHzZv3gxLS0s0bdpUvJUOKB43d+5cbNmyBWfPlpz8dOjQAbGxsRrbq28WFtL9t+jQoQMuXbpU7utYW1ujZcuWKCws1Ehwj42NrXQNkL///ht79+7FCy+8AKDkcysqKkJqamqZ1y89baeiPqhHAKytrVFUVFSpPj2uffv2uHz5ss52r7zyCoqLi7F69WoAjz5Lb2/vMu9FPZVNJpOhW7duWLBgAc6dOwdra2u9E5z1+az0/Rzu3r2LmzdviiNWAQEBsLKywoEDB8Q2ycnJuHjxYpmA4uLFi2jfvr1efa5pQX4qrB7dHoaGw0PbuTMhm4ioFqnRgKL0WvoV3Uqf5PznP//BuXPnsH//fsjlcrz66qsaCZflefwKa3lTDEpbsmQJnJycxJuHh0fV3mQt1rJlS3Tp0gWzZs3Cyy+/rDHSMG/ePOzcuRNXr17FpUuX8Ntvv1WYFzBlyhQxCfjMmTOIi4vD999/j9jYWMTHx2P27Nk4efIkbty4gf379+PKlSsG5xg0btwYQ4cOxbx588T+bdy4ESEhIbh06RJiYmLE0Q8pzZo1CydPnsTbb7+NqKgoxMXF4ddff8XUqVMBlEzNCgoKwsSJE/HXX38hMjISEyZM0DlqA5QEASkpKUhKSkJ0dDRWrlwpJi3/5z//AVCSizJmzBi8+uqr2L59O+Lj43H69Gl8+umn2LNnj7gvKysrTJ06FX/99RfOnj2L119/HV26dEGnTp0AlOTAxMfHIyoqCmlpaVWqddG/f3+cPHlS54m5hYUFZsyYgU8++QQ5OTl4++23kZ6ejpdffhmnTp3C9evXsX//fowbNw5FRUX466+/sHjxYpw5cwaJiYnYvn077ty5o/e/FX0+K29vb2RlZeGPP/5AWloacnJykJWVhZkzZ+LkyZNISEhAeHg4hgwZAldXVzz//PMAACcnJ4wfPx7vvfce/vjjD5w7dw5jx46Fv78/+vbtK/YhJycHkZGRGiOrpm5gG3esfMmwAKifBKtEERGR6ajRgGLKlCmIiYnReitd/MzV1RXNmzdHv379sHXrVuzZswd//vlnuftWX1F8fDQiNTW1zKhFabNnz0ZGRoZ4M7QYmr5c7VzLjD48zsbSBq525a+MZCrGjx+P/Px8cQUoNWtra8yePRtt2rRBjx49IJfLsXXr1nL3Ua9ePRw6dAhZWVno2bMnAgICsHbtWlhZWcHOzg5///03XnjhBTRv3hxvvPEGpkyZUqkpa++99x52796Nv/76C/3798dvv/2GAwcO4KmnnkKXLl2wYsUKMZlXKm3atEFERATi4uLQvXt3tG/fHnPnzhWvXAMlU7o8PDzQs2dPDB8+HG+88YZedRcuXboElUoFT09P9OrVCz/++CNmz56No0ePakzRCQ0Nxauvvor33nsPLVq0wHPPPYe//vpLI1i2s7PDrFmzMHr0aAQGBsLW1lbjeL3wwgsICgpC7969Ub9+fWzZsqXSn8nAgQNhZWWlsVxqRcaNGycmjLu7u+P48eMoKipC//794efnh+nTp8PJyQkWFhaoU6cOjhw5goEDB6J58+b46KOPsHz5coMKEer6rLp27YpJkyZh1KhRqF+/PpYuXQq5XI7o6GgMHToUzZs3x2uvvYbmzZvj5MmTGos/fP755xg2bBhGjhyJbt26wc7ODrt27dKYXrVz5054enqie/fuBnyiNW9wO3dM7O6tV1vWnyAiqn1kgq5L/Cbq5s2b8PT0xOHDh9GrV68yzwuCAHd3d7zzzjt4//33AZSsMe/m5oZPP/1U7xPSzMxMODk5ISMjA3Xq1NF4Ljc3F/Hx8fDx8TF43j1QUtxOW50JVztXoxS1k9KiRYuwdetWREdH13RXqJLCwsIwY8aMSk+zqozVq1dj586d2LdvX7W9pjno1KkTZsyYgdGjR1fYpqrfO8a0aPdlrD0ar7XN/8Z2QJCfSmsbIiKqftrOeXUxi6TsU6dO4dSpU3j66adRt25dXL9+HfPmzUOTJk0QGBgotvP19cWSJUvw/PPPQyaTYcaMGVi8eDGaNWuGZs2aYfHixbCzs9P6Y12dPJ08TT5gqEhWVhZiYmKwcuVKLFy4sKa7Q2bmjTfewL179/DgwQOTrehd3VJTU/Hiiy+KS/CaozmDWqG9R128//MFZOUVajxX184KS4b7M5ggIqqFzCKgsLW1xfbt2zF//nxkZ2dDpVIhKCgIW7duhUKhENvFxsYiIyNDvP/+++/j4cOHeOutt3Dv3j107twZ+/fv5wmMBKZMmYItW7Zg2LBhZaY7EeliaWmJOXPm1HQ3TIqbm5s4mmrOBrZRob+fEn9eu4uT19MAyBDYpB66NK7HRGwiolrKbKc8VRdjTnkiIjIUv3eIiMgYqjLlyayWjSUiIiIiItPCgIKIiIiIiCqNAYUEOGuMiKoLv2+IiMjUMKCoAnWF6ZycnBruCRE9KdTfN5WtcE9ERCQ1s1jlyVTJ5XI4OzsjNTUVQElxMG1VuImIKksQBOTk5CA1NRXOzs4aBfGIiIhqEgOKKlJX5FYHFURExuTs7Cx+7xAREZkCBhRVJJPJoFKp4ObmhoKCgpruDhHVYlZWVhyZICIik8OAQiJyuZw/9ERERET0xGFSNhERERERVRoDCiIiIiIiqjQGFEREREREVGnModBBXUQqMzOzhntCRERERGQc6nPdyhRQZUChw4MHDwAAHh4eNdwTIiIiIiLjevDgAZycnAzaRiZUJgx5ghQXFyMpKQmOjo41UrQuMzMTHh4euHnzJurUqVPtr0+Vw+NmnnjczBOPm3nicTNfPHbmSddxEwQBDx48gLu7OywsDMuK4AiFDhYWFmjUqFFNdwN16tThf1ozxONmnnjczBOPm3nicTNfPHbmSdtxM3RkQo1J2UREREREVGkMKIiIiIiIqNIYUJg4hUKB+fPnQ6FQ1HRXyAA8buaJx8088biZJx4388VjZ56MedyYlE1ERERERJXGEQoiIiIiIqo0BhRERERERFRpDCiIiIiIiKjSGFCYsNWrV8PHxwc2NjYICAjA0aNHa7pLT7QjR45gyJAhcHd3h0wmwy+//KLxvCAICAkJgbu7O2xtbdGrVy9cunRJo01eXh6mTp0KV1dX2Nvb47nnnsOtW7eq8V08eZYsWYKnnnoKjo6OcHNzw7BhwxAbG6vRhsfO9KxZswZt2rQR10sPDAzE77//Lj7PY2YelixZAplMhhkzZoiP8diZnpCQEMhkMo2bUqkUn+cxM123b9/G2LFjUa9ePdjZ2aFdu3aIjIwUn6+uY8eAwkRt27YNM2bMwJw5c3Du3Dl0794dAwYMQGJiYk137YmVnZ2Ntm3bYtWqVeU+v3TpUqxYsQKrVq3C6dOnoVQq0a9fPzx48EBsM2PGDOzYsQNbt27FsWPHkJWVhcGDB6OoqKi63sYTJyIiAm+//Tb+/PNPHDhwAIWFhXj22WeRnZ0ttuGxMz2NGjXCJ598gjNnzuDMmTPo06cPhg4dKv4Q8piZvtOnT+Pbb79FmzZtNB7nsTNNrVu3RnJysniLjo4Wn+MxM0337t1Dt27dYGVlhd9//x2XL1/G8uXL4ezsLLaptmMnkEnq1KmTMGnSJI3HfH19hQ8++KCGekSlARB27Ngh3i8uLhaUSqXwySefiI/l5uYKTk5Owv/+9z9BEATh/v37gpWVlbB161axze3btwULCwth79691db3J11qaqoAQIiIiBAEgcfOnNStW1f47rvveMzMwIMHD4RmzZoJBw4cEHr27ClMnz5dEAT+fzNV8+fPF9q2bVvuczxmpmvWrFnC008/XeHz1XnsOEJhgvLz8xEZGYlnn31W4/Fnn30WJ06cqKFekTbx8fFISUnROGYKhQI9e/YUj1lkZCQKCgo02ri7u8PPz4/HtRplZGQAAFxcXADw2JmDoqIibN26FdnZ2QgMDOQxMwNvv/02Bg0ahL59+2o8zmNnuuLi4uDu7g4fHx+89NJLuH79OgAeM1P266+/omPHjhgxYgTc3NzQvn17rF27Vny+Oo8dAwoTlJaWhqKiIjRo0EDj8QYNGiAlJaWGekXaqI+LtmOWkpICa2tr1K1bt8I2ZFyCIODdd9/F008/DT8/PwA8dqYsOjoaDg4OUCgUmDRpEnbs2IFWrVrxmJm4rVu34uzZs1iyZEmZ53jsTFPnzp2xceNG7Nu3D2vXrkVKSgq6du2Ku3fv8piZsOvXr2PNmjVo1qwZ9u3bh0mTJmHatGnYuHEjgOr9/2ZZlTdCxiWTyTTuC4JQ5jEyLZU5Zjyu1WfKlCm4cOECjh07VuY5HjvT06JFC0RFReH+/fv4+eef8dprryEiIkJ8nsfM9Ny8eRPTp0/H/v37YWNjU2E7HjvTMmDAAPFvf39/BAYGokmTJtiwYQO6dOkCgMfMFBUXF6Njx45YvHgxAKB9+/a4dOkS1qxZg1dffVVsVx3HjiMUJsjV1RVyubxMZJiamlomyiTToF4NQ9sxUyqVyM/Px7179ypsQ8YzdepU/Prrrzh8+DAaNWokPs5jZ7qsra3RtGlTdOzYEUuWLEHbtm3x5Zdf8piZsMjISKSmpiIgIACWlpawtLREREQEvvrqK1haWoqfPY+dabO3t4e/vz/i4uL4/82EqVQqtGrVSuOxli1bigv4VOexY0BhgqytrREQEIADBw5oPH7gwAF07dq1hnpF2vj4+ECpVGocs/z8fERERIjHLCAgAFZWVhptkpOTcfHiRR5XIxIEAVOmTMH27dtx6NAh+Pj4aDzPY2c+BEFAXl4ej5kJe+aZZxAdHY2oqCjx1rFjR4wZMwZRUVFo3Lgxj50ZyMvLQ0xMDFQqFf+/mbBu3bqVWQb9ypUr8PLyAlDNv296p29Ttdq6datgZWUlrFu3Trh8+bIwY8YMwd7eXkhISKjprj2xHjx4IJw7d044d+6cAEBYsWKFcO7cOeHGjRuCIAjCJ598Ijg5OQnbt28XoqOjhZdffllQqVRCZmamuI9JkyYJjRo1Eg4ePCicPXtW6NOnj9C2bVuhsLCwpt5WrTd58mTByclJCA8PF5KTk8VbTk6O2IbHzvTMnj1bOHLkiBAfHy9cuHBB+PDDDwULCwth//79giDwmJmT0qs8CQKPnSl67733hPDwcOH69evCn3/+KQwePFhwdHQUzzl4zEzTqVOnBEtLS2HRokVCXFyc8MMPPwh2dnbCpk2bxDbVdewYUJiwr7/+WvDy8hKsra2FDh06iMtcUs04fPiwAKDM7bXXXhMEoWR5tvnz5wtKpVJQKBRCjx49hOjoaI19PHz4UJgyZYrg4uIi2NraCoMHDxYSExNr4N08Oco7ZgCE0NBQsQ2PnekZN26c+P1Xv3594ZlnnhGDCUHgMTMnjwcUPHamZ9SoUYJKpRKsrKwEd3d3Yfjw4cKlS5fE53nMTNeuXbsEPz8/QaFQCL6+vsK3336r8Xx1HTuZIAiCgSMsREREREREAJhDQUREREREVcCAgoiIiIiIKo0BBRERERERVRoDCiIiIiIiqjQGFEREREREVGkMKIiIiIiIqNIYUBARERERUaUxoCAiIiIiokpjQEFERDVGJpPhl19+qeluICQkBO3atavpbhARmSUGFEREtVhqairefPNNeHp6QqFQQKlUon///jh58mRNd00SCQkJkMlkiIqKqumuEBE9sSxrugNERGQ8L7zwAgoKCrBhwwY0btwY//zzD/744w+kp6fXdNeIiKiW4AgFEVEtdf/+fRw7dgyffvopevfuDS8vL3Tq1AmzZ8/GoEGDxHYrVqyAv78/7O3t4eHhgbfeegtZWVni82FhYXB2dsZvv/2GFi1awM7ODi+++CKys7OxYcMGeHt7o27dupg6dSqKiorE7by9vbFw4UKMHj0aDg4OcHd3x8qVK7X2+fbt2xg1ahTq1q2LevXqYejQoUhISND7PYeHh0Mmk+GPP/5Ax44dYWdnh65duyI2Nlaj3SeffIIGDRrA0dER48ePR25ubpl9hYaGomXLlrCxsYGvry9Wr14tPjdu3Di0adMGeXl5AICCggIEBARgzJgxeveViKi2YEBBRFRLOTg4wMHBAb/88ot44lseCwsLfPXVV7h48SI2bNiAQ4cO4f3339dok5OTg6+++gpbt27F3r17ER4ejuHDh2PPnj3Ys2cPvv/+e3z77bf46aefNLb77LPP0KZNG5w9exazZ8/GO++8gwMHDpTbj5ycHPTu3RsODg44cuQIjh07BgcHBwQFBSE/P9+g9z5nzhwsX74cZ86cgaWlJcaNGyc+9+OPP2L+/PlYtGgRzpw5A5VKpREsAMDatWsxZ84cLFq0CDExMVi8eDHmzp2LDRs2AAC++uorZGdn44MPPgAAzJ07F2lpaWX2Q0T0RBCIiKjW+umnn4S6desKNjY2QteuXYXZs2cL58+f17rNjz/+KNSrV0+8HxoaKgAQrl69Kj725ptvCnZ2dsKDBw/Ex/r37y+8+eab4n0vLy8hKChIY9+jRo0SBgwYIN4HIOzYsUMQBEFYt26d0KJFC6G4uFh8Pi8vT7C1tRX27dtXbl/j4+MFAMK5c+cEQRCEw4cPCwCEgwcPim12794tABAePnwoCIIgBAYGCpMmTdLYT+fOnYW2bduK9z08PITNmzdrtFm4cKEQGBgo3j9x4oRgZWUlzJ07V7C0tBQiIiLK7SMRUW3HEQoiolrshRdeQFJSEn799Vf0798f4eHh6NChA8LCwsQ2hw8fRr9+/dCwYUM4Ojri1Vdfxd27d5GdnS22sbOzQ5MmTcT7DRo0gLe3NxwcHDQeS01N1Xj9wMDAMvdjYmLK7WtkZCSuXr0KR0dHcXTFxcUFubm5uHbtmkHvu02bNuLfKpUKAMS+xcTElNsvtTt37uDmzZsYP3682A8HBwd8/PHHGv0IDAzEzJkzsXDhQrz33nvo0aOHQX0kIqotmJRNRFTL2djYoF+/fujXrx/mzZuHCRMmYP78+QgODsaNGzcwcOBATJo0CQsXLoSLiwuOHTuG8ePHo6CgQNyHlZWVxj5lMlm5jxUXF+vsj0wmK/fx4uJiBAQE4IcffijzXP369fV5q6LSfVO/nj59K91u7dq16Ny5s8Zzcrlco93x48chl8sRFxdnUP+IiGoTjlAQET1hWrVqJY4+nDlzBoWFhVi+fDm6dOmC5s2bIykpSbLX+vPPP8vc9/X1Lbdthw4dEBcXBzc3NzRt2lTj5uTkJFmfWrZsWW6/1Bo0aICGDRvi+vXrZfrh4+Mjtvvss88QExODiIgI7Nu3D6GhoZL1kYjInDCgICKqpe7evYs+ffpg06ZNuHDhAuLj4/F///d/WLp0KYYOHQoAaNKkCQoLC7Fy5Upcv34d33//Pf73v/9J1ofjx49j6dKluHLlCr7++mv83//9H6ZPn15u2zFjxsDV1RVDhw7F0aNHER8fj4iICEyfPh23bt2SrE/Tp0/H+vXrsX79ely5cgXz58/HpUuXNNqEhIRgyZIl+PLLL3HlyhVER0cjNDQUK1asAABERUVh3rx5WLduHbp164Yvv/wS06dPx/Xr1yXrJxGRuWBAQURUSzk4OKBz5874/PPP0aNHD/j5+WHu3LmYOHEiVq1aBQBo164dVqxYgU8//RR+fn744YcfsGTJEsn68N577yEyMhLt27fHwoULsXz5cvTv37/ctnZ2djhy5Ag8PT0xfPhwtGzZEuPGjcPDhw9Rp04dyfo0atQozJs3D7NmzUJAQABu3LiByZMna7SZMGECvvvuO4SFhcHf3x89e/ZEWFgYfHx8kJubizFjxiA4OBhDhgwBAIwfPx59+/bFK6+8orF0LhHRk0AmCIJQ050gIqLax9vbGzNmzMCMGTNquitERGREHKEgIiIiIqJKY0BBRERERESVxilPRERERERUaRyhICIiIiKiSmNAQURERERElcaAgoiIiIiIKo0BBRERERERVRoDCiIiIiIiqjQGFEREREREVGkMKIiIiIiIqNIYUBARERERUaUxoCAiIiIiokr7f3K3RAW3n4KCAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# === Device Setup ===\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# === Initialize Model & Optimizer ===\n",
    "model = ResNet1DContrastive()  # Move model to device\n",
    "criterion_depth = nn.MSELoss()  # Loss for depth prediction\n",
    "criterion_estimated_snow_depth = nn.MSELoss()  # Loss for predicted\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.0005)  # removed weight_decay from here.\n",
    "\n",
    "# Check for multiple GPUs and wrap with DataParallel if available\n",
    "if torch.cuda.device_count() > 1:\n",
    "    print(f\"Let's use {torch.cuda.device_count()} GPUs!\")\n",
    "    model = nn.DataParallel(model)\n",
    "\n",
    "# Move model to device\n",
    "model = model.to(device)\n",
    "\n",
    "# === Training Setup ===\n",
    "epochs = 500\n",
    "batch_size = 16\n",
    "\n",
    "# Convert data to PyTorch datasets\n",
    "train_dataset = torch.utils.data.TensorDataset(X_train_tensor, y_train_tensor)\n",
    "train_dataloader = torch.utils.data.DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "test_dataset = torch.utils.data.TensorDataset(X_test_tensor, y_test_tensor)\n",
    "test_dataloader = torch.utils.data.DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# === Store losses & predictions ===\n",
    "train_losses = []\n",
    "\n",
    "# === Training Loop ===\n",
    "for epoch in range(epochs):\n",
    "    total_loss = 0\n",
    "    model.train()  # Set to training mode\n",
    "\n",
    "    for batch_x, batch_y in train_dataloader:\n",
    "        batch_x, batch_y = batch_x.to(device), batch_y.to(device)  # move batch to device.\n",
    "        optimizer.zero_grad()\n",
    "        batch_x_aug = augment_data(batch_x)\n",
    "        # ✅ Correct Forward Pass for DataParallel\n",
    "        if isinstance(model, nn.DataParallel):\n",
    "            outputs = model(batch_x, batch_x_aug)\n",
    "            depth_pred = outputs[0]\n",
    "            params_pred = outputs[1]\n",
    "            estimated_snow_depth_pred = outputs[2]\n",
    "            contrastive_loss_value = outputs[3]\n",
    "        else:\n",
    "            depth_pred, params_pred, estimated_snow_depth_value = model(batch_x, batch_x_aug)\n",
    "\n",
    "        loss_depth = criterion_depth(depth_pred, batch_y[:, -1, :])\n",
    "        loss_estimated_snow_depth = criterion_depth(estimated_snow_depth_pred, batch_y[:, -1, :])\n",
    "        contrastive_loss_value = torch.mean(contrastive_loss_value)  # Ensure scalar\n",
    "        loss = loss_depth + loss_estimated_snow_depth + contrastive_loss_value\n",
    "\n",
    "        # L1 Regularization\n",
    "        l1_lambda = 0.001  # Adjust lambda as needed\n",
    "        l1_norm = sum(p.abs().sum() for p in model.parameters())\n",
    "        loss += l1_lambda * l1_norm\n",
    "\n",
    "        # L2 Regularization\n",
    "        l2_lambda = 1e-5  # adjust lambda as needed.\n",
    "        l2_norm = sum(p.pow(2.0).sum() for p in model.parameters())\n",
    "        loss += l2_lambda * l2_norm\n",
    "\n",
    "        # ✅ Backpropagation\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        total_loss += loss.item()\n",
    "\n",
    "    # Store loss for visualization\n",
    "    train_losses.append(total_loss / len(train_dataloader))\n",
    "\n",
    "    # ✅ Print Progress Every 50 Epochs\n",
    "    if epoch % 50 == 0:\n",
    "        print(f\"Epoch {epoch}/{epochs}, Loss: {train_losses[-1]:.4f}\")\n",
    "\n",
    "# === After Training: Evaluate on Test Set ===\n",
    "model.eval()\n",
    "depth_predictions = []\n",
    "estimated_depth_predictions = []\n",
    "with torch.no_grad():\n",
    "    for batch_x, _ in test_dataloader:\n",
    "        batch_x = batch_x.to(device)\n",
    "        batch_x_aug = augment_data(batch_x)  # create augmented data.\n",
    "        if isinstance(model, nn.DataParallel):\n",
    "            outputs = model(batch_x, batch_x_aug)\n",
    "            depth_pred = outputs[0]\n",
    "            params_pred = outputs[1]\n",
    "            estimated_snow_depth = outputs[2]\n",
    "            contrastive_loss_value = outputs[3]\n",
    "        else:\n",
    "            depth_pred, params_pred, estimated_snow_depth, contrastive_loss_value = model(batch_x, batch_x_aug)  # unpack 4 values.\n",
    "        depth_predictions.append(depth_pred.cpu())\n",
    "        estimated_depth_predictions.append(estimated_snow_depth.cpu())\n",
    "\n",
    "# ✅ Convert Predictions to NumPy\n",
    "estimated_depth_predictions_np = torch.cat(estimated_depth_predictions).squeeze().numpy()\n",
    "depth_predictions_np = torch.cat(depth_predictions).squeeze().numpy()\n",
    "true_depths_np = y_test_tensor.cpu().squeeze().numpy()\n",
    "print(depth_predictions_np.shape)\n",
    "print(true_depths_np.shape)\n",
    "avg_pred = depth_predictions_np  # Take mean along axis 0\n",
    "avg_est = estimated_depth_predictions_np # Take mean along axis 0\n",
    "avg_true = true_depths_np.mean(axis=1)\n",
    "# === Save Training Results ===\n",
    "torch.save(\n",
    "    {\n",
    "        \"epoch\": epochs,\n",
    "        \"model_state_dict\": model.state_dict(),\n",
    "        \"optimizer_state_dict\": optimizer.state_dict(),\n",
    "        \"train_losses\": train_losses,\n",
    "        \"depth_predictions_np\": depth_predictions_np,\n",
    "        \"estimated_depth_predictions_np\": estimated_depth_predictions_np,\n",
    "        \"true_depths_np\": true_depths_np,\n",
    "    },\n",
    "    \"Resnet50-training_results.pth\",\n",
    ")\n",
    "print(\"Training results saved to training_results.pth\")\n",
    "\n",
    "# === Write to CSV file ===\n",
    "df = pd.DataFrame({\n",
    "    'avg_pred': avg_pred,\n",
    "    'avg_est': avg_est,\n",
    "    'avg_true': avg_true\n",
    "})\n",
    "\n",
    "# Write to a CSV file\n",
    "df.to_csv('Resnet50-average_depths.csv', index=False)  # index=False prevents writing the row numbers to the CSV\n",
    "print(\"Data successfully written to average_depths.csv\")\n",
    "\n",
    "# === Plot Training Loss ===\n",
    "# === Plot all three in the same figure ===\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.plot(range(len(avg_true)), avg_true, label=\"True Depth\", marker='o', linestyle='-')\n",
    "\n",
    "plt.plot(\n",
    "    range(len(avg_est)),\n",
    "    avg_est,\n",
    "    label=\"Physics-Refined Depth (Resnet50)\",\n",
    "    marker='s',\n",
    "    linestyle=\"-.\",\n",
    "    color=\"green\",\n",
    ")\n",
    "\n",
    "plt.xlabel(\"Sample Index\")\n",
    "plt.ylabel(\"Avg Snow Depth anomalies\")\n",
    "plt.title(\"Averaged Snow Depth Prediction\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "#plt.ylim(0, 1)  # Set y-axis limits between 0 and 1\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ef1b2ccd-618d-4f8f-97c8-faf076cb9768",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction:\n",
      "  MSE  = 0.4308\n",
      "  RMSE = 0.6563\n",
      "  Mean = -0.0101\n",
      "\n",
      "Physics-Refined Prediction:\n",
      "  MSE  = 0.4315\n",
      "  RMSE = 0.6569\n",
      "  Mean = -0.0159\n",
      "\n",
      "Ground Truth Mean:\n",
      "  Mean = 0.0152\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import mean_squared_error\n",
    "# Reduce true depths to match prediction shape\n",
    "true_depth_avg = true_depths_np.mean(axis=1)  # shape (580,)\n",
    "\n",
    "# Then compute metrics\n",
    "mse_lstm = mean_squared_error(true_depth_avg, depth_predictions_np)\n",
    "rmse_lstm = np.sqrt(mse_lstm)\n",
    "mean_lstm = depth_predictions_np.mean()\n",
    "\n",
    "mse_phys = mean_squared_error(true_depth_avg, estimated_depth_predictions_np)\n",
    "rmse_phys = np.sqrt(mse_phys)\n",
    "mean_phys = estimated_depth_predictions_np.mean()\n",
    "\n",
    "mean_true = true_depth_avg.mean()\n",
    "\n",
    "print(\"Prediction:\")\n",
    "print(f\"  MSE  = {mse_lstm:.4f}\")\n",
    "print(f\"  RMSE = {rmse_lstm:.4f}\")\n",
    "print(f\"  Mean = {mean_lstm:.4f}\\n\")\n",
    "\n",
    "print(\"Physics-Refined Prediction:\")\n",
    "print(f\"  MSE  = {mse_phys:.4f}\")\n",
    "print(f\"  RMSE = {rmse_phys:.4f}\")\n",
    "print(f\"  Mean = {mean_phys:.4f}\\n\")\n",
    "\n",
    "print(\"Ground Truth Mean:\")\n",
    "print(f\"  Mean = {mean_true:.4f}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2fcb5c3d-6af2-4f5a-9bfb-f459ec13e902",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "operands could not be broadcast together with shapes (580,) (580,10) ",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[8], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# Compute RMSE at each time step\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m rmse_lstm_per_t \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msqrt(np\u001b[38;5;241m.\u001b[39mmean((depth_predictions_np \u001b[38;5;241m-\u001b[39m true_depths_np) \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m \u001b[38;5;241m2\u001b[39m, axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m))\n\u001b[1;32m      3\u001b[0m rmse_phys_per_t \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msqrt(\n\u001b[1;32m      4\u001b[0m     np\u001b[38;5;241m.\u001b[39mmean((estimated_depth_predictions_np \u001b[38;5;241m-\u001b[39m true_depths_np) \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m \u001b[38;5;241m2\u001b[39m, axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m)\n\u001b[1;32m      5\u001b[0m )\n\u001b[1;32m      7\u001b[0m \u001b[38;5;66;03m# Create DataFrame for RMSE values\u001b[39;00m\n",
      "\u001b[0;31mValueError\u001b[0m: operands could not be broadcast together with shapes (580,) (580,10) "
     ]
    }
   ],
   "source": [
    "# Expand single value to each timestep (broadcast across 10 timesteps)\n",
    "depth_pred_expanded = np.tile(depth_predictions_np[:, np.newaxis], (1, true_depths_np.shape[1]))\n",
    "estimated_depth_expanded = np.tile(estimated_depth_predictions_np[:, np.newaxis], (1, true_depths_np.shape[1]))\n",
    "\n",
    "# Compute RMSE per timestep\n",
    "rmse_lstm_per_t = np.sqrt(np.mean((depth_pred_expanded - true_depths_np) ** 2, axis=0))\n",
    "rmse_phys_per_t = np.sqrt(np.mean((estimated_depth_expanded - true_depths_np) ** 2, axis=0))\n",
    "\n",
    "# Create DataFrame for RMSE values\n",
    "rmse_df = pd.DataFrame({'rmse_lstm_per_t': rmse_lstm_per_t, 'rmse_phys_per_t': rmse_phys_per_t})\n",
    "# save to csv\n",
    "rmse_df.to_csv('Resnet50-rmse_values.csv', index=False)\n",
    "print(\"RMSE values saved to rmse_values.csv\")\n",
    "\n",
    "# Plot RMSE per timestep\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.plot(\n",
    "    rmse_lstm_per_t, label=\"Predicted RMSE (Resnet50)\", marker=\"x\", linestyle=\"--\"\n",
    ")\n",
    "plt.plot(\n",
    "    rmse_phys_per_t,\n",
    "    label=\"Physics-Refined RMSE (Resnet50)\",\n",
    "    marker=\"s\",\n",
    "    linestyle=\"-.\",\n",
    ")\n",
    "\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel(\"RMSE\")\n",
    "plt.title(\"RMSE\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.ylim(0, 1)  # set the ylim 0 to 1\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18b452fa-d1e2-467d-b764-db44946f8de4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "myenv",
   "language": "python",
   "name": "myenv"
  },
  "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
