{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Import libs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn.functional as F"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name = \"kuleshov-group/caduceus-ph_seqlen-131k_d_model-256_n_layer-16\"\n",
    "tokenizer_caduseus = AutoTokenizer.from_pretrained(model_name, trust_remote_code=True)\n",
    "config_caduseus = AutoConfig.from_pretrained(model_name, trust_remote_code=True)\n",
    "config_caduseus.bidirectional_weight_tie = False\n",
    "model_caduseus = AutoModel.from_pretrained('your_path', trust_remote_code=True, config=config_caduseus)\n",
    "model = CADUSEUS_for_token_classification(model_caduseus)\n",
    "\n",
    "seq = ['ATCGATCGATCGATCG']\n",
    "\n",
    "tokenized_data = tokenizer(seq, return_tensors='pt')\n",
    "\n",
    "result = model(**tokenized_data)['logits']"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Configure model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.chdir('/home/jovyan/dnalm/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jovyan/dnalm/my_saved_conda_envs/gena/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from transformers import AutoTokenizer, AutoConfig\n",
    "tokenizer = AutoTokenizer.from_pretrained('./data/tokenizers/t2t_1000h_multi_32k/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.gena_lm.modeling_bert import BertForLetterLevelTokenClassification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_cfg = AutoConfig.from_pretrained('./data/configs/L24-H1024-A16-V32k-preln-lastln.json') # here it soulbe config for backbone model, don't change it, you can change only path to it\n",
    "model_cls = BertForLetterLevelTokenClassification\n",
    "model = model_cls(config=model_cfg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import GPT2LMHeadModel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_cfg = AutoConfig.from_pretrained('./data/configs/GPT2.json')\n",
    "model_cls = GPT2LMHeadModel\n",
    "decoder = model_cls(config=model_cfg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "rmt_config = {\n",
    "    'num_mem_tokens': 5,\n",
    "    'max_n_segments': 100000,\n",
    "    'input_size': 512,\n",
    "    'decoder_chunk_size': 1024,\n",
    "    'decoder_look_back_size': 512,\n",
    "    'bptt_depth': -1,\n",
    "    'sum_loss': True,\n",
    "    'tokenizer': tokenizer\n",
    "}\n",
    "\n",
    "from src.gena_lm.modeling_rmt import RMTEncoderDecoderValidation\n",
    "rmt_cls = RMTEncoderDecoderValidation\n",
    "model = rmt_cls(model, decoder, **rmt_config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "missing: ['decoder.transformer.h.2.ln_1.weight', 'decoder.transformer.h.2.ln_1.bias', 'decoder.transformer.h.2.attn.c_attn.weight', 'decoder.transformer.h.2.attn.c_attn.bias', 'decoder.transformer.h.2.attn.c_proj.weight', 'decoder.transformer.h.2.attn.c_proj.bias', 'decoder.transformer.h.2.ln_2.weight', 'decoder.transformer.h.2.ln_2.bias', 'decoder.transformer.h.2.crossattention.c_attn.weight', 'decoder.transformer.h.2.crossattention.c_attn.bias', 'decoder.transformer.h.2.crossattention.q_attn.weight', 'decoder.transformer.h.2.crossattention.q_attn.bias', 'decoder.transformer.h.2.crossattention.c_proj.weight', 'decoder.transformer.h.2.crossattention.c_proj.bias', 'decoder.transformer.h.2.ln_cross_attn.weight', 'decoder.transformer.h.2.ln_cross_attn.bias', 'decoder.transformer.h.2.mlp.c_fc.weight', 'decoder.transformer.h.2.mlp.c_fc.bias', 'decoder.transformer.h.2.mlp.c_proj.weight', 'decoder.transformer.h.2.mlp.c_proj.bias', 'decoder.transformer.h.3.ln_1.weight', 'decoder.transformer.h.3.ln_1.bias', 'decoder.transformer.h.3.attn.c_attn.weight', 'decoder.transformer.h.3.attn.c_attn.bias', 'decoder.transformer.h.3.attn.c_proj.weight', 'decoder.transformer.h.3.attn.c_proj.bias', 'decoder.transformer.h.3.ln_2.weight', 'decoder.transformer.h.3.ln_2.bias', 'decoder.transformer.h.3.crossattention.c_attn.weight', 'decoder.transformer.h.3.crossattention.c_attn.bias', 'decoder.transformer.h.3.crossattention.q_attn.weight', 'decoder.transformer.h.3.crossattention.q_attn.bias', 'decoder.transformer.h.3.crossattention.c_proj.weight', 'decoder.transformer.h.3.crossattention.c_proj.bias', 'decoder.transformer.h.3.ln_cross_attn.weight', 'decoder.transformer.h.3.ln_cross_attn.bias', 'decoder.transformer.h.3.mlp.c_fc.weight', 'decoder.transformer.h.3.mlp.c_fc.bias', 'decoder.transformer.h.3.mlp.c_proj.weight', 'decoder.transformer.h.3.mlp.c_proj.bias', 'decoder.transformer.h.4.ln_1.weight', 'decoder.transformer.h.4.ln_1.bias', 'decoder.transformer.h.4.attn.c_attn.weight', 'decoder.transformer.h.4.attn.c_attn.bias', 'decoder.transformer.h.4.attn.c_proj.weight', 'decoder.transformer.h.4.attn.c_proj.bias', 'decoder.transformer.h.4.ln_2.weight', 'decoder.transformer.h.4.ln_2.bias', 'decoder.transformer.h.4.crossattention.c_attn.weight', 'decoder.transformer.h.4.crossattention.c_attn.bias', 'decoder.transformer.h.4.crossattention.q_attn.weight', 'decoder.transformer.h.4.crossattention.q_attn.bias', 'decoder.transformer.h.4.crossattention.c_proj.weight', 'decoder.transformer.h.4.crossattention.c_proj.bias', 'decoder.transformer.h.4.ln_cross_attn.weight', 'decoder.transformer.h.4.ln_cross_attn.bias', 'decoder.transformer.h.4.mlp.c_fc.weight', 'decoder.transformer.h.4.mlp.c_fc.bias', 'decoder.transformer.h.4.mlp.c_proj.weight', 'decoder.transformer.h.4.mlp.c_proj.bias', 'decoder.transformer.h.5.ln_1.weight', 'decoder.transformer.h.5.ln_1.bias', 'decoder.transformer.h.5.attn.c_attn.weight', 'decoder.transformer.h.5.attn.c_attn.bias', 'decoder.transformer.h.5.attn.c_proj.weight', 'decoder.transformer.h.5.attn.c_proj.bias', 'decoder.transformer.h.5.ln_2.weight', 'decoder.transformer.h.5.ln_2.bias', 'decoder.transformer.h.5.crossattention.c_attn.weight', 'decoder.transformer.h.5.crossattention.c_attn.bias', 'decoder.transformer.h.5.crossattention.q_attn.weight', 'decoder.transformer.h.5.crossattention.q_attn.bias', 'decoder.transformer.h.5.crossattention.c_proj.weight', 'decoder.transformer.h.5.crossattention.c_proj.bias', 'decoder.transformer.h.5.ln_cross_attn.weight', 'decoder.transformer.h.5.ln_cross_attn.bias', 'decoder.transformer.h.5.mlp.c_fc.weight', 'decoder.transformer.h.5.mlp.c_fc.bias', 'decoder.transformer.h.5.mlp.c_proj.weight', 'decoder.transformer.h.5.mlp.c_proj.bias', 'decoder.transformer.h.6.ln_1.weight', 'decoder.transformer.h.6.ln_1.bias', 'decoder.transformer.h.6.attn.c_attn.weight', 'decoder.transformer.h.6.attn.c_attn.bias', 'decoder.transformer.h.6.attn.c_proj.weight', 'decoder.transformer.h.6.attn.c_proj.bias', 'decoder.transformer.h.6.ln_2.weight', 'decoder.transformer.h.6.ln_2.bias', 'decoder.transformer.h.6.crossattention.c_attn.weight', 'decoder.transformer.h.6.crossattention.c_attn.bias', 'decoder.transformer.h.6.crossattention.q_attn.weight', 'decoder.transformer.h.6.crossattention.q_attn.bias', 'decoder.transformer.h.6.crossattention.c_proj.weight', 'decoder.transformer.h.6.crossattention.c_proj.bias', 'decoder.transformer.h.6.ln_cross_attn.weight', 'decoder.transformer.h.6.ln_cross_attn.bias', 'decoder.transformer.h.6.mlp.c_fc.weight', 'decoder.transformer.h.6.mlp.c_fc.bias', 'decoder.transformer.h.6.mlp.c_proj.weight', 'decoder.transformer.h.6.mlp.c_proj.bias', 'decoder.transformer.h.7.ln_1.weight', 'decoder.transformer.h.7.ln_1.bias', 'decoder.transformer.h.7.attn.c_attn.weight', 'decoder.transformer.h.7.attn.c_attn.bias', 'decoder.transformer.h.7.attn.c_proj.weight', 'decoder.transformer.h.7.attn.c_proj.bias', 'decoder.transformer.h.7.ln_2.weight', 'decoder.transformer.h.7.ln_2.bias', 'decoder.transformer.h.7.crossattention.c_attn.weight', 'decoder.transformer.h.7.crossattention.c_attn.bias', 'decoder.transformer.h.7.crossattention.q_attn.weight', 'decoder.transformer.h.7.crossattention.q_attn.bias', 'decoder.transformer.h.7.crossattention.c_proj.weight', 'decoder.transformer.h.7.crossattention.c_proj.bias', 'decoder.transformer.h.7.ln_cross_attn.weight', 'decoder.transformer.h.7.ln_cross_attn.bias', 'decoder.transformer.h.7.mlp.c_fc.weight', 'decoder.transformer.h.7.mlp.c_fc.bias', 'decoder.transformer.h.7.mlp.c_proj.weight', 'decoder.transformer.h.7.mlp.c_proj.bias']\n",
      "unexpected_k: []\n"
     ]
    }
   ],
   "source": [
    "# load pre-trained weights\n",
    "ckpt = torch.load(str('/home/jovyan/dnalm/runs/annotation_encoder_bert_large_24_classes_GPT2_1024_decoder_4k_with_overlaps_no_loss_weights_with_all_embeddings_in_decoder_avg_hyperparameters/bert_large_512_lastln_t2t_1000G_bs256_lr_1e-04_fp16/model_1750000/rmt_seglen_512_len4096_maxnsegm_10000_msz_5_bptt-1_lr5e-05_AdamW_constant_with_warmup_wd1e-04_p10000_bs_it500000/run_1/model_best/pytorch_model.bin'))\n",
    "missing_k, unexpected_k = model.load_state_dict(ckpt, strict=False)\n",
    "print(f'missing: {missing_k}') # if no missing tensors - that is correct, otherwise - no!\n",
    "print(f'unexpected_k: {unexpected_k}') # if no missing tensors - that is correct, otherwise - no!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "RMTEncoderDecoderValidation(\n",
       "  (model): BertForLetterLevelTokenClassification(\n",
       "    (bert): BertModel(\n",
       "      (embeddings): BertEmbeddings(\n",
       "        (word_embeddings): Embedding(32005, 1024, padding_idx=3)\n",
       "        (position_embeddings): Embedding(512, 1024)\n",
       "        (token_type_embeddings): Embedding(2, 1024)\n",
       "        (LayerNorm): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (encoder): BertEncoder(\n",
       "        (layer): ModuleList(\n",
       "          (0-23): 24 x BertLayer(\n",
       "            (pre_attention_ln): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "            (post_attention_ln): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "            (attention): BertAttention(\n",
       "              (self): BertSelfFlashAttention(\n",
       "                (query): Linear(in_features=1024, out_features=1024, bias=True)\n",
       "                (key): Linear(in_features=1024, out_features=1024, bias=True)\n",
       "                (value): Linear(in_features=1024, out_features=1024, bias=True)\n",
       "                (dropout): Dropout(p=0.1, inplace=False)\n",
       "                (softmax): Softmax(dim=-1)\n",
       "              )\n",
       "              (output): BertSelfOutput(\n",
       "                (dense): Linear(in_features=1024, out_features=1024, bias=True)\n",
       "                (dropout): Dropout(p=0.1, inplace=False)\n",
       "              )\n",
       "            )\n",
       "            (intermediate): BertIntermediate(\n",
       "              (dense): Linear(in_features=1024, out_features=4096, bias=True)\n",
       "              (intermediate_act_fn): GELUActivation()\n",
       "            )\n",
       "            (output): BertOutput(\n",
       "              (dense): Linear(in_features=4096, out_features=1024, bias=True)\n",
       "              (dropout): Dropout(p=0.1, inplace=False)\n",
       "            )\n",
       "          )\n",
       "        )\n",
       "        (last_layer_ln): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "      )\n",
       "    )\n",
       "    (embeddings): Embedding(32005, 1024, padding_idx=3)\n",
       "  )\n",
       "  (decoder): GPT2LMHeadModel(\n",
       "    (transformer): GPT2Model(\n",
       "      (wte): Embedding(26, 1024)\n",
       "      (wpe): Embedding(1024, 1024)\n",
       "      (drop): Dropout(p=0.1, inplace=False)\n",
       "      (h): ModuleList(\n",
       "        (0-7): 8 x GPT2Block(\n",
       "          (ln_1): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): GPT2SdpaAttention(\n",
       "            (c_attn): Conv1D()\n",
       "            (c_proj): Conv1D()\n",
       "            (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "            (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "          )\n",
       "          (ln_2): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "          (crossattention): GPT2SdpaAttention(\n",
       "            (c_attn): Conv1D()\n",
       "            (q_attn): Conv1D()\n",
       "            (c_proj): Conv1D()\n",
       "            (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "            (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "          )\n",
       "          (ln_cross_attn): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): GPT2MLP(\n",
       "            (c_fc): Conv1D()\n",
       "            (c_proj): Conv1D()\n",
       "            (act): NewGELUActivation()\n",
       "            (dropout): Dropout(p=0.1, inplace=False)\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (ln_f): LayerNorm((1024,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "    (lm_head): Linear(in_features=1024, out_features=26, bias=False)\n",
       "  )\n",
       "  (nucleotide_embedding): Embedding(100, 1024)\n",
       "  (label_embedding): Embedding(26, 1024)\n",
       ")"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = model.eval().to('cuda')\n",
    "model.half()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Valid dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import h5py\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<KeysViewHDF5 ['ID', 'Parent', 'chromosome', 'gene_seq', 'strand', 'transcript_seq', 'type']>"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_file = h5py.File('/home/jovyan/evo2_experiments/sequences.hdf5', \"r\")\n",
    "dataset_file[f'transcript_{0}'].attrs.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "980"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(list(dataset_file.keys()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3156"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset_file[f'transcript_{4}'].attrs['gene_seq'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_file = h5py.File('/home/jovyan/shares/SR003.nfs2/mane_no_intergenic_combined/mane_transcript_train_dataset_max_exon_cds.hdf5', \"r\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['transcript_0',\n",
       " 'transcript_1',\n",
       " 'transcript_10',\n",
       " 'transcript_100',\n",
       " 'transcript_1000',\n",
       " 'transcript_10000',\n",
       " 'transcript_10001',\n",
       " 'transcript_10002',\n",
       " 'transcript_10003',\n",
       " 'transcript_10004']"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list(dataset_file.keys())[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<KeysViewHDF5 ['coordinates', 'input_ids', 'labels', 'labels_atcg', 'token_atcg']>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_file[f'transcript_{0}'].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<KeysViewHDF5 ['gene_name', 'strand', 'transcript_name', 'type']>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_file[f'transcript_{0}'].attrs.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'lnc_RNA'"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_file[f'transcript_{0}'].attrs['type']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "17724"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 32385/32385 [03:37<00:00, 148.96it/s] \n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "counter = 0\n",
    "with h5py.File('mane_transcript_train_dataset_max_exon_cds_mRNA_only.h5', 'w') as f:\n",
    "\n",
    "    for i in tqdm(range(len(list(dataset_file.keys())))):   \n",
    "        sample_name = \"transcript_\" + str(i)\n",
    "        if dataset_file[sample_name].attrs['type'] == 'mRNA':\n",
    "            group = f.create_group(\"transcript_\" + str(counter))\n",
    "            group.create_dataset('input_ids', data=np.array(dataset_file[sample_name]['input_ids'])[:], compression='gzip', compression_opts=4) # 4 is default\n",
    "            group.create_dataset('labels', data=np.array(dataset_file[sample_name]['labels'])[:], compression='gzip', compression_opts=4) # 4 is default\n",
    "            group.create_dataset('labels_atcg', data=np.array(dataset_file[sample_name]['labels_atcg'])[:], compression='gzip', compression_opts=4) # 4 is default\n",
    "            group.create_dataset('token_atcg', data=np.array(dataset_file[sample_name]['token_atcg'])[:], compression='gzip', compression_opts=4) # 4 is default\n",
    "            counter += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[29260 44148]\n"
     ]
    }
   ],
   "source": [
    "print(np.array(dataset_file[f'transcript_{0}']['coordinates']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_file = h5py.File('/home/jovyan/shares/SR003.nfs2/decoder/gena_decoder_val.hdf5', \"r\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "24346"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(list(dataset_file.keys()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "24346"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "12173 * 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "tss_polya_counter_not_first = 0\n",
    "\n",
    "for i in range(len(list(dataset_file.keys()))):\n",
    "    tr = np.array(dataset_file[f'transcript_{i}'][\"labels\"])[:90000] # 32768\n",
    "    if (21 in tr or 22 in tr) and tr[0] != 21 and tr[0] != 22:\n",
    "        tss_polya_counter_not_first += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "12173"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tss_polya_counter_not_first"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6034666885730715"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "7346 / 12173"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2400000000"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "75000 * 32000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5923"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "counter = 0\n",
    "\n",
    "for i in range(len(list(dataset_file.keys()))):\n",
    "    tr = np.array(dataset_file[f'transcript_{i}'][\"labels\"])[:32768]\n",
    "    if (tr[0] == 21 or tr[0] == 22) and tr[-1] == 23:\n",
    "        counter += 1\n",
    "counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "tss_polya_counter_not_first = 0\n",
    "\n",
    "for i in range(len(list(dataset_file.keys()))):\n",
    "    tr = np.array(dataset_file[f'transcript_{i}'][\"labels\"])[:32768]\n",
    "    if (21 in tr or 22 in tr) and tr[0] != 21 and tr[0] != 22:\n",
    "        tss_polya_counter_not_first += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7346"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tss_polya_counter_not_first"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'TTGTTCTAAAAAAAATTAAACCTTTTTATTAGTATATTTATTTTATATATAAAAGAAATACAAAAAAAAAAAAAAACAGAAAGAAAATGCTTTTATGGCA'"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "transcript_idx = 10000\n",
    "tokenizer.decode(np.array(dataset_file[f'transcript_{transcript_idx}'][\"token_atcg\"]))[:100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_seq = tokenizer.decode(np.array(dataset_file[f'transcript_{transcript_idx}'][\"token_atcg\"]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([22, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 14,  1,  0,  2,  1,  0,  2,  1])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[:100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'input_ids': array([[1, 9, 2]]), 'token_type_ids': array([[0, 0, 0]]), 'attention_mask': array([[1, 1, 1]])}"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer(['G'], return_tensors='np')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'ATCG'"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode([6, 15, 8, 9])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prepare_sequence(sequence, tokenizer):\n",
    "    model_input = dict()\n",
    "    input_features = tokenizer([sequence], return_tensors='np')\n",
    "    \n",
    "#    print(input_features['input_ids'].shape)\n",
    "    \n",
    "    model_input['input_ids'] = input_features['input_ids']\n",
    "    model_input['token_type_ids'] = input_features['token_type_ids']\n",
    "    model_input['attention_mask'] = input_features['attention_mask']\n",
    "    # model_input['labels'] = np.random.randint(0, 5, (1, model_input['input_ids'].shape[1], 5)) # change it in future\n",
    "    # model_input['labels_ohe'] = torch.randint(0, 6, (model_input['input_ids'].shape[0], 6)) # change it in future\n",
    "    model_input['labels_mask'] = (input_features['input_ids'] > 5).astype(int)\n",
    "    \n",
    "    token_repeater_numbers = []\n",
    "    meaningful_tokens_only = model_input['input_ids'][model_input['input_ids'] > 5]\n",
    "    for t in meaningful_tokens_only:\n",
    "        atcg_seq_token = tokenizer.convert_ids_to_tokens(int(t))\n",
    "        token_repeater_numbers.append(len(atcg_seq_token))\n",
    "    \n",
    "    token_repeater = []\n",
    "    for n, i in enumerate(token_repeater_numbers):\n",
    "        # print(i)\n",
    "        for j in range(i):\n",
    "            token_repeater.append(n)\n",
    "    \n",
    "    letter_level_tokens = []\n",
    "    for letter in sequence:\n",
    "        letter_level_tokens.append(tokenizer.convert_tokens_to_ids(letter))\n",
    "        \n",
    "    # if len(letter_level_tokens) < max_length:\n",
    "    #     letter_level_tokens += [-100] * (max_length - len(letter_level_tokens))\n",
    "    #     token_repeater = token_repeater + [-100] * (max_length - len(token_repeater))\n",
    "\n",
    "    model_input['letter_level_attention_mask'] = np.expand_dims(np.ones(len(letter_level_tokens)).astype(int), axis=0) # it's okay because we will truncate paddings with mask\n",
    "    model_input['letter_level_token_types_ids'] = np.expand_dims(np.zeros(len(letter_level_tokens)).astype(int), axis=0)\n",
    "    model_input['letter_level_tokens'] = np.expand_dims(np.array(letter_level_tokens), axis=0)\n",
    "    # model_input['letter_level_labels'] = np.array([[24] + [0] * len(letter_level_tokens)]) # np.random.randint(0, 5, (1, len(letter_level_tokens), 5)) # change it in future\n",
    "    model_input['letter_level_labels_mask'] = model_input['letter_level_tokens'] != -100 #  model_input['letter_level_labels'] != -100\n",
    "    model_input['embedding_repeater'] = np.expand_dims(np.array(token_repeater), axis=0)\n",
    "    \n",
    "    for k, v in model_input.items():\n",
    "        model_input[k] = torch.tensor(v)\n",
    "        print(k, v.shape)\n",
    "    \n",
    "    return model_input"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10000000\n"
     ]
    }
   ],
   "source": [
    "# import random\n",
    "\n",
    "# # Define the length of the sequence and the nucleotides\n",
    "# sequence_length = 10000\n",
    "# nucleotides = ['A', 'T', 'C', 'G']\n",
    "\n",
    "# # Generate a sequence with equal probability for each nucleotide\n",
    "# sequence = ''.join(random.choices(nucleotides, k=sequence_length))\n",
    "\n",
    "with open('./downstream_tasks/annotation/10M.fa', 'r') as f:\n",
    "    for line in f:\n",
    "        print(len(line))\n",
    "\n",
    "# sequence = line[1932462:1972348].upper()\n",
    "# sequence = line[1932462:1932462+16000].upper()\n",
    "sequence = dataset_seq[:32768]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'AAAAATTAAACCTTTTTATT'"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sequence[10:30]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prediction(transcript_seq, model):\n",
    "    \n",
    "    seq = transcript_seq\n",
    "\n",
    "    model_input_data = prepare_sequence(seq, tokenizer)\n",
    "    for k, v in model_input_data.items():\n",
    "        model_input_data[k] = v.to(\"cuda\")\n",
    "\n",
    "    with torch.no_grad():\n",
    "        # model.forward(**model_input_data)\n",
    "        out = model.generate(model_input_data, generate_the_most_probable=True, threshold=0.2, temperature=0.9, \n",
    "                             targets_without_bos_token=None)\n",
    "\n",
    "    return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "input_ids (1, 5208)\n",
      "token_type_ids (1, 5208)\n",
      "attention_mask (1, 5208)\n",
      "labels_mask (1, 5208)\n",
      "letter_level_attention_mask (1, 32768)\n",
      "letter_level_token_types_ids (1, 32768)\n",
      "letter_level_tokens (1, 32768)\n",
      "letter_level_labels_mask (1, 32768)\n",
      "embedding_repeater (1, 32768)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jovyan/dnalm/my_saved_conda_envs/gena/lib/python3.9/site-packages/transformers/modeling_utils.py:1101: FutureWarning: The `device` argument is deprecated and will be removed in v5 of Transformers.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CURR LOGITS SHAPE torch.Size([1, 5206, 1024])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 32768/32768 [02:22<00:00, 230.34it/s]\n"
     ]
    }
   ],
   "source": [
    "gene_dict = prediction(sequence, model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([22, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(gene_dict[:100])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('for_artyom_decoder_output.npy', np.array(gene_dict))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "93"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len([22, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
    "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
    "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
    "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
    "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
    "       16, 16, 16, 16, 16, 16, 16, 14])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([22, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,\n",
       "       16, 16, 16, 16, 16, 16, 16, 14,  1,  0,  2,  1,  0,  2,  1])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[:100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,\n",
       "       18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,\n",
       "       18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,\n",
       "       18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,\n",
       "       18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,\n",
       "       18, 18, 18, 18, 18, 18, 18, 18, 20, 16, 16, 16, 16, 16, 16])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(gene_dict[3300:3400])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,\n",
       "        4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,\n",
       "        4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,\n",
       "        4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,\n",
       "        4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,\n",
       "        4,  4,  4,  4,  4,  4,  4,  4, 10,  0,  2,  1,  0,  2,  1])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[3300:3400]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0028076171875"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "select_size = 32768\n",
    "np.sum(np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[:select_size] == np.array(gene_dict[:select_size])) / select_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2.1061e+02, 2.1027e+02, 2.1061e+02, 2.4285e+09, 4.9705e+00, 9.1546e+00,\n",
       "        5.2431e+00, 3.6945e+04, 5.6307e+04, 2.6567e+04, 3.6922e+04, 5.6253e+04,\n",
       "        2.6576e+04, 1.3250e+05, 1.3203e+05, 8.9892e+01, 8.9457e+01, 7.4846e+00,\n",
       "        9.8910e+00, 6.3503e+04, 6.3706e+04, 1.0213e+05, 1.0187e+05, 4.3984e+00,\n",
       "        2.4285e+09, 2.4285e+09])"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "w = torch.tensor([11531128.0, 11549727.0, 11531095.0, 1.0, 488589751.0, 265281019.0, 463184462.0, 65733.0, 43130.0, 91413.0, 65774.0, 43172.0, 91380.0, 18329.0, 18394.0, 27016189.0, 27147388.0, 324472532.0, 245528623.0, 38243.0, 38121.0, 23780.0, 23839.0, 552140823.0, 1.0, 1.0])\n",
    "torch.sum(w) / w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "def get_label_counts(gene_array):\n",
    "    label_dict = {0: 'CDS-0', 1:'CDS-1', 2:'CDS-2', 3:'CDS-skip', 4:'intron-0', 5:'intron-1', 6:'intron-2', 7:'ASS-0', 8:'ASS-1', 9:'ASS-2', 10:'DSS-0', 11:'DSS-1', 12:'DSS-2', 13:'START', 14:'STOP', 15:'nc_exon_plus', 16:'nc_exon_minu', 17:'nc_intron_plus', 18:'nc_intron_minus', 19:'nc_ASS', 20:'nc_DSS', 21:'TSS' , 22:'PolyA', 23:'IR'}\n",
    "    # Use numpy.unique to get the unique labels and their counts\n",
    "    unique_labels, counts = np.unique(gene_array, return_counts=True)\n",
    "    \n",
    "    # Map each unique label to its corresponding name using label_dict\n",
    "    label_names = [label_dict[label] for label in unique_labels]\n",
    "    \n",
    "    # Create and return the DataFrame\n",
    "    df = pd.DataFrame({\n",
    "        'label name': label_names,\n",
    "        'count value': counts\n",
    "    })\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'gene_dict' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[31], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m get_label_counts(\u001b[43mgene_dict\u001b[49m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'gene_dict' is not defined"
     ]
    }
   ],
   "source": [
    "get_label_counts(gene_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>label name</th>\n",
       "      <th>count value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>CDS-0</td>\n",
       "      <td>281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CDS-1</td>\n",
       "      <td>281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CDS-2</td>\n",
       "      <td>280</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>intron-0</td>\n",
       "      <td>2812</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>intron-2</td>\n",
       "      <td>29014</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>ASS-0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>ASS-2</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>DSS-0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>DSS-2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>STOP</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>nc_exon_minu</td>\n",
       "      <td>91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>PolyA</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      label name  count value\n",
       "0          CDS-0          281\n",
       "1          CDS-1          281\n",
       "2          CDS-2          280\n",
       "3       intron-0         2812\n",
       "4       intron-2        29014\n",
       "5          ASS-0            1\n",
       "6          ASS-2            3\n",
       "7          DSS-0            1\n",
       "8          DSS-2            2\n",
       "9           STOP            1\n",
       "10  nc_exon_minu           91\n",
       "11         PolyA            1"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_label_counts(np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[:32768])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 14, 16, 22]),\n",
       " array([  549,   549,   548,  2812, 32883, 52547,     1,     2,     7,\n",
       "            1,     2,     6,     1,    91,     1]))"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])[:90000], return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.unique(gene_dict, return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# top_values.index(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generated_seq = prediction(sequence, model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generated_seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# start = 85000\n",
    "# generated_seq[start:start+1000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# len(generated_seq)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compare classes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jovyan/dnalm/my_saved_conda_envs/gena/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "missing: []\n",
      "unexpected_k: []\n",
      "missing: []\n",
      "unexpected_k: []\n",
      "loaded\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\"\n",
    "import os\n",
    "import json\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "\n",
    "os.chdir('/home/jovyan/dnalm/')\n",
    "from transformers import AutoTokenizer, AutoConfig\n",
    "tokenizer = AutoTokenizer.from_pretrained('./data/tokenizers/t2t_1000h_multi_32k/')\n",
    "from src.gena_lm.modeling_bert import BertForLetterLevelTokenClassification\n",
    "model_cfg = AutoConfig.from_pretrained('./data/configs/L24-H1024-A16-V32k-preln-lastln.json') # here it soulbe config for backbone model, don't change it, you can change only path to it\n",
    "model_cls = BertForLetterLevelTokenClassification\n",
    "model = model_cls(config=model_cfg)\n",
    "from transformers import GPT2LMHeadModel\n",
    "model_cfg = AutoConfig.from_pretrained('./data/configs/GPT2.json')\n",
    "model_cls = GPT2LMHeadModel\n",
    "decoder = model_cls(config=model_cfg)\n",
    "rmt_config = {\n",
    "    'num_mem_tokens': 5,\n",
    "    'max_n_segments': 100000,\n",
    "    'input_size': 512,\n",
    "    'decoder_chunk_size': 1024,\n",
    "    'decoder_look_back_size': 512,\n",
    "    'bptt_depth': -1,\n",
    "    'sum_loss': True,\n",
    "    'tokenizer': tokenizer\n",
    "}\n",
    "\n",
    "from src.gena_lm.modeling_rmt import RMTEncoderDecoderValidation\n",
    "rmt_cls = RMTEncoderDecoderValidation\n",
    "model = rmt_cls(model, decoder, **rmt_config)\n",
    "# load pre-trained weights\n",
    "ckpt = torch.load(str('/home/jovyan/dnalm/runs/annotation_decoder_with_2k_intergenic_only_1024/bert_large_512_lastln_t2t_1000G_bs256_lr_1e-04_fp16/model_1750000/rmt_seglen_512_len4096_maxnsegm_10000_msz_5_bptt-1_lr5e-05_AdamW_constant_with_warmup_wd1e-04_p10000_bs_it500000/run_1/model_best/pytorch_model.bin'))\n",
    "missing_k, unexpected_k = model.load_state_dict(ckpt, strict=False)\n",
    "print(f'missing: {missing_k}') # if no missing tensors - that is correct, otherwise - no!\n",
    "print(f'unexpected_k: {unexpected_k}') # if no missing tensors - that is correct, otherwise - no!\n",
    "model_val = model.eval().to('cuda')\n",
    "model_val.half()\n",
    "\n",
    "os.chdir('/home/jovyan/dnalm/')\n",
    "from transformers import AutoTokenizer, AutoConfig\n",
    "tokenizer = AutoTokenizer.from_pretrained('./data/tokenizers/t2t_1000h_multi_32k/')\n",
    "from src.gena_lm.modeling_bert import BertForLetterLevelTokenClassification\n",
    "model_cfg = AutoConfig.from_pretrained('./data/configs/L24-H1024-A16-V32k-preln-lastln.json') # here it soulbe config for backbone model, don't change it, you can change only path to it\n",
    "model_cls = BertForLetterLevelTokenClassification\n",
    "model = model_cls(config=model_cfg)\n",
    "from transformers import GPT2LMHeadModel\n",
    "model_cfg = AutoConfig.from_pretrained('./data/configs/GPT2.json')\n",
    "model_cls = GPT2LMHeadModel\n",
    "decoder = model_cls(config=model_cfg)\n",
    "rmt_config = {\n",
    "    'num_mem_tokens': 5,\n",
    "    'max_n_segments': 100000,\n",
    "    'input_size': 512,\n",
    "    'decoder_chunk_size': 1024,\n",
    "    'decoder_look_back_size': 512,\n",
    "    'bptt_depth': -1,\n",
    "    'sum_loss': True,\n",
    "    'tokenizer': tokenizer\n",
    "}\n",
    "\n",
    "from src.gena_lm.modeling_rmt import RMTEncoderDecoder\n",
    "rmt_cls = RMTEncoderDecoder\n",
    "model = rmt_cls(model, decoder, **rmt_config)\n",
    "# load pre-trained weights\n",
    "ckpt = torch.load(str('/home/jovyan/dnalm/runs/annotation_decoder_with_2k_intergenic_only_1024/bert_large_512_lastln_t2t_1000G_bs256_lr_1e-04_fp16/model_1750000/rmt_seglen_512_len4096_maxnsegm_10000_msz_5_bptt-1_lr5e-05_AdamW_constant_with_warmup_wd1e-04_p10000_bs_it500000/run_1/model_best/pytorch_model.bin'))\n",
    "missing_k, unexpected_k = model.load_state_dict(ckpt, strict=False)\n",
    "print(f'missing: {missing_k}') # if no missing tensors - that is correct, otherwise - no!\n",
    "print(f'unexpected_k: {unexpected_k}') # if no missing tensors - that is correct, otherwise - no!\n",
    "model = model.eval().to('cuda')\n",
    "model.half()\n",
    "\n",
    "print('loaded')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Parameter containing:\n",
       "tensor([[ 6.4453e-02, -9.6664e-03, -1.0626e-01,  ..., -3.3302e-03,\n",
       "          2.3102e-02, -7.6782e-02],\n",
       "        [ 2.5497e-02, -4.6967e-02, -8.2016e-03,  ...,  3.9856e-02,\n",
       "          3.7689e-02, -3.0632e-03],\n",
       "        [-3.2501e-02, -2.6550e-02,  4.8431e-02,  ..., -6.4278e-03,\n",
       "         -3.6133e-02,  1.2756e-01],\n",
       "        ...,\n",
       "        [-1.1145e-01, -7.0801e-02,  2.7725e-02,  ...,  1.4160e-01,\n",
       "          6.8542e-02, -1.3696e-01],\n",
       "        [-1.1566e-02, -5.7281e-02,  1.0150e-01,  ...,  3.1830e-02,\n",
       "          7.7576e-02,  1.3125e-04],\n",
       "        [ 8.6487e-02, -6.0516e-02, -9.6680e-02,  ..., -7.2266e-02,\n",
       "         -8.0719e-03, -6.2500e-02]], device='cuda:0', dtype=torch.float16,\n",
       "       requires_grad=True)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# new model\n",
    "model.model.bert.encoder.layer[0].attention.self.query.weight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Parameter containing:\n",
       "tensor([[ 6.4453e-02, -9.6664e-03, -1.0626e-01,  ..., -3.3302e-03,\n",
       "          2.3102e-02, -7.6782e-02],\n",
       "        [ 2.5497e-02, -4.6967e-02, -8.2016e-03,  ...,  3.9856e-02,\n",
       "          3.7689e-02, -3.0632e-03],\n",
       "        [-3.2501e-02, -2.6550e-02,  4.8431e-02,  ..., -6.4278e-03,\n",
       "         -3.6133e-02,  1.2756e-01],\n",
       "        ...,\n",
       "        [-1.1145e-01, -7.0801e-02,  2.7725e-02,  ...,  1.4160e-01,\n",
       "          6.8542e-02, -1.3696e-01],\n",
       "        [-1.1566e-02, -5.7281e-02,  1.0150e-01,  ...,  3.1830e-02,\n",
       "          7.7576e-02,  1.3125e-04],\n",
       "        [ 8.6487e-02, -6.0516e-02, -9.6680e-02,  ..., -7.2266e-02,\n",
       "         -8.0719e-03, -6.2500e-02]], device='cuda:0', dtype=torch.float16,\n",
       "       requires_grad=True)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# old model\n",
    "model.model.bert.encoder.layer[0].attention.self.query.weight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "30592 [ 0  1  2  5  6  8  9 11 12 13 14 16 18 19 20 21 22 23]\n"
     ]
    }
   ],
   "source": [
    "import h5py\n",
    "transcript_idx = 870\n",
    "dataset_file = h5py.File('/home/jovyan/shares/SR003.nfs2/decoder/gena_decoder_val.hdf5', \"r\")\n",
    "dataset_bpe_tokets = np.array(dataset_file[f'transcript_{transcript_idx}'][\"input_ids\"])\n",
    "dataset_seq_atcg = tokenizer.decode(np.array(dataset_file[f'transcript_{transcript_idx}'][\"token_atcg\"]))\n",
    "dataset_labels = np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])\n",
    "print(len(dataset_labels), np.unique(dataset_labels))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prepare_sequence(sequence, tokenizer):\n",
    "    model_input = dict()\n",
    "    input_features = tokenizer([sequence], return_tensors='np')\n",
    "    \n",
    "#    print(input_features['input_ids'].shape)\n",
    "    \n",
    "    model_input['input_ids'] = input_features['input_ids']\n",
    "    model_input['token_type_ids'] = input_features['token_type_ids']\n",
    "    model_input['attention_mask'] = input_features['attention_mask']\n",
    "    # model_input['labels'] = np.random.randint(0, 5, (1, model_input['input_ids'].shape[1], 5)) # change it in future\n",
    "    # model_input['labels_ohe'] = torch.randint(0, 6, (model_input['input_ids'].shape[0], 6)) # change it in future\n",
    "    model_input['labels_mask'] = (input_features['input_ids'] > 5).astype(int)\n",
    "    \n",
    "    token_repeater_numbers = []\n",
    "    meaningful_tokens_only = model_input['input_ids'][model_input['input_ids'] > 5]\n",
    "    for t in meaningful_tokens_only:\n",
    "        atcg_seq_token = tokenizer.convert_ids_to_tokens(int(t))\n",
    "        token_repeater_numbers.append(len(atcg_seq_token))\n",
    "    \n",
    "    token_repeater = []\n",
    "    for n, i in enumerate(token_repeater_numbers):\n",
    "        # print(i)\n",
    "        for j in range(i):\n",
    "            token_repeater.append(n)\n",
    "    \n",
    "    letter_level_tokens = []\n",
    "    for letter in sequence:\n",
    "        letter_level_tokens.append(tokenizer.convert_tokens_to_ids(letter))\n",
    "        \n",
    "    # if len(letter_level_tokens) < max_length:\n",
    "    #     letter_level_tokens += [-100] * (max_length - len(letter_level_tokens))\n",
    "    #     token_repeater = token_repeater + [-100] * (max_length - len(token_repeater))\n",
    "\n",
    "    model_input['letter_level_attention_mask'] = np.expand_dims(np.ones(len(letter_level_tokens)).astype(int), axis=0) # it's okay because we will truncate paddings with mask\n",
    "    model_input['letter_level_token_types_ids'] = np.expand_dims(np.zeros(len(letter_level_tokens)).astype(int), axis=0)\n",
    "    model_input['letter_level_tokens'] = np.expand_dims(np.array(letter_level_tokens), axis=0)\n",
    "    # model_input['letter_level_labels'] = np.array([[24] + [0] * len(letter_level_tokens)]) # np.random.randint(0, 5, (1, len(letter_level_tokens), 5)) # change it in future\n",
    "    model_input['letter_level_labels_mask'] = model_input['letter_level_tokens'] != -100 #  model_input['letter_level_labels'] != -100\n",
    "    model_input['embedding_repeater'] = np.expand_dims(np.array(token_repeater), axis=0)\n",
    "    \n",
    "    for k, v in model_input.items():\n",
    "        model_input[k] = torch.tensor(v)\n",
    "        print(k, v.shape)\n",
    "    \n",
    "    return model_input\n",
    "\n",
    "def prepare_sequence_forward(sequence, tokenizer, labels):\n",
    "    model_input = dict()\n",
    "    input_features = tokenizer([sequence], return_tensors='np')\n",
    "    \n",
    "#    print(input_features['input_ids'].shape)\n",
    "    \n",
    "    model_input['input_ids'] = input_features['input_ids']\n",
    "    model_input['token_type_ids'] = input_features['token_type_ids']\n",
    "    model_input['attention_mask'] = input_features['attention_mask']\n",
    "    model_input['labels'] = np.random.randint(0, 5, (1, model_input['input_ids'].shape[1], 5)) # change it in future\n",
    "    # model_input['labels_ohe'] = torch.randint(0, 6, (model_input['input_ids'].shape[0], 6)) # change it in future\n",
    "    model_input['labels_mask'] = (input_features['input_ids'] > 5).astype(int)\n",
    "    \n",
    "    token_repeater_numbers = []\n",
    "    meaningful_tokens_only = model_input['input_ids'][model_input['input_ids'] > 5]\n",
    "    for t in meaningful_tokens_only:\n",
    "        atcg_seq_token = tokenizer.convert_ids_to_tokens(int(t))\n",
    "        token_repeater_numbers.append(len(atcg_seq_token))\n",
    "    \n",
    "    token_repeater = []\n",
    "    for n, i in enumerate(token_repeater_numbers):\n",
    "        # print(i)\n",
    "        for j in range(i):\n",
    "            token_repeater.append(n)\n",
    "    \n",
    "    letter_level_tokens = []\n",
    "    for letter in sequence:\n",
    "        letter_level_tokens.append(tokenizer.convert_tokens_to_ids(letter))\n",
    "        \n",
    "    # if len(letter_level_tokens) < max_length:\n",
    "    #     letter_level_tokens += [-100] * (max_length - len(letter_level_tokens))\n",
    "    #     token_repeater = token_repeater + [-100] * (max_length - len(token_repeater))\n",
    "\n",
    "    model_input['letter_level_attention_mask'] = np.expand_dims(np.ones(len(letter_level_tokens)).astype(int), axis=0) # it's okay because we will truncate paddings with mask\n",
    "    model_input['letter_level_token_types_ids'] = np.expand_dims(np.zeros(len(letter_level_tokens)).astype(int), axis=0)\n",
    "    model_input['letter_level_tokens'] = np.expand_dims(np.array(letter_level_tokens), axis=0)\n",
    "    model_input['letter_level_labels'] = labels[None, :]\n",
    "    model_input['letter_level_labels_mask'] = model_input['letter_level_labels'] != -100 #  model_input['letter_level_labels'] != -100\n",
    "    model_input['embedding_repeater'] = np.expand_dims(np.array(token_repeater), axis=0)\n",
    "    \n",
    "    for k, v in model_input.items():\n",
    "        model_input[k] = torch.tensor(v).to('cuda')\n",
    "        # print(k, v.shape)\n",
    "    \n",
    "    return model_input\n",
    "\n",
    "def prediction(transcript_seq, model, targets_without_bos_token=None):\n",
    "    \n",
    "    seq = transcript_seq\n",
    "\n",
    "    model_input_data = prepare_sequence(seq, tokenizer)\n",
    "    for k, v in model_input_data.items():\n",
    "        model_input_data[k] = v.to(\"cuda\")\n",
    "\n",
    "    with torch.no_grad():\n",
    "        # model.forward(**model_input_data)\n",
    "        out = model.generate(model_input_data, generate_the_most_probable=True, threshold=0.2, temperature=0.9, \n",
    "                             targets_without_bos_token=targets_without_bos_token)\n",
    "\n",
    "    return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'dataset_file' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[3], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;28mlen\u001b[39m(\u001b[43mdataset_file\u001b[49m))\n",
      "\u001b[0;31mNameError\u001b[0m: name 'dataset_file' is not defined"
     ]
    }
   ],
   "source": [
    "print(len(dataset_file))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/12173 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[26941 46149 28941 44149]\n",
      "CAGCTTGGGCAAATAGCAAGACCCTTATGTCTACAAAAAATATATATATATATATTAGATGGCATGCTTGCACATACCTGTAGTCCCAGCTACCCAGGAGGCTGAAGCGGGAGGATTGCTTGAGCCCAGGAGTTCGAGGCTGCAATGAGCCAGCCATAATCGCACCACTGCACTCCAGCCTGGGCGACAGAGTGAGACCCTGTCTCTCTCTCTCTGTCACACACACACACACGTTAAATTTGTTGGATTATATATTTCGGGGGTTGAGCACTTTTCGTTATAAAATATTTATGATTGTGGGAACAAGTTAATAAAGACATGAAAGTTATTTAAATGTCCCAGAACTTTAAGAACAAAAAGCATTCTTAGTTTAAAAATAAGTTTTACTTTAAAGGTAACAGTACACACATAAATTGTTGTTAAAATCGACAGTAACAAAGAGAAGTAACAATACTAATAGCCTGTCACAAACTGATTCTTAATAACCTATATAAACAAACATTAAGCCCGGGCGCCGGGTGGCTCATGCCTGTTATCCCAGCACTTTGGGAAGCCGAGGCAGGCAGATCACTTGAGGCCAGCAGTTCCAGACCAGCCTGACCAACATGGTGAAGCCCAGTCTCTACCAAAAACACAAAAAATTAGCCGGGTATATTGGCACGCACCTGTAATCCCAGCTACTTGGGAGACTGAGGCAGGAGAATCCTTGAACCCAGGAAGCAGAGGTCGCAGTGAGGCGAGACCATGCCATTGTGACAGGAGAGAAACTCTGTCTCAAAAAAAAATTATATGTTTACAACAGGTGCATTTCTCCTCTTGCTTTCTGAGGACGCCCTGCTATGTAGCTGAGTAGTCACTAATAAACTATCTTAACTTCACTATACTCTGTGACTTGCCAAAAGGTCTTTCCCATGTGAAATCCAAAAACCTGTTCTTGGGGTCTAGGACAAGACCCATTTTATAATGACAAAACTATACAAATTCTAGAGGGAAACATAGAAAGAAAGCTATGTGACCTTGCGTTTGGCCATGAGTTTTAACACGACACTATCAGAGGCATTTGAACCCCTCCTCTATATGAACTCCAGGGTGGTTTATGTTCCATTGGCTAAGAGAAAGTTTTCTTCAAAAATGTGACATGATTTGAGGTCAAACATTAATATCAAGTAAACTCAAAAGATTGAGAAGCTAGCATTAGTTCTGGGAAAACCAGAAGTGTGCCTTTTTTGGAAATAATCATTGGTAGCACAAACTTAAGAATCTCCAAAGGAAATAAAAATGAGTTATTAACTTACAGTTTTCACCAATTAAGATATAAATGAAGCTAACGAAATCCGGAAATACAATTTCACTGTTTTTAATGTTCATTAAAAAAAAATCCTTATCAAATAGCCCCAGTAAGTCACCAATTAAGTCTTTACTACTTAAAAGCAAAATCCACCTATGTCCTGAACAGTATCCACTTTACGAGCCTCATTATATGTACAGGAGATAAAATTCAGAAATAAATAAATATACATGTATACGTATACAAATATATTTCAAATTAAAAAATACTTTTAGATAGTGGTATGTATTACATTTAGAAATTAATAACGAAGTAAATTATGGGATGTCATCCACGCCTGTCCCAAAGGTACCGAATTTATAAATCATCTCAGGTGCGGAGCAGGACAGGTTGAAAATAGGAATGACATGAACCCGCGCGGAACAGCTGCCGGCACGGTGTCCAGGGCGGCACCCCGCCCGGTCCCGGCCCCTCCAGCCCTGGGCCCGACCCCTACTACGCCTCTGCCTCGACGCGAACGCGGAGCCCGAGCGCGCGTCACGCCGTGTGGGGCCGAAGAGGCTGCTACCCAGAGGCGGAGTGCGGGCTCGCGAGGGTCCCCACCCGACTCTCGCTCCCGCCAGCACCTACGGACTCGCGTCCCCGCCGCGCGCCGACTCGGGAGCAGCACCGCCCCCGGCACAGGAGCCTCACGCGCCTCTTACCTAACAGGAAGTTGGGTGGAAGCAGCGCGGACCCACGGCACACCGAACGCACTCCAACAGAACCCGACGCAGACACGCGCTTTCAACCGGCGGAGACACTGGCAGGGCCAGAAACGCGCGCAGCGGGGGCGGGAGGTCGGTAAGCTCCCCGCCCCTGCCCGAGACCCCGCCCCGGCCCGGCCCCGCCTTTTTCTCTGCCTCCCCTCCCTGCACGTACGGGCCCCGCCCCTCGCGCGACGTTTTTTGTTGACCCGGAAACGGATTCTCCGGAGCCGAGGTCCGCTCGGGTGAGTGCCCTCCGCTTTTTGTGGCCAAACCCAGCCACGCAGTTCCCTTCCTGCGGCGTCCTCCACACCCGGGGTCTGCTGGTCTCCGCGGATGTCACAGGCTCGGCAACCGCCCTCCTGTCGGCGGGGAGTCCCGCGACGCCCGGAAATGCTCCGAAGCCTGTCGCCCAGCTGCCAGATCTGCGTCTGTGTCCGGTTCCGTCACTGAGGTCGCCCCTGTCCGGCCCTTCCACCCTAGTTCTCTTCACCGTCCGCCCATCCTATCGCGCGCGGCCTCAGGTCCCGATTCGGCATGTGGCTTGTCTTCCATCGTCCCCACCCTCGCCCCTCTTGGCCCCTCAGGGCAGCCCTGGGATTCGGCAGACGCCAGTCCTCCCTGAGATGCTTCCCCGTCCTTCCCTCCGCCAGGCCCTACGTCTCCGCAAACCCCACGCTTCGGGGTGGCCGCCTCAGACAGGACCCTGAGTCCGAGACTGGGGTAGGGGACCTGCCCGATCCTGTAACAACCCTCGTGCTTCCGCACAATCGCCTCCAACTAGCGGTGACTGTTGGGTGTTTACCTTCCCGGTGTCCCACTGAGAAGCGGGCTCTTCCTTGGCAGGGGCTTCTTCATTGCCTCGCTGTGGATGTCGAGGTGGGGCAGGAGAGTGAGGAGAAAACAGAGGAGGGAGGTAGAGCCAACGAGCGAGAAAAGGGGAGGGAAGTTTAGATGGGAAGTGGATGGGTCTGAGGAATTTGAACAAACACCGACAATGAAGGAGAGTGACCTGAGCAAGTAGTAGTGGGGTAAATGGAAATAGACAAAATGGGAATCAGCAGAGATATGGAGGACAGAATACAATGAGGAGGCCTTGACCGTCAGTAGCAGAGAGGGCAGCAGAAGCCTAATTCCCAAATTCTTTAGATGGTTTTCTGATTTCCAAATTAGTTTCCCTTTTAAATTTATTGTGTCAGGTTCAGCTTATGAGGCCTCAATACTTTTCAGTCTTAATTGTATATTGAAAATACTTTTTGTTTACTAAATGCTTTTTACATTAATTCAGTGTGCACTTCGTAAGGATAATGATGATTTGAGTTAGTTTAGTATTCAACAGCTTCCTCTATTCCTTTATATGATCTCTGTATTTAATGGCTGTGGCATAAAGTTTCCAACTAAGTTTAAGTATCAAGTTTTCTTTGTGCTGTTTTCTGCAAATATTGAAGGATGACCTGGATTGTCCTAGAACTTTGTTCCAACAGATTACATGTGTTCATAATGAATAGACTGCTCAAAGATATTTCCAAAGCTCACCTTTTATGTTTTTCAGTTCCAATAATTACATCTTTTTAAGGTTTATATTTTTTGATGACTTAATGTGATGTTCTGGAGAAGACAAATGCTTTTAATCAATATGATTAAAACCGTGAAAGACAAATCGCTGTTACTTAAGAGTGTGACATATGATCTGAAATCTTTAGGGGGCAGGGATGTTAAGGGAAAACTGCCACTATCGTATTAAGGTCATGCCATTCCTGTGAAGCTGGTGCTTGTTACTCTCTACTGGCTTCTGTTCACCTTTCCACCGGCCCCAAGACACACACATAGTGACACAAGGCAGTGGACAGGGAAAGAGCAAGACTTTATAAAGTAAGCACAGAACAAAGGTATCTTTCTAATGAGGAGGAGGTGTTGGTTCTGGGAAGGAAGCTTGGGATTTGGGTATTCAGGATCCAGAAGTGAGAGAGCCTGGGAAGTTCAGGAACCAGAGAAAGAAAAAGCCTTGCCCATTCTCACCCATGACACTGTGCTCAGCAGGTACTAGCAGACTTCAGGCTCTGTGACTAAAAGGGGTCAGACCAGTTGATATACCCACAGCTGCCATGTAAGGATGTGTGTGGACTTCACTAGGGAAGAACGGTGTTACGAAAGAAGGGGCAGAAAAACTCACCTGTTGGTCTGCATGTAGAGGTTTATTGTCCTGAATTCCTGGAGGTTCAGTGAAAAGCAGAAGATTGTCTTTTACACATGTTGAGTTATGCCCCCATATATGTGGTTGTGGTAAAGAAAGAGGGTGTGTTGATGAGAGGTCCTGAAATGCATTTTCCTAATACTCAGCAGGGGCTTCTCAAGAAGGATCTTCCCTAAGAAAGAAGCTCAGAGAACAAAAATGGAAAAGGATTAGATATGGCACTTTCACTGGAAAAAGTCATGTTATTCATTGATTGTTTTGTCATCTCCCGCCTTAAGTGTTGTTTTTAGGATGTGGTAATCTCTGACCCTGCCTAACACATTTCCCAACTCAACCATAGCCTTCCCTTAACGTCCTCCCATCTTCACGCTATCACACTGTGACCCAGTGAATTCGAACTTGTGAAGTTCCATTCGGGGGATCATATGGGAAGGGCTTCACACCCAGACATAGATTATAGATGGGAAGTGGGCCACATGGTGTCAGTGAGGCAAGTATGGGTCGTTTAGGGACAATGCACTGTCAGATCTTTGTTGACCATGATTAGAGAAACTCTGCATATTAGTAGTGAATTAATGTCAGGAATATCTGACAAATCCTGGAAAAGAAGATTGATGAGAGGAAATGTGTTCTGCCCAACTGTATAATGCATTTGAAGCTTAAAACAATGAATCAGTATTGATCTGGCCACAAAATATTAATGATTTGAATTAAAAAGAAAAGTTTAGAAAATGATAGCTTTGACAAATTAAGGTAGCATTTCATCCACACGATGGAGTGTGTTTTATTCAGTAATTGATTTAAAAATGGAATCAACCTAAGTGTCTAACAGGAGGGAGTTTTATAAATTGTTCACAGAACATCTGTTCCAAGGAGACCTTGATGTTCATAGATTTGTAAAGAATGCTGCTTACTAGCACACTGACTGCTCTGCAAATGTCTGAGGGTTCCTCCACTTGGGGCAAGTTGGGGGTTTGATCGCAGAGTAAATAAATGGTGCATTTTATAATGTAATATATTCTAGCAAGATGCAGCCCACAAACTGTATAGATACTCTTATGTACCACATAAAGTTCATCTACTACTTTAACCAGAACTTGATACTGTATGTATGTTTTTTTTTTTTAGATTTGGATAAAATGACAACTCATTGTTATTTCCAGTTCACAAAGTAATTGTGAGGCTGAATAAATTTTATTATTTTATAGACATATGTGTAAAATGAATTTTTCTATGAAACTCATTTTTGATGTATATTAGATGCTATTTTATATTCTGTAGTTTAATTATATGTACGCACACATAAACACACACTTCGGTGTCTTATTATGTTTCTGCAGTGAAACCAAAATCCTTCCTTCACGCCCTTTGATTTTATGTTTTCCTCAGGAAGGCAGGAGCTATTGTATATGATAAAATATTATGTTTTATTCAGTCCACTTATGAAATTGTTTAATATTGTTATAAATATTTATATGACTTATTTTAAATTTCCAAATAACATAGGTTACATGAAATTTGACAACTTTATTTTTTTCTTTTCACAACTATTTTGACTGTATACTCACCAAAAATCAAAATTTAGACAAAATTGACTTTTAGACTAATTCTCATTTTTTACATGTAAAAGACCACATGGGACTTTTAAGTCTAGGTTGCCCTGAGTCTACAGTCACTGAGGTTTTATGTCACTATGTCCTCCATTCTAATAATAGGATTTTCAGGCTTTATTCATGTCATTTTTATATCCTCATTAAGTTTTAAAATTTATTTACATGGGTCTACAAATTTATTTCAAATCGTAGTCATAATATTTGCCTGTTGTAAATAGACACTGATTTTGTGTGTTTGCTTTTTTTAAGGACTAATGTTGCTAAACAGGAAATATTGATTTCAGAATATTCATAATAGTTTTGCCCACTTTTTAAATATTCTTATTAGTATTGATAATTAGAATTGATTCCACTTTTTCAAGTTTACAGTCACGTCATCTGAGAATAACTACAGTTGCAGCTCTTTGACTCCATTTTTGTAGTCCCTCTCCTTTTCCCTCTTGTTTTGGTCCCACCTCAGGCATCATGTGCAGTGGTGAATGGCATCAGCCTCACCCAGCCTCCTTTTTCCAGCCTTACCTTTAGTGGAAATGGTTCTTTTGTTAACTGCTGAATATATTGTTGAGATTTTATTGATTAAGAAGAATTAGTCCCCACAATTTGGTATGATTTTTAAAGATTTTATATTATTTTTAAAGATTTAAATTATATGAAAATGTTTTTTCAAAGGTCTATTAATGTGATTTTTTTAATCTTTAAAATTACTTTGTGAAAATGATAGGTTTTCTAGTATGGAATTATCCTTTTATTATTGCAATAAACTCCACTTTACCATGCTCTGTCATTATTTAACCATACCAGTGATGGCCAGGTGGCCAAAATAAATAGCCAAATGGCTAAAATTGTATTGATGATTTTTGCAAATGTAAGTAAGGAAAATTGTTGGTTAAATTTGTAGTTATTGTTACATTCATGTTCATTTTGATTAGCATAATAAACTAATGAGGACAGGCTTATTTTTCTCCTTCAAAATAACTTAGGTTACAAAGGAACTAGAAGTGATTTCACATGTAAGAACTCTCACAAATCACTTTTACAGTTAAACTCTGATATATAACTTAAACATTAAAATTGGCTAATCAGATTTTTGTGCTGATTAATGAGGGAAAGTTTTTACTCTATTTTTGTGGAAAGTAATATACATATTCATGTTGGAATATAATTATTCCCATTTCTTAGATTTTAAATTACTACTTTTAAATAAATACAGTCTCTTTTATTAACCTGTGTTTTTTCTTTCCACCGTGGGTCTTTTCAGTTTCATGATTTTGCTCTCAAAACTTTTTAATTATTGATTTCTGTCAAATCTGTTCATTCATTACATTATTTTATTATTTATTAAATTGTTTTATCTTTTTAAGTCTTATTAATATGTACTGAATTTGTAACAATTTGGAAAGTCAAGTAACTCCTGTTTTATCTTTTTCTTGGTTTATGAGTGTTTTTAAAGTTTTACGTTTCTTGAAGATCACAGCTGTAGCCCCAATTCCATGGTTCTGGCTACTTACATTTATCATACTTATTAATATCATGAATGTAATTGGAATACCCCTTTGATTTTACTGGTGACGTATACCCACTAGTGTACTGAGACGGAAAAAAAAGTCTTTAGAACTCAGATAAATATACAGTTCATATTTACTATTTATGTATGTGTGATCTCGTTATTAAATTACTCTATCATGTTTGTGGAATTAGCAGTTTCTCTTTGAATTTGGATGTTTCTAGTTATGTGTATTTCCAACGTATGTTTTTAGCCACATACACTTTATTGAATATCATATTTGGTGTTTAATTTTTGCTAGGATTATAGGCTGGACTCCAGATCCAAACTTGACATGTAGCAGACCCATTAAAAACATACATTAAGCCCCTAGCACTGTTTTAATCTCCATGGCCTGGCTGAGCTTCTGCCATCTGTCTTCCTAGGCACCATGAGGTCTGGACATCTCATTTGGCATAGCTCAGCTGTGGCCATTGGTGGATCTCATCCTTAGTACTAGTCCCTGCTGGCAGGGGTGACCCAGGCCCACATAAGCCATTGCTGGCCTCCTTGGAGGACTTAGAGAATCCTGAGATTGCCCATGAGGATGGACATGCCTTTCAGTCTAGCACCCACCTTTAGTGATGCCTGTGGAGATTGAGAAGCTCACAGCGGCCTTGGATGTCTTTCTTATACCTCCATTGTCTGCAGCGTGACTCCCATACTCTTGAGCCAAGGTAGAGAATTTTTAGGAGGCTTGTGTGGAGGTTTATGGTGGCCCCCATGGTTCTGTGAGACTGGTAGAAAGCACAGACCCCTTAGACTTCTCCCCAAGGAGAATACGTGAGACTAGTGGAGGAAAGGAGAGTAATGAAATATGCATTTCGTGTCCCAGGCTATCAGAGCACAGCTCTAAGGAAAAATACAGGGCATCGTATAGCAACTGGCACAGCTCTGTGAGACTGGGAGATATTGCACAACCTTGAAAAATCAAGATGTGACCCTACTGAATGAACAAAATAAATCTCCAATAATTGACCATAAAGAAATACAGGTTTCTGGCTGGGTGCGGTGGCTCACACTTGTAATCACAGCACTTTGAGAGGCCGAGGTAGGCAGATCATTTGAGGCCAGGAGTTCAAAATCAGCTTTGCCAACATGGTGAAATACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAATTAGCTGGTCGTGGTGACGGGCACCTATAATCCCAGCTACTCAGGAGGCTGAGGCAGGAGAATCACTTGAATCCAGGAGGTGGAGGTTGCAGTGAGCTGGTATCGTGCCGTTGCACTACAGCCTGGGCAACACGAGTGAAACTCCGCTTTAAAAAAAAGAAAAAGAAATGGAGGTTTCTGATTTTCCTGATAAGAATTACAGGTAATTGCCTTAAAGGAGGTCAATGAGCTATGAGACAACACTGATAGACAAGTAAAATCTGGAAAAGGATACATGAACAACATGAGAATATCAACAAAGAAAAACCATAATAAAAGAATCAAATATAGATTCTGGGGCTGAAGAATACAGTAACTGAACTGGATCAATACAGGGCTTCAAGAGCTGACTTGATCAAGCAGAAGAAAGAACCAGTGAACTCAAAGACAGGTTATTTGAAATTATTCAATCAGAAGAGCAAGTAGAAAAAGAATTTTTTAAAAGTGAAGAAACTGTCTGTCTTTGCTAAAAATTGGAGGGTCCTAAGAACTCCTCCCCGCCCCCACTGCCAATGCAGAGTCTTACTCTGTCACCCAGGCTGGAGTGCAGTGGTTCGATCTCCGCTCACTGCAACCTCCACCTCCCAGGTTCAAGCGATTCTCATACCTCAGCCTCCCGAATAGCTGAGATTACAGGTGCCTGCCACCATGCCCAGCTAATTTTTGTACTTTTAGTAGAAACGGGGTTTTGGGGTTTCACCAAGTTGGCCAGGCTGGTTTTGAACTTCTGACCTCAGGTGATCCTCCTGCCTTGGCCTCCCAAAGTGCTGGGATTACAGGCGTGAGCCACCATGCCCGGCAAGAACTCCTTTTTATGTTAGATTCACTAGGGTTTAGCAGCTCACAGAACCCAGGAAAACAGTTTACTTAGCTGATTTATTACAAAGGACATTTTAAATATTACATATGAACAGCCAGCTAAAGAGTTACATACAGCAAGTTTTGGAAGCATCTTAGGTTTAGGAGGTCTGTCTCCAAGCAGTTGGGGGGTACCATTGTTTCAGCATATGGATGTGTTCTTCACCCACCCAGAAGCTCTAGGAATCCCATCATTCAGGGATTTTTATGTGGTGTTCATCAAGTAGGCATAATTGTTATTAACTCGATCTCCAGCCTCTGTCCCTTTCCCAAAGGATAGGGGGTGGGACTGTACGTTCCAAGCTTCTGATCAAGTCATGGTCTTTCAGGTGATCACCCCCCATCCTAGAGCCTAGTAATAATTGTCTCATTAGAACAGAAGACACTCTTATCACCTATGAAGTTCCAAGGCATTACGAGCTCTGTACTGGGAACCAGGGTCAAAGACCAAAAAGAACAAAAGCTTCTCCTAGCAACTCTGTTGCTTAGGAAATTACAAGGGTTTTGGGTGGCTCTGTGCCAGGAACTGGGGATGAAAACCAAACTATCTATTTCTTACAACTAACAATGTCACATACATGTTCAAGTTTTCATGTTCTTAGTGTCCTTTCATTTCAACTTGAGGAACTCCCTTTAGCATTTCTTGTAAGGTATGTCACTTGTAAAGTGTGTCTTTTAAGGAATCCACCATGATAAAATGAAATTTGAAGCTGCTTGGTAGATAAATTCATGCTACATTTATCTACAGGTCAGACTTGAGGGACTGGTATTTCTAGAAGCCTCACATGGAAGAGACAGAATCATTCAGTACAAGTGTATCCAGAGGACCAGCAGAAGGGAGAAGGAATGGAGGGAGGCTCCTGAGGGCTGAGATGCATGTGGAGAAAGCCTGCAAGCACACAAACCGAGAATAATTAAATCTGAGAAATTCCAGGATTTATCTGTAGGTGGAGCCACATCTCCATGATTCAGGGATTCTTAGGATTTGGAATCATAGAAGGAATTAAACATTTCAGAATTCCATGCGCTAGGTGGCATATGAAACTCCATGATTTTCACATTTCTAGGTCTAAAATAAAAATATTTATATCTTTATTAGCAGCAATAGTCATTTCTTCTGACCCTGGGAGAGGAGAGCCACCAACCCAACCCACCCCCTACCCACTGCATGTCCTTGTTGGTTGGACTGGGGCTAATAGCTTTGGGGCAGATGTTAGAAGCAAAACTGGAGTGTCATGGTTTTTTTGTTTTTGTTTTTGTTTTTGCTCAGATTTGTCTTCTTAGTGCTTGGATGGTGTGAGTGAAAACCCAGAGGAATACATTTGGTGGCTGAGCTAGTACAATGCCATCACCGGTGAGTGGGAAATTCTTCTTTCTACTGAAATTTGTACCCCTGTTACCAGCCTAAGGGCAGATTCATCCTATTAACATGGATGTTCTAAGTGCACTCAAGGATCCAAGCTCCAATTAAGATTCCCCAGGGCTTCGGAATGTTTACATTGGCTCAAAGAGTCATCAAGAAGTAATGTCCTTTCAACAGTACACTAAGGCATTCCAGCCTCTACTAAGGCTGTGTATTAAGATGTGAGAGGTTTTTGTTTCTCTCATCCAGTCTCAGGGAAATCATTCATTACGAGCCTCTCATGGCCTTGTTGGGGAAATAAATTCACTCATTACCTATGTTATTGGCAGGAGTGGGCTTGAGAGTATATGTGGGTAGGTGGTGAAAATAAGTGAGAGCAGGTTATAGCCCATACAAAGGCAAGCTCAGTTAGTCTAGTGTTTCAGGTGTTAGGGGAGGGCTGTTTAACTTGAAGGGAAAGCAGATAGGGTTAGGACAGAGGAGACAATGAGGAATTATTCATTTATTTTTCCTATCTCAAAATCTTAATGTCTTGAGAGAATAAATGTGAACTTTTGAAAAACTTAAAAAGCAAAATTAAAATTCTTATTACCCTTGTCCCCAAATTAACCTCTGATCAAATTTGATAACTGGAAGCAACTGGAGTGTTGTTTCTTTAATTTTGGTTGTGCATTAAGTGATGGAGTATAGGAAACAGAGTAAATTTAAAACTCTGAGGAAATTTTTGAAGTGGAGAGACCAGGACAATCAAAGGATTTTTTTTCCCCTAAATCTAGAGACAACATGAAGAAACAAAATAGAATAGTACCTAGTGCATTAGTCCATTTTCCCACCGCTATAAAAAACTACCTGATAGTGGGTAATTTATGAAGAAAAGAAGTTTAACTGACTGACAGTTCTGCAGGCTTAACAGGAAGCATGACTGGGAGGCCTCCAGAAACTTACAATCATGGTGGAAGGGGAAGCAAGCACCTTCTTCATAAGGCAGCAGGAGAGAGACCAAATCAGGAAATGCCACACACTGTTAAATCATCAGATCTTCTGAGATATTACTAGCATGAGAACAGCAAGGGGGAAGTTCACCCCCATGATTCAATCACCTCCCACCGGACCCCTCCCCCAACATGTGGGGATTACAATTCAAGATGAGATTTGGGTGGGGACACAGAGCCAAACTATATCACCTGGTGTTTGAAGATCCCACATAAAATTGAGAAAGGAAATCCTCAGACCATGGAAAGTGGCAGGATGAGACCATCTTTCAGTACTGAAGTCTTAGAGTCCCTGGCTTGTGCTGCTGAGCCATTCATCCTTATCCATTAACAGTGAACACCTGAGTTGTGTAGACATAAGAGGCTGCATCTGCTGATACCAAGTTCTATATGAAAGTTGTTCACACAACTGAGTGTTCTCAGTCATTTCATGAATAATGTATTTGTGGCTTGTATCTAAAAAGTGATAGATAGGAACCACTTTACATACTATCTCATTGGACCTTTTTGAACTCATAACAGGTCTTTATTTTATTCTGAGGACACTGAGGTCCTATAGTGGAATATCTAACTATAGTCTTGATTAAAACGTGACAAATTATGGATGCTGCCTCCCTTGTAGTGAGTCTATAGATTTTCTTGAAGGTGGTGGAGAGGAGAATTTTAGTTCTAAATTTCCAAGTACAGATTTCATAATTAGTATCTGTAAGTTATACTTTAGAAGTCTATTGGGAAATCTTCAGGTTATATTATGCCACACCACATGTGATATTTCTCTATGTGAAGTTTTATGTATGAGTAAATCTGAAAGCCAGATTCCCAGTTCAGATTTAAAGCAATGTGACAGGAACCCCAAACACTGTTTTGAGTTTTCTGTTCATACCACCCACACTTCCTTAGTACAGTCACTTTGATCTTGCTCCACTGAACATTGGCAGAGATAGCCCTGTTTGCAGTAGAATGTCCATAATGTTTTAGGATTCCATGACCTTCGAGGATATCATTGTAGACTTCACTCAAGAAGAGTGGGCCCTGCTGGACACATCCCAGAGAAAGCTGTTTCAAGATGTGATGTTGGAGAACATCAGTCATCTGGTCTCTATTGGTGAGTCTCTTTATATTTATTATGTATGTATATACGGATTCATTCACTCACTCATTTTTCACTGATTCATTCTTTCATTCTACACGTGCTTAGAACAGCTTTCTCATCTATCACTTCAACTTCTGCTTTGATCCTTTCATAACTCTCACAATTACCTGACAGCCATTTCTTTCCTTTTCACTTATATTGATTTGTCCTCTCTCTAGAAAGTCATCTTTCTGACCACAGTTTCACATCCTTCTTGCTCTTTAATCTCCCAAACTCAGAAAAGTTATGGTAATTCACTGCTTTGGTATGCATAAATAAATGTATTGATTTCTTTAAAGTAATTATTCTATCATAGGGACTGTTCTGCACAGAACCTAGATTGTTCTGGTGGAGCTAATATTTATTGCATAGTTTTTTAATATAATGTCAAATACTATGACAATTTGTAATTTCTCACTAAGTGAAAACACTGAGGATTCTGAAATCAGTATTTGAAGTGAGGCATGGCCATCAGCAATTATAGGTCTTTTATGTCTGGGAACAAGTTCAAGAGTTTTCATTTTGCTCGTGAAGGACTGTCAATGTTGTCTTCAAGGTACTCTTCCCAGGCTGACCTTCAGTGGCTAACTTATCCTTCCCAGTAGGCTGCCCTGTATCTGATAACCTTGTACATTTGTCAGCACAGAACTCAAAATCCATGTATCTTTTTCCCCAAAACAGGCAAACAGCTCTGCAAATCAGTTGTGCTTTCCCAATTGGAGCAAGTAGAGAAACTTTCAACACAAAGAATAAGCTTACTGCAAGGTGAGCTCTAAGAAGCAGTGCTTCAATAGGAGGAGGAGAAACATGGCCAGTGAGTGAGTAGGACCCAACAGTTGCCAAAGGAAGATTTCTTTTGTTTTTTTAGACAGAATCTCACTCTGTCACCCAGGCTGGAGTGCAGTGGCGTGATCTCGGCTCACTGCAACCTCTGCTTCCCAGATTCAAGTGATTCTCTTGCCTCAGCCTCCCGAGTAGCTAGGACTACAGGTGTGCGCCACCATGCCCAGCTAATTTTTTTCTATTTTTAATAGAGACAGGGTTTCAACATGTTGGCCAGGCTGGTCTTGAACTCCTGACCTCAAGAAATCCACCCACCTCAGCCTCCCAGAGTGCTGGGATTACAGTCATGAACCACCACGCCCAGCCGGAAGGTTTCTTAAATTTGCAGTGTTTCTGAAATGTAGGCAAAAACCTGAGGGAAACATTTCTCAGATATTGTCATTATACTTTGTAGGTATCAATTTTTATTCAAGTATCTCTCTGTCATTGTCTTTGTCTTTTGTAAAGGGGATATTTGTGTACTTATTTGAGTTAAACTATTACATACTAGCCCTTTATAATGGTCCTCTTCTTTGAAAATTTTTCTTTCCTTCCTCGACTTGCCTTTATTTTTTTATATGCTGAAAATGTCAGTAGTCAATGTGCTATAATACTCTTCTCCTTAAAGTATGGTTAATTTAACATTCTTTCCCTGTCTGTGTGTATTTGAAACACACTCAAATGGGCTTTGGAGCTATTTAACATTTTTATTCCCCTAATGCCTATATAGCATCTTTTTTTTTTCATTTATTTCAGGTAGAGAAGTTGGCATTAAACATCAAGAGATACCATTCATTCAACATATCTATCAGAAGGGCACGTCCACCATCAGCACAATGGTAAGCTTTATGGATGCAAACCCTGTTCTTACATATAGAAACCTGGACATTAAACAACTTTGGAATTTGGTACAGGTACCTGACTGTACTTAAAGCCCTCCCAGCAGTTTTAGATAGTTTGGATTTAGTGAAGACGTTAACTTCAAATCAAAACCATAATATGAGGCCTTATGACAGGACAATTGTACAAACTTGACTACGTGCTGAAACTTTCAAACATGATAAAGTCTTAATAACTAGTTAGACAGCTCTTCAGTTGGGATGCTACAACAGGAAAACTCTCTACATGCAGTTAGATAATATACTACGTTTGTATAACTGATATAGGAACAATTGTAACTGGAGTCTACCACTGAATGATTATTCTAGAATTAATATGTAGAGAAATGAATGAAGTAATGAATGAGTGTGGATAAACCTTTAATAGTCTTTCATTTCATTCCCAAAACCAGAGATCTCATACTCAAGAGGATCCTTTTCTATGCAATGACTTAGGAGAAGATTTCACTCAACATATAGCATTGACTCAAAATGTGATTACCTACATGAGAACGAAACACTTTGTAAGCAAAAAGTTTGGGAAAATCTTCAGTGACTGGTTATCCTTTAATCAACACAAGGAAATTCACACCAAATGTAAATCATATGGAAGTCATCTATTTGATTATGCCTTTATCCAAAACTCTGCCCTTAGACCACACAGTGTGACTCACACTAGAGAGATAACATTGGAATGTCGTGTGTGTGGGAAAACCTTTAGCAAAAATTCTAATCTTAGGCGACATGAGATGATTCACACTGGAGAGAAACCACACGGATGTCATCTATGTGGGAAAGCCTTTACTCATTGCTCTGATCTTCGAAAACATGAGAGAACTCACACTGGAGAGAAGCCATATGGATGTCATCTATGTGGGAAAGCCTTCAGTAAAAGTTCTAACCTTAGACGACATGAGATGATTCACACTAGAGAAAAAGCACAGATATGCCATCTATGTGGGAAAGCCTTCACTCATTGCTCTGACCTTAGAAAACATGAGAGAACTCACTTAGGAGATAAACCATATGGATGTCTCCTATGTGGGAAGGCTTTCAGTAAATGTTCTTACCTTAGACAACATGAAAGAACTCACAATGGAGAGAAACCATATGAATGTCATCTATGTGGAAAAGCCTTCTCTCATTGTTCTCACCTTAGACAACATGAGCGAAGTCACAATGGAGAGAAACCACATGGATGTCATCTATGTGGGAAAGCATTCACTGAATCTTCTGTGCTTAAACGACATGAGAGAATTCACACTGGAGAGAAACCATATGAGTGCCATGTATGTGGGAAAGCCTTCACTGAATCTTCTGACCTCAGACGACATGAGAGAACTCACACTGGAGAAAAACCATATGAATGCCATCTATGCGGAAAAGCCTTCAATCACTCTTCTGTCCTTAGACGACATGAGAGAACTCACACTGGAGAGAAACCATATGAATGCAATATATGTGGTAAAGCCTTCAATAGAAGTTACAACTTTAGACTTCATAGAAGAGTTCACACTGGAGAGAAACCATATGTATGTCCTCTATGTGGGAAAGCCTTTAGTAAATTTTTTAACCTTAGACAACATGAGAGAACTCACACTAAAAAAGCAATGAATATGTAAGAATCATCAGCTGTAGCGTTAACACTAAATACACCAAGGACAAACATACTACAGGAATATTATGTCTGTAATCAGTGTGGAAAAGCCTTTATTTATATTTACCACTTTGCTCAACCTAAATGAATTCAAGGTAGAGAGAATCCAGATGTATTTAATGTTTATGGCACAAACTTCAGACTCTAGGCTGACCATATACAACGTGAGAGAATGAAACTATAGATCAAAGGAATGTGGAGGAGTCTTCATCCACAGCTCTGTTAAATAAATGGGAGAAATCACATCACGAAAATTCTGTGCCTGTCGTCAGTGTGAAAATGCCTTTGCTGATAATTTATCCTCTAAACAAATGAGTAAAATCCACAGGCAAGCAACCATATGTCTGTAATTGCTGTGCACTCTCATTCAGCTAAGCACCAATTTTGGTGTGTGCAAGAAAATTCATTATAAGGTAACTGATAAAAACAGGAAATATGTGAAAATATTTTTTATTAGGTGGATGAGGCCTCTTGAACAATTCCAGAAATTCATAGTGGAGAAGTTATTCAATGAAAACTCATGAGAAATCCTTTTCTTAATACAGCAGCACTTCTATAATAGATCAGAATTCACATGGTGTAGAACTCTCAATGACATGAATGGAGGGTAGTCCTCAGTAAATTACTCATTCCTTAGTCAATACTAGCATTTTTCCAGTGAGAAAACTATCTTGACAGGATAGTGGAAAAACCTTCAGGCAGCTTTTATGTCAAAAAAGTGAGACAGGGATGAAAACTCTAAAAAGCCATTGATGAGATGTATAGCTGGGGGACAAAACATAAAGCCATCAAGCACGTGCTTGAGAAAAAAATTATAATTTTGAATAAAGACTTTCTACTTAAAATATGTGGGTTGAAATGTACAATTCTGAAATAACCTGGGAATATTGAATGCAGAATTATGTAAGAAGTAATAAGATTAAATTAGTACTGTCAAAAATACAAGCATTAAGTGTTGTTGCTGAATAATCTAATAGGTTTATTAAAATCTGTGTTTTTTGTTTTTTGTTTTGAGACAGGGTCTCGCTCTGTAACCCAGGCTGGAGTGCAGTGGCGCAGTCTCAGCTCAATGCAAGCTCTGCCTCCTTGGTTCATGCCATTCTCCTGCCACAGCCTCCCGATTAGCTGGGACTACAGGGACCCACCACCACACCAGGCTAATTTTTTGTATTTTTAGTAGAGACAGGGTTTCACTGTGTTAGCCAGGATGATCTTGATCTCCTGACCTCGTGATCTGCCTGCCTCAGCCTCCCAAAGTGCTGGGATTACAGGCATGAGCCACCGCGCCCGGCCCAAACTCTATGTTTTTAATTCAGTTTTAAACACATAGATTTGGGTCAGTTAGAAAATGCGGATGGGCATGGCGGGTCACACCTGTAATCCCAGCACTTTGGGAAGCTGATATTGGTGGATCACTTGAGGTCAGGAATTCGACAACAGCCTGGCCAACGTGGTGAAACCCCATCCCTACTAAAAATACAAAATTAGTTGGGCATGATGGTGTATGCCTGTAGTCCTAGCTATTCAGGAGGCTGAGGCAGGAGAATCACTTGAACCCAGGAGATGGAGGTTGCAGTGAGCCAAGATCATGCTACTGCGCTCCAGCCTGGGCAACAGAGTGAGACTCTGGCTCAAAACAAAAAGACAGTGACATTCAATGGAACTAATACACATAGAACACAAAATTATAGGTCCTAACTATAGTAGTGGTATATATGTACATGGTAATGATTAAGTCAAACATGGATTATGAAAGACTCACTTTAAAAGTACAGTCTTATGGTGCTTAAATTTGCCTTTTTGTTTTTAAACCACTTTATCAAAGTGTAATTGACAAAAGCTGTTACTTAATGTATACAACTTAATAAGTTTTGAGATAAGGATAAGCCCAGGAAACCATCACCACCACCATCTGTGCCACAAACATTCATTCTCTCCAAAATTTCCTTCCCTCATTTTTCATTGTTCTCTTTGTGATAAAACCACTTACATCACAGCAACCTGTAGCAAATTTTTAAGTATATAATACAGTATTGATAAGTATAGGCAATATATTATATGATTTAACATTGCAAAAATAAAACTAATTACAAATGAATCTATTTAAATATAATTTGGCAGTGCTGGATAATTGTGGTTACATTTGCAAGAATGTCTCCCAGAATCAGGTATGAGCATCATAACATAGAGATTTTTGTTGCCATGGGCTTTTTTTCTTTAAGAACCTTTCTGTTCTGTGTGTAAATGTTTAATATTCTCACTTCTCACAAGGGCTATTTATGGAATCTTAGCTTATATATTCCTCTCTAGCCTCTAAAGCTTACACTTTAAATTAATCTGTTTTTTTTTTCTTTTTTTGTTTCATCTTTATTCACTCCATCCTACCCAGAAGCAGAAACCCCACTATTTTGCACAAAACAAAAATGTCAGCTTATTTTTCCTCTGCCTAGACAGGCCATCTTTCTTCTGGGACCTTATGTTCCCTTCATGTTAATTTTCAAGTGCTTGAGAAAATCCAGTGTGATACTTCATTGACTCTCCCCTTTCTCATGAATTCTACCTCAGAAAATCCTGTCCGAACAGGCTACCCTCATGCCTAAAGCAGCTGTTTCATGTATTTCGTTTAAGTTTTGTTACTGTTAATGGTGGGTTGGTCCAATAACATCCACAGTCATGCTGGGAACAAAAATTTTTTACTCAAATATTTTAAGCCAAATAATGGTTATTCTATTTTTATGGGTGAAATAATTAAATCAGAATTTTCACAATAATGACTATTTCTATACGAAAAAGTTCTCCACTGTTCACAGCTTAACATCACATTAAATCCATTGGTGTCAGCTGCCTCATTTACCACATGCGACCATAAGGCCCGGCTCTTTTGGCCTGTGACAGAAGTCAGTGTATTTTCTCCCTGTGCCACATGTGTCCCTGCTCCCAGTC\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "ename": "AssertionError",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAssertionError\u001b[0m                            Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[42], line 12\u001b[0m\n\u001b[1;32m      9\u001b[0m dataset_labels \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marray(dataset_file[\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtranscript_\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mtranscript_idx\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m'\u001b[39m][\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlabels\u001b[39m\u001b[38;5;124m\"\u001b[39m])\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28mprint\u001b[39m(dataset_seq_atcg)\n\u001b[0;32m---> 12\u001b[0m \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[1;32m     14\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mno_grad():\n\u001b[1;32m     15\u001b[0m     gene_pred_forward \u001b[38;5;241m=\u001b[39m model\u001b[38;5;241m.\u001b[39mforward(\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mprepare_sequence_forward(dataset_seq_atcg, tokenizer, np\u001b[38;5;241m.\u001b[39mconcatenate((np\u001b[38;5;241m.\u001b[39marray([\u001b[38;5;241m24\u001b[39m]), dataset_labels), axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m)))\n",
      "\u001b[0;31mAssertionError\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import h5py\n",
    "from tqdm import tqdm\n",
    "dataset_file = h5py.File('/home/jovyan/shares/SR003.nfs2/decoder_dataset_2k_correct/gena_decoder_human_val_intergenic_2k.hdf5', \"r\")\n",
    "\n",
    "all_preds, all_targets = [], []\n",
    "for transcript_idx in tqdm(range(len(dataset_file))):\n",
    "    print(np.array(dataset_file[f'transcript_{transcript_idx}'][\"coordinates\"]))\n",
    "    dataset_seq_atcg = tokenizer.decode(np.array(dataset_file[f'transcript_{transcript_idx}'][\"token_atcg\"]))\n",
    "    dataset_labels = np.array(dataset_file[f'transcript_{transcript_idx}'][\"labels\"])\n",
    "\n",
    "    print(dataset_seq_atcg)\n",
    "    assert False\n",
    "\n",
    "    with torch.no_grad():\n",
    "        gene_pred_forward = model.forward(**prepare_sequence_forward(dataset_seq_atcg, tokenizer, np.concatenate((np.array([24]), dataset_labels), axis=0)))\n",
    "    gene_pred_forward_processed = torch.argmax(gene_pred_forward['logits'], axis=-1)[0, 1:].detach().cpu().numpy()\n",
    "\n",
    "    all_preds.append(gene_pred_forward_processed)\n",
    "    all_targets.append(dataset_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "3 in all_targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "label_dict = {0: 'CDS-0', 1:'CDS-1', 2:'CDS-2', 4:'intron-0', 5:'intron-1', 6:'intron-2', 7:'ASS-0', 8:'ASS-1', 9:'ASS-2', 10:'DSS-0', 11:'DSS-1', 12:'DSS-2', 13:'START', 14:'STOP', 15:'nc_exon_plus', 16:'nc_exon_minu', 17:'nc_intron_plus', 18:'nc_intron_minus', 19:'nc_ASS', 20:'nc_DSS', 21:'TSS' , 22:'PolyA', 23:'IR'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABjQAAAa8CAYAAAC8/nInAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdeVhUZf/H8c8MKKCyo+IKKooroqbivmduuZWZ+5ZrLuljZrmlqWVq7pZauWdZar+yXFLbXUrFfU8zU1FAcAERhd8f6OAEKNQMM03v13Wd64oz9znz/XDPw4N8z32OITk5OVkAAAAAAAAAAAB2zGjrAgAAAAAAAAAAAB6HhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAACQjU6dOqUnn3xSnp6eMhgM2rBhg0XPf+7cORkMBi1dutSi5/03q1+/vurXr2/rMgAAAAD8QzQ0AAAA8J9z5swZ9evXT8WLF5erq6s8PDxUq1YtzZ49W/Hx8VZ97+7du+vQoUOaPHmyVqxYoSeeeMKq75edevToIYPBIA8Pj3S/j6dOnZLBYJDBYND06dOzfP6LFy9qwoQJCg8Pt0C1AAAAAP5tnG1dAAAAAJCdNm7cqGeffVYuLi7q1q2bypcvrzt37ujHH3/UyJEjdeTIES1atMgq7x0fH6+dO3fqtdde04svvmiV9wgICFB8fLxy5MhhlfM/jrOzs+Li4vTFF1+oQ4cOZq+tWrVKrq6uun379t8698WLF/X6668rMDBQoaGhmT5uy5Ytf+v9AAAAANgXGhoAAAD4zzh79qw6duyogIAAbd++XQUKFDC9NmjQIJ0+fVobN2602vtfvXpVkuTl5WW19zAYDHJ1dbXa+R/HxcVFtWrV0kcffZSmobF69Wq1aNFCn332WbbUEhcXp1y5cilnzpzZ8n4AAAAArItbTgEAAOA/Y9q0abp586bef/99s2bGA0FBQRo6dKjp67t372rSpEkqUaKEXFxcFBgYqFdffVUJCQlmxwUGBqply5b68ccfVa1aNbm6uqp48eJavny5acyECRMUEBAgSRo5cqQMBoMCAwMlpdyq6cF/P2zChAkyGAxm+7Zu3aratWvLy8tLefLkUXBwsF599VXT6xk9Q2P79u2qU6eOcufOLS8vL7Vu3VrHjh1L9/1Onz6tHj16yMvLS56enurZs6fi4uIy/sb+RadOnfT1118rJibGtO+XX37RqVOn1KlTpzTjo6Oj9b///U8VKlRQnjx55OHhoWbNmunAgQOmMd9++62qVq0qSerZs6fp1lUPctavX1/ly5fX3r17VbduXeXKlcv0ffnrMzS6d+8uV1fXNPmbNm0qb29vXbx4MdNZAQAAAGQfGhoAAAD4z/jiiy9UvHhx1axZM1Pj+/Tpo3Hjxqly5cp65513VK9ePU2dOlUdO3ZMM/b06dN65pln1KRJE82YMUPe3t7q0aOHjhw5Iklq166d3nnnHUnS888/rxUrVmjWrFlZqv/IkSNq2bKlEhISNHHiRM2YMUNPP/20fvrpp0ce980336hp06a6cuWKJkyYoOHDh+vnn39WrVq1dO7cuTTjO3TooBs3bmjq1Knq0KGDli5dqtdffz3TdbZr104Gg0Hr1q0z7Vu9erVKly6typUrpxn/22+/acOGDWrZsqVmzpypkSNH6tChQ6pXr56puVCmTBlNnDhRktS3b1+tWLFCK1asUN26dU3niYqKUrNmzRQaGqpZs2apQYMG6dY3e/Zs5c2bV927d9e9e/ckSe+99562bNmiuXPnqmDBgpnOCgAAACD7cMspAAAA/Cdcv35df/75p1q3bp2p8QcOHNCyZcvUp08fLV68WJI0cOBA5cuXT9OnT9eOHTvM/mB+4sQJff/996pTp46klKZAkSJF9OGHH2r69OkKCQmRh4eHXnrpJVWuXFldunTJcoatW7fqzp07+vrrr+Xn55fp40aOHCkfHx/t3LlTPj4+kqQ2bdqoUqVKGj9+vJYtW2Y2vlKlSnr//fdNX0dFRen999/XW2+9lan3c3d3V8uWLbV69Wr16tVLSUlJWrNmjQYMGJDu+AoVKujkyZMyGlOvt+ratatKly6t999/X2PHjlX+/PnVrFkzjRs3TjVq1Ej3+3f58mW9++676tev3yPr8/Ly0vvvv6+mTZvqzTffVKdOnfS///1Pbdq0+VvzAgAAACB7sEIDAAAA/wnXr1+XlPLH9sz46quvJEnDhw832z9ixAhJSvOsjbJly5qaGZKUN29eBQcH67fffvvbNf/Vg2dvfP7550pKSsrUMZcuXVJ4eLh69OhhamZIUkhIiJo0aWLK+bD+/fubfV2nTh1FRUWZvoeZ0alTJ3377be6fPmytm/frsuXL6d7uykp5bkbD5oZ9+7dU1RUlOl2Wvv27cv0e7q4uKhnz56ZGvvkk0+qX79+mjhxotq1aydXV1e99957mX4vAAAAANmPhgYAAAD+Ezw8PCRJN27cyNT433//XUajUUFBQWb7/f395eXlpd9//91sf9GiRdOcw9vbW9euXfubFaf13HPPqVatWurTp4/y58+vjh076pNPPnlkc+NBncHBwWleK1OmjCIjI3Xr1i2z/X/N4u3tLUlZytK8eXO5u7vr448/1qpVq1S1atU038sHkpKS9M4776hkyZJycXGRn5+f8ubNq4MHDyo2NjbT71moUKEsPQB8+vTp8vHxUXh4uObMmaN8+fJl+lgAAAAA2Y+GBgAAAP4TPDw8VLBgQR0+fDhLx/31odwZcXJySnd/cnLy336PB893eMDNzU3ff/+9vvnmG3Xt2lUHDx7Uc889pyZNmqQZ+0/8kywPuLi4qF27dlq2bJnWr1+f4eoMSZoyZYqGDx+uunXrauXKldq8ebO2bt2qcuXKZXolipTy/cmK/fv368qVK5KkQ4cOZelYAAAAANmPhgYAAAD+M1q2bKkzZ85o586djx0bEBCgpKQknTp1ymx/RESEYmJiFBAQYLG6vL29FRMTk2b/X1eBSJLRaFSjRo00c+ZMHT16VJMnT9b27du1Y8eOdM/9oM4TJ06kee348ePy8/NT7ty5/1mADHTq1En79+/XjRs30n2Q+gOffvqpGjRooPfff18dO3bUk08+qcaNG6f5nmS2uZQZt27dUs+ePVW2bFn17dtX06ZN0y+//GKx8wMAAACwPBoaAAAA+M94+eWXlTt3bvXp00cRERFpXj9z5oxmz54tKeWWSZI0a9YsszEzZ86UJLVo0cJidZUoUUKxsbE6ePCgad+lS5e0fv16s3HR0dFpjg0NDZUkJSQkpHvuAgUKKDQ0VMuWLTNrEBw+fFhbtmwx5bSGBg0aaNKkSZo3b578/f0zHOfk5JRm9cfatWv1559/mu170HhJr/mTVaNGjdL58+e1bNkyzZw5U4GBgerevXuG30cAAAAAtuds6wIAAACA7FKiRAmtXr1azz33nMqUKaNu3bqpfPnyunPnjn7++WetXbtWPXr0kCRVrFhR3bt316JFixQTE6N69eppz549WrZsmdq0aaMGDRpYrK6OHTtq1KhRatu2rYYMGaK4uDgtXLhQpUqVMnso9sSJE/X999+rRYsWCggI0JUrV7RgwQIVLlxYtWvXzvD8b7/9tpo1a6YaNWqod+/eio+P19y5c+Xp6akJEyZYLMdfGY1GjRkz5rHjWrZsqYkTJ6pnz56qWbOmDh06pFWrVql48eJm40qUKCEvLy+9++67cnd3V+7cuVW9enUVK1YsS3Vt375dCxYs0Pjx41W5cmVJ0ocffqj69etr7NixmjZtWpbOBwAAACB7sEIDAAAA/ylPP/20Dh48qGeeeUaff/65Bg0apFdeeUXnzp3TjBkzNGfOHNPYJUuW6PXXX9cvv/yiYcOGafv27Ro9erTWrFlj0Zp8fX21fv165cqVSy+//LKWLVumqVOnqlWrVmlqL1q0qD744AMNGjRI8+fPV926dbV9+3Z5enpmeP7GjRtr06ZN8vX11bhx4zR9+nSFhYXpp59+ynIzwBpeffVVjRgxQps3b9bQoUO1b98+bdy4UUWKFDEblyNHDi1btkxOTk7q37+/nn/+eX333XdZeq8bN26oV69eqlSpkl577TXT/jp16mjo0KGaMWOGdu3aZZFcAAAAACzLkJyVJ/sBAAAAAAAAAADYACs0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAgEz7/vvv1apVKxUsWFAGg0EbNmx47DHffvutKleuLBcXFwUFBWnp0qVZfl8aGgAAAAAAAAAAINNu3bqlihUrav78+Zkaf/bsWbVo0UINGjRQeHi4hg0bpj59+mjz5s1Zel9DcnJy8t8pGAAAAAAAAAAAOIaEhAQlJCSY7XNxcZGLi8sjjzMYDFq/fr3atGmT4ZhRo0Zp48aNOnz4sGlfx44dFRMTo02bNmW6RudMjwT+ptt3bV2B5a0/9KetS7CKthUK2boEwGHFJdyzdQlWkcvFydYlAA7r3NU4W5dgceuOXrJ1CVYxvF4JW5cAAAAcnCt/xc0yt0ov2rqEf51Rrf30+uuvm+0bP368JkyY8I/PvXPnTjVu3NhsX9OmTTVs2LAsnYf/KQAAAAAAAAAA8B83evRoDR8+3Gzf41ZnZNbly5eVP39+s3358+fX9evXFR8fLzc3t0ydh4YGAAAAAAAAAAD/cZm5vZSt8VBwAAAAAAAAAABgNf7+/oqIiDDbFxERIQ8Pj0yvzpBoaAAAAAAAAAAAACuqUaOGtm3bZrZv69atqlGjRpbOQ0MDAAAAAAAAAABk2s2bNxUeHq7w8HBJ0tmzZxUeHq7z589LSnkeR7du3Uzj+/fvr99++00vv/yyjh8/rgULFuiTTz7RSy+9lKX35RkaAAAAAAAAAADHYuBafmv69ddf1aBBA9PXDx4m3r17dy1dulSXLl0yNTckqVixYtq4caNeeuklzZ49W4ULF9aSJUvUtGnTLL0vDQ0AAAAAAAAAAJBp9evXV3JycoavL126NN1j9u/f/4/elzYVAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnbOsCAAAAAAAAAACwKIPB1hXAClihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuOdu6AAAAAAAAAAAALMrAtfyOiFkFAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPecbV0AAAAAAAAAAAAWZTDYugJYASs0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaNixy5cva/DgwSpevLhcXFxUpEgRtWrVStu2bZMkBQYGymAwyGAwyM3NTYGBgerQoYO2b9+e5lzr169XWFiYPD095e7urnLlymnYsGGPrWHt2rUqXbq0XF1dVaFCBX311VeWjpmhNatXqVmThqpaqYI6d3xWhw4efOT4LZu/VuuWT6lqpQpq36aVfvj+O7PXk5OTNX/ubDWqV1vVKoeob+8e+v33c1ZMkL49mzfonRef16SuTbX4tYG6cPpYhmOP7vle773aX1N7tdLk7s21cNQLOvD9FrMx6xe8pQkdG5ptK6aOsnaMNBx1vsiVgly2zfXpx6vVtkVj1QsLVe9uz+nI4Ufn2rZ1k55r10L1wkLVuUNr/fyjea5J419VjcplzbZhg/paM0IajjpX5EpBLtvm2rj+Y73wXHM906S6/jegq04eO5zh2PNnz+jNcSP0wnPN1bp+Jf3f2lXpjou6ekUz33hNXZ6ur2efDNOQns/q1PEj1oqQruPffaFPx/TQiiGttXHaMF09dyJTx5399TstG9hc29+dmOGYnavnatnA5jq6fYOFqs08R/0ckisFuchlaY6YSSLXA+QiF4DHo6Fhp86dO6cqVapo+/btevvtt3Xo0CFt2rRJDRo00KBBg0zjJk6cqEuXLunEiRNavny5vLy81LhxY02ePNk0Ztu2bXruuefUvn177dmzR3v37tXkyZOVmJj4yBp+/vlnPf/88+rdu7f279+vNm3aqE2bNjp8OON/FFvKpq+/0vRpU9Vv4CCtWbtewcGlNaBfb0VFRaU7Pnz/Pr0ycoTatntGH3+6QQ0aNtKwwYN06tRJ05gP31+sj1at0JjxE7Tyo0/k5uamAX17KyEhwep5Hjj88w5tXrFQ9Z/ppn5T31P+gBJaOXWUbsZeS3e8W24P1W3TWX0mzdOAtxarUr2ntOHdaTp94BezcUEVq2nEu5+atmcGj8mOOCaOOl/kSkEu2+b6ZvPXmjPzLfXuO1BLV3+qkiVL66VBfRUdnX6ugwf2a/yrI9WqdTstW/2Z6tZvpFHDB+vM6VNm48Jq1taXW74zbROnvp0dcSQ57lyRKwW5bJvrh+2b9cGCGXquRz/NXLxaxUqU0oSRAxVzLTrd8QkJt5W/QGF17TtE3j5+6Y65eeO6Xnmxh5ycnTXurXmat+wz9Rw4XHncPawZxczZX7/TL58tVsUWndRq9Fx5Fyqub+aOVfyNmEcedzMqQr+uW6J8QeUyHPN7+M+6eu6E3Dx9LVz14znq55BcKchFLjJlDrlSkItcADKHhoadGjhwoAwGg/bs2aP27durVKlSKleunIYPH65du3aZxrm7u8vf319FixZV3bp1tWjRIo0dO1bjxo3TiRMpV6198cUXqlWrlkaOHKng4GCVKlVKbdq00fz58x9Zw+zZs/XUU09p5MiRKlOmjCZNmqTKlStr3rx5Vs0uSSuWfah2z3RQm7btVSIoSGPGvy5XV1dtWPdZuuNXrVyumrXrqEevPipeooReHDJMZcqW1ZrVKyWldMVXrViuF/oNUIOGjVUquLTemDpNV69c0fZt31g9zwM7N65V5YbNVal+M+UrHKiWfV5Sjpwu2v/t1+mOL1YuVGWq1VHeQgHy8S+ksObtlb9ocZ0/fshsnFOOHHL38jFtbnncsyOOiaPOF7nIZQ+5Plq1VE+3fVYtW7dTseJBevm18XJxddWXn69Ld/wnq1eoeo3a6tK9twKLl1C/gUMUXLqsPv3Y/KrrnDlzytcvr2nz8PDMjjiSHHeuyEUue8j1+dqVerJFOzVu1lpFA0towPDX5OLqqm++2pDu+JKly6nngJdUt9FTypEjR7pjPlv9ofzy+WvoK6+rVJnyyl+gkCpVraEChYpYMYm5o9vXq2Stp1SyxpPyKlBUNZ5/UU45XXT65y0ZHpOUdE/ffzhNoS26yN2vQLpjbsVEas8nC1Wnx0gZnZysVX6GHPVzSC5ykYtM5CIXuewj13+ewciW1e1f4N9R5X9MdHS0Nm3apEGDBil37txpXvfy8nrk8UOHDlVycrI+//xzSZK/v7+OHDmS5ZUVO3fuVOPGjc32NW3aVDt37szSebIq8c4dHTt6RGE1apr2GY1GhYXV1MED+9M95mB4uMLCapjtq1mrtg6Gh0uS/rxwQZGRV1U9LPWc7u7uqhBSMcNzWtrdu4m6ePakileoYtpnNBpVvEIVXTh59LHHJycn67dD+xR16YICyoSYvXbuaLim9W2nuS9105dL3lHcjViL158RR50vcqUilw1zJd7RiWNHVbV6mGmf0WhU1eo1dPhgeLrHHD4UrqrVzXNVr1FLhw8eMNu379df1LxRbT3XtrmmTXldsTExli4/XQ47V+QyIZctf2Yk6syJY6pYpbppn9FoVMUq1XXi6KNvmfAoe37+TiWCy+qt8SPVrU1DDevTUVu+TL+pag337iYq6vxpFQwONe0zGI0qWDpUV88ez/C4g199JFd3L5Ws1TTd15OTkvTj0ukq17i9vAsGWLrsx3LYzyG5TMhFLktyxEwSuR5GLnIByBxnWxeAtE6fPq3k5GSVLl36bx3v4+OjfPny6dy5c5KkwYMH64cfflCFChUUEBCgsLAwPfnkk+rcubNcXFwyPM/ly5eVP39+s3358+fX5cuXMzwmISEhzdK5ZCeXR77PX12LuaZ79+7J19d82b+vr6/Onv0t3WMiIyPl6+uXZnxkVOT916+m7PNLe87IyMhM1/ZPxF2PVXJSkvJ4epvtz+3prcg/z2d43O24m5oxoIPu3U2UwWhUi17DVCLkCdPrQaFVVaZabXnnK6DoiIvatuZ9rXzzFfWZNE9Go/WvNHTU+SJXKnLZLldMTIzu3bsnn7/cBsbHx1e/n0s/V1RkpHz+8n3w8fVTVFRqzWE1a6t+w8YqULCw/rxwXu/Om6WXBvfT4qWr5WTlK5Qdda7IlYpctst1PfaakpLuycvHx2y/l7evLpw/97fPG3HxT236fK1ad+iiZ7v01qnjR7R4zjQ5Ozur4VNP/8OqHy/h5nUlJyXJ1cP8dyhXdy/FRvyRfs2nj+jUz5vV6tWMVxYf3rJWBqOTyjRobdF6M8tRP4fkSkUuclmSI2aSyPUwcpELQOawQsMOJScnW+QcBoNBkpQ7d25t3LhRp0+f1pgxY5QnTx6NGDFC1apVU1xcnM6fP688efKYtilTpvzt9506dao8PT3NtrffmvqP8/yX5XTNpf5vLdYLkxeq0XO9tXnFAp09Em56vULNhir9RC3lL1pcZarWVqeXJ+vimRM6d+RAxicF8J/WpGlz1anXUEElS6leg8aaPnuhjh05pH2/7rF1aQDsUHJykoqXKq2uLwxW8ZKl1bRVezVp2Vab/u9TW5eWrsTbcfpx2XTV6DxErnnSv51e1PlTOvrt/6l2t+Gm35kBAAAA2D8aGnaoZMmSMhgMOn484yX0jxIVFaWrV6+qWLFiZvtLlCihPn36aMmSJdq3b5+OHj2qjz/+WAULFlR4eLhp69+/v6SUW1VFRESYnSMiIkL+/v4Zvvfo0aMVGxtrto0cNTpL9Xt7ecvJySnNg5eioqLk55f+wyr9/MyvPjaNv98t9/PLm7IvMvPntLRcHp4yGI1pHgB+K/aa8nj5ZHBUyjJHX/9CKhAYpJotO6hs9Xr68fPVGY73yV9Qudw9FR3xp8VqfxRHnS9ypSKX7XJ5eXnJyclJ0dHmdUZHR6W5GugBXz8/Rf/l+xAdlfbqoYcVKlxEXl7euvBHxqvFLMVR54pcqchlu1went4yGp0UE23+APCYa1Hy9vn7D7z29vVTkYDiZvuKBBTT1SsZr9q1JJc8HjIYjbp93fx3qNs3YuTmkfZ3qBtXL+lmVIS2L3xdy19sqeUvttSZ3dv0x6HdWv5iS12/ekkRp4/o9o0YfTqmu2nMregr+vWzJfp0TI9syeWon0NypSIXuSzJETNJ5HoYucgFIHNoaNghHx8fNW3aVPPnz9etW7fSvB7zmPucz549W0ajUW3atMlwTGBgoHLlyqVbt27J2dlZQUFBps3n/m0KatSooW3btpkdt3XrVtWoUSO9U0qSXFxc5OHhYbZl5XZTkpQjZ06VKVtOu3elPqsjKSlJu3fvVEjFSukeExIaqt0PPSxdknbt/FkhoaGSpEKFC8vPL6927049582bN3Xo4IEMz2lpzs45VLBYKZ09vM+0LykpSb8d3qfCpcpm+jzJyUm6m5iY4euxUVcVd/P6I5skluSo80WuVOSyYa4cORVcpqx+3ZNaZ1JSkn7ds0vlQ0LTPaZ8hVCz8ZK0Z/dOlQ+pmOH7XIm4rNjYGPnlzWuRuh/FYeeKXCbksuXPjBwqEVxGB/ftNu1LSkrSwb17FFw25BFHPlqZ8qG6+MfvZvv+/OO88uZP/0HblubknEO+RYN06UTq6tPkpCRdOhGuvMXS3qLV07+Inh6zQK1enWfailSoLv9SIWr16jzl9vZT8WoN9fRr883GuHn6qlyT9moy+I1syeWwn0NymZCLXJbkiJkkcj2MXOQCkDk8Q8NOzZ8/X7Vq1VK1atU0ceJEhYSE6O7du9q6dasWLlyoY8eOSZJu3Lihy5cvKzExUWfPntXKlSu1ZMkSTZ06VUFBQZKkCRMmKC4uTs2bN1dAQIBiYmI0Z84cJSYmqkmTJhnWMHToUNWrV08zZsxQixYttGbNGv36669atGiR1fN37d5TY18dpXLlyqt8hRCtXLFM8fHxatO2nSTptdEvK1++/Br60ghJUucu3dS7R1ctW/qB6tatp01ff6Ujhw9r7ISJkiSDwaDOXbtp8XsLFVA0QIUKF9b8ubOVN18+NWzUOMM6LK1Gi2e1fuGbKlg8WIWCSmvXV58pMeG2KtV7SpK0bv5Uefj4qfHzL0iSftiwWgWLl5J3/oK6dzdRp/bv1sEftqpF72GSpITb8fru02UqU72u8nj66FrERW1d/Z588hdSUMWq2ZbLUeeLXOSyh1zPd+6hSeNHq3TZ8ipXroLWrF6u2/Hxavl0W0nS62NfUd58+TRw8HBJUodOXTXwhe5aveJD1axdT99s/krHjx7WK2NelyTFxd3S++8tUINGT8rXz08X/jiv+bNnqHCRoqpeo3a2ZHLUuSIXuewhV+tnu2j21HEKCi6rkmXK64tPV+v27Xg1bpbynIh3poyRr18+des7RFLKg8T/uP9MnsS7iYqKvKLfTp2Qm5ubChQuKkl6+tkuGjWoh9aufF+16zfRyeNHtOXLzzRwxNhsy1W2YVv9uHymfANKyi+glI7t+Fx3ExIUVCPld9kflk5XLi9fVWnTU045csq7YKDZ8Tlz5ZEk036nPDnkmsfDbIzRyUluHt7yzF/Y6nkecNTPIbnIRS4ykYtc5LKPXP953FrUIdHQsFPFixfXvn37NHnyZI0YMUKXLl1S3rx5VaVKFS1cuNA0bty4cRo3bpxy5swpf39/hYWFadu2bWrQoIFpTL169TR//nx169ZNERER8vb2VqVKlbRlyxYFBwdnWEPNmjW1evVqjRkzRq+++qpKliypDRs2qHz58lbNLklPNWuua9HRWjBvjiIjryq4dBkteG+JfO8vy7t86ZKMhtQFRqGVKmvqtOmaN2eW5s6aqaIBgZo1d75KlixlGtOz9wuKj4/XxAnjdOPGdVWqXEUL3luS5RUk/0T5mg1063qMdqz9UDdjrsk/oIS6vPKWaTVFbOQVGR7KdSchXhs/mK3rUVflnNNFfgWLqN2gV1W+Zsr8Go1GRZz/TeHfb9HtWzfl7u2rEiFPqGGHnnLOkTPbcjnqfJGLXPaQq3HTZrp2LVpLFs5VVFSkSgaX1jvz3pPP/aXMEZcvyWhMzRVSsZJenzxNixbM0bvzZqlI0QC9NXOuSgSVlCQZjU46c+qkvv7yc924cV1+efOpelgt9R04WDlzZs/PDUedK3KRyx5y1WnYVNdjrmn1hwt1LTpKxYKCNX7afHndv+VUZMRls1zRkVf10gsdTV9v+Hi5Nny8XOUrVtHk2UskSSVLl9PoSTO0YvFcfbxskfIXKKQ+L45U/SbNsy1XsSfq6fbN6wr/coXir1+TT+HiavziRLndf1D4rWtXZXjoZ+G/haN+DslFLnKRiVzkIpd95AIckSHZEk+gBh7h9l1bV2B56w9lz/MpslvbCoVsXQLgsOIS7tm6BKvI5eJk6xIAh3XuapytS7C4dUcv2boEqxher4StSwAAAA7OlcvSs8yt+khbl/CvE7/7bVuX8Fj/vsuYAAAAAAAAAADAfw4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvH3dcAAAAAAAAAAI7FwLX8johZBQAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3nG1dAAAAAAAAAAAAFmUw2LoCWAErNAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPWdbFwAAAAAAAAAAgEUZuJbfETGrAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOyes60LAAAAAAAAAADAogwGW1cAK2CFBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7Z0hOTk62dRFwbLfv2roCAIC1DF532NYlWMXcduVtXYJVfHXkkq1LsIrm5QrYugTAIV2Ijrd1CVZR0NvV1iVYhdFgsHUJAAArcnW2dQX/Pm61x9q6hH+d+B8n2bqEx2KFBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC752zrAgAAAAAAAAAAsCiDwdYVwApYoQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7jnbugAAAAAAAAAAACzKwLX8johZBQAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3nG1dAAAAAAAAAAAAFmXgWn5HxKwCAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHvOti4AAAAAAAAAAACLMhpsXQGsgBUaAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joWHHLl++rMGDB6t48eJycXFRkSJF1KpVK23btk2SFBgYKIPBIIPBIDc3NwUGBqpDhw7avn17mnOtX79eYWFh8vT0lLu7u8qVK6dhw4Y98v2PHDmi9u3bm95n1qxZVkiZsTWrV6lZk4aqWqmCOnd8VocOHnzk+C2bv1brlk+paqUKat+mlX74/juz15OTkzV/7mw1qldb1SqHqG/vHvr993NWTJA+cqUgF7msgVwp/g256gf5aGqLUlrQvqxGNyquQB+3DMfWDPTS4g7lzbYF7cuaXncySO1D8mv8k0Ga166s3m4VrF7VCsnT1Tk7ophxxLmSpJ2b1uutQc9pbOcmmv/qAP1x+liGYw/v/l7zXumr13u00LiuT2nOyN7a9/0WszHffPKhZg7rqnFdn9LrPVtqyaThOn/qqLVjpOGo80WuFOSyba4v161Rz2ebqU2janqpbxedOHoow7G/nz2tyWNGqOezzdSiTqg2fLLykef+ZOUHalEnVIvmTLN02Y/18Uer1PzJhqpeOURdn++gw4cePV9bN29S21bNVL1yiJ5tm3a+tm3dogEv9FL9WtVVqXxpnTie8c9Xa3LUz6Ej5nLETBK5HiAXuQA8Hg0NO3Xu3DlVqVJF27dv19tvv61Dhw5p06ZNatCggQYNGmQaN3HiRF26dEknTpzQ8uXL5eXlpcaNG2vy5MmmMdu2bdNzzz2n9u3ba8+ePdq7d68mT56sxMTER9YQFxen4sWL680335S/v7/VsqZn09dfafq0qeo3cJDWrF2v4ODSGtCvt6KiotIdH75/n14ZOUJt2z2jjz/doAYNG2nY4EE6deqkacyH7y/WR6tWaMz4CVr50Sdyc3PTgL69lZCQkF2xyHUfuchlDeRK8W/I9UQRD3Wo6K8vjlzRpK1ndCHmtobVDZS7i1OGx8TduacR/3fctI368oTptZzORhX1ctPGo1c0aetpLfzpvPK7u+jF2gHZEcfEEedKkg7+vF0bly9Qo2d66MW3FqtAQAl9MHmkbsZeS3d8rjzuatCuqwa8sUBD335fVRo002cL3tTJ8D2mMX4Fi+jpXkM1bPoH6j9xrrzz+uuDN0bq5vWYbErluPNFrhTksm2u77dt1uJ5M9SpRz/NWfKRigWV0tgRAxVzLTrd8Qm3b8u/QCH16DdU3j5+jzz3yWOHten/PlWxEqWsUfojbf76K82Y9qb6DRik1WvXqVRwsAb266PoR8zX6JdHqE3bZ/TR2vWq37Cxhg95Uacfmq/4+HiFVq6iIS/9L7tipOGon0NHzOWImSRyPUAucsEKDEa2rG7/Aobk5ORkWxeBtJo3b66DBw/qxIkTyp07t9lrMTEx8vLyUmBgoIYNG5ZmpcX48eP1xhtv6OjRowoODtawYcN04MAB7dix42/Xk9F7Zcbtu1l/v84dn1W58hX06phxkqSkpCQ92aienu/UVb1f6Jtm/MgRwxQfH695C94z7evyfAcFly6tseMnKjk5WY3r11G3Hj3VvWdvSdKNGzfUsG5NTZz8ppo1b5H1Iv8GcpGLXORytFyD1x3OcqbRjYrrXHS8Ptp/SZJkkPRWy2BtPx2lTccj04yvGeil50ILaOiGzF+1GujtptealNCoL08oOu7RDfz0zG1XPsvH2PtcSdJXRy5l+Zj5rw5Q4RLBat17mCnXWwM6qEaztqrfpnOmzjF31AsKrhSmJzv2Tvf123G39HqPFuo9doaCKlTJco3NyxXI8jH/hvn6O8hFLkvmuhAd/7dyvdS3i0qVKacBL4025erRvqlatn9eHbr0euSxPZ9tptbPdlabDl3SvBYfF6chvTtq4IhX9fGyxSpeMlh9h7yc5foKertm+RhJ6vp8B5UrX16vvJY6X081rq+OnbqoV5+08zVqxEuKj4/TnIfmq1un51QquLTGjH/dbOzFPy+oRdPGWvPpegWXLvO36jMaDH/rOHv/HP5djpjLETORi1zkyjwbLED/13NrOPnxg2Amfvtrti7hsf4dbZf/mOjoaG3atEmDBg1K08yQJC8vr0ceP3ToUCUnJ+vzzz+XJPn7++vIkSM6fDjrf3SyhcQ7d3Ts6BGF1ahp2mc0GhUWVlMHD+xP95iD4eEKC6thtq9mrdo6GB4uSfrzwgVFRl5V9bDUc7q7u6tCSMUMz2lp5EpFLnJZGrlS2XsuJ6NBAd5uOhZx07QvWdKxKzdVwjdXhse5OBv1ZotSeqtlsAbVKqqCHi6PfB+3HEYlJScr7s49S5X+SI44V5J0926iLv52wqzJYDQaVaJCFZ0/+fhbRCUnJ+v0ob26evEPFStbMcP32PPNF3LNlVsFAkpYrPZHcdT5IlcqctkwV2KiTp88ptAq1U37jEajQp+oruNHHn3rjsdZ+M4UVa1RR5WeCPunZWZZYmLKfD38vTUajaoeVkMHD4Sne8zBA+Gq/tD8SlKNmrUyHG8LDvs5dMBcjphJItfDyEUuAJlDb88OnT59WsnJySpduvTfOt7Hx0f58uXTuXPnJEmDBw/WDz/8oAoVKiggIEBhYWF68skn1blzZ7m4PPoPQlmVkJCQZulcspNLlt7nWsw13bt3T76+vmb7fX19dfbsb+keExkZKV9fvzTjI6Mi779+NWWfX9pzRkamvRrYGsiVilzksjRypbL3XHlyOsnJaND1BPPle9dv35W/e/r/X3H5RoKW/fKnLsTellsOo54M9tOohsU1YfMpXYtPuwzQ2WhQ+xB//XI+VrfvJlklx1854lxJUtz1WCUlJSmPl4/Zfncvb129eD7D427H3dTUfs/o7t1EGY1Gte79kkqGPGE25tjen7Vm1kQl3kmQu5eveo2ZodweXtaIkYajzhe5UpHLdrmux15T0r178vIxr8HL21d//IP7hn/3zSadPnlcsxat+ocV/j3XrqXMl0+a+fLTubNn0z0mMjIy7Xg/P0Vl01xkhqN+Dh0xlyNmksj1MHKRC0DmsELDDlniLmDJycky3F9ynDt3bm3cuFGnT5/WmDFjlCdPHo0YMULVqlVTXFyczp8/rzx58pi2KVOm/O33nTp1qjw9Pc22t9+a+o/zAAD+u36LitfO32P0R8xtnbwap4U/ndfNhLuqW8InzVgng9SvRhHJIK3ce9EG1UKScrrm0uC3l2jQ1Hf1ZMc+2rh8vn47Yn4lWolylTT47SXqP2meSoVW00fvTMjwuRwA/tuuRlzWojnTNHLsFOW08AVZAAAA+HehoWGHSpYsKYPBoOPHj/+t46OionT16lUVK1bMbH+JEiXUp08fLVmyRPv27dPRo0f18ccfq2DBggoPDzdt/fv3/9u1jx49WrGxsWbbyFGjs3QOby9vOTk5pXnwUlRUlPz80n9IoJ+fn6KiItOOv98t9/PLm7IvMvPntDRypSIXuSyNXKnsPdfNO/d0LylZHi7mi0Q9XJ11PZMPXbqXLJ2Pua18eXKa7U9pZhSVb+4ceue7c9m2OkNyzLmSpFwenjIajboZY/4g3xsx1+Tulbah9IDRaJSff2EVDCypOq2eU/mwevp2w2qzMTld3eTnX1hFS5VT+wEvy+jkpF+3f2WVHH/lqPNFrlTksl0uD09vGZ2cFBNtXkPMtSh5+/69Gk6fOKqYa9Ea0ud5tapfRa3qV9Gh8L36v08/Uqv6VXTvnvVvL+jtnTJff30AeFRUpHwfMV9pxkdmPN4WHPVz6Ii5HDGTRK6HkYtcADKHhoYd8vHxUdOmTTV//nzdunUrzesxMTGPPH727NkyGo1q06ZNhmMCAwOVK1cu3bp1S87OzgoKCjJtPj4Z/4HicVxcXOTh4WG2ZfW2Vjly5lSZsuW0e9dO076kpCTt3r1TIRUrpXtMSGiodu/aZbZv186fFRIaKkkqVLiw/Pzyavfu1HPevHlThw4eyPCclkauVOQil6WRK5W957qXlKzfr8WrTP48pn0GSWXy5dGZqLhMncNgkAp5uir2odtNPWhm5HPPqZnfndOtbHp2xgOOOFeS5OycQwWLB+vM4X2mfUlJSTpzeK+Kliqb6fMkJyXrbuKdR49JfvwYS3HU+SJXKnLZMFeOHAoqVUbhe/eY9iUlJSl87x6VLhfyt85Z8Ynqmr/sU8394GPTVrJ0WdVv0lxzP/hYTk5Olio/Qzly3J+v3ebztWf3LoVUDE33mJCKodrz0PxK9+crg/G24LCfQwfM5YiZJHI9jFzkghUYDGxZ3f4FeIaGnZo/f75q1aqlatWqaeLEiQoJCdHdu3e1detWLVy4UMeOHZMk3bhxQ5cvX1ZiYqLOnj2rlStXasmSJZo6daqCgoIkSRMmTFBcXJyaN2+ugIAAxcTEaM6cOUpMTFSTJk0yrOHOnTs6evSo6b///PNPhYeHK0+ePKZzW0vX7j019tVRKleuvMpXCNHKFcsUHx+vNm3bSZJeG/2y8uXLr6EvjZAkde7STb17dNWypR+obt162vT1Vzpy+LDGTpgoSTIYDOrctZsWv7dQAUUDVKhwYc2fO1t58+VTw0aNrZqFXOQiF7nIZW7ryUj1qlZY56LjdTY6Xo1L+Sqns1E/nU253VCvaoV0Lf6u1h+KkCS1LJtXv0XF68rNBOXK4aSmpf3kmyuHfrg/3skg9a9ZVEW93TT3h99lNBjk4ZryK86t+ytCsoMjzpUk1Wn5rNbOn6pCxYNVJKiMfvrqU91JuK0q9ZtJkj6ZN0UePn56qlNfSdK361epUIlg+eYvqLuJiTqxf5f2/7BFbfq8JEm6czteO9atVJknasrd21dxN2K1c9MGXY++qgo16mdbLkedL3KRyx5ytX2uq2ZOGauSpcuqVJny+nztKt2Oj1eT5q0lSTPeGCNfv3zq0X+IpJQHiZ8/d0aSdDfxrqKuXtGZU8fl5pZLBQsXVa5cuRVY3PzfH66ubvLw9Eyz35q6dOuhca+9orLlyqt8+RCtXpkyX63bpMzXmNGjlC9fPg25P1/Pd+mqF3p20/KlH6hO3fra/PVGHT1yxDRfkhQbG6PLly7pypUrkmR6Hoevn5/p6l5rc9TPoSPmcsRM5CIXuQBkFQ0NO1W8eHHt27dPkydP1ogRI3Tp0iXlzZtXVapU0cKFC03jxo0bp3Hjxilnzpzy9/dXWFiYtm3bpgYNGpjG1KtXT/Pnz1e3bt0UEREhb29vVapUSVu2bFFwcHCGNVy8eFGVKqV2jadPn67p06erXr16+vbbb62S+4GnmjXXtehoLZg3R5GRVxVcuowWvLfEtDz78qVLMhpSFxiFVqqsqdOma96cWZo7a6aKBgRq1tz5KlmylGlMz94vKD4+XhMnjNONG9dVqXIVLXhvicUfjE4ucpGLXOR6tF//uC53l8tqXT6fPFyd9UfMbc3+/pxuJKSsqvDJlVMPP04qV04ndXuioDxcnRV3555+v3Zbb27/TZeuJ0iSvNxyKLSQhyRpfFPzP2y9veOsTl5Nu9rRGhxxriQppGZD3bweo28++VA3YqJVIDBIPV+dZrrlVExkhOm5XZJ0JyFeny95R7FRV5Ujp4vyFiqq5wa/ppCaDSVJBqNRVy+e174Zm3XrRqxyuXuocInS6vv6XOUvUizdGqzBUeeLXOSyh1x1GzVVbMw1rXx/oa5FR6p4ULAmTl8g7/sPCr8accns50Z05BUN6dXR9PW6Ncu1bs1yVQitojfnvp9tdT9O02bNde1atBbOm6uo+/M1/93FD83XRRmNqblCK1XWlLema/7cWZo3+x0VDQjUzDnzFPTQfH23Y7vGj3nV9PUrI4dLkvoNGKT+gwZnSy5H/Rw6Yi5HzEQucpELQFYZki3xBGrgETJ5S3QAwL/Q4HWHbV2CVcxtV97WJVjFV0cu2boEq2heroCtSwAc0oXoeFuXYBUFvV1tXYJVGP8lt4kAAPw9rlyWnmVujabYuoR/nfhtrz5+kI3xDA0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7x2IlAAAAAAAAAIBjMXAtvyNiVgEAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPWdbFwAAAAAAAAAAgEUZDLauAFbACg0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAds/Z1gUAAAAAAAAAAGBRBq7ld0TMKgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC752zrAgAAAAAAAAAAsCiDwdYVwApYoQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7jnbugAAAAAAAAAAACzKwLX8joiGBqwuITHJ1iVYnEsOfiACgCTNbVfe1iVYxbs7z9q6BKvoX6OYrUuwim9PXLV1CVZRPzivrUuwuKTkZFuXYBWHzl+3dQlWUTHA09YlAAAAAGb4qywAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg93goOAAAAAAAAADAsRgMtq4AVsAKDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z9nWBQAAAAAAAAAAYFEGruV3RMwqAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnbOsCAAAAAAAAAACwKIPB1hXAClihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuOdu6AAAAAAAAAAAALMrAtfyOiFkFAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaNixy5cva/DgwSpevLhcXFxUpEgRtWrVStu2bZMkBQYGymAwyGAwyM3NTYGBgerQoYO2b9+e5lzr169XWFiYPD095e7urnLlymnYsGGPfP/FixerTp068vb2lre3txo3bqw9e/ZYI2q61q5ZpdbNGql2tYrq2eU5HTl08JHjv9mySc+2aa7a1Srq+Wee1k8/fJfh2KlvTFC10DL6aOUyS5f9WGtWr1KzJg1VtVIFde74rA4dfHSuLZu/VuuWT6lqpQpq36aVfvjePFdycrLmz52tRvVqq1rlEPXt3UO//37OignSR64U5CKXNThiLkfMJEmHt/+fVo7qpkX9W+mzyUMV8duJTB13as+3WtjnKX0973Wz/b/t/VFfzHxVHwx9Vgv7PKXI82esUfZjOep8/fD1Z3q93zMa8VxDzRz1gn4/dTTDsQd2fafpI3vrlS5PaeTzjTVteA/98u0mszHJycn66qMlGturtf7XsaHmTxiqKxf/sHaMNBx1vj7+aJWaP9lQ1SuHqOvzHXT4Mb8bbt28SW1bNVP1yiF6tm3aXNu2btGAF3qpfq3qqlS+tE4cP2bN8jP0zRdrNbxHa/VuXVsThvXUmRNHMhy7Y9MGvTHyBfXv0Ej9OzTSm68OeuT4D+dOVbfm1bRpw0fWKP2RHPVzSK4U5OJ3KEsjVwpykQsWZjCyZXX7F/h3VPkfdO7cOVWpUkXbt2/X22+/rUOHDmnTpk1q0KCBBg0aZBo3ceJEXbp0SSdOnNDy5cvl5eWlxo0ba/LkyaYx27Zt03PPPaf27dtrz5492rt3ryZPnqzExMRH1vDtt9/q+eef144dO7Rz504VKVJETz75pP7880+r5X5g6+avNGvGW+rTb5CWf/SZSpYK1pCBLyg6Oird8QfD92vs6P/p6TbttWLNOtVr0EgjXxqsM6dPphm7Y/tWHT54QHnz5rN2jDQ2ff2Vpk+bqn4DB2nN2vUKDi6tAf16Kyoq/Vzh+/fplZEj1LbdM/r40w1q0LCRhg0epFOnUnN9+P5ifbRqhcaMn6CVH30iNzc3DejbWwkJCdkVi1z3kYtc1uCIuRwxkySd3vOdfvpksZ5o1UXPjJsn3yLF9eWs1xR3PeaRx12PvKyda5eoQMnyaV5LvHNbBUqWU1j7Xlaq+vEcdb72/bhN6z+cp6Ydemrk9PdVMDBICycO142Ya+mOz5XHXU3ad9OwN9/VqHeWqVrD5lo9b6qO7d9tGrNt/Sp9v/FTdej/P7305iLldHHTu5OGK/EOPzP+qc1ff6UZ095UvwGDtHrtOpUKDtbAfn0U/Yhco18eoTZtn9FHa9erfsPGGj7kRZ1+KFd8fLxCK1fRkJf+l10x0tj13VatXjxLbTr10cS5y1W0eEm9PXaIrsdEpzv++MG9CqvXVKOnLtS4Ge/L1y+/3h4zWNGRV9KM/fXnHTpz4rC8ffNaO0Yajvo5JFcKcvE7lKWRKwW5yAUgc2ho2KmBAwfKYDBoz549at++vUqVKqVy5cpp+PDh2rVrl2mcu7u7/P39VbRoUdWtW1eLFi3S2LFjNW7cOJ04kXJV6BdffKFatWpp5MiRCg4OVqlSpdSmTRvNnz//kTWsWrVKAwcOVGhoqEqXLq0lS5YoKSnJtELEmlavWKY27Z5VqzbtVLxEkF4ZM0Gurq76YsO6dMevWb1cYTVrq2uP3ipWvIT6Dxqq0mXK6JM1q83GXYmI0Iw3J2vilGlydna2eo6/WrHsQ7V7poPatG2vEkFBGjP+dbm6umrDus/SHb9q5XLVrF1HPXr1UfESJfTikGEqU7as1qxeKSml279qxXK90G+AGjRsrFLBpfXG1Gm6euWKtm/7hlzkIhe57DKXI2aSpANb16lsnadUuvaT8ikYoHpdBitHThcd/3FzhsckJd3TtsXTVPXpLvLI65/m9eAajfVEq84qXLaSNUt/JEedr2+/WKOaTVoprFEL+Rcppg79Riqni6t2bf8y3fEly1dWxbB68i8cKD//QqrfsoMKBpTQb8cOmnJ99+VaPflMN1WoVkeFAoPUZcgYxUZH6dCeH7Itl6PO18rlS9XumWfVum17lSgRpNfG3c+1Pv1cH61coZq1aqt7r94qXqKEBg0eej/XKtOYlk+3Vr8BgxRWo0Z2xUhj0/rVqv9UG9V9spUKFS2uHi++IhcXV3235Yt0xw94eZIat3xGASVKqWCRQPUe+pqSkpJ19MAvZuOiI69oxcIZ6j9yopyc+J2XXORylFyOmIlc5CIXgKyioWGHoqOjtWnTJg0aNEi5c+dO87qXl9cjjx86dKiSk5P1+eefS5L8/f115MgRHT58+B/VFRcXp8TERPn4+Pyj8zxOYuIdHT92RFWrp/7j0mg0qmr1Gjp0MDzdYw4dPKBq1c3/MRpWo7bZ+KSkJI0fM0pduvdSiaCS1ij9kRLv3NGxo0cUVqOmaZ/RaFRYWE0dPLA/3WMOhocrLMw8V81atXUwPFyS9OeFC4qMvKrqYanndHd3V4WQihme09LIlYpc5LI0R8zliJkk6d7dRF39/ZRZ48FgNKpQmUqK+C3j29j8+sVquXl4qUydp7KjzCxz1Pm6m5ioP86cVKmQJ0z7jEajSoU8oXOPuH3PA8nJyTpx8FdduXheJcqGSpKiIi7qekyUSlWsahrnljuPAkqW1dkT/+x3sMxy1PlKTEzJ9XANRqNR1cNq6OCB8HSPOXggXNUf+j5IUo2atTIcbwt3ExN17vRxlQtN/cwYjUaVDa2q08cPZeocCQm3de/eXeXO42Hal5SUpPemj1fz9l1UOKCExet+HIf9HJLLhFz8DmVJ5EpFLnIByBwaGnbo9OnTSk5OVunSpf/W8T4+PsqXL5/OnTsnSRo8eLCqVq2qChUqKDAwUB07dtQHH3yQ5SVuo0aNUsGCBdW4ceMMxyQkJOj69etmW1bfJ+ZajO7duycfX1/zXL6+ioqMTPeYqMhI+fj6pRkf/dD45R8ukbOTk57r1DVL9VjKtZhrunfvnnz/ksvX11eRGeSKjIyU719y+fr6KjIq8v7rV1P2+WX+nJZGrlTkIpelOWIuR8wkSbdvXldyUpLcPLzM9ufy8FJcbPq3MLp06rCO/7hZ9boNzYYK/x5Hna9bN2KVlHRP7l7mF2m4e/noRkz6txWQpPhbNzWyUxMN71Bfiya/rPZ9hqn0/T9G37h/iyB3T++/nNNbN66lf/sgS3PU+bp27Vq6vxv6+vpl+LthZGRk2vF+GY+3hRvXY5SUdE8e3uafQ08vH8VmcJvVv/r4w3ny9vFTuUrVTPs2rl0uJydnPdn6OYvWm1kO+zkklwm5+B3KksiVilzkApA5NDTsUHJyskXOYTAYJEm5c+fWxo0bdfr0aY0ZM0Z58uTRiBEjVK1aNcXFxen8+fPKkyePaZsyZUqa87355ptas2aN1q9fL1dX1wzfd+rUqfL09DTbZr795j/O808dO3pEa1av0LiJU03fFwAAbOXO7Thte/9t1es2VG7unrYuB5nk4pZLL8/4UCOmLVGLTi9ow4fzdOrwPluXhf+oLz5Zpt3fbdWQsdOUM6eLJOnsqWPa8n9r9MLwcfzOCwAAAIdEQ8MOlSxZUgaDQcePH/9bx0dFRenq1asqVqyY2f4SJUqoT58+WrJkifbt26ejR4/q448/VsGCBRUeHm7a+vfvb3bc9OnT9eabb2rLli0KCQl55HuPHj1asbGxZtvwka9kqX4vby85OTmlechjdFSUfP380j3G189P0VGRacb73B8fvu9XXYuO0tPNGqpGlfKqUaW8Ll26qNkzp6l1s0ZZqu/v8vbylpOTU5oHSkVFRckvg1x+fn6K+kuuqKgo+d2/CsDPL+Uhj1GRmT+npZErFbnIZWmOmMsRM0mSax4PGYxGxf/lAeBx12OU6y9X7EvS9SuXdCMyQl/PHa93+zbXu32b68TObTp3YJfe7dtcsVcuZkvdj+Oo85Xb3VNGo5NpVcUDN2Ki5e7lm8FRKbceyFugsAoXK6mGrZ9XxRr19c26lPskP1jtceMvK3JuxFyTu7d1b9f5gKPOl7e3d7q/G0ZFRWb4u6Gfn1/a8ZEZj7cFdw8vGY1Ouv6XFTyxMdHy9Mn4cyhJX322UhvXLtPIN+aoaLHUW6meOBKu6zHX9FL3p9WjZQ31aFlDkVcu6aMlszW8R2ur5Pgrh/0cksuEXPwOZUnkSkUucsEKDAa2rG7/AjQ07JCPj4+aNm2q+fPn69atW2lej4mJeeTxs2fPltFoVJs2bTIcExgYqFy5cunWrVtydnZWUFCQaXv4GRnTpk3TpEmTtGnTJj3xxBMZnu8BFxcXeXh4mG0uLi6PPe5hOXLkVOky5fTLntSHnyclJenXPbtUISQ03WMqhFQ0Gy9Ju3f9bBrfrOXTWr12g1Z+vM605c2bT12699KchUuyVN/flSNnTpUpW067d+007UtKStLu3TsVUjH9h72GhIZq9y7zXLt2/qyQ0FBJUqHCheXnl1e7d6ee8+bNmzp08ECG57Q0cqUiF7kszRFzOWImSXJyzqG8ASV14Vi4aV9yUpL+PB6u/MXLpBnvVaCIOrz+rp4dv8C0BVYMU6Hginp2/ALl8cmbLXU/jqPOl3OOHCpSopROHtxr2peUlKSTB/cqMLhcps+TnJyku4l3JEm++QvKw8tXJw/+anr9dtwt/X7qqIoFl7dc8Y/gqPOVI8f9XLvNc+3ZvUshFUPTPSakYqj2PPR9kO7nymC8LTjnyKHAoNI68tADvZOSknQ0/FcFla6Q4XEb1y7X5x+9r/9Nmq3ipcqavVarYTNNnr9ab8xbadq8ffOqefsuGvnGHKtleZjDfg7JZUIufoeyJHKlIhe5AGSOs60LQPrmz5+vWrVqqVq1apo4caJCQkJ09+5dbd26VQsXLtSxYykPGL1x44YuX76sxMREnT17VitXrtSSJUs0depUBQUFSZImTJiguLg4NW/eXAEBAYqJidGcOXOUmJioJk2aZFjDW2+9pXHjxmn16tUKDAzU5cuXJcl0aypr6tS1u14fO1plypZXufIVtGbVcsXHx6tl67aSpPFjRilfvvwaNGS4JKljp27q16ebVi3/ULXq1NOWTV/p2NEjenXc65IkLy9veXmZXyHr7OwsX18/BQSar2Sxpq7de2rsq6NUrlx5la8QopUrlik+Pl5t2raTJL02+mXly5dfQ18aIUnq3KWbevfoqmVLP1DduvW06euvdOTwYY2dMFGSZDAY1LlrNy1+b6ECigaoUOHCmj93tvLmy6eGjTJ+1gm5yEUuctkylyNmkqSKTdpp+wfTlTegpPIXC9bBb9YrMeG2Std6UpK07f23ldvLV2Hte8k5R075Fgo0O94lV25JMtt/++YN3Yy+olv3n+sQc/mCJCmXp7dyeWbPVf+OOl/1W3XUqrmTVTSotIqWLKPvvvhEdxLiVb1hC0nSytmT5OmbV626pKxc3frZChUpUVp+/gV1926iju7dqV++26wOff9nylWv5bPa8uky5S1QRL75C+irj5bI08dXFarVybZcjjpfXbr10LjXXlHZcuVVvnyIVq9MydW6TUquMaNHKV++fBpyP9fzXbrqhZ7dtHzpB6pTt742f71RR48cMeWSpNjYGF2+dElXrlyRJJ07e1ZSysrfB1dVWttTbTtp8czXVaxkGRUvVU5bPl+jhIR41W3SUpL03vTx8vbNpw49B0mSvly7TOtWLNKAlyfJL18BxUSnXBnq6pZLrm655O7hJfe/PMvHyclZnt6+KlA4IFsySY77OSQXuWydyxEzkYtc5AKQVTQ07FTx4sW1b98+TZ48WSNGjNClS5eUN29eValSRQsXLjSNGzdunMaNG6ecOXPK399fYWFh2rZtmxo0aGAaU69ePc2fP1/dunVTRESEvL29ValSJW3ZskXBwcEZ1rBw4ULduXNHzzzzjNn+8ePHa8KECRbP/LAmTZvr2rVrWrRwjqIiI1UquIxmL1hkeuBSxKVLMhpSFxiFhFbSpClv6935s7Vg7jsqUjRAb78zVyWCSlm1zqx6qllzXYuO1oJ5cxQZeVXBpctowXtLTLc/uPyXXKGVKmvqtOmaN2eW5s6aqaIBgZo1d75KlkzN1bP3C4qPj9fECeN048Z1VapcRQveW5LllTHkIhe5yJVduRwxkyQFVaun+Jux+uXzFYq7fk1+RYqr5bA3TLecuhl1Jcv3tD93YKd2fDjT9PXWRVMlSU+06qyqrbtarvhHcNT5qly7kW5ej9FXHy3R9ZhoFS4WpP5jZ8jj/q2jrkVGyGBMzXUnIV5rF89QbNQV5cjponyFAtR16DhVrp1668pGbTvrTsJtffzuNMXfuqniZSqo/9gZypGTnxn/VNNmzXXtWrQWzpurqPu55r+7+KFcF2U0pv7vK7RSZU15a7rmz52lebPfUdGAQM2cM09BD+X6bsd2jR/zqunrV0amXCjTb8Ag9R80OFtyhdVrohvXr2ndikWKvRalosVLaeTE2fL0TrnlVNRV88/h9o3rdPduouZOMb+la5tOfdSuS99sqTkzHPVzSC5y2TqXI2YiF7nIBSCrDMmWeAI18Aix8Um2LsHiXHJwtzYAcGTv7jxr6xKson+N7FuVmJ2+PXHV1iVYRf1g+7j1mCUlOeg/PQ6dv27rEqyiYoCnrUsAAAD3uXJZepa5Pb3w8YNgJv7/Bti6hMfir7IAAAAAAAAAAMDu0dsDAAAAAAAAADgWA9fyOyJmFQAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdc7Z1AQAAAAAAAAAAWJTBYOsKYAWs0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg95xtXQAAAAAAAAAAABZl4Fp+R8SsAgAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7zrYuAAAAAAAAAAAAizIYbF0BrIAVGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsnrOtCwAAAAAAAAAAwJIMBoOtS4AVsEIDAAAAAAAAAADYPVZowOpcctA3A4CtxyJsXYJVNCmT39YlWEX/GsVsXYJV1Jq6w9YlWMVPoxvYugRkktFBr5KrGOBp6xIAAACA/wT+0gwAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7xzM0AAAAAAAAAAAOxeCgz2/7r2OFBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC752zrAgAAAAAAAAAAsCiDrQuANbBCAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdc7Z1AQAAAAAAAAAAWJLBYLB1CbACVmgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHvOti4AAAAAAAAAAABLMhgMti4BVsAKDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z9nWBfxX1K9fX6GhoZo1a5atSwEAAAAAAAAAh2YwGGxdAqyAFRrZZN26dZo0aVKmxp47d04Gg0Hh4eHWLeoxbt++rUGDBsnX11d58uRR+/btFRERkW3vv2b1KjVr0lBVK1VQ547P6tDBg48cv2Xz12rd8ilVrVRB7du00g/ff2f2enJysubPna1G9WqrWuUQ9e3dQ7//fs6KCdJHrhTkIpc1OGqun75ep8kDOuiV5xtr9iv9dP7U0QzHHtr1nWa9/ILGdGuu0Z2f1Mz/9dLe7zabXr93966+XLFQ04d31+jOT2riC2310ZzJio2OzI4oJo46V46a69knCumLwWH6eXRdLetVReUKuj9yfB4XZ416qqQ2D6upnaPrad3A6qoV5GN63WiQBtQvpv97MUw/vVJXnw8KU586AdaOkYajzhe5UpCLXNZArhTksl0uR8wkkesBcpELwOPR0MgmPj4+cnd/9D/+s+rOnTsWPd9fvfTSS/riiy+0du1afffdd7p48aLatWtn1fd8YNPXX2n6tKnqN3CQ1qxdr+Dg0hrQr7eioqLSHR++f59eGTlCbds9o48/3aAGDRtp2OBBOnXqpGnMh+8v1kerVmjM+Ala+dEncnNz04C+vZWQkJAtmSRyPUAuclmDo+YK/2mb/m/ZfDV5toeGTVuigoFBWvzG/3Qj9lq6493yeKhR+64aPGWBRsz4UFUbNNPH89/UifA9kqQ7Cbf159lTavxMd700bYm6j3xDVy6e14dvjs62TI46V46aq0nZfBreJEiLvj+nzot/1cmIm5rXqaK8c+VId7yz0aAFXSqqoJebXv70iNot2K03vjyhKzdSa+5eM0DPVCmoaZtO6ZmFezRn+xl1q1FUHasWyq5YDjtf5EpBLnJZA7lSkMt2uRwxk0SuB8hFLgCZQ0Mjm9SvX1/Dhg2TJAUGBmrKlCnq1auX3N3dVbRoUS1atMg0tlixYpKkSpUqyWAwqH79+pKkHj16qE2bNpo8ebIKFiyo4OBgSdKhQ4fUsGFDubm5ydfXV3379tXNmzdN53tw3PTp01WgQAH5+vpq0KBBSkxMzLDe2NhYvf/++5o5c6YaNmyoKlWq6MMPP9TPP/+sXbt2Wfi7k9aKZR+q3TMd1KZte5UICtKY8a/L1dVVG9Z9lu74VSuXq2btOurRq4+KlyihF4cMU5myZbVm9UpJKV3xVSuW64V+A9SgYWOVCi6tN6ZO09UrV7R92zdWz0MucpGLXH/Xd198ouqNW6paw+byLxKo9n1HKIeLq37ZvjHd8UHlK6lC9brKXzhQfv6FVKfFsyoQUFxnj6VcXeSWO4/6jZup0JoNla9QUQWUKqe2fYbpwm8ndO1q9qzCc9S5ctRcXcKKaP3+i/riwGWdjYzTlI0ndDsxSa1DC6Q7vnVoAXm65tCITw7pwIVYXYq9rX3nY3Qq4pZpTMXCHvr2RKR+PB2lS7G3te3YVe36LVrlCnlkVyyHnS9ykYtc5CKX4+ZyxEzkIhe5AGQVDQ0bmTFjhp544gnt379fAwcO1IABA3TixAlJ0p49KVfRfvPNN7p06ZLWrVtnOm7btm06ceKEtm7dqi+//FK3bt1S06ZN5e3trV9++UVr167VN998oxdffNHs/Xbs2KEzZ85ox44dWrZsmZYuXaqlS5dmWN/evXuVmJioxo0bm/aVLl1aRYsW1c6dOy34nUgr8c4dHTt6RGE1apr2GY1GhYXV1MED+9M95mB4uMLCapjtq1mrtg7ev23XnxcuKDLyqqqHpZ7T3d1dFUIqZnhOSyNXKnKRy9IcNdfdxET9+dtJlQp5wrTPaDSqZIUq+v3Ekccen5ycrFMH9+rKxT9UvGzFDMfdjrslg8Egt9x5LFL3ozjqXDlqLmejQaUL5NGes6krgpIl7TkbrQqF028+1C3lp4N/xmpUs1La8lItfdyvqnrWCpDxodvXHrhwXdWKeauoj5skqWT+3Aot4qWfT0dbM46Jo84XuVKRi1yWRq5U5LJNLkfMJJHrYeQiF4DM4aHgNtK8eXMNHDhQkjRq1Ci988472rFjh4KDg5U3b15Jkq+vr/z9/c2Oy507t5YsWaKcOXNKkhYvXqzbt29r+fLlyp07tyRp3rx5atWqld566y3lz59fkuTt7a158+bJyclJpUuXVosWLbRt2za98MIL6dZ3+fJl5cyZU15eXmb78+fPr8uXL2eYKyEhIc3SuWQnF7m4uGTyOyNdi7mme/fuydfX12y/r6+vzp79Ld1jIiMj5evrl2Z8ZFTk/devpuzzS3vOyMjsuW88uVKRi1yW5qi5bt2IVVLSPeXx9Dbb7+7loyt/ns/wuPhbNzWpX3vdTbwjo9FJ7fq8pFIVq6Y7NvFOgjaufFehtRrJNVdui9afHkedK0fN5ZUrh5yNRkXdNL/NZdStRAX6pf95KeztqgJeXvr6UISGfHRARXxy6ZVmpeTsZNDi789Jkpb+9LvyuDjps4HVlZSULKPRoAU7ftPXh7NnlZCjzhe5UpGLXJZGrlTksk0uR8wkketh5CIXgMxhhYaNhISEmP7bYDDI399fV65ceexxFSpUMDUzJOnYsWOqWLGiqZkhSbVq1VJSUpJpxYcklStXTk5OTqavCxQoYHq/KVOmKE+ePKbt/PmM/0j2OFOnTpWnp6fZ9vZbU//2+QAAWefilkvD335fQ99cpKee76P/WzZfpw+nvQro3t27WjFzvJScrPZ9R9igUjgig8Gga7cSNXnjCR2/fFNbj17RBz/+rmcqFzSNaVIun54qn1+vrT+qzkt+1fjPj6lLWFG1DPF/xJkBAAAAIPMMBgNbFrd/AxoaNpIjh/mDNA0Gg5KSkh573MONC0u9X//+/RUeHm7aChYsKH9/f925c0cxMTFmx0VERKRZNfKw0aNHKzY21mwbOSprD5r19vKWk5NTmgcvRUVFyc/PL91j/Pz8FBUVmXb8/W65n1/KqpeoyMyf09LIlYpc5LI0R82V291TRqOTbv7lAeA3YqLl4eWT4XFGo1F+BQqrULGSqv90R4XUqKft61eajXnQzLh2NUJ9x83MltUZkuPOlaPmiolL1N2kJPnmyWm23zd3DkXeTP9hhpE37+j3qDglJafuOxt5S37uLnK+f9+poY1KaOnP57XlyBWdvnJLXx2K0Ordf6hnraJWy/IwR50vcqUiF7ksjVypyGWbXI6YSSLXw8hFLgCZQ0PDDj1YgXHv3r3Hji1TpowOHDigW7dSH7T5008/yWg0mh4a/jg+Pj4KCgoybc7OzqpSpYpy5Mihbdu2mcadOHFC58+fV40aNTI8l4uLizw8PMy2rNxuSpJy5MypMmXLafeu1Gd1JCUlaffunQqpWCndY0JCQ7X7Lw8r37XzZ4WEhkqSChUuLD+/vNq9O/WcN2/e1KGDBzI8p6WRKxW5yGVpjprLOUcOFSpeSqcO7TXtS0pK0ulD+xQQXC7T50lOStbdxETT1w+aGVcvXVC/ce8ot7unRet+FEedK0fNdTcpWccv3VTVwNTbnhkkVS3mrUMXrqd7zIE/YlXEx00PX9sT4JtLV28k6O79LodrDiclJyebHZeUnJxtVwQ56nyRKxW5yGVp5EpFLtvkcsRMErkeRi5yAcgcGhp2KF++fHJzc9OmTZsUERGh2NjYDMd27txZrq6u6t69uw4fPqwdO3Zo8ODB6tq1q+n5GX+Hp6enevfureHDh2vHjh3au3evevbsqRo1aigsLOxvnzezunbvqXWffqL/27Bev505ozcmTlB8fLzatG0nSXpt9Mua/c4M0/jOXbrp559+0LKlH+jsb2e0cP5cHTl8WB07dZGUsiKlc9duWvzeQn27fZtOnTyhMaNfVt58+dSwUeP0SiAXuchFLrvIVa9VB+3+5kv98u3XirhwTusWz9CdhHhVbdBckvTRnMn6atV7pvHb1q3UyQO/KCrioiIunNO3/7dGe7/frCp1n5SU0sxYPn2s/jhzXJ2HjlVS0j1dvxal69eizJoe1uSoc+WouVbu+kNtKxdQyxB/Bfrl0ujmpeSWw0n/d+CSJOn11mX0YsPipvGf7v1THm459L+mJVXUx021g3zVs1aAPvn1T9OYH05FqlftANUO8lUBT1c1CPZT5+pFtOPE1WzL5ajzRS5ykYtc5HLcXI6YiVzkIheArOKh4HbI2dlZc+bM0cSJEzVu3DjVqVNH3377bbpjc+XKpc2bN2vo0KGqWrWqcuXKpfbt22vmzJn/uI533nlHRqNR7du3V0JCgpo2baoFCxb84/NmxlPNmutadLQWzJujyMirCi5dRgveWyLf+8vyLl+6JKMhtR8XWqmypk6brnlzZmnurJkqGhCoWXPnq2TJUqYxPXu/oPj4eE2cME43blxXpcpVtOC9JVleQUIucpGLXNmZK7RWI928HqPNaz7QjZhoFQwMUp/Xpsv9/i2nrkVGyGBMvar9TkK81i2eqZjoq8qR00X5ChZVpyFjFFqrkSQpNvqqjvz6kyRp5v96mb1X/wmzFVTe+lcLOepcOWqurUevyDtXDvWvV0y+eXLqZMRNDV59UNG3Uhpg/h4uZqstIq4n6MVVBzTiySCt6VdVV6/f0Ud7LmjZz7+bxkzbdEoD6hfTK81KyTt3DkXeuKPP9l00PTQ8OzjqfJGLXOQiF7kcN5cjZiIXucgFIKsMyX9d7w9Y2O27tq4AAGxv67EIW5dgFU3K/P3VgMh+tabusHUJVvHT6Aa2LgEAAACwKlcuS88yz+dX2LqEf53Yj7rauoTH4n8KAAAAAAAAAADHkj2P6EM24xkaAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOyes60LAAAAAAAAAADAkgwGg61LgBWwQgMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3XO2dQEAAAAAAAAAAFiSwWCwdQmwAlZoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7zrYuAAAAAAAAAAAASzIYDLYuAVbACg0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAds/Z1gUAAAAAAAAAAGBJBoPB1iXAClihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPe45RQAANmgSZn8ti7BKj47cMHWJVhF+4qFbV2CVfw0uoGtS7CKJ+f8ZOsSrGLLkFq2LgEAAAAA7AorNAAAAAAAAAAAgN2joQEAAAAAAAAAAOwet5wCAAAAAAAAADgWg60LgDWwQgMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3XO2dQEAAAAAAAAAAFiSwWCwdQmwAlZoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7zrYuAAAAAAAAAAAASzIYDLYuAVbACg0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAds/Z1gUAAAAAAAAAAGBJBoPB1iXAClihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuOdu6AAAAAAAAAAAALMpg6wJgDazQyAb169fXsGHDbF0GAAAAAAAAAAD/WjQ0ssG6des0adKkTI09d+6cDAaDwsPDrVvUYyxatEj169eXh4eHDAaDYmJisr2GNatXqVmThqpaqYI6d3xWhw4efOT4LZu/VuuWT6lqpQpq36aVfvj+O7PXk5OTNX/ubDWqV1vVKoeob+8e+v33c1ZMkD5ypSAXuayBXCn+Dbl+2bJBs4d00uTuT2nJ2EH68/TxDMce2/ODFr82QG/1eVpTe7bQe6P76uAPW9OMu/rn71ozfYze6p0ybsmYgYqNjLBmjDQcca4kx83VtqK/Pu5dRVuH1NC7z4eojH+eR47P4+KklxoW1/q+VfXNkBpa1bOywop5pzu2c9VC+n54LQ2uX8wapT+So84XuVKQi1zWQK4U/4ZcjphJItcD5CIXgMejoZENfHx85O7ubtFz3rlzx6Ln+6u4uDg99dRTevXVV636PhnZ9PVXmj5tqvoNHKQ1a9crOLi0BvTrraioqHTHh+/fp1dGjlDbds/o4083qEHDRho2eJBOnTppGvPh+4v10aoVGjN+glZ+9Inc3Nw0oG9vJSQkZFcsct1HLnJZA7lS/BtyHdm5Q1tWvqt67bqp7+R35V+0hFa9OUq3Yq+lO94tj7vqtOmsXq/PVb83Fyu0blN9/t40nT7wi2lMdMRFLX19qHwLFlG3sTPU783FqtO2i5xz5MyWTJJjzpXkuLkalvLToHrFtHTXH+qzMlynr97S9Hbl5OWWI93xzkaDZrQvJ38PF4398ri6LN2naVtP6+qNtDWXzp9HT4f46/TVW9aOkYajzhe5UpCLXNZArhT/hlyOmEki1wPkIheAzKGhkQ0evuVUYGCgpkyZol69esnd3V1FixbVokWLTGOLFUu5iq9SpUoyGAyqX7++JKlHjx5q06aNJk+erIIFCyo4OFiSdOjQITVs2FBubm7y9fVV3759dfPmTdP5Hhw3ffp0FShQQL6+vho0aJASExMfWfOwYcP0yiuvKCwszILficxbsexDtXumg9q0ba8SQUEaM/51ubq6asO6z9Idv2rlctWsXUc9evVR8RIl9OKQYSpTtqzWrF4pKaUrvmrFcr3Qb4AaNGysUsGl9cbUabp65Yq2b/uGXOQiF7nIlY25dn71qSo3aK7Q+k8pb+FAteg9TDlcXLT/u03pjg8sG6rSVWsrb6EA+eQvqOrN2it/0eL648Rh05gdH7+voNDqatKpnwoElpRP/oIKrlJTuT3Tv3reGhxxrhw5V4cqBfXl4Qh9feSKfo+O14xvzuj23XtqUT5fuuObl88vD1dnvfp/x3X44g1dvp6gAxeu60xknNk4txxGjW1eStO2ntaN23ezI4oZR50vcpGLXOQil2NmIhe5yAUgq2ho2MCMGTP0xBNPaP/+/Ro4cKAGDBigEydOSJL27NkjSfrmm2906dIlrVu3znTctm3bdOLECW3dulVffvmlbt26paZNm8rb21u//PKL1q5dq2+++UYvvvii2fvt2LFDZ86c0Y4dO7Rs2TItXbpUS5cuzba8WZV4546OHT2isBo1TfuMRqPCwmrq4IH96R5zMDxcYWE1zPbVrFVbB+/fuuvPCxcUGXlV1cNSz+nu7q4KIRUzPKelkSsVuchlaeRKZe+57t1N1KWzJ1WsfGXTPoPRqGLlK+vCqaOPPT45OVm/Hd6nqEsXVLRMhZR9SUk6Fb5bvv6FtXLqKE3v315Lxg7S8V9+tFqOv3LEuZIcN5ez0aBS+fPo199jTPuSJe39PVblCqS/qrZ2CW8duXRDLzUsrg39qmppt1B1qVZYxr88aPClhiW087dr2ns+1noBMuCo80WuVOQil6WRK5W953LETBK5HkYucgHIHBoaNtC8eXMNHDhQQUFBGjVqlPz8/LRjxw5JUt68eSVJvr6+8vf3l4+Pj+m43Llza8mSJSpXrpzKlSun1atX6/bt21q+fLnKly+vhg0bat68eVqxYoUiIlLvGe7t7a158+apdOnSatmypVq0aKFt27ZZJVtCQoKuX79utmV1Kd21mGu6d++efH19zfb7+voqMjIy3WMiIyPl6+uXdnxU5P3Xr6bs88v8OS2NXKnIRS5LI1cqe88VdyNWyUlJaVZO5Pb01s2Y6AyPux13U1N7ttDkbk310duv6qnuL6pEhSckSbeux+jO7Xj99MUaBVWsqi6vvKXSVWvrk1kTdO7YAavmecAR50py3FyebjnkbDToWpz5itXouDvyyZ3+bcoKeLqqXkk/ORkNenn9US3fdUHPVSmobtWLmMY0DPZTqfy5tejHc9YsP0OOOl/kSkUuclkauVLZey5HzCSR62HkIhcsz2AwsGVx+zegoWEDISEhpv82GAzy9/fXlStXHntchQoVlDNn6j+yjx07pooVKyp37tymfbVq1VJSUpJpxYcklStXTk5OTqavCxQoYHq/KVOmKE+ePKbt/Pnz/yjb1KlT5enpaba9/dbUf3ROAABcXHOp39RF6jNpgRp26KUtKxfq3NFwSVJycpIkKbhKTYU1f0b+gUGq/fTzKlUpTHu/+cKGVcORGA0GxcQl6u2tp3Xyyi1tPxmpFbsvqHWIvyQpX56cGlK/mCZ+dVJ37iXbuFoAAAAAcEw0NGwgRw7zh00aDAYlJSU99riHGxeWer/+/fsrPDzctBUsWPBvvccDo0ePVmxsrNk2ctToLJ3D28tbTk5OaR68FBUVJT8/v3SP8fPzU1RUZNrx97vlfn4pK1+iIjN/TksjVypykcvSyJXK3nPlcveUwWhM8wDwW7HXlMfLJ4OjUm5L5eNfSP6BQarRooPKVqurHz//yHROo5OT/AoFmB3jV6ioYqMef8GAJTjiXEmOmys2PlF3k5Llncv8dySfXDkVfetOusdE3bqjP67FK+mhXsXv0XHyzZPTdAsrn9w5taRLqLYPq6ntw2qqUhFPta9UQNuH1UxzayprcNT5IlcqcpHL0siVyt5zOWImiVwPIxe5AGQODQ0782AFxr179x47tkyZMjpw4IBu3bpl2vfTTz/JaDSaHhr+OD4+PgoKCjJtzs7Of6/w+1xcXOTh4WG2ubi4ZOkcOXLmVJmy5bR7107TvqSkJO3evVMhFSule0xIaKh279pltm/Xzp8VEhoqSSpUuLD8/PJq9+7Uc968eVOHDh7I8JyWRq5U5CKXpZErlb3ncnLOoQLFSunskdT7xiYnJenskf0qXLJsps+TnJyse3cTTecsWDxYUZf+MBsTdemCvPzyW6bwx3DEuZIcN9fdpGSdjLipKkU9TfsMkioX9dSRSzfSPebQn9dVyMtVD/clini7KfLmHd1NStbe87Hqvmy/eq8IN23HLt/Q1mNX1XtFuFkjxFocdb7IlYpc5LI0cqWy91yOmEki18PIRS4AmUNDw87ky5dPbm5u2rRpkyIiIhQbm/EDJTt37ixXV1d1795dhw8f1o4dOzR48GB17dpV+fP/sz/gXL58WeHh4Tp9+rQk6dChQwoPD1d0dMb3N7ekrt17at2nn+j/NqzXb2fO6I2JExQfH682bdtJkl4b/bJmvzPDNL5zl276+acftGzpBzr72xktnD9XRw4fVsdOXSSlrErp3LWbFr+3UN9u36ZTJ09ozOiXlTdfPjVs1DhbMpGLXOQiF7lS1Gj+jPbt2KgD32/W1T9/18YPZinx9m2F1msqSdqw4E1tW7PENP7Hz1frzKFfdS3ioq7++bt2bvxEB3/cqgq1G5nG1Gz5nI7s/Fb7tm9U9OU/tWfzBp3ct1NPNH46WzJJjjlXjpzrk70X1bKCv54qm1cBPm4a0biE3HI46asjKat6Xn2qpPrWTl318/mBy/JwddaQBsVU2MtVYcW81aVaYa0PvyRJik+8p7NRcWbb7cQkXb99V2ej4rItl6POF7nIRS5ykcsxM5GLXOQC/v3mz5+vwMBAubq6qnr16tqzZ88jx8+aNUvBwcFyc3NTkSJF9NJLL+n27duZfr9/djk+LM7Z2Vlz5szRxIkTNW7cONWpU0fffvttumNz5cqlzZs3a+jQoapatapy5cql9u3ba+bMmf+4jnfffVevv/666eu6detKkj788EP16NHjH5//cZ5q1lzXoqO1YN4cRUZeVXDpMlrw3hL53l+Wd/nSJRkNqf240EqVNXXadM2bM0tzZ81U0YBAzZo7XyVLljKN6dn7BcXHx2vihHG6ceO6KlWuogXvLcnyChJykYtc5CLXP1OuRgPduh6rbz9dqpsx15Q/oIQ6vfKm8nim3HIqNuqKDA/dn+dOwm19/cEcXY++KuecLvIrWERtB45WuRoNTGNKV62tFr2H6afPP9KmZfPkW7CIOgyboKKlK2RLJskx58qRc20/GSmvXM7qVbOofHLl1Omrt/S/dUdMDwrP7+6i5OTUZRVXbt7R/9Yd1Yv1i+nDbv6KvJmgT/df0upfLmRbzZnhqPNFLnKRi1zkcsxM5CIXuYB/t48//ljDhw/Xu+++q+rVq2vWrFlq2rSpTpw4oXz58qUZv3r1ar3yyiv64IMPVLNmTZ08eVI9evSQwWDI9N+0DckP/0sNsILbd21dAQDAWj47YF9/zLWU9hUL27oEZMGTc36ydQlWsWVILVuXAAAAADvhymXpWeb/wqe2LuFf5/d5rZSQkGC2z8XFJcNGXPXq1VW1alXNmzdPUsrt2ooUKaLBgwfrlVdeSTP+xRdf1LFjx7Rt2zbTvhEjRmj37t368ccfM1Ujt5wCAAAAAAAAAOA/burUqfL09DTbpk6dmu7YO3fuaO/evWrcOPU2akajUY0bN9bOnTvTPaZmzZrau3ev6bZUv/32m7766is1b9480zXS2wMAAAAAAAAA4D9u9OjRGj58uNm+jFZnREZG6t69e2me5Zw/f34dP3483WM6deqkyMhI1a5dW8nJybp796769++vV199NdM1skIDAAAAAAAAAID/OBcXF3l4eJhtlnzuy7fffqspU6ZowYIF2rdvn9atW6eNGzdq0qRJmT4HKzQAAAAAAAAAAECm+fn5ycnJSREREWb7IyIi5O/vn+4xY8eOVdeuXdWnTx9JUoUKFXTr1i317dtXr732mozGx6+/YIUGAAAAAAAAAADItJw5c6pKlSpmD/hOSkrStm3bVKNGjXSPiYuLS9O0cHJykiQlJydn6n1ZoQEAAAAAAAAAcCgGg8HWJTi84cOHq3v37nriiSdUrVo1zZo1S7du3VLPnj0lSd26dVOhQoVMDxZv1aqVZs6cqUqVKql69eo6ffq0xo4dq1atWpkaG49DQwMAAAAAAAAAAGTJc889p6tXr2rcuHG6fPmyQkNDtWnTJtODws+fP2+2ImPMmDEyGAwaM2aM/vzzT+XNm1etWrXS5MmTM/2ehuTMruUA/qbbd21dAQDAWj47cMHWJVhF+4qFbV0CsuDJOT/ZugSr2DKklq1LAAAAgJ1w5bL0LCvQ9zNbl/Cvc2lRe1uX8Fg8QwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j7uvAQAAAAAAAAAcisFgsHUJsAJWaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwe862LgAAAAAAAAAAAIsy2LoAWAMrNAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPWdbFwAAAAAAAAAAgCUZDAZblwArYIUGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B7P0AAAAH9b+4qFbV2CVazef97WJVhFp0pFbV2CVWwZUsvWJVhFi4U7bV2CxW0cUMPWJQAAAAD4F2OFBgAAAAAAAAAAsHus0AAAAAAAAAAAOBSDwWDrEmAFrNAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPecbV0AAAAAAAAAAACWZDAYbF0CrIAVGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsnrOtCwAAAAAAAAAAwKIMti4A1sAKDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z9nWBQAAAAAAAAAAYEkGg8HWJcAKWKEBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO4527oAAAAAAAAAAAAsyWAw2LoEWAErNAAAAAAAAAAAgN2joZFN6tevr2HDhtm6DAAAAAAAAAAA/pVoaGSTdevWadKkSZkae+7cORkMBoWHh1u3qEeIjo7W4MGDFRwcLDc3NxUtWlRDhgxRbGxsttWwZvUqNWvSUFUrVVDnjs/q0MGDjxy/ZfPXat3yKVWtVEHt27TSD99/Z/Z6cnKy5s+drUb1aqta5RD17d1Dv/9+zooJ0keuFOQilzWQK8W/IZcjZpKkfVs/18JhXTS9Z3MtHz9YF88cz3DsiV9+0LKxAzWrbxvN7N1KH77aT4d/3Go25s7teG1dNlfzBz+vGT1baMnLvbV/2xfWjpGGo86Xo+ZqXSG/VnWvpK8HVNe8Z8srOH+eR47PndNJQ+oV0ye9qujrgdW1rEuoqgV4mV5/vkpBze9QQV/0q6ZPez+hiS2CVdjL1cop0nLU+SJXCnKRyxocMZcjZpLI9QC5yAXg8WhoZBMfHx+5u7tb9Jx37tyx6PkedvHiRV28eFHTp0/X4cOHtXTpUm3atEm9e/e22ns+bNPXX2n6tKnqN3CQ1qxdr+Dg0hrQr7eioqLSHR++f59eGTlCbds9o48/3aAGDRtp2OBBOnXqpGnMh+8v1kerVmjM+Ala+dEncnNz04C+vZWQkJAtmSRyPUAuclkDuVL8G3I5YiZJOrbrW21f9Z5qte2iHm8sVL6ixfXJW6N1K/ZauuPdcnuoxtOd1GX8bPWc8p4q1G2qrxZN128HfzGN2b7qXf124Fe1GvCK+kx7X0881U5bl83Tqb0/Z1csh50vR81Vv6Sv+tcJ1PI9F9R/zUGdiYzTW0+XkZdb+o/OczYaNK1NWeX3cNHrX59UjxXhmrH9N0XeSv09M6SQp/7v4GW9uPaQXv78qJyMBk1rXVauztn3TwlHnS9ypSAXuazBEXM5YiaJXA+Qi1wAMoeGRjZ5+JZTgYGBmjJlinr16iV3d3cVLVpUixYtMo0tVqyYJKlSpUoyGAyqX7++JKlHjx5q06aNJk+erIIFCyo4OFiSdOjQITVs2FBubm7y9fVV3759dfPmTdP5Hhw3ffp0FShQQL6+vho0aJASExMzrLd8+fL67LPP1KpVK5UoUUINGzbU5MmT9cUXX+ju3bsW/u6ktWLZh2r3zP+zd9/hUVVrG4efmQwpQAghEUJooSYQEooCARSUIoiCIiAg3SCCygcebCACoogiKtJEIVgRbGCjKmA7UlR6EUQpUgJJSE9Ine+PyCQxCSQ4w2zm/G6vfV2Hvdfa8z5nKWLeWXvfo7t691H9Bg00eeoz8vT01GcrPy12/LL331W7G2/S8PtGql79+nr4/8arcZMmWvHB+5LyuuLL3ntX9z8wRrd06qJGwSF6buYsxZw7p00bv3F4HnKRi1zkIpdrZ5Kkn9d+qma33Kbwjt3lX6OOuo0Yp3IeHtr73fpix9du0kyNWt0o/xp15FstUDd0v1tVa9XTyUP7bWNO/X5ATW/qqtpNmsnnugA173S7qtaurzN/HrpasVx2vVw1V9/m1bVm/zmtPxij4/HpmrP5T2Vk56p7k6rFju/epKoqeVo0ZfUh7T+TrLPJGdpzOkl/xqbZxkz84qDW/xaj4+fT9WdsmmZ9fUTVKnmoYdUKVyuWy64XuchFLnL9r2ciF7nIBaCsaGg4ycsvv6wbbrhBO3fu1IMPPqgxY8bo0KG8H05s375dkvTNN9/ozJkzWrlypW3exo0bdejQIX399df66quvlJqaqm7dusnX11c///yzPv74Y33zzTd6+OGHC33e5s2b9ccff2jz5s1655139Pbbb+vtt98uU82JiYmqVKmSLJbiv+FnL1mZmTp4YL8i2raznTObzYqIaKc9u3cWO2fPrl2KiGhb6Fy79jdqz9+P7Tp18qRiY2PUJiL/nt7e3goLb1biPe2NXPnIRS57I1c+o+dyxUySlJOdpeijh1UntKXtnMlsVlBoS506cuCy861Wq47t26Hz0SdVKyTMdr5GwyY6smOLks/Hymq16viBXYqPPqm6Ydc7JMc/uep6uWoui9mkRlUrasdfCbZzVkk7/kpQk4Didwq3q+urA2eS9X8d6+qTyOu15N5muveGGjKbSv6cCh55fxZMvuD4L7lIrrte5MpHLnLZmyvmcsVMErkKIhe5YH8mk4mjjMe1wLE/mUaJevTooQcffFCS9MQTT+jVV1/V5s2bFRwcrOuuu06S5Ofnp4CAgELzKlSooCVLlsjd3V2StHjxYl24cEHvvvuuKlTI+5bc/Pnz1bNnT7344ouqVq2aJMnX11fz58+Xm5ubQkJCdPvtt2vjxo26//77S1VvbGysnn32WY0aNeqS4zIyMopsnbO6ecjDw6NUnyNJ8QnxysnJkZ+fX6Hzfn5+Onr0zxLr8/PzLzI+Ni727+sxeef8i94zNja21LX9G+TKRy5y2Ru58hk9lytmkqS05ERZc3NVwce30PnyPr6KO/NXifMy0lK1YOwA5WRnyWQ269bh/1eoWdFl6ENaHzVHC/9voMxubjKZzOoe+YhqhYQ7LEtBrrperprLx8siN7NJ8WmFd+HGp2Wplq9XsXOq+3iqRU0PbTwUq4lf/KYalT01rmNduZlNem/7ySLjTZIeuilIe08n6dj5dEfEKMJV14tc+chFLntzxVyumEkiV0HkIheA0mGHhpOEh+f/IMJkMikgIEDnzp277LywsDBbM0OSDh48qGbNmtmaGZLUvn175ebm2nZ8SFJoaKjc3Nxsv65evbrt855//nlVrFjRdpw4caLQZyYlJen2229XkyZNNG3atEvWN3PmTPn4+BQ6Xnpx5mVzAQDwv8jd00sjZizS0Onz1aHfCG1atkgnDuy2Xf91w+c6feSg+vxnuoY9u1C33DtKX78zT8f27XBi1XAlZknx6Vl6ZfMf+j0mVd/+Hqdlv5xSz6bVih3/fzfXVZCfl55b9/vVLRQAAAAAREPDacqVK1fo1yaTSbm5uZedV7BxYa/PGz16tHbt2mU7AgMDbeOSk5PVvXt3eXt7a9WqVUXu808TJ05UYmJioeOxJyaWqVbfyr5yc3Mr8uKluLg4+fv7FzvH399fcXGxRcf/3S3398/b9RIXW/p72hu58pGLXPZGrnxGz+WKmSSpvLePTGZzkReApyXGF9m1UZDJbJZvQA1Vq9NArXv0U3Crm7Tly+WSpKzMDH3/0VJ1GjRaDVq2VdXa9XT9rXcppE1HbV/9sUPzXOSq6+WquRLTs5WTa5Vv+cJ/XvMtX07n04p/d1pcWpZOJqQr15p/7kR8uvwquMvyj+dOje1YVxFBvpqw6kChl4Y7mquuF7nykYtc9uaKuVwxk0SugshFLgClQ0PDgC7uwMjJybns2MaNG2v37t1KTU21nfvvf/8rs9lse2n45VSpUkUNGjSwHRffkZGUlKRbb71V7u7u+uKLL+Tp6XnZe3l4eKhSpUqFjrI8bkqSyrm7q3GTUG3busV2Ljc3V9u2bVF4sxbFzglv3lzbtm4tdG7rlp8U3ry5JKlGzZry979O27bl3zMlJUV79+wu8Z72Rq585CKXvZErn9FzuWImSXKzlFNA3UY6vj//ebjW3Fwd279TNRo0KfV9rFarcrLyfvCcm52t3Jxs/fNlBiazm6zWy38Jwh5cdb1cNVd2rlWHz6WoRU0f2zmTpBa1fHQgOrnYOfvPJKmGj6cK/l1Ws7KnYlMylV2gyzG2Y13dWK+KHl11QNFJGUVv5ECuul7kykcuctmbK+ZyxUwSuQoiF7kAlA4NDQOqWrWqvLy8tG7dOp09e1aJiYkljh00aJA8PT01bNgw7du3T5s3b9bYsWM1ZMgQ2/szrsTFZkZqaqqioqKUlJSk6OhoRUdHl6rR8m8NGTZCKz/5SF98tkp//vGHnps+Tenp6bqr992SpKcmPq7XXn3ZNn7Q4KH66b8/6J23l+ron3/o9QXztH/fPg24d7CkvB0pg4YM1eI3Xte3mzbq98OHNHni47qualV16tzF4XnIRS5ykYtcrp1Jklrd1ke7v12jvd9vUOyp41r/1lxlZVxQWMdukqSvFr2o7z6Mso3f8sVyHd37qxLOnVHsqePavuZj7f/vNwpt31mS5FG+gmqFhOvb5Yt14sBuJZw7o73fr9f+H79WoxtuvGq5XHW9XDXXJ7vO6PbQaro15DrV9vXS+FvqydPipvUH8p7j/ETXBopsW9s2/ou9Z+XtadFDHYJUs7Kn2gRV1r031NDne6NtY/6vY111CfbXjPW/Ky0rR77ly8m3fDm5u129/5Rw1fUiF7nIRa7/9UzkIhe5AJQVLwU3IIvForlz52r69OmaMmWKbrrpJn377bfFji1fvrzWr1+vcePGqVWrVipfvrz69OmjV1555V/VsGPHDm3btk2S1KBBg0LXjh49qqCgoH91/8vpflsPxZ8/r4Xz5yo2NkbBIY218I0l8vt7W170mTMym/L/I7p5i5aaOWu25s+do3lzXlHtOkGaM2+BGjZsZBszIvJ+paena/q0KUpOTlKLltdr4RtLyryDhFzkIhe5yEWm4jSOuFlpSQn68dN3lJoYr6p16uuex5+3PXIqKfacTKb878FnZVzQ12/PVfL5WFncPVQlsJbuGPOkGkfcbBvT6+Gn9N2HUfry9Zm6kJKsSv7VdFO/EWre+Y6rlstV18tVc337e5x8vMppeJta8q1QTn/EpOrJLw4qPj1v50/Viu6yWvN3XsSkZOrJzw9qzE1BWjywmWJTM7Vyd7RW/HrKNubO8ABJ0qt9Qgt91qyvj2j9bzFXIZXrrhe5yEUucv2vZyIXucgFRyr4319wHSZrwf+iARzgQrazKwAAoGw+2HnC2SU4xL0tal9+EAzj9te3XH7QNWb1mLbOLgEAAOCa5MnX0sus7vjVzi7hmnN0zu3OLuGyeOQUAAAAAAAAAAAwPBoaAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI/XyQAAAAAAAAAAXIvJ2QXAEdihAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAzP4uwCAAAAAAAAAACwJ5PJ5OwS4ADs0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGZ3F2AQAAAAAAAAAA2JPJZHJ2CXAAdmgAAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADM/i7AIAAAAAAAAAALAnk8nZFcAR2KEBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8HiHBhxu1d5Tzi7B7nqH1XB2CSiDLnN+cHYJDvHN+JucXQLgsu5tUdvZJQBaPaats0sAAAAAAENhhwYAAAAAAAAAADA8dmgAAAAAAAAAAFyKyWRydglwAHZoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOzOLsAAAAAAAAAAADsyWRydgVwBHZoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOzOLsAAAAAAAAAAADsyWQyObsEOAA7NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDhWZxdAAAAAAAAAAAA9mQyObsCOAI7NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDhWZxdAAAAAAAAAAAA9mQ2m5xdAhyAHRoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6FxDdiyZYvc3Nx0++23F7m2atUqRUREyMfHR97e3goNDdX48eNt13NycvTCCy8oJCREXl5eqlKlitq0aaMlS5Zc8jOtVqumTJmi6tWry8vLS126dNHvv/9u72iXtH39Z3r14YF6dkg3LX7qQZ08crDEsQe2f683Jo3WzPt6asawHnr9ifu1+/sNhcasWviipg3oVOh4b+YTjo5RxIoPlum2rp3UqkWYBg3op7179lxy/Ib1a3XnHd3VqkWY+tzVUz98/12h61arVQvmvabOHW9U65bhGhU5XMePH3NgguK5aq67m1fXx/e30sbx7fXmoGZqHFDxkuMrerjpP53r67PRbbRpfHstv+96RdT1tV2/r11t/fjoTYWOZSOud3SMIlx1vciV51rI5YqZJHJdRC5yOQK58pCLXI5ArjzXQi5XzCSR6yJykQvA5dHQuAZERUVp7Nix+v7773X69Gnb+Y0bN6p///7q06ePtm/frl9//VUzZsxQVlaWbcwzzzyjV199Vc8++6wOHDigzZs3a9SoUUpISLjkZ86aNUtz587VokWLtG3bNlWoUEHdunXThQsXHBWzkH0/bdb6917XzX2H6oGZb6hanfp6f+YTSkmML3a8V4VK6nDXII18dr7GvLhYLTp212eLZunI7p8LjWvQrLUmLPrEdvQdO/lqxLFZt3aNZs+aqQcefEgrPl6l4OAQjXkgUnFxccWO37Vzh558bIJ6391XH37ymW7p1Fnjxz6k338/bBvzVtRiLV/2niZPnab3l38kLy8vjRkVqYyMjKsVy2VzdQr218M319NbW04o8r2dOnIuVa/0barK5csVO95iNunVfmEK8PHU018c1L1Lf9GLG44oNiWz0Lg/Y1PVa+FW2/Hgit1XI46Nq64XufJcC7lcMZNErovIRS5HIFcecpHLEciV51rI5YqZJHJdRC5yASgdk9VqtTq7CJQsJSVF1atX1y+//KKpU6cqPDxckyZNkiSNHz9eu3fv1ubNm0uc37x5c/Xu3VtTp04t9WdarVYFBgZqwoQJevTRRyVJiYmJqlatmt5++20NGDCgTBmW7zxVpvGStPipBxVYP1i33zdOkpSbm6tXH+qv1t1766Y77y3VPRY9OUqNWkSoU//7JOXt0LiQlqKBjz5b5nr+qXdYjSuaN2hAP4U2DdOkyVMk5eW6tXNHDbx3iCLvH1Vk/GMTxis9PV3zF75hOzd44D0KDgnR01Ony2q1qsvNN2no8BEaNiJSkpScnKxOHdpp+owXdFuPort6HMHoubrM+eGKcr05qJkORqfo1Y1/SJJMklY+0Fqf7jyt97efLDL+zmYBurdVTd279Ffl5Bb/W+t97WrrpgZ+GvHuziuqqaBvxt90RfOMvl5XilzXTi5XzEQucpGLXOQiF7nIRSZykYtcjszlabnCcP/DmkzacPlBKOTA87c6u4TLYoeGwX300UcKCQlRcHCwBg8erKVLl+piDyogIED79+/Xvn37SpwfEBCgTZs2KSYmptSfefToUUVHR6tLly62cz4+PmrTpo22bNly5WFKKTs7S6ePHla9sPzH8JjNZtULu14nDx+47Hyr1ao/9+5Q3JmTqtM4vNC1Ywd2adaouzXvkaH6asmrSktOtHv9JcnKzNTBA/sV0bad7ZzZbFZERDvt2V38D7f37NqliIi2hc61a3+j9uzaJUk6dfKkYmNj1CYi/57e3t4KC29W4j3tzVVzWcwmNarmrV+OJ9jOWSX9ciJBoYGVip1zY30/7TudrAmd6+uLMW307vCWGtKmlsymwuNq+nrps9Gt9dHIGzSlR7CqeXs4Lsg/uOp6kSuf0XO5YiaJXAWRi1z2Rq585CKXvZErn9FzuWImiVwFkYtcsD+TiaOsx7WAhobBRUVFafDgwZKk7t27KzExUd99l/dMvrFjx6pVq1YKCwtTUFCQBgwYoKVLlxbauvbKK68oJiZGAQEBCg8P1+jRo7V27dpLfmZ0dLQkqVq1aoXOV6tWzXatJBkZGUpKSip0ZGWWbStdWlKirLm5qujjW+h8BR9fpSScL3HehbQUzRjWQ88OvlXLZk3UbcPHqn74DbbrDZq3Uu8Hn9SwybPV5d5ROnZwj95/4Unl5uaUqb4rFZ8Qr5ycHPn5+RU67+fnp9jY2GLnxMbGys/Pv+j4uNi/r+c1qvz8S39Pe3PVXD5e5WQxm3Q+tfDjos6nZsqvQvGPnAr08dTNjfxlNpv02Mr9envLCQ24oYaGRdS2jTlwJlnPrz2sCZ/s0+xvjqi6j6cWDAyXVzk3h+a5yFXXi1z5jJ7LFTNJ5CqIXOSyN3LlIxe57I1c+YyeyxUzSeQqiFzkAlA6NDQM7NChQ9q+fbsGDhwoSbJYLOrfv7+ioqIkSRUqVNDq1at15MgRTZ48WRUrVtSECRPUunVrpaWlSZKaNGmiffv2aevWrbrvvvt07tw59ezZUyNHjpQkLVu2TBUrVrQdP/xwZY/muWjmzJny8fEpdHy+dP6/umdpuXuW1+gXF+v+Ga+rc/9IrX9voY7u32W7Htauk0JuaK9qteupcasbde/jM3T6j0M6tv/qvr8ArstskhLSMjVrw+86dDZFmw7F6t2tf+nOZtVtY7Yejdfmw7H6IzZN248l6LGV+1TRw6JOwf6XuDMAAAAAAAAAGhoGFhUVpezsbAUGBspischisej111/Xp59+qsTE/Ecl1a9fXyNHjtSSJUu0Y8cOHThwQB9++KHtutlsVqtWrTR+/HitXLlSb7/9tqKionT06FH16tVLu3btsh033HCDAgICJElnz54tVM/Zs2dt10oyceJEJSYmFjruvO/hMuUuX8lHJrO5yAvAUxPjVbFylRLnmc1m+QXUUPWgBmp3xz1q0qajfvz8gxLHV6kWqPLePjp/tuzv+LgSvpV95ebmVuSFUnFxcfL3L/6H2f7+/oqLiy06/u9vAfj7X5d3Lrb097Q3V82VmJ6l7FyrqlRwL3S+SgV3xaVmFTsnNjVLf8Wnq+DrM46fT5N/RXdZ/vncqb+lZOTor/h01fT1slvtl+Kq60WufEbP5YqZJHIVRC5y2Ru58pGLXPZGrnxGz+WKmSRyFUQucgEoHRoaBpWdna13331XL7/8cqGGw+7duxUYGKjly5cXOy8oKEjly5dXampqifdu0qSJJCk1NVXe3t5q0KCB7fDy8lLdunUVEBCgjRs32uYkJSVp27Ztatu2bUm3lSR5eHioUqVKhY5y7mV7P4DFUk6BdRvp6L4dtnO5ubn6c98O1WzUpNT3sVpzlZ1V/A+eJSkxLkZpKUmXbJLYUzl3dzVuEqptW/PfQ5Kbm6tt27YovFmLYueEN2+ubVu3Fjq3dctPCm/eXJJUo2ZN+ftfp23b8u+ZkpKivXt2l3hPe3PVXNm5Vh0+m6zra1e2nTNJur52Ze0/nVTsnL2nElWjspcKti5q+XopNiVD2SW8JNyrnFk1fDwVl5JZ7HV7c9X1Ilc+o+dyxUwSuQoiF7nsjVz5yEUueyNXPqPncsVMErkKIhe5AJSOxdkFoHhfffWV4uPjFRkZKR8fn0LX+vTpo6ioKEVHRystLU09evRQnTp1lJCQoLlz5yorK0tdu3aVJPXt21ft27dXu3btFBAQoKNHj2rixIlq1KiRQkJCiv1sk8mk8ePH67nnnlPDhg1Vt25dPf300woMDNRdd93l6OiSpLa399Oq119QYL1g1WgQoq1rPlVWxgW16NhdkrRywUxVquKvLgPvlyT98NkHCqzXSL7VApWTnaXfd27Tnh++1u2R4yVJGRfS9d0n76hxmw6q6FNF8WdP6+sP3lCVajXUoFmrq5JJkoYMG6GnJz2h0NCmahoWrvffe0fp6em6q/fdkqSnJj6uqlWradwjEyRJgwYPVeTwIXrn7aXq0KGj1q1do/379unpadMl5a3VoCFDtfiN11Wndh3VqFlTC+a9puuqVlWnzl1KrINcpbPil1N66rZg/XY2WQfPJOue62vIq5xZq/fl7V6afFsjxaRk6o0fjkmSPtt9Rn1aBGpcp/r6dOdp1fT11JA2tfTJjtO2ez7Usa7++8d5RSddkH9Fd0W2q6Mcq/TNbzFXLZerrhe5rp1crpiJXOQiF7nIRS5ykYtM5CIXuYyWC3BFNDQMKioqSl26dCnSzJDyGhqzZs3S4MGDtW/fPg0dOlRnz56Vr6+vWrRooQ0bNig4OFiS1K1bNy1fvlwzZ85UYmKiAgIC1KlTJ02bNk0WS8nL//jjjys1NVWjRo1SQkKCbrzxRq1bt06enp4Oy1xQ03a3KDUpQZs/fkspCfEKqFNfg5980babIjH2nEym/A1GmRnpWr30NSXFxcji7iH/wFq6+6FJatruFkl5j6M6e+JP7fp+gy6kpsjb10/1w29Qp3tGyFLOvdgaHKH7bT0Uf/68Fs6fq9jYGAWHNNbCN5bI7+/thtFnzshcIFfzFi01c9ZszZ87R/PmvKLadYI0Z94CNWzYyDZmROT9Sk9P1/RpU5ScnKQWLa/XwjeWyMOjbDtjyFXUpkOxqly+nEa2r6Mq5d11JCZFEz7Zr/i0vJ0/1Sp5FHq81LnkTP3nk336v1vq6e1hLRWbkqGPd5zWsu1/2cZc5+2haXcEq5JnOSWkZ2nPqSQ9sGyXEtJL3k1kb666XuS6dnK5YiZykYtc5CIXuchFLjKRi1zkMlqu/3UmU/GP/8a1zWS1Wot/DgpgJ8t3Xp13VFxNvcNqOLsElEGXOf/uZfdG9c34m5xdAgAAAAAAuAo8+Vp6mTWd/LWzS7jm7Huuq7NLuCzeoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGgAAAAAAAAAAADD43UyAAAAAAAAAACXYjI5uwI4Ajs0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOFZnF0AAAAAAAAAAAD2ZDKZnF0CHIAdGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwLM4uAAAAAAAAAAAAezKZTM4uAQ7ADg0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHg0NAAAAAAAAAABgeBZnFwAAAAAAAAAAgD2ZTM6uAI7ADg0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHi8Fh8P1Dqvh7BLsbs+JRGeX4BDhtX2cXYJDfDP+JmeX4BCNHvnC2SU4xOFXezm7BAAAAAAAABgQDQ0AAAAAAAAAgEsxmUzOLgEOwCOnAAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOFZnF0AAAAAAAAAAAD2ZDI5uwI4Ajs0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOFZnF0AAAAAAAAAAAD2ZDKZnF0CHIAdGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwLM4uAAAAAAAAAAAAezKZnF0BHIEdGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwLM4uAAAAAAAAAAAAezKZTM4uAQ7ADg0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0PjGrBlyxa5ubnp9ttvL3Jt1apVioiIkI+Pj7y9vRUaGqrx48fbrufk5OiFF15QSEiIvLy8VKVKFbVp00ZLliy55GeuXLlSt956q/z8/GQymbRr1y47p7q8FR8s021dO6lVizANGtBPe/fsueT4DevX6s47uqtVizD1uaunfvj+u0LXrVarFsx7TZ073qjWLcM1KnK4jh8/5sAExfv6y4/1yLA7dV+vGzV1/Aj9cWh/iWM3r/1Mzz56vx7o11kP9OusFyY+VGT8yvff1OP391PkXR1sY478ts/RMYpw1fVy1VxDbwrSf6d10eFXbtfnE25SszqVSxz74f+104l5vYocb41uYxtT3PUT83rpgc71r0KafK66Xq6YyxUzSeS6iFzkcgRy5SEXuRyBXHmuhVyumEki10XkIheAy6OhcQ2IiorS2LFj9f333+v06dO28xs3blT//v3Vp08fbd++Xb/++qtmzJihrKws25hnnnlGr776qp599lkdOHBAmzdv1qhRo5SQkHDJz0xNTdWNN96oF1980VGxLmnd2jWaPWumHnjwIa34eJWCg0M05oFIxcXFFTt+184devKxCep9d199+MlnuqVTZ40f+5B+//2wbcxbUYu1fNl7mjx1mt5f/pG8vLw0ZlSkMjIyrlYsbf3ua33w5hz1HjRSz857V7XrNtSsyf+nxITzxY4/uOdXtb25mya98LqmvhKlKtdV06ynxup87DnbmIAatTX0wcc08/Xlenr2m/KvVl2znhqrpIT4qxXLZdfLVXP1bBmop3uHas7aQ7p91nc6eCpR7z8YIb+K7sWOH7XkZ10/ab3t6DJjs7JzcrV6Z/7vRwWvXz9pvSa8v1O5uVat3XXmasVy2fVyxVyumEki10XkIpcjkCsPucjlCOTKcy3kcsVMErkuIhe5AJSOyWq1Wp1dBEqWkpKi6tWr65dfftHUqVMVHh6uSZMmSZLGjx+v3bt3a/PmzSXOb968uXr37q2pU6de0ecfO3ZMdevW1c6dO9W8efMruseF7LLPGTSgn0KbhmnS5CmSpNzcXN3auaMG3jtEkfePKjL+sQnjlZ6ervkL37CdGzzwHgWHhOjpqdNltVrV5eabNHT4CA0bESlJSk5OVqcO7TR9xgu6rUfR3S+XsudEYtlDSZo6foTqNWqiYQ8+Zss1fmhPde11j3reM+yy83NzcvRAvy4a9uCjurFL8TWnp6ZoVN9OevL5+Qpt0bpM9YXX9inT+IuMvl5Xyui5Gj3yxRXl+nzCTdp9IkFTPt4rSTKZpG3Tu+rt749q4ddHLjs/8uZ6+k+PYN0weYPSM3OKHbP4/laq6GHRwPlbylzf4Vd7lXmOZPz1ulKumMsVM5GLXOQiF7nIRS5ykYlc5CKXI3N5Wq4w3P+w1s9/6+wSrjnbJ93s7BIuix0aBvfRRx8pJCREwcHBGjx4sJYuXaqLPaiAgADt379f+/aV/HihgIAAbdq0STExMVer5H8tKzNTBw/sV0TbdrZzZrNZERHttGf3zmLn7Nm1SxERbQuda9f+Ru35+1FZp06eVGxsjNpE5N/T29tbYeHNSrynvWVnZenY778ptHkr2zmz2azQ5q105ODeUt0jI+OCcnKyVcG7UomfsWntZypfoaJq12tkl7ovx1XXy1VzlXMzKayWj348lP97gtUq/XgoVi2DfEt1j/5ta+vLHadKbGb4e3uoU2g1rdhywi41l4arrpcr5nLFTBK5CiIXueyNXPnIRS57I1c+o+dyxUwSuQoiF7kAlA4NDYOLiorS4MGDJUndu3dXYmKivvsu75l8Y8eOVatWrRQWFqagoCANGDBAS5cuLbR17ZVXXlFMTIwCAgIUHh6u0aNHa+3atQ6rNyMjQ0lJSYWOsm6li0+IV05Ojvz8/Aqd9/PzU2xsbLFzYmNj5efnX3R8XOzf1/N+eOvnX/p72ltyUoJyc3Pk41ul0PlKvlWUEF/8FsZ/+nDpfPlW8S+y82Lnth80sndH3XfnjVr/2XI9MWO+vH0q26v0S3LV9XLVXFUquMviZlZsUuF/LmOTM3RdJc/Lzm9Wp7JCAitp+SWaFX1b11LqhWyt2331HjflquvlirlcMZNEroLIRS57I1c+cpHL3siVz+i5XDGTRK6CyEUuAKVDQ8PADh06pO3bt2vgwIGSJIvFov79+ysqKkqSVKFCBa1evVpHjhzR5MmTVbFiRU2YMEGtW7dWWlqaJKlJkybat2+ftm7dqvvuu0/nzp1Tz549NXLkSEnSsmXLVLFiRdvxww8//KuaZ86cKR8fn0LHSy/O/Ff3RJ4vP3pHW7/7WuOmzJK7u0eha42b3aAZC97XlJeXKOz6CM2bObHE93IA/8aAiNo6eCpJu48nlDjmnra1tOqXk8rIzr16hQEAAAAAAMDl0dAwsKioKGVnZyswMFAWi0UWi0Wvv/66Pv30UyUm5r/DoX79+ho5cqSWLFmiHTt26MCBA/rwww9t181ms1q1aqXx48dr5cqVevvttxUVFaWjR4+qV69e2rVrl+244YYb/lXNEydOVGJiYqHjsScmlukevpV95ebmVuTFS3FxcfL39y92jr+/v+LiYouO/7tb7u9/Xd652NLf0968K1WW2eymxPjCjYak+POq7OtXwqw8qz95X1999I4enzFXtes2LHLd09NL1QJrqUHjMN3/yNNyc7Pou/VX9n6FsnLV9XLVXOdTM5Wdkyv/SoWbYv7eHopJunDJuV7ubup5fQ19uOV4iWNa16+iBtW8r+rjpiTXXS9XzOWKmSRyFUQuctkbufKRi1z2Rq58Rs/lipkkchVELnIBKB0aGgaVnZ2td999Vy+//HKhhsPu3bsVGBio5cuXFzsvKChI5cuXV2pqaon3btKkiSQpNTVV3t7eatCgge3w8vL6V3V7eHioUqVKhQ4PD4/LTyygnLu7GjcJ1bat+S8Tzs3N1bZtWxTerEWxc8KbN9e2rVsLndu65SeF//0i8xo1a8rf/zpt25Z/z5SUFO3ds7vEe9qbpVw5BTUM0YFdP9vO5ebmav+uX9SgcViJ8776+F19vjxKjz37muo1alKqz7Lm5io7K/Nf11warrperporK8eqvX8lqn2j/D9AmUxS+0b+2nEs/pJzb28RKHeLWSt/PlnimP5ta2vPiQQdPJVkt5pLw1XXyxVzuWImiVwFkYtc9kaufOQil72RK5/Rc7liJolcBZGLXABKx+LsAlC8r776SvHx8YqMjJSPj0+ha3369FFUVJSio6OVlpamHj16qE6dOkpISNDcuXOVlZWlrl27SpL69u2r9u3bq127dgoICNDRo0c1ceJENWrUSCEhISV+/vnz53XixAmdPn1aUt7jr6S8l4wHBAQ4KHW+IcNG6OlJTyg0tKmahoXr/ffeUXp6uu7qfbck6amJj6tq1Woa98gESdKgwUMVOXyI3nl7qTp06Kh1a9do/759enradEmSyWTSoCFDtfiN11Wndh3VqFlTC+a9puuqVlWnzl0cnuei23rfqzdffkZ1GzZWveBQrf9shTIy0tWh6x2SpEWzp8rXr6r6j3hIkvTVR+/o0/fe1INPPCv/atWVcD6v++/pVV6eXuV14UK6vljxllq2uUmVq/grOSlB33z5ieLjYtT6ps5XLZerrper5lqy+Q+9PLiF9p5I1K7j8Yq8uZ7Ke7jpo61/SZJeHdJC0QkX9OKXBwvNG9C2tjbsiVZCWlax963oadHtzQP13Kr9Ds9QHFddL1fM5YqZyEUucpGLXOQiF7nIRC5ykctouf7XmUwmZ5cAB6ChYVBRUVHq0qVLkWaGlNfQmDVrlgYPHqx9+/Zp6NChOnv2rHx9fdWiRQtt2LBBwcHBkqRu3bpp+fLlmjlzphITExUQEKBOnTpp2rRpslhKXv4vvvhCI0aMsP16wIABkqSpU6dq2rRp9g1bjO639VD8+fNaOH+uYmNjFBzSWAvfWCK/v7flRZ85I7Mpf4NR8xYtNXPWbM2fO0fz5ryi2nWCNGfeAjVs2Mg2ZkTk/UpPT9f0aVOUnJykFi2v18I3lpR5B8m/EdGxq5IT4/Xp+28q8XycatdvpMeefU0+fz9yKu7cWZkK5Nq4eqWys7M0d8aThe7Te9BI3T14lMxms878dUxzv1mt5MQEVazko3qNmmjyS2+qZp36Vy2Xq66Xq+b6csdpVanorv/cHqzrvD104FSShizcqtjkvBeFB/p6KddqLTSnXtUKal3fT4PmbynulpKkXi1ryGSSPv/1lEPrL4mrrpcr5nLFTOQiF7nIRS5ykYtcZCIXuchltFyAKzJZrf/4qRVgZxeynV2B/e05kXj5Qdeg8NpFG2gwrkaPXJ33pFxth1/t5ewSAAAAAAAwFE++ll5mbWZ+5+wSrjnbJnZ0dgmXxTs0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGB5PXwMAAAAAAAAAuBSTydkVwBHYoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6EBAAAAAAAAAAAMz+LsAgAAAAAAAAAAsCeTyeTsEuAA7NAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhmdxdgEAAAAAAAAAANiTyeTsCuAI7NAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhmdxdgEAAAAAAAAAANiTyWRydglwAHZoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOzOLsA4FoUXtvH2SU4xLIdJ5xdgkMMalnb2SU4xOFXezm7BIfouWirs0twiC9HRzi7BAAAAAAA/meYTM6uAI7ADg0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHg0NAAAAAAAAAABgeBZnFwAAAAAAAAAAgD2ZTCZnlwAHYIcGAAAAAAAAAAAwPBoaAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI+GBgAAAAAAAAAAMDyLswsAAAAAAAAAAMCeTCaTs0uAA7BDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABiexdkFAAAAAAAAAABgTyaTsyuAI7BDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABiexdkFAAAAAAAAAABgTyaTydklwAHYoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGhcA7Zs2SI3NzfdfvvtRa6tWrVKERER8vHxkbe3t0JDQzV+/Hjb9ZycHL3wwgsKCQmRl5eXqlSpojZt2mjJkiUlfl5WVpaeeOIJhYWFqUKFCgoMDNTQoUN1+vRpR8Qr0YoPlum2rp3UqkWYBg3op7179lxy/Ib1a3XnHd3VqkWY+tzVUz98/12h61arVQvmvabOHW9U65bhGhU5XMePH3NgguK5aq4dX3+uRY8M1sv39dB7U8fqzB+/lTj28M8/6J0pD+q1B+7Sq5E99fZTD2j/j18XGpN5IV1fvzNPC/9voF6573ZFPRGpnRu/dHSMIlx1vVw1V6+wanpvaAutHt1ac/s2VXDVCpccX8HdTWM7BGnFiJZaPaa13hrcTK3rVLZdH3B9oOb3a6rPR7XSR/ddr2k9GqlmZU8HpyjKFdfLFTNJ5LqIXORyBHLlIRe5HIFcea6FXK6YSSLXReQiF4DLo6FxDYiKitLYsWP1/fffF2oqbNy4Uf3791efPn20fft2/frrr5oxY4aysrJsY5555hm9+uqrevbZZ3XgwAFt3rxZo0aNUkJCQomfl5aWph07dujpp5/Wjh07tHLlSh06dEi9evVyZMxC1q1do9mzZuqBBx/Sio9XKTg4RGMeiFRcXFyx43ft3KEnH5ug3nf31YeffKZbOnXW+LEP6fffD9vGvBW1WMuXvafJU6fp/eUfycvLS2NGRSojI+NqxXLZXAe3fqvNH7yh9r0Ha9izr+u62vX00ayJSk2ML3a8Z8VKatvrXg2e8pqGP/+GmnbopjWLZ+vonp9tYzYtW6Sje37RHWOeVOSLUbq+29365t35+n3HT1crlsuul6vm6tjATw/cWEfv/3xSYz7cqz/jUjWzV2NV9rIUO95iNunFOxurWiUPPbv2sO57f7de3fSnYlMybWPCAyvpi71n9X+f7NOTnx+UxWzSC70ay9Ny9f716Yrr5YqZJHJdRC5yOQK58pCLXI5ArjzXQi5XzCSR6yJykQtA6ZisVqvV2UWgZCkpKapevbp++eUXTZ06VeHh4Zo0aZIkafz48dq9e7c2b95c4vzmzZurd+/emjp16r+q4+eff1br1q11/Phx1a5du0xzL2SX/fMGDein0KZhmjR5iiQpNzdXt3buqIH3DlHk/aOKjH9swnilp6dr/sI3bOcGD7xHwSEhenrqdFmtVnW5+SYNHT5Cw0ZESpKSk5PVqUM7TZ/xgm7rUXT3iyMYPdeyHSeuKNd7U8cqoF4jdR02VpJkzc3V6+PvVcuudymi54BS3ePtyWNUv3kb3dR3uCRp6ZP3KySio9rdNdg25p2nH1S98Fa6qd+IMtU3qGXZ/p61zTP4el0po+fquWjrFeWa27epDp9L0fzvj0mSTJI+GN5Sn+2J1oc7iu4wuyO0qvq1DNR9y3YrJ7d0/yr08bTok5E36D8r92vv6eQy1ffl6Igyjb/I6OtFJnKRi1zkIhe5yEUu/gxFLnKRy/G5PIv/rh4u4ZbXrt6XYl3F5nHtnF3CZbFDw+A++ugjhYSEKDg4WIMHD9bSpUt1sQcVEBCg/fv3a9++fSXODwgI0KZNmxQTE/Ov6khMTJTJZFLlypX/1X1KIyszUwcP7FdE2/x/gMxmsyIi2mnP7p3Fztmza5ciItoWOteu/Y3as2uXJOnUyZOKjY1Rm4j8e3p7eyssvFmJ97Q3V82Vk52l6GOHFRTa0nbOZDarTmhLnT5y4LLzrVarju/fofgzJ1UrOMx2PrBhEx3ZsUXJ52PzxhzYpfPRJxUUdr1DcvyTq66Xq+aymE1qVLWCdvyVaDtnlbTjZKKaBFQsdk7bur46EJ2ssR2D9NF9LfXmwHANvD5QZlPJn1PBw02SlHwlndor4Irr5YqZJHIVRC5y2Ru58pGLXPZGrnxGz+WKmSRyFUQucgEoHRoaBhcVFaXBg/O+od69e3clJibqu+/ynsk3duxYtWrVSmFhYQoKCtKAAQO0dOnSQlvXXnnlFcXExCggIEDh4eEaPXq01q5dW6YaLly4oCeeeEIDBw5UpUqV7BeuBPEJ8crJyZGfn1+h835+foqNjS12TmxsrPz8/IuOj4v9+3peQ8fPv/T3tDdXzZWWnChrbq7K+/gWOl+hkq9SE4p/5JQkZaSl6tWRPfXyiNv0ycuT1XnoQ4WaFV2GPiS/GnX0+riBeWNemqSuw8aqVki4w7IU5Krr5aq5fLwscjObFJ+eVeh8fFqWfMu7FzsnwMdTHer7yWwy6akvD2nZz6fUt0V13XtDjWLHmySNuSlI+04n6dj5dHtHKJYrrpcrZpLIVRC5yGVv5MpHLnLZG7nyGT2XK2aSyFUQucgFoHRoaBjYoUOHtH37dg0cOFCSZLFY1L9/f0VFRUmSKlSooNWrV+vIkSOaPHmyKlasqAkTJqh169ZKS0uTJDVp0kT79u3T1q1bdd999+ncuXPq2bOnRo4cKUlatmyZKlasaDt++OGHQjVkZWXpnnvukdVq1euvv37ZmjMyMpSUlFTo4NmAKI67p5eGz1ikIc/M1019R2jzB4t04uBu2/UdGz7X6SMHdfcj0zV0+kLdcu8off3OPB3bt8OJVcOVmE1SQnqW5mz+U7/HpOq7I3H64JdTuqNptWLHj+1YV0FVymvG+iNXuVIAAAAAAABINDQMLSoqStnZ2QoMDJTFYpHFYtHrr7+uTz/9VImJ+Y9VqV+/vkaOHKklS5Zox44dOnDggD788EPbdbPZrFatWmn8+PFauXKl3n77bUVFReno0aPq1auXdu3aZTtuuOEG27yLzYzjx4/r66+/LtXujJkzZ8rHx6fQ8dKLM8uU27eyr9zc3Iq8eCkuLk7+/v7FzvH391dcXGzR8X93y/39r8s7F1v6e9qbq+Yq7+0jk9mstH+8ADw1KV4VKvuWMCvvsVS+1WqoWp0Gat2jnxq1uklbv1wuScrKzND3Hy9Vp0Gj1aBlW1WtXU8tu96lkDYd9fOajx2a5yJXXS9XzZWYnq2cXKt8vcoVOu9bvpzi0zKLnXM+NUsnEy6o4OszTpy/IL8K7rL847lTD3cIUpugynps1QHFphZ/P0dwxfVyxUwSuQoiF7nsjVz5yEUueyNXPqPncsVMErkKIhe5AJQODQ2Dys7O1rvvvquXX365UMNh9+7dCgwM1PLly4udFxQUpPLlyys1NbXEezdp0kSSlJqaKm9vbzVo0MB2eHl5ScpvZvz+++/65ptvimy7K8nEiROVmJhY6HjsiYllyl7O3V2Nm4Rq29YttnO5ubnatm2Lwpu1KHZOePPm2ra18IuEt275SeHNm0uSatSsKX//67RtW/49U1JStHfP7hLvaW+umsvNUk4BQY10/ED+MyCtubk6vn+nAhs0Kf2NrFblZOU9Lig3J1u5OdkymQr/UNlsdpPVmmuXui/HVdfLVXNl51p1+FyqWtTysZ0zSWpRs5IORKcUO2f/mWQF+niq4N9lNSt7Ki41U9kFuhwPdwhS+3pV9PhnBxWdfHV3nLnierliJolcBZGLXPZGrnzkIpe9kSuf0XO5YiaJXAWRi1wASsfi7AJQvK+++krx8fGKjIyUj49PoWt9+vRRVFSUoqOjlZaWph49eqhOnTpKSEjQ3LlzlZWVpa5du0qS+vbtq/bt26tdu3YKCAjQ0aNHNXHiRDVq1EghISHFfnZWVpb69u2rHTt26KuvvlJOTo6io6MlSVWqVJG7e/HPo5ckDw8PeXh4FDp3Je/OHTJshJ6e9IRCQ5uqaVi43n/vHaWnp+uu3ndLkp6a+LiqVq2mcY9MkCQNGjxUkcOH6J23l6pDh45at3aN9u/bp6enTZckmUwmDRoyVIvfeF11atdRjZo1tWDea7qualV16tyl7AVeIVfNdcNtfbTmzVkKqNtI1esF65f1q5SVcUFhHbpJklYvelEVff3VsX+kJGnrF8sVULeRKlcLVE5Wpv7YvV37//uNug7/P0mSh1cF1QoJ17fLF8vi7qFKflX11297tP/Hr3XLvaOvWi5XXS9XzfXprjN6vEt9HT6XokNnU9S7WXV5Wty0/mDes0sf71JfsamZWrrlL0nSl/vOqld4NT3YIUif7YlWDR9PDbwhUJ/tjrbdc2zHIHVq5K+pqw8pLStHvuXzdoCkZmQrM8datAgHcMX1csVM5CIXuchFLnKRi1xkIhe5yGW0XP/r/vlFWbgGGhoGFRUVpS5duhRpZkh5DY1Zs2Zp8ODB2rdvn4YOHaqzZ8/K19dXLVq00IYNGxQcHCxJ6tatm5YvX66ZM2cqMTFRAQEB6tSpk6ZNmyaLpfjlP3XqlL744gtJUvO/O8sXbd68WTfffLNdsxan+209FH/+vBbOn6vY2BgFhzTWwjeWyO/vbXnRZ87IbMrfYNS8RUvNnDVb8+fO0bw5r6h2nSDNmbdADRs2so0ZEXm/0tPTNX3aFCUnJ6lFy+u18I0lRRow5Cq7xhE3Kz05QT9++o5SE+NVtXZ99XvseVX4+0XhSXHnCv1LJCvjgja8M1cp52NlcfdQleq1dPvoJ9U44mbbmJ4PPaXvP4rSV6/P1IWUZFXyr6ab+o1Q8853XLVcrrperprruyNxquxl0bDWteRboZz+iEnTpC9/U8LfLwqv6u0ha4EeRExKpiZ+8ZvG3FhHbw4IV2xqplbtjtaHO07bxvQKC5AkvXx3aKHPeumbP7ThtxjHh5JrrpcrZiIXuchFLnKRi1zkIhO5yEUuo+UCXJHJarVena+Y4n/WlezQgHMs23HC2SU4xKCWtZ1dAsqg56Ktlx90DfpydISzSwAAAAAAXKM8+Vp6mXWau+Xyg1DIpv9r6+wSLot3aAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8nr4GAAAAAAAAAHApJpOzK4AjsEMDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGJ7F2QUAAAAAAAAAAGBPZpPJ2SXAAdihAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAzP4uwCAAAAAAAAAACwJ5PJ2RXAEdihAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAzP4uwCAAAAAAAAAACwJ5PJ5OwS4ADs0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGZ3F2AQAAAAAAAAAA2JPZ5OwK4Ag0NIAr8OAne51dgkMs7Bvm7BIcYvqGw84uwSGm3NrI2SU4xJejI5xdAgAAAAAAAAyIR04BAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8HgpOAAAAAAAAADApZhMJmeXAAdghwYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAoswULFigoKEienp5q06aNtm/ffsnxCQkJeuihh1S9enV5eHioUaNGWrNmTak/z/JvCwYAAAAAAAAAwEhMJmdX4Po+/PBD/ec//9GiRYvUpk0bzZkzR926ddOhQ4dUtWrVIuMzMzPVtWtXVa1aVZ988olq1Kih48ePq3LlyqX+TBoaAAAAAAAAAAD8j8vIyFBGRkahcx4eHvLw8Ch2/CuvvKL7779fI0aMkCQtWrRIq1ev1tKlS/Xkk08WGb906VKdP39eP/30k8qVKydJCgoKKlONPHIKAAAAAAAAAID/cTNnzpSPj0+hY+bMmcWOzczM1K+//qouXbrYzpnNZnXp0kVbtmwpds4XX3yhtm3b6qGHHlK1atXUtGlTPf/888rJySl1jezQAAAAAAAAAADgf9zEiRP1n//8p9C5knZnxMbGKicnR9WqVSt0vlq1avrtt9+KnfPnn39q06ZNGjRokNasWaMjR47owQcfVFZWlqZOnVqqGmloAAAAAAAAAADwP+5Sj5eyh9zcXFWtWlVvvvmm3NzcdP311+vUqVN66aWXaGgAAAAAAAAAAAD78/f3l5ubm86ePVvo/NmzZxUQEFDsnOrVq6tcuXJyc3OznWvcuLGio6OVmZkpd3f3y34u79AAAAAAAAAAALgUE3+V+a+ycHd31/XXX6+NGzfazuXm5mrjxo1q27ZtsXPat2+vI0eOKDc313bu8OHDql69eqmaGRINDQAAAAAAAAAAUEb/+c9/tHjxYr3zzjs6ePCgxowZo9TUVI0YMUKSNHToUE2cONE2fsyYMTp//rzGjRunw4cPa/Xq1Xr++ef10EMPlfozeeQUAAAAAAAAAAAok/79+ysmJkZTpkxRdHS0mjdvrnXr1tleFH7ixAmZzfl7KmrVqqX169frkUceUXh4uGrUqKFx48bpiSeeKPVn0tAAAAAAAAAAAABl9vDDD+vhhx8u9tq3335b5Fzbtm21devWK/48HjkFAAAAAAAAAAAMj4YGAAAAAAAAAAAwPB45BQAAAAAAAABwKWaTsyuAI7BDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHg0NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQ8Oghg8fLpPJJJPJpHLlyqlatWrq2rWrli5dqtzcXNu43bt3q1evXqpatao8PT0VFBSk/v3769y5c7Yxq1atUkREhHx8fOTt7a3Q0FCNHz/+sjV8/PHHCgkJkaenp8LCwrRmzRpHRC3Rig+W6baundSqRZgGDeinvXv2XHL8hvVrdecd3dWqRZj63NVTP3z/XaHrVqtVC+a9ps4db1TrluEaFTlcx48fc2CC4nVqUEWzegbrjX6hmty1vupW8SpxbPu6lbV0QFih441+oYXG3Nm0qmb0aKjX+4Zq3t1N9OjNdVXvEvd0FFddrz9+XK210yO16rG7tenVCTp//HCp5v2143t9+khP/RT1XKHznz7Ss9jj0KaVjii/RK66XuTKcy3kcsVMErkuIhe5HIFcechFLkcgV55rIZcrZpLIdRG5yAXg8mhoGFj37t115swZHTt2TGvXrtUtt9yicePG6Y477lB2drZiYmLUuXNnValSRevXr9fBgwf11ltvKTAwUKmpqZKkjRs3qn///urTp4+2b9+uX3/9VTNmzFBWVtYlP/unn37SwIEDFRkZqZ07d+quu+7SXXfdpX379l2N6Fq3do1mz5qpBx58SCs+XqXg4BCNeSBScXFxxY7ftXOHnnxsgnrf3VcffvKZbunUWePHPqTff8//4fNbUYu1fNl7mjx1mt5f/pG8vLw0ZlSkMjIyrkomSWpVy0f9W1TXF/vO6Zn1R/RXwgX95+a68vZwK3FOWmaOxn920HY89sWhQtejkzO07NfTmrL2sGZ+84diUzMve097c9X1+mvnD9rz2RI17jZQnSfMkU9gXf34xhRdSE645LzU82e194ul8q8XWuTa7c+8W+i4fsA4yWRSjfB2DkpRlKuuF7nyXAu5XDGTRK6LyEUuRyBXHnKRyxHIledayOWKmSRyXUQucsH+Ln5ZnKP0x7XAZLVarc4uAkUNHz5cCQkJ+uyzzwqd37Rpkzp37qzFixfL399f/fr1U3p6uiwWS7H3GT9+vHbv3q3NmzeX6fP79++v1NRUffXVV7ZzERERat68uRYtWlSme13ILtNwSdKgAf0U2jRMkyZPkSTl5ubq1s4dNfDeIYq8f1SR8Y9NGK/09HTNX/iG7dzggfcoOCRET0+dLqvVqi4336Shw0do2IhISVJycrI6dWin6TNe0G09bi9TfQ9+srfsoSRN7lpfR+PStWzHaUmSSdLsXiHa+Huc1hyMKTK+fd3KGtgiUA+vPFDqz/C0mLWwb6he2vynDp5NLVN9C/uGlWn8RUZfr+kbSrer4p82vTpBvrUbqkWf0ZIka26u1kwfoQY33qHgLv2KnWPNzdF38yaqTpsuivtzvzLTU9UucnKJn/FT1HPKzkhXhwdnlLm+Kbc2KvMcyfjrdaXIde3kcsVM5CIXuchFLnKRi1xkIhe5yOXIXJ7F/+gPl3Dn4l+cXcI15/P7b3B2CZfFDo1rTKdOndSsWTOtXLlSAQEBys7O1qpVq1RSXyogIED79+8v886KLVu2qEuXLoXOdevWTVu2bLni2ksrKzNTBw/sV0Tb/G+sm81mRUS0057dO4uds2fXLkVEtC10rl37G7Vn1y5J0qmTJxUbG6M2Efn39Pb2Vlh4sxLvaW9uZpPq+HrpwNkU2zmrpANnU1Tfr3yJ8zwsZs3qGazZvYI19sY6CqzkccnP6Fi/itIyc/RX/AV7ll8iV12v3OwsJZw8oqqNmtnOmcxmVW3YXHHHD5U47+D6FfLw9lHdiFsv+xkXkuMVfeAXBbXpapeaS8NV14tc+YyeyxUzSeQqiFzksjdy5SMXueyNXPmMnssVM0nkKohc5AJQOjQ0rkEhISE6duyYIiIiNGnSJN17773y9/fXbbfdppdeeklnz561jR07dqxatWqlsLAwBQUFacCAAVq6dOllt7dFR0erWrVqhc5Vq1ZN0dHRDslUUHxCvHJycuTn51fovJ+fn2JjY4udExsbKz8//6Lj42L/vp63+8HPv/T3tDdvdze5mU1K+seWlaQL2fLxKr7NHp2Uqbe2n9S8H47rzS0nZTJJk7rUl+8/xjcL9NbCPk30Rr9Q3Rrsr9nfHlVKZo7DshTkquuVkZoka26uPL19C5339K6sC0nxxc6J/XO/jm37Wi3vebhUn3F8+yZZPL2u6uOmXHW9yJXP6LlcMZNEroLIRS57I1c+cpHL3siVz+i5XDGTRK6CyEUuAKVDQ+MaZLVabc80mzFjhqKjo7Vo0SKFhoZq0aJFCgkJ0d69eY9EqlChglavXq0jR45o8uTJqlixoiZMmKDWrVsrLS1NJ06cUMWKFW3H888//69qy8jIUFJSUqGDZwNeuT/i0vTTsQT9lXBBh2NSteDH40rOyNbNDQr/C/Hg2RRNW39Ez3/zh/ZFJ2tMu9pX9R0akLIupOnnZa+oZf+H5VHRp1Rzjm3/WrVb3iy3cu4Org4AAAAAAAC49tHQuAYdPHhQdevWtf3az89P/fr10+zZs3Xw4EEFBgZq9uzZhebUr19fI0eO1JIlS7Rjxw4dOHBAH374oQIDA7Vr1y7bMXp03rsCAgICCu30kKSzZ88qICDgkrXNnDlTPj4+hY6XXpxZpny+lX3l5uZW5MVLcXFx8vf3L3aOv7+/4uJii47/u1vu739d3rnY0t/T3pIzc5STa1Wlfzz0sJKnRYnppXvRSI5VOhF/QVUrFv4BeGaOVedSMvVnXLre2n5KuVarbqpXxW61X4qrrpdHhUoymc26kFx4N8aF5AR5VvItMj41Llpp58/ppyXPauWEO7Vywp06/stmndm/XSsn3KmU2DOFxsf+sV8p504pqBSPprInV10vcuUzei5XzCSRqyBykcveyJWPXOSyN3LlM3ouV8wkkasgcpELQOnQ0LjGbNq0SXv37lWfPn2Kve7u7q769esrNbXkl0EHBQWpfPnySk1NlcViUYMGDWxHlSp5PwRv27atNm7cWGje119/rbZt2xZ3S5uJEycqMTGx0PHYExPLlLGcu7saNwnVtq357+vIzc3Vtm1bFN6sRbFzwps317atWwud27rlJ4U3by5JqlGzpvz9r9O2bfn3TElJ0d49u0u8p73l5Fp1PD5djatVsJ0zSWpcraL+iEsr1T1MJqlmZQ8lXKYBYjJJ5dxM/6bcUnPV9TJbyqlyzQaKObzHds6am6uY33fLr05wkfHeVWuqy+Pz1fnRubajemhrXdcgTJ0fnavylQv/geXYtg2qXLOBKteoW+RejuSq60WufEbP5YqZJHIVRC5y2Ru58pGLXPZGrnxGz+WKmSRyFUQucsH+TCaOsh7XguIf3A9DyMjIUHR0tHJycnT27FmtW7dOM2fO1B133KGhQ4fqq6++0ooVKzRgwAA1atRIVqtVX375pdasWaO33npLkjRt2jSlpaWpR48eqlOnjhISEjR37lxlZWWpa9eSX0Q8btw4dezYUS+//LJuv/12rVixQr/88ovefPPNS9bs4eEhD4/CL62+ULrNB4UMGTZCT096QqGhTdU0LFzvv/eO0tPTdVfvuyVJT018XFWrVtO4RyZIkgYNHqrI4UP0zttL1aFDR61bu0b79+3T09OmS5JMJpMGDRmqxW+8rjq166hGzZpaMO81XVe1qjp17lJiHfa2/rdYjYyoqWPn03X0fLq6NvKTh8WsH//M2wUwsk1Nxadn6dM9ebtjeoZW1Z9xaTqXnCEvdzfdFnKd/Mq764c/z0uS3N1MuiO0qnadSlJierYqeripU0M/+XqV088nEq9aLlddr4Y336VfPnhVvrUayLdOIx357nNlZ15QnTZ5Nfy87BV5+fip6R3D5FbOXT7V6xSa7+6V17z65/msC2k6ufu/Cu8VeXWC/IOrrhe5rp1crpiJXOQiF7nIRS5ykYtM5CIXuYyWC3BFNDQMbN26dapevbosFot8fX3VrFkzzZ07V8OGDZPZbFaTJk1Uvnx5TZgwQX/99Zc8PDzUsGFDLVmyREOGDJEkdezYUQsWLNDQoUN19uxZ+fr6qkWLFtqwYYOCg4t+y/yidu3a6YMPPtDkyZM1adIkNWzYUJ999pmaNm16VbJ3v62H4s+f18L5cxUbG6PgkMZa+MYS+f29LS/6zBmZTfkbjJq3aKmZs2Zr/tw5mjfnFdWuE6Q58xaoYcNGtjEjIu9Xenq6pk+bouTkJLVoeb0WvrGkSAPGkX7+K1HenhbdFVZNPp4W/ZVwQa9+e1RJGXldnyoVyim3wPgK7m4a1qqGfDwtSsvM0bH4dD3/zR86nZT3XpJcq1Td20Pt29dRRQ83pWbm6GhcumZu/NM25mpw1fWq1eImZaQk6sC6ZbqQFC+fGvV04wPP2F4UnhYfY3ufTVn8teN7yWpVrZYd7F1yqbjqepHr2snlipnIRS5ykYtc5CIXuchELnKRy2i5AFdkslqtVmcXAdd2JTs0jO7BT/Y6uwSHWNg3zNklOMT0DYedXYJDTLm10eUHAQAAAACAa54nX0svs7uW/OLsEq45n428wdklXBbv0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgem5UAAAAAAAAAAC7FfAXvPYXxsUMDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGJ7F2QUAAAAAAAAAAGBPJpOzK4AjsEMDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGJ7F2QUAAAAAAAAAAGBPJpPJ2SXAAdihAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAzP4uwCAAAAAAAAAACwJ5PJ2RXAEdihAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAzP4uwCAAAAAAAAAACwJ7PJ5OwS4ADs0AAAAAAAAAAAAIbHDg3gCizsG+bsEhwifNI6Z5fgEHue7+7sEhxi+5/nnV2CQ7SuV8XZJQAAAAAAAMCA2KEBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8HiHBgAAAAAAAADApZicXQAcgh0aAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADI+GBgAAAAAAAAAAMDwaGgAAAAAAAAAAwPAszi4AAAAAAAAAAAB7MplMzi4BDsAODQAAAAAAAAAAYHg0NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4FmcXAAAAAAAAAACAPZlNzq4AjsAODQAAAAAAAAAAYHg0NAAAAAAAAAAAgOHR0AAAAAAAAAAAAIZHQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4FmcXAAAAAAAAAACAPZlMJmeXAAdghwYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaBjV8+HCZTCaZTCaVK1dO1apVU9euXbV06VLl5ubaxu3evVu9evVS1apV5enpqaCgIPXv31/nzp2zjVm1apUiIiLk4+Mjb29vhYaGavz48Zf8/P3796tPnz4KCgqSyWTSnDlzHJS0ZCs+WKbbunZSqxZhGjSgn/bu2XPJ8RvWr9Wdd3RXqxZh6nNXT/3w/XeFrlutVi2Y95o6d7xRrVuGa1TkcB0/fsyBCYrnqrkGta2tTU921N4ZXfXxwxEKr+VT4tj3Hmitw7O6FzneHNHSNmZs1wZa9+iN2vVcF/08rbPevv+GS97TUVx1vTav/kRPRvbWmLs76vkJkTp6eH+JY79f/7lefGK0xg24VeMG3KpXJo8tMv7+nm2LPdavfN/RUQpx1fVyxVyumEki10XkIpcjkCsPucjlCOTKcy3kcsVMErkuIhe5YF8mE0dZj2sBDQ0D6969u86cOaNjx45p7dq1uuWWWzRu3Djdcccdys7OVkxMjDp37qwqVapo/fr1OnjwoN566y0FBgYqNTVVkrRx40b1799fffr00fbt2/Xrr79qxowZysrKuuRnp6WlqV69enrhhRcUEBBwNeIWsm7tGs2eNVMPPPiQVny8SsHBIRrzQKTi4uKKHb9r5w49+dgE9b67rz785DPd0qmzxo99SL//ftg25q2oxVq+7D1NnjpN7y//SF5eXhozKlIZGRlXK5bL5urRLEATe4Zo/jdHdNdrP+m3M8mKirxBVSq4Fzv+4Xd3qt30Tbajx8s/KjsnV2v3nLWNORqTqumfHVTPV/6rga9v06n4dL018gb5Vih3tWK57Hr9/MM3+mjJXPUcGKmn57ytmnUbas6UR5SUcL7Y8Yf27lDrDl014fn5evKlN+XrX02vThmv+Lj8xunsd78qdAwf95RMJpNatrvlasVy2fVyxVyumEki10XkIpcjkCsPucjlCOTKcy3kcsVMErkuIhe5AJSOyWq1Wp1dBIoaPny4EhIS9NlnnxU6v2nTJnXu3FmLFy+Wv7+/+vXrp/T0dFkslmLvM378eO3evVubN2++4lqCgoI0fvz4y+7qKMmF7LLPGTSgn0KbhmnS5CmSpNzcXN3auaMG3jtEkfePKjL+sQnjlZ6ervkL37CdGzzwHgWHhOjpqdNltVrV5eabNHT4CA0bESlJSk5OVqcO7TR9xgu6rcftV5TN1XKFT1p3Rbk+fjhCe/9K1PTPD0rK6+h+P+lmvfff43rz26OXnT/sxjoad2tDtX92s9KzcoodU8HDTTuf7aphb27XliPF/+C9JHue716m8RcZfb22/1m2/x8uen5CpIIaNta9ox+15XpixJ3qdEc/3dZv6GXn5+bkaNzAWzVw9AS169Sj2DELnntCF9JTNWHG/DLX17pelTLPkYy/XlfKFXO5YiZykYtc5CIXuchFLjKRi1zkcmQuz+J/9IdLGLJst7NLuOa8N6iZs0u4LHZoXGM6deqkZs2aaeXKlQoICFB2drZWrVqlkvpSAQEB2r9/v/bt23eVK71yWZmZOnhgvyLatrOdM5vNiohopz27dxY7Z8+uXYqIaFvoXLv2N2rPrl2SpFMnTyo2NkZtIvLv6e3trbDwZiXe095cNVc5N5NCa1TST0fyv7VgtUo//R6n5nUql+oefVvV1OrdZ0psZpRzM6l/m1pKSs/Sb6eT7VH2ZbnqemVnZen4kUNq3KyV7ZzZbFbj5q30x6HS/T6RmXFBOTnZqlCxUrHXk+LPa+8v/9WNXXvapebScNX1csVcrphJIldB5CKXvZErH7nIZW/kymf0XK6YSSJXQeQiF4DSoaFxDQoJCdGxY8cUERGhSZMm6d5775W/v79uu+02vfTSSzp7Nv+xPWPHjlWrVq0UFhamoKAgDRgwQEuXLjX09rb4hHjl5OTIz8+v0Hk/Pz/FxsYWOyc2NlZ+fv5Fx8fF/n09Ju+cf+nvaW+umsu3grssbmbFJmcWOh+bkqHrvD0uOz+8lo+Cq3vr4+0ni1y7ufF12vlsF+2dcatG3BSkEYt/VnzapR+XZi+uul4pSQnKzc1RJd/CuyAqVa6ipPjit9L+06dvL1TlKtepSfNWxV7/adMaeXiVV8t2N//bckvNVdfLFXO5YiaJXAWRi1z2Rq585CKXvZErn9FzuWImiVwFkYtcAEqHhsY1yGq1yvT3W1pmzJih6OhoLVq0SKGhoVq0aJFCQkK0d+9eSVKFChW0evVqHTlyRJMnT1bFihU1YcIEtW7dWmlpaTpx4oQqVqxoO55//vl/VVtGRoaSkpIKHUZunsD5+raqqd/OJGvPX4lFrm07cl53zvlJ/Rdu1feHYjVncPMS38uBq2Ptx+9q+w9f68FJL6ice/ENq/9+/aXa3NytxOsAAAAAAADAlaChcQ06ePCg6tata/u1n5+f+vXrp9mzZ+vgwYMKDAzU7NmzC82pX7++Ro4cqSVLlmjHjh06cOCAPvzwQwUGBmrXrl22Y/To0f+qtpkzZ8rHx6fQ8dKLM8t0D9/KvnJzcyvy4qW4uDj5+/sXO8ff319xcbFFx//dLff3vy7vXGzp72lvrporPjVT2Tm58vcu3Gjwr+ihmORLN7O8yrnp9mYB+qSY3RmSlJ6VoxNxadp9IlFPfbJPOblW9Wtd0261X4qrrlfFSpVlNrspKb7w+zeSEs6rkq9fCbPyrF+5TGs/fU+PTH9NNes2KHbM4f27FH3qhG66tZfdai4NV10vV8zlipkkchVELnLZG7nykYtc9kaufEbP5YqZJHIVRC5ywf5MJhNHGY9rAQ2Na8ymTZu0d+9e9enTp9jr7u7uql+/vlJTU0u8R1BQkMqXL6/U1FRZLBY1aNDAdlSpcmUv471o4sSJSkxMLHQ89sTEMt2jnLu7GjcJ1batW2zncnNztW3bFoU3a1HsnPDmzbVt69ZC57Zu+UnhzZtLkmrUrCl//+u0bVv+PVNSUrR3z+4S72lvrporK8eq/aeS1LZB/g/DTSapbQM/7TqecMm53cMD5G4x64udp0v1WWaTSe6Wq/Pblquul6VcOdVpEKyDe36xncvNzdXB3b+ofnDTEuet+/R9rf7wLY2b9qqCGjYucdyPG75UnQYhqlW3oV3rvhxXXS9XzOWKmSRyFUQuctkbufKRi1z2Rq58Rs/lipkkchVELnIBKB2LswtAyTIyMhQdHa2cnBydPXtW69at08yZM3XHHXdo6NCh+uqrr7RixQoNGDBAjRo1ktVq1Zdffqk1a9borbfekiRNmzZNaWlp6tGjh+rUqaOEhATNnTtXWVlZ6tq1a4mfnZmZqQMHDtj+96lTp7Rr1y5VrFhRDRoU/81sSfLw8JCHR+HHzFzILnv2IcNG6OlJTyg0tKmahoXr/ffeUXp6uu7qfbck6amJj6tq1Woa98gESdKgwUMVOXyI3nl7qTp06Kh1a9do/759enradEl5HdlBQ4Zq8Ruvq07tOqpRs6YWzHtN11Wtqk6du5S9wCvkqrne+uGYXrwnTPtOJmrPX4kadmOQvNzd9OkvpyRJs/qH6Wxihl5ed7jQvH6ta+ib/eeU8I/3YniVc9OYzvW08cA5xSRlyLeCuwa1q61qlTy0dk/0VcvlquvV9a6BWvrqswpqEKK6jUL1zecrlHnhgtp3uUOSFPXKM/L1u053D3tQkrT2k/f0xbLFGvnoM/KvVl2Jf79rw8PTS55e5W33TU9L1a//3aR+kWOvWpaCXHW9XDGXK2YiF7nIRS5ykYtc5CITuchFLqPlAlwRDQ0DW7dunapXry6LxSJfX181a9ZMc+fO1bBhw2Q2m9WkSROVL19eEyZM0F9//SUPDw81bNhQS5Ys0ZAhQyRJHTt21IIFCzR06FCdPXtWvr6+atGihTZs2KDg4OASP/v06dNq0SK/Yzx79mzNnj1bHTt21Lfffuvo6Op+Ww/Fnz+vhfPnKjY2RsEhjbXwjSXy+3tbXvSZMzKb8r+p37xFS82cNVvz587RvDmvqHadIM2Zt0ANGzayjRkReb/S09M1fdoUJScnqUXL67XwjSVFGjDkKrs1u6NVpYK7/u/WhrrO20MHTycpMuoXxaXkvSi8emUv5VoLz6l7XQXdULeKhi/+ucj9cqxW1buugnoPaSHfCu6KT8vU3r8Sde/r23TkbMrViCTJdder1U1dlJwYr8+XLVFSfJxq1Wuocc+8antR+PmYszIVyPXd2pXKzs7SohcmFbpPz4GR6nXvSNuvf/7+a8lqVesOt16dIP/gquvlirlcMRO5yEUucpGLXOQiF5nIRS5yGS0X4IpMVqvVevlhwJW7kh0acI7wSeucXYJD7Hm+u7NLcIjtf56//KBrUOt6/+7RdwAAAAAAuBpPvpZeZkM/2OPsEq45794b7uwSLot3aAAAAAAAAAAAAMOjtwcAAAAAAAAAcClmk7MrgCOwQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYnsXZBQAAAAAAAAAAYE8mk8nZJcAB2KEBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADM/i7AIAAAAAAAAAALAnk7MLgEOwQwMAAAAAAAAAABgeDQ0AAAAAAAAAAGB4NDQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYnsXZBQAAAAAAAAAAYE9mk8nZJcAB2KEBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8GhoAAAAAAAAAAAAw6OhAQAAAAAAAAAADM/i7AIAAAAAAAAAALAnk8nZFcAR2KEBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPB45BYe78YXNzi7B7n588hZnl+AQe57v7uwSUAat61VxdgkOsf5gtLNLcIhujQOcXQIAAAAAAMA1jR0aAAAAAAAAAADA8GhoAAAAAAAAAAAAw+ORUwAAAAAAAAAAl2IymZxdAhyAHRoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8CzOLgAAAAAAAAAAAHsymZxdARyBHRoAAAAAAAAAAMDwaGgAAAAAAAAAAADDo6EBAAAAAAAAAAAMj4YGAAAAAAAAAAAwPBoaAAAAAAAAAADA8CzOLgAAAAAAAAAAAHsym0zOLgEOwA4NAAAAAAAAAABgeDQ0AAAAAAAAAACA4dHQAAAAAAAAAAAAhkdDAwAAAAAAAAAAGB4NDQAAAAAAAAAAYHhX1ND44YcfNHjwYLVt21anTp2SJL333nv68ccf7VocAAAAAAAAAABlZTJxlPW4FpS5ofHpp5+qW7du8vLy0s6dO5WRkSFJSkxM1PPPP2/3AgEAAAAAAAAAAMrc0Hjuuee0aNEiLV68WOXKlbOdb9++vXbs2GHX4gAAAAAAAAAAAKQraGgcOnRIHTp0KHLex8dHCQkJ9qgJAAAAAAAAAACgkDI3NAICAnTkyJEi53/88UfVq1fPLkUBAAAAAAAAAAAUVOaGxv33369x48Zp27ZtMplMOn36tJYtW6ZHH31UY8aMcUSNAAAAAAAAAADgf5ylrBOefPJJ5ebmqnPnzkpLS1OHDh3k4eGhRx99VGPHjnVEjQAAAAAAAAAAlJrJZHJ2CXCAMu/QMJlMeuqpp3T+/Hnt27dPW7duVUxMjJ599llH1Pc/a/jw4TKZTDKZTCpXrpyqVaumrl27aunSpcrNzbWN2717t3r16qWqVavK09NTQUFB6t+/v86dO2cbs2rVKkVERMjHx0fe3t4KDQ3V+PHjL/n5ixcv1k033SRfX1/5+vqqS5cu2r59u6PiFqvf9TX0xcMR+u+THfT2iOsVGuh9yfEVPSx6vHtDrRvXTj892VGfjmmj9vWr2K6bTdLojnX1+cMR+vGJDvrsoQhF3ljH0TGKWPHBMt3WtZNatQjToAH9tHfPnkuO37B+re68o7tatQhTn7t66ofvvyt03Wq1asG819S5441q3TJcoyKH6/jxYw5MUDxy5SGXc3P9tHaVZo7pr0kDu2rek6N14veDJY7du/V7vfb4KE0ZerueGtRNrz4aqV+/W2+7npOdrTXvLdIr/xmupwZ107P3360Vc2co8Xzs1YhSiCuulytmksh1EbnI5QjkykMucjkCufJcC7lcMZNErovIRS4Al1fmhsZF7u7uatKkiVq3bq2KFSvasyb8rXv37jpz5oyOHTumtWvX6pZbbtG4ceN0xx13KDs7WzExMercubOqVKmi9evX6+DBg3rrrbcUGBio1NRUSdLGjRvVv39/9enTR9u3b9evv/6qGTNmKCsr65Kf/e2332rgwIHavHmztmzZolq1aunWW2/VqVOnrkZ0dW1SVY90baDFPxzT4CW/6PDZFM0b2Ey+5csVO95iNmnBoGYK9PHSE5/uV5/Xt2nG6kM6l5xhGzOsXR31vT5Qs9b9rn6Ltmvexj80tG1t9W9V46pkkqR1a9do9qyZeuDBh7Ti41UKDg7RmAciFRcXV+z4XTt36MnHJqj33X314Sef6ZZOnTV+7EP6/ffDtjFvRS3W8mXvafLUaXp/+Ufy8vLSmFGRysjIKPaejkCuPORybq5d/92kL99ZoC79hmncrMWqHlRfUc89qpTE+GLHl6/orc59Buuh5xfoPy8vVatbbtPHC17UoV15zdvMjAs6dfSwOvcdqnGzFmvoY88q5vRfevuFSVctk+Sa6+WKmSRyXUQucjkCufKQi1yOQK4810IuV8wkkesicpELQOmYrFartSwTbrnllktu19m0adO/Lgp5OzQSEhL02WefFTq/adMmde7cWYsXL5a/v7/69eun9PR0WSzFPz1s/Pjx2r17tzZv3vyv6snJyZGvr6/mz5+voUOHlmnuDc+V/bPfHnG9DpxO0qz1v0uSTJJW/187ffjLSb3z04ki4/u0DNSQtrXV5/Vtyskt/m/pV/uH6Xxqpp796pDt3Kw+obqQnaspn5f8Le7i/PjkLWUaf9GgAf0U2jRMkyZPkSTl5ubq1s4dNfDeIYq8f1SR8Y9NGK/09HTNX/iG7dzggfcoOCRET0+dLqvVqi4336Shw0do2IhISVJycrI6dWin6TNe0G09br+iOslFLmfmWn8w+opyzXtytGo1CNFdI8fbcj0/up/a33a3buk9qFT3mPPYSDVu2VbdBkYWe/2vIwc178nRmvj6R/K9rlqZ6uvWOKBM4y8y+nqRiVzkIhe5yEUucpGLP0ORi1zkcnwuzzK/OAAPrSrbz/sgLejd2NklXFaZd2g0b95czZo1sx1NmjRRZmamduzYobCwMEfUiAI6deqkZs2aaeXKlQoICFB2drZWrVqlkvpSAQEB2r9/v/bt2/evPjctLU1ZWVmqUqXK5Qf/SxazSSHVK2rb0fxvVVslbT92XuE1KhU7p0Mjf+05magnujfS+vHt9eGoVhrRvo7MBXpve04mqVWQr2pX8ZIkNaxaQc1qVdZPf5x3ZBybrMxMHTywXxFt29nOmc1mRUS0057dO4uds2fXLkVEtC10rl37G7Vn1y5J0qmTJxUbG6M2Efn39Pb2Vlh4sxLvaW/kykcu5+XKzsrSqT8Pq0H49bZzZrNZDcOu1/FD+y8732q16vc9vyrm9F+q2yS8xHEX0lJlMpnkVeHq7Ex0xfVyxUwSuQoiF7nsjVz5yEUueyNXPqPncsVMErkKIhe5AJROmXt7r776arHnp02bppSUlH9dEC4vJCREe/bsUUREhCZNmqR7771Xo0ePVuvWrdWpUycNHTpU1arlfXN47Nix+uGHHxQWFqY6deooIiJCt956qwYNGiQPD49Sf+YTTzyhwMBAdenS5ZLjMjIyimydy83OlNniXurPqly+nCxms86nZhY6fz4lS0F+FYqdU6Oyp24Iqqx1+85q3IrdqlWlvJ7o3kgWs0mLfzgmSXr7v8dVwd1Nn4xpo9xcq8xmkxZu/lPr9p0tdW3/RnxCvHJycuTn51fovJ+fn44e/bPYObGxsfLz8y8yPjYu9u/rMXnn/IveMzb26jznn1z5yOW8XKnJicrNzZG3j2+h8xUr++rcqaK7ui5KT03RjAf6KjsrU2azm3qPHK9GzVoVOzYrM0Nr3n9Dzdp3lmf54n8vsjdXXC9XzCSRqyBykcveyJWPXOSyN3LlM3ouV8wkkasgcpELQOlc8Ts0/mnw4MFaunSpvW6HS7BarbbHfs2YMUPR0dFatGiRQkNDtWjRIoWEhGjv3r2SpAoVKmj16tU6cuSIJk+erIoVK2rChAlq3bq10tLSdOLECVWsWNF2PP/880U+74UXXtCKFSu0atUqeXp6XrK2mTNnysfHp9AR/f0H9v8/4R9MJpPiU7M0Y/Uh/Radoq8PnNNb/z2uPi0DbWO6Nqmq7mHVNHnVAQ1a8oumfXFQgyNq6/bwK3sMDIBrn4dXeY1/aYn+74U31G3gSH35zkL9sa/ot2VysrP1/ivTZLVadfeo/zihUgAAAAAAUBZmjjIf1wK71blly5bL/rAb9nHw4EHVrVvX9ms/Pz/169dPs2fP1sGDBxUYGKjZs2cXmlO/fn2NHDlSS5Ys0Y4dO3TgwAF9+OGHCgwM1K5du2zH6NGjC82bPXu2XnjhBW3YsEHh4SU/huWiiRMnKjExsdAR0OHeMuVLSMtSdm6uqlQovKujSsVyiksp/sVJsSmZOn4+TQVfn3E0NlX+3h6y/P3cqf/rUl/v/PeENhw4pz9iUrVm71kt3/6XRrSrXab6rpRvZV+5ubkVeaFUXFyc/P39i53j7++vuLjYouP//haAv/91eediS39PeyNXPnI5L1cFbx+ZzW5K/scLwFMS4uVdueRH5ZnNZvlXr6nAug3VsVd/hbXtqM2rlhUak9fMmKqEmLO6f8rLV213huSa6+WKmSRyFUQuctkbufKRi1z2Rq58Rs/lipkkchVELnIBKJ0yNzTuvvvuQkfv3r0VERGhESNG6IEHHnBEjShg06ZN2rt3r/r06VPsdXd3d9WvX1+pqakl3iMoKEjly5dXamqqLBaLGjRoYDsKviNj1qxZevbZZ7Vu3TrdcMMNparPw8NDlSpVKnSU5XFTkpSda9VvZ1LUum7+o2NMkloF+WrPqaRi5+w+mahavl4q+Lr62lXKKyY5Q9l/dzk8LW7K/ce7RnJyrZd8yb09lXN3V+Mmodq2dYvtXG5urrZt26LwZi2KnRPevLm2bd1a6NzWLT8pvHlzSVKNmjXl73+dtm3Lv2dKSor27tld4j3tjVz5yOW8XJZy5VSjXiMd2fur7Vxubq6O7N2hOsGhpb6PNTdX2VlZtl9fbGbEnjml+6e8ogrePnat+3Jccb1cMZNEroLIRS57I1c+cpHL3siVz+i5XDGTRK6CyEUuAKVT5ndo+PgU/mGO2WxWcHCwpk+frltvvdVuhSHvfRTR0dHKycnR2bNntW7dOs2cOVN33HGHhg4dqq+++korVqzQgAED1KhRI1mtVn355Zdas2aN3nrrLUl57zZJS0tTjx49VKdOHSUkJGju3LnKyspS165dS/zsF198UVOmTNEHH3ygoKAgRUdHS5Lt0VSOtmzbX5rWK0QHziRr/6kk3dumprzKuenL3WckSc/0aqxzyRlasDnvWYaf/npK99xQQ492a6gPfz6pWlXKa0T7Ovrw55O2e/7we6zuu7GOopMy9GdMqoIDKmpQm1r64u97Xg1Dho3Q05OeUGhoUzUNC9f7772j9PR03dX7bknSUxMfV9Wq1TTukQmSpEGDhypy+BC98/ZSdejQUevWrtH+ffv09LTpkvIetTVoyFAtfuN11aldRzVq1tSCea/puqpV1anzpd93Qi5yuVqum3reo4/mz1TN+iGq1SBEP67+RJkZ6brhltskSSvmzpCP33W6bdAoSdKmle+rZv1g+QXUUHZWpn7bsU07vt+g3vfnPVIqJztb782eolNHD2vExBdkzc1Rcnzet2u8KlaSpVy5q5LLFdfLFTORi1zkIhe5yEUucpGJXOQil9FyAa6oTA2NnJwcjRgxQmFhYfL19b38BPwr69atU/Xq1WWxWOTr66tmzZpp7ty5GjZsmMxms5o0aaLy5ctrwoQJ+uuvv+Th4aGGDRtqyZIlGjJkiCSpY8eOWrBggYYOHaqzZ8/K19dXLVq00IYNGxQcHFziZ7/++uvKzMxU3759C52fOnWqpk2b5sjYkqSvD5yTb/lyGt2xrvwquOvw2RSNXb5H51Pzvjkd4ONRaLfF2aQMjf1gt/7TtYGWj2qlmORMrfj5pN756bhtzEvrf9fojnX15G2N5Fu+nGJTMrVy52kt/v6Yw/Nc1P22Hoo/f14L589VbGyMgkMaa+EbS+T393bD6DNnZDblb5xq3qKlZs6arflz52jenFdUu06Q5sxboIYNG9nGjIi8X+np6Zo+bYqSk5PUouX1WvjGkjK99J1c5HKFXM3bd1JqUoI2rFiq5ITzCgxqoMinXrI9cioh9pxM5vxcmRkXtGrxq0o8H6Ny7h6qGlhbA/5vspq37yRJSjwfowO//FeSNOfRyEKf9cC0Oarf9Op8q8YV18sVM5GLXOQiF7nIRS5ykYlc5CKX0XIBrshktf7jGTyX4enpWeQdDsCl3PDcZmeXYHc/PnmLs0sAXNb6g9HOLsEhujUOcHYJAAAAAIBrlGeZn7ODsasOOruEa8683o2dXcJllfkfhaZNm+rPP/+koQEAAAAAAAAAMKSr9d5cXF1lfin4c889p0cffVRfffWVzpw5o6SkpEIHAAAAAAAAAACAvZV6h8b06dM1YcIE9ejRQ5LUq1evQl0uq9Uqk8mknJwc+1cJAAAAAAAAAAD+p5W6ofHMM89o9OjR2rzZ9d6HAAAAAAAAAAAAjK3UDY2L7w7v2LGjw4oBAAAAAAAAAAAoTpneocGLVAAAAAAAAAAAgDOUeoeGJDVq1OiyTY3z58//q4IAAAAAAAAAAAD+qUwNjWeeeUY+Pj6OqgUAAAAAAAAAgH/NzMOGXFKZGhoDBgxQ1apVHVULAAAAAAAAAABAsUr9Dg3enwEAAAAAAAAAAJyl1A0Nq9XqyDoAAAAAAAAAAABKVOpHTuXm5jqyDgAAAAAAAAAAgBKVeocGAAAAAAAAAACAs5TppeAAAAAAAAAAABidmVdCuyR2aAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwaGgAAAAAAAAAAADDszi7AAAAAAAAAAAA7MlkMjm7BDgAOzQAAAAAAAAAAIDh0dAAAAAAAAAAAACGR0MDAAAAAAAAAAAYHg0NAAAAAAAAAABgeDQ0AAAAAAAAAACA4VmcXQAAAAAAAAAAAPZkNjm7AjgCOzQAAAAAAAAAAIDh0dAAAAAAAAAAAACGxyOn4HAPdK3n7BIAXEO6NQ5wdgkAAEBSrze2OrsEh/jigQhnlwAAAIArxA4NAAAAAAAAAABgeDQ0AAAAAAAAAACA4fHIKQAAAAAAAACASzGZnF0BHIEdGgAAAAAAAAAAwPBoaAAAAAAAAAAAAMOjoQEAAAAAAAAAAAyPhgYAAAAAAAAAADA8GhoAAAAAAAAAAMDwLM4uAAAAAAAAAAD+n707D4/p7P84/pnsIUEW+xZb7LFLbLUX1YVaai9V1FpVa6ulWqV+2tpV0dJaa616UKpobUGJ2KmGlsaS2IIgZH5/hEmmSUh0JjOZvl/Pda7rcc99zvl+3K3iO/c5gCU5GQy2LgFWwA4NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHbPxdYFAAAAAAAAAABgSXyT3zGxrgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsnoutCwAAAAAAAAAAwJIMBltXAGtghwYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu+di6wIAAAAAAAAAALAkJ4PB1iXACtihYacuX76s3r17q1ChQnJ3d1eePHnUpEkTjR07VgaD4bHH1q1bJUnnzp2Tm5ubypUrl+I9kp6TLVs2VatWTd9//70kqV69eo+9R7169az+c3DgpzX6clBnfd69uRaM7q/I08dTnXty73Z9+35fTX2jpSa9/oLmj3xDR3b8ZDbn3p1Y/fTNNH3xZgdN6v68vhr+usJ+XmvtGMksWbRQzRo3ULVK5dWxXRsdCg9/7PyNP67XS883VbVK5dWqxQv69ZdtZp8bjUZNnzpZDevWVvXKQerZvavOnj1jxQQpI1cCcpHLGhwxlyNmksj1CLnIZQ3kSpBZcr1QLre+6VxJa3tV15TW5VQyV9bHzs/q5qx+zwRocdfKWvtGdX3VsYKqFc5h+rxd5Xya2rqcVveopu+6VdHoZoEqkMPDyimSc9T1IleCzJDLETNJ5HqEXOQC8GQ0NOxUq1atdODAAc2fP18nT57UmjVrVK9ePZUvX16RkZGmo23btmratKnZWM2aNSVJ8+bNU9u2bXXjxg2FhoameJ+vv/5akZGR2rdvn2rVqqXWrVvr0KFDWrlypel6e/bskST99NNPprGVK1daNf/x3Vu1ddEs1WjRSZ3HzFCuQkW1/P/e0a0bV1Oc7+HlrZAX26vDe5PVdewslavTRBtmT1RE+D7TnK2LvtCZ8H167o1h6jZ+jqo0aanN30zT7/t3WTVLUhvWr9PECePUq09fLVm2SiVLllLvXt0VHR2d4vywA/s1fMjbavlyay1dvlr1GzTUwP59derUSdOcr+fO1uKF32rkqNFasPg7eXp6qnfP7rp7925GxSLXQ+QilzU4Yi5HzCSR6xFykcsayJUgs+SqW9xPvWoX1oK959Tnu0P6I+qWPn6htHJ4pvyAABcng8a/WFq5vd314YaT6r7woD7f8oeib94zzSmfL5vWHL6oN1cc1vA1x+TsZNC4F0vLwyXj/kjrqOtFrgSZIZcjZpLI9Qi5yAUgbQxGo9Fo6yJg7tq1a/Lx8dHWrVtVt27dx87t2rWrrl27ptWrV5uNG41GFS9eXDNmzNCWLVt05coVffnll2ZzDAaDVq1apRYtWkiSYmJilC1bNk2ePFkDBgwwzTtz5oyKFCmiAwcOqGLFiunOMzv0bLrPWTC6v/IULalGXfol5ImP16y3OqpSo5cU/EK7NF3jm/f6qGiF6qrduqsk6esRPVQquK5qtOhkmvPt+31UJKiaarfulq76OlcpnK75j3Rs10Zly5XXOyPflyTFx8fr2YZ11b5DZ3Xv0TPZ/CFvD1RsbKymzZhlGuvUvq1Kliql90aNkdFoVKN6ddSlaze92q27pIR1bPBMTY0ZO17Nnmv+VHWSi1zkIheZyEUucpGLXC/O2v1Uuaa0LqcTF29q+q9nJEkGSQtfrazvD13Q0v1/J5vfvGwutamUT90XHdSD+LT98TS7h4uWda+qt1ce0aHImHTVt6ZXSLrmP2Lv6/W0yJV5cjliJnKRi1xp58GLA9LtvQ2nbF1CpvNh0xK2LuGJ2KFhh7y8vOTl5aXVq1c/ddd2y5Ytun37tho1aqROnTppyZIlunXrVqrz79+/r7lz50qS3NzcnuqelvLgfpwunjmlwmUrmcYMTk4qVKaS/v792BPPNxqNOnvkgK5E/qUCpcqbxvOXKKPfD+xWzJUoGY1G/Xk0TFcunFfhclWskuOf4u7d07GjRxRSo6ZpzMnJSSEhNRV+8ECK54SHhSkkpIbZWM1atRUeFiZJOn/unKKiLis4JPGa3t7eKh9UIdVrWhq5EpGLXJbmiLkcMZNErqTIRS5LI1eizJDLxcmgEjmz6sC566Yxo6QD566rdB6vFM+pUcRHxy7EqP8zAVrarbK+bBekdlXyyekxj73O6u4sSYq5e9+S5afKUdeLXInsPZcjZpLIlRS5yAUgbWho2CEXFxfNmzdP8+fPV44cOVSrVi298847Cn/Cs/uSmjt3rtq1aydnZ2eVK1dORYsW1bJly5LNa9++vby8vOTu7q633npLAQEBatu27VPXfvfuXd24ccPsiLuXvqZMbMwNGePjlTWbj9l41uw+unX9Sur3vn1Lk3u8qM9fe04rPxuphp37KiBJs6JB577yy1dIswZ20OevPacVE99Voy79VLBUUPpCPqWr167qwYMH8vPzMxv38/NTVFRUiudERUXJz88/+fzoqIefX04Y80/7NS2NXInIRS5Lc8RcjphJIldS5CKXpZErUWbIlc3DRc5OBl29HWc2fvV2nHyzpPzFqbzZPFSnmJ+cDAaNXHtCC/edV+uKedWhav4U5xskvVE7QIf/vqEzV2ItHSFFjrpe5Epk77kcMZNErqTIRS4AaUNDw061atVKf//9t9asWaOmTZtq69atqly5subNm/fEc69du6aVK1eqU6fERyt16tTJtAMjqc8//1xhYWFav369ypQpozlz5sjX1/ep6x43bpyyZ89udqyfP+Opr5cebh6e6vLRTHUaPU21W3fT1sWz9Oexg6bPD2z6XpGnj6vlWx+o8wfTVbd9T/30zTSdPbw/Q+oDAAAAkJzBIF2LjdOkrX/o1OVb2vZ7tBbvO6/mZXOnOL9f3SIK8M2ijzf+nsGVAgCAzMRg4EjvkRnQ0LBjHh4eaty4sd577z3t3LlTXbt21ahRo5543qJFi3Tnzh0FBwfLxcVFLi4uGjZsmLZv366TJ0+azc2TJ4+KFy+uZ599Vl9//bVeeeUVXbp06alrHjFihK5fv252NHu1T7qu4emdTQYnp2QvAL91/aqyZk+92WJwcpJP7vzKVbiYqjVrrcBqdbTnhyWSpLh7d/Xrsq9Vr0MvFatUQzkLFVXlxi+pVHBd7V2/PP1Bn4JPDh85Ozsne6FUdHS0/P39UzzH399f0dFRyec//BaAv3/OhLGotF/T0siViFzksjRHzOWImSRyJUUuclkauRJlhlw37tzXg3ijfLK4mo37ZHHVldv3Ujznyq04nbt2R0lfn/Hn1Tvyy+oml388d6pvnQCFFM6hoauPKupWytezBkddL3IlsvdcjphJIldS5CIXgLShoZGJlClT5rHvwXhk7ty5evvttxUWFmY6Dh48qDp16uirr75K9bzq1aurSpUqGjt27FPX6O7urmzZspkdrm7u6bqGs4urcgeU0J9Hwkxjxvh4/Xk0TPmKl07zdYzxRt2/n7DVPf7BfcU/uC/DP1qNBicnGY3x6arvabm6ual0mbIK3b3LNBYfH6/Q0F0KqlApxXOCKlZU6G7zlzHu3rVTQQ9fzp6/QAH5++dUaGjiNW/evKlD4QdTvaalkSsRuchlaY6YyxEzSeRKilzksjRyJcoMue7HG3Xq8i1VLJDdNGaQVLFANh27cDPFc45ciFG+7B5K+jv1/Dk8FH3rnu4n6XL0rROgWkV9NeT7Y7oQ83TvGnxajrpe5Epk77kcMZNErqTIRS4AaUNDww5FR0erQYMGWrBggcLDwxUREaFly5ZpwoQJeumllx57blhYmPbv36/XX39d5cqVMzvat2+v+fPn6/791F+cN3DgQM2aNUvnz5+3dKx0qdq0lcK3rdPhXzcq+vyf2jR/iuLu3lG5Z5pIktbNmqBfvkt8hFboD4t15vBvunYpUtHn/9Te9ct1dOdPKlOzoSTJ3TOrCpQK0rYls/XnsYO6djlSh3/dqKPbf1KJKrUyLFfnV7tp5fLvtGb1Kv1x+rQ+GjNasbGxatHyZUnSuyOGavLnn5rmd+zURTt3/Kr5875SxB+nNXP6VB05fFjtOiQ8TsxgMKhj5y6aPWumtv68WadOntDIEUOVM1cuNWjYiFzkIhe57DKXI2YiF7nIRS5yJVoRFqnnyuRS45L+KujjoQH1isjDxVk/Hkt4nviQhsX0WkhB0/y1hy/K28NZvesEKH92D1UvnEPtq+TTmkMXTHP6PxOghiX9NW7TKcXGPZBPFlf5ZHGVm3PGPRvBUdeLXJknlyNmIhe5yAUgvVxsXQCS8/LyUnBwsD7//HOdPn1acXFxKliwoHr06KF33nnnsefOnTtXZcqUUalSpZJ91rJlS/Xr10/r1q3Tiy++mOL5TZs2VZEiRTR27FjNmJEx775ISamQerodc107Vn6j29evKmehomo9ZKyyZk94UfiN6Etmuy3i7t7RT/On6uaVKLm4ucs3b0E912uYSoXUM815oc87+mXZV1r3xXjduRmjbP65VLt1V1Vo8HyG5Wra7DldvXJFM6ZNUVTUZZUsVVozZs2R38PthhciI+VkSOwzVqxUWeMmTNS0KZM0ddJnKlQ4QJOmTleJEoGmOd2691BsbKzGjH5fMTE3VKlyFc2YNUfu7unbGUMucpGLXBmVyxEzkYtc5CIXuRJt+z1a2T1d1CW4oHyyuOqPqNt6d+1xXYtN2D2dy9tdxiSPl7p8857eWXNcb9QurFntghR1655WhV/Qd/v/Ns15oXweSdKnLcua3ev/Np/WpuOXrR9Kjrte5Mo8uRwxE7nIRS4A6WUwGpP+VhKwvNmhZ21dgsV1rlLY1iUAAAAAVvXirN1PnpQJrekVYusSAABINw++lp5u7/94ytYlZDpjmpSwdQlPxL8KAAAAAAAAAACH4pRxT6ZEBuIdGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsnoutCwAAAAAAAAAAwJKcDAZblwArYIcGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnYusCAAAAAAAAAACwJIPB1hXAGtihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuudi6AAAAAAAAAAAALMnJYOsKYA3s0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg91xsXQAAAAAAAAAAAJZkkMHWJcAK2KEBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu8c7NGB1nasUtnUJSKOtJy7bugSrqFcyp61LAABY0YN4o61LsApnJ575C9ta0yvE1iVYRe3xW2xdglVsH17f1iUAAABYHTs0AAAAAAAAAACA3WOHBgAAAAAAAADAobDh2TGxQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3XOxdQEAAAAAAAAAAFiSk8HWFcAa2KEBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO652LoAAAAAAAAAAAAsyWAw2LoEWAE7NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRdbFwAAAAAAAAAAgCU5GWxdAayBHRoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7J6LrQsAAAAAAAAAAMCSDAZbVwBrYIcGAAAAAAAAAACwezQ0MpnLly+rd+/eKlSokNzd3ZUnTx41adJEY8eOlcFgeOyxdetWSVJsbKxGjRqlwMBAubu7y9/fX23atNGRI0fM7jV69GjTuS4uLgoICNBbb72lmzdvZkjWJYsWqlnjBqpWqbw6tmujQ+Hhj52/8cf1eun5pqpWqbxatXhBv/6yzexzo9Go6VMnq2Hd2qpeOUg9u3fV2bNnrJggZY6a69f1K/RBr9Z6+5UG+mxYD509f9Lc4wABAABJREFUdTTVuQd3b9PEId01vFNTDWnfSBMGddXerRvM5hiNRq1bPEfvvfaSBrdroOmj39Slv/+ydoxkHHW9yJWAXLbL5YiZJHI9kllyLV28UM2bNFBIlSB16dBWhw89PtemHzfo5ReaKaRKkNq2fEHbk+SKi4vT5M8mqm3LF1SzeiU926CO3ntnmC5fumjtGMk46nqRKwG5bJurTZX8WtMvRDuGP6N53aqobD7vx873cnfR0KYltOHNmto5vK5W9A5WrWK+ps+dDNIbdYvo+34h2j7sGa3uG6LutQtbO0YyjrpejpjLETNJ5HqEXOQC8GQ0NDKZVq1a6cCBA5o/f75OnjypNWvWqF69eipfvrwiIyNNR9u2bdW0aVOzsZo1a+ru3btq1KiRvvrqK3300Uc6efKk1q1bp/v37ys4OFi7d+82u1/ZsmUVGRmpM2fO6JNPPtGXX36pt99+2+o5N6xfp4kTxqlXn75asmyVSpYspd69uis6OjrF+WEH9mv4kLfV8uXWWrp8teo3aKiB/fvq1KmTpjlfz52txQu/1chRo7Vg8Xfy9PRU757ddffuXavnecRRc+3fvlmrvp6mJm27acjEucoXUFwzxwxSzLWrKc7P4uWtxq26aOD4LzTs8/mq3uA5LZo2TscOhJrmbF61UL/8b7navjFYb43/Um7unvriw0GKu8d6/VvkSkAu2+VyxEwSuR7JLLl+3LBOn/3fePV8o68WfbdSJQJLqm+v13UllVwHw/brnWFv66WXW2vRslWq16CRBr3ZT78/zHXnzh0dP3ZUr/fqo0VLV2ji51N19kyEBvbvk2GZJMddL3IlIJdtczUuk0tvNS6u2b+eUac5+3Ty4k1NbV9BPllcU5zv4mTQ9I4VlC+7p4atOKJWM0M19n8ndCkmseZXaxZW6yr5NGHDKbX5Yo+mbj6tLjUK6ZVq+TMqlsOulyPmcsRMErkeIRe5AKSNwWg0Gm1dBNLm2rVr8vHx0datW1W3bt3Hzu3atauuXbum1atXm41/8sknGjFihA4cOKAKFSqYxuPj4xUcHKzbt2/r8OHDMhgMGj16tFavXq2wsDDTvJ49e+qHH35QZGRkmuu+cz/NU006tmujsuXK652R75vqe7ZhXbXv0Fnde/RMNn/I2wMVGxuraTNmmcY6tW+rkqVK6b1RY2Q0GtWoXh116dpNr3brLkmKiYlRg2dqaszY8Wr2XPP0F/kU7D3X1hOXnyrXZ8N6qFDx0mrdY5Ap1+ieL6vOc63U+OXOabrG/739mspUqaHmHXrIaDTq/e4tVP/FV9SgRQdJUuytmxr52ovq2P8dVa7dKF311SuZM32BHrL39Xpa5CKXrXM5YiZy2TbXg/j0/3a2S4e2KlO2nIa/m5irWeN6ate+k7q9njzXsMFvKTb2tqZMT8zVpeMrKlmylN59/4MU73Hk8CF1bt9G/9v4s/LmzZfuGp2d0v/Q38ywXk+DXOSyZK7a47c8Va553aro6N83NOHHU5Ikg6T/DaippfvOaf7OP5PNb1U5nzrXKKRWM0NT/XXq81fK68qte/pw7QnT2IRWZXXnfrze//5YuurbPrx+uuY/Yu/r9bQcMZcjZiIXuciVdh68CTndPvvlD1uXkOkMeqaorUt4InZoZCJeXl7y8vLS6tWrn7qbu2jRIjVu3NismSFJTk5Oeuutt3T06FEdPHgw1fM9PT117969p7p3WsXdu6djR48opEZNs/pCQmoq/OCBFM8JDwtTSEgNs7GatWor/GEz5vy5c4qKuqzgkMRrent7q3xQhVSvaWmOmut+XJz+On1SgUFVTWNOTk4KDKqqMyeOPObMBEajUSfC9+nS33+qWJmKkqToi3/rxrVoBVaoZprnmdVLhUuUUcSJwxbPkBJHXS9yJSKXbXI5YiaJXEllilxxCbmS1uDk5KTgkBoKPxiW4jmHDoaZzZekGjVrpTpfkm7GxMhgMMjbO5slyn4ih10vcpmQy3a5XJwMKpXXS6ERiTuQjZL2nLmioPwp/zv+TKC/ws9d17CmgfpxYC0t7VlN3WoVVtJeZfi5G6oW4KNCvp6SpBK5sqpCwRzaefqKNeOYOOp6OWIuR8wkkSspcpELQNrQ28tEXFxcNG/ePPXo0UNffPGFKleurLp166pdu3YKCgpK0zVOnjyp+vVT/uZO6dKlTXMqVqyY7PPffvtNixYtUoMGDVK9/t27d5M1W4zO7nJ3d09TfZJ09dpVPXjwQH5+fmbjfn5+iohIubMaFRUlPz//ZPOjoqMefp6w88DPP/k1o6Ki0lzbv+GouW7FXFd8/AN55/A1G/fO4atL58+mel7srZt6v0dL3Y+7JycnZ7XpOUilKiY0MGKuJfwBzju7zz+u6aOYqxnzhztHXS9yJSKXbXI5YiaJXEllhlzXribk8v1HLl8/f52JiEjxnIRc/6zZX9Gp1Hz37l1N/nyimjZrLi8vL8sU/gSOul7kSkQu2+XKkcVVLk5OunLL/MtdV27GKcAva4rn5M/hoaoBObTh8EW9ueSgCvpm0bCmgXJxMmj2r2ckSfN2nFVWN2ct7x2s+HijnJwMmrHlD204nDHv33HU9XLEXI6YSSJXUuQiFyzPyZD+Hc+wf+zQyGRatWqlv//+W2vWrFHTpk21detWVa5cWfPmzUvzNdLzlLFDhw7Jy8tLnp6eql69umrUqKFp06alOn/cuHHKnj272fF/n4xL8/3w3+HumUVDP/1ab0+Yo+Ydemj119N06vB+W5cFAMC/FhcXp2GDB0qSRrw32qa1ALAdg8Ggq7fiNPZ/J3T8wk1tOnpJX+84q1aVEx9B17hMLjUtn1sjVx1Vxzn7NHrNMXUKKaTmQXlsWDkAAID9oqGRCXl4eKhx48Z67733tHPnTnXt2lWjRo1K07mBgYE6dizlZ7E+Gg8MDDSNlSxZUmFhYTp27JhiY2O1Zs0a5c6dO9XrjxgxQtevXzc7hgwbkY50kk8OHzk7Oyd78VJ0dLT8/f1TPMff31/R0VHJ5z/slvv7J7xDIToq7de0NEfNldU7u5ycnE27Kh6JuXZF3jn8UjkrYftmzrwFVKBICTV4qb0q1Kinn1YukCTTbo+Y6+YvFY+5dlXePr7JrmUNjrpe5EpELtvkcsRMErmSygy5cvgk5PrnC8CvRCf/pt0jCbn+WXOU/P5Rc1xcnIYPfkuRf/+tGV/OzbDdGZLjrhe5EpHLdrmu3Y7T/fh4+WZ1Mxv39XJV9M2UHwccdfOezl65raSvz4iIuiV/b3e5PHzu1IBGxTR/x5/aePSSTl++pXWHLmrxnr/UrWYhq2VJylHXyxFzOWImiVxJkYtcANKGhoYDKFOmjG7dupWmue3atdNPP/2U7D0Z8fHx+vzzz1WmTBmz92u4ubmpePHiCggIkJub2z8vl4y7u7uyZctmdqTncVOS5OrmptJlyip09y6z+kJDdymoQqUUzwmqWFGhu3ebje3etVNBDx+dlb9AAfn751RoaOI1b968qUPhB1O9pqU5ai4XV1cVLBaok+G/mcbi4+N1Mvw3BZQsm+brGI3xuh+XsIXfL3c+Zcvhp5Ph+0yf37l9S2dPHVWRkuUsV/xjOOp6kSsRuWyTyxEzSeRKKlPkck3ItSfUPNee3bsVVKFiiueUr1DRbL4khe7aaTb/UTPjzz/P6ovZXytHDh9lJIddL3KZkMt2ue7HG3U88qaqF0n899ogqVqAj8LP30jxnIPnrqugj6eSPuyikG8WXY65q/sPuxweLs6K/8cO+gfxRhky6BEZjrpejpjLETNJ5EqKXOQCkDY0NDKR6OhoNWjQQAsWLFB4eLgiIiK0bNkyTZgwQS+99FKarvHWW2+pevXqeuGFF7Rs2TL9+eef2rt3r1q1aqVjx45p7ty5Gfab58fp/Go3rVz+ndasXqU/Tp/WR2NGKzY2Vi1avixJenfEUE3+/FPT/I6dumjnjl81f95XivjjtGZOn6ojhw+rXYdOkhK2e3fs3EWzZ83U1p8369TJExo5Yqhy5sqlBg0bketfqvdCO+366Qft2bJeF86d0bJZE3XvbqyCGzSXJC2Y/KF+WPCFaf6mFd/qeNheRV04rwvnzujn7xdr77YfVfWZJqZcdZ9vo43L5+vQnu36++xpLZjykbL7+ql89ToZlstR14tc5LJ1LkfMRK7Ml6tjl65atWKZfvh+lf7447Q+/jAh14stEnK9984wTZ2UmKtDp87atWO7vp3/lSL++ENfzJiqo0eO6JX2HSUlNDOGDnpTR48c1tjx/6cH8Q8UFXVZUVGXFRd3L8UarMFR14tc5LKHXAtD/1KLSnnVPCiPAvyyaMRzgfJ0ddYPByMlSR+8WFp96xc1zV/x23ll83TV4CYlVMjXU7WK+6lbrcJatu+8ac6vp6L0Wu3CqlXcT3mze6heSX91DC6orScuZ1guR10vR8zliJnIRS5yAUgvXgqeiXh5eSk4OFiff/65Tp8+rbi4OBUsWFA9evTQO++8k6ZreHh46Oeff9bHH3+sd955R2fPnpW3t7fq16+v3bt3q1y5jPn2+5M0bfacrl65ohnTpigq6rJKliqtGbPmmB7rcCEyUk6GxH5cxUqVNW7CRE2bMklTJ32mQoUDNGnqdJUokfj4rG7deyg2NlZjRr+vmJgbqlS5imbMmpPuHSTkSq5y7Ya6eeOa1i2eoxvXrqhAkeJ6471Ple3ho6OuRl2UwSkx1727sVo2+1Ndj74kVzd35cpfWJ3ffF+Vazc0zWnYsqPu3b2jpV9MUOytmypaurzeeO9TubqxXuQiV2bP5YiZyJX5cjVpmpBr5vSpin6Ya9oXs5Pk+tvsJYIVKlbW2PETNWPaJE2b/LkKFQ7QZ5OnqfjDXJcvXdS2rT9Lktq1bmF2ry+/mq+q1YIzJJejrhe5yGUPuTYdvSSfLK56o24R+WV108mLN9V/cbiu3IqTJOXJ7m622+Lijbvqv+igBjUursU9q+lyzD0t2XtO83eeNc35vx9P6Y26RTS8WaB8srgq6uY9rTzwt2b/cibDcjnqejliLkfMRC5ykQtAehmM6XlDNPAU7ty3dQVIq4z8JlhGqlcyp61LAABY0YN4x/ztrLOT7XfNAo6o9vgtti7BKrYPr2/rEgAAVuTB19LTbcr2CFuXkOkMqF3E1iU8EY+cAgAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3XGxdAAAAAAAAAAAAlmQw2LoCWAM7NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAACH4iQDRzqPpzF9+nQFBATIw8NDwcHB2rNnT5rOW7JkiQwGg1q0aJGu+9HQAAAAAAAAAAAA6bJ06VINGjRIo0aN0v79+1WhQgU1adJEly5deux5Z86c0eDBg1WnTp1035OGBgAAAAAAAAAA/3F3797VjRs3zI67d++mOv+zzz5Tjx491K1bN5UpU0ZffPGFsmTJoq+++irVcx48eKCOHTvqgw8+UNGiRdNdIw0NAAAAAAAAAAD+48aNG6fs2bObHePGjUtx7r179/Tbb7+pUaNGpjEnJyc1atRIu3btSvUeY8aMUa5cudS9e/enqtHlqc4CAAAAAAAAAAAOY8SIERo0aJDZmLu7e4pzo6Ki9ODBA+XOndtsPHfu3Dp+/HiK52zfvl1z585VWFjYU9dIQwMAAAAAAAAAgP84d3f3VBsY/1ZMTIw6d+6s2bNny9/f/6mvQ0MDAAAAAAAAAOBQDAZbV+DY/P395ezsrIsXL5qNX7x4UXny5Ek2//Tp0zpz5oxeeOEF01h8fLwkycXFRSdOnFCxYsWeeF/eoQEAAAAAAAAAANLMzc1NVapU0ebNm01j8fHx2rx5s2rUqJFsfqlSpXTo0CGFhYWZjhdffFH169dXWFiYChYsmKb7skMDAAAAAAAAAACky6BBg/Tqq6+qatWqql69uiZNmqRbt26pW7dukqQuXboof/78GjdunDw8PFSuXDmz83PkyCFJycYfh4YGAAAAAAAAAABIl1deeUWXL1/W+++/rwsXLqhixYrasGGD6UXhf/75p5ycLPuQKBoaAAAAAAAAAAAg3fr166d+/fql+NnWrVsfe+68efPSfT/eoQEAAAAAAAAAAOweOzQAAAAAAAAAAA7FyWDrCmAN7NAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4vBQdgUq9kTluXAABAujnztr9MY/PxS7YuwSoalspl6xKQDtuH17d1CYDDqjVui61LsIodIxzz1414o9HWJViFk4HfGwKOjIYGAAAAAAAAAMCh0NxyTDxyCgAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdc7F1AQAAAAAAAAAAWJLBYOsKYA3s0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg91xsXQAAAAAAAAAAAJbkZDDYugRYATs0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9F1sXAAAAAAAAAACAJRkMtq4A1sAODQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z8XWBQAAAAAAAAAAYEl8k98xsa4AAAAAAAAAAMDu0dD4Dzlz5owMBoPCwsJsXQoAAAAAAAAAAOlCQwN2a8mihWrWuIGqVSqvju3a6FB4+GPnb/xxvV56vqmqVSqvVi1e0K+/bDP73Gg0avrUyWpYt7aqVw5Sz+5ddfbsGSsmSBm5EpCLXNZArgSZIZcjZpLI9Qi5yGUN29ev1IdvtNHQdg01aXhPnT11NNW54bu36bOhr+udzs00vENjTXy7m/Zt3ZBszhdjBmnkq801qFUdnY84Ze0IKXLU9SJXAnKRy9IcMZMktamaXz/0D9HOEc9o/mtVVDaf92Pne7m7aFjTEvpxYE3tGlFXK/sEq1ZxX9PnTgapd70iWtMvRDuGP6Pv+4bo9TqFrR0jGUddr6WLF+q5ZxsouHKQOrdvq8OHHp9r048b1PKFZgquHKQ2LZPn2rxpo3r3eE31agWrUrlSOnH8mDXLT5WjrhfgaGhowC5tWL9OEyeMU68+fbVk2SqVLFlKvXt1V3R0dIrzww7s1/Ahb6vly621dPlq1W/QUAP799WpUydNc76eO1uLF36rkaNGa8Hi7+Tp6anePbvr7t27GRWLXA+Ri1zWQK4EmSGXI2aSyPUIuchlDQd2bNb386apSduuGvR/c5SvcHF9+eHbirl+NcX5WbyyqVGrLnpz3EwN/myeqtd/Tkumj9fxA6GmOffuxKpIqfJ6vvMbGRUjGUddL3IlIBe5yJQ2jcvk0qDGxfXlL2fUcfY+nbx4U9M6VJBPFtcU57s4GTSjUwXly+GpocuP6OUZofpo7Qldikms+dWahdW6Sj5N2HBKrWfu0ZSfT6tLjUJqVy1/RsVy2PX6cf06fTphvHr17qtFy1YqsGRJ9en1uq48JteIoW+rRcvWWrxsleo1aKRBA/rp9yS5YmNjVbFyFQ14a3BGxUjGUdcLcEQO19CoV6+eBgwYoKFDh8rX11d58uTR6NGjTZ9fu3ZNvXr1Uu7cueXh4aFy5cpp7dq1abr29u3bVadOHXl6eqpgwYIaMGCAbt26JUn65ptv5OXlpVOnEr/Z1adPH5UqVUq3b9+WJG3btk3Vq1eXu7u78ubNq+HDh+v+/ftprv1JDAaDZs6cqWbNmsnT01NFixbV8uXLU50/b9485ciRw2xs9erVMhgMph8fPHhQ9evXl7e3t7Jly6YqVapo3759aa7paX07/2u93LqtWrRspWLFi2vkqA/k4eGh1StXpDh/4YJvVLN2HXV97XUVLVZM/QYMVOkyZbRk0QJJCV3xhd9+ox69eqt+g0YKLFlKH42boMuXLunnzT9ZPQ+5yEUucpHLsTORi1zksq5tPyxVSKMXVL1Bc+UpWEStew2Wq7uH9mz+X4rzi5erpKDgZ5S7QID88+TXM8+3Ud7CRRVx/JBpTtV6TdWkbTcFBlXNqBjJOOp6kYtc5CJTenQKKahVB/7WDwcvKCLqtj7+3wndiYvXSxXzpjj/pYp5ld3DVW9/d0gHz11X5PU72v/nNZ26eMs0p0KBbNp6Ikrbf49W5PU72nzssnb/cUVl82fLqFgOu14Lvpmnl1u30UstW6lYseJ69/2HuValnGvxgm9Vs1ZtvfpadxUtVkx9+7/5MNdC05znX3xJvXr3VUiNGhkVIxlHXS/AETlcQ0OS5s+fr6xZsyo0NFQTJkzQmDFjtGnTJsXHx6tZs2basWOHFixYoKNHj2r8+PFydnZ+4jVPnz6tpk2bqlWrVgoPD9fSpUu1fft29evXT5LUpUsXPffcc+rYsaPu37+v//3vf5ozZ44WLlyoLFmy6Pz583ruuedUrVo1HTx4UDNnztTcuXP10Ucfpan2tHrvvffUqlUrHTx4UB07dlS7du107NjTb9Xr2LGjChQooL179+q3337T8OHD5eqa8rckLCXu3j0dO3pEITVqmsacnJwUElJT4QcPpHhOeFiYQkLM/8NXs1ZthT98X8j5c+cUFXVZwSGJ1/T29lb5oAqpXtPSyJWIXOSyNHIlsvdcjphJIldS5CKXpd2Pi9O50ycVGFTFNObk5KTAoKo6c/LIE883Go06Gb5Pl//+S0XLVLBmqeniqOtFrkTkIpclOWImKWG3Ram8XtoTkbjjzihpT8QVlS+QcvPhmUB/hZ+/rmHNArXxrVpa2quautUqLKfE72bq4Lkbql7ER4V8PSVJJXJnVcWCObTz9yvWjGPiqOsVF5eQK2kNTk5OCg6pofCDYSmeE34wTMFJfh4kqUbNWqnOtwVHXS8kfPmbI31HZuBi6wKsISgoSKNGjZIklShRQtOmTdPmzZtlNBq1Z88eHTt2TIGBgZKkokWLpuma48aNU8eOHTVw4EDTdadMmaK6detq5syZ8vDw0KxZsxQUFKQBAwZo5cqVGj16tKpUSfiD14wZM1SwYEFNmzZNBoNBpUqV0t9//61hw4bp/fffl5OT02Nrb9y4cZrqbNOmjV5//XVJ0ocffqhNmzZp6tSpmjFjRtp+8v7hzz//1JAhQ1SqVClTTY9z9+7dZFvnjM7ucnd3T/M9r167qgcPHsjPz89s3M/PTxERf6R4TlRUlPz8/JPNj4qOevj55YQx/+TXjIqKSnNt/wa5EpGLXJZGrkT2nssRM0nkSopc5LK0WzHXFR//QN45fM3GvbP76NL5s6meF3vrpj7o+bLux92Tk5OzWvUYpJIVqlm73DRz1PUiVyJykcuSHDGTJOXI4ioXJydF37xnNh59K04B/llTPKeAj4fy5sih9YcuasDigyrom0XDmwXKxdmg2b+ckSTN23FWXu7OWtEnWPHxRjk5GTRjyx9af/iitSNJctz1uno1IZdvslz+OhMRkeI5UVFRyef7+ys6g2pOC0ddL8BROeQOjaCgILMf582bV5cuXVJYWJgKFChgamakx8GDBzVv3jx5eXmZjiZNmig+Pl4RD3/R9vHx0dy5czVz5kwVK1ZMw4cPN51/7Ngx1ahRw6zTVatWLd28eVPnzp17Yu1pVeMf2/Nq1Kjxr3ZoDBo0SK+//roaNWqk8ePH6/Tp04+dP27cOGXPnt3s+L9Pxj31/QEAAICn4e6ZRW9P/EpvfTJbz3Xooe/nTdPvh/lGJABkdgaDQVdvxWns/07o+IWb2nT0kr7aflatK+czzWlcNpealsutd1cdVcc5+zTq+2PqFFJIzwflsWHlAABLcMiGxj8fiWQwGBQfHy9PT8+nvubNmzfVq1cvhYWFmY6DBw/q1KlTKlasmGneL7/8ImdnZ0VGRprer2GJ2q3ByclJRqPRbCwuLs7sx6NHj9aRI0fUvHlz/fzzzypTpoxWrVqV6jVHjBih69evmx1Dho1IV10+OXzk7Oyc7MVL0dHR8vf3T/Ecf39/RUdHJZ//sFvu758zYSwq7de0NHIlIhe5LI1ciew9lyNmksiVFLnIZWlZvbPLyclZMdfMHxMSc/2qvHP4pXJWwu91c+YtoPxFSqjei+1UoUZdbV75rbXLTTNHXS9yJSIXuSzJETNJ0rXbcbofHy8/Lzezcb+sroq6mfKLk6Nu3tPZ6NuKT/LXGRFRt+Tv7S6Xh8+derNhMc3b+ac2Hrmk3y/d0rpDF7Uo9C91q1XIalmSctT18vFJyPXPF4BHR0fJ7zG5ks2PSn2+LTjqegGOyiEbGqkJCgrSuXPndPLkyXSfW7lyZR09elTFixdPdri5JfyHd+fOnfrkk0/0ww8/yMvLy/R+DUkqXbq0du3aZdZA2LFjh7y9vVWgQIF/H+6h3bt3J/tx6dKlU5ybM2dOxcTEmDVewh4+6y+pwMBAvfXWW9q4caNefvllff3116ne393dXdmyZTM70vO4KUlydXNT6TJlFbp7l2ksPj5eoaG7FFShUornBFWsqNB/Zt+1U0EVK0qS8hcoIH//nAoNTbzmzZs3dSj8YKrXtDRyJSIXuSyNXInsPZcjZpLIlRS5yGVpLq6uKlAsUKcO/WYai4+P16nw3xQQWDbN1zEajbp/P+7JEzOIo64XuRKRi1yW5IiZJOl+vFHHI2+qWoCPacwgqVoRHx06dyPFcw7+dV0FfT2V9Envhf2y6HLMXd1/2OXwcHVO9gXOeKMxw54P76jr5er6MFeoea49obsVVKFiiucEVaioPUl+HqSHuVKZbwuOul6Ao/pPNTTq1q2rZ555Rq1atdKmTZsUERGh9evXa8OGDU88d9iwYdq5c6f69eunsLAwnTp1St9//72paRETE6POnTtrwIABatasmRYuXKilS5dq+fLlkqQ+ffror7/+Uv/+/XX8+HF9//33GjVqlAYNGmR6f4YlLFu2TF999ZVOnjypUaNGac+ePWaNlaSCg4OVJUsWvfPOOzp9+rQWLVqkefPmmT6PjY1Vv379tHXrVp09e1Y7duzQ3r17U22QWFLnV7tp5fLvtGb1Kv1x+rQ+GjNasbGxatHyZUnSuyOGavLnn5rmd+zURTt3/Kr5875SxB+nNXP6VB05fFjtOnSSlLDTpWPnLpo9a6a2/rxZp06e0MgRQ5UzVy41aNjI6nnIRS5ykYtcjp2JXOQil3XVfeEV7f5prfZuWa+L585o+Zef6t7dWFVv8JwkadGUj7R2wRem+T+t/FYnDu5V9IW/dfHcGW1ds0T7tv2oKs88a5pzK+aGzkec0oW/zkiSLv39p85HnNKNq+bfpLQmR10vcpGLXGRKjwW7/1LLynn1fFAeBfhn0YjnAuXp6qw1ByMlSR+8VFr9GiS+/3T5b+eVzdNVg5uUUCFfT9Uu7qdutQrru33nTXN+PRWl12oXVu3ifsqb3UP1S/qrY3BBbTlxOcNyOep6derSVauWL9Oa7xNyffxhQq6XWiTkGjlimKYkydW+U2ft3LFd38z7ShF//KEvpk/V0SNH1K5DR9Oc69ev6cTxY6bHnJ+JiNCJ48dM76HICI66XoAjcsiXgj/OihUrNHjwYLVv3163bt1S8eLFNX78+CeeFxQUpG3btundd99VnTp1ZDQaVaxYMb3yyiuSpDfffFNZs2bVxx9/LEkqX768Pv74Y/Xq1Us1atRQ/vz5tW7dOg0ZMkQVKlSQr6+vunfvrpEjR1o03wcffKAlS5aoT58+yps3rxYvXqwyZcqkONfX11cLFizQkCFDNHv2bDVs2FCjR49Wz549Jcm03a5Lly66ePGi/P399fLLL+uDDz6waM0padrsOV29ckUzpk1RVNRllSxVWjNmzTFtSbwQGSknQ2IjqGKlyho3YaKmTZmkqZM+U6HCAZo0dbpKlEh8X0q37j0UGxurMaPfV0zMDVWqXEUzZs1J9w4ScpGLXOQiF5nIRS5yZWyuSrUa6ub1a9qwZK5uXLui/EWKq+fIiaYXhV+Numj2rdt7d+5oxZef6dqVS3J1c1fu/IXV8c33VKlWQ9OcI3u3a8n0xHe9ffvZaEnSs227qekrr2VILkddL3KRi1xkSo9NRy/JJ4ur3qhbRH5ebjp58ab6LwrXlVsJu+ryZHM3221x8cZd9Vt4UG8/W1xLelXT5Rv3tHjPOc3fedY0Z8KGU+pdr4iGNwuUT1ZXRcXc04r9f5teGp4RHHW9mjR7TlevXtHMaVMV/TDX9C9mJ8n1t5ycEv+bXLFSZX38yURNnzpJ0yZ/rkKFA/TZlGkqniTXti0/a9TId0w/Hj5kkCSpV+++eqNv/wzJ5ajr9V+XMXuykNEMxn/uwUOmZTAYtGrVKrVo0cLWpZi5c9/WFQAAAMAebD5+ydYlWEXDUrlsXQIA2IVa47bYugSr2DGivq1LsIp4B/0rQacMerRYRvP4z30t/d/7Zt9fti4h0+lStaCtS3ii/9QjpwAAAAAAAAAAQOZEQ+OhZs2aycvLK8Xj0WOkbGnhwoWp1le2bNpfhggAAAAAAAAAQGbEZqWH5syZo9jY2BQ/8/X1zeBqknvxxRcVHByc4meurq6SJJ4eBgAAAAAAAABwVDQ0HsqfP7+tS3gsb29veXt727oMAAAAAAAAAABsgoYGAAAAAAAAAMChOOoL4v/reIcGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnYusCAAAAAAAAAACwJIOtC4BVsEMDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN1zsXUBAAAAAAAAAABYksFg6wpgDezQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3XGxdAAAAAAAAAAAAlmQwGGxdAqyAHRoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7J6LrQsAAAAA8N/QsFQuW5dgFTF37tu6BKvw9uCPi4C11Pz4Z1uXYBU732lg6xKs4sCZa7YuwSoqBeSwdQmAVfFNfsfEugIAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwey62LgAAAAAAAAAAAEsyGAy2LgFWwA4NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHbPxdYFAAAAAAAAAABgSQZbFwCrYIcGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnYusCAAAAAAAAAACwJIPBYOsSYAXs0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg91xsXQAAAAAAAAAAAJbEN/kdE+sKAAAAAAAAAADsHg0NAAAAAAAAAABg92ho/AeMHj1aFStWtHUZAAAAAAAAAAA8NRoa/wGDBw/W5s2bbV1Gui1ZtFDNGjdQtUrl1bFdGx0KD3/s/I0/rtdLzzdVtUrl1arFC/r1l21mnxuNRk2fOlkN69ZW9cpB6tm9q86ePWPFBCkjVwJykcsayJUgM+RyxEwSuR4hF7mswVFzrfhukVo/31gNalRSjy7tdPTw43P9vOlHdXj5eTWoUUld2rbQru2/JJtzJuK0hr3VV02eCVajWlX1eue2uhD5t7UipMhR14tcCchlu1xtq+bX2gE1tOuduprfvYrK5vN+7HwvdxcNbxaoH9+qpd3v1NOqviGqVdzP9HkWN2cNfraE/jegpnaOqKuvu1VRmSdc0xocca0k6ae1y/R2txZ6vUUdjXnrNf1x4kiqc7duWK2Ph/ZUn7aN1KdtI014p1+y+bM/G6OuzYPNjonvvWntGMk46no5ai7A0dDQ+A/w8vKSn5/fkyfakQ3r12nihHHq1aevlixbpZIlS6l3r+6Kjo5OcX7Ygf0aPuRttXy5tZYuX636DRpqYP++OnXqpGnO13Nna/HCbzVy1GgtWPydPD091btnd929ezejYpHrIXKRyxrIlSAz5HLETBK5HiEXuazBUXNt3rhe0z6boG49+2juwmUqHlhSg/r10tUrKec6dPCAPnh3iJ5v8bK+WrRcdeo10Ii3++uP30+Z5pz/60/16d5ZhQOKaOqX8zR/yUp1ff0Nubu7Z1Qsh10vciUgl+1yPVsmlwY9W0JfbjujDl/u1akLNzW9Y0X5ZHFNcb6Lk0EzO1VU3hweGrr8sFpO360P1x7XpZjEet9/oZSCi/rovdVH9coXe7T7jyua2amScnq7ZUgmyTHXSpJCf9mkJbMnq0WH7vpgynwVLFJcE997UzeuXUlx/vFD+xX8zLMaNm6GRn46R745c+n/3hugq1GXzOaVr1JDk75dZzp6D/0wI+KYOOp6OWouwBFlyoZGvXr1NGDAAA0dOlS+vr7KkyePRo8ebfr82rVr6tWrl3Lnzi0PDw+VK1dOa9euTdO1t2/frjp16sjT01MFCxbUgAEDdOvWLUnSN998Iy8vL506lfgHhj59+qhUqVK6ffu2JGnbtm2qXr263N3dlTdvXg0fPlz3799Pc+1PYjAYNGvWLD3//PPKkiWLSpcurV27dun3339XvXr1lDVrVtWsWVOnT582nfPPR0517dpVLVq00MSJE5U3b175+fmpb9++iouLM7vP6tWrze6dI0cOzZs3L821/hvfzv9aL7duqxYtW6lY8eIaOeoDeXh4aPXKFSnOX7jgG9WsXUddX3tdRYsVU78BA1W6TBktWbRAUkJXfOG336hHr96q36CRAkuW0kfjJujypUv6efNPGZKJXOQiF7nI5biZyEUucpHraSxZMF8vtGyt5i+2VJGixTXknVHy8PDQ2u9Xpjh/2eIFCq5RWx26vKaAIsXUo88ABZYqoxXfLTLN+XLGFNWo9Yz6vDlYgaVKK3/BQqpdt4F8fDPuC06Oul7kIpetc3WsUVCr9v+tNQcjFRF1W2P/d0J34uL1UqV8Kc5/qVJeZfN01dtLD+ngX9cVef2O9p+9plMXb0qS3F2c1KB0Tk3efFr7/7ymv67Gata2CJ27clttqhbIkEySY66VJP24arHqNn1JdRq/oPyFiurVfsPl5uGhXzb+kOL8N4aMUcPnW6twsUDlKxig1wa8K2N8vI4e3Gc2z8XVVTl8/UxHVu9sGRHHxFHXy1Fz/dcZDAaOdB6ZQaZsaEjS/PnzlTVrVoWGhmrChAkaM2aMNm3apPj4eDVr1kw7duzQggULdPToUY0fP17Ozs5PvObp06fVtGlTtWrVSuHh4Vq6dKm2b9+ufv36SZK6dOmi5557Th07dtT9+/f1v//9T3PmzNHChQuVJUsWnT9/Xs8995yqVaumgwcPaubMmZo7d64++uijNNWeVh9++KG6dOmisLAwlSpVSh06dFCvXr00YsQI7du3T0aj0VRzarZs2aLTp09ry5Ytmj9/vubNm5dhzYonibt3T8eOHlFIjZqmMScnJ4WE1FT4wQMpnhMeFqaQkBpmYzVr1VZ4WJgk6fy5c4qKuqzgkMRrent7q3xQhVSvaWnkSkQuclkauRLZey5HzCSRKylykcvSHDZX3D2dPH5UVasn1unk5KSq1UN05NDBFM85HB6mqsEhZmPBNWrpcHiYJCk+Pl47t29TwUKFNahvDz3fqI56dGmnX7Zk3ONnHXa9yGVCLtvkcnEyqHReb4VGJH673ygpNOKKggqk/BfadQP9dejcdQ1vFqhNg2rruzeq67XaheX08O+rnJ0McnFy0r378Wbn3bkfr4oFs1srihlHXCtJuh8XpzO/H1eZitVNY05OTipbsZpOHz+UpmvcvXtHDx48SNawOH5ov/p3aKrhPdto/vRPdPPGdYvW/jiOul6OmgtwVJm2oREUFKRRo0apRIkS6tKli6pWrarNmzfrp59+0p49e7Ry5Uo1btxYRYsW1fPPP69mzZo98Zrjxo1Tx44dNXDgQJUoUUI1a9bUlClT9M033+jOnTuSpFmzZikyMlIDBgxQ9+7dNXr0aFWpUkWSNGPGDBUsWFDTpk1TqVKl1KJFC33wwQf69NNPFR+f+BuE1GpPq27duqlt27YKDAzUsGHDdObMGXXs2FFNmjRR6dKl9eabb2rr1q2PvYaPj4+pzueff17Nmze3yHs27t69qxs3bpgd6d1Kd/XaVT148CDZY7L8/PwUFRWV4jlRUVHy8/NPPj866uHnlxPG/NN+TUsjVyJykcvSyJXI3nM5YiaJXEmRi1yW5qi5rl+7pgcPHsj3H7l8/fwUnUoNV6Kjku208PH105WHj8O4eiVasbdva8G8uQquWVufT/9Sz9RvqHeHvKkDv+21TpB/cNT1IlcictkmV44srnJxctKVW/fMxq/cuic/r5QfD5Xfx1MNy+SUk5NBAxYf1JxfzqhTSCG9XidAknT73gMd/Ou6Xq8TIH8vNzkZpOfK51ZQgezyT+WaluaIayVJMTeuKT7+gbLn8DUbz5bDV9evpvzIqX9a9vV05fD1V5mK1Uxj5auEqOegURr68TS16dZPJw7t16ejBir+wQOL1p8aR10vR80FOKpM3dBIKm/evLp06ZLCwsJUoEABBQYGpvuaBw8e1Lx58+Tl5WU6mjRpovj4eEVEREhKaATMnTtXM2fOVLFixTR8+HDT+ceOHVONGjXMtufUqlVLN2/e1Llz555Ye1olPT937tySpPLly5uN3blzRzdu3Ej1GmXLljXbtZLeGlIzbtw4Zc+e3ez4v0/G/evrAgAAAHg8o9EoSapdt75e6fiqSpQsrc7deqhmnbpavWKpjasDkNGcDAZduRWnj9Ye17HIGG08eklzt59Rqyr5TXPeW31UBoO0cVBt7X63ntpVL6gfD1/Uw19OYCNrv5uv0F82acDIT+TmlvgOpJC6z6pSyDMqGFBcVWrU1cBRnyni5FEdP7TfhtUCQMbKtA0NV1fzl14ZDAbFx8fL09Pzqa958+ZN9erVS2FhYabj4MGDOnXqlIoVK2aa98svv8jZ2VmRkZGm92tYovanOf9R8ySlscdd80k1GAwG0x+IHkn6jo3UjBgxQtevXzc7hgwb8cTzkvLJ4SNnZ+dkL16Kjo6Wv79/iuf4+/srOjoq+fyH3XJ//5wJY1Fpv6alkSsRuchlaeRKZO+5HDGTRK6kyEUuS3PUXNlz5JCzs7Npd8UjV6Kj5ZdKDb5+/sleGH71SrRpl0fCNV0UULSY2ZzCRYrq0oVIC1afOkddL3IlIpdtcl27Haf78fHyzWq+c8I3q5uib95L8Zyom3f1Z/RtxSf5o31E1C3l9HaXy8PnTp27Gqse8w+o5ritem7STnWZu08uzgaduxZrtSxJOeJaSZJ3thxycnLW9X+8APzGtSvK7uObylkJ1q9YoP8t/0aDP5qigkVKPHZurrz55Z0thy5G/vWva04LR10vR80FOKpM29BITVBQkM6dO6eTJ0+m+9zKlSvr6NGjKl68eLLDzS3hNw07d+7UJ598oh9++EFeXl5m76p49ILupI2AHTt2yNvbWwUKZNwLtSwhZ86cioxM/EPPqVOnTC8+fxx3d3dly5bN7HB3d3/ieUm5urmpdJmyCt29yzQWHx+v0NBdCqpQKcVzgipWVOju3WZju3ftVNDDl6HnL1BA/v45FRqaeM2bN2/qUPjBVK9paeRKRC5yWRq5Etl7LkfMJJErKXKRy9IcNpermwJLldFvexPrjI+P1297Q1W2fIUUzykXVFH79pjn2hu6S+WCKpquWbpsOf119ozZnL/OnlXuPCm/NNjSHHa9yGVCLtvkuh9v1LHIGFUv4mMaM0iqXsRH4edSfjrDwb+uq6Cvp5K+4rWwbxZdjrmr+/HmX2C8ExevqJv35O3hohrFfLXtRMY8EscR10pKeHF3QPFSOhqW+Li/+Ph4HQ3bq2Klyqd63rrl32rNkq/09phJKlKi9BPvcyXqom7GXFcOn4z5C3JHXS9HzQU4KodraNStW1fPPPOMWrVqpU2bNikiIkLr16/Xhg0bnnjusGHDtHPnTvXr109hYWE6deqUvv/+e1PTIiYmRp07d9aAAQPUrFkzLVy4UEuXLtXy5cslSX369NFff/2l/v376/jx4/r+++81atQoDRo0SE5OmeunukGDBpo2bZoOHDigffv26Y033ki2q8OaOr/aTSuXf6c1q1fpj9On9dGY0YqNjVWLli9Lkt4dMVSTP//UNL9jpy7aueNXzZ/3lSL+OK2Z06fqyOHDatehk6SEHScdO3fR7FkztfXnzTp18oRGjhiqnLlyqUHDRuQiF7nIRa4MzOWImchFLnKR62m06/Sqfli1XOt/WK0zEac1cdwYxcbGqvmLLSVJH74/Ql9M/dw0v037TgrduUOLv52nsxF/aO6s6Tp+9LBate1gmtO+czdt3rhea1Yu07m/zmrF0oXa+etWtWzTLsNyOep6kYtcts61cNdfalk5n54PyqMi/ln0TvOS8nR11pqwvyVJY14qrX4NiprmL9t3Xtk8XTWkaQkV8vVU7RJ+eq12gL7bm/hI7BrFfFWzmK/y5fBQcFEffdmlks5E3daasIzZ1SU55lpJUpOW7bXtx++1/af/6e8/I/TN9E90984d1Wn8vCTpy09Ha9m86ab5/1v2jVZ+O0uvDRwp/1z5dO1KtK5didad2IQvl96Jva0lc6fo9+OHdPni3zoatleTxwxRrrwFVK5KSIblctT1ctRc/3UGjnQfmYGLrQuwhhUrVmjw4MFq3769bt26peLFi2v8+PFPPC8oKEjbtm3Tu+++qzp16shoNKpYsWJ65ZVXJElvvvmmsmbNqo8//lhSwnsrPv74Y/Xq1Us1atRQ/vz5tW7dOg0ZMkQVKlSQr6+vunfvrpEjR1o1rzV8+umn6tatm+rUqaN8+fJp8uTJ+u233zLs/k2bPaerV65oxrQpioq6rJKlSmvGrDmm7fcXIiPlZEhsElWsVFnjJkzUtCmTNHXSZypUOECTpk5XiRKJ71Lp1r2HYmNjNWb0+4qJuaFKlatoxqw56d5BQi5ykYtc5CITuchFLnJZQsNnm+na1Sua88U0XYmOUvHAUvp06iz5PnxcxcULkXJK8n6+8hUqadTYCZo9c4q+nD5JBQoV1rhPp6po8cRHktRt0EiD3xmlBV/P1qSJ41SocIA+mjBJFSpVybBcjrpe5CKXrXNtPHpJPlld1bteUfl5uenExRj1W3RQV24lPB46T3YPs8dLXbxxV/0WhuntZ0to6RvVdenGPS3e85fm7ThrmuPl7qJ+DYopdzZ3XY+N08/HLmv6ltPJdnBYkyOulSQFP9NYMdevadWCL3X9arQKFQ3U22MmKbtPwmMCoy9flCFJrp/XrdT9+3Ga/rH5Y7tf6vC6WnbsIScnJ50787t2bF6n27dilMM3p8pVqq6XO/eSq2vGvMRdctz1ctRcgCMyGP/5ogTAwu7ct3UFAAAAgPXEOOhveL09HPL7b4BdqPnxz7YuwSp2vtPA1iVYxYEz12xdglVUCshh6xKQDvxnOf1Wh1+wdQmZTougPLYu4Yky13OQAAAAAAAAAADAf9J/qqHRrFkzeXl5pXg8eoyULS1cuDDV+sqWLWvr8gAAAAAAAAAAsJn/1GalOXPmKDY2NsXPfH19M7ia5F588UUFBwen+FlGvpAbAAAAAAAAAAB7859qaOTPn9/WJTyWt7e3vL29bV0GAAAAAAAAAGRqBoOtK4A1/KceOQUAAAAAAAAAADInGhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3XOxdQEAAAAAAAAAAFiSkwy2LgFWwA4NAAAAAAAAAABg92hoAAAAAAAAAAAAu0dDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHbPxdYFAAAAAAAAAABgSQaDrSuANbBDAwAAAAAAAAAA2D0aGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdc7F1AQAAAAAAAAAAWJJBBluXACtghwYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu+di6wIAAAAAAAAAALAkg8HWFcAaaGgAAAAAwL/g7cEfqwCkz7FVK21dgnW808DWFVhFpYActi4BAPAQj5wCAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B5vrwMAAAAAAAAAOBQnGWxdAqyAHRoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7J6LrQsAAAAAAAAAAMCSDAZbVwBrYIcGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALvnYusCAAAAAAAAAACwJIPB1hXAGtihAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuudi6AAAAAAAAAAAALMkgg61LgBWwQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4bGQ/PmzVOOHDlsXYZVde3aVS1atLB1GQAAAAAAAAAApBsNjYdeeeUVnTx5Ml3n1KtXTwMHDrROQdCSRQvVrHEDVatUXh3btdGh8PDHzt/443q99HxTVatUXq1avKBff9lm9rnRaNT0qZPVsG5tVa8cpJ7du+rs2TNWTJAyciUgF7msgVwJMkMuR8wkkesRcpHLGsiVgFzksgZyJbD3XLUqF9PySb30x8axij0wTS/UC3riOXWqlNDORcN0LfRzHf5+lDq9EJxsTq+2z+j4/z7Q1d2f65dvBqtq2cLWKP+xHG2tHiFXAnLZNhfgaGhoPOTp6alcuXJZ/LpGo1H379+3+HUd3Yb16zRxwjj16tNXS5atUsmSpdS7V3dFR0enOD/swH4NH/K2Wr7cWkuXr1b9Bg01sH9fnTqV2KT6eu5sLV74rUaOGq0Fi7+Tp6enevfsrrt372ZULHI9RC5yWQO5EmSGXI6YSSLXI+QilzWQKwG5yGUN5EqQGXJl9XTXoZPnNXDc0jTNL5zPT6umvqFf9p1UcLvxmrZoi2a+30GNapQ2zWn9bGV98nZLjZ21XjU6fKLwk+e1ZkZf5fTxslaMZBxxrSRyPUIu2+b6r3MycKT3yAwyXUOjXr16GjBggIYOHSpfX1/lyZNHo0ePNn1+7do19erVS7lz55aHh4fKlSuntWvXPvG6/3zk1OjRo1WxYkV9++23CggIUPbs2dWuXTvFxMRISnh807Zt2zR58mQZDAYZDAadOXNGW7dulcFg0Pr161WlShW5u7tr+/btunv3rgYMGKBcuXLJw8NDtWvX1t69e033e3Te5s2bVbVqVWXJkkU1a9bUiRMn0vTz8qjeWbNmqWDBgsqSJYvatm2r69evp3pOQECAJk2aZDZWsWJF08+n0WjU6NGjVahQIbm7uytfvnwaMGBAmur5t76d/7Vebt1WLVq2UrHixTVy1Afy8PDQ6pUrUpy/cME3qlm7jrq+9rqKFiumfgMGqnSZMlqyaIEpy8Jvv1GPXr1Vv0EjBZYspY/GTdDlS5f08+afMiQTuchFLnKRy3EzkYtc5CIXuchFLnJZ28YdR/XBjLVas+Xx3xp/pEfr2jpzPlrDP1ulExEX9cXSX7Rqc5j6d6xvmjOgUwN9vXKnvl2zW8f/uKD+Y5co9s49vdqihrViJOOIa0UuctlLLsARZbqGhiTNnz9fWbNmVWhoqCZMmKAxY8Zo06ZNio+PV7NmzbRjxw4tWLBAR48e1fjx4+Xs7PxU9zl9+rRWr16ttWvXau3atdq2bZvGjx8vSZo8ebJq1KihHj16KDIyUpGRkSpYsKDp3OHDh2v8+PE6duyYgoKCNHToUK1YsULz58/X/v37Vbx4cTVp0kRXrlwxu+e7776rTz/9VPv27ZOLi4tee+21NNf7+++/67vvvtMPP/ygDRs26MCBA+rTp89TZZekFStW6PPPP9esWbN06tQprV69WuXLl3/q66VV3L17Onb0iEJq1DSNOTk5KSSkpsIPHkjxnPCwMIWEmP+Gq2at2goPC5MknT93TlFRlxUcknhNb29vlQ+qkOo1LY1cichFLksjVyJ7z+WImSRyJUUuclkauRKRi1yWRq5EmSFXegVXKKItoeZfkty085iCg4pIklxdnFWpdEH9nGSO0WjUz6EnVP3hHGtz1LUiVyJyZZ5fM4DMwsXWBTyNoKAgjRo1SpJUokQJTZs2TZs3b5bRaNSePXt07NgxBQYGSpKKFi361PeJj4/XvHnz5O3tLUnq3LmzNm/erLFjxyp79uxyc3NTlixZlCdPnmTnjhkzRo0bN5Yk3bp1SzNnztS8efPUrFkzSdLs2bO1adMmzZ07V0OGDDGdN3bsWNWtW1dSQlOkefPmunPnjjw8PJ5Y7507d/TNN98of/78kqSpU6eqefPm+vTTT1Os8Un+/PNP5cmTR40aNZKrq6sKFSqk6tWrP/acu3fvJts6Z3R2l7u7e5rve/XaVT148EB+fn5m435+foqI+CPFc6KiouTn559sflR01MPPLyeM+Se/ZlRUVJpr+zfIlYhc5LI0ciWy91yOmEkiV1LkIpelkSsRuchlaeRKlBlypVduv2y6eCXGbOzSlRvK7u0pD3dX+WTLIhcXZ13655zoGyoZkDtDanTUtSJXInJlnl8zgMwiU+7QCAoyf/FV3rx5denSJYWFhalAgQKmZsa/FRAQYGpmJL1PWlStWtX0/0+fPq24uDjVqlXLNObq6qrq1avr2LFjZuclzZY3b15JSvM9CxUqZGpmSFKNGjUUHx+f5sdW/VObNm0UGxurokWLqkePHlq1atUT3wcybtw4Zc+e3ez4v0/GPdX9AQAAAAAAAAB4JFM2NFxdXc1+bDAYFB8fL09Pzwy5T1pkzZr1X9/TYEh4E0ta75leTk5OMhqNZmNxcXGm/1+wYEGdOHFCM2bMkKenp/r06aNnnnnGbM4/jRgxQtevXzc7hgwbka66fHL4yNnZOdmLl6Kjo+Xv75/iOf7+/oqOjko+/2G33N8/Z8JYVNqvaWnkSkQuclkauRLZey5HzCSRKylykcvSyJWIXOSyNHIlygy50uti9A3l9vU2G8vlm03XY2J1526coq7e1P37D5Trn3P8sulC9I0MqdFR14pciciVeX7NADKLTNnQSE1QUJDOnTunkydPZsj93Nzc9ODBgyfOK1asmNzc3LRjxw7TWFxcnPbu3asyZcpYrJ4///xTf//9t+nHu3fvlpOTk0qWLJni/Jw5cyoyMtL04xs3bigiIsJsjqenp1544QVNmTJFW7du1a5du3To0KFUa3B3d1e2bNnMjvQ8bkqSXN3cVLpMWYXu3mUai4+PV2joLgVVqJTiOUEVKyp0926zsd27diqoYkVJUv4CBeTvn1OhoYnXvHnzpg6FH0z1mpZGrkTkIpelkSuRvedyxEwSuZIiF7ksjVyJyEUuSyNXosyQK71CD0aoXnXzvw9oGFJKoeEJf+6Pu/9AB479pfrBiXMMBoPqVw/UnnDzvxuwFkddK3IlIlfm+TXDERn4X7r/lxk4VEOjbt26euaZZ9SqVStt2rRJERERWr9+vTZs2GCV+wUEBCg0NFRnzpxRVFRUqjspsmbNqt69e2vIkCHasGGDjh49qh49euj27dvq3r27xerx8PDQq6++qoMHD+rXX3/VgAED1LZt21Tfn9GgQQN9++23+vXXX3Xo0CG9+uqrZi9QnzdvnubOnavDhw/rjz/+0IIFC+Tp6anChQtbrObUdH61m1Yu/05rVq/SH6dP66MxoxUbG6sWLV+WJL07Yqgmf/6paX7HTl20c8evmj/vK0X8cVozp0/VkcOH1a5DJ0kJvynr2LmLZs+aqa0/b9apkyc0csRQ5cyVSw0aNrJ6HnKRi1zkIpdjZyIXuchFLnKRi1zksrasnm4KCsyvoMCER00H5PdTUGB+FczjI0ka0/9Fzfmws2n+7OXbVaSAn8a++ZICA3KrZ5s6atW4kqYu3GKaM2XBz+rWsqY6vhCskkVya8o7ryiLp7u++d78L2qtyRHXilzkspdcgCPKlC8Ff5wVK1Zo8ODBat++vW7duqXixYtr/PjxVrnX4MGD9eqrr6pMmTKKjY1NtrshqfHjxys+Pl6dO3dWTEyMqlatqh9//FE+Pj4Wq6d48eJ6+eWX9dxzz+nKlSt6/vnnNWPGjFTnjxgxQhEREXr++eeVPXt2ffjhh2YZcuTIofHjx2vQoEF68OCBypcvrx9++CHZS5KsoWmz53T1yhXNmDZFUVGXVbJUac2YNUd+D7flXYiMlJMhsR9XsVJljZswUdOmTNLUSZ+pUOEATZo6XSVKJL5PpVv3HoqNjdWY0e8rJuaGKlWuohmz5qR7Bwm5yEUucpGLTOQiF7nIRS5ykYtcGZ2rcpnC2jjnTdOPJwxuJUn6ds1u9Ry1QHn8s6lgHl/T52f/jlbL/l9owuCX1bdDPZ2/eE29xyzST7sS3+W5fON++ft46f3ezZXbz1vhJ87rpb7Tk70o3Jocca3IRS57yQU4IoPxny9RQKY0evRorV69WmFhYbYuJZk7j3+POAAAAAAA/yk+1frZugSruLp3mq1LAByWh8N9Ld36fj4e/eRJMNOglPW/yP5vOdQjpwAAAAAAAAAAgGP6zzQ0mjVrJi8vrxSPjz/+2NblPVHZsmVTrX/hwoW2Lg8AAAAAAAAAAKv6zzxy6vz584qNjU3xM19fX/n6+qb4mb04e/as4uLiUvwsd+7c8vb2zuCK0o5HTgEAAAAAkIhHTgFILx45lX5bTvDIqfSqX9L+Hzn1n/lXIX/+/LYu4V8pXLiwrUsAAAAAAAAAAMBm/jOPnAIAAAAAAAAAAJkXDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYvf/MS8EBAAAAAAAAAP8NBhlsXQKsgB0aAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOyei60LAAAAAAAAAADAkpwMtq4A1sAODQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z8XWBQAAAAAAAAAAYEkGGWxdAqyAHRoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7J6LrQsAAAAAAAAAAMCSDAZbVwBrYIcGAAAAAAAAAACwe+zQAAAAAAAAyEBX906zdQlW4VOtn61LsApHXS8AyIzYoQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7xzs0AAAAAAAAAAAOxWDrAmAV7NAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdcbF0AAAAAAAAAAACW5GQw2LoEWAE7NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRdbFwAAAAAAAAAAgCUZbF0ArIIdGgAAAAAAAAAAwO7R0AAAAAAAAAAAAHaPhgYAAAAAAAAAALB7NDQAAAAAAAAAAIDdo6EBAAAAAAAAAADsnoutCwAAAAAAAAAAwKIMti4A1sAODQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDuOWRDY968ecqRI4ety8hwBoNBq1evtnUZAAAAAAAAAABYnEM2NF555RWdPHkyXefUq1dPAwcOtE5BGSQyMlLNmjWzdRkWs2TRQjVr3EDVKpVXx3ZtdCg8/LHzN/64Xi8931TVKpVXqxYv6Ndftpl9bjQaNX3qZDWsW1vVKwepZ/euOnv2jBUTpIxcCchFLmsgV4LMkMsRM0nkeoRc5LIGciUgF7msgVwJMkMuR8xUq3IxLZ/US39sHKvYA9P0Qr2gJ55Tp0oJ7Vw0TNdCP9fh70ep0wvByeb0avuMjv/vA13d/bl++WawqpYtbI3yH8sR10si1yOZJRfgaByyoeHp6alcuXJZ/LpGo1H379+3+HUtJU+ePHJ3d7d1GRaxYf06TZwwTr369NWSZatUsmQp9e7VXdHR0SnODzuwX8OHvK2WL7fW0uWrVb9BQw3s31enTiU2tr6eO1uLF36rkaNGa8Hi7+Tp6anePbvr7t27GRWLXA+Ri1zWQK4EmSGXI2aSyPUIuchlDeRKQC5yWQO5EmSGXI6YSZKyerrr0MnzGjhuaZrmF87np1VT39Av+04quN14TVu0RTPf76BGNUqb5rR+trI+ebulxs5arxodPlH4yfNaM6Ovcvp4WStGMo66XuRKkFly/dcZ+F+6/5cpGG2obt26xv79+xuHDBli9PHxMebOnds4atQo0+dXr1419uzZ05grVy6ju7u7sWzZssYffvjhidf9+uuvjdmzZzf9eNSoUcYKFSoYv/nmG2PhwoWN2bJlM77yyivGGzduGI1Go/HVV181SjI7IiIijFu2bDFKMq5bt85YuXJlo6urq3HLli3GO3fuGPv372/MmTOn0d3d3VirVi3jnj17TPd7dN5PP/1krFKlitHT09NYo0YN4/Hjx9P08/Ko3rlz5xoLFixozJo1q7F3797G+/fvGz/55BNj7ty5jTlz5jR+9NFHZudJMq5atcpoNBqNERERRknGFStWGOvVq2f09PQ0BgUFGXfu3JnsPkl9/vnnxsKFC5tlqVatmjFLlizG7NmzG2vWrGk8c+ZMmnI8EhuX/uPlVq2N7436wPTjW3cfGGvVrm2cNmNWivP7DXjT2L1HT7OxVq3bGN8Z+Z4xNs5ovH0v3lizZi3jF1/OMX1+6coNY7ly5Ywrv1/7VDWSi1zkIhe5yEQucpGLXOQiF7nIxe+hEg+Pin3/1WE0Go1tBs567JyJX200Hj513mzsuw37jD9uP2L68Z7wCOPMxVtNP/as1M94/uJV48jJq5+qLkddL3JlrlxIv92/X+NI55EZ2HyHxvz585U1a1aFhoZqwoQJGjNmjDZt2qT4+Hg1a9ZMO3bs0IIFC3T06FGNHz9ezs7OT3Wf06dPa/Xq1Vq7dq3Wrl2rbdu2afz48ZKkyZMnq0aNGurRo4ciIyMVGRmpggULms4dPny4xo8fr2PHjikoKEhDhw7VihUrNH/+fO3fv1/FixdXkyZNdOXKFbN7vvvuu/r000+1b98+ubi46LXXXktXvevXr9eGDRu0ePFizZ07V82bN9e5c+e0bds2ffLJJxo5cqRCQ0Mfe513331XgwcPVlhYmAIDA9W+ffs07zK5f/++WrRoobp16yo8PFy7du1Sz549ZTBYt1sXd++ejh09opAaNU1jTk5OCgmpqfCDB1I8JzwsTCEhNczGataqrfCwMEnS+XPnFBV1WcEhidf09vZW+aAKqV7T0siViFzksjRyJbL3XI6YSSJXUuQil6WRKxG5yGVp5Epk77kcMdPTCq5QRFtCT5iNbdp5TMFBRSRJri7OqlS6oH5OMsdoNOrn0BOq/nCOtTnqepErUWbIBTgqF1sXEBQUpFGjRkmSSpQooWnTpmnz5s0yGo3as2ePjh07psDAQElS0aJFn/o+8fHxmjdvnry9vSVJnTt31ubNmzV27Fhlz55dbm5uypIli/LkyZPs3DFjxqhx48aSpFu3bmnmzJmaN2+e6X0Vs2fP1qZNmzR37lwNGTLEdN7YsWNVt25dSQlNkebNm+vOnTvy8PBIU71fffWVvL29VaZMGdWvX18nTpzQunXr5OTkpJIlS+qTTz7Rli1bFByc/FmRjwwePFjNmzeXJH3wwQcqW7asfv/9d5UqVeqJNdy4cUPXr1/X888/r2LFikmSSpcu/dhz7t69m2zrnNHZPV2Pwrp67aoePHggPz8/s3E/Pz9FRPyR4jlRUVHy8/NPNj8qOurh55cTxvyTXzMqKirNtf0b5EpELnJZGrkS2XsuR8wkkSspcpHL0siViFzksjRyJbL3XI6Y6Wnl9sumi1dizMYuXbmh7N6e8nB3lU+2LHJxcdalf86JvqGSAbkzpEZHXS9yJcoMuQBHZfMdGkFB5i97yps3ry5duqSwsDAVKFDA1Mz4twICAkzNjKT3SYuqVaua/v/p06cVFxenWrVqmcZcXV1VvXp1HTt2zOy8pNny5s0rSWm+5z/rzZ07t8qUKSMnJyezsSdd79/U4Ovrq65du6pJkyZ64YUXNHnyZEVGRj72nHHjxil79uxmx/99Mi5N9wMAAAAAAAAAIDU2b2i4urqa/dhgMCg+Pl6enp4Zcp+0yJo167++56PHNKX1ninV+zQZHleDk5OTjEaj2fy4uDizH3/99dfatWuXatasqaVLlyowMFC7d+9O9X4jRozQ9evXzY4hw0Y8tsZ/8snhI2dn52QvXoqOjpa/v3+K5/j7+ys6Oir5/Ifdcn//nAljUWm/pqWRKxG5yGVp5Epk77kcMZNErqTIRS5LI1cicpHL0siVyN5zOWKmp3Ux+oZy+3qbjeXyzabrMbG6czdOUVdv6v79B8r1zzl+2XQh+kaG1Oio60WuRJkhF+CobN7QSE1QUJDOnTunkydPZsj93Nzc9ODBgyfOK1asmNzc3LRjxw7TWFxcnPbu3asyZcpYs0SLy5kzpy5cuGDW1Ah7+Ky/pCpVqqQRI0Zo586dKleunBYtWpTqNd3d3ZUtWzazIz2Pm5IkVzc3lS5TVqG7d5nG4uPjFRq6S0EVKqV4TlDFigr9R6Nl966dCqpYUZKUv0AB+fvnVGho4jVv3rypQ+EHU72mpZErEbnIZWnkSmTvuRwxk0SupMhFLksjVyJykcvSyJXI3nM5YqanFXowQvWqlzQbaxhSSqHhEZKkuPsPdODYX6ofnDjHYDCofvVA7Xk4x9ocdb3IlSgz5IJkMHCk98gM7LahUbduXT3zzDNq1aqVNm3apIiICNNLsq0hICBAoaGhOnPmjKKiolLd+ZA1a1b17t1bQ4YM0YYNG3T06FH16NFDt2/fVvfu3a1Sm7XUq1dPly9f1oQJE3T69GlNnz5d69evN30eERGhESNGaNeuXTp79qw2btyoU6dOPfE9GpbQ+dVuWrn8O61ZvUp/nD6tj8aMVmxsrFq0fFmS9O6IoZr8+aem+R07ddHOHb9q/ryvFPHHac2cPlVHDh9Wuw6dJCX85qVj5y6aPWumtv68WadOntDIEUOVM1cuNWjYyOp5yEUucpGLXI6diVzkIhe5yEUucpGLTE8nq6ebggLzKygwvyQpIL+fggLzq2AeH0nSmP4vas6HnU3zZy/friIF/DT2zZcUGJBbPdvUUavGlTR14RbTnCkLfla3ljXV8YVglSySW1PeeUVZPN31zfepP3HC0hx1vciVuXIBjsjmLwV/nBUrVmjw4MFq3769bt26peLFi2v8+PFWudfgwYP16quvqkyZMoqNjVVEROpd+/Hjxys+Pl6dO3dWTEyMqlatqh9//FE+Pj5Wqc1aSpcurRkzZujjjz/Whx9+qFatWmnw4MH68ssvJUlZsmTR8ePHNX/+fEVHRytv3rzq27evevXqZfXamjZ7TlevXNGMaVMUFXVZJUuV1oxZc+T3cFvehchIORkS+3EVK1XWuAkTNW3KJE2d9JkKFQ7QpKnTVaJE4jtYunXvodjYWI0Z/b5iYm6oUuUqmjFrTrp3kJCLXOQiF7nIRC5ykYtc5CIXucjF76Eso3KZwto4503TjycMbiVJ+nbNbvUctUB5/LOpYB5f0+dn/45Wy/5faMLgl9W3Qz2dv3hNvccs0k+7Et9runzjfvn7eOn93s2V289b4SfO66W+05O9KNyaHHW9yJW5cgGOyGD850sUAAu7c9/WFQAAAAAAAGvzqdbP1iVYxdW902xdAiAPu/5aun3a88d1W5eQ6VQvmt3WJTyR3T5yCgAAAAAAAAAA4JFM2dBo1qyZvLy8Ujw+/vhjW5f3RGXLlk21/oULF9q6PAAAAAAAAAAA7E6m3Kw0Z84cxcbGpviZr69viuP2ZN26dYqLi0vxs9y5c2dwNQAAAAAAAADgWAy2LgBWkSkbGvnz57d1Cf9K4cKFbV0CAAAAAAAAAACZSqZ85BQAAAAAAAAAAPhvoaEBAAAAAAAAAADsHg0NAAAAAAAAAABg92hoAAAAAAAAAAAAu5cpXwoOAAAAAAAAAECqDLYuANbADg0AAAAAAAAAAGD3aGgAAAAAAAAAAAC7R0MDAAAAAAAAAADYPRoaAAAAAAAAAADA7tHQAAAAAAAAAAAAds/F1gUAAAAAAAAAAGBJBhlsXQKsgB0aAAAAAAAAAADA7tHQAAAAAAAAAAAAdo+GBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOyei60LAAAAAAAAAADAkgwGW1cAa2CHBgAAAAAAAAAAsHs0NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3aGgAAAAAAAAAAAC752LrAgAAAAAAAAAAsCSDrQuAVbBDAwAAAAAAAAAA2D12aAAAAAAA/jNKD/6frUuwisX9a9m6BKuoWDiHrUtAOlzdO83WJQAAHBw7NAAAAAAAAAAAgN2joQEAAAAAAAAAAOweDQ0AAAAAAAAAAGD3eIcGAAAAAAAAAMCxGGxdAKyBHRoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2j4YGAAAAAAAAAACwezQ0AAAAAAAAAACA3aOhAQAAAAAAAAAA7J6LrQsAAAAAAAAAAMCSDDLYugRYATs0AAAAAAAAAACA3aOhAQAAAAAAAAAA7B4NDQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9F1sXAAAAAAAAAACAJRkMtq4A1sAODQAAAAAAAAAAYPdoaAAAAAAAAAAAALtHQwMAAAAAAAAAANg9GhoAAAAAAAAAAMDu0dAAAAAAAAAAAAB2z8XWBQAAAAAAAAAAYEkGWxcAq2CHBgAAAAAAAAAASLfp06crICBAHh4eCg4O1p49e1KdO3v2bNWpU0c+Pj7y8fFRo0aNHjs/JTQ0AAAAAAAAAABAuixdulSDBg3SqFGjtH//flWoUEFNmjTRpUuXUpy/detWtW/fXlu2bNGuXbtUsGBBPfvsszp//nya72kwGo1GSwUAUnLnvq0rAAAAAIAEpQf/z9YlWMXi/rVsXYJVVCycw9YlAIBd8ODFAel28M8YW5eQ6ZTK7aa7d++ajbm7u8vd3T3F+cHBwapWrZqmTZsmSYqPj1fBggXVv39/DR8+/In3e/DggXx8fDRt2jR16dIlTTWyQwMAAAAAAAAAgP+4cePGKXv27GbHuHHjUpx77949/fbbb2rUqJFpzMnJSY0aNdKuXbvSdL/bt28rLi5Ovr6+aa6R3h4AAAAAAAAAAP9xI0aM0KBBg8zGUtudERUVpQcPHih37txm47lz59bx48fTdL9hw4YpX758Zk2RJ2GHhgMrVaqU3N3ddeHChWSfRUREqEOHDsqXL588PDxUoEABvfTSS2b/sG3btk0NGjSQr6+vsmTJohIlSujVV1/VvXv3MqT+JYsWqlnjBqpWqbw6tmujQ+Hhj52/8cf1eun5pqpWqbxatXhBv/6yzexzo9Go6VMnq2Hd2qpeOUg9u3fV2bNnrJggZeRKQC5yWQO5EmSGXI6YSSLXI+QilzWQKwG5bJurc+3C+vX9+jr+f0216q2aqlAoe6pzF/cLUcSk5smOuT2qmeb8X4egZJ/P61Ut1Wtay08/LNPbXVvo9Zfq6IOBr+n0iSOpzt26YbXGDump3m0bqXfbRvrknX7J5s/+bIxefS7Y7Jj43pvWjpGMI/5z6IiZJHI9Qi5ywcIMHOk93N3dlS1bNrMjtYbGvzV+/HgtWbJEq1atkoeHR5rPo6HhoLZv367Y2Fi1bt1a8+fPN/ssLi5OjRs31vXr17Vy5UqdOHFCS5cuVfny5XXt2jVJ0tGjR9W0aVNVrVpVv/zyiw4dOqSpU6fKzc1NDx48sHr9G9av08QJ49SrT18tWbZKJUuWUu9e3RUdHZ3i/LAD+zV8yNtq+XJrLV2+WvUbNNTA/n116tRJ05yv587W4oXfauSo0Vqw+Dt5enqqd8/uyZ4LZ03kSkAuclkDuRJkhlyOmEki1yPkIpc1kCsBuWybq3mlvHq3RWlN3nBKz0/crmPnYzT/jWD5ebmlOP+Nr35Ttfd+Mh3Pjt+m+w/ite5gpNm8rccumc0b8M2BjIhjErptkxbPnqyXOnTXB1Pnq2DR4pr43pu6ce1KivOPh+9XSN1nNXzcDL336Rz5+ufSxJEDdCXK/OWf5avU0OQF60xH76EfZkQcE0f859ARM0nkeoRc5AIyG39/fzk7O+vixYtm4xcvXlSePHkee+7EiRM1fvx4bdy4UUFBQem6Lw0NG6lXr54GDBigoUOHytfXV3ny5NHo0aNNn1+7dk29evVS7ty55eHhoXLlymnt2rVpvv7cuXPVoUMHde7cWV999ZXZZ0eOHNHp06c1Y8YMhYSEqHDhwqpVq5Y++ugjhYSESJI2btyoPHnyaMKECSpXrpyKFSumpk2bavbs2fL09LTIz8HjfDv/a73cuq1atGylYsWLa+SoD+Th4aHVK1ekOH/hgm9Us3YddX3tdRUtVkz9BgxU6TJltGTRAkkJXfGF336jHr16q36DRgosWUofjZugy5cu6efNP1k9D7nIRS5ykcuxM5GLXOQiF7kcP9fr9Ypo6a6/tHzPOf1+8abeXXZIsfceqE1wwRTnX78dp6iYu6ajdkl/xcY90Low84bGvfvxZvNuxN7PiDgmG1YtVt2mL+mZZ19Q/kJF1bXfcLm5e+iXjT+kOP+NoWPU8PnWKlwsUPkKBqj7m+8qPj5eRw/uM5vn6uqqHL5+piOrd7aMiGPiiP8cOmImcpGLXEDm5ebmpipVqmjz5s2msfj4eG3evFk1atRI9bwJEyboww8/1IYNG1S1atV035eGhg3Nnz9fWbNmVWhoqCZMmKAxY8Zo06ZNio+PV7NmzbRjxw4tWLBAR48e1fjx4+Xs7Jym68bExGjZsmXq1KmTaSfGr7/+avo8Z86ccnJy0vLly1PdbZEnTx5FRkbql19+sUjW9Ii7d0/Hjh5RSI2apjEnJyeFhNRU+MGUv60UHhamkBDzf1Fq1qqt8LAwSdL5c+cUFXVZwSGJ1/T29lb5oAqpXtPSyJWIXOSyNHIlsvdcjphJIldS5CKXpZErEblsl8vV2aByBbJr+8ko05jRKO04GaXKATnSdI22wQW1dn+kYu+Z/xkspLif9n7YSJvfqasP25RTjiyuliz9se7HxenM78dVtmJ105iTk5PKVqym348fStM17t69owcPHsjLy7xhcfzQfvVr31TDerTRvGmf6OaN6xat/XEc8Z9DR8wkkSspcpELyIwGDRqk2bNna/78+Tp27Jh69+6tW7duqVu3bpKkLl26aMSIEab5n3zyid577z199dVXCggI0IULF3ThwgXdvHkzzffkpeA2FBQUpFGjRkmSSpQooWnTpmnz5s0yGo3as2ePjh07psDAQElS0aJF03zdJUuWqESJEipbtqwkqV27dpo7d67q1KkjScqfP7+mTJmioUOH6oMPPlDVqlVVv359dezY0XSfNm3a6Mcff1TdunWVJ08ehYSEqGHDhurSpYuyZUv9mzV3795NtnXO6OyermetXb12VQ8ePJCfn5/ZuJ+fnyIi/kjxnKioKPn5+SebHxUd9fDzywlj/smvGRUVpYxArkTkIpelkSuRvedyxEwSuZIiF7ksjVyJyGW7XD5Z3eTi7KSoGPM/60TF3FWx3FmfeH6FQtlVKl82DV9i/jz2bccu68eDF/TXlVgV8s+iIc1Lal6v6np50g7FGy0aIUUxN64pPv6Bsvv4mo1nz+GryL/Opuka3309XTl8/VWmUuK7P8pXCVGVmvWUM3c+XYo8r+XzZ2ji+wP1/qdz5JTGL+r9G474z6EjZpLIlRS5yAVkRq+88oouX76s999/XxcuXND/s3ff4VGUbRuHr90kEDohAem9BAKhCaGo9CoICCi9qoCIIirFQlVAsSBNaaELCAIqVaoFBBSkBaSD0kkIEJIQErLvH5GFfZMggU1mZ/2d3zHH8e7MM5v7cpZ8m7nnmalQoYLWrl1rf1D4X3/9Jav17pyKL774Qrdu3VKbNm0c3mfYsGEOdy+6H2ZoGOj/7w+WJ08eXbp0SXv27FH+/PntzYyUCg4OVqdOneyvO3XqpCVLligiIsK+rm/fvrpw4YIWLFig6tWra8mSJQoICND69eslSR4eHpo1a5bOnDmjjz76SPny5dPo0aMVEBCg8+fPJ/qZd4wZM0bZsmVzWMZ9OOahcgAAAACAO3iuWgH9ee669v7lOEth5R/ntSHkkg6fj9D6/RfVc/pvKl8ou6oV903mnVzLyq/naMeP6/Xqex8qXbq7F7FVq9VQlao9pQJFiqtyjVp6ffinOnnkoA7t321gtQAAIDW88sorOn36tGJiYrRjxw4FBQXZt23ZskWzZ8+2vz516pRsNlui5UGbGRINDUN5eTlOJbZYLIqPj3+kZ1QcPHhQ27dv18CBA+Xp6SlPT09Vq1ZNUVFRWrRokcPYLFmyqHnz5vrggw+0d+9ePfnkk3r//fcdxuTLl0+dO3fWpEmTFBISops3b+rLL79M9ucPGTJE165dc1jeGjQk2fFJ8cnuIw8Pj0QPXgoLC5Ofn1+S+/j5+SksLDTx+H+65X5+ORPWhT74ezobue4iF7mcjVx3uXoud8wkkete5CKXs5HrLnIZlys88pbibsfLL4vjzHO/LOl1+fr9H+6aIZ2HmlXMq8Xb//7Xn/N3WLTCbsSoUM5/n/XhDFmyZpfV6qFr4Y4PAL929Yqy5ciRzF4JVn8zX6uWzNVb709QwSIl7js2V558ypI1uy6d+/f/Bs7gjp9Dd8wkkete5CIXnM/C/6X4/8yAhoYLCgwM1JkzZ3TkyJEU7ztz5kw99dRT2rt3r/bs2WNfBgwYoJkzZya7n8Vikb+/vyIjI5Md4+Pjozx58tx3TPr06ZU1a1aHJSW3m5Ikr3TpVLpMgHZs/9W+Lj4+Xjt2/KrA8hWT3CewQgXt2L7dYd32X7cpsEIFSVK+/Pnl55dTO3bcfc8bN25o/769yb6ns5HrLnKRy9nIdZer53LHTBK57kUucjkbue4il3G5Ym/bdODMNdUscfcklMUi1Sjpq92nrt5336YV8ii9p1Urfj/7rz8ndzZv+WRMp8vXbj5qyQ/E08tLhYv76+De3+zr4uPjdXDPbyruXy7Z/VYtmafvFgbrjVHjVaRk6X/9OVdCL+pGxDVly5E2J/Hc8XPojpkkct2LXOQC8GBoaLigWrVq6amnnlLr1q21fv16nTx5UmvWrNHatWvvu19sbKzmzZun9u3bq2zZsg7LCy+8oB07digkJER79uxRixYttHTpUh08eFDHjh3TzJkzFRwcrBYtWkiSpk6dqj59+uiHH37Q8ePHFRISokGDBikkJETNmzdP9f8Gnbt217KlX+u7Fct14vhxvT9yuKKjo9Wy1bOSpHeGDNTnn31iH9+xUxdt2/qz5swO1skTx/XF5IkKOXBA7Tok3HrLYrGoY+cumj71C23ZtFFHjxzWu0MGKmeuXKpbr36q5yEXuchFLnK5dyZykYtc5CKX++easeWk2lUvoGer5FOxxzLr/bZllTGdp5buSJh18EnH8nqrWalE+z0fVEA/7L+oq1GxDuszpvPQkGf8VaFQduXLkUE1Svhq2guP63RopH76M+3ur964VXv9uPZb/bJhlc79dVJzJn+omJiberJBM0nS1I+H6+tZk+3jVy2Zq2Xzpqpn/3fllyuvrl4J09UrYboZHSVJuhkdpUUzJ+jYn/t1+eI5hez5TeNHvqVcefKrXOVqaZbLHT+H7piJXOQiF4CU4qHgLuqbb77Rm2++qfbt2ysyMlLFixfX2LFj77vPd999p7CwMLVq1SrRttKlS6t06dKaOXOm3n77bRUuXFgjRozQqVOnZLFY7K9ff/11SVLVqlX1yy+/qHfv3jp37pwyZ86sgIAArVixQrVq1UqVzPdq3KSpwq9c0ZRJExQaelml/EtrytQZ8v1nWt6F8+dltdztx1WoWEljPvpYkyaM18Txn6pgocIaP3GySpS4+xyS7j1fVHR0tEYOH6qIiOuqWKmypkydkeIZJOQiF7nIRS4ykYtc5CIXuf57uVb9cV6+mdJpQJOS8suaXofOXle3qTsVeuOWJCmvTwbF2xyf5F00VyZVKZZDnafsSPR+t202+efNqmer5FfWDF66dP2mfv4zVJ+uPqxbt+PTJJMkBdVqoOvXr2rZvGm6Fh6mgkVL6s2R45XNJ+E5HlcuX3R4mOemVcsUFxerSaMdby3cssMLatXpRVmtVv198ph+2bBaUZER8smRUwGVqqp1517y8kqXZrnc8XPojpnIRS5yAUgpi832f9+4ACe7GWd0BQAAAACQoPSbq4wuIVUs7FfT6BJSRYVC2Y0uAQBcgjeXpafYvr9vGF2C6QQWyGx0Cf+KW04BAAAAAAAAAACXR0PDZJo0aaLMmTMnuYwePdro8gAAAAAAAADAcBYLS0oXM2CyksnMmDFD0dHRSW7LkSNHGlcDAAAAAAAAAEDaoKFhMvny5TO6BAAAAAAAAAAA0hy3nAIAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDL4xkaAAAAAAAAAAC3YjG6AKQKZmgAAAAAAAAAAACXR0MDAAAAAAAAAAC4PBoaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHmeRhcAAAAAAAAAAIBTWYwuAKmBGRoAAAAAAAAAAMDl0dAAAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy6OhAQAAAAAAAAAAXJ6n0QUAAAAAAAAAAOBMFlmMLgGpgBkaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFyep9EFAAAAAAAAAADgTBaL0RUgNTBDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOVxyykAAAAAQCJPjN1sdAmp4tDHTxtdAlJg3aELRpeQKhqVzm10CQAAmBIzNAAAAAAAAAAAgMujoQEAAAAAAAAAAFwet5wCAAAAAAAAALgVi9EFIFUwQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDl0dAAAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy/M0ugAAAAAAAAAAAJzKYnQBSA3M0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAADg8jyNLgAAAAAAAAAAAGeyyGJ0CUgFzNAAAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy6OhAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PI8jS4AAAAAAAAAAABnsliMrgCpgRkaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFyep9EFAAAAAAAAAADgTBajC0CqYIaGm9iyZYssFossFousVquyZcumihUrauDAgTp//rzD2KioKA0ZMkTFihWTt7e3cubMqVq1aunbb7+1jzl58qQ6dOigvHnzytvbW/nz51eLFi30559/plmmRV8tUJMGdVWlYjl1bNdW+/ftu+/4H9atUYtmjVWlYjm1btlcP//0o8N2m82myRM/V71aT6hqpUC91LObTp8+lYoJkkauBOQiV2ogVwIz5HLHTBK57iAXuVIDuRKYJVfbyvn03SvVtHXwU5rdvbIC8ma57/jM6T01sHEJrX2thrYNrqVv+gSpZrEc9u1Wi9S7VhF9+0o1/TLoKa3oW009nyiU2jEScdfj5a65tq1ZrjF9ntfb7Rto4uDe+uvooWTH7t/+kz4f+JKGdnla73RspM/e7KldP66zb78dF6fV877UpwO66Z2OjTTqxWe1aMIHunYlNC2i2LnrsSJXAnKRC8C/o6HhZg4fPqxz587pt99+06BBg7RhwwaVLVtW+/fvt4/p3bu3li1bpokTJ+rPP//U2rVr1aZNG4WFhUmSYmNj1aBBA127dk3Lli3T4cOHtXjxYpUrV05Xr15Nkxxr16zWxx+NUa+X+2rRkuUqVcpffXr1tNf4//b8sVuD33pDrZ5to8VLV6hO3Xrq36+vjh49Yh8za+Z0LVwwT+8OG675C79WhgwZ1OelnoqJiUmTTBK57iAXuVIDuRKYIZc7ZpLIdQe5yJUayJXALLkalMml1xsU1/SfT6nTjN915OINTWxfXj4ZvZIc72m1aHLH8sqbLYMGfROi1l/s0AerDutSxN2au9YopDaV8+qjtUfV9sudmrjxuLpUL6jnq+RLq1hue7zcNdeerZv0/ZzJqt+2q177aLryFC6mme+/qRvXwpMcnzFzFtVr3Ul9R0/WgE+CVaVOEy2Z/KEO79kpSboVc1NnTx5RvTZd9NpH09XlrVG6fO5vzR77dpplctdjRa4E5CIXgAdjsdlsNqOL+C+pXbu2AgMD5e3trRkzZihdunTq3bu3hg8fLkm6evWqBg0apBUrVujatWsqXry4xo4dq2bNmt33fbds2aI6deooPDxc2bNnt6+Pjo5WxYoV5efnp19++UWSlD17dn3++efq2rVrku+1Z88eVaxYUadOnVKhQo9+1dPNuJTv07FdWwWULae33x0qSYqPj1fDerXUvkNn9XzxpUTj33qjv6KjozVpylT7uk7tn1Mpf3+9N2ykbDab6td+Ul26dVfX7j0lSREREar7VA2N/GCsmjR9+uHCkYtc5CIXuchELnKRi1xumuuJsZsfKtfs7pV18Nx1fbTuqKSE2z2serWGFv9+RnO2/ZVofOtKedW5ekG1/mKHbscn/efpZ8+X05XIWxq18rB93UetA3QzLl5Dv03+qvuk/DK4TorG3+Hqx+thuXqudYcuPFSuiYN7q0Bxf7V8ob891+jebVWzybOq06rjA73H+LdeUOlK1dWofc8kt/997JAmDu6tIV98LZ+cj6Wovkalc6dovOT6x+phkYtc5How3jw4IMWOXIgyugTTKZk7o9El/CtmaBhgzpw5ypQpk3bs2KGPPvpII0eO1Pr16xUfH68mTZpo69atmj9/vg4ePKixY8fKw8PjoX9WhgwZ1Lt3b23dulWXLl2SJOXOnVurV69WREREkvvkzJlTVqtVS5cu1e3btx/6Zz+s2Fu3dOhgiKpVr2FfZ7VaVa1aDe3b+0eS++zbs0fVqlV3WFej5hPat2ePJOnsmTMKDb2soGp33zNLliwqF1g+2fd0NnLdRS5yORu57nL1XO6YSSLXvchFLmcj111myOVptcg/T2btOHn3KnibpJ2nrigwX9Yk93mqpJ/2nbmmQY1Lal3/mlr8UhV1r1lI1ntufL3vzHVVKeyjgjkySJJK5Mqk8gWya9vxK6kZx85dj5e75oqLjdXZE0dUPLCyfZ3ValWJcpV1+nDIv+5vs9l0dN8uXT73t4qUCUx23M2oSFksFmXIlNkpdd+Pux4rct1FLnIBeDD09gwQGBioYcOGSZJKlCihSZMmaePGjbLZbNq5c6cOHTqkkiVLSpKKFi36yD/P399fknTq1CnlypVL06ZNU8eOHeXr66vy5cvriSeeUJs2bVSzZk1JUr58+TRhwgQNHDhQI0aM0OOPP646deqoY8eO/1pPTExMoqlzNo/0Sp8+/QPXG341XLdv35avr6/Del9fX508eSLJfUJDQ+Xr65dofGhY6D/bLyes80v8nqGhaXPPU3LdRS5yORu57nL1XO6YSSLXvchFLmcj111myJU9o5c8rVZdibzlsP7KjVgV9s2U5D75snvr8cLZtfbARb22aK8K5MioQY1LytNq0fSfT0mSZm89rUzpPLS0T5Di422yWi2asvmE1h64mNqRJLnv8XLXXJER1xQff1tZsvk4rM+c3UeXziaeJXRHdOQNfdCrjeJib8lq9VCrF/qrZPkqSY6NvRWj1fOnqnzNevLOmPRn25nc9ViR6y5ykQvAg2GGhgECAx2v8MiTJ48uXbqkPXv2KH/+/PZmhrPcuauYxZJwidNTTz2lEydOaOPGjWrTpo1CQkL05JNPatSoUfZ9+vbtqwsXLmjBggWqXr26lixZooCAAK1fv/6+P2vMmDHKli2bwzLuwzFOzQMAAADAfVgsFoVHxuqDVYf154UbWn/wkmZtPa3WlfLaxzQok0uNyz2md5cfVMcZv2v4d4fUqVpBPR2Y8tv2AMlJnyGj+o+boVfHTlWj9i/o+zlTdPxA4iupb8fFaf6nw2Wz2fTsSwMMqBQA8EAsLCleTICGhgG8vBwfhmexWBQfH68MGTKkys87dCjhnrKFCxd2qOHJJ5/UoEGD9MMPP2jkyJEaNWqUbt26eyVVlixZ1Lx5c33wwQfau3evnnzySb3//vv3/VlDhgzRtWvXHJa3Bg1JUb0+2X3k4eGR6MFLYWFh8vPzS3IfPz8/hYWFJh7/T7fczy9nwrrQB39PZyPXXeQil7OR6y5Xz+WOmSRy3Ytc5HI2ct1lhlxXo2IVFx+vHJnSOazPkdlLYTeSfghq6I1bOn0lSvc+PuNkaKT8sqSX5z/3nXq1fjHN2fqXfjh4SccvR2r1/otauPNvda9RMNWy3Mtdj5e75sqUJZusVg9F/N8DwG9cDVeW7DmS3c9qtcovT37lLVJCtZ55XuWq19Lm5QscxiQ0M4bp6uWLenHoJ2kyO0Ny32NFrrvIRS4AD4aGhgsJDAzUmTNndOTIEae9Z3R0tKZNm6annnpKOXPmTHZcmTJlFBcXp5s3bya53WKxyN/fX5GRkff9eenTp1fWrFkdlpTcbkqSvNKlU+kyAdqx/Vf7uvj4eO3Y8asCy1dMcp/AChW0Y/t2h3Xbf92mwAoVJEn58ueXn19O7dhx9z1v3Lih/fv2Jvuezkauu8hFLmcj112unssdM0nkuhe5yOVs5LrLDLni4m368/wNVS1y91Y/FklVCvto39nrSe6z98w1FfDJ4HBRYMEcGXU5IkZx/3Q5vD09FG9zfGD47XibfRZ6anPX4+WuuTy9vJSvaEkd27/Lvi4+Pl7H9u9WoVIBD/w+tvh4xcXG2l/faWaEnj+rF4d+qkxZsjm17vtx12NFrrvIRS4AD4aGhgupVauWnnrqKbVu3Vrr16/XyZMntWbNGq1du/aB3+PSpUu6cOGCjh49qkWLFqlmzZoKDQ3VF198YR9Tu3ZtTZ06Vbt27dKpU6e0evVqvf3226pTp46yZs2qPXv2qEWLFlq6dKkOHjyoY8eOaebMmQoODlaLFi1SI3oinbt217KlX+u7Fct14vhxvT9yuKKjo9Wy1bOSpHeGDNTnn31iH9+xUxdt2/qz5swO1skTx/XF5IkKOXBA7Tp0kpTQkOnYuYumT/1CWzZt1NEjh/XukIHKmSuX6tarnyaZyEUucpGLXO6biVzkIhe5yHXXgh1/q2XFPHo6MLcK+2bUkKYllcHLQ9/vPS9JGvFMafWtc/fZfN/sOqusGbz0ZqMSKpgjg2oW91X3moW05Pez9jE/Hw1VjycKqWZxX+XJ5q3apfzUMaiAthy+nGa53PV4uWuuJ5s/p50bVun3LWt18cwpLZ/+qW7FROvxOk0kSYsmfKA1C6bZx29aNl9H9v6msIvndPHMKf343WLt/ukHVXyqgaSEZsa8j4fqzPHDav/au7LF31ZEeJgiwsMcmh6pyV2PFbnIRS4AKcFDwV3MN998ozfffFPt27dXZGSkihcvrrFjxz7w/qVKlZLFYlHmzJlVtGhRNWzYUAMGDFDu3HfvLduoUSPNmTNHb7/9tqKiopQ3b141a9ZMQ4cOlSTlz59fhQsX1ogRI3Tq1ClZLBb769dff93pmZPSuElThV+5oimTJig09LJK+ZfWlKkz5PvPtLwL58/Larnbj6tQsZLGfPSxJk0Yr4njP1XBQoU1fuJklShx93kk3Xu+qOjoaI0cPlQREddVsVJlTZk6I8UzSMhFLnKRi1xkIhe5yEUuciVv/cFL8snopd61isg3UzoduXhD/Rbu05XIhJO+ubOld5htcfF6jPp9tVcDGhTXwpeq6HLELS367YzmbDttHzNu3VH1rlVEg5uUlE9GL4XeuKVlf5zT9J9OpVkudz1e7pqrQs26irx+VT8sClbE1SvKW7i4er4zzn7Lqauhl2Sx3s11K+amlk//TNeuXJZXuvTKlbeg2r36rirUrCtJunblsg7+vlWSNP7Nng4/q9fw8SpWNvWvuHbXY0UucpELQEpYbLb/m7cLONnNOKMrAAAAAJBST4zdbHQJqeKXwXWMLgEpsO7QBaNLSBWNSvNAewAp481l6Sl25GKU0SWYTsnHMhpdwr/inwIAAAAAAAAAwK1YlDbP2kLa4hkaJtGkSRNlzpw5yWX06NFGlwcAAAAAAAAAQKpihoZJzJgxQ9HR0Uluy5EjRxpXAwAAAAAAAABA2qKhYRL58uUzugQAAAAAAAAAAAzDLacAAAAAAAAAAIDLo6EBAAAAAAAAAABcHrecAgAAAAAAAAC4FYvF6AqQGpihAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PJoaAAAAAAAAAAAAJdHQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDleRpdAAAAAAAAAAAAzmQxugCkCmZoAAAAAAAAAAAAl0dDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5nkYXAAAAAAAAAACAU1mMLgCpgRkaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFyep9EFAAAAAAAAAADgTBZZjC4BqYAZGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5FpvNZjO6CLi3qFj3+4hZLdyDDwAAIKXi3fRPD74bmkvvJfuMLiFVfNk20OgSAMAljNtyzOgSUsV79YsbXYLpnLh80+gSTKdoTm+jS/hXzNAAAAAAAAAAAAAuz9PoAgAAAAAAAAAAcCYm0bonZmgAAAAAAAAAAACXR0MDAAAAAAAAAAC4PBoaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHmeRhcAAAAAAAAAAIAzWYwuAKmCGRoAAAAAAAAAAMDl0dAAAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy6OhAQAAAAAAAAAAXJ6n0QUAAAAAAAAAAOBUFqMLQGpghgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAADg8mhoAAAAAAAAAAAAl+dpdAEAAAAAAAAAADiTRRajS0AqYIYGAAAAAAAAAABweTQ0AAAAAAAAAACAy6OhAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PJoaAAAAAAAAAAAAJfnaXQBAAAAAAAAAAA4k8VidAVIDczQAAAAAAAAAAAALo+GhhuyWCz3XYYPHy5JWr58uapVq6Zs2bIpS5YsCggIUP/+/e3vc/v2bY0dO1b+/v7KkCGDcuTIoaCgIM2YMSNNcixeuEBNG9ZVUKVAdW7/nA7s33ff8evXrVWr5k0UVClQbVs1188//eiwfeP6H9TnxR6qXTNIFcv66/Cfh1Kz/GQt+mqBmjSoqyoVy6lju7bav+/+uX5Yt0YtmjVWlYrl1Lpl4lw2m02TJ36uerWeUNVKgXqpZzedPn0qFRMkjVwJyEWu1OCOudwxk0SuO8hFrtTAd8MEZjle7pqrXglffdzcX9OfK6v3GhRXkRwZkh37RBEfzW4f6LBMf65ssuO7Pp5Ps9sHqmEpv9Qo/b7c9Xi5Yy53zCSR6w5yGZvr8I8rtfy97vrqtZZa89HrCj11+IH2O/X7j5rf92ltmToq2TE7Fk7S/L5P69CmFU6qFvjvoqHhhs6fP29fxo8fr6xZszqse/PNN7Vx40Y9//zzat26tXbu3Kldu3bpgw8+UGxsrP19RowYoc8++0yjRo3SwYMHtXnzZr300ku6evVqqmdYt2a1PvlorHr16auvlixTyVKl9HKvF3QlLCzJ8Xv+2K0hA99Qy1ZttHDJctWuW18DXn1Fx44esY+Jjo5WhUqV9errb6Z6/clZu2a1Pv5ojHq93FeLlixXqVL+6tOrp8Luk2vwW2+o1bNttHjpCtWpW0/9+/XV0XtyzZo5XQsXzNO7w4Zr/sKvlSFDBvV5qadiYmLSKha5/kEucqUGd8zljpkkct1BLnKlBr4bJjDL8XLXXFULZlO7inm04sBFDVt7VH9fjdabdYooS3qPZPeJunVbry0/aF/e+O7PJMdVyp9VxfwyKjwqNsntqcldj5c75nLHTBK57iCXsblO7fpJu5ZNV2DTDmo6eIJ88hfRpknv6WbE1fvudyPsonYvn6lcxQKSHfPXnm0KPfmnMmTzdXLVwH8TDQ03lDt3bvuSLVs2WSwWh3WZM2fW999/r5o1a+qtt95SqVKlVLJkSbVs2VKTJ0+2v893332nl19+WW3btlWRIkVUvnx59ezZU2++mfp/9M2fO1vPtmmrFq1aq1ix4npn6Ah5e3trxfJvkhy/cP481aj5hLr26KmixYqpb7/XVLpMGS36aoF9TLNnWqhXn76qVr16qtefnHlzZunZNs+pZavWKla8uN4d9k+uZUnnWjB/rmo88aS69XhBRYsV0yuv9v8n13xJCVcxLJg3Vy/26qM6deurZCl/vT/mI12+dEmbNm4gF7nIRS6XzOWOmchFLnKlLr4bJjDL8XLXXI1K5dSPx6/ol5PhOnc9RnN+O6tbcTY9VTTHffe7djPOvly/GZdoe/YMnupUOa++3PaXbsfbUqv8ZLnr8XLHXO6YiVzkcpVchzYuV/EajVWsegNlz1NQQe1ekUc6bx379Ydk94mPv62ts8cp8OmOyuyXO8kxUVdD9fuSL1Wz21uyeiTfAAfw4Gho/Eflzp1bISEhOnDgwH3HbNq0SZcvX07DyqTY2Fs6dDBEQdVq2NdZrVYFVauufXv3JLnPvr17FFS9hsO66jVqJjveCLG3EnJVq+6Yq1q1Gtq3948k99m3Z4+qVXP8I7tGzSe0b88eSdLZM2cUGnrZ4b9VlixZVC6wfLLv6Wzkuotc5HI2d8zljpkkct2LXORyNr4b3mWK4+WmuTysFhXOkUEHL9ywr7NJCrkYoWJ+GZPdL72nVR8/469PnvHXq08WUt6s6R22WyS9VL2g1hy6rHPX0+5K5Dvc9Xi5Yy53zCSR617kMi7X7bhYXfn7mPL4V7Cvs1ityuNfQaEnkp5ZJ0n7Vy+Ud5bsKl6jUZLbbfHx2jrnE5Wp31rZ8xZydtnAfxYNjf+ofv36qUqVKipXrpwKFy6sdu3aKTg42GE636effqrLly8rd+7cCgwMVO/evbVmzZr7vm9MTIyuX7/usKR0imB4eLhu376tHL6OU/F8ff0UFhqa5D6hoaGJx/slP94I4VcTcvkmyuWr0Pvk8vX1Szw+LPSf7QnNJl+/B39PZyPXXeQil7O5Yy53zCSR617kIpez8d3wLlMcLzfNlSW9hzysFl37vxkW12/GKZu3V5L7nL8eo5k7/taEn05p2q9/y2qx6N0GxeWT4e74pmVyKj7epvVHkr5VS2pz1+PljrncMZNErnuRy7hcMTeuyxYfL+8s2R3We2fJrujr4Unuc+lYiI7/+oOCOvRL9n1D1i+V1eqhUrWfcWa5SAELS4oXM6Ch8R+VKVMmrVq1SseOHdO7776rzJkz64033lDVqlUVFRUlSSpTpowOHDig7du3q0ePHrp06ZKaN2+uF154Idn3HTNmjLJly+awfPzhmLSKBQAAAAAu4XhYlLaduqq/rt7U4cuRmvjzKUXExKlO8YRbVBXyyaCGJf00Y8ffBlcKAEiJ2JtR2jr3EwV1eFXembMlOSbsr6P6c/O3qt75dVksZjlNDJgDDY3/uGLFiumFF17QjBkztHv3bh08eFCLFy+2b7darapSpYr69++vZcuWafbs2Zo5c6ZOnjyZ5PsNGTJE165dc1jeHDQkRTX5+PjIw8Mj0UMew8JC5evnl+Q+fn5+iceHJj/eCD7ZE3L9/4OywsLC5HefXGFhoYnH/3N1g59fzoR1oQ/+ns5GrrvIRS5nc8dc7phJIte9yEUuZ+O74V2mOF5umisi5rZux9uUzdvTYX1Wb09du/lgD/K+bZP+Co9WriwJt50qlSuTsnh76pNnSmvm8+U08/ly8sucTu0q5NHHzf2dniEp7nq83DGXO2aSyHUvchmXK33mrLJYrYkeAH4z4qoyZPVJND7i8nlFhl3Uli9HaEG/5lrQr7lO7NykM/t3aEG/5oq4fF6XjoXo5o1rWv5eN/uYyCuXtHvZTC1/r3ua5ALcFQ0N2BUuXFgZM2ZUZGRksmPKlCkjScmOSZ8+vbJmzeqwpE+fPsmxyfHySqfSZQK0Y8ev9nXx8fHauWO7AstXSHKfwPIVtHP7rw7rtv+6LdnxRvBK90+u7Y65duz4VYHlKya5T2CFCtqxfbvDuu2/blNghQqSpHz588vPL6fDf6sbN25o/769yb6ns5HrLnKRy9ncMZc7ZpLIdS9ykcvZ+G54lymOl5vmuh1v06kr0SqTO7N9nUVSmccy63ho1AO9h8Ui5c/uravRCQ2QrSfD9d6aIxq69u4SHhWrNX9e1sdbkr6AzNnc9Xi5Yy53zCSR617kMi6Xh6eXchQorguH99jX2eLjdeHwHvkVTdxgzpa7gJq9M1lPD5loX/KXC1LuEoF6eshEZfTxU9GqddXs7UkOYzJk81WZ+s+q7iuj0iQX4K48/30I3NHw4cMVFRWlpk2bqlChQrp69aomTJig2NhYNWjQQJLUpk0b1axZUzVq1FDu3Ll18uRJDRkyRCVLlpS/f+peMdSpSzcNfWewygSUVdmygfpq/hxFR0erRctnJUnvDhmkXLly6dXX35Akte/UWS9276K5s4P15FO1tW7NKh0MCdF7w0fa3/Patau6cP68Ll26JEk69c8sE18/P/sVAamtc9fueu/tQQoIKKuy5QI1f15CrpatEnK9M2SgcuV6TK/9k6tjpy7q2a2z5swO1lNP1dLaNasVcuCAPZfFYlHHzl00feoXKlSwkPLlz6/JEz9Xzly5VLde/TTJRC5ykYtcZCIXuciV2vhuaK7j5a651h2+rBerFdDJK9E6ERalhqX8lN7Tqp9PJtxf/cVqBRQeHauley9Ikp4JyKXjYVG6FHFLGdN5qEnpnPLNmE4/Hb8iSYq8dVuRt247/Izb8TZduxmnCxFp94Bwdz1e7pjLHTORi1yukqt0vVbaNvdT5ShYQn6FS+rQpm8VF3NTxaolnCPbOucTZczuq4otusnDK52y5y3ssH+6DJkkyb7eI7OX0mfO6jDG6uEh76w+yvZY/lTPA7gzGhr/UbVq1dLkyZPVpUsXXbx4UT4+PqpYsaJ++OEHlSpVSpLUqFEjLVy4UGPGjNG1a9eUO3du1a1bV8OHD5enZ+p+dBo1aarw8Cv6YtJEhYVeVin/0pr85XT7bQIunD8nq/XuPQgrVKyk0R9+rMkTx2vS55+pYKHC+nTCJBUvUdI+5sfNmzTs3bftrwe/NUCS1KtPX/Xum/xDnJypcZOmCr9yRVMmTVDoP7mmTJ1xT67zslruTpyqULGSxnz0sSZNGK+J4z9VwUKFNX7iZJW4J1f3ni8qOjpaI4cPVUTEdVWsVFlTps5I8cwYcpGLXORKq1zumIlc5CJX6uK74d1cZjhe7ppr51/XlCW9p1qVe0zZvD31V/hNfbLlpK7/86Bw34xestls9vGZ0nmoe9X8yubtqahbt3XqSrTe33BM566nXbPiQbjr8XLHXO6YiVzkcpVchSs/pZiIa9q3cr6iI8Llk6+o6vYdab/lVGT4ZZ6FAbgIi+3eb1xAKoiKdb+PmJX/JwYAAJBi8W76pwffDc2l95J9RpeQKr5sG2h0CQDgEsZtOWZ0CanivfrFjS7BdM6Eu9ZFBGaQ3yftGokPi2doAAAAAAAAAAAAl0dDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5nkYXAAAAAAAAAACAc1mMLgCpgBkaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFyep9EFAAAAAAAAAADgTBaL0RUgNTBDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDL8zS6AAAAAAAAAAAAnMlidAFIFczQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyPI0uAAAAAAAAAAAAZ7JYjK4AqYEZGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDL46HgSHVWnsBjGjGx8UaXkCrSe9G7BQDAFbjr98L4eJvRJaSKDzYeNbqEVPFl20CjSwAApKKwyDijSwCQimhoAAAAAAAAAADcikXueTHNfx2XLQMAAAAAAAAAAJdHQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDl0dAAAAAAAAAAAAAuj4YGAAAAAAAAAABweZ5GFwAAAAAAAAAAgFNZjC4AqYEZGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDLo6EBAAAAAAAAAABcnqfRBQAAAAAAAAAA4EwWowtAqmCGBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyaGgAAAAAAAAAAACX52l0AQAAAAAAAAAAOJPFYnQFSA3M0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAADg8jyNLgAAAAAAAAAAAGeyyGJ0CUgFzNAAAAAAAAAAAAAuj4bGf8Ds2bOVPXt2o8sAAAAAAAAAAOCh0dAwiW7duslischisShdunQqXry4Ro4cqbi4uFT9uY0aNZKHh4d+++23VP05SVn01QI1aVBXVSqWU8d2bbV/3777jv9h3Rq1aNZYVSqWU+uWzfXzTz86bLfZbJo88XPVq/WEqlYK1Es9u+n06VOpmCBp7ppryaIFatGknp6oWl7dOz2vkP33z7Xhh7Vq27KpnqhaXu3bPKOtP/+Y7Ngx7w9X1QqltXD+HGeX/a/c9XiRKwG5jMvljpkkct1BLnKlBnfNtXjhAjVtVFdBlQPVucNzOvAv36HWr1urVs2bKKhyoNq2Spxr44Yf1OelHqr9RJAqlvPX4T8PpWb5yTr28yqtHtFTy958Vhs/fUNXTh95oP3+3v2TlvZvrm0z3k+07fqFv7V1+iitGPy8lg9so42fvK6o8EvOLv2+3PVzSK4EZsjljpkkct1BLmNzPVEku4Y2KKZxzUrq9acKqWB27wfar2K+LBrfwl89q+ZzWJ85vYc6VMyjEY2K6aOnS6pXtfzyy+SVGqUD/yk0NEykcePGOn/+vI4ePao33nhDw4cP17hx41Lt5/3111/atm2bXnnlFQUHB6faz0nK2jWr9fFHY9Tr5b5atGS5SpXyV59ePRUWFpbk+D1/7Nbgt95Qq2fbaPHSFapTt5769+uro0fv/uE0a+Z0LVwwT+8OG675C79WhgwZ1OelnoqJiUmrWG6ba/261Rr/yYd6oVdfzV34jUqULKVXX35RV64knWvfnj/03pA39UzL1pq3aJlq1amnt17vp+PHEv+hu3nTeh3Yt1c5c+ZK7RiJuOvxIlcCchmXyx0zSeS6g1zkSg3ummvd2tX6ZNxY9erdV199vUwlS5bSy71e0JXkcu3ZrSGD3lDLZ9to4ZLlql23vga89oqO3ZMrOjpaFSpW1quvv5lWMRL5e/fP2rdihso0bq/6b45X9nxF9POXQ3Uz4up994sMu6h93wbLr2hAom03Qs9ry4RByvJYftV6ZbQaDJyo0o3ayeqZLpVSJOaun0NyJTBDLnfMJJHrDnIZm6ti3ixqGZBLaw+H6uMfT+nstRj1rl5AmdN53He/HBm81CIgl46HRiXa9kLV/PLN6KUZO87q4x9PKTw6Vi/XKKh0HjzXAXgUNDRMJH369MqdO7cKFSqkPn36qH79+vruu+8UHh6uLl26yMfHRxkzZlSTJk109OjRJN/j1KlTslqt+v333x3Wjx8/XoUKFVJ8fLx93axZs9SsWTP16dNHCxcuVHR0dKrmu9e8ObP0bJvn1LJVaxUrXlzvDhshb29vrVj2TZLjF8yfqxpPPKluPV5Q0WLF9Mqr/VW6TBkt+mq+pIRu/4J5c/Virz6qU7e+Spby1/tjPtLlS5e0aeMGcj2ir+bNUctn26p5y2dVtFhxDX53uLy9vfX9imVJjl/01VxVq/GEOnfrqSJFi6l339fkX7q0vl70lcO4Sxcv6pOxH2jk6I/k6emZFlEcuOvxIhe5jM7ljpnIRS5ykethzJ87W8+2bqsWrVqrWLHiemfoCHln8NaK5UnnWjh/nmrUfEJdu/dU0aLF1Lffawm5Fi6wj2nWvIV69emratWqp1WMRI5sWaEi1RupcFB9Zc1dUJXaviyPdOl1asf6ZPexxd/WzvmfqEyTDsrk+1ii7QdWzVPuMpUV+Ex3+eQvpsx+eZS3bJC8s2RPxSSO3PVzSC7z5HLHTOQil6vkql08h349fU07/7qmixG3tGTvBd26Ha+gQtmS3cciqVPlPFrzZ6jComIdtuXM5KXCOTJoyb4L+vvqTV26cUtL9l6Ul4dFlfJlTeU0gHujoWFiGTJk0K1bt9StWzf9/vvv+u677/Trr7/KZrOpadOmio2NTbRP4cKFVb9+fc2aNcth/axZs9StWzdZrQkfCZvNplmzZqlTp07y9/dX8eLFtXTp0jTJFXvrlg4dDFG16jXs66xWq6pVq6F9e/9Icp99e/Yk+qOtRs0ntG/PHknS2TNnFBp6WUHV7r5nlixZVC6wfLLv6Wxumyv2lv48FKIqQXfrtFqtqhJUXfv37Ulyn/379qpqkGOuatWfcBgfHx+vYe8OUqeuPVSseInUKP2+3PZ4kcuOXMbkcsdMErnuRS5yOZvb5opNyHVvDVarVUHVqmvf3j1J7rNv7x6H8ZJUvUbNZMcbIT4uVlfPHFOukuXt6yxWqx4rWUFhpw4nu9/BdYuUPnM2FanWMNE2W3y8Lhz8XZlz5tPPXwzV9+920sZP39DZfb+mSoakuO3nkFx2rp7LHTNJ5LoXuYzL5WGR8mfz1pHLkfZ1NklHLkepsE+GZPdrVMpPN27d1o6/riXa5vnP+bXY2zaH94yLt6mob0an1Y5/YWFJ8WICNDRMyGazacOGDVq3bp0KFiyo7777TjNmzNCTTz6p8uXLa8GCBTp79qxWrFiR5P4vvPCCFi5caJ+6t3v3bu3fv1/du3e3j9mwYYOioqLUqFEjSVKnTp00c+bMf60tJiZG169fd1hSOkUw/Gq4bt++LV9fX4f1vr6+Cg0NTXKf0NBQ+fr6JR4fFvrP9ssJ6/we/D2dzV1zXQ2/qtu3byvH/+XK4eursGRqCAsNVY7/y5XD11dX7hk/d9YMeXp46PkOnZ1f9ANw1+NFrrvIZUwud8wkkete5CKXs7ltrvDwJL9D+fr6KSws+VxJjk+jmh9ETOR12eLj5Z3Fx2F9+izZdfN6eJL7hJ4I0ant61X5+VeSfs8b1xQXE63DG5fqsdKV9GTvkcoXWE2/zhqjy8f2Oz1DUtz2c0guO1fP5Y6ZJHLdi1zG5cqU3lMeVosiYhyfUxsRE6es3knfLaJIjgyqViibFu+5kOT2izdidCUqVs3K5FQGL6s8LFK94jnkk8FLWb3vfxsrAPdHQ8NEVq5cqcyZM8vb21tNmjTR888/r27dusnT01NBQUH2cb6+vipVqpQOHUr6AYAtW7aUh4eHli9fLkmaPXu26tSpo8KFC9vHBAcH6/nnn7ff5qd9+/baunWrjh8/ft8ax4wZo2zZsjks4z4c84jJ8V9z6GCIFn01T0NHjpHFYpL2MAAAAFIs9maUds7/VJWef0XpMyd9Ww+bLeG2uHnLBqlk7ZbKnr+o/Ou3VZ4yVXRi69q0LBcAAKX3tKpTpTxavOeCIm/dTnJMvE0K3nlGuTKn05imJfVRs1Iq7pdRBy/ekM2W5C4AHhANDROpU6eO9uzZo6NHjyo6Olpz5sx5qJO96dKlU5cuXTRr1izdunVLX331lXr06GHffuXKFS1fvlxTpkyRp6enPD09lS9fPsXFxf3rw8GHDBmia9euOSxvDRqSovp8svvIw8Mj0QOlwsLC5Ofnl+Q+fn6Jr2QLCwuT3z9XAfj55UxYF/rg7+ls7poru092eXh4JHp45ZWwMPkmU4Ovn5+u/F+uK2FhyvHP+D27f1f4lTA906Suqlcuq+qVy+r8+XP6/NOP1KJJvdQJ8n/c9XiR6y5yGZPLHTNJ5LoXucjlbG6by8cnye9QYWGJr2S9w8/PL+nxaVTzg0ifKassVqtuRjjOxoiJuCrvrD6JxkeGXlDUlUvaNmOUvhnQQt8MaKHTv2/WuZCd+mZAC90IPf/Pe3ooa+6CDvtmeayAoq5eTtU8d7jt55Bcdq6eyx0zSeS6F7mMyxUZE6fb8TZlSe84GyNLek9dvxmXaLxfRi/5ZkqnF4Ly65PmpfRJ81J6vEBWBeTOrE+al5JvRi9J0plrMRq35ZQGrzqioeuOaer2M8qUzkOhUYlvEQ/gwdHQMJFMmTKpePHiKliwoH3mROnSpRUXF6cdO3bYx4WFhenw4cMqU6ZMsu/1wgsvaMOGDZoyZYri4uL07LPP2rctWLBA+fPn1969e7Vnzx778sknn2j27Nm6fTvp7rOU8ODyrFmzOizp06dPUU6vdOlUukyAdmy/e0/c+Ph47djxqwLLV0xyn8AKFbRj+3aHddt/3abAChUkSfny55efX07t2HH3PW/cuKH9+/Ym+57O5ra5vNLJv3SAftt5t874+Hj9vnO7ygVWSHKfcoHlHcZL0o7t2+zjmzR7Rl8tWaH5i5fZl5w5c6lT1x6a8MWM1IriwG2PF7nsyGVMLnfMJJHrXuQil7O5bS6vf3LtcMy1c/t2BZavkOQ+geUraOcOx+dGbP91W7LjjWD19FL2/MV16eg++zpbfLwuHdkr38KlEo3P8lh+NRg0SfXfmmBf8gZUVc7i5VT/rQnKmN1PVk8v+RQsoYhLZxz2vXH5rDL65Ez1TJIbfw7JZefqudwxk0Sue5HLuFy3bdKZazdVImcm+zqLpJI5M+pUeHSi8Rdv3NLYTSc0bstJ+xJy4YaOhUZp3JaTuhrt2LC4GRevyFu35ZfJSwWye+vA+YjUjgS4NRoaJleiRAm1aNFCL774on755Rft3btXnTp1Ur58+dSiRYtk9ytdurSqVaumQYMGqX379sqQ4e5DjmbOnKk2bdqobNmyDkvPnj0VGhqqtWtTf1p3567dtWzp1/puxXKdOH5c748crujoaLVsldB4eWfIQH3+2Sf28R07ddG2rT9rzuxgnTxxXF9MnqiQAwfUrkMnSZLFYlHHzl00feoX2rJpo44eOax3hwxUzly5VLde/VTP4+65OnTuqm+XLdHK71bo5Inj+vCDEYqOjlazFq0kScPeHaTJEz61j2/XoYt+3faLFsydpVMnT2jaF5N06GCInmvXQZKUPbuPihUv6bB4enrK19dPhQoXSbNc7nq8yEUuo3O5YyZykYtc5HoYnbp00/Jvlui7b5frxInjGj0qIVeLlgm53n17kCaMv5urfafO2rb1F82dE6yTJ07oyykTdTAkRO3ad7SPuXbtqg7/ech+q9hTp07q8J+H7PcoTwsla7fUyV/X6dTOjbp+4W/tXjJFcbduqnBQwn/bnfM/1f7v50iSPLzSKVueQg6LV4ZM8kqfQdnyFJLVM+Eq11J1n9Xff/yiE7+u043L53Ts55U6H7JTxZ5omma53PVzSC7z5HLHTOQil6vk2nLsiqoXyqYqBbLqsczp1Lb8Y0rnYbU/8LtjpTxqVjqhiR4Xb9OFiFsOS3RsvGLi4nUh4pbuPAe8fN4sKu6bUb4ZvVQ2d2a9XKOg9p+/ocOXo9IsF+COkn6yDUxl1qxZeu2119SsWTPdunVLTz31lFavXi0vL6/77tezZ09t27bN4XZTu3bt0t69ezV9+vRE47Nly6Z69epp5syZevrpp52e416NmzRV+JUrmjJpgkJDL6uUf2lNmTrDPp3+wvnzslru9uMqVKykMR99rEkTxmvi+E9VsFBhjZ84WSVKlLSP6d7zRUVHR2vk8KGKiLiuipUqa8rUGSmeQUKuxBo0aqrw8HBN+2KCwkJDVbJUaX0+ZZr9dgkX/y9XYIWKGjV6nL6c/LmmTPxMBQoW0rjPJqpY8ZLJ/QhDuOvxIhe5jM7ljpnIRS5ykethNGqckOuLyRMV9k+uyV9OvyfXOVnvucVshQqVNHrsx5o8abwmff6ZChYqrE8/n6Ti9+T6cfMmDXvvbfvrwW8NkCT16tNXvV/ulya5ClR6UjGR13RwzQLdvB6ubPmK6oleI+wPCo8Kv5ziW+fmC6yuSm1f1uENS7Rn2TRlyZlP1bsPkV/RgNSIkCR3/RySyzy53DETucjlKrn+OBehTOk91MQ/p7Km99DZ6zGauv1v3YhJuEuJTwavFD/7Ipu3p1qWzWW/ddVvf1/TD4fT5kHnSMBTWd2TxWbjUTT/VaNGjdKSJUu0b9++fx/8CJK43SBcVExsvNElpIr0XkxGAwAAqSc+3j3/pPpg41GjS0gV7zVwrYtoAADONXjVn0aXkCrGt/A3ugTTCb3BScmU8svs+vMfOMv3H3Tjxg0dOHBAkyZNUr9+aXOVFgAAAAAAAAAAj4KGxn/QK6+8osqVK6t27doOt5sCAAAAAAAAAMBVuf4cEjjd7NmzNXv2bKPLAAAAAAAAAADggTFDAwAAAAAAAAAAuDxmaAAAAAAAAAAA3IrFYnQFSA3M0AAAAAAAAAAAAC6PhgYAAAAAAAAAAHB5NDQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAADg8jyNLgAAAAAAAAAAAGeyyGJ0CUgFzNAAAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy6OhAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PI8jS4AAAAAAAAAAABnsliMrgCpgRkaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyaGgAAAAAAAAAAACXR0MDAAAAAAAAAAC4PBoaAAAAAAAAAADA5dHQAAAAAAAAAAAALo+GBgAAAAAAAAAAcHkWm81mM7oIuLebcUZXAAAAAAAA8HB8Go81uoRUcXr5G0aXkCqyZvAyuoRU4e1pdAXmczX6ttElmE72DB5Gl/CvmKEBAAAAAAAAAABcHg0NAAAAAAAAAADg8mhoAAAAAAAAAAAAl0dDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOV5Gl0AAAAAAAAAAADOZJHF6BKQCpihAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PJoaAAAAAAAAAAAAJdHQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDleRpdAAAAAAAAAAAAzmSxGF0BUgMzNAAAAAAAAAAAgMujoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyaGgAAAAAAAAAAACXR0MDAAAAAAAAAAC4PE+jCwAAAAAAAAAAwJksRheAVMEMDQAAAAAAAAAA4PJoaAAAAAAAAAAAAJdHQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDl0dAAAAAAAAAAAAAuz9PoAgAAAAAAAAAAcCqL0QUgNTBDAwAAAAAAAAAAuDwaGgAAAAAAAAAAwOXR0AAAAAAAAAAAAC6PhgbsunXrppYtW9r/t8VikcVikZeXl4oUKaKBAwfq5s2baVbPoq8WqEmDuqpSsZw6tmur/fv23Xf8D+vWqEWzxqpSsZxat2yun3/60WG7zWbT5Imfq16tJ1S1UqBe6tlNp0+fSsUESSNXAnKRKzWQK4EZcrljJolcd5CLXKmBXAnIRa7UQK4EZsjljpkk983V65lK+nN+H4WvflM/Teyix0vlSXasp4dVQzrVVMjcXgpf/aZ2TO2hBlWKOIx5sXlF7ZzWQxe/fV0Xv31dWyZ0VsMqRVM7RiLLvl6ots0bql6NSnqpa3sdPLD/vuM3b1injq2bq16NSur6fCv9+stPDtuffLxskstXc4NTM0Yi7vo5BNwNDQ0kq3Hjxjp//rxOnDihzz77TFOnTtWwYcPS5GevXbNaH380Rr1e7qtFS5arVCl/9enVU2FhYUmO3/PHbg1+6w21eraNFi9doTp166l/v746evSIfcysmdO1cME8vTtsuOYv/FoZMmRQn5d6KiYmJk0ySeS6g1zkSg3kSmCGXO6YSSLXHeQiV2ogVwJykSs1kCuBGXK5YybJfXO1qe2vD3vX1QfzflH13rO078QlfTf2eeXMnjHJ8cO7P6UXmlXQgEnrVbHndM1Y+YcWD39W5Ys/Zh9z9nKE3puxRTVenq2aL8/Wlj9Oa8nI1ipdyC+tYmnjD2s06bOP1O3FPpoxf4mKlyylN/r1UviVpI/X/r1/aMQ7A/V0i1aauWCJnqxdV2+/+apOHDtqH7Ni7RaHZfDQUbJYLKpdt0FaxXLbzyHglmzAP7p27Wpr0aJFov99x7PPPmurWLFiit83Ojbly7Ot29jeGzbC/joy5rat5hNP2CZNmZrk+Fdefc3W88WXHNa1btPW9va779miY222qFvxtho1atq+nDbDvv3Sleu2smXL2pZ9u/KhaiQXuchFLnKRiVzkIhe5yEUucpGL71Dun8u73pgULzsPnrV9sfx3++sM9cfYzl6+bnt3+uYkx5+7fN322ufrHNYt/+lP21fr99/354Rdi7L1GrfqoWq8eP1WipcWrVrbBr8zzP76/NWbtho1n7B9MmFKkuN79+1n69rjBYd1LZ9tY3tr8DvJ/oweL/a2tevY+aHqu3j9ltt+DpFyETfjWVK4mAEzNPBADhw4oG3btildunSp/rNib93SoYMhqla9hn2d1WpVtWo1tG/vH0nus2/PHlWrVt1hXY2aT2jfnj2SpLNnzig09LKCqt19zyxZsqhcYPlk39PZyHUXucjlbOS6y9VzuWMmiVz3Ihe5nI1cd5GLXM5GrrtcPZc7ZpLcN5eXp1UVS+bWpt2n7OtsNmnT7lOqWiZfkvukS+epm7fiHNZFx8SqRtkCSY63Wi1qW7u0Mnl7acfBs06r/X5iY2N15M+DqhxU7Z46rHq8ajWF7Nub5D4H9u3V41Udj1fV6jV0YH/S46+EherXX35SsxbPOq/wf+Gun0PAXdHQQLJWrlypzJkzy9vbW+XKldOlS5f01ltv3XefmJgYXb9+3WFJ6VS68Kvhun37tnx9fR3W+/r6KjQ0NMl9QkND5evrl3h8WOg/2y8nrPN78Pd0NnLdRS5yORu57nL1XO6YSSLXvchFLmcj113kIpezkesuV8/ljpkk983lly2jPD2suhQe6bD+UnikcvtkSnKfDb+f0KttqqhYPh9ZLFLdSoXV4olSyp3DcXxAkZy6/P0AXVvzlib0b6Tnhy/Tn38lfVskZ7v2z/HKkcPxv61PDl+FhSX93/ZKWGii8Tly+OlKMuPXrPxOGTNl1FN16jun6Afgrp9DwF3R0ECy6tSpoz179mjHjh3q2rWrunfvrtatW993nzFjxihbtmwOy7gPx6RRxQAAAAAAAObz5uQNOn42XHuDX9T1tQP1Wb8Gmrtun+JtNodxR/4OU1CvYD31yhxN//4PTR/YTP4FfZN5V/NZ/d1yNWjcTOnTpze6FAAuioYGkpUpUyYVL15c5cuXV3BwsHbs2KGZM2fed58hQ4bo2rVrDstbg4ak6Of6ZPeRh4dHogcvhYWFyc8v6Qdd+fn5JboaICwsTH7/dMv9/HImrAt98Pd0NnLdRS5yORu57nL1XO6YSSLXvchFLmcj113kIpezkesuV8/ljpkk980Vei1Kcbfjlev/ZmPk8smkC/83a+PuPtF6btgy+Tb7RKU6TFH57tMVGR2rk+evOoyLjYvXiXNX9cfRixo680ftP3FJfZ99PLWiOMj2z/G68n8PAA+/EpZotsIdOXz9Eo2/ciVUOZIYv/ePXfrr9Ek1b5l2t5uS3PdzCLgrGhp4IFarVW+//bbeffddRUdHJzsuffr0ypo1q8OS0q66V7p0Kl0mQDu2/2pfFx8frx07flVg+YpJ7hNYoYJ2bN/usG77r9sUWKGCJClf/vzy88upHTvuvueNGze0f9/eZN/T2ch1F7nI5WzkusvVc7ljJolc9yIXuZyNXHeRi1zORq67XD2XO2aS3DdXbFy8/jhyQXUqFbavs1ikOhULaee/PO8iJva2zoXdkKeHVS2fLKWV247ed7zVYlF6L09nlP2vvLy8VNK/jHbt3GFfFx8fr12/7VBAYPkk9ykbWF67fnM8Xr/v+FVlyyUev/LbZSpVuoyKl/R3buH/wl0/h4C7oqGBB9a2bVt5eHho8uTJqf6zOnftrmVLv9Z3K5brxPHjen/kcEVHR6tlq4Qu/TtDBurzzz6xj+/YqYu2bf1Zc2YH6+SJ4/pi8kSFHDigdh06SZIsFos6du6i6VO/0JZNG3X0yGG9O2SgcubKpbr10u6+jOQiF7nIRS73zEQucpGLXOQiF7nIRSZy3WvCNzvVvWl5dWxQVqUK+mrCa42U0Tud5q7dJ0maMaiZRvasZR9fxT+PWjxRUoXzZFPNsvn13ZjnZLVa9Oniu82DkT1rqWa5Air4WDYFFMmpkT1r6anyBbVoY0ia5Xq+YxetXLFUa1Z+q1Mnj+uTMaMUHR2tps1bSpLeHzpEX076zD6+TbtO2rFtqxbNn63Tp04oeOpk/XkwRM8+18HhfSNv3NCWDT+oWYv73+o8tbjr5/C/zmJhSeliBmnTwoVb8PT01CuvvKKPPvpIffr0UaZMST/IyhkaN2mq8CtXNGXSBIWGXlYp/9KaMnWGfP+Zlnfh/HlZLXf7cRUqVtKYjz7WpAnjNXH8pypYqLDGT5ysEiVK2sd07/mioqOjNXL4UEVEXFfFSpU1ZeqMNL0vI7nIRS5ykcs9M5GLXOQiF7nIRS5ykYlc91q65U/5Zcuood2e1GM+mbTv+CW1GLJYl65GSZIK5Mqq+Pi7z8dIn85Tw7o/pSJ5sutG9C2t23lCPT9cqWuRMfYxObNn1MxBzZQ7RyZdi4zRgZOX1XzwYm3afSrNctVr2ERXw8M188tJuhIWquIl/fXxxC/tt5C6eOG8LNa7x6tc+Yoa9sGHmj5loqZN/lz5CxTS6I8nqGjxEg7vu/GHNbLZbKrfuGmaZbmXu34OAXdksdn+7+lCgJPdjDO6AgAAAAAAgIfj03is0SWkitPL3zC6hFSRNYOX0SWkCm8uS0+xyFuc9k6pTOlcf5oGt5wCAAAAAAAAAAAuj4YGAAAAAAAAAABweTQ0AAAAAAAAAACAy+PuawAAAAAAAAAAt+L6T4PAw2CGBgAAAAAAAAAAcHk0NAAAAAAAAAAAgMujoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyaGgAAAAAAAAAAACX52l0AQAAAAAAAAAAOJXF6AKQGpihAQAAAAAAAAAAXB4NDQAAAAAAAAAA4PJoaAAAAAAAAAAAAJdHQwMAAAAAAAAAALg8GhoAAAAAAAAAAMDleRpdAAAAAAAAAAAAzmSRxegSkAqYoQEAAAAAAAAAAFweDQ0AAAAAAAAAAODyaGgAAAAAAAAAAACXR0MDAAAAAAAAAAC4PBoaAAAAAAAAAADA5XkaXQAAAAAAAAAAAM5ksRhdAVIDMzQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAACQYpMnT1bhwoXl7e2toKAg7dy5877jlyxZIn9/f3l7e6tcuXJavXp1in4eDQ0AAAAAAAAAAJAiixcv1oABAzRs2DDt3r1b5cuXV6NGjXTp0qUkx2/btk3t27dXz5499ccff6hly5Zq2bKlDhw48MA/02Kz2WzOCgAk5Wac0RUAAAAAAAA8HJ/GY40uIVWcXv6G0SWkiqwZvIwuIVV4expdgflwTjLlLLdjFBMT47Auffr0Sp8+fZLjg4KCVKVKFU2aNEmSFB8frwIFCqhfv34aPHhwovHPP/+8IiMjtXLlSvu6atWqqUKFCvryyy8frEgb4AZu3rxpGzZsmO3mzZtGl+JU5DIXcpkLucyFXOZCLnNxx1zumMlmI5fZkMtcyGUu5DIXcgHmMWzYMJskh2XYsGFJjo2JibF5eHjYli9f7rC+S5cutmeeeSbJfQoUKGD77LPPHNYNHTrUFhgY+MA1MkMDbuH69evKli2brl27pqxZsxpdjtOQy1zIZS7kMhdymQu5zMUdc7ljJolcZkMucyGXuZDLXMgFmEdMzIPP0Dh37pzy5cunbdu2qXr16vb1AwcO1I8//qgdO3Yk2iddunSaM2eO2rdvb183ZcoUjRgxQhcvXnygGpmsBAAAAAAAAADAf9z9bi/lKngoOAAAAAAAAAAAeGB+fn7y8PBINLPi4sWLyp07d5L75M6dO0Xjk0JDAwAAAAAAAAAAPLB06dKpcuXK2rhxo31dfHy8Nm7c6HALqntVr17dYbwkrV+/PtnxSeGWU3AL6dOn17Bhw1x+SlRKkctcyGUu5DIXcpkLuczFHXO5YyaJXGZDLnMhl7mQy1zIBbivAQMGqGvXrnr88cdVtWpVjR8/XpGRkerevbskqUuXLsqXL5/GjBkjSXrttddUq1YtffLJJ3r66ae1aNEi/f7775o2bdoD/0weCg4AAAAAAAAAAFJs0qRJGjdunC5cuKAKFSpowoQJCgoKkiTVrl1bhQsX1uzZs+3jlyxZonfffVenTp1SiRIl9NFHH6lp06YP/PNoaAAAAAAAAAAAAJfHMzQAAAAAAAAAAIDLo6EBAAAAAAAAAABcHg0NAAAAAAAAAADg8mhoAAAAAAAAAAAAl0dDAwAAAAAAADDY6dOndfDgQcXHxxtdCgC4LBoaAAAAAEyrbt26unr1qtFlAADwwIKDg/Xpp586rHvppZdUtGhRlStXTmXLltXff/9tUHUA4NpoaMCUDh48qJdfflkVK1ZUnjx5lCdPHlWsWFEvv/yyDh48aHR5qeL48eOqW7eu0WU8lPPnz2v+/PlavXq1bt265bAtMjJSI0eONKgywNxu3bqlr7/+Wq+//rrat2+v9u3b6/XXX9eSJUsS/VtzFxcvXjT174wzZ87oxo0bidbHxsbqp59+MqAiwPy2bNnilr/zIiMj1adPH+XLl085c+ZUu3btdPnyZaPLcqrdu3dr//799tfffvutWrZsqbffftstj6k7uX37tvbs2aPw8HCjS3kkf//9t86cOWN/vXPnTvXv31/Tpk0zsKqHFxcXp5iYGId1Fy9e1IgRIzRw4ED98ssvBlWG/zdt2jT5+PjYX69du1azZs3S3Llz9dtvvyl79uwaMWKEgRWmDpvNpjVr1qhNmzZGl5IqoqOjjS4B+E+w2Gw2m9FFACmxZs0atWzZUpUqVVKjRo302GOPSUr4orZ+/Xrt2rVL3377rRo1amRwpc61d+9eVapUSbdv3za6lBT57bff1LBhQ8XHxys2Nlb58uXTihUrFBAQICnhuOXNm9d0ue7YuXOnfv31V124cEGSlDt3blWvXl1Vq1Y1uLLUER4eru+//15dunQxupSHEh8fL6s1cS8/Pj5eZ86cUcGCBQ2o6uEcO3ZMjRo10rlz5xQUFOTwu3DHjh3Knz+/1qxZo+LFixtcqXOZ9Xfh+fPn1aJFC+3atUsWi0UdOnTQlClTlDlzZknm/1148OBBTZo0Kcnfh6+88orKlCljcIXOd/z4cb344ovatGmT0aWk2Pnz57Vx40blyJFD9evXV7p06ezbIiMj9cknn2jo0KEGVpgyVqtVFy5cUK5cuYwuxakGDBigadOmqWPHjsqQIYO++uor1axZU8uXLze6NKepUqWKBg8erNatW+vEiRMKCAhQq1at9Ntvv+npp5/W+PHjjS7xocydO/e+2834Pap///4qV66cevbsqdu3b6tWrVratm2bMmbMqJUrV6p27dpGl/hQnnzySb300kvq3LmzLly4oFKlSikgIEBHjx5Vv379TPW7UJK6d++udOnSaerUqZKkiIgIBQQE6ObNm8qTJ48OHjyob7/9Vk2bNjW40pQ5cuSIrl696vA31saNG/X+++8rMjLS3gg1E19fX23ZskXlypWTJPXp00eXL1/W0qVLJSU067t3766TJ08aWabTnDx5UsHBwZo9e7YuX76s+vXra+XKlUaX5TQxMTGaNGmSxo0bZ/8uDCD10NCA6ZQvX14tWrRI9grd4cOHa9myZdq3b18aV/ZoJkyYcN/tZ8+e1ccff2y6k10NGjRQgQIFNGPGDEVGRmrQoEH6+uuvtX79elWsWNG0J/EuXbqk1q1ba+vWrSpYsKDDyeS//vpLNWvW1DfffON2J1fMejL5+vXreuGFF/T9998ra9as6tWrl4YNGyYPDw9J5jyZ3KBBA2XKlElz585V1qxZHbZdv35dXbp0UXR0tNatW2dQhQ/n3353//nnn2rfvr2pjpUkde3aVYcPH9akSZN09epVDR48WBaLRT/88IN8fHx08eJF5cmTx5T3S+ZCA3N9Ft3xQgOr1apNmzYpR44c9x0XGBiYRhU5R5EiRfTRRx+pbdu2kqRdu3apWrVqio6Olqenp8HVOUe2bNm0e/duFStWTB9++KE2bdqkdevWaevWrWrXrp1pb7dy71XXUsIsvKioKKVLl04ZM2bUlStXDKrs4eXPn18rVqzQ448/rhUrVqhv377avHmz5s2bp02bNmnr1q1Gl/hQfHx8tH37dpUqVUoTJkzQ4sWLtXXrVv3www/q3bu3Tpw4YXSJKVKyZElNmjRJDRs2lCRNnjxZo0eP1sGDB5UtWzYNGjRIO3fu1ObNmw2uNGVatWqlcuXK2c8BnDx5UgEBAXryySfl7++v4OBgjRo1Sv379ze20BTImDGjDh06pEKFCklKOM/Rs2dPvfrqq5Kkv/76S6VKlTL1Ff8xMTFaunSpZs6cqV9++UW3b9/Wxx9/rJ49eyb6+8UMYmJiNHz4cK1fv17p0qXTwIED1bJlS82aNUvvvPOOPDw89Morr2jQoEFGlwq4Pff4Joz/lCNHjqhjx47Jbm/fvr0+/PDDNKzIOfr37688efI4XCV5L7NOu9+1a5cmT54sq9WqLFmyaMqUKSpYsKDq1aundevWmeqK+Hu9/PLLun37tg4dOqRSpUo5bDt8+LB69Oihvn37asmSJQZV+HCuX79+3+0RERFpVIlzvffee9q7d6/mzZunq1ev6v3339fu3bu1bNky+785s/X3t27dqp07dyb5x0DWrFk1atQoBQUFGVDZo6lQoYIsFkuSx+POeovFYkBlj2bDhg1avny5Hn/8cUkJx69t27aqW7euNm7cKEmmzCVJgwcP1qBBg5K80GD48OEaPny43nrrLdM1NB7kQgMzevvtt9WqVSuHCw1q1aplv9DArOrVq/evvzfM1KSREm5RV7NmTfvrypUry8vLS+fOnTPt96f/Z7PZ7I3cDRs2qFmzZpKkAgUKKDQ01MjSHklSt2E6evSo+vTpo7feesuAih5daGiocufOLUlavXq12rZtq5IlS6pHjx76/PPPDa7u4cXGxip9+vSSEj6DzzzzjCTJ399f58+fN7K0h3L27FmVKFHC/nrjxo1q3bq1smXLJinhAotZs2YZVd5D+/333zVw4ED76wULFqhkyZL2C3cCAwM1ceJEUzU0ChUqpF27dqlQoUIKDQ1VSEiIw+/8Cxcu2I+b2ezatUszZ87UwoULVbx4cXXu3FkLFy5U/vz51ahRI1M2MyRp6NChmjp1qurXr69t27apbdu26t69u7Zv365PP/1Ubdu2tV8wByB10dCA6RQuXFirVq1KdBL5jlWrVtmvcjCTQoUK6cMPP9Rzzz2X5PY9e/aocuXKaVyVc9y8edPh9eDBg+Xp6amGDRsqODjYoKoezbp16/TTTz8l+Tm8c4WXGafeZ8+e/b4nVc16MnnFihWaM2eO/Zi0bNlSTz/9tJo3b67vvvtOkvlOJmfPnl2nTp1S2bJlk9x+6tQpZc+ePW2LcoIcOXLoo48+Ur169ZLcHhISoubNm6dxVY/u2rVrDlfspk+fXsuWLVPbtm1Vp04dzZ8/38DqHg0XGpiLu15osGPHDuXMmdPoMpwqPj5eXl5eDus8PT1N15i5n8cff1zvv/++6tevrx9//FFffPGFpISrr+/M9nIXJUqU0NixY9WpUyf9+eefRpeTYo899pgOHjyoPHnyaO3atfZjFRUVZeoTeAEBAfryyy/19NNPa/369Ro1apQk6dy5c/L19TW4upTz9vZ2uKJ/+/btGjdunMP2pJ7l5epCQ0OVP39+++vNmzc7fB+sXbu23njjDSNKe2hdu3ZV3759FRISok2bNsnf39/h7/1t27Yl+z3f1QUFBalfv3722U/uYsmSJZo7d66eeeYZHThwQIGBgYqLi9PevXtN97ckYHY0NGA6I0eOVIcOHbRlyxbVr1/f4dYWGzdu1Nq1a/XVV18ZXGXKVa5cWbt27Uq2oZHcFcuurmzZstq2bVui2zy8+eabio+PV/v27Q2q7NGkT5/+vrMZIiIi7Fd7mUmWLFn0zjvvJHtl/9GjR9WrV680rurRXb582aHR6efnpw0bNqhRo0Zq2rSpZsyYYWB1D+eFF15Qly5d9N5776levXqJfhe+//776tevn8FVplzlypV17ty5ZBvTV69eNeXvwqJFi2rfvn0OV016enpqyZIlatu2rf2qZDPiQgPzcccLDQoWLOh2t3m02WyqV6+ew+2loqKi1Lx5c4dG2+7du40ozynGjx+vjh07asWKFXrnnXfsz31aunSpatSoYXB1zufp6alz584ZXcZD6d69u5577jnlyZNHFotF9evXl5TQTPT39ze4uof34YcfqlWrVho3bpy6du2q8uXLS5K+++47Uz4Tr0KFCpo3b57GjBmjn3/+WRcvXlTdunXt248fP668efMaWOHDyZEjh86fP68CBQooPj5ev//+uwYMGGDffuvWLdN9Pxw4cKCioqK0bNky5c6dO9HM/q1bt5r2b+V69epp5syZunTpkjp37qxGjRq5xQn/M2fO2L/7lS1bVunTp9frr7/uFtkAs6GhAdNp27at8uXLpwkTJuiTTz5J9PDRLVu2qHr16gZXmXIjR45UVFRUstvLlCljygeCdenSRT/++KN69+6daNvAgQNls9n05ZdfGlDZo3n++efVtWtXffbZZ6pXr5592uz169e1ceNGDRgwwJRfQCtVqiRJqlWrVpLbs2fPbro/FqSEE12HDh1SkSJF7OuyZMmiH374QQ0bNlSrVq0MrO7hjBw5UpkyZdK4ceP0xhtv2L9I22w25c6dW4MGDXKYmm8WvXv3VmRkZLLbCxYsaMpbJTRp0kTTpk1T69atHdbfaWq0bt1aZ86cMai6R8OFBubirhcauKNhw4YlWteiRQsDKkk9gYGB2r9/f6L148aNM/VV/3dmf95hs9l0/vx5TZo0yeGWMmYyfPhwlS1bVn///bfatm1rv3DHw8NDgwcPNri6h1e7dm2Fhobq+vXrDjMpX3rpJWXMmNHAyh7O0KFD1aRJE3399dc6f/68unXrpjx58ti3L1++3JSfwdq1a2vUqFGaMmWKlixZovj4eIfZ8AcPHlThwoUNq+9hWK1WjRw5Mtlng5rt1sX3Wrdunf7++2/NmjVLffr0UXR0tJ5//nlJ5psVf6/bt287XFDg6empzJkzG1gR8N/FQ8EB4CHExMSof//+Cg4OVlxcnP2Lza1bt+Tp6amePXvqs88+M90sjenTpys6Otr+MLr/d/HiRX355ZdJnmRxZa+++qrOnz+f5B8GERERatCggX777TfT3sbj5MmTDs3dexs3cA1xcXGKiopK9p7BcXFxOnv2rClnMkgJt0WYMGGCfv3110QXGrz22mumvNDg4MGDioqKsj/35P/FxsbedzaRq5oxY4Z+/PFHzZs3L8ntH374ob788ktTXURRp04dLV++PNnb7J0/f14ffPCBJk2alLaF4T/LarU6vLZYLMqZM6fq1q2rTz75xOEEM+Bshw4d0g8//KDcuXOrbdu2Dp/HadOmqWrVqqpQoYJxBT6EU6dOqUGDBjp+/Lg8PDw0YcIE9enTx769ZcuWKlKkiD777DMDq3x0N2/e1OLFixUZGamGDRvaZ62Z3fr16zVr1iwtX75cBQoUUJs2bdSmTRv7xXRmYbVa1aRJE/vf+N9//73q1q2rTJkyOYxbtmyZEeUB/yk0NOAWxo4dq969e5vyfvH3Qy7Xd/36de3atcvhBF7lypVN+6AzdxUeHq5z584pICAgye0RERHavXt3sjNTzGLr1q16/PHHTddI+zfkAvBvQkJCtHnzZqVLl07PPfecsmfPrtDQUH3wwQf68ssvVbRoUYWEhBhd5kPbt2+fjhw5IkkqWbJkohk2ZmW1Wu97ta5ZLzRwR8ldRX7H0KFD06gS5ypSpMh9P4MnTpxIw2pwP3FxcQoJCVHOnDkT3TZr7969yp8/v6meezJgwADFxsZq4sSJkhIujAsKClJISIgyZsyouLg4rV+/3pQXhSQnPDxc8+fPV3BwsPbt22e63/HdunV7oBkmZpxNDpgNDQ24haxZs2rPnj0qWrSo0aU4FbnM5cyZM8qbN2+iq/LMjlzm4a7/tshlPu7UuL4XuVzTd999pzZt2iguLk5SwjNrpk+frueee06VK1dW//791bhxY4OrfDg7d+5Uz549dfDgQfstziwWiwICAjRz5kxVqVLF4AofzbfffuvwOjY2Vn/88YfmzJmjESNGqGfPngZVhv9XsWJFh9exsbE6efKkPD09VaxYMdM+y+Xzzz93eH3nM7h27Vq99dZbprud1pEjR3T16lWH53/cebZaZGSkWrZsqbffftvACp0rLi5ON2/eNOVtf8qWLavRo0frmWeekZRwEvyNN97QH3/8oYIFC6pHjx66dOmSVq1aZXClqWP37t2mm6EBwHXQ0IBbyJIli/bu3et2J4XIZS7uenKSXObhrv+2yGU+7vjvSyKXq6patapq1qypUaNGacaMGRowYIACAgIUHBxs6hP+Bw8eVFBQkEqXLq3XX39dpUuXtq//7LPPdPjwYW3fvl1lypQxuFLn++qrr7R48eJEDQ+zuH37tmbPnq2NGzfq0qVLio+Pd9i+adMmgypzruvXr6tbt25q1aqVOnfubHQ5TjV58mT9/vvvprvSulWrVipXrpx9Rs3JkycVEBCgJ598Uv7+/goODtaoUaPUv39/YwtNoe+//15hYWHq1q2bfd0HH3ygUaNGKS4uTnXr1tXixYsdnoPi6rJmzardu3fbbyvVvn17ZcmSRdOmTZMk7dmzR02bNtW5c+eMLPORFC5cWD169FC3bt1UsGBBo8t5ZM8+++y/jrFYLPrmm2/SoBrgv819LksFAIO5a3+YXABSyl3/fZHLNR0+fFh9+/ZV5syZ1a9fP1mtVn322WembmZICQ9hbtCggXbs2KH27durQoUKqlChgjp06KCdO3eqXr16Gj58uNFlpopq1app48aNRpfx0F577TW99tprun37tsqWLavy5cs7LO4ia9asGjFihN577z2jS3G6Jk2amPKk5O+//64mTZrYXy9YsEAlS5bUunXr9Pnnn2v8+PGaPXu2cQU+pE8//VSRkZH219u2bdPQoUP13nvv6euvv9bff/+tUaNGGVhhylmtVof//7t9+3ZVq1bN/jp79uwKDw83ojSn6d+/v5YtW6aiRYuqQYMGWrRokWJiYowu66Fly5btXxduPQ2kDU+jCwCc4eDBg8qXL5/RZTgduQCkxNSpU/XYY48ZXYbTkQvA/URERNhPIHh4eChDhgymnW1yr82bN2vNmjVJ3q/bYrHo7bffVtOmTQ2oLHVFR0drwoQJpv6uuGjRIn399ddueXz+37Vr13Tt2jWjy3C6pUuXKkeOHEaXkWKhoaHKnz+//fXmzZvVvHlz++vatWvrjTfeMKK0RxISEqJPP/3U/nrp0qVq0KCB3nnnHUmSt7e3XnvtNYcxrq506dL6/vvvNWDAAIWEhOivv/5SnTp17NtPnz5t+u+J/fv3V//+/bV7927Nnj1b/fr108svv6wOHTqoR48eprvllNlmbAHujIYG3ELOnDk1b948RUZGqkGDBipRooTRJTkFuczl7bffNuUfPv+GXObRoUMHnT59WqdPn5a/v7/bPB+EXObjro1rcrmudevWKVu2bJKk+Ph4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",
      "text/plain": [
       "<Figure size 2000x2000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import confusion_matrix, ConfusionMatrixDisplay\n",
    "import seaborn as sns\n",
    "cm = confusion_matrix(all_targets, all_preds)\n",
    "\n",
    "np.fill_diagonal(cm, 0)\n",
    "cm_normalized = cm.astype('float') / cm.sum(axis=1, keepdims=True)\n",
    "cm_normalized = np.nan_to_num(cm_normalized)\n",
    "\n",
    "plt.figure(figsize=(20, 20))\n",
    "sns.heatmap(cm_normalized, annot=True, fmt='.2f', cmap='Blues', xticklabels=list(label_dict.values()), yticklabels=list(label_dict.values()))\n",
    "plt.xlabel('Predicted')\n",
    "plt.ylabel('True')\n",
    "plt.title('Confusion Matrix')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(19208,)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_targets[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_preds = np.concatenate(all_preds, axis=0)\n",
    "all_targets = np.concatenate(all_targets, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "input_ids (1, 309)\n",
      "token_type_ids (1, 309)\n",
      "attention_mask (1, 309)\n",
      "labels_mask (1, 309)\n",
      "letter_level_attention_mask (1, 2000)\n",
      "letter_level_token_types_ids (1, 2000)\n",
      "letter_level_tokens (1, 2000)\n",
      "letter_level_labels_mask (1, 2000)\n",
      "embedding_repeater (1, 2000)\n",
      "CURR LOGITS SHAPE torch.Size([1, 307, 1024])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:20<00:00, 95.45it/s] \n"
     ]
    }
   ],
   "source": [
    "gene_pred_generation = prediction(dataset_seq_atcg[:2000], model_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[3.8326e-05, 8.2076e-05, 3.5572e-04, ..., 4.1931e-02, 4.8364e-01,\n",
       "        4.7241e-01],\n",
       "       [1.3530e-05, 1.1116e-04, 2.5034e-06, ..., 1.6081e-04, 3.5763e-07,\n",
       "        2.6226e-06],\n",
       "       [5.9605e-07, 1.5497e-06, 1.4305e-06, ..., 8.4758e-05, 5.9605e-08,\n",
       "        1.1921e-07],\n",
       "       ...,\n",
       "       [1.0133e-06, 2.3246e-06, 7.7486e-07, ..., 2.4052e-03, 2.9802e-07,\n",
       "        6.5565e-07],\n",
       "       [9.5367e-07, 2.3246e-06, 7.1526e-07, ..., 2.4147e-03, 2.9802e-07,\n",
       "        6.5565e-07],\n",
       "       [4.6492e-06, 6.1393e-06, 6.1393e-06, ..., 6.6528e-02, 1.3351e-05,\n",
       "        1.4186e-05]], dtype=float16)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gene_pred_generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9993135460251046"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(dataset_labels == gene_pred_generation) / len(dataset_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('gene_pred_generation.npy', gene_pred_generation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "input_ids (1, 4670)\n",
      "token_type_ids (1, 4670)\n",
      "attention_mask (1, 4670)\n",
      "labels (1, 4670, 5)\n",
      "labels_mask (1, 4670)\n",
      "letter_level_attention_mask (1, 30592)\n",
      "letter_level_token_types_ids (1, 30592)\n",
      "letter_level_tokens (1, 30592)\n",
      "letter_level_labels (1, 30593)\n",
      "letter_level_labels_mask (1, 30593)\n",
      "embedding_repeater (1, 30592)\n"
     ]
    }
   ],
   "source": [
    "gene_pred_forward = model.forward(**prepare_sequence_forward(dataset_seq_atcg, tokenizer, np.concatenate((np.array([24]), dataset_labels), axis=0)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [],
   "source": [
    "gene_pred_forward_processed = torch.argmax(gene_pred_forward['logits'], axis=-1)[0, 1:].detach().cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9991827928870293"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(dataset_labels == gene_pred_forward_processed) / len(dataset_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('gene_pred_forward_processed.npy', gene_pred_forward_processed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([22, 16, 16, 16, 16, 16, 16, 16, 16, 16])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_labels[:10]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tensorboard logs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation Scores: [ 0.    0.    0.58  0.58  0.99  0.99  1.    1.    1.    1.    1.    1.\n",
      "  1.    1.    1.    1.    1.    1.    1.    1.    0.99  0.99  1.    1.\n",
      "  1.    1.    1.    1.   -0.   -0.    0.    0.    0.    0.    0.    0.\n",
      "  1.    1.    0.5   0.5   0.44  0.44  0.56  0.56  1.    1.    0.45  0.45\n",
      "  0.41  0.41  0.5   0.5   1.    1.    0.51  0.51  0.45  0.45  0.58  0.58\n",
      "  0.33  0.33  0.57  0.57  0.63  0.63  0.52  0.52  0.26  0.26  0.48  0.48\n",
      "  0.68  0.68  0.37  0.37  0.41  0.41  0.64  0.64  0.66  0.66  0.61  0.61\n",
      "  0.48  0.48  0.69  0.69  0.68  0.68  0.69  0.69  0.36  0.36  0.59  0.59\n",
      "  0.71  0.71  0.5   0.5   0.53  0.53  0.73  0.73  0.71  0.71  0.75  0.75\n",
      "  0.01  0.01  0.02  0.02  0.86  0.86  0.01  0.01  0.    0.    0.    0.\n",
      "  0.    0.    0.    0.    1.    1.    0.09  0.09  0.09  0.09  0.1   0.1\n",
      "  1.    1.    0.04  0.04  0.04  0.04  0.04  0.04  1.    1.    0.25  0.25\n",
      "  0.23  0.23  0.27  0.27  1.    1.    0.23  0.23  0.21  0.21  0.26  0.26\n",
      "  0.11  0.11  0.27  0.27  0.55  0.55  0.18  0.18  0.15  0.15  0.37  0.37\n",
      "  0.57  0.57  0.27  0.27  0.16  0.16  0.28  0.28  0.6   0.6   0.18  0.18\n",
      "  0.21  0.21  0.32  0.32  0.8   0.8   0.2   0.2   1.    1.    0.16  0.16\n",
      "  0.15  0.15  0.17  0.17]\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "from tensorboard.backend.event_processing import event_accumulator\n",
    "\n",
    "os.chdir('/home/jovyan/dnalm/')\n",
    "# Path to your logs directory\n",
    "log_dir = 'runs/annotation_encoder_bert_large_24_classes_GPT2_1024_decoder_4k_with_overlaps_no_loss_weights_with_all_embeddings_in_decoder_avg_hyperparameters_shuffle_starts_featured/bert_large_512_lastln_t2t_1000G_bs256_lr_1e-04_fp16/model_1750000/rmt_seglen_512_len16000_maxnsegm_10000_msz_5_bptt-1_lr5e-05_AdamW_constant_with_warmup_wd1e-04_p10000_bs_it500000/run_1/events.out.tfevents.1742236734.anogena-0.1563066.0'  # replace this with actual path\n",
    "\n",
    "# Load event files\n",
    "ea = event_accumulator.EventAccumulator(log_dir)\n",
    "ea.Reload()\n",
    "\n",
    "# List all tags (i.e., card names)\n",
    "all_tags = ea.Tags()\n",
    "\n",
    "# Only select validation scalar tags\n",
    "validation_tags = [tag for tag in all_tags['scalars'] if '/valid' in tag]\n",
    "\n",
    "# Fetch the latest scalar value for each validation tag\n",
    "latest_scores = []\n",
    "\n",
    "for tag in validation_tags:\n",
    "    events = ea.Scalars(tag)\n",
    "    if events:\n",
    "        latest_value = events[-1].value  # Get the last value\n",
    "        latest_scores.append(latest_value)\n",
    "\n",
    "# Convert to numpy array\n",
    "validation_scores_np = np.array(latest_scores)\n",
    "\n",
    "# Print or return it\n",
    "print(\"Validation Scores:\", np.round(validation_scores_np, 2))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Copy and paste the following into Google Sheets:\n",
      "\t0.9932\n",
      "\t0.9990\n",
      "\t0.9972\n",
      "\t0.0000\n",
      "\t0.3900\n",
      "\t0.4264\n",
      "\t0.4601\n",
      "\t0.7231\n",
      "\t0.6852\n",
      "\t0.7950\n",
      "\t0.6919\n",
      "\t0.7206\n",
      "\t0.7363\n",
      "\t0.1009\n",
      "\t0.1083\n",
      "\t0.0681\n",
      "\t0.0250\n",
      "\t0.1697\n",
      "\t0.0875\n",
      "\t0.3779\n",
      "\t0.4084\n",
      "\t0.0176\n",
      "\t0.0184\n",
      "\t0.0007\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "OrderedDict([('CDS-0', 0.9931769967079163),\n",
       "             ('CDS-1', 0.9990405440330505),\n",
       "             ('CDS-2', 0.9971976280212402),\n",
       "             ('CDS-skip', 0.0),\n",
       "             ('intron-0', 0.3899613916873932),\n",
       "             ('intron-1', 0.4263862371444702),\n",
       "             ('intron-2', 0.46005386114120483),\n",
       "             ('ASS-0', 0.7230976819992065),\n",
       "             ('ASS-1', 0.6852438449859619),\n",
       "             ('ASS-2', 0.7949564456939697),\n",
       "             ('DSS-0', 0.6919227838516235),\n",
       "             ('DSS-1', 0.7205707430839539),\n",
       "             ('DSS-2', 0.736315906047821),\n",
       "             ('START', 0.10092044621706009),\n",
       "             ('STOP', 0.1083148792386055),\n",
       "             ('nc_exon_plus', 0.06809669733047485),\n",
       "             ('nc_exon_minu', 0.024983562529087067),\n",
       "             ('nc_intron_plus', 0.16967032849788666),\n",
       "             ('nc_intron_minu', 0.08745795488357544),\n",
       "             ('nc_ASS', 0.37789517641067505),\n",
       "             ('nc_DSS', 0.40839439630508423),\n",
       "             ('TSS', 0.017570143565535545),\n",
       "             ('PolyA', 0.01841171272099018),\n",
       "             ('IR', 0.0006542973569594324)])"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from tensorboard.backend.event_processing import event_accumulator\n",
    "from collections import OrderedDict\n",
    "import os\n",
    "\n",
    "os.chdir('/home/jovyan/')\n",
    "# Path to your logs directory\n",
    "log_dir = 'dnalm/runs/annotation_decoder_with_2k_intergenic_only_1024_selected_start_less_1500_weighted_4_classes_recall_TSS_level_selection/bert_large_512_lastln_t2t_1000G_bs256_lr_1e-04_fp16/model_1750000/rmt_seglen_512_len4096_maxnsegm_10000_msz_5_bptt-1_lr5e-05_AdamW_constant_with_warmup_wd1e-04_p10000_bs_it500000/run_1/events.out.tfevents.1743932859.anogena-0.61706.0'  # replace this with actual path\n",
    "\n",
    "ea = event_accumulator.EventAccumulator(log_dir)\n",
    "ea.Reload()\n",
    "\n",
    "# Exact ordered list from your image (as seen visually)\n",
    "ordered_labels = [\n",
    "    \"CDS-0\", \"CDS-1\", \"CDS-2\", \"CDS-skip\",\n",
    "    \"intron-0\", \"intron-1\", \"intron-2\",\n",
    "    \"ASS-0\", \"ASS-1\", \"ASS-2\",\n",
    "    \"DSS-0\", \"DSS-1\", \"DSS-2\",\n",
    "    \"START\", \"STOP\",\n",
    "    \"nc_exon_plus\", \"nc_exon_minu\",\n",
    "    \"nc_intron_plus\", \"nc_intron_minu\",\n",
    "    \"nc_ASS\", \"nc_DSS\",\n",
    "    \"TSS\", \"PolyA\",\n",
    "    \"IR\"\n",
    "]\n",
    "\n",
    "# Initialize ordered result dictionary\n",
    "results_dict = OrderedDict()\n",
    "sheets_lines = []\n",
    "\n",
    "for label in ordered_labels:\n",
    "    # Construct expected TensorBoard tag prefix\n",
    "    prefix = f\"f1_{label}_level/samples/valid\"\n",
    "    \n",
    "    # Check if it exists in the scalars\n",
    "    if prefix in ea.Tags()[\"scalars\"]:\n",
    "        events = ea.Scalars(prefix)\n",
    "        value = events[-1].value if events else 0.0\n",
    "    else:\n",
    "        value = -1.0  # default if not present\n",
    "    \n",
    "    results_dict[label] = value\n",
    "    # sheets_lines.append(f\"{label}\\t{value:.4f}\")\n",
    "    sheets_lines.append(f\"\\t{value:.4f}\")\n",
    "\n",
    "\n",
    "# For Google Sheets — Copy/Paste\n",
    "print(\"Copy and paste the following into Google Sheets:\")\n",
    "print(\"\\n\".join(sheets_lines))\n",
    "\n",
    "# Also return as Python dictionary (ordered)\n",
    "results_dict\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_segments_ones(array):\n",
    "        ones_idx = np.where(array == 1)[0]\n",
    "        if len(ones_idx) == 0:\n",
    "            return []\n",
    "    \n",
    "        split_idx = np.where(np.diff(ones_idx) > 1)[0] + 1\n",
    "    \n",
    "        split_ones_idx = np.split(ones_idx, split_idx)\n",
    "        segments = [(segment[0], segment[-1] + 1) for segment in split_ones_idx]\n",
    "    \n",
    "        return segments\n",
    "\n",
    "def exon_level(y_labels, p_labels, metrics):     \n",
    "    \"\"\"\n",
    "    Update metrics with chosen threshold\n",
    "    \"\"\"\n",
    "    y_labels_segments = find_segments_ones(y_labels)    \n",
    "    p_labels_segments = find_segments_ones(p_labels)\n",
    "\n",
    "\n",
    "    y_exons_set = set(sorted(y_labels_segments))\n",
    "    p_exons_set = set(sorted(p_labels_segments))\n",
    "\n",
    "    assert metrics[f'TP'] == 0\n",
    "    assert metrics[f'FP'] == 0\n",
    "    assert metrics[f'FN'] == 0\n",
    "    \n",
    "    metrics[f'TP'] += len(y_exons_set & p_exons_set)\n",
    "    metrics[f'FP'] += len(p_exons_set - y_exons_set)\n",
    "    metrics[f'FN'] += len(y_exons_set - p_exons_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "preds = torch.tensor([0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1])\n",
    "answ = torch.tensor([1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "label = 1\n",
    "y_label = (answ == label).type(torch.int32)\n",
    "p_label = (preds == label).type(torch.int32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "exon_level_data = {}\n",
    "\n",
    "exon_level_data[f'TP'] = 0\n",
    "exon_level_data[f'FP'] = 0\n",
    "exon_level_data[f'FN'] = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "exon_level(y_label, p_label, exon_level_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'TP': 3, 'FP': 1, 'FN': 3}"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exon_level_data"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gena_ipynb",
   "language": "python",
   "name": "gena_ipynb"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
