From 9910639751162f1b66cc1c7b2bf5929cb072a096 Mon Sep 17 00:00:00 2001 From: Ben Cassell <98852248+benc-db@users.noreply.github.com> Date: Thu, 5 Oct 2023 08:57:42 -0700 Subject: [PATCH 01/37] Update databricks-configs.md Updating to call out incompatibility of insert_overwrite with SQL Warehouses --- website/docs/reference/resource-configs/databricks-configs.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/website/docs/reference/resource-configs/databricks-configs.md b/website/docs/reference/resource-configs/databricks-configs.md index e57e1efc04a..9bfe4d862cf 100644 --- a/website/docs/reference/resource-configs/databricks-configs.md +++ b/website/docs/reference/resource-configs/databricks-configs.md @@ -182,6 +182,9 @@ insert overwrite table analytics.databricks_incremental +#### Usage Notes +* This strategy is not currently compatible with SQL Warehouses + ### The `merge` strategy The `merge` incremental strategy requires: From b86332bd608c916ad551d72db495763b6f3ab52a Mon Sep 17 00:00:00 2001 From: Ly Nguyen Date: Mon, 27 Nov 2023 12:07:05 -0800 Subject: [PATCH 02/37] Fast-follows for MS Fabric docs --- .../about-connections.md | 3 ++- .../connect-microsoft-fabric.md | 27 +++++++++++++++++++ .../about-core-connections.md | 1 + .../connect-data-platform/fabric-setup.md | 2 +- .../microsoft-fabric-support-rn.md | 6 +++-- website/docs/guides/microsoft-fabric-qs.md | 3 +++ website/sidebars.js | 1 + website/snippets/_adapters-verified.md | 2 +- 8 files changed, 40 insertions(+), 5 deletions(-) create mode 100644 website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md diff --git a/website/docs/docs/cloud/connect-data-platform/about-connections.md b/website/docs/docs/cloud/connect-data-platform/about-connections.md index 1329d179900..93bbf83584f 100644 --- a/website/docs/docs/cloud/connect-data-platform/about-connections.md +++ b/website/docs/docs/cloud/connect-data-platform/about-connections.md @@ -3,7 +3,7 @@ title: "About data platform connections" id: about-connections description: "Information about data platform connections" sidebar_label: "About data platform connections" -pagination_next: "docs/cloud/connect-data-platform/connect-starburst-trino" +pagination_next: "docs/cloud/connect-data-platform/connect-microsoft-fabric" pagination_prev: null --- dbt Cloud can connect with a variety of data platform providers including: @@ -11,6 +11,7 @@ dbt Cloud can connect with a variety of data platform providers including: - [Apache Spark](/docs/cloud/connect-data-platform/connect-apache-spark) - [Databricks](/docs/cloud/connect-data-platform/connect-databricks) - [Google BigQuery](/docs/cloud/connect-data-platform/connect-bigquery) +- [Microsoft Fabric](/docs/cloud/connect-data-platform/connect-microsoft-fabric) - [PostgreSQL](/docs/cloud/connect-data-platform/connect-redshift-postgresql-alloydb) - [Snowflake](/docs/cloud/connect-data-platform/connect-snowflake) - [Starburst or Trino](/docs/cloud/connect-data-platform/connect-starburst-trino) diff --git a/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md b/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md new file mode 100644 index 00000000000..0fe36bf3976 --- /dev/null +++ b/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md @@ -0,0 +1,27 @@ +--- +title: "Connect Microsoft Fabric" +description: "Configure Microsoft Fabric connection." +sidebar_label: "Connect Microsoft Fabric" +--- + +The following are the required fields for setting up a connection with a [Microsoft Fabric](https://docs.starburst.io/starburst-enterprise/index.html) using service principal authentication. + +| Field | Description | +| --- | --- | +| **Server** | The service principal's **host** value for the Fabric test endpoint. | +| **Port** | The port to connect to Microsoft Fabric. By default, it's 1433 for the standard SQL server port number. | +| **Database** | The service principal's **database** value for the Fabric test endpoint. | +| **Authentication** | Choose **Service Principal** from the dropdown. | +| **Tenant ID** | The service principal's **Directory (tenant) ID**. | +| **Client ID** | The service principal's **application (client) ID id**. | +| **Client secret** | The service principal's **client secret** (not the **client secret id**). | + + +## Supported authentication methods + +- Service principal in Azure Active Directory (AAD) +- Username/password in Azure Active Directory (AAD) + +## Configuration + +To learn how to optimize performance with data platform-specific configurations in dbt Cloud, refer to [Microsoft Fabric DWH configurations](/reference/resource-configs/fabric-configs). diff --git a/website/docs/docs/core/connect-data-platform/about-core-connections.md b/website/docs/docs/core/connect-data-platform/about-core-connections.md index 492e5ae878a..61a7805d232 100644 --- a/website/docs/docs/core/connect-data-platform/about-core-connections.md +++ b/website/docs/docs/core/connect-data-platform/about-core-connections.md @@ -14,6 +14,7 @@ dbt Core can connect with a variety of data platform providers including: - [Apache Spark](/docs/core/connect-data-platform/spark-setup) - [Databricks](/docs/core/connect-data-platform/databricks-setup) - [Google BigQuery](/docs/core/connect-data-platform/bigquery-setup) +- [Microsoft Fabric](/docs/core/connect-data-platform/fabric-setup) - [PostgreSQL](/docs/core/connect-data-platform/postgres-setup) - [Snowflake](/docs/core/connect-data-platform/snowflake-setup) - [Starburst or Trino](/docs/core/connect-data-platform/trino-setup) diff --git a/website/docs/docs/core/connect-data-platform/fabric-setup.md b/website/docs/docs/core/connect-data-platform/fabric-setup.md index 11a8cf6f98b..deef1e04b22 100644 --- a/website/docs/docs/core/connect-data-platform/fabric-setup.md +++ b/website/docs/docs/core/connect-data-platform/fabric-setup.md @@ -8,7 +8,7 @@ meta: github_repo: 'Microsoft/dbt-fabric' pypi_package: 'dbt-fabric' min_core_version: '1.4.0' - cloud_support: Not Supported + cloud_support: Supported platform_name: 'Microsoft Fabric' config_page: '/reference/resource-configs/fabric-configs' --- diff --git a/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md b/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md index 13aefa80ffc..66295d079ad 100644 --- a/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md +++ b/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md @@ -8,11 +8,13 @@ tags: [Nov-2023] Public Preview is now available in dbt Cloud for Microsoft Fabric! -To learn more, check out the [Quickstart for dbt Cloud and Microsoft Fabric](/guides/microsoft-fabric?step=1). The guide walks you through: +To learn more, refer to [Connect Microsoft Fabric](/docs/cloud/connect-data-platform/connect-microsoft-fabric) and [Microsoft Fabric DWH configurations](/reference/resource-configs/fabric-configs). + +Also, check out the [Quickstart for dbt Cloud and Microsoft Fabric](/guides/microsoft-fabric?step=1). The guide walks you through: - Loading the Jaffle Shop sample data (provided by dbt Labs) into your Microsoft Fabric warehouse. - Connecting dbt Cloud to Microsoft Fabric. - Turning a sample query into a model in your dbt project. A model in dbt is a SELECT statement. - Adding tests to your models. - Documenting your models. -- Scheduling a job to run. \ No newline at end of file +- Scheduling a job to run \ No newline at end of file diff --git a/website/docs/guides/microsoft-fabric-qs.md b/website/docs/guides/microsoft-fabric-qs.md index c7c53a2aac7..6b194f0baf7 100644 --- a/website/docs/guides/microsoft-fabric-qs.md +++ b/website/docs/guides/microsoft-fabric-qs.md @@ -108,6 +108,9 @@ A public preview of Microsoft Fabric in dbt Cloud is now available! 2. Enter a project name and click **Continue**. 3. Choose **Fabric** as your connection and click **Next**. 4. In the **Configure your environment** section, enter the **Settings** for your new project: + - **Server** — Use the service principal's **host** value for the Fabric test endpoint. + - **Port** — 1433 (which is the default). + - **Database** — Use the service principal's **database** value for the Fabric test endpoint. 5. Enter the **Development credentials** for your new project: - **Authentication** — Choose **Service Principal** from the dropdown. - **Tenant ID** — Use the service principal’s **Directory (tenant) id** as the value. diff --git a/website/sidebars.js b/website/sidebars.js index 720b752ed41..01a41c5a552 100644 --- a/website/sidebars.js +++ b/website/sidebars.js @@ -54,6 +54,7 @@ const sidebarSettings = { link: { type: "doc", id: "docs/cloud/connect-data-platform/about-connections" }, items: [ "docs/cloud/connect-data-platform/about-connections", + "docs/cloud/connect-data-platform/connect-microsoft-fabric", "docs/cloud/connect-data-platform/connect-starburst-trino", "docs/cloud/connect-data-platform/connect-snowflake", "docs/cloud/connect-data-platform/connect-bigquery", diff --git a/website/snippets/_adapters-verified.md b/website/snippets/_adapters-verified.md index b9a71c67c36..c3607b50125 100644 --- a/website/snippets/_adapters-verified.md +++ b/website/snippets/_adapters-verified.md @@ -46,7 +46,7 @@ Date: Mon, 27 Nov 2023 12:15:25 -0800 Subject: [PATCH 03/37] Update website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md typo --- .../release-notes/02-Nov-2023/microsoft-fabric-support-rn.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md b/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md index 66295d079ad..9197fb54c11 100644 --- a/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md +++ b/website/docs/docs/dbt-versions/release-notes/02-Nov-2023/microsoft-fabric-support-rn.md @@ -17,4 +17,4 @@ Also, check out the [Quickstart for dbt Cloud and Microsoft Fabric](/guides/micr - Turning a sample query into a model in your dbt project. A model in dbt is a SELECT statement. - Adding tests to your models. - Documenting your models. -- Scheduling a job to run \ No newline at end of file +- Scheduling a job to run. \ No newline at end of file From 0d51f2e6336596c544ec8e7deeafc04920334667 Mon Sep 17 00:00:00 2001 From: Ly Nguyen Date: Mon, 27 Nov 2023 12:26:33 -0800 Subject: [PATCH 04/37] update supported auth methods section --- .../cloud/connect-data-platform/connect-microsoft-fabric.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md b/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md index 0fe36bf3976..649bd92b5b3 100644 --- a/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md +++ b/website/docs/docs/cloud/connect-data-platform/connect-microsoft-fabric.md @@ -18,9 +18,11 @@ The following are the required fields for setting up a connection with a [Micros ## Supported authentication methods +The two supported authentication methods are: +- AAD service principal +- AAD password -- Service principal in Azure Active Directory (AAD) -- Username/password in Azure Active Directory (AAD) +SQL password (LDAP) is not supported in Fabric Synapse so you must use Azure Active Directory (AAD). This means that to use Microsoft Fabric in dbt Cloud, you will need at least one AAD service principal to connect dbt Cloud to Fabric, ideally one service principal for each user. ## Configuration From 45252b2645b06d3db93d55eae5dc68752b132115 Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Mon, 27 Nov 2023 19:18:32 -0500 Subject: [PATCH 05/37] Adding language about name uniqueness --- website/docs/docs/build/dimensions.md | 3 ++- website/docs/docs/build/entities.md | 2 +- website/docs/docs/build/measures.md | 3 ++- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/website/docs/docs/build/dimensions.md b/website/docs/docs/build/dimensions.md index b8679fe11b0..08373ac0180 100644 --- a/website/docs/docs/build/dimensions.md +++ b/website/docs/docs/build/dimensions.md @@ -15,7 +15,8 @@ In a data platform, dimensions is part of a larger structure called a semantic m Groups are defined within semantic models, alongside entities and measures, and correspond to non-aggregatable columns in your dbt model that provides categorical or time-based context. In SQL, dimensions is typically included in the GROUP BY clause.--> -All dimensions require a `name`, `type` and in some cases, an `expr` parameter. +All dimensions require a `name`, `type` and in some cases, an `expr` parameter. The `name` for your dimension must be unique to the semantic model and can not be the same as an existing `entity` or `measure` within that same project. + | Parameter | Description | Type | | --------- | ----------- | ---- | diff --git a/website/docs/docs/build/entities.md b/website/docs/docs/build/entities.md index 464fa2c3b8c..3e57e53c5f8 100644 --- a/website/docs/docs/build/entities.md +++ b/website/docs/docs/build/entities.md @@ -8,7 +8,7 @@ tags: [Metrics, Semantic Layer] Entities are real-world concepts in a business such as customers, transactions, and ad campaigns. We often focus our analyses around specific entities, such as customer churn or annual recurring revenue modeling. We represent entities in our semantic models using id columns that serve as join keys to other semantic models in your semantic graph. -Within a semantic graph, the required parameters for an entity are `name` and `type`. The `name` refers to either the key column name from the underlying data table, or it may serve as an alias with the column name referenced in the `expr` parameter. +Within a semantic graph, the required parameters for an entity are `name` and `type`. The `name` refers to either the key column name from the underlying data table, or it may serve as an alias with the column name referenced in the `expr` parameter. The `name` for your entity must be unique to the semantic model and can not be the same as an existing `measure` or `dimension` within that same project. Entities can be specified with a single column or multiple columns. Entities (join keys) in a semantic model are identified by their name. Each entity name must be unique within a semantic model, but it doesn't have to be unique across different semantic models. diff --git a/website/docs/docs/build/measures.md b/website/docs/docs/build/measures.md index 74d37b70e94..9a03bdcb6f7 100644 --- a/website/docs/docs/build/measures.md +++ b/website/docs/docs/build/measures.md @@ -34,7 +34,8 @@ measures: When you create a measure, you can either give it a custom name or use the `name` of the data platform column directly. If the `name` of the measure is different from the column name, you need to add an `expr` to specify the column name. The `name` of the measure is used when creating a metric. -Measure names must be **unique** across all semantic models in a project. +Measure names must be across all semantic models in a project and can not be the same as an existing `measure` or `dimension` within that same model. + ### Description From ba53693f6c443bd34e411098d7f9ad8561204b69 Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Mon, 27 Nov 2023 19:22:26 -0500 Subject: [PATCH 06/37] updating language --- website/docs/docs/build/dimensions.md | 2 +- website/docs/docs/build/entities.md | 2 +- website/docs/docs/build/measures.md | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/website/docs/docs/build/dimensions.md b/website/docs/docs/build/dimensions.md index 08373ac0180..683ff730d3c 100644 --- a/website/docs/docs/build/dimensions.md +++ b/website/docs/docs/build/dimensions.md @@ -15,7 +15,7 @@ In a data platform, dimensions is part of a larger structure called a semantic m Groups are defined within semantic models, alongside entities and measures, and correspond to non-aggregatable columns in your dbt model that provides categorical or time-based context. In SQL, dimensions is typically included in the GROUP BY clause.--> -All dimensions require a `name`, `type` and in some cases, an `expr` parameter. The `name` for your dimension must be unique to the semantic model and can not be the same as an existing `entity` or `measure` within that same project. +All dimensions require a `name`, `type` and in some cases, an `expr` parameter. The `name` for your dimension must be unique to the semantic model and can not be the same as an existing `entity` or `measure` within that same model. | Parameter | Description | Type | diff --git a/website/docs/docs/build/entities.md b/website/docs/docs/build/entities.md index 3e57e53c5f8..e44f9e79af6 100644 --- a/website/docs/docs/build/entities.md +++ b/website/docs/docs/build/entities.md @@ -8,7 +8,7 @@ tags: [Metrics, Semantic Layer] Entities are real-world concepts in a business such as customers, transactions, and ad campaigns. We often focus our analyses around specific entities, such as customer churn or annual recurring revenue modeling. We represent entities in our semantic models using id columns that serve as join keys to other semantic models in your semantic graph. -Within a semantic graph, the required parameters for an entity are `name` and `type`. The `name` refers to either the key column name from the underlying data table, or it may serve as an alias with the column name referenced in the `expr` parameter. The `name` for your entity must be unique to the semantic model and can not be the same as an existing `measure` or `dimension` within that same project. +Within a semantic graph, the required parameters for an entity are `name` and `type`. The `name` refers to either the key column name from the underlying data table, or it may serve as an alias with the column name referenced in the `expr` parameter. The `name` for your entity must be unique to the semantic model and can not be the same as an existing `measure` or `dimension` within that same model. Entities can be specified with a single column or multiple columns. Entities (join keys) in a semantic model are identified by their name. Each entity name must be unique within a semantic model, but it doesn't have to be unique across different semantic models. diff --git a/website/docs/docs/build/measures.md b/website/docs/docs/build/measures.md index 9a03bdcb6f7..29feecd5d2c 100644 --- a/website/docs/docs/build/measures.md +++ b/website/docs/docs/build/measures.md @@ -34,7 +34,7 @@ measures: When you create a measure, you can either give it a custom name or use the `name` of the data platform column directly. If the `name` of the measure is different from the column name, you need to add an `expr` to specify the column name. The `name` of the measure is used when creating a metric. -Measure names must be across all semantic models in a project and can not be the same as an existing `measure` or `dimension` within that same model. +Measure names must be unique across all semantic models in a project and can not be the same as an existing `measure` or `dimension` within that same model. ### Description From a3a45d3a8bafda4c04a4bfcfd6b45dabfd2c2574 Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Mon, 27 Nov 2023 19:32:17 -0500 Subject: [PATCH 07/37] Update website/docs/docs/build/measures.md Co-authored-by: Leona B. Campbell <3880403+runleonarun@users.noreply.github.com> --- website/docs/docs/build/measures.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/website/docs/docs/build/measures.md b/website/docs/docs/build/measures.md index 29feecd5d2c..feea2b30ca4 100644 --- a/website/docs/docs/build/measures.md +++ b/website/docs/docs/build/measures.md @@ -34,7 +34,7 @@ measures: When you create a measure, you can either give it a custom name or use the `name` of the data platform column directly. If the `name` of the measure is different from the column name, you need to add an `expr` to specify the column name. The `name` of the measure is used when creating a metric. -Measure names must be unique across all semantic models in a project and can not be the same as an existing `measure` or `dimension` within that same model. +Measure names must be unique across all semantic models in a project and can not be the same as an existing `entity` or `dimension` within that same model. ### Description From dfe7b6ef61eac406e7f2dd79fc48a1ac8faaf5c1 Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Mon, 27 Nov 2023 20:34:06 -0500 Subject: [PATCH 08/37] New best practice guide for clone --- .../clone-incremental-models.md | 89 +++++++++++++++++++ website/sidebars.js | 1 + 2 files changed, 90 insertions(+) create mode 100644 website/docs/best-practices/clone-incremental-models.md diff --git a/website/docs/best-practices/clone-incremental-models.md b/website/docs/best-practices/clone-incremental-models.md new file mode 100644 index 00000000000..ae5c38d69f4 --- /dev/null +++ b/website/docs/best-practices/clone-incremental-models.md @@ -0,0 +1,89 @@ +--- +title: "Clone incremental models as the first step of your CI job" +id: "clone-incremental-models" +description: Learn how to define clone incremental models as the first step of your CI job. +displayText: Clone incremental models as the first step of your CI job +hoverSnippet: Learn how to clone incremental models for CI jobs. +--- + +### Main content + +Imagine that you've created a [Slim CI job](https://docs.getdbt.com/docs/dbt-cloud/using-dbt-cloud/cloud-enabling-continuous-integration#slim-ci) in dbt Cloud. + +img width="1332" alt="Screenshot 2023-10-27 at 10 37 28 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/3574bce0-cad2-44f6-8e22-8cbf33b61cf8" + +Your CI job: +- defers to your production environment +- runs the command `dbt build --select state:modified+` to run and test all of the models you've modified and their downstream dependencies +- is triggered whenever a developer on your team opens a PR against the main branch + +Now imagine your dbt project looks like this: + +img width="1074" alt="Screenshot 2023-10-27 at 10 39 43 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/30d4dab9-1d6a-460e-b3d8-867f29d1c0db" + +When you open a PR that modifies `dim_wizards`, your CI job will kickoff and build _only the modified models and their downstream dependencies_ (in this case: `dim_wizards` and `fct_orders`) into a temporary schema that's unique to your PR. + +This build mimics the behavior of what _will_ happen once the PR is merged into the main branch (so you have confidence that you're not introducing breaking changes), without requiring a build of your _entire_ dbt project. + +**But what happens when one of the modified models (or one of their downstream dependencies) is an incremental model?** + +Because your CI job is building modified models into a PR-specific schema, on the first execution of `dbt build --select state:modified+` the modified incremental model will be built in its entirety **because it does not yet exist in the PR-specific schema** aka [is_incremental will be false](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#understanding-the-is_incremental-macro). You're running in `full-refresh` mode. + +This can be suboptimal because: +- typically incremental models are your largest datasets, so they take a long time to build in their entirety which can slow down development time and incur warehouse $$$ +- there are situations where a `full-refresh` of the incremental model passes successfully in your CI job but an _incremental_ build of that same table in prod would **fail** when the PR is merged into main (think schema drift where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`) + +We can alleviate the above problems by zero copy cloning the relevant, pre-exisitng incremental models into our PR-specific schema as the first step of the CI job using the `dbt clone` command. This way, the incremental models already exist in the PR-specific schema when you first execute the command `dbt build --select state:modified+` so the `is_incremental` flag will be `true`. + +Now, we'll have 2 commands for our dbt Cloud CI check to execute: +1. Clone all of the pre-existing, incremental models that have been modified or are downstream of another model that has been modified -> `dbt clone --select state:modified+,config.materialized:incremental,state:old` +2. Build all of models that have been modified and their downstream dependencies `dbt build --select state:modified+` + +Because of our first clone step, the incremental models selected in our `dbt build` in the second step will run in incremental mode. + +img width="768" alt="Screenshot 2023-10-27 at 10 47 22 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/7a5feed1-9665-4c30-9ee9-e1d63dc75fe5" + +Your CI jobs will run faster, and you're more accurately mimicking the behavior of "what will happen once the PR has been merged into main". + +Disclaimers: +- `dbt clone` is only available with dbt version 1.6+ +- this strategy only works for warehouse that support zero copy cloning (otherwise `dbt clone` will just create pointer views) +- some teams may want to test that their incremental models run in _both_ incremental mode _and_ full-refresh mode + + +### Additional information + +**Relevant slack thread:** https://dbt-labs.slack.com/archives/C05FWBP9X1U/p1692830261651829 + +**From my "Better CI for better data quality coalesce talk:** +If you use the incremental materialization in your dbt project, you should consider cloning your relevant, pre-existing incremental models into your PR-specific schema as the first step of your CI check. This will force your second step to run in incremental mode (where is_incremental is true) because now the models already exist in your PR-specific schema (via cloning). This is beneficial because it more accurately mimics what will happen when you merge your changes into production and it will save time and money by not rebuilding your incremental models (which are often large data sets) from scratch for every PR that modifies them. + +**Expansion on "think schema drift where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`" from above:** +Let’s imagine you have an incremental model my_incremental_model with the following config: + +```sql + +{{ + config( + materialized='incremental', + unique_key='unique_id', + on_schema_change='fail' + ) +}} + +``` + +Now, let’s say I open up a PR that adds a new column to `my_incremental_model` - in this case: +- an incremental build will fail +- a `full-refresh` will succeed + +If you have a daily production job that just executes a `dbt build` (without a `--full-refresh` flag), once the PR is merged into main and the job kicks off, you will get a failure. So the question is - what do you want to happen in CI? +- Do you want to also get a failure in CI, so that you know that once this PR is merged into main you need to immediately execute a `dbt build --full-refresh --select my_incremental_model` in production in order to avoid a failure in prod? This will block your CI check from passing. +- Do you want your CI check to succeed, because once you do run a `full-refresh` for this model in prod you will be in a successful state? This may lead to you being surprised that your production job is suddenly failing when you merge this PR into main because you didn’t realize you would need to execute a `dbt build --full-refresh --select my_incremental_model` in production. + +Probably not a perfect solution here, it’s all just tradeoffs! Personally, I'd rather have the failing CI job and have to manually override the blocking branch protection rule so that I'm not surprised and can proactively run the appropriate command in production once I merge the PR in. + +**Expansion on "why `state:old`"** + +For brand new incremental models we actually want those to run in `full-refresh` mode in CI, because they will run in `full-refresh` mode in production when the PR is merged into `main` because they also don't exist yet in the production environment... they're brand new! +If you don't specify this, you won't get an error just a “No relation found in state manifest for…” - so it technically works with our without specifying `state:old`. But adding `state:old` is more explicit and means it won't even try to clone the brand new incremental models. \ No newline at end of file diff --git a/website/sidebars.js b/website/sidebars.js index 720b752ed41..e63ff5eae9a 100644 --- a/website/sidebars.js +++ b/website/sidebars.js @@ -1050,6 +1050,7 @@ const sidebarSettings = { "best-practices/materializations/materializations-guide-7-conclusion", ], }, + "best-practices/clone-incremental-models", "best-practices/writing-custom-generic-tests", "best-practices/best-practice-workflows", "best-practices/dbt-unity-catalog-best-practices", From bf26e2491053a19823c77575f8cde316fc21468f Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Tue, 28 Nov 2023 21:31:44 -0500 Subject: [PATCH 09/37] Updates to the doc --- .../clone-incremental-models.md | 81 +++++++++--------- .../img/best-practices/clone-command.png | Bin 0 -> 44464 bytes .../static/img/best-practices/dag-example.png | Bin 0 -> 200045 bytes .../static/img/best-practices/slim-ci-job.png | Bin 0 -> 232318 bytes 4 files changed, 39 insertions(+), 42 deletions(-) create mode 100644 website/static/img/best-practices/clone-command.png create mode 100644 website/static/img/best-practices/dag-example.png create mode 100644 website/static/img/best-practices/slim-ci-job.png diff --git a/website/docs/best-practices/clone-incremental-models.md b/website/docs/best-practices/clone-incremental-models.md index ae5c38d69f4..8b45e3ef478 100644 --- a/website/docs/best-practices/clone-incremental-models.md +++ b/website/docs/best-practices/clone-incremental-models.md @@ -6,60 +6,57 @@ displayText: Clone incremental models as the first step of your CI job hoverSnippet: Learn how to clone incremental models for CI jobs. --- -### Main content +Before you begin, you must be aware of a few conditions: +- `dbt clone` is only available with dbt version 1.6 and newer. Refer to our [upgrade guide](https://docs.getdbt.com/docs/dbt-versions/upgrade-core-in-cloud) for help enabling newer versions in dbt Cloud +- This strategy only works for warehouse that support zero copy cloning (otherwise `dbt clone` will just create pointer views). +- Some teams may want to test that their incremental models run in both incremental mode and full-refresh mode. -Imagine that you've created a [Slim CI job](https://docs.getdbt.com/docs/dbt-cloud/using-dbt-cloud/cloud-enabling-continuous-integration#slim-ci) in dbt Cloud. +Imagine you've created a [Slim CI job](https://docs.getdbt.com/docs/dbt-cloud/using-dbt-cloud/cloud-enabling-continuous-integration#slim-ci) in dbt Cloud and it is configured to: -img width="1332" alt="Screenshot 2023-10-27 at 10 37 28 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/3574bce0-cad2-44f6-8e22-8cbf33b61cf8" +- Defer to your production environment. +- Run the command `dbt build --select state:modified+` to run and test all of the models you've modified and their downstream dependencies. +- Trigger whenever a developer on your team opens a PR against the main branch. -Your CI job: -- defers to your production environment -- runs the command `dbt build --select state:modified+` to run and test all of the models you've modified and their downstream dependencies -- is triggered whenever a developer on your team opens a PR against the main branch + -Now imagine your dbt project looks like this: +Now imagine your dbt project looks something like this in the DAG: -img width="1074" alt="Screenshot 2023-10-27 at 10 39 43 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/30d4dab9-1d6a-460e-b3d8-867f29d1c0db" + -When you open a PR that modifies `dim_wizards`, your CI job will kickoff and build _only the modified models and their downstream dependencies_ (in this case: `dim_wizards` and `fct_orders`) into a temporary schema that's unique to your PR. +When you open a pull request (PR) that modifies `dim_wizards`, your CI job will kickoff and build _only the modified models and their downstream dependencies_ (in this case, `dim_wizards` and `fct_orders`) into a temporary schema that's unique to your PR. -This build mimics the behavior of what _will_ happen once the PR is merged into the main branch (so you have confidence that you're not introducing breaking changes), without requiring a build of your _entire_ dbt project. +This build mimics the behavior of what will happen once the PR is merged into the main branch (so you have confidence that you're not introducing breaking changes) without requiring a build of your entire dbt project. -**But what happens when one of the modified models (or one of their downstream dependencies) is an incremental model?** +## What happens when one of the modified models (or one of their downstream dependencies) is an incremental model? -Because your CI job is building modified models into a PR-specific schema, on the first execution of `dbt build --select state:modified+` the modified incremental model will be built in its entirety **because it does not yet exist in the PR-specific schema** aka [is_incremental will be false](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#understanding-the-is_incremental-macro). You're running in `full-refresh` mode. +Because your CI job is building modified models into a PR-specific schema, on the first execution of `dbt build --select state:modified+`, the modified incremental model will be built in its entirety _because it does not yet exist in the PR-specific schema_ and [is_incremental will be false](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#understanding-the-is_incremental-macro). You're running in `full-refresh` mode. This can be suboptimal because: -- typically incremental models are your largest datasets, so they take a long time to build in their entirety which can slow down development time and incur warehouse $$$ -- there are situations where a `full-refresh` of the incremental model passes successfully in your CI job but an _incremental_ build of that same table in prod would **fail** when the PR is merged into main (think schema drift where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`) +- Typically incremental models are your largest datasets, so they take a long time to build in their entirety which can slow down development time and incur high warehouse costs. +- There are situations where a `full-refresh` of the incremental model passes successfully in your CI job but an _incremental_ build of that same table in prod would fail when the PR is merged into main (think schema drift where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`) -We can alleviate the above problems by zero copy cloning the relevant, pre-exisitng incremental models into our PR-specific schema as the first step of the CI job using the `dbt clone` command. This way, the incremental models already exist in the PR-specific schema when you first execute the command `dbt build --select state:modified+` so the `is_incremental` flag will be `true`. +You can alleviate these problems by zero copy cloning the relevant, pre-exisitng incremental models into your PR-specific schema as the first step of the CI job using the `dbt clone` command. This way, the incremental models already exist in the PR-specific schema when you first execute the command `dbt build --select state:modified+` so the `is_incremental` flag will be `true`. -Now, we'll have 2 commands for our dbt Cloud CI check to execute: -1. Clone all of the pre-existing, incremental models that have been modified or are downstream of another model that has been modified -> `dbt clone --select state:modified+,config.materialized:incremental,state:old` -2. Build all of models that have been modified and their downstream dependencies `dbt build --select state:modified+` +You'll have two commands for your dbt Cloud CI check to execute: +1. Clone all of the pre-existing incremental models that have been modified or are downstream of another model that has been modified: `dbt clone --select state:modified+,config.materialized:incremental,state:old` +2. Build all of the models that have been modified and their downstream dependencies: `dbt build --select state:modified+` -Because of our first clone step, the incremental models selected in our `dbt build` in the second step will run in incremental mode. +Because of your first clone step, the incremental models selected in your `dbt build` on the second step will run in incremental mode. -img width="768" alt="Screenshot 2023-10-27 at 10 47 22 AM" src="https://github.com/dbt-labs/docs.getdbt.com/assets/53586774/7a5feed1-9665-4c30-9ee9-e1d63dc75fe5" + -Your CI jobs will run faster, and you're more accurately mimicking the behavior of "what will happen once the PR has been merged into main". +Your CI jobs will run faster, and you're more accurately mimicking the behavior of what will happen once the PR has been merged into main. -Disclaimers: -- `dbt clone` is only available with dbt version 1.6+ -- this strategy only works for warehouse that support zero copy cloning (otherwise `dbt clone` will just create pointer views) -- some teams may want to test that their incremental models run in _both_ incremental mode _and_ full-refresh mode +## Additional help +**Relevant `dbt clone` Slack thread:** https://dbt-labs.slack.com/archives/C05FWBP9X1U/p1692830261651829 -### Additional information +### From the "Better CI for better data quality" coalesce talk +"If you use the incremental materialization in your dbt project, you should consider cloning your relevant, pre-existing incremental models into your PR-specific schema as the first step of your CI check. This will force your second step to run in incremental mode (where is_incremental is true) because now the models already exist in your PR-specific schema (via cloning). This is beneficial because it more accurately mimics what will happen when you merge your changes into production and it will save time and money by not rebuilding your incremental models (which are often large data sets) from scratch for every PR that modifies them." -Grace Goheen, dbt Labs Product Manager -**Relevant slack thread:** https://dbt-labs.slack.com/archives/C05FWBP9X1U/p1692830261651829 +### Expansion on "think schema drift" where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`" from above -**From my "Better CI for better data quality coalesce talk:** -If you use the incremental materialization in your dbt project, you should consider cloning your relevant, pre-existing incremental models into your PR-specific schema as the first step of your CI check. This will force your second step to run in incremental mode (where is_incremental is true) because now the models already exist in your PR-specific schema (via cloning). This is beneficial because it more accurately mimics what will happen when you merge your changes into production and it will save time and money by not rebuilding your incremental models (which are often large data sets) from scratch for every PR that modifies them. - -**Expansion on "think schema drift where [on_schema_change](https://docs.getdbt.com/docs/building-a-dbt-project/building-models/configuring-incremental-models#what-if-the-columns-of-my-incremental-model-change) config is set to `fail`" from above:** -Let’s imagine you have an incremental model my_incremental_model with the following config: +Imagine you have an incremental model `my_incremental_model` with the following config: ```sql @@ -73,17 +70,17 @@ Let’s imagine you have an incremental model my_incremental_model with the foll ``` -Now, let’s say I open up a PR that adds a new column to `my_incremental_model` - in this case: -- an incremental build will fail -- a `full-refresh` will succeed +Now, let’s say you open up a PR that adds a new column to `my_incremental_model`. In this case: +- An incremental build will fail. +- A `full-refresh` will succeed. -If you have a daily production job that just executes a `dbt build` (without a `--full-refresh` flag), once the PR is merged into main and the job kicks off, you will get a failure. So the question is - what do you want to happen in CI? +If you have a daily production job that just executes `dbt build` without a `--full-refresh` flag, once the PR is merged into main and the job kicks off, you will get a failure. So the question is - what do you want to happen in CI? - Do you want to also get a failure in CI, so that you know that once this PR is merged into main you need to immediately execute a `dbt build --full-refresh --select my_incremental_model` in production in order to avoid a failure in prod? This will block your CI check from passing. -- Do you want your CI check to succeed, because once you do run a `full-refresh` for this model in prod you will be in a successful state? This may lead to you being surprised that your production job is suddenly failing when you merge this PR into main because you didn’t realize you would need to execute a `dbt build --full-refresh --select my_incremental_model` in production. +- Do you want your CI check to succeed, because once you do run a `full-refresh` for this model in prod you will be in a successful state? This may lead unpleasant surprises if your production job is suddenly failing when you merge this PR into main if you don’t remember you need to execute a `dbt build --full-refresh --select my_incremental_model` in production. -Probably not a perfect solution here, it’s all just tradeoffs! Personally, I'd rather have the failing CI job and have to manually override the blocking branch protection rule so that I'm not surprised and can proactively run the appropriate command in production once I merge the PR in. +There’s probably no perfect solution here; it’s all just tradeoffs! Our preference would be to have the failing CI job and have to manually override the blocking branch protection rule so that there are no surprises and we can proactively run the appropriate command in production once the PR is merged. -**Expansion on "why `state:old`"** +### Expansion on "why `state:old`" -For brand new incremental models we actually want those to run in `full-refresh` mode in CI, because they will run in `full-refresh` mode in production when the PR is merged into `main` because they also don't exist yet in the production environment... they're brand new! -If you don't specify this, you won't get an error just a “No relation found in state manifest for…” - so it technically works with our without specifying `state:old`. But adding `state:old` is more explicit and means it won't even try to clone the brand new incremental models. \ No newline at end of file +For brand new incremental models, you want them to run in `full-refresh` mode in CI, because they will run in `full-refresh` mode in production when the PR is merged into `main`. They also don't exist yet in the production environment... they're brand new! +If you don't specify this, you won't get an error just a “No relation found in state manifest for…”. So, it technically works without specifying `state:old` but adding `state:old` is more explicit and means it won't even try to clone the brand new incremental models. \ No newline at end of file diff --git a/website/static/img/best-practices/clone-command.png b/website/static/img/best-practices/clone-command.png new file mode 100644 index 0000000000000000000000000000000000000000..96a558dd97cd0282d1f688abb1544d469f663114 GIT binary patch literal 44464 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ⅅwj``1D+jb@EFD3Wv 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 literal 0 HcmV?d00001 diff --git a/website/static/img/best-practices/dag-example.png b/website/static/img/best-practices/dag-example.png new file mode 100644 index 0000000000000000000000000000000000000000..247ede40afe15edfa42e0e7b33394e9305afe173 GIT binary patch literal 200045 zcmeFZcTiJX-!=@`0DD0?q9|2Bx^xi5gGfEtu4>* z<`?1T;^NwE_Q%=FTwJ{FTwGfo@NNg6WLV)txw!Z--X;N}iOnK!Vr1vH zU6$aomi@?gQ%+g@d-8+29}iDBa6Ml<7Wt{b;Rhf5{4;4|k+aJmw#rz{e%UH>QB~w3 z>Fhn+{zC3sGQrhPj&n8b`b=&bJ8=}%cRe(|Ir8vV z+r9b`vsI^#ttd++Ewc`ri1b6mL~D7=VWmyO#NjCO@C?727{0s_cQYd)H`^q&h@_1D z$Gt9nBqn(uo|74t(RMhzPrF@DP8XiB;+!kFLaji3=+2T|7;c((4?I@rAj#gH>uF~C zjA)m4uRX&P>t2XGsd0J6>hO(`mEb2*c}3bzLK*=X1+TvwtEu=^yB^z_yrjHuC4$_; zPG;#tSJT${wde2-&HK6MYJ(U*CSd`*A$2a0&Q)yc&?>#%&HVE#($ zdKcry3iaejbe4mtyy2%q@T(K*TQr-vydPZP+Okz@^Cnl*fs?Hn{k*y+MCW4{FLb!Q zNfMR5dgH9#w8Ji4QQZhG>6z)C>7O|UsJ%y5@xre39bAJe!^6W~o;N?3a%DO1<(h4X zBQJ|LQtdAcOFGzfQM&**<6<+y0sSln!w|mKdso<5!75(CEl-o6Tr;K;M zFnEc(E}wC`@(kg{mM@R5OXwV|6{+QeCK%j9V7}#**l*+T? zZI>@{7aj`c3g!>y>yDpny!qJ;7g8eED=c~|zM=3cxqk^6KfHSJ z#)*6TmhX+;Q@po+@9;;9GltjVUR_i_QFBo0f!t^OXH_@-*#onDv-%Ius!CQTjV0g9 zcfKqYxdGpR@)j7{O;~<5VqbvH+XH;HU$KU?au06n9kpgDSoB%%Jj98O{uj$hH7%Y(_%s_Tm-#y{q(xT`lE~l5p#>@ zm6u9gn3dF5HBW2OYK&^FYmIB2)*o#*`2>-&g=Ly1lWZ(13ZutvwijeXs4IK#@$Re` ztO#?Ac5K8;cz>cEre32eR4jRa{UXuXNtx~2Kh5Z>ex;Ug-pB5;=v3^~FVcN=o-+UC z;8f~Fc3(t;wZ|JF?>JRcU6{SAlcAAop=;^a*M^=~efD`Ld40M1vnT0#lln#VlPZ2{ zVwzoQ8NL-=uR10kt9*Foo#jXDe)lP?=X1|-s{38D)T;Y0yHC<9_=sT83cFUJd&k!C+6!_AHHr z_l6lPsV@A85dSH1HNE_@{dxNUqCfEjy@+^z0L!pt*d0kpthah$Ra6!mkRMRZQZw9A zf4p9&{#w-eO@WP4?q|22-}2{P($*1^D0-?UHX-&-{*C?vu|pD9Bo_4gkJ%p>R29q- zJ&jx&l$nnke>kQQeQTd((_&K5i^3P_FY4PGJN9O~s%)Nn=HK7)CgFz9@{^yRz8{ey zN>!fKOHhB5a<1~6oT*}5alA_UC7vaxDz*0r3JM@4;qJFtcf@zD z3hF4Gv=0k-JelY52&>fVoK?BZIM8rn@Py0{mD$eO`@{7?Chs%`A8)lhEF_TNdYw-llNaYbh7lpTS@`|f95344riIs*=*H71J2L_KHE>euBbgPQ3q|?T#nbx?V zK+C|di`6tybDEcwcol z@2>v+k9+WaI(@woy#~aBJ=kQ*ZV895k={$WFWcF6Y|8G1m^|3GXN-PK?r>BcQg0%R z#y9qGHJK!%V0Fn#K=Vv|tLXjACz;_HuuOvGjvTmepszOj5nFi&c_R1qX-qhxRr^Qv zui)YF;Eu$KSf~3+$DtFxPF;)3Zfy+&<~&VTc^kAQXn-}>u*a@(MPUZg;T&2UzA7^B z*d1Cl9j_%8khKaH7n^L$?0Bv00L`yK)s!xcqUk|@GEH!1d9eCsTJTc%5^)9_@pwsM z&^4@noO|;_>wWLNUkzF!)fZ1M@r{{%w<#zpAXns4etB*B`O!)wcMsY#a%TC!y2n+&NyuQ|+kmmJj&(cG zQK~rx21;WW-X*`};=goSW&bVY4({ild5mhK+xG4(9Gf(|U0BC0&G$DI>UKQ#C(oPOTIV9Kug%)%GjEy%TU`?QrtHSY??g5A?AlDL z+w}f$)^5j7t2N~d=eD2Xx}m=xpx0Ordoxc93od!^o|kJYw+PoZ@Qxe&8gPsL`@Jc* zEZ3IbpYw2W-S_6&`d`Obf>+K@68Pnu^RL$}Phz-sfd3AF->~OA|9v#C`|~aT{eH^> z@Ew=2jft5Vc(s8Ad3eBsuLp$e-igM55BP5U;SkKlb@&A5m)q>}@t>glKJP2`A@&v* zbzlMhO4r;2+&q-R{BLl|;nEA!0dM_1Las@M`TN0xb;9(I{XRkmyytwZd`$B9AtAo{ z$LuYvB~1c?JR~)hPAQ!_X235gDXACa?x}P6tm%K94*t_Wc0DBIhK{l_5{Xnoswo8o zc`2)CYilc?QdL$}RRl*U2BY91*TNLx!BYP!k$kK^1cz`9RQc)lzYuBAT&h( z*fGw9{{8c>dU}L;|Id}+!T)tz;0BdB-zcjnol^dH+2B+?&Zj!o-eDeo4rjgnL7RbV z7-*kT*ZY0^pT7B@EB?os_WyIHs*3vQ|2*|SzWP5;wGH+NG70bp*9q`=ii@#hBn~WQ~r0S8StN^Ts;Q*QOx_S)fMmxMj7Xa`!o0>`>$8< zp8Ju)M8(D-E-oW3v$Mum!nhejJF=i2*_*Sj)HZk3Wctp1XRe<)v%Bj6&*gmHSF%q- zJ)leVn0K$Hv3b)qSZvKxXkR7b+*V_2ql{bklI|Uj-IugLkFfH*yg456tvc(Xr)qL@ zZT)yh78zChq&k=uOkT_Sx}r}Gjtqw1uWfca$t!t_i|23rId^cv$k?>=BuZ-QJ|iyf z|Micgzzv0_{+dvXKb<%rub@yGu{6{B+D0bL;<;v(-+}n_&V$!N;g%+75!Q&mhFV80~6rKNc6oDx&E~%{S z)j}jMGoOAg^{|KiM26bj6oE9Q z<^_YSkTK+}cqn-m9%m4&iO^qb(?!l)953$iBAeto;4msz<7Tl`N+d&@9zWn^=L%g* z@ygZyj2(-pC1oE)2$;u0%L0q2-NZZ8KIhcFtjDWuJ`nUfy@m8tqzNND0jZ%}G@P0s zNJo3(r^N}ry(MPj#l*EX9Z%V(dgT2LaYONJJQ{D+lUS=8nRJo|Nld0JueGWGd| ztuEQGqjw4x9)$6WtyL?Z;aPBF?^0{dw$M?i?tB8Gdp~ZCnlk`gd5FeYAG94d(`F+=&;T z!$KIv0WXtHS_r5ILk{Jh1;fw=EQD@roaY8Xd$NcaSpKSd4hpiC9CT;#+NdF!NVtH~ z5+0v=_B|EZdK8hmrIz1X{eE7vk+8xhik)7Ln@&e+bo3rCb8EtoOUy#r`NrfB0_QVc z&c#976TNdzDx}f%h};{F0Wji|KROc-^2AW-B-FS&+n{8LdmuZhvfR&cJK@Kjv z96a~pPQN}PnfsyTlsux=GD`sw+V+L-7&#&32{B86Fm(|X`fctoVai!HGWD(=7y*#G zM|av9_kvA zto5BxQ$XMiBiK+-T0)|TZ$!Kb(p@>PU|~CRkEZmG!o2m2hWyF;_Bm0+pT1 z?%t!?X8Jf~o0dHs^&`0OS@}_gh9s)(F4PgV9(Y{vSrs?PT1rW17u}aH*pxHtP06#^UPuR> z8KXCXZsWyGi<{tR@qt*9E+RDUOP$!X*kkHa+)xs@5`eBcs&Wehx(7R`9`m<=9BSWlNvXX~>7i%;PF1)epnIIFy?6bskuoO< zFrq}I>hy!ZRTV7go_9grLVs&ijTqm$6Q}3r(Yya|RmFLmY}1X=LY2QYs{R?^f1V)! zpBmt|oQz3h?V0|cVs_g>q5k^e3vW8IbqOV}sDl;W$&}t+$EBH}Qkx=6B_w=|0Wn1yVAF%PF0SZ8|&Z&uH-*6P~O-BN2AeHcpnxDr4Dg8g-b1!!zs{fi}>PV z`7{JR2S8lh9&sJ}Tmy8;+qYc>Lx80Wtg@%O`zMD8RsUiddL(SG14##dT{q%n>{0(= z03q>f{X^BkULq!7jc)W*L?`!`-iR9to$hrwckW!qL23kJ>U4q7Tn9l%NdfF}uu&*G zP%l9k2M`?u1z|>v4b{}>*zEG2?I5VYAnUJl^doAP(kZTXfC;1nAVC1zF9hqHJ~qU? zWqbZ`a>x#a*(h*i2OS0WTp}hg36%2%*13_d@_epz5wnTau86d6y*FN!ZjjIYErH5^kTXR zefRLtq8I_U+7=7dj#x^sQa~inVo9#lIu{gVUS{e%sfC~u@Iq`NG~o{%CaVk}gT85J z3s9Lxc!@zd)%K*^*ND-2d-Pa84x?A5Emby)U2Tm$+JODh0I$d6q%&GcP&;88F2NZQ~t=j&iez93&`imMyY-`O3*}(FFJACm}aV?HqE%DrKDX(n_Pl%Pc#=I@F zKN=o&qs^E;JYBF$<2M^(1q%6$$agaL5ge@qc7`=#rMm>qyKH&l$0&xDbu_f4t67*e zsUb9)vh*VmB80o!cVDn_3}dto^ix)g502xm|G1=WjFL2E_&fofm@DxpK~M+&ISwkW z<~9O#t5T1!2Y^sezyu&Cz2^u@+Jb#gfbE`zgdsmVMdg#Psy>IN>BEq8BC7D=u7*-7 zJ40wE+H=&94b@+5lb6m>^Gaaa<_>7HlGCv*;{vKnr1@pWQ)-EjTr^5DR6e<6l7?B2MaP0&vR#uiC~dGJ82pPn(RxRLdux zYm5cm1B`L1eD?q|LVxT2|)R3^irP3fXqTl%f14Y7Dx*Ke5-A35K#)+q1`q zWo3`Nf+n7@W3(W@e~j*R7#{iqH$CLl+iwHNb1lDRnzCz7hpqR;JXlO$7?>W7W~|wn z!Rp{{Ky&+dqdm*|Da6WNhztbqT>#$}(lzK5gA(Sn2BhHFk$7b7c<~{Ee1bKd4WJJa z2H37K9-D*G%984GPK9vjZxC?~4Tv#7$_?jQpDI2&K!9%(E}rT<`*_bGoztjLvDE9K z*1cPwQx~7T=}f@fP3E!FE!)%L!t^1-rEK#tR*4cNKo zZhZlHV0mgV+bU303Q^lg7%(VD(kWqmfWad_xweIaG1NKA$VQH041!DgOD~WJIZ>ei z+QvGu(`x|{1MKq+0y?YqS>bL#9Xv_!`roJ}ymXpQYs)ENY0s4=^UYM7O zJz7>5uE`-d@#gAucI;86jY#fwS35e}(TxOeGbm4Z?6UT@kolFOFCKF9cOcz+rmT6@QKT9nGBr@`=|3W$d<_CX8Q zg@>Q*U-WRRssO0hqC(k;3d}opTNKVs z%MS1oS9@2o_FH?Ed<4GEQ4c0-N4Q1{CqIq`bJVp20Rsbz@*^9p$0lHIu%YvZ2{~(T z-DFG|Bp)qC>+0mB7?l#<*hD}*8nSQPMMhs(yWF%yXOd2P-V=%yAkbCv*&%>)b$q__ zw;&zwKQQgjh*R<(9`a`%^A8XCGmrU)hx}jQA@55iVZ)^ON(9q!y0VpS!i%_B-^EeoEHkKJC2UK)ucvpob>HR8eCr z6kK4wB%}LFwFtRCo&z>?OsB+B$Mpb$0FuXM*ch}u_nmoz!d>$zGa=5%V z-EuCx5xc4mq%C4*JajaI*)7pZb^qw;(Pi9s{0@LSsz(D*S^yX4ZlD@w7ACv9jdLqY zz3AB*<~Twho?N2R{A*>td-jjG{?aSC11boOYcD^9mh{^O-kH1I7l!Q2J2x2yId}!I zyMsZoP^Ob3WPM(~@G{+2;)=n~HlUEO$rK<(q?VBg)IuMK3{(Fw2&v~fti4&3t0HE` zAyc;qaFjP9run>p`^X8zcw2h%VtVS@ArlvrmK6?TM&D*eXQnKqcUP_;5rcofw>##zf9zg-j z^l)ffb07+=GMyaJWz?_?P)2fDx47dJ_gRXyg;$$2n zeQ;|@a`T0s5;CF`2b)YCS9xxBltR0JAqn6+}_I> z+mp+T0c{AqyRHOH1vH;*&8Qh4a!2dxG=lq*_5+ke8x*k{3q(y2w^#$be)mUWuNEL* z?-pBj#ENtD!IpU)&$ADQ`qtVwVF^I#5>kn3lE+JA7SPlorg8=fpo2(>2Pz zg_d-=YWQ3n8S?6&aioK+GVN_;^)Yr|ZC8wjlZhixHU)$}FcIQKJvnZFaF(?4VJNw} z_!ONoSOivyCPD^mk-?Ej>f(C`eCuNm6U=r^@?Xl4dBQocpW>W4S9_S;zZ(UC9c4mX z)~*P#Iu^#Ij1gh*d{K&T3&hh6g_@F5FyUw4)~%| zkrXh{Kn0^>X+oS;uDI;QiWRG$qRG)Uqhg_@Wqt3|JVDH42JkcJ5WlMWKE6kNAIzAq zq3iS1haYuFa0m%?!%hZj9>>HWU_y=km5vZam0m4UrR^`$jgD>{&>k@TovWn&BI2+e z^YLcBHT4|H(M?S4!B7{R_6ExCRvV8&;H?@?+cjL*BGrlMB5JGr`^(%IWK-4@3lZ@WyGs!VlxDz$u$3-=H1zNG4?mLjX?3cIy6EgCh8Yn%OlHU9 z(Vtesv6!0=hu);6E_$^wr%^Xk-0UGki-WmM)tJzB8wL;=uD^WyHysB50K$I&;h$;3{{=w!kMi;->i+*1 z<)!aV9B>E~7K-bHTwkhG>C-T!sZe_?Q;HC}G4+?8 z-YqY}_4bw5-q1@J6?-`(X#0(Jwu zQ~zc+(|u&XZZ1!uWzm}y41`vbKjcyy;lvto1q203g>py)FgdL*u>$lX7Aq3Ob!#dJ zVY6;DpquO#*XapgnE2i`1_XwSOgM*Z>=yOZ(9lp~&h+CxJynAG5D?6_M@?evLqqZA zAh7NK6_n8b{`TDx;Ez&b!hyNV4(sflnwmNpS&%Ey3bYZ6z)<>ebKdn*KJ8 z@h-LD)r~WtXutQjxMy$}{}OaHu!AXyH|-G6eNR>=;;k z+%dek`t>A0q)_Ur%pyhnYbV9+~T)l3z!;c3=D{344B5LkodzMo%rLLI7?c5`g{_GWc41m%nS- zEIb3LL2thX;;t-DpvH%f7&dr6!(3(*v!*(+Zs(cd;~>5(I#x`a=LjHU&)8P5Q}O!x zjlfMHzZ4!1Sk$yOxr9jYXnk72n$qw};n==FOn$y?syt#G3c}t%H#!}UOdSu!l6^AL4LSOtyLkjPKUN@fp+~##cBk*|UiOWUT}VCZ(J z(W3pKH^3c*S2Fvy5Vby1eV%Y39Kf!wc^&SebzlEEb|I|pe7o%7aKMnZW!xC7&^u-=*0$IX52k2vfhkXg`L9i15D~UaV z2hna0GfJ2%aVYN^J`3ao@!mxVg2?q4K6&kkQK*2RcitaB;ovAZW=!qiv3wMWiGu-` zV_E3~t(}9@-5|+=8J}NWB)I})YViY@@b3DSCHLdpI7DRf;el*>N*x1OJQ%$)XitFz z)Yy<8gVY3Ywz}m{`;ef}jbAI#508}*ogNJJZSH#y$LtWsW)OAz``{TO>LE_$p#E@;dn60Ux@qt5a{&!-^qb#yexLUpcoO3fEt z>!!t2tIq*)5*Qog-(sc?q@XUE3MzIK@ky_|?}%I)@Dl+H&hY};eokeo0oBrv0qk5R zbfEW)Yaldcx;eMrdt^_wfcvW&(;eqa^ZWRqp}iq)woHDCZ_ov1af_)xAUqoHZ3)GW zb_AC#&iL2-(s<16+u%SvCe|Y~zo!l&;{d|v&zYFyewPLzAIJ_{{K2TEv8mh`1E9{3GCWn<>|5p*gN)M)LGJvaoA?cU83|;ylZqn zWu&%`3j!kU(9xp~<3|y;w_fWVk^+7$>!_CL{G`R#dO%cp95<=vyH|E2518d*78S`H z@q-fXliS6&g$&ji3hu(evn~f)sZPM^1RD}UX(^+}fW#Ds#9KvJob=7T%#h#op3Shg zbHb4bm)6>vaq@N?=Tzv;9wAqme4^!qPkmQiN#GsM-3pTkK-sGcikpSE0hd?V#!D}{ z1xLFA#Szl{F40r*UW^!_%LYI;Mv1Uuh@vMD$v2-5M}w2M{qan#%en413Bm!bgk#D4 z3~mh#stjlmW=`h?2CW?jA{Z(i`%yqsMR@{Uz)oUrMy-!BxpxmbRuXR|2L=K-6I4|N z)>kTNBKq_nd(eNP&wuPee_^`%#~$=2Z2gb_?aw^c=>J{+8^<05Agmt<()Z$EjSH^# z_lP^&UGXpW$J01D2bz>7U<>L(P(0%hz!IN@4VHt1v8V8pG}aJ73kq4^MXO3-#w;Za zU>6mbpFrpl?XZU1KviKvQ}I;xU>dAaG(k9rrX_}PFF`!21u;=w)YtVyf{vZ{+SB48 zQm+X!nmIiL?3a%c9s_xry<2630`CWrDiBV+L|85I$3(f9SAwl{_X=H#<*5j(!1OD6 z?uw2)i>MVLh$je#UtCLp>>5>Jk=mkSomjwk5k87(Dfsm7gqC*AHAsjz0`ZrJSVQb@P><*Ko zF=q@UWA=pZrEaoc>=jl(P$JWmpm`%l$v5`_Bk3C?u;l*^59Of#xFjIOiuqNPn*#)H zN_fOr{TFzg5I-6MqTs2UZg^3*KS--y^S1JPCGS_RMMn5}$#d`evFBke9-`rcVm>WFXY zL6o`FmRRK)c;7F^#o#|#pr*7Vys06Xx>1*4R^RKk^LQm_59DO5j&EO@Q{drEd1<7o z~LFcJ`g3NSnXFY@k|cB&34u(h-M?G!66ZYco9u)d59Io9vQ3ziSGugvwU zA6-%NV^@K>KaiQ4o2$6JX(EzgCu3g#(a4^hQ_C2Ic+n~#p8a_Zt$G>od4I8pHr`B? zV0fnMUOQmAY=Ib6Uv2uvZMNx^6fYF{EIV-3?8MreqpV^>pn)XckT7o|0M@Fx-n}&z zfHaIj!m1{)U5^fNQXx0Wk*mh)Ou3cmH1zYf5fN!YPC;#l!pj-|%3>pFlYK6*XnUgX6igk}|3V~4oeuHAv6 zAQl@Mw+rV4g)(spnQnj(FwJv@0j%?>>jMM^h*=>-8mO8q3KEFjAUcAe7lS+a5Z0Mgf{?NTJ;~nu#urI=0MAD*{P}& zIMC5!+jbt#M;+aZ6J2f7Y1h8~MY0MtW{*OGk|$BUSYT?;h2?77(J8Z+rh$Y6`yKNi zs|rnU2DUXKhDh)mcw4~{iGbTBGPO_p7_$)$Y2uCE|3dPU?~T&k#UBa}xY!(oS?SN; zS^vIaIPkQTb|DQ-`>vZJWSVb_l6TIF=g*$C%=@KmnH3&?$+;h zZnjIF%#giIaJd`4`&P<9_2yy#**l_R52kEM9ZbDXlpaxkLrvqx(Sj>>V zK?kt+gF&k@Ix;jAvi)p#y{@0ZeU9a1PGw5tH6%KZm-QVnxW4PK8{kb*%g+t(bcaEh zC=&d%@j?Ehfc%IM%x2A>c>&?1$(NIo!GFqx;gbp80L4V{%Ebb-JxE-E2!JFeq=uEW zD_f1of7Ev5<-rO0{L2zRmji6qs>mN$5rJX|h%-o+3RUH}*JjXTzlj7Vd8!r=^S0Gb zNOn4K#c<48i(WvLJ2=t4{sE0!drD2SWgL`3*!F-@fL`N8ryL$~g=G{~`6GMF@>R7KhhN^}K?HDiLEBnVI`M)^1*hHMvm zj^xufue_&1qW%{1zB67&W; z^rsgz7bjQV@k(0H@T~59-M4Dc>TlMy$=9$%fnpd;vrDG9vZwnMSjEuM_d=*DgJuH0 z*|jxXz}P3Z`)tkFVfCZq`0K8h2~+0b0kQ|T!;1ZWe+{Hf$+(80#gj% z0n{M=*CS#IAPGYx5hOa1s*i%zW1{6Wpd`>*Oa9kGr|5u6kMfKfiYs&23>pjo%MTbK z6J`tuM)aw%;O29#(4e-TfPaL>XCv9dZlAGB&bGjbwLH7JMPgt~ktKiRdN%Orr64Kr z95;@*1_W+*7RVD5_?=(zJALU3lCs>5;k~>f8HWs|>2jQ7qtL25yIwq{1%17HknzIM z;)0=_hXr0dcyUtm#>mg0wPzk{sHrhU`9to%*2dwoG;;F}6Rz7@TNfEX8X}AvXR3Sn zeD8?*b-%vy@%cc8!mS%yZXf0!M2w>s&(4K$y@iy78t>Isuq&7V1~=H zWj3^#^>ErmE8Pv6oVV-g)1B5yok0pY4~?q%E=G97td9s*6&&$x`gVIUJ!*9=XzjsG ziLEV;SEquN2ioha71ran>^TA-cV4la?kUJCF$}IopXOI>@qhFaweR{Sk1}yNcKyeg zZnuDVLK@(>8Ia=kAA7!CJ}Z$Pk;I6=a3U$!#htC7Jke!BcdI2|7?}wy8Vi$ z`ec)Rom(n;RMhZ~@8{#R2TbFH#Y3ekC?vV2>lmj5a{PNyo|?-^SfQTRHs{wC`!<>J zJKjZe@mTN^bzqh2U#;L~M+})C&6!P?WVBYCC9XSy)PX|(u&vx%FDU$EvepO3I$Yf; z6ezR4Zeg-ZlSGjE3*lkJQ8I0tu+@pL;y0%QHk07X!G>WLbG9db+4}nCfdYG9&5CSo zG5=OASU6x&^~+%0dX;(rjpp0Q!z*V0EoV&vXQ;n;FBJRg4W?`}C3ND;_xH-*I!!@d z!u6DB-Tg-Ijjy(V+sXKO{QN(uie0(-GRvXi+qwGxun)RafXANG7;_{4`C*U zx;w&Iw$+0_8|=OLRbyW?MM&<0TwRH!Gz;9V%Z+@nzX<>tl=xyyE)wzrOEnj7XUVVC)r zNg@vunr|3_N#$s?F2Rnfa1Q!@n!tE6 zTL6Eubp9{0RGMBJ8SGSj(%L>mthk1W{>MK^IBVGr79ni&l;O%_FugD$5v|Td&8(1 zj2#3LAee=G3Jq;I$3*Bm{8bLg?ROw|1x(v1{iHi_cHOgQwzgaVW8y7U?B+8~P8Lj{ z=7DX(4S^$2u%(BBV=Fr1A%B%vB$fqk|M5=Mr)}8*qIPBY(o8K{uZ7c-s7!yF-TI&# z?a5lPuWzZ-k_cwTF8S9@CZcMjE@yqU|I7YQd*Qx zgSjuZQ&kh|6kwjr6W0(tM!O?i?$@Ev?SDQfeXv(az%~`p!`C>lzfr>fQ-TQG9IDh{%@XV0@f6 zev_BiWvPqI$_}4FA*kB0olA{%pf?$cMr*tyPM}F|21NBr{FzbyJOC2GUP!`5e-vo0 z)ZOojDxkj^cZtMJe!X?gs_FQ zF4!mGBHMK`pB#4k)j3twCjg7UPw2}N>`t5$PV3h;yJlKeSL?Kp(X03Hzn2Rua7S}A z>6>|ThaW(baDnSJ`Mkrk3m1gS^fvu4ITcbX|NSfgoTc`>pY92{4x!{<7zPzjVRcgl z!TfU6cDc{R(*Ux#UJAt$cl<@}lufDH%6KKkeCfJEe4Tw6?1d?3QkTxYcLnVm73}CoOC+M$B68W7_73iEV^u|8U!^_6HTR_-j~14)5~7UE$F73`+;Dhw zeV@^{t01}Vw2)%XqrYhSFOHn1zmgQVhK%yF+L-NJuWSu0%5guReIqOW^mlvF$X~cM z{m3`Swy4mUcC<%KJIbTRB5I>y-6gX3gkV3xa1psSfB$fV%PEDeox3Zz5D(a z$tu4Tb0i`zKB{q4bG1ZeZP2yN)djtABI4LeYzm~%pq@GuY7ToNQr1b*#SW zoorSAqxQ%f-un)8r97utMztt$JFrd+T3}{acrk!0LhdbW6d#A|pZYn6({e zE>On4eX8KTefhBauSRy1SFjiH(iP#;@(LKgws*6W^_RS|1ZI?|WN)&bx6P5Llj{&y z*Q&2;E@2d1=6YY$&HA;yqk8}tI+xgY?AH4iAiXv4)g9trEJ{YtPk_sTZQ;p!e&;xN zmEDOv_GJvT*7e}bxV>Ty&#!C~Zau72A!@i#hwh#E+)X;}DymBF_#;-OxQ4=*x0j22 zO{;0hG2>Uu$zFI?`)jc0%)u?&_u|Sni{H84HZ?ZAohHgFxsQ_z$vdI`@Xym@#2QRU zuo2eMY?3;CbX*=7Iq+F0U9!u(ySID$)(f^tvrSNBe_8!z{TiQG;DU;#v|P(+G-IVV z>gTt03FTgK%u_{keiiBdo_rzLhm!QQT4q|*&E(y>Z`rPoyMFEl5KQ(Xi&yfS97vWe z()9m}J#7W#=-vgpB5NINdw=c(0rx?4H<^jejH2fo6B?eSk5h@OwOWd;U{h2F3k5Cu+{^+#0~VSeMl>si(LvOzbCI_NW?l- zLv!+WL^9^u#WyGB$EzkZz->HuD0B3dktkm)m)()QcDC~>Er90OB=MMm0J6HFf>k@(RciY zGoRT->`Iw$wn;B|9(-?<2(Vh8ycXf}@ss9of#BW;8aF0RiAKy8Xl}$Rl-3kRe6OZe z`n_$Oscn?jU$|9j|MuODC}5j&2};j4K-|1MIP2-VECA@2x-<#REBVEagL{92_dk!> z3PrF2XYs3kgm>a#=XKe{a^{=I=N-Ntz3caL|9uCtLG8y+iW}9}nBh*9S09%;)C?YO z&w-JxZhi!8u6tq{jLF}K`dcU{r(a;->C@cgJ8`h{xtEu3>>Tf?l#z%$1-eK=CiDT4mC} z^VG7LuQ27SHO$JJ-w)8<2HL;^C=+PVL@gh)c_n|=fZ@X6=M~E`D!CKKD7rZ|%cr^W zVU0ODp3_Vp`a#Rq34QzM>xPo<^ha~Q{>M@xXz^{r@o#U)fI1%J)Ui3nUE{CnD9Cvf zPjzt7WUeJw2zWY9NC9u6M`MC`rEj0oG{~f*!a=;8v8c-`m$TCM`i-b{4!JLg>V2_O zcKVL1@fO`pdnx%TJ||}1^<*CUHeq1iz}Muzzi6nCTz2EK%TIfbp`6{^rz^J?SeEq; zQEejx1O(tr`6am>EfA(pt^Q&B>zifHWl?md50nCzOAC^1;+=+6g+9^`=@ZwS-H7lX znzH>qBON87HRVoN&hTZ9sFC4w+TX!_-Pvlm-{`qM{~>}Tc<7GyDZ33DLd$KJN2^z+ zd|z3_<7?+?SCf3Imz{NMFEo+Wixmy@2IZT z7?3}za^^I!QCm-7BC3E1K){4rNv#TL`zeBaYO>3Fjgw|~lu3?tAR{P+8x7#;6a@N; z!N^e3ePY666iCU`1;@s|@Y|S=139R`dcUh74q6)AwB(|4$PGfP>?ofyI%C3t@N+` z_*(|XfALYb-{}b)`M|D#si6ZdEID-$SIqEGEwZlr8`b^3hQ9v7H-`(coiRTRy z1QzzUVY5FfBw^sGIo>YUM_>Z$Sdb`92^pMcme^n#t64lH6>VM3>b#+b?CL4c%*A9VLCaBCeu!ENtOX2^njPR%09D4EA!*D zN`IPPQ_@lIx~2ZT8rRBieE+zRA58@|U3>M%N?sO8sKs>7lc*G)7z7u&AG2JSFEc1# zO$4T*SgIFDAON|EmcW#b4h0FOr~T%~+9xY*X)ZY6nc(RT<46nOxl(%*_g#=-2`W0K zkY>JpxZ550`2449L`BzIV^3VevoG5&Punyli?jCVkpX1(% z1X0w0K8_=ql*4fnPu+{2n*oXKPi`9aXt0!^H9d>c(GTxFftgmphx8C03ZLOmkfCkB zNZxKMN1k?$A1l#&3S3`B<360nFd0mR6=Y$S{aL`aED9{~O?prF5eQH6G#Zk|q=55- zV_XNqPwr*QFLfirgcjpisfH3HefK=D3xo*>dB7mE)3(b8Fl4bg;5rHhIk5=`MOfht zz^s&}SgvF?`*2K6uaT1-%Wro=|AqV{D)dXJbXn-t|kb5=u(I!>p3 zD;0CJ8^Jp5wKF+av=^(OM<0yOL5I`6H;Q@OkJsypIbpchFx-8PEgcY&QHLBB1grR- z$Bkg7OMZhUy=buu^-*6b+LP6{HFf(j@VKZg8Gh`Gl`XfYWHHb(WAM zayub9yY!w`1+b^p>1){03K-ARe2q=NDcT)9hoj5f#Ksto>#KFbP0%{ zln4S!2}s9CcgN63t8|wzgmiZg64Cd-T2M@Hf9*l7!SdFeLq z%G~Qbo!PQ7JxZ#Uu=r<;@kO4xn!4tj3cNVgxL+;^*6#ZSSCaqu#@}Wl@QD-~Te(2q zLp7T8+g>$hTJMY6?$&w9sp@*0<)=c>Oc*P1D4FP}m{uK7-TU=NcMh`kX1f4L!q}YG zzxjnOTgd}PY^A%A?$fJn^sgY4sJ{F3)&tdhXV{jdD<>HJZdBOn>(L}?(n}~D>(K!X zlT`3=5(pKFLkh2ZNHor`DE#CsFXV(YFoG5bj`_?V;}W)S zg@ zCFrt0J8l10$-76Om4={z7F<92S8H^VWEc(wGw)!^phC!TXJ$oyny^35Beb# zM$-e{=@u5t$@yCU)^@+!Ru*G1cO;7u3%%3*w;W2`D|ar?ouC9c}@;ptdhq zRly@JfFfT4IH0xOS@_>k&K-0-1yK0}`{7te7pw|}b9qk0xeUKB)mjio!?R(pUYxRw zFRdcW6*i8zLeLb-!WsA)uRuv{>ccs04c?cO=D2MY=wEsq{v_Mwv~>&FKFf&Xe|NNW z;$?jaf5Uk>@O*IpTAq?~*#|uA!r?4N5`r|yi(O|V~RXD!d! z-<*4h)xkH+1=!9+$ap8|`Bj}^@qVQE^YhQ`MW!&lsbFmX1o^$um3T?tFxZ`A`LU??ZH~cs_KP#1@B67l>RTY z8(pY3Iu+jVvJmhNePmqaoRk9mo+(T|pcec0Sw5a@{04ZSs;v@*Y`K{cJ^Z3b>^*oK zcGkS_<+5E|n}fdZKGC>?n2~j4q`)`C<`s@L&l0&UWxo|`?qQIJkaCyL?A3L7yNuXk zt4m^AmasE;ZImt;PUtyiQ$M#dt4o3HN`68qj!;&Joce&`!(Hh3{(pa_Pp=ODi_F*% za7{1PtI2fLE>414OwwSG|N3-j7jriO;$1)Ib8{Wo<#W9aNnu*n7!5&UHWKl#d;#Me@8 zZ7*|%D`HVc&3B1T={C&baT4BWg{V@0urCdG0zXPj)~C)}9~$=>ws(L4wA!+yzSE{* zlWBXpdRrVWi}ZB&cuC(%!aKb#+N%`@Hc#mCWW0)aCxA^m_<$wd--9ot-5gV@2fa+> z7dc&3LWCD`Rn{_MP>hX@VIB`hi=BOQ94Kc_bA4=`TkP{ot*1Qt-p0+d;@PxIF&+A> z&E0;6{}w{v#Qh1fLwi2m%4Ml{M%ma_&BRojW~KFE|BD(kgs^tv)ohuI?$TkWjnmfb zl!XUE=H`@qXz(5mrNMPDUX5>$aRm~e(uyQ5E->Mia#D^|8d~hkz}}f_oY>mlE@r!U zNgXeMK0Shkh0QxZSu*?jUrwe-5%-~89-03|oWYjG*V6gyxcqy|y9724V= z@&-kooWdtCP(0Ugwqsu1?4ebgY!lX8^cxA*`L;}DDR>25JYcDmpt$oKn0K?;x)Txo zF^J;9Yguu-jfd^KMYTFsxv3s$xQ}?N?0g&r_TZcAE)&1RxP^B+ZM{I@=Jjsr?2iqH zcGXZCjJJnL)Gne}^H3_PEn?4WvY>%k9@861f-`hIc1tbElg(@Wk zf#(oQVc(QWWck9MH9T}YmiGmIp}^&J8h1j+T>H80bnbQdTfLWFJFY^`J8mwQFII{S za}|)n^9Kpz#73jG3nnVe@>OJMiALPQFS3`kr#E)?z-a=LmTk^iZe4a>vKtIxTVB{O5(G>^{Xe4Xvn(z zqZHq|jR=4gb<$b&e^V^C`S7EZIEaqoaQ_Ck5UXJ{q9Vn8J;Xk&G2>ryUi5s?A0c*g zEVkK)Jl!^}oplIlzT7HARF``F+JhtaP9z&>u1<2rQs*biQWNytdu*Cd)kX%HVV=BR z-qzN|sm|k?F1@U|llALqmbPBo+GlP_3PTXLwYZ!Zdac_GxpVgIz^~qMeOm0QT`T~y zi(I&Yhf%$#IPgGpw&ROgEnNMvWNtVaqdS{*jNn&$bOe53-ut|rHivt6tT18D8@W4G zJGGARx$5$njAboN{UCJQ&$k-_xmp&DF!fQgZ`~Rz9BD+M_HX9rQHa{y+Ee%D2vV;S zv8yHg&E12A2%js%#^V8@_EJvN3xkgPAax^Km|&$YH0~Q2PBQ`fO|&na@>1vR(F8nu6-2kcNzvNwrt&=CMQusYRsy5)>FEgX z_oYIp$*f)Y!h+}f(jHMaFlOU&{7YblZ&27!QS91@UVs(9pv3_(WjfR; zLb*^TP2={&tMEXjg(bK7;+HMgvkWS?l`sKP@4@-^Vv9lx7vUnP^OYKlv4Ru&HST7; z(icksL_pVMjA+I8E<30IYee?ks5`Q4|7V@}O)yH42ay%D57LOlL+`&eNm*|32`I4> zycR_O)X0)8$31f!tY%lAv4vlw-EshJ*Eb$MBh0%G6fJ&+0W`=acOL`)W&Kl7$e(mb z3hEQ6ZNhFYV7uFp8~5`uCxew1)OO3xG3>^337%tfwcUcU)QXJc41dID5-Nh+soa$P z&@}Wx-&X*0Mh+gM)L4y|*OaAv(Tb({nX!WS$(}9;5TeX=lV~ zg?_O+4(+%C-&Hc=3x8#(Nm zi2Npsx;iN!uNGNg;j%0NZOUOrME^>}^l=PrEk>m&by?WR0J-G^swG0RMcg0nylGtc zQ6=5Vc}$md{l;WB$`*u=NJLPYWTtBh1~Tc+XE? z&iVY}pU`M;Dr{3Bam%B%OMmk-t=G4U`b^4xh`qGQz}9^v1@EN7-#ZjFNNIH9GhZe+ zsttNl1$3o<3mUU8AZS2O%Iv(Fe)amH?wV%DqXx_?5A#RlsTJ`FS%E4jKb-)|u!_sEN^nvBly5pdTX)es$eF-}EK1v$FZP4!D&=#oB8Sn;j zs;sM{GcN+|RK#vh4dq@8TljB6Y^h<0-i;zm z#V3EK8Q7h2DtK7yrjKHfx30&n!>ZSF<=&x0Y$zv6A3*odDk~~_J41yQI=>0bgC^n# z1$(#P);ZB`(ibADtreo3pSiHfeUS<%4vmY314j7qPSxtdLk3xOISLRG!-eyvd?vqo zN)UH!7Y?FYs-esf=Bzc}V5UhZ{Duf<(faN{h-j#U%|6MyIW4fu1$N<`s04->c7@Mz zb0hW_d|HqvqP^S?NIA;pn>})EXNLVkgI>tJN!_Y6DlM>2AIyipsxwGRQ~&CRb18 zb1FYK&7vVwVgc^8`d9OO$AUD-T>vAF$u#j>sTCd+w0Z}iO ztvM01g4}`%bOXH+e)kE7yB-3Yr~$&fBB3PVn&xd1Lfv-Fu2xhgp41|2Q(*U4_-0s^ zo8Jo~h*XzeQhnL1&J*mY>OpTrC31G|Lq?YvYDH`s+Jc-rsmBeGN(Nzr70s!gEJmMw zHbKJJmMI$n@j4w_nmEZVd3F>P;rZPT2IrMh$NRlDi7$3#Hv+-BxtwU3w{5Qa_2E;L zZUqMUk~fJ`)6Mn1fbNpyeyx6c(8;#>OP8HQJ^nY4x0$6)SRq^(H@CTVQ+>iryWl_y zrlkJTyzZHBQg+uV3I7Dd$7?BHi`MIB$XDB{{zM*z=HVc?G9yQVu8XES|W?iPMD6%i4EC?a3x}1#X0AjmesJx4sjs@XR#X zODw^I1b`2XRc-`z0Vn>Rc?$>X#=8alfcEfgmXOb~04o?Knfg>+4mwlZ*p%7AO*oEh@6iBusEp{1o zeU#9`A-t}=a2fA)6a$myMdcC~lNBE}$h_W>b_*xtA?I%^o81DwYHi)&y}5)XRb-Zv<0 ztFm{U1^QrBXf|=-Jy7on#E#8ebc@wa{5K5+TWD!@^6J8^0>bjh_BcqsXK)pAL_*xq z%zUx^6OFSgO}KZUewk3{FjNKqq)NiQ2*_h@t109UOwplL_syf3DIzj%_<3d+P-nNS zZyUKGj%H|Y&buD?T-SqH*^^Smb`m_Nr2QQdrW2EfVPE)V=2G$1@ClyFwbo0yLc_D4dAsun4b2-e*i`5v#oCRCj zwBw{f&(04|qjfAHS(@0m_ery@ z(Y^(urbIdFI=Q^_D0E&D(w@W49{8>FD!Y`g&wDI6En$}|&+Zh^9lz(0oVcZu8O*cp z+r>yvFHP4dxXDf^-@wzg;vMCJ+oX2lQ-Rdvu>l=DoHz48nDF0{TKWsXYydgW!vmOy zRfT;0&Ckgt%wfhMAA(v3I^4isN?Tl^+~YEoQa5ltr&pLx|TOf~GeEz&roZ2r3gBUs2u?L?n@wOzM)oi@O z8p%~uq}@u^2`nyuJrYl9Gz$=c%b2Pfu@X7Ri)pCEXrdmpd?7Y zk+{iSLP7IdRQ}&04nbn00Nlg26~)O}^_&@?fGUrZjSp(5 z3LzsGO0#X>gQm#KjMCCtmhouL*r5q|x#Va02jeZ5W2HN#HBvd1CFCbCM&cz`U!WR^&tY zO!Ly1@CPG8_)AH3dyRUBg_aYMSU((+M;mPPG0chzVj=SoX7gmWDjC>l+f4=hwp@@` zFYe|7@FwWzv#IsX8m{Jfa1%<~oX@djN^*@gdJw8R1nrxKkZ){D!8agOBGiL;{Z)h5(tsl4hc0sM6qfW3RP&#g2vSaq>pzaiAB zh)9LbyCEhGBc_r})68#c#LIJFp!F}lvE7!Gu6ZS1O3nNILblUXG4Zxys@(Tn7urN_ zwt!ole^`rB8-B+;K0sMeU?S|{4(tF(jDB2 z!!|poA>OIzeME$8Y(X}*IXX!|tg{LWLn#GH>_}p~(g-#aI{Fo_q4LRLWnz8a&Q;Uqc{!s}@iYGRatJxgUE5oQXnSLluYuFX`a!P^PBP~oA z6|kd{wGgfunGq*;cyjo5&lc7DcxB+l2pknRsNDkh!Zw-kS*}FHaP&0uaOdvMpRsg!4-IRe16ozLdPnDAccVGB+2OLTr7!yo>=ih6v0^wwGSB zsfq`Q%G5+i+^qk=$UpH(o^vh+5iQp8Y%b^8Sk1k<;_KIe((9e0=|Qekq3jlD&s9kw zT=hu{bi8Hta9+ei!`S%Eao91=e?KYy@tp<4*u#9ftb7qUb&|XZr3?rRHtFv6~vCu7hX%Nkf3Z?<)c`+)bPX-Ad9 z`>b(+q~zUU9|SdA0?68vV)$wC&EUM-KT=93)>rsg)P&IlgzntKLNYOIY;WGT4*Fpz zefaR6W0FM4b64XNndBQ{_IJ|m`*iZ|!2v@;0i;)mq^8Cl-93k%HJiO?;jASWQ&UqH z@5)L(q2nDNQPTTF^B(&mmM=)|Kc)-)l=93x`iCDHRXlcUG`+dKOCPDr1L^@t#B0HS zGT!;##rRNFrfk14L~m*BhOD3{E7BKG2`6eIF%pDf+P~hPZyt%}*KBkt=Fn~UfTi(g z5N7+uU^aE1m-#l!op-O%h@C*9g^E!k zSeHy7r&Bn`?4jm!9}5fdS(=$fXlX@}(N~F7v`kw+7xdRHU_?)d)@4$$kgk26`x8d7 z80x&8o<>~=u=%wTLVpy+?;*t|WItWQwmF*S9GJT`8tn^fl?slJ*8A8W2DXnvj3nzW zIjwerSNoGPT-|uFBLDf@&#OPT4Xa2jUfvPwSWOIajb${VjZOO!baD;64jpxB(noT# zM2U}l>F(gkYL6Cas+4_u2i(77Y2j8shw1GG#crBjRoxK)uI1#sMxUnu}Rn_W9;g~Jno+neq$HEccq_d z1WZ|2IU*Jl=fuD9fYCd~#WLjfvby61Juaf-Cz!z1oqO4XxewoCb+7HBrwdfQ4_y{L?f`?6ebTgEs~-=0 zgo7Zq=;Q<>C=_xZVWwjvA!82V9f0}aAbd*5?trz>bZuNyh_oLo8*rH-=z-KbjBUV} z$Xj}5dXVaC74$BhF7CRn8sf&{438i8mvs^|MRnS0O@BMdX+L=K>h52ET5kp5*t|`k z-0IZzJyZX9VynhB#*@5Avs#4N8=f|+eyu8Ys z<@&W!zQzIs0`c>o8a*#6DqIb22uTjBZRWJ775l^xJtUqy*s_!m&%;1rz@%=S*tT4& z0WOrj8dqErTpBQ1V_t0tw)`--4Pb4Z%||d&PrNf?d*$1p+R?Oq((gp zYOp7KCjIXx3~w;)J32ZvjM2jPn~uXto@5ab0%EHw-bwsBsCJ`(U8&Y#<4hU1#EL?s zep-k_Fb1KVRqIx;8*O6OFTfi}X{;GtZk{_cb`M2yjnMh_gTVxxg;*W1U`RyQ+imSV zITaJIfkVkp>#NMh1?A1ZlipY3^}gI>P7<`ww8+&746J^t;bt)_XzY#l{ zg)AK@jIu)u8-PhBfr(*|%XFlXApoOPXUM?8(Z6NrT0zi>im216=(uCXCPct0Q5D58 z`N?jjfWD)dgIN(4rP8^uIkG;wZ;aoD%TfEtTw{<$sVOg(O{rglg7tCS2e;4YGN1nT zL&x{8niHpVf2Na$wLd^Q z*hTCgGimmEm|-6dQ?Lw@2#YH5Fr)5DQW4lD;>qevmJXgk&mOeiFLL^^q(xs~y%&g3aE^lY{@ReIG&h5}Jz%TAyxhMI`7V>kP~A^CNX7K7Tk@9mU7 z!)5yQ^b1BIlS?fS;ju#CO>=$wfV@7Z<{|1f03FE#dEa|lk-j=7TO*J^+**HlBT*`C#Y6j_Ws`AWN3-{D2zoqJSL?+XrjSJG@Jp+cX zT~FB9dS{(4fYA~JQ}#WI)TrzxX4dxOP1o9PBA22%Deo|eIK^F9OC(FK0{PuAzV+yz z6uAQwGp1m)qK|8^(}6i#mNZ70(J))Xsw!amGKEVqo%wHh5G2P}L!i0m?}t-rI}8>| zqs}g4)@eju&09qCb(!`nJI3x;l8EeAO!CQ3fN5roz`P7f>mf1+13Mtl8J&aS?ipxs z7jSFPr+<xG|DA5Ld=s46q0|i}WuzKJ)LAw)a2lUjS-5?2Z_hKE?l9AUW7I z?J?I0Nd$ zE$DtbVZK91_qU(>3jb=;mrhfYrqIa|+-yA9FTH35Siwoo~;7+`Wre z2kut6zw8Lg#k8V;r+*H?lF-q7R+6*FhI7rA>HBLj{gi9JIQvNki3QBs(2)zNQM#1^ zOtd(Bg~tEW6A<)juE@?WM9frhQE$+3S&LB=Eyp}WJ_iUwx*xsb5vb}tRnlAOx?d@{ zi=c}7A$6mMIhP_++Sq|4(XIPFTRcU&KbCmPLjEah!;pPsSMRXqu%Rf3347^WpoQo= z=_1tBZG4F>zT+1=+4M+IL0!{N_wJ}lX9+}m&XKi4f8tXudo zN+1$k_oVK1-fcf+d!KI^k0w4QNEO#qog?S7K7Ur;qCk$>R=nl6!8OtUw38MA%oG<7 znt(z~h>SkEMdzlu_x5tbw*toQn+9jgmyur9*{>8y?4gr`mTF{g9DAW%Vzq7S5r#!I$V z(7FiN&I_B5j8Jq&C><>O77=M*cto zM~)7!sz!u9PRsPT|4tPSkJ}p^>#Rw zeX~CpdiW(otO%VVr{#i@M(urXJQo*9UqZZ{1dEjP-+{&xf+qATEZ(O*VWrnkTayHA z^%5W}NHn5h$?3$|Uop%P6rQNHGu8^%DT^;`DzCRxBA56PAW7QkRiO8|djgutj?Opo57!2~S->y@&wJ8W6+=V4Oh_*Dqw@UJ zRDxV9k9uYp%=_|f8EMm8>oP_WmtY9id;Irj->3taZ@a;jwbN%$x_?YGel*ld_#|k& z)*FW>`?W4~vS$QtgoQ`1cv~8NDAm)|jIRSg=PTL7X8$yqAI@h8fG>t$-r3<2tbHUW zb$mhO86~9OhVJXyG4}VZJEoGopBG3&7qQZxzcR&kb6uJuV0jI z{4jyKg*naOL+1up8ejfiQfs)_NH&OtY%&f%oK=${4_G%;>}okCl)te&Bb55uIA|HT z4#HwNwa34rStEh09fP!H$C-SbXGkx}?|nc>M1-Qg5?Y_V7f^Vqd73SJoO&>bX&P+G z*bz~78Apm)&VH$qGeX}DPDTMh63pKmR@1dZc5Mun-$;D3|A5Ct73I3J?^kZy5E=PR zdB8Q7Q;9>1(>hvpMwhSU{0%MPu1L{EoqG_7D~p+(#$~U6WF@y01PHuLP6~$-UPI>M z7~eq3tGgUAyi5$Q?rmm>ncD8}EO|CtkI&6Yr6e-H0>7#2yhdgmBAjwoA%^TnRPb(d z4LhG628tAw)+j+Exh|i(ng~WjowHG|yB-w%V=62Z3DMout9N+Q4BaYebY(K!Avt@R zM&7VzT)B5|*^A6gDuwcM!-Gzg_d@l;2waXs-*xXm!RUM9M`u&KSRJ-(D(u4$3b#;smk zm*PeP_b(C~{zU{v7^ZL7dq%R}gK`Ap$qru36NzBFY7eX;s31%XR4{JWrxVm| zODHb2qC|h%4xF;0rQRt{rNk~GLPCz;zMG~fcS574({XLqcqtyvphWw+%fNH}KmAGL z^crv$rObe8TbpzoI;&4Itxhc59xpClNBY*a_Q$<-k@Id9zi$9L@FVD|8eQV(e&uQ! z!g1i={)FtP0hq^Fx}~f#JT6)0iMTjcucbpnV=lY88;m5|^}`De$JpbqLgV4#v9Obq zZUA#n(G0=(g?IF3M>e`Q?KBh?&kt9&)(T~!9^)C%`Q${HVjodGd`K^&KJfr+k2RL( z5reglOAY{rzo?1jzz)ds>Y}Nz9E9T-<3S1rza520lJ%TB+=b5C2YG##{@Ywmo+2a{Tm!7t|E&jL@M=ZH) zhUO&b0VCfuh#f@J&HOB6Y<%&}ei>L)+Jq=aew1A?iLJymMXpmg0JmMRk+soVy`TBKOK+V|G z%6@>rINdg@a!%Em%*!Ne?hQmDSfa6UqAc$VB-NR0|K6k8F3IMBh7cFB>ldHh4WA*B z&@`ck51(GDG;DLt6TP>s9-q4j<6Ef@efeG1&Z4IAC9UEtenTPs(c5{Up(>O=|cFVAC` zYH~6nWd>ZbtduiKZ{vF$M~7w)^hU~nw(!^~&McZ9#&<4-@Bj=Q(Hv?e>z zXOcdxi(_F(M?3fwrv@yCeoF+;d19h#>qn~WVT7r4k{^zc+kUOTeB?ti7#-&f^i))$ zGbyIahkML6FFHf8Kjt_7=0Z!0g{_)g8-wdpqH%#Ustyknv+;m$M`Pg#UN2$Qy1v{lU5k>YDG$%C ziPHUdA0+N_-P`|-xQsLftTBt#>P7EMIL;g6jBNY#aGu!-i}>It$Nc^QS1_Et^O=+2Nz(6@)cN0uWFWX(=P^v%B9TnY!1qH ze_8rv2~_|C5U?cE=`|8y>f0|Em{Y_$f(vJKQ%im-f)m4k+6;fusd@1+XAJN${a;=H zPF%6(EQas3Cmxg}aUF$(7Zkn>eTuR(LmmV_S2t}8dDc2Lzjw*tGhpw>Gu-*$OABT^ zYqwp_{+xFi7H?#T^$fJPSa<)JO=5)kiba)8{bXx)RN=KYjxUUz2RIIioB7r>fx*E1 zH(7dt39n>T@(|&e%WMc$0p3s(UnSbsr+w6iI0Efkpit_Uc))GuN>QKAxl$|T)>xK>4EkdyWH~1Jz&&T*PEOSDjCMUU0h@@XHzc&t2<&_t_ zLL^0*HU(ca4qBB)m_T$VepDnq-&@;JhWW8I?-7nrz4kyx-*-{>g{N)flRp0rPDr1OdJYP?HSNsXBD-O~d&JkDBqg_SLeU z)ZEzA-o1joqxXb&Dbf-k zK9huo5Yu~G(R*jQc0nUkd&z^LuSRdf-A5J2b{Sw-N(+ z`-i;r4_TWLKYdIW#Xk>Z4&0HxS!43zSqagWdqls_LYYb}qr*Cy^VAkwAM*o@gk7!Q zuKnY@t?ML%;(HW^{|IOI{UG6E3K=>Ez#4VmZ{A+NmqmxBUh6nPvw3=6c{haI+@4XE zIL21WlZ}L32U5epxt=Y6bC2vGj(J+@a}k~U0pbmoHI-ft&!8Wym&zeJ2xBb7!c5|(5>H&P0II};e?}FpK$>9 z@6-d`9WU8{CVZLzrF1 zQ8)_~Q#Fp#y?EXXhX3?3#cr3KrTf#Oerrem(M;Lz&VcSyevjQZ2@@KXwcdq)h7aL; z%1t`tNcxM5MO9U;M5xom7@VCFxZV=2uqZXmX2gFN{Xb2Nu3VZ7UByyqtq zqCoxKazBkw_1Uy_;wT=tLz{w{hQYUA0?5_+Rn(e>7wIA&ig!l&W3H7C2nZRijt#LR)n4cIJ)u-XTk%G7A%!nn+l)==(p4DF(YKluJ=c$_=mIuSl$$&q%C_^!>QsA5$q0wYJ=~osG#U_#W1^juIXA0%b&>6go^ZJR^ zogNj|@E0B@NV~{U>+#7cA$cUR(RVB&w5We+UWSd3&t#8`(0Lzs3sTW?do?)Obt@Hy zr)J-z)88@_1ZaLZjh0Xk0k^F%C1i3r)HquvF zfmig2MvHx6(L$AOSrL}bo=%2xrIvBNYF35x@3fb`H-GQf{e$&A1;|{<35+~Vi#SDn zhMgX`XD5$kXY=$BlBj&p>=Ufp|Fkn*r#a50fbtuPp+oZvx#YC@aHuQ)F4_<)*l2&8 z8ZTbpBhN}R3?ART@mQ?^5yojb-sh9%{dV{A>a~=s+WY_a_AK)bnP4|?b6|W?(JGqv#sqp3B+OHv06b-vz%DZGDX;* z{)hPagg$)RKjX$Am&Va=4-uiM`FOT5qiw?%|HOU`Z*PiOr4#kI+Qy1Se!AA>zCmrI zQtevUFc_<&3TLM1OP53KNhcxNPfu&N7e?jMXpVv;1b1}!;7;z16C)LaWs!F<4?8Pi zP3)=`s_ICDkDa`j7YbtTb4IOP_!bSB@yvGQwN$ba4;>adKS&yW4X&>C;xa#I{X%_d zapRbZXI`!%4rgqmB<$_+ya8HyIs1FA%$SpQksTlbzpkd{zDQx!P>M4tfRX8FOU+(uVdl zgw3ojXUpa!jOJ^qZjHfPr`PZOC(gDL%%?47(;5CACFi}IQ~ZDx+n7<&ggRZ19%-N6 zDf!wLL)R|6KC-?Lc`B=(r+c4Msz2=`O@;Raw>BdT&-K@|kJqZHaz@b2y-}9#viFYu z=)AYj&Fg%4xQzDdhdQ9+7_f;sSTN7_WB%+4bsz8hSgo0y)o>ooHut<9q&TJQ6|+>! zHw2B4#HiibrnhPPZngF7&G(vEboab|ObZCGbU%H2kbn-d2|@RsA5QGyCg1ufFO$$2 zRoT}jrydP+jnbfiV3LZfI`RKNb1sU2Z`4F=6necOn{?b|^aie)puLvid)>?yScT22 z)}PGXzR(1RUojK;$dz052t}MG=-yZ zS`;07A-%@E_ti0Fj>84Ck*G;PRnvYTXU5t9#$iF;f8=-^i4L+s(^+YuM+NGl_Db)3 zka@Uh?w7;vG{0Mwp~nmF)v~IsNllAUOBM(`rs+dctzW1$zV1FV4h5=u)MB(F zgASN2{b;2IPsedP;@Wjr)c&Z7zIT!Xa~WR~(_$iz<8=GG4r&oTB>TN7p-B>Z`O(W=bu4Zwn>Uz!kIEwT z8x)ztV?J-NI8Jc4fW^aLXJEXud%Jky->^&^ZWk{!sruFB%>s1=w9CbOxS<&5$}Dg4 zCsC<4BKw=D_v3ay9J+n2mY_GNq}qG3DFeF2URGeAeDW6p9ed4N|GSb0uDh3<6)r1k z+aG(Dd3v>^B$uA{MNs~=qYwVk{PqPW_=SQwfweK@rC?;xo3BCETD`c=mhbkO+^ECr zXWoX;t@Mr+9{urG>}?f6et1^a?aL^;V>34U=4i~)pR=@-Od)1yh`@4zmJ&RbKikTa zJJ+{QHTaFy#O5xjYp!1Wp(H(6Z|XLy>Q zF(2Ol4@usd5g|fdWDP_QrV7A#81FrTTeEi~_Nh79D zyw_Aiw) zU)=(*6F$?gNhzO7G03qn5q(6uwkq#G)*JM%!+JM~y5cY%>d@`^fe$|qmHbI8|8Rh-TgHAUP`We$7WXIhrOW`;3#xF` z!RFJX>lw*4b$|-p_Pe6+x~|J5#Dm20cohhTfTteLb$^n%Pze51vvVa{ z;)ED2*J(=iK@#0cdqP?aW2I@qGmBAM7Jq5)?MN`-iziqo0UqV&?W5G(4WdJ9!@2)# zu{WNLOP*pp{_0}HhsT#E$r2BgITfdXcHd{4En9XZ6#bZzz$(%t=ih4Xw`u1N zCKLd`id)OpVZ9$34Msn=aHH)6FLVWXAL~#ESarRJZk5_cGX&GLSpWjEp@;s+2}E1I=3< zLy-jS%2J&9I^|ZEj}6TJUUYVw+$Ozpx_0jy9YLs`W{HL{|CF#`xX3XoMY+^ig*{RC z|AQ+#X7wnl;Aee2f()_uwsyrTKIqt0JKMq>*%8q5<#YHumV3-x!w>Hi-<{q0-z zCN}!#bnLt3Q72kNA4qV-7eYv3mQ>oN3AVsdbaIn)S}{tlO7GN{H>?~<1 z8wG4*#G7H|SE4A#BFUe1dh;FFv8}iOVcd_*jd>Lb>=qbgu>BIE%M76& z6$pMP&{KK+T4J<@8=V}CI>!iwawo}8_zV%4kCj)}7kUG(>Hj#N_8+(|p!_SW#@y>8 zU6tM_*L<)CpwqesCRTbDbtLy67Ay01u`21%&VH3bZqweC{M_qXB;5?5{y3*#{?O>h zaHpg0er3GarrjB}gJO%Q8r7tr+ew|U2hur1dT<>UT>}+Vs1p3P=uZuJhJT`zB3}{Q zKG1z^--O8g+Xq_0^8-&nsm2i_kmfo1&fuWiHe2dCXk7I9|L=qi4JA4F5|eBE?;bi& z{L1pb_YfZ`&mhxZ>snt9FcgJ@>lX?OLaCcv9R)WyC%c$2L^NMSJ5y%AiS+&9*r^y@ zPU~Zwde+lH%gEdCxjG{34CXFggK8GPh`Zfl7v2Hw_K@4ww`FE%1p3|Ey7h;hX+cuL zD-$q-eYT@g;jrY1AtKECPD(zBzW!LyyGKr3>Q6JX+ZqU^&0D|H%cK{usMy#ied^Yc z)-;OyQBu8xD4IfrUBwz1{UX1o996_NsqwX^2SLwOQn-&Gh8E zJ~y<9dt?;RBNy+JfyIjq5!1cLzUjALafs|8_tWnCM$g4NE9xuP#JEptSwv4eg@*SK zHskPmAbR*ewg#MiEi47vUC?q<{sN8j9N~O0_0s&awF}1buL?< zHQ26Po8<93h#1W$nyXy5}lChVx@N zD2mlra^HRCd9}U+qLr!5>lW?a+CwbF@4>Gzji(Au9q11;zt(-#XUx)!X@JWIlw$<^ zXt_bLtKwufY^LyY18XP-WV9J4xt36s@+no zc#6z_oFeTAFvwjrW|@4gZmngkG&cGjg6^Xi(lJ1M?0tcJv2k40Lq!!blTY|jlA!^ z2H>E%AfyqCJW{y1ZCUC|V4Z5Iur;BA%?=;da}`4)3UQGdm;j;MKkK9d2TVnUh8ue= z-g9)I5;$(}yqDo3J8X6(3n0MxM-JG=b*S5p2H%fM^VD;w6`C_$K(p3h2pL%EH!s0r zxi1s2k$b?X-5`lZ%v*pN!iaAY!nP}``3dGuI;Q+8Qdq~+-}87!$}bS5ZklZ)Px&@T zxkyK%B`-CRTp?n~3Xx5a_*6!{AOD9ah@7MmbRf?1s}WBgX%y=*|G+6OD{1ihusND% z#AlK9e?;$h|3>WMMjy>@<2EWx+c4WssQ_RT(mq=3qG-OD|9;*11RgPov`v}P_NUD| zYQ-mR9lEOh_v7VQqb&mh>M7PuBr$Uy3uXY0!x_?#SqhF!atcr8)7)W+UTe^HX_B9H zK1vg%d=qqXHb5oIkFjcp*-Hpcm0rS)&O#Jo7(5JPLV*O*XlKh(HY~Lll9Gy9Ypg~N z&lO{am)zw8_iSIfxV4u_8S?&Gt6OMOmYfMo%ySG3Q_j}m$yctdxvC7dtG=Dv#yDLo zW7Z{-nXrK#A3>}l@p?dR#XXdjA1nf9==92_(XOS{zRla8NxtzDUO5&WZ7)l}(4}NE z5xxRA^o0;H*-5uJu}(2|ao)R}1ldoI4!Rz<1-^>GfD3Gu1#oj2!cCZ<+>Iz$94!VWxmqd0l5luh zxUvnEKy9`m_5=J#@oM8s?U@>fQr3qy`Ytb>j6a={stop#- zpp+?J{fD}8wOyq_L!+D>BZ&6H0DmS3IaTyh$c-VCFZfeueFGzvT__~%ab$^tW^3W+TE~P-&D7ImIas%&v-n}i`IK% z#Xw<`rd~&rQO2hzbGXhp5%^d8E&h<1P;m*W6Z}OQk zjMTQL3B-d*eTtupNha_**Xb2NOGj`Ou4 zyrPS}W9-`6{WLDA4Df`$H55V?P>mNP762zh&1K~99Ts>%-Bp3X>}NL3s<*GKGV0zx zeu8AZ8WMs)tDGBx-wC2QMztjeT%ZQU{ssZF7X{7{neDsXJm7taVi6D&@(%EFe}cs! zAt}Y5NlC$-Al{L}vHJc=EO^`)ezYq*3(aM{7lX%8(@M05oR?SI0uru3IJ-d8A(Ozg zf_zAeLQPs48yoBGMFxC>xLkmaZ}Up8CfGU~DWI9qZ-KO zbxD-t0U$(Ok3XvBvYMf#pR}xEDty(1ubiVzWg#R$0GcjT-wyx=rivFT(fiqykH7^e z8q=6mS59Wf7PoB1=FG+(_kH6wyAg|0@LZz_1m)g6U8cZ%i!aZ3qkuQ=o4q;6PB+35 z@W}lb#9DRY3f!yvPk&Kdd`@Gog1n8ENuc>OyPyhty-f-i3e0+y;|t%qu=3<~7_J@w z-OhLII-ow>M>D8zun)H*%JLD&QzG1IIpZXgJC_{l+* zfcmmq6vmJGy29T!TK3YIA}wuN zkjNB3q(JK=iPQR#q!p+(hHm`gMF8H86E3%iJ|^t*25JTt)_^v36s4W?vNB-s8Rm)2 zs72dy$NCN3e?10rg{tZwbC!hF5v~-|1_4_hsV3sh@eeqy@^={kZH;TQL6iE)21X(K z(Loj{GV9Of+>TK_6^4Z0p>CqFlzg-(LekI3YSm06>un8YY!Gis`66=v>~fq(J@AAz zH}a06yTH+FA^J&R8@~DOKKmLhqg=^qri^SB&jeCx)O){ecCi?{>E0ubZ%#O#WJ;|b z=-q%{LZ;>tiKrg&Bl~a{-waK40d@QuFhe$7PSQn*Mt=^n>@gkER{1n6R+15m>9${& zl$S;U&G%$3Moov)ms_wEc zU}KQb8#$ky)76P?$w&pa;o}kqoiOwNYr^W>kIoMJM_sT-Ip%bIYJJY>+2?doCS5U& zQnoU992D--* z?eeXh?q)YFLe%dA_<`b%9Q=plt7sTj@UN4*k3R;^q)Bt2kq=GV`VTN{|2#01 z%R~=B5x)@VVz1Ztg(I_Bo{r z(xP#tVEQ&3oG{o()*z0B!}9}0k^bXXLSGBro9}a!KdXk4LPYic3UZAF050Zeo%K^j zO(hD%7jS8PF}_)dji;Nz_UH3%Ysg)X>@RdPZqo5{p8E|#!MmjdvcI<4<9*rpiFtuF z#c48ALtGv>h{LC8t>bve8^j$qcEwp!*tIx$M`xv1(6^=wli=SV$19KW2fDGSp~?4 ziwB(MGmWn{>s|F|5#d5wHSTZqYOI$Ssp!>WKkFVMeOEKSGp6nBy)o$}j1e}aim}}e zX}nlrak>;Z+M$lbA0H~x>KmVGdb@)^Q|{5yFXnf1i6V>VlxKXBBA4-{$o3>vBBtDC z3XN8;AYz>@=?khP2q0OKkV-@0q#l52TlV^W@4_%wpk64_?Jq&Uet|ePF)L)1wY_su zz4;TTF!L#G@Ar<>{1{&$M9cXqc}edd@iN)>Dowef^`m!kQFigdNuG{ty!Z>bwAF(RbYNJIk(M^RuMwoo+H~@x0pLD$ud0vSRA8`I?eAFm2-o1jcRN z;;|yWr8vIM8Z&8IeMZ+59n?tf=6{CFZY7+8j+pD`>qTC=k#YaL+=M=Nh2fDMHGnPI zF%IJ&Aa0W%uQ6kpT=rLEV#cWmUN58S_OTHGyRXCOWZ|w?CHeMzmkpgk5crqPhvB%ljOExV*1(4c#Vz9rbL{EU5ELxyhx@FPR zeci;%vA&Y2<4%W*M7MJMDpk;;+=+IgAR(C=wLT#NUVKfG1%Zu8ua49riGi)ikb$KW zH+*BZ+G2-XDNmiK!(I{@{39F6q|Ttbbwvk_X~_Fr!IXH)gC|cP%f$1qCnZ(5=9w{r zc7=@htx*BFYU4Zj{E?DCGi{U=VerdPK-N!AVtIeY;j|AYXJh&#K92r{s-E|XbSM*M zYW`_!IF+9;X3EtR|E0wwj1!_7{)^aIu4>fv4debQ@Wdo^b%#^?$;mHw_Nkn%nB}a` z*Z)v16ZXdYb%TXTtWKk{MN6-HW4HD`G~ef2a-noz{Lw~#LX2tTp3LEVeT6dTdqHNu zr^c4rmCB6Lrx&Y%_N%|jRkaqBASD2G<(y#oRBum(%$~MD`7@0(dEV_b7k@GNG1vg9 zG=FaZk<)vE2q)k-9I-L%j5qMHEwNOq z2i>G9UI+j2)qCQYVB}oV4p>rR02&_C`k8cNQf=S2_G8S$UM!NK?oFMV<3}*8!3||V zNFA^la6;IZ--Js_S5p5(S&?gtcsYbSDlS}0N?|>0Ef!F&q}4eM@p@e_g-i5WF0Hyn zLfdhh2B0V#yNUD_uA7cpY!%>kN)O?yNZNK{^f zZ{#W)we_bA>U#lKQBArAg#Xw)$D=E}wumKIUJj)z7nnW^Wm1tjeTkhE^Bw)D&-6We zDG@&d@|SOkUwaYUKHcZckoF9cBN{8f+~X$`k@!fhVxdW=pFrMy``Ok{Krj{W;o;bq zj<=>3FYJq$&hMms$LF5jNpL`>bI9+O=Xv0c`MRbtKtfVF3jLfynLhj1Px^?T%gIvk zVo$HP#azB%C-gvf4$=j1pnYDu z&u6Qos|9e3er3t>>1|TTXptKaFC5;MLY6WN3WIEgch{(@$Yy`yYy9eWjEsEq)M|U< zE(GVcp6Lu9*j2E4FDP^5j(YId zUx_P~pCw~2i`~uH9;H^ps*OW(i#g@@(;7~hnAq-R6iFCLba6P4aFV*rFN)w#t|fmG zQDtaMkds;#U6l|Kdb1GpE%kU8)}s$KjY|apzIyN~0Hy6!fJ4GTi|4axQQIAFAmcOP z8{2%A9YF*+&)@68^!S!Go_J~^YdU*loP>N)OKKEs*!Sk_<&mtYPDLWCi%!9m1!?5# z>cq_;bPCE0@+n3OjR63*qVD1ONGpSEOPc0B_^O4bnD0{WBM=KNn0AW+L+uMr9|TfQ zYEa<&&k+=31we+Amh7bluUfD#D0AM#HwH-8G*OJko|tlR#8L(EXz_x_Xi$uloLq+v zUq8oX&$IF=o%q;r>X&ubyfy`c+ipflp*M-3K*%@E%<;CQRN>aW!WtF6TttPm5goI) z9gZAzFIbH(Dc)L_SE||5tS7n6v*ncsq1I3KM$Ke5NU<9P(jRND7i z5wI4hdVYWaToNDW2mo)fK1^efd=LM<^^q_#qSwy`) zsM*OsM+Lp_X4h*qt){nrVhw@q?THAm197=El%XBcdi#X)EsE-lDfIL>L-BP2Q82Uq zf$hfIHds_IUL@nNLIgqHGo`aF3zm^9^h9k&afSbV<1^9VzGq4YQ;q(+qy666z!G`^ z=X}6JI-pUUESp^V)q;tbfRT%{fMUh4>euF;=vgulm&*%3)$DObOMYFWY(mxjcDf+) zDWiJ(N{Wy(ldhcVB%3;(I{Rd)&Sp%fuZvKOcH{@%Una&tkT~M|T0OXnJD_|JB(%e3 z{paItp`-hs8~!Vd`S*^|DdD1s`N-(iZ4xNDnRWj2xPpqmh<%{e8ru!f9B8<+!DCy- ztBt{bVMB}hx+a#|ico^UT2ZRUFXJ_5U%}-M46Pa8-B3M z2jLF`jQ2b6MnWM44k%8Y4yUQ*>%Gl;$B}EdS2KD#sSx+vrdhQk?Xk;ErAX3H8X59k8lAMXhWydf zmb?LtgjBsdlY_O&tv!|Mr;&L4uJPk zjj=b8>5W9SkOkUb^BJP|FVMeJ_4+=@w*G-#Vch*f>(`W{bffLi!NdkY=J0FZQE=h4 zM-c3CN?{!Cr;b%vPU;6C7=?8n%*3zOE#!24tL=}pnv<1!`?UiTI0H@7+I;{6Mi0op z6!ghVKfq4;pV2`tg6>0;aVt)Lj;a3!ULXglqq04lM${^I&mm;>UI`PIkXn1hK}F5m zf55{Z!}~D9KceKxc?FZ{VnS#|C%W4Hbk)eILp27`>%p>=kyoMY=Lhp-$e$HsC&IDo zkltNBV^-7FcG)cmzzsxtNpoMkcMrO}$vXj;#&2I7)FJj&X9wy3i{T5GL8n(!#((Pf z^!`1gF-$PYO!}M*CYI=$gTBbDMYQ9kuXW$eE3xXHu-LNs2_v$}-Fej7#Mi4(_r3vv z83+M)4km2IYPbgEYn_q`s`ox~XZc4wmD+~Ro;-Bn$RnlAQ2zI^MxcYv9>7K3{GPGD zFGgkm-Gv2mjQ8{3|qFU;V#VG5E<289I)SlzQnL z!*hj9^)G?X7z{KAzEXn-PEPT~3~v#WNH@`wv$(m)mZ~~fh)Z9@NlPzz$Gadtjaq5; z`s(X@>1Q~TEIJvWG)_-<2G(mY8Z?JR%NykXO0+2vwze_#9w)}MYn;?U1TfcJ2G+BD;y{gQphry44krR^o-mXjq3=8!%P#WgjnR?V zT(SPtjQ(2r#yl{9+YwnF(D%@Y7OO5MohOn?t^k?A^m{!t6|!L3`3ZoQrcT^U09Zgv zMgJx+{|=Td^s}b4Y{UN-v4AujLlfd1UbIj*(XW=j%Bl=8RinixGQYH=NcCkBd6a~| zb7fHKXmpWif~?=Q#svG+xQ;^12Yh>B=mY$ns`c!5OjJPuEmIlgvk(7|X^M$N=)_ZJ zGhke+Gvt6}0!{qNUnHN2rM!}`$4_G4j)RspKJfVgSishp0sMV4v~+Zo$|m_|gpS39 zKL9_q%OCcjhpg`dSLstaRVh(1F#+8Vicu8uxw;>PAJS@;eXQ|IQu(6L2L-{8J|H2m4!n-&bQ8+aT!3j256B&4T7bj`v=Bkm z*Pkbw47U-^78w!}qf>8hF3mMUqcJ~RAJKq?ON3R;}Z>Ni=+| z^(%mU6>E587EJ)!XbGP^%gc=C&BVLEyDlXKm|1RNAzG>v7cH%{0DDRIo=!CAzE3;QF04S_HTum*4cHvwA z3~GyQ)+57dYM>@fSj-fj$Srp^tbQ=gW5IJ`}c0Z7FK33Pac=Nb2istX*~gHj|% z84bJNtMGmpUk$=z;;G2ZE@XKlV-MX7dg*KBBGkAJ-tgQ5WKS;O8q9Z_C@E0js2sM8 zQrqbj1AT#KsQ?MPH~=kital-Tx!`-;(wXBXzx?XeuSdukI_#4JbW;-FqmHjrv zG)b_M%Sk{9+PKM~ZZfW$;brO&h2VrUjG}8Kxv8o4anZ$)@0+APO8+UfD7q#nQW zFx%28N{xumS?-(AF6j4(ir@`!R@x$r^(vy{8`rIZ2k<6Xs;^+P-o6dTW-PEm7ZMcI zb7E4m3wuhNU93`Rvn0roN=QUhZ2d;}$yaD^4-x?uR?g_eNN-L%x$X@%z|lE`7hlZo z2t1Bl1WLRU=FqA@M$cLIioB~_+%k}kdpuP4#fkd`46tKU&fpp+djSWabtZh67w*v2 z^s<4MqwWjnocjTT8UtW;&@Mm~5fT}x7B9xT%f#Dn3VN8{{&M7&^IgG1>}l8&S_R93 zH`iiR5HvpRGEoP`XpHOY5}kpjB(NliB#A^xUIw#+{y;@nQ-kl4!5!fmKxN?E8HX8k zCX=Xxs)mOR^H4Tr@cvOPz|a2x!{@Hu^bvosGAHgcq;6J zhIY_c;-WC6vDRec4u>~aO8_I8v-s&&3{uzu1PB5!wjsNqVV!d8?)F-(e)U#y>bj(9 zIO66_`>Wvh(~piaarGsa)TTgzt7gRPk^b3)6Qa_0v!Dm?x9Vr9y47TN%ht_DM=pE4M#^-wcaW@{W;Bd8h6u`t6y8K+Ey)OaY-W)E7 zm>K`}z2oG<0>q{8$+2TJd(L5Yi=UgiE|?3qbq$XNj#+@V8{WyAK`bV9=R3d#1Ab5r zz+lq&uiU+a#9|#q(K+TS8GZ}Su7y?IF|Sg370aY2 zbL=}h5i9zbh>MkXd;9yg3=Wnu`pacv$;(~*vjC|F7wp7OUGYZLf?;%BMntCay-|!8 zx|Z2M+i0i*xDQY`%D-L=lAw4p1g-PzbjafHzG%>E-gnaY5{Ob&|Fs2F_$p-=x{wiP zbr+m2wnuXOot0b`)G}U*#rQdEXj})I&p zT2mg+cbU2;SwH*QvFYwSYB&_7`B-?1?6@G2x{8-?F-QYe=m%2R3>rDYkFgUI-?K+L zz6A*J<2tFS=Y}_u>!PG>zgs@o*)1rN!iq2GrSI3AB8^RD;_lcfC^~n1RnoxQCxzqL z#)H07ahMHvvj=lI*bDlMsq%lMVt{(@7W`d>3dG|8fA(7Eq4^OwpX!2HH3QByTp%AZ zW<9_HHotRud*6ybyiv4h_DFtQcU@zP9d;PWcJg*mSTL5Up9B4XY4H~3WHA-=4OeD; zf*fAupnbAV8A#D-NWb~%1@gxrnw%i1&rjxo9ez7ZaoL1J6g$ zCOGH)*&K0PEL2uWz;2n-sj-@vM>m@%&#<;S;*1!A1--dhK^YXu z$E2x9K4zumbs#Iivj0cu2S7R?dqn@C<{*xU??O6`jK+V!3gt$PrN~5;trJfo`;6ge z%L~mDwCeMO8=qG3fB+WVj0K4elp)E`4O_{()r^E$ic0{?D^IouO(y--iv}re#UF0m zivAIReb6_auTt#j^K0dC8;|1-g>clNn+c#ec;NE`n$Pb9Cx#dV#<{`R9lzu8zi-u8 z3+BskdOSd=`i2&+HvqUrpS3ZNz*1zI5F1DJhM}dX4p94SWH>b8@RFHyYs7J7HHwCm zHpx*`Msy=LQFYwALYW*HQ=vMmedJ)dqcr5f5)M}<9BdTf#(M*UdCG`w=(H=yK)tw?xZvT5P8<0 zs4Sbdt@BPA$J+;yO(Bb$diZSnok@;U57X#n^JA)lw^wjXucz)A#UAk+b&VC9F@rdm z*+PhsAeo68UXL|9@l^E5D-f}SpiPt1R<0beultz1nz z(f`cD?+F3);g|=Lyun=&L_u8<6fYGu;mDDL@di>8)Y~IG-F|4^rFwPf`=i*p`LvEz znA~b3zbaSG%X4pfq@3eT0ctk&8(FiGfbRpTwT|_fEQ*ONRPR6c;pC?LacL7z$xlAo z#!SKIhi%M%e>!*C(`k;^Cz>|owGn8Rd(q*Z1P_`lDCBXz2~#dZDT0k~J!5~5cz{33 zBHaJHYszK6)=aOHceL@aC&5KA^$r`#>g-{7N$g=b^mHqR@Wn={b{!xMMl@=U73%R` z!<5b20s=aOfM>m4vOb1To%oU;76}`X}--GRhZfKnj&I`D9Sx8`%P&0m-!a(`IcfBC(OOqoquQT9_lePpTKvxwGy`>no~d3>wfU3F{GCQ(al3AR ztw<}kQ0&hm1*s$@=jV_F1`LX02m{Q2wE(7vETNK_Whs0n*%6ofVzrup*u*%o$CWS} zi7%Tod5~*B))RUOdJbxebQvv@nd2wIH~UT~Ue14>x;y9Fxcidj&o&umZM7C z=$9%_frc6&<+pAtZ)ayWS~&G{!zxD4)wRwOD6z4*pS_&{R!~TQJmqFSk{uXU2m}Vy z313DNCtfW1=$j5_TIreigVx$jUV zkBAN01C_9TV0<)wBItGX)l0(_zBUY|2SndUv{o9_ihF~;VJ0=0O_NPOwrtDhTC{j%w4&E%~Ptc!l2xjJzI zENNb8*IF}DNJgNqTY;Tt((SoIdJG^S0rou5QAq@1tva6-GU$MsqDD^`HX|J>0cQem zqU|rPT`af(>}cPQ#{1LdbV38k%(bWQuk-Yp+((PF*r7Wa6(yy3SK&1<*mJ}(bN};T zkXFUCefZ6T`#WtTyj4b$bgth0+GiK3^3+3ZcX%2xw#TI|=VGRYAfcVVfEBDZ@s zpyjy5Fpmsuw`w<5HyHvBvy9Opy)^kFW#une1MoQTUnsADrcz46X`9Y^;jSi+Iqce# z&B0i)T@D*_hWJs@wAz*~tGWn6gj~|KK5y8KQmr4OPM0oD2b8g~fhK!385OpDr;ZtX zUhUD!dG@Eq-VF*bU`n;CWk}h4)lgi}U_xnCKKB9>T$A}aJ37s1Vu5vFC1A(Bv6bbM zRb*7CkV|KYL^tu zFT1s39+F9cC{4H9+#P6CiF8MkFoPtm^6+7Z0I9p3Ga@3Q3?Wd}Bi|B3y9SFFbDlj< zCei+Q3fhc>)-U&0#|9zdchMkIJu2x0plmIJ zE1QDV%R?hMvEAl$y$^Kmg~8$-YnB=K8JsRUqT>sv zFYgQ9o~gJU)^8Cuma9q<;|!+(aXanin^W0m*mlDoTy$I4q+?F@D~IU{$61}o5IFbAI0VJbj@k<)7St1T@I9J=lT6fh(t$q-*9X%8TCroF2oWTG_Vg0iH!>e9a0@GYa^|g#&8(Z+ zzBEIjQKB?c;~iRA+vCNs<4YyIFDq@p6AT=xG#GK>gnYbB5Mi)3HD%gofHaw5cc_U1 zFxw+H=}(9Sd2inUa|?r}X?x=PkcaWNR5A%l*hFOkh)MMI@je-(;-6 zSqo=wR#KNA6hp6Z1V(@JYArM`HTPH+fFE0Sl2#ig6}o0CXu6;-dt=CJ_AqqE2FEzX z8~wDk0x?NI4EzD7`1REM&pPAKXDo@4AP|+QH2qeD4*M7_flMq&^Ll!^-r-Ay`y2N+ zGjXg&-BM^q(qv}A9`Gh6yz38(4u-U1M#>DusB&$c6jvG_6T1on{Q(OJKPo*^d_T>O z!xFuw0)|}S`8O^@{t>ykl!zReE1w;lqE~S{rGVIN%^}|WH6W9^q}s4E=|j=Ke|nyN z$B+B~RPJD>2>KHq{XKVnC>T-=&hqC3?GXVTFE`fv*zI@E@ai2e!+N+6CSTZZ3{jz5 zuMZIwc(Xo4XbZXwH~RF6Oi%F;{yk|2n({g$>XOtJ;O^<8QK#naBep{H~@`;rv)eM?nFLqOSJ6uDfQ+h z)a$YO2H{4%RFAPNY`Nc1v=IQ$Xe+w%&K?!}#~^Bu`j*B~OsQOH`mn77Sm2oicCis< zd7g$=+bp$q@-vX7K>g#Di!@msrk=L|Ip+jupi`&Ac>53;t#-lr1Meb`5N{i$wJqbV z09s6-g%B1Qt!(|lV~oc|lG73hncQh7b=UGzQc9DGgH*g_^8;1pV}zYZ++3`zBP+88 ztXO_G7Ri;EKBh7U?C@OKePW8 z_yCUK8~@5js4?Bi8jLLN=j-j9XsBNNW=Y4<&e#{AG0WHw1WY`YAYp&B;H0&qGOR zhQ`sBHuj4n0gvu8Z*_rGWI>`%*X}Y7(8c?)I+V#vD{Fdda`P<)6h6}yl^a#f^OtU@ z^T(>{RU66j%36`Wx={czUIee*g=s-~p2G`co1KgC95h3h!&wTKg}K*5=|3$q)<=Sm z;*<5IKK$yC18V>5n8d`^hcZB?lrSl`3~ic|({g&5#ryyn)Ip+L_se@M^L3U2oKP4X z3>y%!s1X=w>g>y+Mj9`Fn&^}IwyrlZ6D1vf)hy3`mRGqA>mLghq9qFEh82C_z?1Up zmn$vsAapteel=f`9{Tl&JrST>^1d#1LLmT6Dy>&yb2U~bKm&$OL9^T!otl?-mMrq@ zP#6Kj2utf*2A_sjYFUpFj`7DLCDX%saI<+p{&I5VsO4VI;1dN07Z7{gnX4^*)~OZa z2U{npQuT0U5cEU9VYB#u0}{`2S=CZVPkWi+BU@lDf5G~@ds;33Vy*+uoexaQdee1Nbbp!?!DzrrNlC`~`wKk{L$Yqy z-5Cwz>!Ag6-isD}Z<>QSZl<-Boz6%CE?xv|Qp)YAQvHH2x@<{z<*yZw14%pF^3ks0 zx%Jm3i(i9)jP9It@*K1gz{MYZ{t*l`3pKtfi8voAFeNYf-0L1T{!n0-4mJW}v>F5N zQGiA`QBMUSI8|Dn)wuuMP11y24Tri>@CHRjAh7MfdD2-8poq3nvK=STqk*ki=j-~| z2R(QC#~uh{_J34*THXkCu;mgzoHv7{{j=Jc;IW7`h^CW z@`>QDkFEH~+^zVMEOnqs7g2I-loEBryxlXPA$bp-;SUjpWu9IfYxh0=Hmm`SXn_CYij_&gOMfe|QTBZML! z;qi{{%)UktJ9xdBRylXEQP9IQz3k_(KN6dIULcTBYk8*{O6%^G`bcrb&Jz^;M?cFG z&~HPPcz~SxWHSU664QzU)xpMYqvM)S*oMp#|E|Bt7sQ;LhTDH%_y&0I8MXs`e?P{06MaP1^k7`?KMS z;$7`C;qdf*ZmaoEdnv4Q@Ls%)X}sM0FnI#bJ-j3`B+cs*&h(jjOym6ph=yHsc(}u} zK;9s>2B3eF3ldDGj_qSP`Iv`=@}Z$P0yPpqnlwR~>P?<;C~g?L<5T>x-^WSs8ML^3 zCee%X_jvxkhNJh(3Catv`z6+Y8c5q-cV1fF9P&7sPva|;uiw5BNLi#Lg81zjdA+C@ zl}3pUCO-aYi;&UM^w6_+SAjB8QVLI4Awq;jvPpF**0PT zy_4c5lv|n^B(XFsHkc?9Aw6Kz&9wIv0mDNyN4#O z@*gbb2s!h~^13lG&VbF$T82S2~)OzVPAmOtodJo)0tC>fsq& z7Mzkvbua6I_gpV3*E}h@=F{$H8Zi$=20V_MzT|XP&`G@%Nq5kC3bddCV&men2Oex} zd;?Brnv0%4^_kE=>mr3KwUwOCs#n=XyZMo~oaaFlk|8$3Kxz?J8SxnlVOIf?mnK;jh~ zo`hBj+)j$1R|5(W@3_KfwnTU?fH%%T5_Px$82~a?XDhZ(ja$QDJD(+07QK!j7SIL> zWoc8nr%XJx{26Bvi?Gf^Ge)9QU=7trVAJ^N7C5%KxoxJJoz?tkX-8rM>iCoyyiOI# zDm&BVIW^y7mre;az2Qy5Jh_QZ5iDrR=3h0rJLRhvrx_q(g~&5#=!kTK*n+CG@igpN zIvR;6mkpY1oA}F@b6;FBjWwUQ%5;Mi;>*CJi#opG#&%J;TI+>*qVo^>-u@^y7+($+ zDfm=Isoc!c(s}mYjUZ-6s59cre#4(=gl{wY16QCYK~Dsze%1fPSv@5Tj+)MmHj4As&?yfdpxM|D?NDxjHg=UVtO)}QsBeE zx1Oywr&_z?tC1>$MpG$OwS)|`t=axu!OZ7|D{b~GG`+%$K%_GJ`EfZa#-jkn*jSuQ z5@2c-2TUQ>Vw^QUuR~1%=g>)jJgp@1bM<2Fyjy-mLnMk`;d&jX3AGwhI2c&KOwn(- z3lw*~Bxy%S5N8Ock|a$4Skk8rllx6QrrbIJFZTE*q6}EgR!M8uSehR+-0FgS*zs_F zMldOhv_tTfRXVqwsCtnm)P5}qlz|#Tl#q-*b>NxW)r3>@maPgn?N;UP&obtlr(R8+ z_ONLcC(^*SM{Iu$OXBkRGjyc;fbf8EUi;wT@6G4$i>E;kl=&Ggrg$!X%SD#<37sOYm_`q+)6k20c``J!bAaw>U#IwQGA!I#`=eR{pNce-YN@5 zmxb$)!88cz(hq%a>xi3`hLOw6twT75Cl~|-79{PRzxa+CjgBC5z8vsd71S$qy{^{> zwHu#;iAO_-y?+@(orTW!riK@LFmaOxdV6DlU(NPHrhv!phKzw73|f0AXw@q)iSFO^ z+VTm+Fm43q-={zicrLkPw&SD7`+YAPg4^qhWPsuAssueDVFFJ8rrajP0a)8SWjHac zUqxaARMY_$A)d4Nb+3((cj}Sb zqCzVsPEy_@O$1F~V-9S4TpK&<#~&#mX^3EuIL_escceRt9}g7;;v2b6FGg069C?)CBk$^%96P zXA*Wkr{NobiW&RonaS~h9-tz}FP}|l3?(b}hZ^fpP-i=9ia$sjRi`5o{fROH*g@dY zUVoPA@@GJQk1XlKQaI<&xw7^$Y5Q^u8C(3G@F))@Ef3N#Nyyb%PL11FzzD)hvU0u$ z!WRtuC$-5NEkgI|5%YC=+Jt+!>QW#pEr0?zlO;8$4@CUk zzzhK{74RFX4UXpYDV{!{9AK&MGbYc42uE>9$RI8J%djiZA&kCP7(rLPD2@>VvA13lBvf4M@7F!ZUf z{|(2_pg`mn0&Sj%nndGwt``CiU?cu8gwp zoCrdxm1?l$a~vc409{`=07Ip)0o$;S5ak3aeWK#qM%g@)mn4ve7c6 z@yBL(7pi1MMMbXn?G;n}{y$3bh$t33@s(!7{lH9QJEU1JAzw&j}3+v`HWIxAVXud9vg- zJWr%Rqx6v6)6e$}NTSbq>bXv_K&;RStjLe-Q^!O@1|IgH!EpnR(^@Zp<!L7Y)~}v0m8aX8_hcpP;6xOx|~ktYp1qr!h4i(G1#+GEwxg6gugc z>}VwObG(E4e|7)_0_c`1|B5~5&+z_LjXXqX#e8(9JjSMj)-zf1DG(Pm5k1GV-kzyP zW)(napmtgziVwS#|gw4wiWt%-&NeGi=d|Jc6S~ukeK0fPA<1i46j>C`g^; zlcTi2O9wEo;vSQDDlHXS!`i!we)YSF#^>l?u`nIWC57eTO>xo$W?Zz7pAb#rMU-fY zNJbOlVp|oYVwymiivM|i0=-fZN;FiTWB=C^-1-GBDvR5kS=JwsVjz)8O~wE*=T%2T zoYM2|Q?zh>=vo^D`IYbxwc-b=3!yXPPi$`HQ&Fb}IQMkp9DzJ;zzfj5J`C9IY}N12 zT9i(#`hl~c4`}mRE2bNnhePqcjT-=)&X~Bx|JY(?h&RZ9D@141t}1gj0S@;5whQ&p zT@@_41F^*+U=S88%MH9(m`=2VPdl*`rD%W3m4H~(%M&DXZb=0Bp!UL;)Y|0d zkxL4G(ZQd;Y?_DdH~G?gJNskoNp;HC#MPl_Dw{A8r{s@O4UEq1U^l8yk1>HalB+y zBATQ7AJ3MA`<_45#DNY50?XxMt~6FYkdzSAII)!`dtmVly^>JSQxgc)<}rFFFzYXB zo|7*34GtzGBs_&GO>}m5BPD6kzOJ#19rI-&6Ky-?1GYP3*qqtf*Rxe{v3PXaWd~Hl8KSTXpp$?}zQPo-E87pCeM+5&^Wl?FuUF zOd}&B%HX)gnwj|g1LVF;noDJGy256QvRWvDRtffmH`mwSKI2>ESOKILMyTQdtht$E zV=U;#JerxA@#o-MDYG^c7Y_*C?+46X$3~@zwdVFxM5wyMZ6M69HOQ62e>w>pj)pgc z*S)flpIQKh7(2}N$Me4Ca#+@&!uMuES4Cg0^~LkmE&Uu? z4rh*>#bgof=jIxb`c-dEU6+gl>yNvD5UFxNG7CGd%bz@Qh+hn$Tg3ed|73U zMGXQ`v;!<%A~qms&?0=fswaAFRI36 zqA!LYH@}`1WDmei3E*|#4~VQYU%LXw7^&0hyE*TAt|Dig1B_LU320}3#tWw!xeQkQ zf}YO4j~@muIFkHCvSD5r|JEV+^Yy+mI{!Mi-Y&!BpNK?YBCTO}7$$bJ8}ezaSXf1v;deyM*vCDx&+ zAQ#wI{CE?Aa+C$-FFKRzsW@G%_r<$sKD&t9X|Rxs@soUzfsBHgn(q5viyKABkOl1| z&0V-{ko-~DcZ82h0;s~S7M)@CmcYocp(8AcZIzRQHK3Y%WVbP&y8FsytQ}&cxP9nr}%o+~cb!hNi_$fwG*;YuGMFrZ!5q3+MAG0>*2?4Tm z1ZzG)nX|@3R$4*R6Y&M0wGvRdTT;-djqs*mK_d9s0n>CgTB@ZBEcgT)2?4O&Nh->) zd?cE14CwHNQTcO@2U$4KLz+={ne?{h&r{>$xhc0T4nZxWua%&XK6+KR1tmD~vEe)QT)3D~ke5jX{ z6Qa}Ck6xSW84zQmRp%KO(gE)mM$&QW-w0$6v@csAyA2-_j9ZSfqmA0(3l0@h_%;@K9Onp6PLrgj`}3vDnELqV zv)7Z7iMt%RdTZ3mrLT<4M?U48;q$*(y7)pOc&XHU{Y#8U{DXq-dY)ppcH89!mns~d z`lgEV80Fq~Lvy8;677;N6&v4{-hf7*9Nc5qeEok`@6S|L(*WnGWF}f3waxox<;Pl0 z?@aK#E`^(jzB=Qq{nD&>Wb|uWEDex{8@mAh^OL)>ubi%MIO0NQeQJE2r@Mx=+sZwP zhJ)j0drxHnNiZvgii5bH`_e+ATje49bHIz2)|f3J9Auf z!V!HamuXbgzyAO5^%hW7Xj{Cu(j_3Mbfy(8H3#}=g-n@cO zQKMR;WdS#?cV7to)WMK*%ue zKXn60RzY4CwSdG%`4m-|?s*oE4}|=#ZHy=>*Xt0sUoA93fu8O69E@9wD*JBR-1)@_ zn0(v-Ulf_q+KL1r;!z7Xzo5GT86iAA_o`A~BQ68k&&!T_9gYf|a?!>@FO( zc_f-XbD}ep(WDX(q9fQnMU|p5Wj=XHHfNa*RE2j?|x0*@w!3v&O z7J=LQKu6^fuQg+5s6Z!Pu&bOCe(^_tY1r>R!8j>$?1$fP4Ch{F3+em_ZE6otX#x!m zZ>$P3#1gfJ(8i8H#WDi85UrhP6)(l+aL~b@PE#K_LHX|vqebk!4(Z(cD&(9wvK>A2 zTGx*J{Uk3_xC-=TFOCHlF)t+-*t5mHhWF)sy=sPqkCLN|Q?ZOR7<1H|%<~xx+gQbw zbhyqYa)-1?v8jiS6G>s4^sjF$%}4IAa83!-7~^vfS{Ay7l1V8z$b@E{_vx-<*prB~ zYwM7>iv-hddag&SZ3HZ**5iHAaQ;HlA{oJe2v@?}doTS4aSofg44Evk%D~ZPnfH7g zIM$x(4+Oox$5bxf!%Vn5dfk+BJxIMB(fFPk^9bSU7K2cBGDC2kbJ%Ihk*MO>^3|f? zIN5y1@)MiS+lr*C?0|ms4cdSF+X4L7U+zfDoZf$|`Dl01%R=N4(2Hcglv7{xaXI`# z+Asmobs-JQruD1KJ-W7@H`}4C>$xO4H%-W_fqG8G6~0GBo?c-U#_V?j`n|Ozo^P&~ zuN0_dV}pB9YSOEL^DFijjdoccy8Bd$Ouy@9GH97>ZqC+N(CNOaVR_2F`mYo&RBDFV zH!<>0+~Qx}_J!Yv#&xMAjslv!*_Y9DvGkV|{a6G!0CoB9mD6L5_Poz=N0&ppOWCqB zsQPzl{0>^yc*8RCbkXaR+z+&Hg#uL{NF{UhQ*i3r?9nav7_n{#YVUel0wQoI95im) zo+=0mn=2gT`>HfU*V?|K4xsCd)&%H`wwTo6JUvnPXYv$%LHUQ0FG{rLzefJgQ`X0p z%=YROPqWb=bl{j$weWQmx&?V|-axcJDv!eDDWJA5=B7tu=)22HoQ={LRbRmH6vi_| zZ5&*G`PHhf*?e)hzH#OZk^pswduH9eprz6g7t`A#Cr&3Hm#Fx>_#ULlB>w{K&m+Tu zERG2bOLvuKD{36EAHl27L7h_}BXc+5e;$a!(AK;RJzv>><<5W4u0Nhn)xvw@iCNJZ zZ_?2|iG@94x; z?}=vslXc;6c~Y(Z_C6C@7^+VnzU2HRbp+?`EWc{UJ-;~|K!9~@ZG%8RE(94MH(|x1 zDlBUUlWJeb%NOHM7*GGuQ!cTZVPREDDoQqFXVN50u)N4$Uv`VQ}sf>+ImE^ z!O5DSJG-mscg#2D35Z$5#6%hM|B0jh4*z_H!~VbyiM8aAa_`pTiQm)WjQ$>9RdZgi z#0y3G5pu_vXqUSF@(W)-1%RM_k@FqVyW3D3$_D$V=}4@1j$O=svNB`Ki-)<_YYmP2 zb`QZ(LPg&POXttx^9IK_MZjAx=erIq-uquW%J{>%g)j4PNV=)I|1~@~=m=r$}xzT3*`{Pf*D7)wFDk)2Ji+#SnLMSrkB7(=0$Dap45+pMi(4Zm!9T{b9R&LkP zpauEbher@H#NqLxH@Hw+p~dSU{rChYy*}$GY3@FK-tpcqDy?FS#uvg#d|$|r#I4&i zlB0s-wiR8@cmz--zJCb=7|4=70YtI1McP*#D#Ajr{g}>mHm1caK$L8M0SSE$`Ca&~lBFDAY3=s#)K zfcs&!T7o!&%E5GtYu0&-8id~I9)P+QcmZgh5$v}-BvwUHKx@I4iI_PVmC168MljH^ zAAI#s;6acUlrB-k$b_5!57@E~mgJlDq)!#j9cnyg<<*wbx#-1|InIyf!Uh^qh@S^~5q)3LE>Qk<4ossO3ND&hGiM+5G81RA0DyE#Y6lhTri7S_8N+B7qFq zn9}&v{KmbMYV#RU?QUA#hN``uNB5YAppxSG?fw^xwIJ_%8JerB#{Ecvn=St4y+SIP zeL{Xk^xcIo9Zg4z*Xy%9_gS_7Wdr@AfDMGV)I51sJlv($YMp|%``)|`hwP8J#`J|o zX}<~^Mg3mfKL_G-)?>+`X?oBw5-k!GzFo9zIn78kCmAh%CatCB$02Zs1<;Z98lx_| z!Q zQD_4(e}(7g0i;F?qg}^?%`P)aO{YL%Wh_7Rzs;?GCh4lNa~NnBQ2=lZM)pGW*vB1L z(s)|mP*xigH2<@Ue1?JOy!d9U=5Utl`gW+FiBL2xwLhFRtxw%FZvGd9>@DbY0h|0r zAoFjVd`F>3!zjLDICFnQvit+-a&V?{maaSQ9nT(I^}C7J+TCS*bp{YYS`=12w@oii z4(}4v*V*omF3&s7mHEj>1MuMS82?g8!0d(-R*LXh@eM%J=>M?eA!TVk)sVRO)BBH` zf{6lF??V6io~%?fd@EBt`wmAR&82{yI2W>0J2%839r6|EcG?3inC z{qamRN74x+C32{EFF&hCUGx*#B5;beJsMOCz*ehj5C1nlY76AcJViRgM6w@kj z_4(1tota*Ykh+fffi@@<)u6n90#)|mgn{IoeKOa(G^i0Ir|2K(UB1myc6?ojL-Vh# zNe(`oBK+Bo&6x48rYE~Cv56?_x0u#hNVKH*PB7nb5upKVVff6-wp zq{Q@qD>J=37m$zW8c;*jU-9J?OMQP9^Ar^a-id&AAkUrVemqi{Ue<;cj#Ux%WzAXpU} z&QFZj{)U0uQepP{LWrJkv6_7i2#3|?u%umRbViyoG;aBQqJ$xW)2OWccQ-sUWp<&u zR!&+ku#~S>96cz*OQr`8=DJ>f7+f{YY|wKB?pV_MGl-LbE&!1=UZEe z6(X7^GvyBPL}RMbF(a)**}wRqQP{!9Tz0J5{8y(0jq-8ImeU;8b3%srFXQ?r3PQ_B zmaCb6z0)j&$NNMu5l>Ls+P+iID+yM>3(kI=($l>=;7&o={^PFnz%V9=9#T!|JJg>x zRjFJEJs0BEtL9LeELyVK2$qSNriE#F48YeYN=l=3V)T8}v2=*P_WL@JWnv+2Cq(8W zi??ejDiJ=R1o>qsEBl_?n&zVgPD1id+#AO36|xt1JkNpNTGQEfG-D4`{6i4NhZ0O1 znr$+lcjB(B+!Rs}#y*uDOEpYLwB4WEPS6L*A3(ASZM-Ab>8H#U*~is?etYi{`L~X@E4QXay6U^F1=3?dQxg?@gQT=x4pA<{_v$4;vi+#hT>| z;Jk(vSyw)@m%1mz!qe@OU85q6Tg!HMC)DkCzMuzV-^l=O*o)}4x)3(w$&^qvr*2;R z@Np%X#NmKvKD)bwnwfF5Qj3W>*u)ueSzD9!sV~i6GgYxF`>GHWfntu{Abro~`I~se z?96yCkPr^6JxuA*yO_!yEwNmNKLjc@&+Vb?l>{XJ22u)#1FuA0PaknDCNg=1Gx{60 zR|)-o=D)pWBn%h>`d*Dp*--D34p-fNmQMtd@2mF-b(f(IHkTf6GMtCho4H@9$NNG0 zo1_He3K2o~$M+t1yd9wOx;N+pyQa?=e(erzDgwsP1`6?aKnQ}&i`Iej96|Ch_y=jA zpXFjz@x;_wSkWA&i6QB9Uz+fg=y?)JdcPXT`tk2=W^dcVPF?|b=T9XOB2@p43-m#!6%Bem&^XNPBwv6 z-5yAgCrSU{Hq_96{v{4G`%i+w=M5ERoG&Exx%u&AWBN9$`9x_WWtBN`(K`0{RwgM$ zUT9DVDmKi42eVok2uf(No#glIqeknnB~xN*z|gDPL@?c*M9Yf~jZ8^-tmgR0DF%1T z3yB9mBaD`V5fc3I$=i!O-@GxqMXO@(akV3Xt}V7ky=ipOLRpu*@tm3*Xi?<=M#UG3 z9c_6IWbQmVA~T@pAx%&U)A&Pw(pj-`B;eYWBUrqb zSuc;K`tX-O2rT9m8O5AD{(guO=nFZdv-!!vg)E!MuddmbP>6j#S*Rf8R*lXHiXQ+| z{WFG7i)cXJTfEC$#2W%lWORTN!qTZ5#7DkJY%9gi8Q86Fl}ThZS=*bs|G6=Z>!F04 z!WH>KMy)6oI89EN+2i*bnIIk@F7_yD3Xc?^OKeC1q?I5H4ax~Whm-zDx>{AC!)>?C z+XqronRIFq^o%=9k&%yE5WD~VDG;Hb!r;*l)e>D1#%Aj*4CX*HATQ-_R?jx|RqV}e z;J4$x=>w-s;;WO?(Y%LK-_T013@xO|eJ}(r!?j8|q_$t0(>0gWl~9_FNT&Vgy)GC+ zS?00+>T-Kd-*GX`^@2F06kCP-1g}4_f4)*bgk`etYf;B5f>?U7=PcrgA>oBY{WB<` zRZz;TA)q1w$}9?)r32)cCqf9lRx>p!&tB*jlR51VOV5s=)EwC01_Go0cgW%gHjKgZ z-iy23kcziQDEUePdapha?qWwQ;{sayvc~qHL)l|4+rtRn^W(W!np1jCiKkmL?9)-b zrxAi76o=vG{Lw@_E>d4=h_X&19#b)T=dc0+zvrWnAUJ7aAIM7bhPd!)EEsRI~*Bdm%n2Ko{c356hS#i}XuEZ5SASmw4|3$Kjv5fn=;5? zmI7;<)YcRrv!1J;ySayR_bcLcp%ztEUyACp`ZrV*JBLd7des#*QA!1`^CP}vWB&=l z93$ZZtUJh(qJxf2(1jTTK$9}{_Un*gUfUlZ2wyo$g8xFUTBsIV(Ql<$rqMf{T%*lV zszrnNYd02KBE0|TOV9WL3y{id=kWSMryi9jJ#tk`?lqy`B^{e3F8j`Wq&#(8KF`Si zOQR$ZMv(~cqI?r4Xa~rT-&3OjNJ9qHLUnd^Nxgm@6WN*m%1Qdy?hFOg*n-Yakj(Xs zbX7>>eGW3?V|EiIy4rvX^r`dx?lj9xt9L8N>FQZb7Ug@(i9%{H_89xCL9V^wmhExr z#D3c%YZqzPLDhI*= z^`Q1+)A{@~(V@bz%Y6nkrL_os0d_;Cu`2q?$@9MCV+(zM9q6G|mTJaHwly0{i-kZS zA5Ih5*x2BYl6TpL)Ulle3PKu2P5S%UG5D=v>_Q-Zz^rK&4L(7RL4sMjVb+Ud&@P@G zp>?c)CPt#72>40b^+D>Xb-KPNvA9bVl<=Y2# z>MFM;(MGCj>3FLVxP`1#&!iO;rkptW`4`^;ToIlV&gvk1eq#&m`%c8~d5xQF$ps<} z`vv8_qZaen>!Ifg*o+|Ob&zs_3K;Y!FiunHtIgk!QH>Y)yl(0~?G_pOIpprs6v?f)20VS#LpStNBc7DGr&H ze)b9hqwvZw9P>s~9Z1#gxDddGl0DMqjJII7eDXXcQ%CeaD|q@;atdzE{=9e)4Bx0k4iaZ#XIFKJcwCw<gv*870q59JeRb@i}ZF zH(W`1!Gjsjsapz$%I^cG5CVcWi>vRiX9uY{2rSGONMw`oWNu`Qc*(*QU2R1JNzZ7^F%tAlTyuBD2 zM_IE>PN?k<7C7BLjas;jpl75Tv_H*W;B)v{1W{LGMJM5=uC`E%j_kO4`YIn+0orPI zWPX4NTYLzaoQ$9Y+*JC}*xwZ`GlEgD;R|{?A zDum0AW-0NNx(#?@9%XpL29?vP>@i;9yggtEGZ^)Sxl+Mx{c6m5Rg!ZYYDWNxB$Gc) zmg@@TdRz;N1^S;IWn!53<0I`a1AhJ*NJ7JydbePchR0O`L{+@(B-jmj*k{x`)}NPL zSZXaR_O(_Ap%nr0D|~}7NO0$l(6SHR!I>YLCfoH^;781@U4wt9I?n;>2sEJP1 z>ecFFi&w2ajB|qPQ=*p$S`p=@edJV~3AtUkGzx_D_Qmr_0J{Oprcd|pt8g3kk z`t+sC!)EBU71hU~`eWxYPhGgi$>>Xcen74U8c>h#9DH0EDL5x9XN*CZMK0O^k z4E`t+F%>O%g#1K3Lh0rSGaMF@0E`d#b<&HBh2!>=1F@J!Q(=3087{kvDpz5+R78w> zK(2f+`82sm%fmpqYb-!cyLMs)BHw&1BWGeU;tweIa355P-6 z#hk5_67vQwDoSN7{z&CanM!hR!R1D1wjjGyCP^Elwu*ErrOXPw4@ySMTJB#+#=i_4 z#Q4X9{NRm*TN$yOzJ~MSHMTFrTj0LIO5>*me^VxY(Ke4o-AiS12=zNH=`Ggm(71;^ zs-S@{I_ptLR8c2hD=1A2!Z79z`&hL#E4AqOe-9Lz(MO>L!F_~okj%=}SW3m$ zFgb8|Gd>6B$e>vTxR?t*LLZ-q@wRRl6$`6S!;wj|d@WSFQ zT-EU)ct@)6wqHc~$G@)A=kN;WiUMBlO{-dTPgUR6EhmE4WZKLj(B1vO4Rbxgbu_wO zXtE8tbk6d8?-XrWLTG&upY;iN$FtJiEN4fC!l}4;te+*M`iY@hXMaCxFx!EPjmtgF z)OFq#yt8MUTw_V~Nb6<%oqBi-Emi+vZZeN`)ZnE_CZV$FCd2vnERrI*^gGbptdfET zf%^!>$&wqaicu;uz}$iC5?>6}Y6~$veXJOy2o{kyr@Bfjx56_0ZuEVxt@&7Xa?go9 z$#j`VK0^Y(SlqXCP`G&YAx%fPLwqz_T>#H>hbT?{d7J>4n)aShDbgY^H3lsg>ZNiq z00%SoxYlA(Bb3Do!#YM1MrzKbe`@Jdw4Y|s?v0pg33;sL zrLFY`TGfa5_WW*Gf*2q?Sw?NUvL+=ZGZceOBi~?)%WfEfM*Ks6xmm{l;k4$LEBeCM zt?<^i_xr;1dJk#g#HIe3rHCLf)q!w$=dD*(#20tRuHJ(ufc1m=a|RO;(9_Ak*-DWf zf{8@(z+;AAmS_W{pUw&TwL+JBvPPF|cepta+1r|}Z9T>35PspLHnZw>NyO!R8qARL zN-FMKGQ}LH{x0WQONr;yzWudGxKy=PwLJ;lB>#U+M9GE0BUm+-H$<={;7vE0twLZv zQk79J%AE57i_48wn_4!J3ia6wjJL0ZUmQo?pCi8LMXGjWYX&P#6)pHB@N6wn|=ef4mJeMAFdq=C^!AccaBBHQe7YuANDT0<|-Ri04CvwG_ZYq z?=gBo3(|TK4!!oW1dUCY3<#ov=i@Q)=f4g-E~%oLrV1oHTxGzyQ(D-g=w)8|8`8-i zA%-*kXBA{DQquX9pISUVgIC=t2A(gCx-9ZPcH*ye7I-a?FSUZtheyOj`S3p?ig=jF zPZB<~0*WGMNjwg5T@Mw}UV{!`s3O72M2o5wZQ2i#@XXN2Z)VHJ(HnF(tjp}uz6n|N z)2ErcZh@w7ah~8IAp6sRhv|*}etkTxj~E1+)v32Pxh3H?`kiDU^)bX0)VI4?<9_A; z>s^uzNSS?njL-Bh(8CJIxcxOmvH#l;S6gm$K-mK1X_dc2l* z$J41vWR(&Po)D9RNK7k%bS$wo#yZlrX+@?dCd}SxCdKeAHXnZXFq?%RH1QQa-~ zEB+344Pr~m4MZe5Fll)1&g@~CFIM?niZYA;$y8lHg+*z5Y3)rwB(ZnXl??d;0(KI= zNZ$v^&uwrp&wI;2{JH+4qv|s@cQj%;IqmB5Ce)k8cVh^bo`CS3!(d3rV_zpYr4*q= zD$5HLYT6!vpXh<%ww@#hvY5|!-Y_Z|e)*&LEf|cI@Sk*wq2*M}K;S9*hz|42f9xkX zTTs1Y=t1Gn`CkJ9{?oqKjSb*zplR0Lw5#)_VNHM5blBpy4L-$lt``*-b9*IM5l#|+ zsY27AsX1n{F&P?dUC%_Tl2dew&njCmRkT;(j{=WZFJ%Y%s7V!}ArT_CG95q*hhDHg z?I|wc@WA<^{ku`j1SUi~+T^IB`W31O;%UUiE0&BDqMSeZZ-1y|6^t-gAZeCBk9A&X zl&bty{DLX{)>^kwY4U|09V)f#0QOIwXs_PY4OD2rQYg|OLhuM0ALsRIN`m_++!jOH zfhCxAFi#d58@zI^IkwgY+LcVxMi;6TytjC6?4kDFvp;ZM#stbOx4I*o8(I)AL{H7q zzW1>=Z+$2|{rCmg#VNjME}u6+g%GCgUr{3@4x5FHF5F!C^vQ?Rc~T$4_Ozuz%cckR zLy_MBd{UnWSX`hR5t5u$Bup$oCWk)}%g^@;k(nKm^iKqvGzIz@!Pmmu>eW@s3_I9- zRT_E2?QWS=gfmL{+o$6uyRxwh+crZbjx)79BBM12G0j_e#7qE!Ljj24J`qr9-(DOt zHju~#&!CiG(gF=$hoqt_&x|piA?NC(>a2Sc3X|_^$Whha`f00i5&<8TSl9Y3vn^Zi zqK3=L*NeSD%>C|O{mT`J-TuL+z z6%CK}yTYaDnKZ`pO$DJqiI=>BFl0bP3KGF2Y)T4;3~JvEmfMdh#(M54Lvs{j2di}B zTztIeTz1I(#6QJ3Z%;)7pAH-E3M7l*lEB^;WAf46O4NcxI&B7{XT?H zpu*()Nx|zvMv>AM`77E1yjVJQJ7W7rIiWyphErfzkYJz@%N9&#=j%L|7T4!j?2j{8%FT*pIr%G<1}6S1R1sao z7s8X~B^pW@#c34<^%>);I?T?+g`)#Uv*cvV$8%x@Z;mcyY{2El)_@ia=L;28`Krq= ztJ_D339ueC>s^(my%2rxn7w2s6t>3GeVUHadOiGF>m6S9rFST-$6}q>z%0W+{i$}J zrPOkDkRN17e2=k-%7QnNFJft~A<$y`@W|?qAw&{_*(zXq`EHUt^>}fCM|!OLOoSOn zmi3<%`RkhNh#+0PQ%`rQSAgn)KG%+-bfUkDS{MAOSIy8T#hpEQ(sfLkJFXu#8x{}R4LW*@O{nsOAep?+RQ?Rpu0bILg(=Kl2^gg!AS87h; zJs*b^Ll43Mp3@U(&6}86553gqJTMMgI_{|*5W!vl$_Fff?_d0%LKP6xNpeay5iyMN zREDO8fV{ABiw8HTm-&6nDKX{Yh9$1nYZL8PjBBd?ssUr1k4jta{OI=ENjT*D`yxEn z6%!JV961ukI>dusWPwo+BL#hc?NfU5T2BFpHT`|x9zykS&utIa%~s;}>`8aZ_{roG z*Q}Qs630Ud_wHb>etUiqg1C=0svN7K*$_H0i9S^dL}?HgZl^sTr2DAe_ z0QdrsFr26lL*Q;$W{Uy49|eebLtwrfyOYD?=^Y)Cg7*myn7O+4nHHmXN^7~e=4(a< z1?3VQ&8^Q2hE=MD|Gv6NeNf@bvgRP%p=a`~db(Lku#D^7?|+}!HnhKuNKxi4pM74{ z&Z1mWwaq)X%Uze9*-sVLN6MPa23l#%ONpl3k{@@ZUw27D(?8Co1%6WFO8s42pPnWSGZ%Ums{AHTWpc^|0~ zVdpdSeSD!p6Pd-?Y`@Zn-C9u{nI%d3%tF;l;9vc&50G_84|n_%K~HSn%OV`6+iORv zXMavDGjth1!uITdyrW5HJCzjH5w<>I00<+#N zJ%2yO#;XT}{eUIMgnU>b1-#J-AR;sa-Te^&0u6ubN(zT`da$Jb^LuKc%GIz4MxVglQMh656#$6E*tFiN1vxA@ zP4!_2T=aaDEyvdS@BkdP2b5{TF#J%}2%8TGjijsRR0Ad}F?g(Y$FkhcH+3>OU%q65 zu62aI^$tXtaGAzB!c}zS3m}0cu=qUi3n_StJ_q#&)O{9iQGEB>NpLZl6W2z`;DD-z zb}wce(f+gbL1FL*t(CnGvMC(;(VL^?pQ==EY5(PW9diEvt~u}c+}8zKVurDO)$evV zX6%$A48HsjN5cBy?|&`~E?XWFVj!sm-FTd@{Xm{A`^q9Z2FYl2T(iRQvH-@UN;^Ib zWYz^u*p13wtK62oaRk_(=H2;v6`EquJ|;dTfof?JgWPF!`G;C?4Z-)o{+r z>T{;*<&un$hpatHrZgAH%%a+(6)&&XOB&9~cxgVSj1TY@pi=m5G#Q+6@)bQKZ0P4| z|Nnk2C;<8FRU)rbPDL<_%C9{E#VoYR0!II=)BN{ahdtCh((}M`9S^X$)7_=`|9BrUkIqkl6hXupDY!`m5P3Je>f(pS?3xs zo=3uziUyo^?=wv^Rv_r-5LH1XrChthq=|04uR0Kw5~DK1?d}$(Vi6KWSWWa8k8Hi% zKjezOw1$G5Uh>oQEFe@;oaIg;Sucu8$20C>{kk?v13qN{l8bQS0~*Sv_%zTlKIy=U zIkaILj7^1W4JmG%biC9$y1Jf<0emG;)>Yzph4YH%KTkY|>joB^X8ISiE>-8K4awrTUJt@)8(nO=;*g0J;u+g zdtAD8gFr4H<50&^v;Qu7oj|hNr`LvSQJwmLrcf5vO+WE_X{`F%g7Lgs6ZNX&B+1yN zQ}5K-f4r%aDSpausaadrbh{Sr6Xa`>5Qt<}K)NRPf2c3Xm@_`we zA+tXQAs|V~h|SHn2a%VXo6oBe+}+(9K(nd%%FcM?#{ymEW%(2?vc$whWi8|r!_^f^ zW#k3fI*_yM1zZ3s&~9!qRZ{FN*BSa(26e)?5uoMw@!2glooi(iL!-s-23^F(1EHB< zLqo$XkVbXu{MZ7S)Axn!5ljuBV$82bjel>xmfX<0&2~6wQ7-Xti#JMh{z#G4t9E95 z+3r^1KH{NS|JH{{%rU$F_-kqOo~OPQoL0oqT4ibfxj@*7m>O>&i}4$Mx8=m1Ea&1j zFFP@zz#ejxS=ilsS0;QLUkDI~j-^wL0#v+b+nz41So)L)O=ZC4qw25KxwJRQ1|8b7 z1AC_#z0MgkyC7)k!5iyJ{FAA02>i#`ed4(?EhY|7K-p;~lVV ztgZE0ci|mP38mK?iqW97z9SLv(gBj{K_aaM!tiV|D_lE_D=+lhycFz&G(3N1jxVfq zeriaLby7TwS54QPSYXZBE&+^x4@UWB3?SQL(Z;SivGAo}f3i?rp*1}r7{>|mpmAo~ zk0$z{@vEYXk&)4-mV^D7N{Jq`W6yIS0q)z{Hom}cTM}w#s&dfy76ZM|8OH=*(w?@q z9K1?@m)8jRTw_kXj*X!W1SBK}wdDng4mdIvS~+@Gd)rEWs_);6*EZtPi-5MOTZfuP zYG~f0O01U#bW}P|fv&}LW@}@Mu-+Ln4j=}9hdk*6)KgMkE>G_#;hA;c`g1ElERC9Q zR=-i}fKnBvoa%_I>n6iCMO|v4B%M5d5zEedAJ@40Tu7ADdTx>ogfa8*6W|X@~o@;U+bw6 z5N&YX`vE8qNTOW=JffYiYE8owdfw=eOPPp=^5F~i&AT(H zX^5I~PD9RHe1fl@`-qQCzB?gwaeo3tf$i2=soFGX3!i<9W^fw%>CA_K9w`v!MqTSt z{tFfq)9i-YtglZkJy*Lzbw6@a509GC^CED0$fEQw^uV2_p8kxnvq#yX7&xE#w=V;-Y@Yv@A@0>&d@ZDvYD7|TgRhK z73rxmN%>|=Wo9-h1Zqd8Ko`?1ea_;GOrS?ybV5QNJj&)kMl&Z!*(_F=gzmFZ=z)gj zV5>G<6RY+NlAt@neS=O*AZ|g%f}nF$0{=Z{v3}T$QFh@>6%VdppPGtl>#G{JrzuS# zkn(71wOMFje*<#;_<16@;V+km)7!2=pSAVt*J5WnCGV^-L1QZ?6_pt3lS5hY%U3<6 zH=5to76LZ00f1o1>1PM%Y-AH|qD}z~*R>CfysI0bgq3!xLZ`T^U%L!;EbPXh2&6%_ zqi|pE!gX?7<0bgucJzETt zt#0%wX>?r@gC?oTs(duQJEr5EO@anFzdBbg^62kh#r4?>(%QdvlH4(mSU=JMFRu`_ z<(tZA6_dNQ8PNXE?zW$gh~iR?@jZ>ztX! zh6|M3+Dp_s?`iQp4_|_k4b#KF<`DC_OM(NP?Q*cl3Xp{H1I&HiT~F0Fr346FH#35c zQ;c*!^nHc$xMyPlk5Dj)RCOgs)+|wZ#|pFYYZ58Ud$hNr?~=s05cN1@$zK@Xtj^MzdLVr zXC*R3gg)eig=5xVRqnchtjzJ~a#L*;OELQ(a7|5y8? z+o%GLi^F%zCPU+>jHBU0(Blhtp%L-hLLCfN#J5Ao2dDGG@Pel)tgnVH4v{$8v--wi+XOSf@g4}*^y zRNC*z;7AH}J8>?&pjRtCGjZk(oG6l_NW7YJAr9Ygc`&qD+IpuI$EZsu6UR_KSL?ht zyXBk*-v0K0!L@-G|fbvdXe}8mJvFLfOo5*RC zcIS@LGmNm}t^@eW1jVMUdo^>r1HAc9{c1sdC~o@Gt8cy$R0#gs=+pOe zcgiZS2v%yfPUY?4b<@}@Iq{qtt8Y1#NJoKTIbD~PLm|7}6ak&eek#FZSngk#%qxIJ zK;i=Zw-995D!d$^YIO{*8+1?8Q(ZfzIi=u9C=Fs}MowSA#{b*s2 zG8Z_tTqdp;?Ix&!)d2_rAhxq3C%3tRXMUDQpU<7?t3}e~)a5j(5ete0X32PISj-Ij z1GLlehG^#pT&Y3P)E9w(>lw#|>RH_;qvR5xzJ)u$$^9JyC_*O7B4-xohs4B7|;gWP(I&muHw?cxT}e~!o83D8sCKg`4NFsyxy(x zX|YQkkB(IvpZMw8ef4o2x4*t;FxXdP=XbEAG3);V5!s58%HZoPMwT#6cLB1LggZ%#|7VRar00 zE}nOZ=bd{i24YsVFF20L+3ytB_5)V)$>&671795gt($HA>mSPAc?5`^`^!3wrCje+7`Zur&^^rDt;ZxfrrZ zb-3*#UKbn62jhO9{|#S5k^pf5$RH2yb|}H}4(DS0QwOG!<}l_j6K}K+27;uUpMA@k zp?a5HbhVOIw+~T%WTV@xr_5;+on85}0f`0EdBdxD{innMll4pMQVeP#1S}*n*cQTX zd-kZT%yx(1F8Rs-ZI!>}>gMKT=$%qG0KC%<@j869;-S7UK<-Ed7B=S1n+5x_8Wy)> zW6%tZ1A~w->hJfUGgM}ohil~IC+c1a%`^G?^ZUz>IvkFle`$eKL(}zgZiVp--Ntj` zTI`io<2#5QarpaJ4^A$C2tgmk%K(#t`4ts^9}bip!s60eRJz{Y1$5!@5dP4yg23FD z?Ie@!4522|=Ru?t&KbPID5saAEcplOmn?PyY<9K!UQc7c>*OICH2 z11EFH%x583PgkI^0)xF2*OAptU)n^T%HuMr?_&5(jzQt!W5mhDs(BDCa7vi&q2!Bu zP)_*WK`Y^d0QG5VCc@7AydmO+nW?EX&?9vESQEA^&t;HmJ7W@W&Nek26o9F*(z~bU zd8X!8*N`yfGvJYI#vw-!;tFs-{N!#`cmblCDn-DBAGxA+P5B0SeXn_~b7+8CstOlsTofm=eoIh-Hy?#FP;ss|SX z69T%aQoTN1bkE3;{LxY8hp`xc>2gR$kQX@$u<1uUkNutIL?b2f={|oPi9C zKz^z#In1|jkZ}iiS+512QJuGbCGY(J4=L)9SQ}pc5|tlEDy2>iaoE14s4aY=s{IQ5vORmgORbA| z7R{l{^XxQAI2{M#3jw~YvNZ_&hP(Mhv~k;&n|{MLUuyA8J7HPgf7yEb!w+Lt-&@P_ zxu!lxI~@CI58EjaiHagr+roQLd#Ff2`OsK}P2(QmW4=#mgugW~S0r0m-=Cm|7 zTQOyl8?%N=v`t0|U`;8xxo6Nf0FW&Xh$6Ht)^Z%K(}|)^8e`lnq$UGgBt5Z)NHeG- zS5tKJI!TWBa0c~`$6C;%#c0)C4B9J@8B(}Xd4v!K0~C^8N~I%=po?@Vmc4O;dgf{7`|#TaCs0&CI8d70ip`F_|24?^k}=wvwq!S!gxP8OaYB_+1YK z9Xy#IeNqw-i?YFLv_DIif~Z73D^>VSf*^Q(Fh!<#nb)lKLHh)FGaxLw=~&A=;aUcM zLae~eGKSmt1yDO*Bfq{&^Mev-stMQMM{7qce@jY$Pr4-u^}p61^M!Osg!LJm@jFX4 zCle{dKp3dnxEwcwQ_haPp5dsdU~P9wrq<0uacJjw|0RbeD2U9UU9ZPMNxk(Ff;%dK z{FX0V3E^c1B;}uk7-<$Xf)CW|oXo72B4}mI1|zfCHZ=8sU=T-MsiO+){iit{oq;+1 zNO&NAsBgo6Hm;&qnH&>CnIQO~11ATQ(AEAs6H6)JUgB}?XV%-v%4+Nsh_ro>g2{D| zA77PuZMhW%q6U9Kt2gpz$2mJuZ8f~$1|nP?%HWoDlKJ@fbhpRzjr5~pV@;CjdvM}4 z5EqjegcehU;S+en?L3g1?N-HaW2s^M>N0^$gmc{@wXH4IU{(if0M%oSibF zs3nEnc-7kP#C_?_b15f@M!+$s=LHx4rv8~(L#lzWENpo|wGMJvee#;Gq}f7))0MJK z924{7z>`DNAlC(C&Ql?QTQCjjZLAtthr*=8z)qWk?#8K1GzQD4y6!VK%hc8VTHSb= z>`IWO&Q=fr=!!aadk|>Ar6n~M_2Hzog^|dX;T>-?tYOT zSJW3ygEJTyNP`78RxmU9TX+gi^8J4`XAT3+`pQ1GXPb`I>N0VT$};i8f5Zwtl!EO5 zE#7!K>%(_VX}%!tBWN^t^~qjw4`)g>JfBK#u4WPjLcOOY^QhXUAG#-^?=c@<^c%=I z%FsUC!NBFMombcQq^ezX|N7bupl9K*vE&iI`d9lS6uql@Yxi~B&1>VQ*)ptMo4uHo zRZ+9o4FFTpPU$#&BH|lN?il2rPhc^sBJI$cR)DUT zXA(1X1F~TvOe%(Zjn@H}_6aJrgrfKwft~iCan3q2)Jc9{-v%3tIoUe#SGN-s-3nD% ztM{{=3Hs2^t+_4_>+U%~Q#QEr?>SQq5J9f^xVR6hL{0>uAmnT{c&OX=-x8Ig#S)S&TlSDWWZz0DjBP0U zt}wM z_w^2-<PAq+)wmhhHk8s3Ru;1Y^FXOmWO^UoKrJkqX zI$^F1O78G407&ApL5DiFOyOZAw+6cDUN%r615}p@(Xn$4{VuGadZxu7w!!Ks@a3*` zx%KIW7iM3=J7m{(`h;4)O(f0u2xvbKrZgD2k&gmM?4~Q*04%xX6+O+;<@|?0 z7()T70P2(A9$yMr94Y6UxZx_q^c&a&s$Yv!K@X3bd0L*&lmV?20W&1P?$xHXql>+r zGKp1Y_JheJjWp9v)i;v;45l(MAfcF{V}cf+U|adGR2FOCgX=~9Q~HLr-dWmfMGEL_ z?Zw98kq2#O`ZSN-l1nwf>o^NY6P_+%FFx`olQJY{KabA*AP9g+`b1 zM|KOeeD%`iqnAHAD0NEs1!AUXa0CL!1Grn{$`^@M_|fmqkzT%}`t`{j=EUohMKxy= zDR^GH8C5(r8gC(N-uQmzQXUX*n1B3)j9pZ;&(s)Ob?XejgJfs?_I#h(6@G&cg}C9; zoZsNM-|yjIMOyVdn~ zK)>Ducr7AUZ8S-^e5QEXM3H*Zu$&p4d^Z9?OCh9=T=d}S^#@d>3>mtnM1jwhmOhau zYvCkps4@q&-L0^IdAA9#qlvYySLs*gszHef!&@>(t#Ei?eH+alOQPhhZ7Io+inHeR zAcr&~w^(BKKp~{m?8JGax`VYaEy-mMSD|OWfqcT}t$=qg!c(2ATN}?M$$VO|IBKR& zIe!RFhj;;F)$46ZaceVeI8Nma@vTiWuNgD_w)rV5jE5BGm*GaPaZ+>L{ZWsEqV$auTF`Q`-|~&h^O#@&B(VbJAia-3 zrSUjG#~o?D?ew)x-QB&+Z-=lwk+i>z>c(!Dvz}6wHyQE#>qvBt~G;P70e(JcHSWCvnjgznx57V$pW3n zRTqOO1HJ$^NkdA^VDW%TY%9S2{@28GdM}WICeBP(jTcbP7|iT=EK3^q5U7%rxBrlKCinw@PTZos`+K2`LP)45 z!x{3w>gD@B+5>y(@qCOz5|o=e;e?PpL|38dqFDexR2tSIwBsAqpm{o9I|BGcm9S;O z=jAsI-YfvkqW2A5at%bq6i`Y0-g~!6op?^I9}{1uB4rj=4tQGbaCFrKY5tj+vGXE} zsnP$%egg5-13>U^%@sM?PT0$Pa>_>&xX!^8fjR%UNPme41Fv{@xn))z6ul|(1yupfjeO5ukze!%0 zYs-{M%Ur1EyEDaAt$y2EZ^$m`OvyX>A9T;xMwhN$awy=b7p&FD- zshc%cwELZ?&HJ>TEY$;)>31!IA51hax?Rjr9tAvX3UvEoL}3o>0bzGunA5wf`m`*U zipDif?8+HgF7_|JhqJ>3y>G9VdovW;^OVCTgK3~Oxn^~>68^vx_sFR2w9;0yHxn^Z zmzv)&fX{gs5{@Y8Z+_KM{;@wMN5z#qoq-1mA#K1`eN4he&jp3&*R|>WY6Xbp0v+8p z(T~kno}`OY(`-50rA#j2ogXgfIZqP5tWI?eSmDRb*WB)|WM$WJv9Zs8r+NPM2?>Yg zHPzU{i{G?cekjgv6?5)tw9H}9VY1s%b+heUIYLWA#SI{*;tbN@8w;6Y4g<>EkWp25 zXPY!>9KEY%%a3u%_{Vb>fwd?F#bA$|#_Fo62LP&=H5Ho{twTR5AFAE*fuN+QdTY`% z@C3Kv^s^W@{aO1gC*pm#4Y6 zV{ab>(L}7Ugi(p=BuZ$mJji?{Z;8GUHy1=9@Camq4t~|3Ufu@LR?qgTDQVoJTXI6= z4E4M7NbZ2WzVu8DnX5^gk*xLeahq?0!Yx}x%t%YmAp26Iyad7&oxF!LAL7Ca-WD{>5pLcW>(AYV0Yu z)aX^L55DpC3$50-^)ey5RyzT+9Vr$}((bRTd~^q@C(^}r0?u3PbN7%llm)1_sO#Pq zW+Ag2}#nd|wEfBoS(SPs$AF?i_bB2G)v0G-@~ z0kX|sjbY8u0K)Y$>&~}5&xScI=OEd8V!5ZG?*`cgfa&>-9#o+kH~hx(qFdIb?^6VP z_UzI1=F)CC2Z+hDV0k;_p|u}H8%UKoAK{M(@_3Zyxhi1lEPhkhus1mrqObVHzfRO? zzf$86R4eJRXwWx)>)s^Xu@N62GLp$+bFU>D_q#I{y*eTf?&edKUg!~0HFX>+ zV*8!cAc6JFl0Dp+s@I4;1hbS){pbYAEAr^*XY?Aia_YfgrgxaOZ#%lw5DqU7D!^NR ztTZOQie+%yQ`|<{44r?;(rFiat$AM1q?$V9wCpebq4zC&jThw)esoFAzME_I?$8Hn zYFYTr>&ekEkErIhmPQLeWpLpMz0`UaGg7s=uE$I=9=AB9PrtI{wxns=x}QlcGM%=( zl)lL*J}i4tZhp!8rQps-m@WL_Q;BJ@<6QxEkJpvt%EzJi-n!2D7UB(|1=bPvUhmJC z{h8sDq`yEf6ckl!2-hL$v=u=VvhRs{7@^2ie@re))skt$mRj~aAwmNCIoFd z4b*tKxkz)K+Nq@6W;sulR)1ee8oulZARuW+@6H^%zE8q&d>V?~o{)z`37mXTx4Wpq&Y7*O1T@6fWR4wM$yjHPs! zpbU5rs|t=VLS;|gnTyODf&-+T82qM69g zK)4AE+E8(2Zg)49Dy}tFt>X0?-{#ulB@zhWQV`NXt94?e!$-6p_WW8<|mR; z`(Nhp`JK1t{+hH}IN@7jbj)T9r+0p{X!q?YsPACm{RG_)=g$LCodURm{Mk6DV#p^u zAn+t$R(o5rYTmpFkU?42Q?PSg6xB*fPk#hoh7NU0ld_~_K3k0yCkm4Fl}^5V>92y2 zk+8g{{vcBWuQRAgVxgf~tA2NL5Oijh=m%)ToM zJ|Mkq{wY;Hpf-tvig0s{I7z&9I$5g1m0A$Rh{V=_ccK3GWZdT-$Q&K4zYGKQ3*JUQ zoBVnb6rMNi5b}p@U-kn8DUlvLP_h_Bo%lU*S%v)aAJQC)yJ8lXIzBmEG*^>CjXSL8AwhreK0je|I!=0xSm z&Ri6v5;t2(HY;v00UqoJ#8BjwIsRx zWy)Nxk5N{8Dm%{HB{x5ev7)fD&U2t9rDjIEv=aD=HOcG-yY1Hm!k zJr=5;epDbAtq;@F%v@zDh!tZ~>a#(ozLD$uAd}u-Xg1*w#N6ky>@GwIhe@ymn1~$3 zM#tQR{*Jig3#Q{2YI?Iz7o6}VX6~&p@%i;!FK9&a{C&yVU`m!X`wp93KheiuPxMWx zy?8moFYCRrLPe@~WQ|s8Bp&}!56}Ax;h?t;p5=AxMKY&dx#qDvW>>dAj$Z`l^#y<5 zA&2pdgwzwYi7Y`p2~Znyb`XZa6NbTXI;Qy`45H&ta*o6iN5TaR3tl?&^uU z#Q4c=8oNZ!ZZ2K+ieK%H%F=!;+;Q%&Gwvj5@7?D?6jUN>=yp0_{|e?n8m?wG52t-v ziqiXTBRH}$;eIVVZ0xww(S*-Mj>9EiN+AzlFON)epRvun%&uwxR0+*LLCjyr(!F>o z_=e(|q zUBhMw=70}3e*0HKVRyXA+5)0bb&%WidhqgR;Dg-%J|-xK+MRb>5(0|2qfg+Rt@ARW zSJf0%GdWT&l2j3$g>8MQdnxwh3`PSMM(<<$uCqKF`({X{HFx&P2M?kq;UvbezIzI- zpBb|J+Z||iD5%1a0i2}w(Koh1$`eEVb zS?WRX;N@@qhZ_2dA=i4#fqxcKA$RH@la)yZgms+p6f9HY8dVl3>H@1Uu28`jyMJ$h zV{^4%L@i?KJhyzLXfRf}o!#M7ZmbiR)$65cMZG44g07n$u>j4eEfGYo@TD$Wr%%ks~ zgcp42MVKF*Aat^$xp*64Q@ zmIE2sf^MHErrfFYf=K^XKfAeL?T)$6Oai1vqm05R(evf9tt-&=PX5h!H?yZ~WOl=V z!6^$|wrSq4j_X!$dHU@x+u84DqoXf3#NZ`zlcO^dq~Mb(TZD^lYh|XPHKM8mFB0ZH zbJTmbW`n%jHkE*G5(}(f$FT0|x@pvx2TZxmexxkriH{UjpPtrS_z}GsV+-j2MIgpf zqy3UuI7@sn=JbfX)cKg`n9_?Dm;d$#)`V_)AIw(x&e%H` z6jp35dKewre3v->eIU46*aBADMExZXMb%om+bb&L!WM@IyIAgfZ*LU?8tLh#kfVpK z?BM*4NG-ZN&^u3us*W!8TDKN5Hi=sKQRmru{fXcd$RO2NCK4&H8rOj`4BwAmJNuf& z=8bpvH9@#??pB?$UrJE8vW5r?sjJW(Mb+g3*S8{i)FNdagJU~3j8eS**R2O&(kM9G z=XYqGH9_(xKH*xf%+uTpf_i!JNgF_`CfGM2tJ;M8N;P}@LMaue=Cp&{UMv;m3-UzZ zDBMet7Mb9qoee7sc!(fI8}HKMqmG^4lcZGFZ#s05?3?ewKgoSv-`_0Lq+N$&6QYBk zaQ(3>4>TL!DnAbjry0J)uWAHbs+i=?v^KD98tUW^@9%F1V9S6y zXcP1&sIfAP5AX>bckRPGYo=?u2!srl$E~#BN4-x0Uu_6D!l_GnbH&zxMOg`0C|-SY zJv`OxN%BP5xUJpU^nI7}2N0%A%@aC`=ajs`$r6JdO)ppbkHdbFG?u5xt6kp*zGG1M zx=*^S;z}nYcd6v>h(EEE9V-~l7gQo1OJi1uB*9WKJ`wgKeZ%23s{;E7iuTWs+OOVn zGUwEyi9*RN4b?Vys7lvOQO>j_Rj!eBd>yYmx?@?DI1nrStyF#9Y^eyefiy?I*2GV4eH7 zOMeg5nfdjF_^&+cklw=kBoYoY&o2fg3Yg0YopV9f?%6Zm_I&ED$Lu+I5(PxaE~0S3 z%=iAnIzH=UW%ez^JOu>6#~Xw~|4lwd5li(Azw4$q?6Q5cBRZn7Af(CO-m+Qxd&yg# z_r1L(YMfFva8)edVI1Xt*W+0S%b%m;&6gA83}km(9(-#EdcraiT`!~}_l*Qp9p5vN{IMYBOe5NP^xhvUcQ}C(PA8j~Lq)t5D~?0GvmW2uUKNZcZMNC=UJr@b zYMV$eapBT#b*7S;dWRi2id9I|;R}eG2Yb%gNR@Sxcv9K)(*)ho{lH4j;GmBzYv0>? z)1@VJxHc_1a2SphPTzGwG7WVn3YbjRmA@yP8N$G^bbd$EX_dn{>}tvr`$B-YSCsYk zR(V#Wow>Y%?h6Gq)f=oH;E2yX`2`7+EUHu0dP>QyqlUc6@pWdkEGiwcHWzx-!*Z zD)e5an;A8KVYK>L-;=2l|EC1@?cvrm?bf|#NNikm3?CPlB5N*~ZjOYc6!uFH;(#I` z`94!9FOl?bJYY-y9CPOXJ8FAiKq~Gy=BOlp4KJ`f&opYV{;62Lgr6T*@A}8(ykif} z3LP+#5N7{gIi^D$cP()TSPd-F#Ip4>v>j#K)W+HFSl?l|)oJs}U%@jwh=S9kOm<4w z#eaVbUkO8qIIX_(5{6@cFo_=S{SMPdTSwSd)zg*My?qjZ+De>M^YBhL9hly^64RX1 zUs2u;8F|5CJvy6pLF|S`%j=9^lqA90;Pr}?tp=0VSpl*{5mO`P^)`WraX&1z(#&%J z>$#jRY%axV*&k{`bgQ<3i~?_?Zk_Jz0{9_)w?WM~aG$PJ$1u>5YNF?w;Z zz}QA&+&vBrr0s^U&LQa`P*?&1_~m8iV$^1CvQBD()eq^7e|d}xWfy*J>7f>I>-2UQ z`&^smrTS_k_;Kf-o%`V{nA>SlHj8^4#Xl3xpx4Gv)K%|M$;hm!$9gujsc1QVcW@aF z&8eu2lKN?U-_G)`VV0OgdV?Xjc;Z@il$apnSZ znNL7Kfk5aOo6^fz31{B}1(~hyfH+uxWS4^V-7_0lA3U}AJ#y(qmMh_{jOFy(H{_Sq z-vT?Kk!96%){-w8#C@a8er?k4hh;x?@a?5prL-qC`x4J?{K-@7@cJ(@(uCzS8K)s! z;dc($oDNraz{={AR+c>~u!E#cNl7oLjwJD2hkK;Rz>x(;na=0j-zW=w|V1 zFDo;^=5C7h{V`v)4MJMCyxl!*Nx?n29%9H=c4J+M6;GUw@o*Q`2M+?3IW2EUWhyql zsc@aAl0n`ygBsn9w792@rNbGg9j{r*P<+V2Q+%f-Z$3f$4@Oy7J-c=n@^P`S0A z>Qd|$us%BHb3{hYP)izc`3@_F47_Ah;QQJifAa)Mu-W7By$JDxtovx%`QF?#F}ty% zl|mYa)atHnsi-<}-ru6|Xq|<* z=ZH(YyhL7h>t}iW{ZW*VEZ*<%RjNyA60^^cPg;5qh2Lr`%DM8s{Ox{c9y*?>k1#XfiGjpHiW;tcVp2Q_Bw8TU8+o|=@H zzQTBHwqv}j98q~DY3#PCZNr#~d%;661|@&v@rerLI|BVVgo(L?p&IXcS7Adqbg()6 zF@;@#hgcAklF{JJ0f{t=?UzyV<>feW?^b%vHua6k!2qO1i_jo!RBwjYpWsTplrnzM zE8symG)*ez+rQbiIoh#@bM+(8YbFipjoGJ_*XF(27;LAy-h<%Xf{~kPyl-iBvD%=Ol2JVQy$V#gch@XSm68wC^$#<5>U=9! z0oW)AkifFCwDdePqs(Dhv)b<_zE`k~hJ7|I4Uv`J*v!VVSqwlXMkWf;V)h>R_HKhL zi&T{f7XwDGE_mJfEWFTedneIU_H4I$0u)U|H-($Ti~5GTV#w87Kx(oS7?P{EY=3;^ z1%7Gew{@vaARX=KH7!iRTjxApZHkWWHk_Gvknvb70^}F(h$bK}O^i_1HV6mWHNb5y z6y$yMDIA`91Zv0shUT5xM&926K$J)E~}Y5d@X zvg_jl0A~e2-UM>VB|`7Ec&-FP7T>P#c`FC(jZO{ZstMsqXM5#jod|C+1LgP4WHRpg z`20RpisEf|QEVDZ5nUXZAdG2$!4K0deZRnDAx=roAbhPx;Y1+K6%Y$I6vFi;@(#1G z_qsy*v%-m(GX^C+sBaSz_5`eDfQySe0L)1blps=xF-?WpO*`wO;P_(Dco_##phGz7 zV;MivvAKXLJtxoU#O3pm=myJXYBEJVDNn(?e>6JWSR~hbzg)1_dEhWxjveBs2X5M# zj$&Y`hQ)}f>coyMy%UTBo(s`(@IWC<3da&uEJ7q7mFL~?$i->_9>VlQo49u&16 ztrVR#Na>AfPTauL?xqeoT=hpIYN;^+$o;&2{Q-6!CJ5uZ-`%y=MuOe4KN=_Pp@#<<(*YU%Ip0A&utYoFK%o;DGIzR{BjVMy2#;!< zH)Ixt9PI#aa1hhW(|x9}Ncbw8urO{}=zi0q+z-0Rz~hlN&ZcyRoXqK?Iy)~rRS{DE zAtjHPLHYXLnKxkNh6e-$5oTkQ>TEF=T#p@{_1f4`8Oys@FMBDsnO&51h*+g-eg7 z6q!_{=iM+V$Tof0i>rBg7fsUo`PhVq9(cf9m$*6hLZgva=Rj|{6|3z(IHdP#BwwAi z&*m2Ok%}Q_D2z;bEO9V#!uU2`4d-bMM=kZ_@F(A1P2x^3?!-yZNU|vvkJl}c_gt!5 zet#z4c;c{U+Z*gAiZd>k?yv@vfxOXK6jrY}Yk>{2i4^?tIU>s&vcw1pjRr#o!^lI( z8GzHdPQ}q50xGYCnU&sPQ*^SX#YHPq-^pnsIAnpS`u=~(bIDYs8ZO8&43g9#5u zL1CE=W*!)8eUW16=5Mc|(4a?V3Fa+eg<0i|zv~cpE4sQ1xTNT8i={`rgN+};s)@pm zZ(JEr(%gnX#&g4W5JLv6jo#5*@=sn5!ueZI8j-kluri)}UnYjQ)0tP_j7Kkw-!uoy z7b&Qoi`84q6QIq9i$V%ZV=TD5nqw_*S11n(9C!~}Er#gf7k=eYooWEKtgsCpHcF38(P> zEJ}L&5k-}~sDqilYYc9k_HL7b7e}5FCQ#DQO@_L-LN7 zg^AS!rk(q7I*CtL-hetLy4bwOe7`+7$tObiD4?2MW#2h%=}Vlk;k=1;&@305g$oDk za_tWc zB-N`%N+*(i92LzqNx7|z(sV$=s)qYzy@2?%Pc1Vo%Hgtn$lFH2`8L$CD6IPxLz%LcaF2fXi6WH< zat@wor7C?%?BMqs#1bUQbRNBRq^1}mRBuLlNgWpW4!9QH5Lh(geD&HnFu3D6ZrI6P zWY|)UH)JNSL3DW2`Ke!jNPIci1eErrd8O+6iS6R0R0`Ai6>dglDHxB4#qRlDYyHIq zGXp1U=%hPLN4+?YzIU&>`U66wL2d#g@}>GlcF8xn2^bW=M?fRH;e;Vfqa}pSz1)wm z4jlwj3>gr#fNZ{xWXL-M<+Nxqn8_XU^wYy%V6jN8bku6I(4s-{LY8uG?&Sf?HeszV zGmasHI+@9PG<=3P*o&ef$BRZgc+61c$x3+GcI;Tzu(7c- ztcuZS+XUX5L-B}vBK%q~aMTTy4Tua5A z!S{nWRsUowYe10LQ)y$`nc0UQ4fv{Bvlc?>H(x$yvugUz)7}R)mx$xf@+fFfJwq*W zfstYM<-~-4R+_)I3m2>mO+lzgqi_A@&U=9P zv{2Jgvx8)`GPk8|hI91_q~d8;e)0@zecqi-x>UOS@ zsP9zntmB3;-e(=8?n9C#&eGTcxBkt>Z>yPyx~u^4Z11KU`;zC%+aS%o$d{S2XVEl=N zV{;c&1H|r^r_5o0ur$_4&|`A-mb2AJGj!9H!<&P(1m8Tr&3T&&hvu%ixsZE|qvJvs zD`Gj{sL8j#jm}U@vo%Ps+AErlT%JvLpu>7%o`40hk%jf{#`-RpdE4DC`ED^8a5g&_ zJlL){#jurzT3uDK>8&1OvBb^4)&T-SsHL{Lv84j9OlCt@9A2=jO4P=4eQ`M8In-~~ zPq+jGn@?9xpCo-q1R`j#lKfYX!=neJWL(@TX7alt_|bWw+c_2X<3G(Y@gh zsf88GvuTWe_`2l7c@Cf7-SYD14}(KlRQ>ggds))r>u#5D@PLBkfwzf>8Mh#pDk~dF zt9r|i7vqQf3gSLZ5?B$e#15IvYWySgV5nxxPJ>YO=$;q??PcnT5ffjz2=N58kC^D6 zS}Sy*TTsv~-3dj0mcP4IM*3U8z&`Gi?@R$rlmL&>Xkxj-UpwY2aTGP~w){9fR(bS% zd~=k~aVC=!yLB7C7M71!sS9-;CECc)!~N+}@!v}shsHkk)1&$y?GxsF&<2tY$Z>cp ztf!mV=SZymGt<#3S5N4T+!FEt%Sc zgd2w6e9~SAg#&5qq32uNs)HLL`^+T(by1zb{o7(wI4O&?Z26&6A>TVVk^M~R(ZkdK z;6%n?jmN%=&Y)b~k~b@hIb!gK*b&Bdk!ANi7d6x`FCzHzvD0yVkU zp0)lXEW%-MG=ku-y+Oax?2y0zeCWJ@u$lT-Mk*1i=Pmq~ZhQcvL`FJ|J3Fn!3KBKL z0-D#UL~2u|8<(pWdTlRXynR%X_M^gY18qvg@9P=C;qnBuds|a`t?>C z$w5LpDVHJ72|ej)UXwN;_7&06-aV^ zpTaUZ7s_sR&uufaY?&cUOI5)OZ~JzpJ9Z6Dc%_Rujtngyb-M{qQ4>M{b{-}oPr4=u zrU2WybDD&V_C`24LjZd9>b~o*9BdvW_x%&0aC)nc?eP&AV0DMQlmIN7Z=em?D@{*& zj-l|t>%4!E@Qm7RWKLzJMWpis<-vH2;vb8vOvInNgTn9OBt{PXe4=&?F3FZmW5Wtd ztk&tgMx7@U0*d5b`qP3w01UX)AqfiaI#R*M_TUEV$|g)$_7}Ge&HNk!>b7PrqZnDx z-P+Pi@wSGBX12q(;`w!M<35|9x!Kquckc$>c}R@%d4)vPSdn+0XtgAZ_~#Rr?n@{S z&b&n}S27d)8NeQ6Wot;96au!k8cbSlZLopd-?ny++!0%Y!4e+lSDJUey;UNr?eu6v zKUVCxFWCT6BlhKw3-h&_uy$>~G5A!0HCpek(||cd`*@6kU9*^$WL9)v{(!am=fW-9$49=~ zN_;vc${V8p27stMnw%<5A8zX?*U#{kl968`lzz?kZaRfEK#TyTiBO-my?S;x zkGBwhQ;`_WpS{3aX^2SF&(d~kH>n=G((%@zlpWspg9yCFL|^{?ON=BK;Md`b74-&V z*V&@;$QfpMb&I$Jj7IXTw1|P|D?^+PXQljJe7R)q=98%ng_~?j_^8khK8XgsfU42A z6}ROi;+pQ3K3&KWCzQ4hOed>)G+^kO!>7RM${G!5e+*LdH!u9b=0WISNFo}r)APx1 z{iVb{GgM|ohjM`napQN`pR-Fv9W;lO)AE{K`e(g5Bw;2vCtnl8D;)QmlTFFYch;_yo((R6^VCWolaja>9FF{EjPG z{{<%THR{6Xskagpk7T|d)hoFsy{J0oeLSHCn>C%BK?c59#t>ImRLFH#T(*`2mGQ7V zZ>wGF^zi)bMn&&OO(yXaW`#_(7+c%Xk8#lbAJA9#s1F|ZRa1I2RM9ER@6B-5mHXG# z-Q2?l6kF_H@UdCZ+FG(P`#$!ufu(Rpy7Xvx!0+) zGd?0AF(f+&R)V-&0(2xNN1{F4sC?;TRFhR2;R(Ju;Aa2(+Sv>Eb?m9rBMC7w4|iV5 z4em^Skg>WpURK3~$Nj15IP!D6?CB=6M>Dw%qB9m?#acxJgCEP|9n1@%Zp_p`U2 z>;PxZ`DO#=l@Y8{*R1cij&11)lGaP~tE;5O)bm+|Cb=)Rhhi<`>u(?9zP7}36zt82&74 zN(4-|fkcQ7oc8GFgJ*--!Td@t$G^prkbwZ%rD~`gn4^K0aL_CtVzXQtb@CA@F`40(_h+RrvF(~zT89^^r&sVP3Zaq-jNgkQ>{MVly z{hQ-Kh!!`IW8B-Gb>fc!y)gz(2QadD+2o*b-@a9q|H7B6u7F1k>Pl&= zE2>7`4p%-Ac#YVXldp9C85|9|rdlB*#r(`9l%d27vGX zU(;vu#I{zyw3z06x5^_0cEeh^z(UR5zb1T>?oYTK5!H&pDD_VOt^_$cMUY%O70q{`n%%Z>cQO zsSitff;3iO1>6rA$>eNbO4ctZfELQN3L;y&(u2aUqwEZYNn-_z9CtPM_o=&mW=w9+ z`8xFN1!X5`ocw24&yteWCW|*%cS7g<`tggR0$JXeNm~#*{jqU6fn|4F=*7*$BM6oy zdU-nI+Jri{Ec%+3R4^i5>*n^Pv1}`wmGVRFg_Nt-gl0y;a#czkcNYEc&=Vvl17}UW z8~l?uv%t~Nug$W8`$}*6TLrA78e3rj67cR%cL^g{PoFQ_J!zFthjRP1j^z&*3y+hh zARR4K)SQ@M#xoCAIE?UREQotePP6=5^jeIYc|JFyKf7`^oi(6_HjNJWuV9v5WP5ydFICD2j z02G|e!4yCn{Cn2J8$SI!b?h?SA+bw|F7{RVL|9s#t&#n(YqzvGCqDK|T>d983;z8( z7f3>>B|TR@$ZpJ)R`9w-U}cyy51rA7;{@3#~ho5^k92J&DIhB&!#FLw>*ZA;L?vrW@yL1FN{LD415 zQ7x`>H7K!jX-)osE6~kGA50ZTAlO@K%mL!xQuF=$eh=hMd}a3wUNt0|8Io_{HIkXn zse}Q6F5@1KdhwUSEX%6Q-Qzs~+Igph6x4vh$yQhnF3S!S`7`0Xe&@FGzS%uasIpyA z2dGrFrl2z(Yo~ecAn|U6NIa`T6pZ(de@0{tKxq7?2!434mXC+YQs27ovr0@2cNCQ(6L@rHYn!C+k1y+S=r1g&oLo4pz#fD7|(Wql3Y=% znJ+CN-w17_KQ$MkUu+MkkHCj?GrcDG;Ms(Ks-$a;m2RPRom^e_PwExGs^?ICJb@(u zA`q`}?e)GyL1VjAahKKK#<}KXGDk^uEBGg}mU_mc^5?>RxhctA7$sauB( zNUK4RZICMD!l{Cs1yV{-r`n^U7S!KcZ^L-!nLu!e>ib7!P(9~?Jt6u1yUw-j76qkd z69DGgFBu?GKTZA8Q?2fOza^x+T(JqAMj9VJ*q`Il-=1rV@lb~GnSQ%x+$@ADB8(S% zr`$VoED@9X6tlVfO!bMeZz2eRWBEUrG3G6m`Zn?!U-Rmp2H6NS6+*ATu}&I)t&i#3 zFG>I#?{&|3*(7fw+q#y0CEn{?mwSZfb0`oI* zpW(24S3Q;+{ts8L>L4Wyn7JuRJM)M1D1v*e1^J6pn>!gqy@rZ$)radAklD169FUFM z8H6`T;&mzJcRs^B#1_Y@M7;~Rn9L!wTvy#Yo|fMaWTD^>i=08l%Fo~;>AAQ& zqjAQ=UIcGYNpJVa>N9UTr&gjT6B69Kj5=s5E1@Py3+Fek=;&9_uXKhMnm*N80c3V3 z!16MEbq`#I$oKV_i9mS}G0WS4uP)p&HPXX&nBKipR?$Yu3v>I?)qGR)~fkmtP!Qxe% z)17R>BSF`a_v4rJ(Fivv0il~4+egIZjcn?$FpOPR#k+;^k#YwgE7Zbm!!p|#;;of_ z50FZ?_dqEq%0p5OH__6kpcN??sgGL`fAUncyd3W6lGI_aoE!nO)>I8K(oy|<+5D`i z2gX@{ap1E~gP~ahKxlmo0ord4+3yFO#NO*3m{8<86nf_YMb+(zO$&%{w*Lb#(5tBMk)O-woAXZKP+x$Vw z8z@s8bO7~c954rS?x%YFR2*ft6P0ir`r);hcc_O3FRspq!vwRp-i_i^<+nB98q+9kz$ z*`#OMUCt4_i%8DWTnQX0w>NmX2V44Lkvhb)WK8E-Oz5)eRHu|2WYV?2lY4SD@1-U= zLmqYiW8Er2na}-(*&!th@(}JS-bYL-YkJ&;Ae%<%o|M*Z|CMK04Ol_&6O{hp%W}`q zhvMt6SlE|dOI3J`hmbVeNOyctnKlr&S$^Sepf_+Cc!{hJDzyvL_j4k_@zpU>ZU_4= zmAiaC3#&I<(x%^>)#okITU8^_+oUs|)VI5Q`RAHs-~tr-<-w@x?1&(>h%SC1GksvV zagtjY7fHL|2pg`dF>gG_ce$$FsIz77_sq8k3MTGP)SaveSMNGmCy_I}ftL5sDiL#k zi`9!J1G^g4-;vTuv|1n~(0mTskC|Nag*2-Qc`&8pPlJ!F2SK6`WDAgj$ZC*Xh`Jq5 zKPT-0ZaOWb;X$T^H&>$=$9q|X9>qK8g=P$eGKsDk;UiOTViJ{??TzzvH5i8qA=%7) zafk(jL4l2zy*C%2oT@v1db|^jA6WQ#gdY?m2*Xxr#ME>Q@-pWLD?JJ+w7{F#?*YSD zYlBq(aCbhz4wl_%B26VDh=W2cD4UQ7@lrGVLUO*}FfkbgEl&Xntffb9*g#VA{1yI{ zGSHRII4nd#5q$&WjdP;tt(8) zCVDG?lb+{_@pOaf+%Q012yg8gF`}x16`dxSt931WaD{!FP2#hmL`sM1CI;XPcB}JN zbdl0RW%um@T=jnDnlvJ>>Pp|N4rfb11W22H31?$Km@GX)@)}9;h3Gnaw35Sc9EV+s zZ=hBt_WRYEO+Tu6LugQYspEV0)yfy&fUga~yz*l~A`a|ZYg@Acc_twfX3;VsT)KJ7 zjBo?sET9qev8CoWK$_?#S3mh@zY)FJ_%?0##l5B1lirO!OM@tBE|jAZuLsP;0}9eu zU{F|+gtJA;Yo)b6DxndZ82O~l=mls(uG7203s}$Mn9*(;C0@u3U4^(C!MnWl-sf&- zLOBaU`z%<3Rnpp3`S5ZlJ!gYi)El-Wr{7@m>i$X%Zi01^oM92a#p47?YNkkF)K8TP zAJR*CW5$5|5q7?+Y4Ea|R07?61fpYQK_d&@Z)p@f=%%v57HE!1b<33itf zDjevE=i=rWU`O;m4WxKWKz>FShEk0~5=Mj1g49}-z0K!Ctye>vqeze=4a4Qv`*q1r ze8f`bacq^Ft2bM3`c(rPh{o}=u@_tZ9Wfu{kpK8Y;D2W!k8uM_;+8|UE^KdAV}+&F zVnyix{!4&SP?)`_`!Cn@Z(r&7vpdXWsu8JzAZ zB=rRk*`GmwNCXbzvA6lb`TBnin*X9}W|?^G$zB84 z>dzA?*Z=#y|3_Os*q#r+Cfg%2m|tlmh8UGXqiB{Atd{6l zwfp|adq*CL5(-ChLqj`gt%Kz2>5&vH$Omutwhvgn=t{D>3PwD(`wL z5|{!^`Yf+B*Bqlumx#p6v*J`?uaEowKMYE)(9K^{bTK z&;qn1x2EIT|F*3Err`h8!(NriREE-})D*WG4AW3uk{+mH0@Y93RQ?0JOM>C}uJDun zcq#oKgZbBwtc4^F?C|CtR@Wp7${d)jlfYYvE*yU{^Pl&=0n*|ODz+9Sy#F#Dmypko zhGGFEV6-jB)BvT|{KGU4d;s>y*@X0O|FSwi+#vVeAHTN0hZ@$;^nCUg3Vm*-o%SQf z0(v~J7m4$FGEC!N9&;k_9qEfG0V%WvqXV`~M>|gR7~*|H%&4k(PL+>X3BkjQX!8Cu z=XaQi@#m>4asS)|`yW<=8r503ifpYMkAduG4aBJRPh&y85rBa&7!&mVq#*vM^$_@! z?4UXEmQ-~hObYGy<-F4TpKo7!1Nxp(^ytRFY)cxeKo{$d3K#3HVi9ofV3*)+m;z)C z*A_}Z*#B2w|H?8;-tZ0jm(_fhM)~pP+s&y%>GXktx6E$33f9f=zxM>d?sU#d zTn!8Vm#2U|;r?B6w8$<@%vpD$>vopXfA0x$;-1KO*Fo_=jluC}k{l~D5YeUm;q?N` zP%5m2R$G$Lc_Q>r>`FGM62V|sR&1#EFMHxCcab?DG>RR%6@JyudFR+HE;9oC8GqdS z3?kmK$MyK+zgU?MH_lzV?fD~wf(d9U;ES@Z_Lqay!j(phW!mwYW;|&_&H(6c72uAs zVeZ3^`QXl&evRj<;}xD_7Q|h`qZDFDtiKHEYv0A0)cSfAj)BX*oF0uODWk+-30!>C zFE&@{mQHP@+AF>qKU(2bO4#2v4n9ZwE&;JN?F(*87LEaohU>3@q}Ff0#~hWhl{)+WnF@& z0dJ0BBnR4rG}oUAp+%MGEmligFOH)I%j6MQKqLYTlLcsFL8KmXL0-s%y;*~SFT^AP zv3I|DRx^QD3UTzJ7_o=N)GlH`jL}l8B%JNn4j7tnz+5XRtU#DUgj2PP5nuEUs^4Th zUIYNZ%L!|3z_Dq*khIBCjQb5-T%Pj5hI}|^0`MOTOq!kPXHkGtN2ovmI#mKfnl0QL z@+^BRYvC)A1~Z6yvZ1$ItYxORW+YwjEsv$LCS*)K`p! zjYB?KWQVu|V&Oz`yMuDI;732H{2}o1%pmGej2hx+`J^lbhRwA|7>Nb`%sVJlbak{N z@2JeIYSG3cF}m1!T)I!*=?AzF<;|qpDnq&J)dlE_e-Tdg3*KTtsK~Gk7@dwF7{^xY z7n+U_ca_=pTo>{LRWWb{rD3OnuL9hGasw1@Fa(&6KlX%%@5ghG=X*bzlEW7IR|P{j zi@(g}!)}^_qN9~U;C{s@jv_qr?ys)JoDhBKa#!Az=yBweI8czPfS>3C|_x zi_&)5 z8a}VDFAAD8i>eoQlLmBDE(8`vi}Fvc^4_$Mp?8JXB8Kz;!4J|Lo_P)RW|(*{JFPtr zALfllEaee2H=nl;Q378TTKA;kbYbUWHFmtlt5gqSmeAn;yJ%sY?EDo^C+l)3F~W(2 zZhiz`s*P8^7?zk{bf3#_zO&-b#mAm?;Fd2g_)5^Dw7cQ##VEOsp@=f$z6>IUW86El z>ugYrSl^pzPx1-X27?URjm1pae~E-9gK`(LlC#_FLkhKeD)yPYwSnQJk3>BJ_>N(4{C!gG}r z&YXk2`?Bz%S0kGD6kzx{f@pc6NGAkwfu_|~vT4-1`ZL0H6O!;8p?M$2V z_fbVMFY8jnNG%99org;rWrlS*5w1`e&HSB=xXw2*Lj_d1q$UY`7LCYX;!tx)LOP3* zU~KLI;J4`|Anq#DDS>WU@^bQgX8zHdggA}h^#Zm_7m1*Mh(?^h1!f1t@>mc*w!vV} z^eEla907QM5&jgX-53pGcwkbxL4+k9u{GoV8J<9&;ce;!foR+V(49pIVBvvj)WB5P zqrf=4qD8e|FGg+W0Eny#fM>3V$m@ff$k=3z^}wn@GX=y6vUFdX?h#?C1gn=i95sG( zqyy~QU*b#)&@}koUxC!1lQk1NEegc6@_-Qvo?|bHd-rGwk}wNM!mEnS5#T!|9)B5t zksKN&J*S;X=5R%d$-Cfd1NJ@8ubV$cYi&D}k-Q7~s zLrY0F(j{FYAV|n>kMHq4=exdheb?_FYKD29XYaMwTKBqFSS=P~!JbdT<}yL34dlqr z50>v4(l(YTf*YD;n=7AFcNdr6f;D|%up^L60^q-rJ9!HRLbkPVQppf@u5;5=TLwK> zS`yF!II0auL%>`NNLQZH&KG2eXl05ob~Ty-F{M3tCTA}ySt(D^(0<8?tZ%?2cBv^} z#0d~dplrKiOto*M!weIF&a?bsHlx{6YG3*|YVV6;FMK@-UECvO4~Rhoj0|Qw!e|NL zcgdkEC`iX;zfliKD-D;J3(zQF`-L(yB`&d10?btR`Yw|8hAsWHAk3DgRKcC8)POh1 z5V^D;q%eZLG}Qdo;o|;%y~I_1qaQ?dL24s1(AGV1KP*6EBbR2~G%tuiM#_AsFzuUq zTU%FQTs~kHY^pu4?Qhr%${Tvk6RY-mW0Zav@D77&fi|EdN^uQ7RQzC!|A33LYxtJN z4=AFua*&^?ht}4roCu;%Rlgd`K@O$+qNUcnbg!H#-!bRjh$<&sSWS zxuh)&VA{Q=C0dUg$g?HT2U#5jY>};UqXUd7s*^$c>f;_9je?y50RoWJ-3g+n`$Y?t zmnEQ<0DOXfD~Xn|CZVsipjHq(2XzMgB-+HLZLbxtuVDsV+cKWL4hlKE5YBRp?gO4k z$haj2Fdt8Li~&4{=K*^G>zjDf0)F&|-^W?SRKuawj{$fhXjQ7inS)@r1L2IVo6%a6 z!INNvbE4uUcd!?Css5YJ^uK*kK-D-Ph9|H@3)h*a)XyEvrN%Tfb=iN2?8%H!#ZXp z{^NK3PiXSn%Ndt6`A)F>W#MOdOZ)-!M{+4~za1bA!8OI;9S>rANHR75TbKGT z9u*(rK!Vj=l5*iofESDNYaQIn{((Cs;HeHgUZ{U1cmCVG1h`@Izr^S1v79pQ9``M-;+vy@p-;v!Ew$fp*|2XF{bpUDP9TZq~{~u7JJ-jt@493*c2s01k;L2W85f4YRwz$w_gN-p*P z!_^gAaY7KOej3d-=G0ScU#9zBIz+jP{x5;}UBAqLlNuZUFMIoEs{%SHD(&YnypP^g z)j8h!36+Q&?v2%&J=b}W0D`5z-}N1y{~|hif%<=d5Q-S%0F?KI^RJ}_nkz83=NC(~ ziqn>Lk465v`Tw0P_b(_y7a4$6rUy`qu{_BBEXv`~d{{?&f zeE=|!F-ZAMj{G@>!Q@y=qN!57wvQujI)YMvruYFZ$EYPt32|% z81tTi>C=}QSKvSXv!-1D3^JIK#7+GtyYkEnWD z1SzzCKzjM|5|n&>ThF7a&@+6g3Q`=5fAw53*#9LnK-#E+5Wnh7#z5;cUhWH z{@Kib5j2WLB#<^>VytjAtbZ^eR9CgBNRm&2u=k(zD6v?O)R8OeXr%QAZU5UxscD*A zMWz2(`o>uYUG}rnX^T1&KAF@o)JXVqX8!*~1QPHTh{!b%5#6(+iJ=nh(s!Y=T$q1E z1Oe=gnhA9!4WUzXy} zVxva4k7BRC_*B5ERqH~#w_FbcRgY!gScIR2{UwyM0PDuGKA`@$#rX5LfUjtS7k=fw zX9p}5S!{*1wRF9t@&Cwrcn8nR9Dn=Y?36$M_djl|&&Xu{2iaq{u9x#4p%rABU}gDF zCjXHd@Q@fR3hGdSsrdh)(6Wk9eL(AzRL}yY-fJsusvGnhH`36KKl@L}fx;fhtZb^{ zP}u(w!4NA!H80n-qLxwqj(>Eqo-)U1ub;o0Q*H1^*q(tKaY5-e|6g1354$7Ag)AL? zyO2;}V81aCU;Aszt-jhq{-3Q0S8$ z&$@Ku^6+?gcW(Q)aj;u}o(&H4+3tNPtgEOZSsRwIup4753GK*J#RV2taB zuyRw`z2bvX`w}xvPzqYzy%E} zmKLkKPXWdOwLhRpX!i?%$+d-UgQHav8vu+Kwd~g?1Ey`}>@cBEl-BNpo!}%4jBP@t z^>80lX{mUe2jCol&W5~!W0qQjwrwtCFv0uJLQdcq>508Qz(nAo^lb-<4G1JFmjEy( zvD^oQ(QXp9<^FEc>Ta|8UWuzc8T;wTlxHD1%yzyAp!6RbmBY}f1h+-tOltpjqi=n* zuPUR4;Ge0Tez!yz6dqlcTt5b^5AftNkC^;Aw@Xn0SE0XXVXO(RLj-$%u4xguh#a0U z8~Aym<&#_Q4|=@;vs9YXm=6cU(k*b@?ZAD15B~o%ur3D)=yFmr;Hp6xUwyJBaJy>R zJNcKV1d>eqG=0gn_Ah5bLl={ro^6wWphfKSGfhSh!+LlDQyHkR1MKz@84c(;u(AJo zy+pJ0#b0D{scLTUN8D^UPkp}!Kyp3Mp!nn6$=Aqe&F>dL!R5;hIv$DY*eoir$NYQ~+Q3d7YlAQf(*+EEc0t(0$KqqiH*4LQ0d2`?TI6 z&p;PO=r&#t>JckCN?bIL8wr8?X~^F&=jk9KKf-CqlOYL+YU8=?c; z^j;B^FYYdari=i`&Qvj*kyU7%Ge#M>uY~}2dfztP5WU1vGJG);z@tgnE`u8S4pk($ z{GtmSQ#jCg%t#GG(|aBAmKH(!LMb584ej-(VC8J4A>f{JK|vXz2e|6%Zg3)-E1ij8 z;F@1F=chDVU;t68lNHrf|6m4{Xh6dKU++Fiw6}B@+a*=7cL(lv#BVZiDkN8w8pLwY zf!92(en3J-Fy-Oy4m|OF>AgjOZd&Iu4QbOrBmpjM;H*r+n9og>5$%6)!3Zt zXW4ytd;iXz+gsd1OY%Q$to9A>``~r|5C!e0^>8TS#9q-%z8Xi~k;Ox+d*UJG%T#nx zHc~$F`tpTN)}s*Ts4XiO!5NIky8c4B8xyQQX}Un3UWRU;1x2X$eytEKW&r>$JbOl1hvWAUq8Q( zi;H^-0)^RBQeg~?P|zhfE;CaZk4Yn|tLrJPMTQVGN(IbWv?>NMOO0xCIogd3QQs7g zqb1f#Dc|+=_4qjN-ATr|dPj0RcB8a+@82`Bu_?(lg5hkrKp%&Bt+l94g+%z)8#KD) zEHN=P8}Gq-Z+BqZk|0@0U6qCC$^nGA;%_ViOO7@-H*tayPAN5g3EEUaPa(X6yBi&^Yw{0vk5igAhSk)+$^HEmhF)ZR(dFo}fXdsk$ zo!pHSZ(XEk9%ygu9^)zSfwArQ{H43F(LxToqDRm%|IuiPF=#fo8M?%>ChsqzUc-37 zk5xxG!%UZ0_sC|U%$g-Mm*rsrvb%%X`!GVNW~6`iE-afAYOyRu-szZtD!we0o^6(e zS$sLv{_>SGfnfZuGr@9z%YtS=)e^M!xc+tLk>NH$HZkPYGIkkg+27U=Hnk+Yk3PR_o=OVy*OU#d`* zH#_oj?G3Jd8F+)m+7$9|5{3F1b%2ZNqkiO8XJ145}ZkqV@NGa36<(aNa$uix*ZK^ILe`YP5m5w@QUm|esr-0C2AvjnW-sPbjh|G z27ZaI`qo0y-%3&=y)OzMV%z9pDEO{iO`@Fo#S=$e~wx}jD zLh7&#lZk#*_?(*Fc70v9zhAb{<3p<8W8wZ|<=SDED{w0U8omTa5Bs$QtO65h;+pIj zF4<1euRV%Lq4|d;UXcvbmuz$R-~k0c?j9|woEfe}w3fPjkd8XP7*d-B?;#FrEscml zP|+nskbZ@2g7p9KO_-X)><3l;l4a8qmR7j$$zw3dRaTtrZQ0>MewS-{?1#0N?>l zOcJ@;oFp8G=7(?ewOksA=LSEBwt#@KWp}7e?grq{hN+(vMDC<8do#EnTdt4s%M(&^ zNK>1Cwe5OYa+Ylt@`!k>mZ*lhMBj7l^GL`CJ)CQEY)da94FUI> zLm0p{*Q}DLM4+A+WuMcKu&U1sp2Ttf+j~y(KG6Q7{5syt*iN(-~5 zlhR$Fj#(_LqA-tRNnR1fS$>X081M>%I`%XK>E(p zwzYh7ai3MUuAjEqddyU#>?ukjN2`-mmQ1E7&srh*?J;ynFq>J>ryJ7s7!mo`sv+xk z9t}OpO_}p!{U@OZ^`Dx4?C~VhPVmmq#?%q;W(y|sc6+k?;&c5Wak+6GON{-g7BfC{ zViV8AFSr{gp!)OY8h@+uhF({W1T1F?YOGp_&JfyEMJnTIRDbb{;%640xG5!R=M3=w z$Ynd^=>tUl`i=1z<+j}QUgc21_~ICasgHYV@?OO8Ebj?<&(O7`ez53KLWqcJCw4jz z>hG5l4ku!V+8}YPw)yt5&1JyCEk_J#h7n|Asid~c=daXqgWb)D$;*YoMH*!8;6llL zzO#bJljKu*Sr$cI#T0ctOA)5`@76>qm$4yf3stK0=FI}za?(M6Eu4pS6Omg@eCf>C zT0Zlcw+PHV%V<$(XU3-!atGn%8lk8y4jKQ;Bqo~^j23UVP&pGiYc0;;=(Mbv7U`DY zxFw2ICaqHO?)9}(CsD?T_QvM-r+Zh9Z%J;UijKDPO`fZ=q@Cbcs=mFmpk%6K9Z~=t z9N!GedLtHw&nj`-bmL|FB}++TT8NanJ21lO1)d+>-RRiB-VyDU|RCn+sK$~lU0~vQ_i;)HSH{{_ZIX2vzZ)Hj*3IwKJq>w2^6JU>Y21bNh)A{u=JiTM-=YQ!QSfra8o-%eeV}u`6 z`;`ftA~6cc;3)om|6gb9u~I|Q1Zo2giTBVe&SZY?CIRO{d5IPd+C(#S*7k}s5Rv>oD=aVGjA99e8P@d@FoNU?HOTuIV|~| z8ncX*%Aaq8BcxXAL(Q+eL9}dY}%EbH#v^8VecH9!6A_EZ*d9Ba?Wx zi-TOd#>D@&y*gf?#>6=wJQah0uP{PyDt%D&#YqZ}`{M^!u4OM<6GYgkbq-CBu>-h& zo(`Lj+|qzv#Zeh;MedemP&nS4Oj`PxqfWqWDh&?VCTq z-a_NSG{S2E%t