You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1915 lines
86 KiB

-- ShamanElemental.lua
-- 09.2020
local addon, ns = ...
local Hekili = _G[ addon ]
local class = Hekili.Class
local state = Hekili.State
local PTR = ns.PTR
-- Conduits
-- [x] Call of Flame
-- [-] High Voltage
-- [-] Pyroclastic Shock
-- [-] Shake the Foundations
-- Covenants
-- [-] Elysian Dirge
-- [-] Lavish Harvest
-- [-] Tumbling Waves
-- [x] Essential Extraction
-- Endurance
-- [-] Astral Protection
-- [-] Refreshing Waters
-- [x] Vital Accretion
-- Finesse
-- [x] Crippling Hex
-- [x] Spiritual Resonance
-- [x] Thunderous Paws
-- [x] Totemic Surge
if UnitClassBase( "player" ) == "SHAMAN" then
local spec = Hekili:NewSpecialization( 262, true )
spec:RegisterResource( Enum.PowerType.Maelstrom )
spec:RegisterResource( Enum.PowerType.Mana )
-- Talents
spec:RegisterTalents( {
earthen_rage = 22356, -- 170374
echo_of_the_elements = 22357, -- 333919
static_discharge = 22358, -- 342243
aftershock = 23108, -- 273221
echoing_shock = 23460, -- 320125
elemental_blast = 23190, -- 117014
spirit_wolf = 23162, -- 260878
earth_shield = 23163, -- 974
static_charge = 23164, -- 265046
master_of_the_elements = 19271, -- 16166
storm_elemental = 19272, -- 192249
liquid_magma_totem = 19273, -- 192222
natures_guardian = 22144, -- 30884
ancestral_guidance = 22172, -- 108281
wind_rush_totem = 21966, -- 192077
surge_of_power = 22145, -- 262303
primal_elementalist = 19266, -- 117013
icefury = 23111, -- 210714
unlimited_power = 21198, -- 260895
stormkeeper = 22153, -- 191634
ascendance = 21675, -- 114050
} )
-- PvP Talents
spec:RegisterPvpTalents( {
control_of_lava = 728, -- 204393
counterstrike_totem = 3490, -- 204331
grounding_totem = 3620, -- 204336
lightning_lasso = 731, -- 305483
seasoned_winds = 5415, -- 355630
skyfury_totem = 3488, -- 204330
spectral_recovery = 3062, -- 204261
static_field_totem = 727, -- 355580
swelling_waves = 3621, -- 204264
traveling_storms = 730, -- 204403
unleash_shield = 3491, -- 356736
} )
-- Auras
spec:RegisterAuras( {
ancestral_guidance = {
id = 108281,
duration = 10,
max_stack = 1,
},
ascendance = {
id = 114050,
duration = 15,
max_stack = 1,
},
astral_shift = {
id = 108271,
duration = function () return level > 53 and 12 or 8 end,
max_stack = 1,
},
celestial_guidance = {
id = 324748,
duration = 10,
max_stack = 1,
},
earth_shield = {
id = 974,
duration = 600,
type = "Magic",
max_stack = 9,
},
earthbind = {
id = 3600,
duration = 5,
type = "Magic",
max_stack = 1,
},
-- might be the debuff on targets
earthquake = {
id = 61882,
duration = 3600,
max_stack = 1,
},
echoing_shock = {
id = 320125,
duration = 8,
max_stack = 1,
},
elemental_blast = {
duration = 10,
type = "Magic",
max_stack = 3,
generate = function ()
local eb = buff.elemental_blast
local count = ( buff.elemental_blast_critical_strike.up and 1 or 0 ) +
( buff.elemental_blast_haste.up and 1 or 0 ) +
( buff.elemental_blast_mastery.up and 1 or 0 )
local applied = max( buff.elemental_blast_critical_strike.applied,
buff.elemental_blast_haste.applied,
buff.elemental_blast_mastery.applied )
eb.name = class.abilities.elemental_blast.name or "Elemental Blast"
eb.count = count
eb.applied = applied
eb.expires = applied + 15
eb.caster = count > 0 and "player" or "nobody"
end
},
elemental_blast_critical_strike = {
id = 118522,
duration = 10,
type = "Magic",
max_stack = 1,
},
elemental_blast_haste = {
id = 173183,
duration = 10,
type = "Magic",
max_stack = 1,
},
elemental_blast_mastery = {
id = 173184,
duration = 10,
type = "Magic",
max_stack = 1,
},
elemental_fury = {
id = 60188,
},
far_sight = {
id = 6196,
duration = 60,
max_stack = 1,
},
flame_shock = {
id = 188389,
duration = function () return level > 58 and ( fire_elemental.up or storm_elemental.up ) and 36 or 18 end,
tick_time = function () return 2 * haste end,
type = "Magic",
max_stack = 1,
},
fleshcraft = {
id = 324631,
duration = 120,
max_stack = 1,
},
frost_shock = {
id = 196840,
duration = 6,
type = "Magic",
max_stack = 1,
},
ghost_wolf = {
id = 2645,
duration = 3600,
type = "Magic",
max_stack = 1,
},
icefury = {
id = 210714,
duration = 15,
max_stack = 4,
},
lava_surge = {
id = 77762,
duration = 10,
max_stack = 1,
},
lightning_lasso = {
id = 305484,
duration = 5,
max_stack = 1
},
lightning_shield = {
id = 192106,
duration = 1800,
type = "Magic",
max_stack = 1,
},
master_of_the_elements = {
id = 260734,
duration = 15,
type = "Magic",
max_stack = 1,
},
primordial_wave = {
id = 327164,
duration = 15,
max_stack = 1,
},
reincarnation = {
id = 20608,
},
spirit_wolf = {
id = 260881,
duration = 3600,
max_stack = 4,
},
spiritwalkers_grace = {
id = 79206,
duration = 15,
type = "Magic",
max_stack = 1,
},
static_discharge = {
id = 342243,
duration = 3,
max_stack = 1,
},
stormkeeper = {
id = 191634,
duration = 15,
max_stack = 2,
},
surge_of_power = {
id = 285514,
duration = 15,
max_stack = 1,
},
surge_of_power_debuff = {
id = 285515,
duration = 6,
max_stack = 1,
},
thunderstorm = {
id = 51490,
duration = 5,
max_stack = 1,
},
unlimited_power = {
id = 272737,
duration = 10,
max_stack = 99,
},
water_walking = {
id = 546,
duration = 600,
max_stack = 1,
},
wind_rush = {
id = 192082,
duration = 5,
max_stack = 1,
},
wind_gust = {
id = 263806,
duration = 30,
max_stack = 20
},
-- Pet aura.
call_lightning = {
duration = 15,
generate = function( t, db )
if storm_elemental.up then
local name, _, count, _, duration, expires = FindUnitBuffByID( "pet", 157348 )
if name then
t.count = count
t.expires = expires
t.applied = expires - duration
t.caster = "pet"
return
end
end
t.count = 0
t.expires = 0
t.applied = 0
t.caster = "nobody"
end,
},
-- Legendaries
-- TODO: Implement like Bloodtalons, but APL doesn't really require it mechanically.
elemental_equilibrium = {
id = 347348,
duration = 10,
max_stack = 1
},
elemental_equilibrium_debuff = {
id = 347349,
duration = 30,
max_stack = 1
}
} )
-- Pets
spec:RegisterPet( "primal_storm_elemental", 77942, "storm_elemental", function() return 30 * ( 1 + ( 0.01 * conduit.call_of_flame.mod ) ) end )
spec:RegisterTotem( "greater_storm_elemental", 1020304 ) -- Texture ID
spec:RegisterPet( "primal_fire_elemental", 61029, "fire_elemental", function() return 30 * ( 1 + ( 0.01 * conduit.call_of_flame.mod ) ) end )
spec:RegisterTotem( "greater_fire_elemental", 135790 ) -- Texture ID
spec:RegisterPet( "primal_earth_elemental", 61056, "earth_elemental", 60 )
spec:RegisterTotem( "greater_earth_elemental", 136024 ) -- Texture ID
local elementals = {
[77942] = { "primal_storm_elemental", function() return 30 * ( 1 + ( 0.01 * state.conduit.call_of_flame.mod ) ) end, true },
[61029] = { "primal_fire_elemental", function() return 30 * ( 1 + ( 0.01 * state.conduit.call_of_flame.mod ) ) end, true },
[61056] = { "primal_earth_elemental", function () return 60 end, false }
}
local death_events = {
UNIT_DIED = true,
UNIT_DESTROYED = true,
UNIT_DISSIPATES = true,
PARTY_KILL = true,
SPELL_INSTAKILL = true,
}
local summon = {}
local wipe = table.wipe
local vesper_heal = 0
local vesper_damage = 0
local vesper_used = 0
local vesper_expires = 0
local vesper_guid
local vesper_last_proc = 0
spec:RegisterEvent( "COMBAT_LOG_EVENT_UNFILTERED", function()
local _, subtype, _, sourceGUID, sourceName, _, _, destGUID, destName, destFlags, _, spellID, spellName = CombatLogGetCurrentEventInfo()
-- Deaths/despawns.
if death_events[ subtype ] then
if destGUID == summon.guid then
wipe( summon )
elseif destGUID == vesper_guid then
vesper_guid = nil
end
return
end
if sourceGUID == state.GUID then
-- Summons.
if subtype == "SPELL_SUMMON" then
local npcid = destGUID:match("(%d+)-%x-$")
npcid = npcid and tonumber( npcid ) or -1
local elem = elementals[ npcid ]
if elem then
summon.guid = destGUID
summon.type = elem[1]
summon.duration = elem[2]()
summon.expires = GetTime() + summon.duration
summon.extends = elem[3]
end
if spellID == 324386 then
vesper_guid = destGUID
vesper_expires = GetTime() + 30
vesper_heal = 3
vesper_damage = 3
vesper_used = 0
end
-- Tier 28
elseif summon.extends and state.set_bonus.tier28_4pc > 0 and subtype == "SPELL_ENERGIZE" and ( spellID == 51505 or spellID == 285466 ) then
summon.expires = summon.expires + 1.5
summon.duration = summon.duration + 1.5
-- Vesper Totem heal
elseif spellID == 324522 then
local now = GetTime()
if vesper_last_proc + 0.75 < now then
vesper_last_proc = now
vesper_used = vesper_used + 1
vesper_heal = vesper_heal - 1
end
-- Vesper Totem damage; only fires on SPELL_DAMAGE...
elseif spellID == 324520 then
local now = GetTime()
if vesper_last_proc + 0.75 < now then
vesper_last_proc = now
vesper_used = vesper_used + 1
vesper_damage = vesper_damage - 1
end
end
if subtype == "SPELL_CAST_SUCCESS" then
-- Reset in case we need to deal with an instant after a hardcast.
vesper_last_proc = 0
end
end
end )
spec:RegisterStateExpr( "vesper_totem_heal_charges", function()
return vesper_heal
end )
spec:RegisterStateExpr( "vesper_totem_dmg_charges", function ()
return vesper_damage
end )
spec:RegisterStateExpr( "vesper_totem_used_charges", function ()
return vesper_used
end )
spec:RegisterStateFunction( "trigger_vesper_heal", function ()
if vesper_totem_heal_charges > 0 then
vesper_totem_heal_charges = vesper_totem_heal_charges - 1
vesper_totem_used_charges = vesper_totem_used_charges + 1
end
end )
spec:RegisterStateFunction( "trigger_vesper_damage", function ()
if vesper_totem_dmg_charges > 0 then
vesper_totem_dmg_charges = vesper_totem_dmg_charges - 1
vesper_totem_used_charges = vesper_totem_used_charges + 1
end
end )
spec:RegisterTotem( "liquid_magma_totem", 971079 )
spec:RegisterTotem( "tremor_totem", 136108 )
spec:RegisterTotem( "wind_rush_totem", 538576 )
spec:RegisterTotem( "vesper_totem", 3565451 )
spec:RegisterStateTable( "fire_elemental", setmetatable( { onReset = function( self ) self.cast_time = nil end }, {
__index = function( t, k )
if k == "cast_time" then
t.cast_time = class.abilities.fire_elemental.lastCast or 0
return t.cast_time
end
local elem = talent.primal_elementalist.enabled and pet.primal_fire_elemental or pet.greater_fire_elemental
if k == "active" or k == "up" then
return elem.up
elseif k == "down" then
return not elem.up
elseif k == "remains" then
return max( 0, elem.remains )
end
return false
end
} ) )
spec:RegisterStateTable( "storm_elemental", setmetatable( { onReset = function( self ) self.cast_time = nil end }, {
__index = function( t, k )
if k == "cast_time" then
t.cast_time = class.abilities.storm_elemental.lastCast or 0
return t.cast_time
end
local elem = talent.primal_elementalist.enabled and pet.primal_storm_elemental or pet.greater_storm_elemental
if k == "active" or k == "up" then
return elem.up
elseif k == "down" then
return not elem.up
elseif k == "remains" then
return max( 0, elem.remains )
end
return false
end
} ) )
spec:RegisterStateTable( "earth_elemental", setmetatable( { onReset = function( self ) self.cast_time = nil end }, {
__index = function( t, k )
if k == "cast_time" then
t.cast_time = class.abilities.earth_elemental.lastCast or 0
return t.cast_time
end
local elem = talent.primal_elementalist.enabled and pet.primal_earth_elemental or pet.greater_earth_elemental
if k == "active" or k == "up" then
return elem.up
elseif k == "down" then
return not elem.up
elseif k == "remains" then
return max( 0, elem.remains )
end
return false
end
} ) )
-- Tier 28
spec:RegisterGear( "tier28", 188925, 188924, 188923, 188922, 188920 )
spec:RegisterSetBonuses( "tier28_2pc", 364472, "tier28_4pc", 363671 )
-- 2-Set - Fireheart - While your Storm Elemental / Fire Elemental is active, your Lava Burst deals 20% additional damage and you gain Lava Surge every 8 sec.
-- 4-Set - Fireheart - Casting Lava Burst extends the duration of your Storm Elemental / Fire Elemental by 1.5 sec. If your Storm Elemental / Fire Elemental is not active. Lava Burst has a 20% chance to reduce its remaining cooldown by 10 sec instead.
spec:RegisterAura( "fireheart", {
id = 364523,
duration = 30,
max_stack = 1
} )
local TriggerFireheart = setfenv( function()
applyBuff( "lava_surge" )
end, state )
spec:RegisterHook( "reset_precast", function ()
if talent.master_of_the_elements.enabled and action.lava_burst.in_flight and buff.master_of_the_elements.down then
applyBuff( "master_of_the_elements" )
end
if vesper_expires > 0 and now > vesper_expires then
vesper_expires = 0
vesper_heal = 0
vesper_damage = 0
vesper_used = 0
end
vesper_totem_heal_charges = nil
vesper_totem_dmg_charges = nil
vesper_totem_used_charges = nil
if totem.vesper_totem.up then
applyBuff( "vesper_totem", totem.vesper_totem.remains )
end
rawset( state.pet, "earth_elemental", talent.primal_elementalist.enabled and state.pet.primal_earth_elemental or state.pet.greater_earth_elemental )
rawset( state.pet, "fire_elemental", talent.primal_elementalist.enabled and state.pet.primal_fire_elemental or state.pet.greater_fire_elemental )
rawset( state.pet, "storm_elemental", talent.primal_elementalist.enabled and state.pet.primal_storm_elemental or state.pet.greater_storm_elemental )
if talent.primal_elementalist.enabled then
dismissPet( "primal_fire_elemental" )
dismissPet( "primal_storm_elemental" )
dismissPet( "primal_earth_elemental" )
if summon.expires then
if summon.expires <= now then
wipe( summon )
else
summonPet( summon.type, summon.expires - now )
end
end
end
if buff.fireheart.up then
if pet.fire_elemental.up then buff.fireheart.expires = pet.fire_elemental.expires
elseif pet.storm_elemental.up then buff.fireheart.expires = pet.storm_elemental.expires end
-- Proc the next Lava Surge from Fireheart.
local next_ls = 8 - ( ( query_time - buff.fireheart.applied ) % 8 )
if next_ls < buff.fireheart.remains then
state:QueueAuraEvent( "fireheart", TriggerFireheart, query_time + next_ls, "AURA_PERIODIC" )
end
end
end )
-- Abilities
spec:RegisterAbilities( {
ancestral_guidance = {
id = 108281,
cast = 0,
cooldown = 120,
gcd = "off",
talent = "ancestral_guidance",
toggle = "defensives",
startsCombat = false,
texture = 538564,
handler = function ()
applyBuff( "ancestral_guidance" )
if buff.vesper_totem.up and vesper_totem_heal_charges > 0 then trigger_vesper_heal() end
end,
},
ancestral_spirit = {
id = 2008,
cast = 10,
cooldown = 0,
gcd = "spell",
spend = 0.04,
spendType = "mana",
startsCombat = false,
texture = 136077,
handler = function ()
end,
},
ascendance = {
id = 114050,
cast = 0,
cooldown = 180,
gcd = "spell",
talent = "ascendance",
toggle = "cooldowns",
startsCombat = false,
texture = 135791,
handler = function ()
applyBuff( "ascendance" )
gainCharges( "lava_burst", 2 )
end,
},
astral_recall = {
id = 556,
cast = function () return 10 * haste end,
cooldown = 600,
gcd = "spell",
startsCombat = false,
texture = 136010,
handler = function ()
end,
},
astral_shift = {
id = 108271,
cast = 0,
cooldown = 90,
gcd = "spell",
toggle = "defensives",
startsCombat = false,
texture = 538565,
handler = function ()
applyBuff( "astral_shift" )
end,
},
bloodlust = {
id = 2825,
cast = 0,
cooldown = 300,
gcd = "spell",
spend = 0.22,
spendType = "mana",
toggle = "cooldowns",
startsCombat = false,
texture = 136012,
handler = function ()
applyBuff( "bloodlust" )
applyDebuff( "player", "sated" )
if conduit.spiritual_resonance.enabled then
applyBuff( "spiritwalkers_grace", conduit.spiritual_resonance.mod * 0.001 )
end
end,
},
capacitor_totem = {
id = 192058,
cast = 0,
cooldown = function () return 60 + ( conduit.totemic_surge.mod * 0.001 ) end,
gcd = "spell",
spend = 0.1,
spendType = "mana",
startsCombat = false,
texture = 136013,
handler = function ()
end,
},
--[[ chain_harvest = {
id = 320674,
cast = function () return 2.5 * haste end,
cooldown = 90,
gcd = "spell",
toggle = "covenant",
startsCombat = true,
texture = 3565725,
handler = function ()
end,
}, ]]
chain_heal = {
id = 1064,
cast = function ()
if buff.chains_of_devastation_ch.up then return 0 end
return 2.5 * haste
end,
cooldown = 0,
gcd = "spell",
spend = 0.3,
spendType = "mana",
startsCombat = false,
texture = 136042,
handler = function ()
removeBuff( "chains_of_devastation_ch" )
removeBuff( "echoing_shock" )
if legendary.chains_of_devastation.enabled then
applyBuff( "chains_of_devastation_cl" )
end
if buff.vesper_totem.up and vesper_totem_heal_charges > 0 then trigger_vesper_heal() end
end,
},
chain_lightning = {
id = 188443,
cast = function () return ( buff.stormkeeper.up or buff.chains_of_devastation_cl.up ) and 0 or ( 2 * haste ) end,
cooldown = 0,
gcd = "spell",
nobuff = "ascendance",
bind = "lava_beam",
spend = 0.01,
spendType = "mana",
startsCombat = true,
texture = 136015,
handler = function ()
removeBuff( "master_of_the_elements" )
removeBuff( "echoing_shock" )
removeBuff( "chains_of_devastation_cl" )
if legendary.chains_of_devastation.enabled then
applyBuff( "chains_of_devastation_ch" )
end
-- 4 MS per target, direct.
-- 3 MS per target, overload.
gain( ( buff.stormkeeper.up and 7 or 4 ) * min( 5, active_enemies ), "maelstrom" )
removeStack( "stormkeeper" )
if pet.storm_elemental.up then
addStack( "wind_gust", nil, 1 )
end
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
cleanse_spirit = {
id = 51886,
cast = 0,
cooldown = 8,
gcd = "spell",
spend = 0.06,
spendType = "mana",
startsCombat = false,
texture = 236288,
handler = function ()
end,
},
earth_elemental = {
id = 198103,
cast = 0,
cooldown = 300,
gcd = "spell",
toggle = "defensives",
startsCombat = false,
texture = 136024,
handler = function ()
summonPet( talent.primal_elementalist.enabled and "primal_earth_elemental" or "greater_earth_elemental", 60 )
if conduit.vital_accretion.enabled then
applyBuff( "vital_accretion" )
health.max = health.max * ( 1 + ( conduit.vital_accretion.mod * 0.01 ) )
end
end,
usable = function ()
return max( cooldown.fire_elemental.true_remains, cooldown.storm_elemental.true_remains ) > 0, "DPS elementals must be on CD first"
end,
timeToReady = function ()
return max( pet.fire_elemental.remains, pet.storm_elemental.remains, pet.primal_fire_elemental.remains, pet.primal_storm_elemental.remains )
end,
auras = {
-- Conduit
vital_accretion = {
id = 337984,
duration = 60,
max_stack = 1
}
}
},
earth_shield = {
id = 974,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 0.1,
spendType = "mana",
talent = "earth_shield",
startsCombat = false,
texture = 136089,
handler = function ()
applyBuff( "earth_shield" )
if buff.vesper_totem.up and vesper_totem_heal_charges > 0 then trigger_vesper_heal() end
end,
},
earth_shock = {
id = 8042,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 60,
spendType = "maelstrom",
startsCombat = true,
texture = 136026,
handler = function ()
if talent.surge_of_power.enabled then
applyBuff( "surge_of_power" )
end
if runeforge.echoes_of_great_sundering.enabled then
applyBuff( "echoes_of_great_sundering" )
end
if runeforge.windspeakers_lava_resurgence.enabled then
applyBuff( "lava_surge" )
applyBuff( "windspeakers_lava_resurgence" )
end
removeBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
auras = {
windspeakers_lava_resurgence = {
id = 336065,
duration = 15,
max_stack = 1,
},
}
},
earthbind_totem = {
id = 2484,
cast = 0,
cooldown = 30,
gcd = "spell",
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 136102,
handler = function ()
end,
},
earthquake = {
id = 61882,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 60,
spendType = "maelstrom",
startsCombat = true,
texture = 451165,
handler = function ()
removeBuff( "echoes_of_great_sundering" )
removeBuff( "master_of_the_elements" )
removeBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
auras = {
echoes_of_great_sundering = {
id = 336217,
duration = 25,
max_stack = 1
}
}
},
echoing_shock = {
id = 320125,
cast = 0,
cooldown = 30,
gcd = "spell",
spend = 0.03,
spendType = "mana",
startsCombat = true,
texture = 1603013,
talent = "echoing_shock",
handler = function ()
applyBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
elemental_blast = {
id = 117014,
cast = function () return 2 * haste end,
cooldown = 12,
gcd = "spell",
spend = -30,
spendType = "maelstrom",
startsCombat = true,
texture = 651244,
handler = function ()
applyBuff( "elemental_blast" )
if talent.surge_of_power.enabled then
applyBuff( "surge_of_power" )
end
if runeforge.echoes_of_great_sundering.enabled then
applyBuff( "echoes_of_great_sundering" )
end
removeBuff( "master_of_the_elements" )
removeBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
far_sight = {
id = 6196,
cast = function () return 2 * haste end,
cooldown = 0,
gcd = "spell",
startsCombat = true,
texture = 136034,
handler = function ()
end,
},
fire_elemental = {
id = 198067,
cast = 0,
charges = 1,
cooldown = 150,
recharge = 150,
gcd = "spell",
spend = 0.05,
spendType = "mana",
toggle = "cooldowns",
notalent = "storm_elemental",
startsCombat = false,
texture = 135790,
timeToReady = function ()
return max( pet.earth_elemental.remains, pet.primal_earth_elemental.remains, pet.storm_elemental.remains, pet.primal_storm_elemental.remains )
end,
handler = function ()
summonPet( talent.primal_elementalist.enabled and "primal_fire_elemental" or "greater_fire_elemental" )
if set_bonus.tier28_2pc > 0 then
applyBuff( "fireheart", pet.fire_elemental.remains )
state:QueueAuraEvent( "fireheart", TriggerFireheart, query_time + 8, "AURA_PERIODIC" )
end
end,
},
flame_shock = {
id = 188389,
cast = 0,
cooldown = 6,
gcd = "spell",
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 135813,
cycle = "flame_shock",
min_ttd = function () return debuff.flame_shock.duration / 3 end,
handler = function ()
applyDebuff( "target", "flame_shock" )
if buff.surge_of_power.up then
active_dot.surge_of_power = min( active_enemies, active_dot.flame_shock + 1 )
removeBuff( "surge_of_power" )
end
removeBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
frost_shock = {
id = 196840,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 135849,
handler = function ()
removeBuff( "master_of_the_elements" )
removeBuff( "echoing_shock" )
applyDebuff( "target", "frost_shock" )
if buff.icefury.up then
gain( 8, "maelstrom" )
removeStack( "icefury", 1 )
end
if buff.surge_of_power.up then
applyDebuff( "target", "surge_of_power_debuff" )
removeBuff( "surge_of_power" )
end
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
ghost_wolf = {
id = 2645,
cast = 0,
cooldown = 0,
gcd = "spell",
startsCombat = false,
texture = 136095,
handler = function ()
applyBuff( "ghost_wolf" )
if talent.spirit_wolf.enabled then applyBuff( "spirit_wolf" ) end
if conduit.thunderous_paws.enabled then applyBuff( "thunderous_paws" ) end
end,
},
healing_stream_totem = {
id = 5394,
cast = 0,
cooldown = 30,
gcd = "spell",
spend = 0.09,
spendType = "mana",
startsCombat = true,
texture = 135127,
handler = function ()
if buff.vesper_totem.up and vesper_totem_heal_charges > 0 then trigger_vesper_heal() end
end,
},
healing_surge = {
id = 8004,
cast = function () return 1.5 * haste end,
cooldown = 0,
gcd = "spell",
spend = 0.24,
spendType = "mana",
startsCombat = false,
texture = 136044,
handler = function ()
removeBuff( "echoing_shock" )
if buff.vesper_totem.up and vesper_totem_heal_charges > 0 then trigger_vesper_heal() end
end,
},
hex = {
id = 51514,
cast = function () return 1.7 * haste end,
cooldown = function () return level > 55 and 20 or 30 end,
gcd = "spell",
startsCombat = false,
texture = 237579,
handler = function ()
applyDebuff( "target", "hex" )
end,
auras = {
-- Conduit
crippling_hex = {
id = 338055,
duration = 8,
max_stack = 1
}
}
},
icefury = {
id = 210714,
cast = 2,
cooldown = 30,
gcd = "spell",
spend = 0.03,
spendType = "mana",
startsCombat = true,
texture = 135855,
talent = "icefury",
handler = function ()
removeBuff( "master_of_the_elements" )
removeBuff( "echoing_shock" )
applyBuff( "icefury", 15, 4 )
gain( 25, "maelstrom" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
lava_beam = {
id = 114074,
cast = function () return 2 * haste end,
cooldown = 0,
gcd = "spell",
buff = "ascendance",
bind = "chain_lightning",
startsCombat = true,
texture = 236216,
handler = function ()
removeBuff( "echoing_shock" )
-- 4 MS per target, direct.
-- 3 MS per target, overload.
gain( ( buff.stormkeeper.up and 7 or 4 ) * min( 5, active_enemies ), "maelstrom" )
removeStack( "stormkeeper" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
lava_burst = {
id = 51505,
cast = function () return buff.lava_surge.up and 0 or ( 2 * haste ) end,
charges = function () return talent.echo_of_the_elements.enabled and 2 or nil end,
cooldown = function () return buff.ascendance.up and 0 or ( 8 * haste ) end,
recharge = function () return buff.ascendance.up and 0 or ( 8 * haste ) end,
gcd = "spell",
spend = 0.06,
spendType = "mana",
startsCombat = true,
texture = 237582,
velocity = 30,
indicator = function()
return active_enemies > 1 and settings.cycle and dot.flame_shock.down and active_dot.flame_shock > 0 and "cycle" or nil
end,
handler = function ()
removeBuff( "windspeakers_lava_resurgence" )
removeBuff( "lava_surge" )
removeBuff( "echoing_shock" )
gain( 10, "maelstrom" )
if talent.master_of_the_elements.enabled then applyBuff( "master_of_the_elements" ) end
if talent.surge_of_power.enabled then
gainChargeTime( "fire_elemental", 6 )
removeBuff( "surge_of_power" )
end
if buff.primordial_wave.up and state.spec.elemental and legendary.splintered_elements.enabled then
applyBuff( "splintered_elements", nil, active_dot.flame_shock )
end
removeBuff( "primordial_wave" )
if set_bonus.tier28_4pc > 0 then
if pet.fire_elemental.up then
pet.fire_elemental.expires = pet.fire_elemental.expires + 1.5
buff.fireheart.expires = pet.fire_elemental.expires
elseif pet.storm_elemental.up then
pet.storm_elemental.expires = pet.storm_elemental.expires + 1.5
buff.fireheart.expires = pet.storm_elemental.expires
end
end
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
impact = function () end, -- This + velocity makes action.lava_burst.in_flight work in APL logic.
},
lightning_bolt = {
id = 188196,
cast = function () return buff.stormkeeper.up and 0 or ( 2 * haste ) end,
cooldown = 0,
gcd = "spell",
essential = true,
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 136048,
handler = function ()
removeBuff( "echoing_shock" )
gain( ( buff.stormkeeper.up and 11 or 8 ) + ( buff.surge_of_power.up and 3 or 0 ), "maelstrom" )
removeBuff( "master_of_the_elements" )
removeBuff( "surge_of_power" )
removeStack( "stormkeeper" )
if pet.storm_elemental.up then
addStack( "wind_gust", nil, 1 )
end
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
lightning_lasso = {
id = 305483,
cast = function () return 5 * haste end,
channeled = true,
cooldown = 30,
gcd = "spell",
startsCombat = true,
texture = 1385911,
pvptalent = function ()
if essence.conflict_and_strife.major then return end
return "lightning_lasso"
end,
start = function ()
removeBuff( "echoing_shock" )
applyDebuff( "target", "lightning_lasso" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
copy = 305485
},
lightning_shield = {
id = 192106,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 136051,
readyTime = function () return buff.lightning_shield.remains - 120 end,
handler = function ()
applyBuff( "lightning_shield" )
end,
},
liquid_magma_totem = {
id = 192222,
cast = 0,
cooldown = 60,
gcd = "spell",
toggle = "cooldowns",
startsCombat = true,
texture = 971079,
talent = "liquid_magma_totem",
handler = function ()
summonTotem( "liquid_magma_totem" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
primal_strike = {
id = 73899,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 0.09,
spendType = "mana",
startsCombat = true,
texture = 460956,
handler = function ()
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
purge = {
id = 370,
cast = 0,
cooldown = 0,
gcd = "spell",
spend = 0.1,
spendType = "mana",
startsCombat = true,
texture = 136075,
toggle = "interrupts",
interrupt = true,
buff = "dispellable_magic",
handler = function ()
removeBuff( "dispellable_magic" )
end,
},
spiritwalkers_grace = {
id = 79206,
cast = 0,
cooldown = 120,
gcd = "spell",
spend = 0.14,
spendType = "mana",
startsCombat = true,
texture = 451170,
handler = function ()
applyBuff( "spiritwalkers_grace" )
end,
},
static_discharge = {
id = 342243,
cast = 0,
cooldown = 30,
gcd = "spell",
spend = 0.03,
spendType = "mana",
startsCombat = off,
texture = 135845,
talent = "static_discharge",
buff = "lightning_shield",
handler = function ()
applyBuff( "static_discharge" )
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
storm_elemental = {
id = 192249,
cast = 0,
charges = 1,
cooldown = 150,
recharge = 150,
gcd = "spell",
toggle = "cooldowns",
talent = "storm_elemental",
startsCombat = true,
texture = 2065626,
timeToReady = function ()
return max( pet.earth_elemental.remains, pet.primal_earth_elemental.remains, pet.fire_elemental.remains, pet.primal_fire_elemental.remains )
end,
handler = function ()
summonPet( talent.primal_elementalist.enabled and "primal_storm_elemental" or "greater_storm_elemental" )
if set_bonus.tier28_2pc > 0 then
applyBuff( "fireheart", pet.storm_elemental.remains )
state:QueueAuraEvent( "fireheart", TriggerFireheart, query_time + 8, "AURA_PERIODIC" )
end
end,
},
stormkeeper = {
id = 191634,
cast = function () return 1.5 * haste end,
cooldown = 60,
gcd = "spell",
toggle = "cooldowns",
startsCombat = false,
texture = 839977,
talent = "stormkeeper",
handler = function ()
applyBuff( "stormkeeper", 20, 2 )
end,
},
thunderstorm = {
id = 51490,
cast = 0,
cooldown = 45,
gcd = "spell",
startsCombat = true,
texture = 237589,
handler = function ()
if target.within10 then applyDebuff( "target", "thunderstorm" ) end
if buff.vesper_totem.up and vesper_totem_dmg_charges > 0 then trigger_vesper_damage() end
end,
},
tremor_totem = {
id = 8143,
cast = 0,
cooldown = function () return 60 + ( conduit.totemic_surge.mod * 0.001 ) end,
gcd = "spell",
spend = 0.02,
spendType = "mana",
startsCombat = true,
texture = 136108,
handler = function ()
summonTotem( "tremor_totem" )
end,
},
water_walking = {
id = 546,
cast = 0,
cooldown = 0,
gcd = "spell",
startsCombat = false,
texture = 135863,
handler = function ()
applyBuff( "water_walking" )
end,
},
wind_rush_totem = {
id = 192077,
cast = 0,
cooldown = 120,
gcd = "spell",
startsCombat = false,
texture = 538576,
talent = "wind_rush_totem",
handler = function ()
summonTotem( "wind_rush_totem" )
end,
},
wind_shear = {
id = 57994,
cast = 0,
cooldown = 12,
gcd = "spell",
startsCombat = true,
texture = 136018,
toggle = "interrupts",
debuff = "casting",
readyTime = state.timeToInterrupt,
handler = function ()
interrupt()
end,
},
-- Pet Abilities
meteor = {
id = 117588,
known = function () return talent.primal_elementalist.enabled and not talent.storm_elemental.enabled and fire_elemental.up end,
cast = 0,
cooldown = 60,
gcd = "off",
startsCombat = true,
texture = 1033911,
talent = "primal_elementalist",
usable = function () return fire_elemental.up end,
handler = function () end,
},
eye_of_the_storm = {
id = 157375,
known = function () return talent.primal_elementalist.enabled and talent.storm_elemental.enabled and storm_elemental.up end,
cast = 0,
cooldown = 40,
gcd = "off",
startsCombat = true,
-- texture = ,
talent = "primal_elementalist",
usable = function () return storm_elemental.up end,
handler = function () end,
},
-- Shaman - Kyrian - 324386 - vesper_totem (Vesper Totem)
vesper_totem = {
id = 324386,
cast = 0,
cooldown = 60,
gcd = "totem",
spend = 0.1,
spendType = "mana",
startsCombat = true,
texture = 3565451,
toggle = "essences",
handler = function ()
summonPet( "vesper_totem", 30 )
applyBuff( "vesper_totem" )
vesper_totem_heal_charges = 3
vesper_totem_dmg_charges = 3
vesper_totem_used_charges = 0
end,
auras = {
vesper_totem = {
duration = 30,
max_stack = 1,
}
}
},
-- Shaman - Necrolord - 326059 - primordial_wave (Primordial Wave)
primordial_wave = {
id = 326059,
cast = 0,
cooldown = 45,
recharge = 45,
charges = 1,
gcd = "spell",
spend = 0.1,
spendType = "mana",
startsCombat = true,
texture = 3578231,
toggle = "essences",
cycle = "flame_shock",
velocity = 45,
impact = function ()
applyDebuff( "target", "flame_shock" )
applyBuff( "primordial_wave" )
if soulbind.kevins_oozeling.enabled then applyBuff( "kevins_oozeling" ) end
end,
auras = {
primordial_wave = {
id = 327164,
duration = 15,
max_stack = 1
},
splintered_elements = {
id = 354648,
duration = 10,
max_stack = 10,
},
}
},
-- Shaman - Night Fae - 328923 - fae_transfusion (Fae Transfusion)
fae_transfusion = {
id = 328923,
cast = function () return haste * 3 * ( 1 + ( conduit.essential_extraction.mod * 0.01 ) ) end,
channeled = true,
cooldown = 120,
gcd = "spell",
spend = 0.075,
spendType = "mana",
startsCombat = true,
texture = 3636849,
toggle = "essences",
nobuff = "fae_transfusion",
start = function ()
applyBuff( "fae_transfusion" )
end,
tick = function ()
if legendary.seeds_of_rampant_growth.enabled then
if state.spec.enhancement then reduceCooldown( "feral_spirit", 9 )
elseif state.spec.elemental then reduceCooldown( talent.storm_elemental.enabled and "storm_elemental" or "fire_elemental", 6 )
else reduceCooldown( "healing_tide_totem", 5 ) end
addStack( "seeds_of_rampant_growth" )
end
end,
finish = function ()
if state.spec.enhancement then addStack( "maelstrom_weapon", nil, 3 ) end
end,
auras = {
fae_transfusion = {
id = 328933,
duration = 20,
max_stack = 1
},
seeds_of_rampant_growth = {
id = 358945,
duration = 15,
max_stack = 5
}
},
},
fae_transfusion_heal = {
id = 328930,
cast = 0,
channeled = true,
cooldown = 0,
gcd = "spell",
startsCombat = false,
texture = 3636849,
buff = "fae_transfusion",
handler = function ()
removeBuff( "fae_transfusion" )
end,
},
-- Shaman - Venthyr - 320674 - chain_harvest (Chain Harvest)
chain_harvest = {
id = 320674,
cast = 2.5,
cooldown = 90,
gcd = "spell",
spend = 0.1,
spendType = "mana",
startsCombat = true,
texture = 3565725,
toggle = "essences",
handler = function ()
if legendary.elemental_conduit.enabled then
applyDebuff( "target", "flame_shock" )
active_dot.flame_shock = min( active_enemies, active_dot.flame_shock + min( 5, active_enemies ) )
end
end,
}
} )
--[[ spec:RegisterSetting( "funnel_damage", false, {
name = "Funnel AOE -> Target",
desc = function ()
local s = "If checked, the addon's default priority will encourage you to spread |T135813:0|t Flame Shock but will focus damage on your current target, using |T136026:0|t Earth Shock rather than |T451165:0|t Earthquake."
if not Hekili.DB.profile.specs[ state.spec.id ].cycle then
s = s .. "\n\n|cFFFF0000Requires 'Recommend Target Swaps' on Targeting tab.|r"
end
return s
end,
type = "toggle",
width = 1.5
} ) ]]
spec:RegisterStateExpr( "funneling", function ()
return false
-- return active_enemies > 1 and settings.cycle and settings.funnel_damage
end )
spec:RegisterSetting( "stack_buffer", 1.1, {
name = "|T135855:0|t Icefury and |T839977:0|t Stormkeeper Padding",
desc = "The default priority tries to avoid wasting |T839977:0|t Stormkeeper and |T135855:0|t Icefury stacks with a grace period of 1.1 GCD per stack.\n\n" ..
"Increasing this number will reduce the likelihood of wasted Icefury / Stormkeeper stacks due to other procs taking priority, and leave you with more time to react.",
type = "range",
min = 1,
max = 2,
step = 0.01,
width = "full"
} )
spec:RegisterOptions( {
enabled = true,
aoe = 3,
nameplates = false,
nameplateRange = 8,
damage = true,
damageDots = true,
damageExpiration = 8,
potion = "potion_of_spectral_intellect",
package = "Elemental",
} )
--[[ spec:RegisterSetting( "micromanage_pets", true, {
name = "Micromanage Primal Elemental Pets",
desc = "If checked, Meteor, Eye of the Storm, etc. will appear in your recommendations.",
type = "toggle",
width = 1.5
} ) ]]
spec:RegisterPack( "Elemental", 20220301, [[dGu8qcqiufpcirTjG6tOcLrjQYPev1QqfPxjQ0Seq3ciP0Uq6xIsnmurDmuvTmrfptOQMgQqUgQi2gqcFtOk14asY5qfQwNqvK5beUhQ0(asDqHQGwOqLhkuf1efQc0fbseFeiPOtcKuTsuvMPqvIBcKizNOk9tGePAPajfEkIMQOKRcKiLVkufWyfQsAVu8xcdwKdt1IH0JP0KH4YkBwkFgWOf0Pv51IIzRQBJWUL8BugUqooQGLd1ZbnDsxxQ2Ua9DGOXluf68cW8fk7NOn8BYYqI46m8MdNZjhohFoNdLZCMZCC(bvgsnGOziJCBghygYYjMHeuYpIvQ)gYipGN5iMSmKqwhBNHmu1iy8u2zdCAyhLAzezdpI(76Xkl2BA2WJWMTHeTFVcQxgudjIRZWBoCoNC4C85CouoZzoZX5pEBiHrZA4nhqrogYWdbzLb1qImO1qck5hXk1FzIm0j8sYhOuo2gkt8hOmLdNZjhjFs(INd9cyW4jjFGALjq9YYWrmSRtMGt1RaGuO62mc0ERnSm1yyzcu3UwhhqGYePYWez2IgMk5duRmfpebrMaLA6yyzYlezcusatMynzsdNmrQmmHm5a(vudzeM1UFgsqzqzzcuYpIvQ)YezOt4LKpqzqzzcukhBdLj(duMYHZ5KJKpjFGYGYYu8COxadgpj5duguwMa1ktG6LLHJyyxNmbNQxbaPq1TzeO9wByzQXWYeOUDTooGaLjsLHjYSfnmvYhOmOSmbQvMIhIGitGsnDmSm5fImbkjGjtSMmPHtMivgMqMCa)kQKpjFGYYeOK4Xz76qKPfC4aKj9iMmPHtMCRYWY0bLjpOFVJ(Jk5ZT6XkincplJa1vUZXAOy)iwP(h414YJ6)kLgHpc)f7hXk1)dQ0vo6pejFGYYeO0GtMivgMiZw0WYueEwgbQRYuV(bHYeKrmzYrqGYeiV)LjyKdYsMGmwrL85w9yfKgHNLrG6AUCZU9dgAXEtd8ACHS(JEfcnQd1(pXW9i9yvSyqw)rVcHgK9UE)eq2hCLk5ZT6XkincplJa11C5MnuzyImBrdh414Q(VsPqLHjYSfnmDLJ(dbCEy)qel4kL6iiqQL1lfeXpwmSFiIfCLsDeei9kqZjCoFjFUvpwbPr4zzeOUMl3SBhEI9JyL6VKp3QhRG0i8SmcuxZLB27hXk1Fb67qnWRXv9FLs3pIvQ)c03HkDLJ(dbmmA)luhdmfsTH(vI)ac16kaqeFjFGYYuCZ6D4KP4LGXjtHouMCzsXEW9YKEelqzsdNm5iiSsMIE3oOmXPA4bLPvkoaovMyLmfphpOm1yyzk(YeCwwHaLjLjtEq2HitiSo6pqTXlbJtMyLmf1)Nk5ZT6XkincplJa11C5M97bDbAhd1a)RMWIWn(bEnU8O(VsP7hXk1Fb67qLUYr)HaggT)fQJbMcP2q)kXFaHADfaiIFSyO9wJcvgMiZw0W0EKKp3QhRG0i8SmcuxZLB22q)kXFaHADfqGxJlpQ)Ru6(rSs9xG(ouPRC0FiGHr7FH6yGPqQn0Vs8hqOwxbaAUXhmpO9wJcvgMiZw0W0EKKp3QhRG0i8SmcuxZLB2rm9yLKpjFGYYeOEPdJ7rQmXAYK1HkKk5ZT6XkyUCZgKxHiGHZXs(CREScMl3SHrh(uq6FMHHcaSBxGeSGxbWLFjFUvpwbZLB2rm9yLKp3QhRG5Yn7oCIthbuYNB1JvWC5MD7DIjGHmBMaVg384r9FLs3pIvQ)c03HkDLJ(djFW8ONnZvaG5jAkfQmmHy)iwP(tDREbh48Gr7FH6yGPqQn0Vs8hqOwxbaI4hlM6)kLs4qDybRj0Wj2pIvkKUYr)HelgUxRXWaJcZeakEEMHHI2nCacKrCWrhh6xu0qYxYNB1JvWC5MDe(iyyKZFbi9GlqBa2Fc1XatHC5pWRXLh0ERrJWhbdJC(laPhC0Ee484jAkfQmmHy)iwP(tDREbxSyWO9VqDmWui1g6xj(diuRRaar8bJ2BnkiVcra0HkfQUndiYHZXIbz9h9ke6phrGgGyXJor0p6kh9hsSy4ETgddmkm6VshEiI9JyLcPJd9lkAi5dopy0(xOogykKAd9Re)beQ1vaGGtIft9FLsjCOoSG1eA4e7hXkfsx5O)qIfd3R1yyGrHzcafppZWqr7goabYio4OJd9lkAiXIbz9h9ke6phrGgGyXJor0p6kh9hsSy4ETgddmkm6VshEiI9JyLcPJd9lkAi5dMh0ERrHr)v6WdrSFeRuiThj5ZT6XkyUCZU9oXeWqMntGxJlp6zZCfa484jAkfQmmHy)iwP(tDREbxSyWO9VqDmWui1g6xj(diuRRaar8bJ2BnkiVcra0HkfQUndiYHZ5dopy0(xOogykKAd9Re)beQ1vaGi(XIP(VsPeouhwWAcnCI9JyLcPRC0FiXIH71AmmWOWmbGINNzyOODdhGazehC0XH(ffnK8L85w9yfmxUz3o8e7hXk1FjFUvpwbZLB2ethdl5ZT6XkyUCZg9zmerRJdiWRXLh1)vk1H2viEzhDLJ(djwm0ERrDODfIx2r7rXIzzShHbYI6q7keVSJIhHFfe0CcNL85w9yfmxUzJomC4mxbe414YJ6)kL6q7keVSJUYr)HelgAV1Oo0UcXl7O9ijFUvpwbZLB2Tdp0NXqc8AC5r9FLsDODfIx2rx5O)qIfdT3AuhAxH4LD0EuSywg7ryGSOo0UcXl7O4r4xbbnNWzjFUvpwbZLB2EzhuX(lS()bEnU8O(VsPo0UcXl7ORC0FiXIH2BnQdTRq8YoApkwmlJ9imqwuhAxH4LDu8i8RGGMt4SKp3QhRG5YnBuhqWAcfF2mWaVgxEu)xPuhAxH4LD0vo6pKyX4bT3AuhAxH4LD0EKKp3QhRG5Yn7GdgnSqz6iK85w9yfmxUz38juSxWwhESkWRX1YcUYlLwhqOkA(aZdUxRXWaJc3qGcwtGDIiVubaMbsnKoo0VOOHaopEu)xPuchQdlynHgoX(rSsH0vo6pKyXq7TgLWH6WcwtOHtSFeRuiThLpyy0(xOogykKAd9Re)beQ1vaGi(s(CREScMl3SB(ek2lyRdpwf414Azbx5LsRdiufnFGX9Anggyu4gcuWAcSte5LkaWmqQH0XH(ffneW5XJ6)kLs4qDybRj0Wj2pIvkKUYr)HelgAV1OeouhwWAcnCI9JyLcP9OyXGr7FH6yGPqQn0Vs8hqOwxbaAUXpFW5zzShHbYI2o8e7hXk1FkEe(vqqNdNJfZYypcdKffQmmHy)iwP(tXJWVcc6C4C(s(CREScMl3SX9s4w9yL4pOgy5eJRZwGqfFwLl)bEnUUvVGtSAe3GGohW5bJ2)c1XatHuBOFL4pGqTUca05elgmA)luhdmfsFpOlqNta6CYxYNB1JvWC5MnUxc3QhRe)b1alNyCHxb8tOogyAGqfFwLl)bEnU8O(VsPqLHje7hXk1F6kh9hcy3QxWjwnIBqqWnhjFUvpwbZLB24EjCRESs8hudSCIXfob8kGFc1XatdeQ4ZQC5pWRXv9FLsHkdti2pIvQ)0vo6peWUvVGtSAe3GGGBos(K85w9yfK6SXfQmmHy)iwP(l5ZT6Xki1zlxUzVaMG1eA4eqLHjc8ACr7Tg16)l(diuRRaO4r4xbbnx(5SKp3QhRGuNTC5M9CSgYHUNzbEnUO9wJoBi7kabmKzZq7rs(CREScsD2YLB22q)krOJdoOk5ZT6Xki1zlxUzdvgMiZw0WbEnUQ)RukuzyImBrdtx5O)qK85w9yfK6SLl3SBVtmbmKzZeOna7pH6yGPqU8h414IxdpyOJ(dCE55w9cobctPT3jMagYSzaroGDREbNy1iUbbb34d2YypcdKfncFemmY5VaKEWrXJWVccc(bfGTSGR8sP1Sy2ZWiG5jAkfQmmHy)iwP(tDREbxSyUvVGtGWuA7DIjGHmBgqWpy3QxWjwnIBqqZLJaZt0ukuzycX(rSs9N6w9coWQ)RukHd1HfSMqdNy)iwPq6kh9hs(XILhUxRXWaJcZeakEEMHHI2nCacKrCWrhh6xu0qaZt0ukuzycX(rSs9N6w9cU8JflpCVwJHbgfg9xPdpeX(rSsH0XH(ffneW55w9cobctPT3jMagYSzar8bZdUxRXWaJoBiBqbRjaWZvbSxidFfaDCOFrrdjwm3QxWjqykT9oXeWqMndi4O8bNNLXEegilAe(iyyKZFbi9GJIhHFfee8dkIfdT3A0i8rWWiN)cq6bhThLF(5l5ZT6Xki1zlxUz3ENycyiZMjWRXLh3QxWjqykT9oXeWqMndyEIMsHkdti2pIvQ)u3QxWbop1)vkLWH6WcwtOHtSFeRuiDLJ(djwmCVwJHbgfMjau88mddfTB4aeiJ4GJoo0VOOHKFSy5H71AmmWOWO)kD4Hi2pIvkKoo0VOOHaMh9SzUcamAV1Or4JGHro)fG0doApkFjFUvpwbPoB5Yn7zdzxbiGHmBMaVgx1)vkD2q2vacyiZMHUYr)HaMW3dvmJa0CbfCgCE4ETgddm6SHSbfSMaapxfWEHm8va0XH(ffneWO9wJoBiBqbRjaWZvbSxidFfaThflgp4ETgddm6SHSbfSMaapxfWEHm8va0XH(ffnK8L85w9yfK6SLl3SDODfIx2f414Q(VsPo0UcXl7ORC0FiGZJNOPuOYWeI9JyL6p1T6fC5dopEu)xP0ZUwhhaDLJ(djwmEq7Tg9SR1Xbq7rG5XYypcdKf9SR1Xbq7r5l5ZT6Xki1zlxUz)hh6hIGWbiCHY0re414Q(VsP)XH(HiiCacxOmDe0vo6pejFUvpwbPoB5YnBBOFL4pGqTUciWRXfgT)fQJbMcP2q)kXFaHADfai4iWO9wJs4qDybRj0Wj2pIvkK2Jat47HkMracoHZs(CREScsD2YLB2ZXAOagYSzc8ACX9Anggy0zdzdkynbaEUkG9cz4RaOJd9lkAiG5bT3A0zdzdkynbaEUkG9cz4RaO9ijFUvpwbPoB5Yn73d6c0ogQbEnUimL2ENycyiZMHIhHFfemmA)luhdmfsTH(vI)ac16kaqWrGZJNOPuOYWeI9JyL6p1T6fC5dop0ERrFpOlGDmWO9iW8G2BnkHd1HfSMqdNy)iwPqApcS6)kLs4qDybRj0Wj2pIvkKUYr)HKVKp3QhRGuNTC5M9CSgYHUNzbEnUWO9VqDmWui1g6xj(diuRRaan3CaZdUxRXWaJoBiBqbRjaWZvbSxidFfaDCOFrrdbCEQ)RukHd1HfSMqdNy)iwPq6kh9hcycFpuXmcqZLt4myEq7TgLWH6WcwtOHtSFeRuiThLVKp3QhRGuNTC5M97bDbAhd1aTby)juhdmfYL)aVgxll4kVuAnlM9mmcyCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgcy4ubkR6qQEdNdOsWrrwWO9wJ(Eqxa7yGr7rG5bT3A0i8rWWiN)cq6bhThj5ZT6Xki1zlxUz)EqxG2XqnqBa2Fc1XatHC5pWRXfT3A03d6cyhdmApcmAV1Or4JGHro)fG0doApcCEO9wJgHpcgg58xasp4O4r4xbbr85ualsSyUvVGtGWuA7DIjGHmBgUWO9VqDmWui1g6xj(diuRRaIfZT6fCceMsBVtmbmKzZWn(G5b3R1yyGrNnKnOG1ea45Qa2lKHVcGoo0VOOHelMB1l4eimL2ENycyiZMHlhLVKp3QhRGuNTC5M97bDbAhd1aVgxeMsBVtmbmKzZqXJWVccggT)fQJbMcP2q)kXFaHADfai4iW4ETgddmkmtaO45zggkA3WbiqgXbhDCOFrrdbmAV1OVh0fWogy0Eey1)vkLWH6WcwtOHtSFeRuiDLJ(dbmpO9wJs4qDybRj0Wj2pIvkK2Jat47HkMraAUCcNL85w9yfK6SLl3SFpOlq7yOg414IWuA7DIjGHmBgkEe(vqW5LhmA)luhdmfsTH(vI)ac16kaqWrGX9AnggyuyMaqXZZmmu0UHdqGmIdo64q)IIgcy1)vkLWH6WcwtOHtSFeRuiDLJ(dj)yXYt9FLsjCOoSG1eA4e7hXkfsx5O)qat47HkMraAUCcNbZdAV1OeouhwWAcnCI9JyLcP9iW5XdUxRXWaJoBiBqbRjaWZvbSxidFfaDCOFrrdjwm0ERrNnKnOG1ea45Qa2lKHVcG2JYhmp4ETgddmkmtaO45zggkA3WbiqgXbhDCOFrrdj)8L85w9yfK6SLl3SFpOlq7yOg414IWuA7DIjGHmBgkEe(vqWWO9VqDmWui1g6xj(diuRRa4YrGX9AnggyuyMaqXZZmmu0UHdqGmIdo64q)IIgcy0ERrFpOlGDmWO9iWQ)RukHd1HfSMqdNy)iwPq6kh9hcyEq7TgLWH6WcwtOHtSFeRuiThbMW3dvmJa0C5eol5ZT6Xki1zlxUzphRHCO7zwGxJlmA)luhdmfsTH(vI)ac16kaqZnhjFUvpwbPoB5YnBBOFL4pGqTUciWRXfT3AuOYWez2IgMIhHFfeeXNtbSiCkAV1OqLHjYSfnmfQUnJKp3QhRGuNTC5M97bDbAhd1aTby)juhdmfYL)aVgx4ubkR6qQEdNdOsWrrwWO9wJ(Eqxa7yGr7rG5bT3A0i8rWWiN)cq6bhThj5ZT6Xki1zlxUz)EqxG2XqnWRXfovGYQoKQ3W5aQeCuKfmAV1OVh0fWogy0EeyEq7TgncFemmY5VaKEWr7rs(CREScsD2YLB2Vh0fODmud8ACr7Tg99GUa2XaJ2JadJ2)c1XatHuBOFL4pGqTUcaeCe484jAkfQmmHy)iwP(tDREbx(GrykT9oXeWqMndvpBMRaK85w9yfK6SLl3S3pIvQ)c03HAGxJR6)kLUFeRu)fOVdv6kh9hcyy0(xOogykKAd9Re)beQ1vaGGtaNhprtPqLHje7hXk1FQB1l4YxYNB1JvqQZwUCZ(9GUaDorGxJR6)kL6q7keVSJUYr)Hi5ZT6Xki1zlxUzBd9Re)beQ1vas(CREScsD2YLB2Vh0fODmudKGf8kaU8h414I2Bn67bDbSJbgThb2YypcdKLap3Qs(CREScsD2YLB2T3jMagYSzcKGf8kaU8hOna7pH6yGPqU8h414IxdpyOJ(tYNB1JvqQZwUCZUHzqvadz2mbsWcEfax(L8j5ZT6Xkifob8kGFc1Xat5cvgMqSFeRu)L85w9yfKcNaEfWpH6yGP5Yn7)ac16kabk71aVgx0ERrHDmWeSMiIbYHP9ijFUvpwbPWjGxb8tOogyAUCZocFemmY5VaKEWfOna7pH6yGPqU8h414Azbx5LsRzXSNHraZdAV1Or4JGHro)fG0doApcmpO9wJcJ(R0HhIy)iwPqApsYNB1JvqkCc4va)eQJbMMl3SxatWAcnCcOYWebEnUO9wJA9)f)beQ1vau8i8RGGMl)CwYNB1JvqkCc4va)eQJbMMl3SBygufWqMntGxJR6)kLE2164aORC0FiGr7Tg9SR1Xbq7rGr7Tg9SR1XbqXJWVccc4u9kaifQUnJaT3AdZPaweofT3A0ZUwhhafQUndy0ERrb5vicGouPq1Tzab)GkjFUvpwbPWjGxb8tOogyAUCZU9oXeWqMntG2aS)eQJbMc5YFGxJlEn8GHo6pjFUvpwbPWjGxb8tOogyAUCZUHzqvadz2mbEnUQ)Ru6zxRJdGUYr)HagT3A0ZUwhhaThbgT3A0ZUwhhafpc)kii4NYpNcyr4u0ERrp7ADCauO62ms(CREScsHtaVc4NqDmW0C5M9(rSs9xG(oud8ACv)xP09JyL6Va9DOsx5O)qK85w9yfKcNaEfWpH6yGP5YnBOYWez2IgoWRXv9FLsHkdtKzlAy6kh9hIKp3QhRGu4eWRa(juhdmnxUzpBi7kabmKzZe414Q(VsPZgYUcqadz2m0vo6peWwg7ryGSOVh0fODmuP4r4xbbbxalcyy0(xOogykKAd9Re)beQ1vaGiNyXi89qfZianxqbNbdJ2)c1XatHuBOFL4pGqTUca0CZbCE8G71AmmWOZgYguWAca8Cva7fYWxbqhh6xu0qIfdT3A0zdzdkynbaEUkG9cz4RaO9O8L85w9yfKcNaEfWpH6yGP5Yn73d6c0ogQbEnU5H2BnkiVcra0HkfQUndi4hubMh0ERrrFgd57qL2JYpwm0ERrFpOlGDmWO9ijFUvpwbPWjGxb8tOogyAUCZ(9GUaTJHAGxJR6)kLoBi7kabmKzZqx5O)qaJ2Bn6SHSRaeWqMndThbggT)fQJbMcP2q)kXFaHADfaiYrYNB1JvqkCc4va)eQJbMMl3SNJ1qo09mlWRXv9FLsNnKDfGagYSzORC0FiGr7TgD2q2vacyiZMH2JadJ2)c1XatHuBOFL4pGqTUca0CZrYNB1JvqkCc4va)eQJbMMl3S)diuRRaeOSxd8ACr7TgfQmmrMTOHP9ijFUvpwbPWjGxb8tOogyAUCZEowd5q3ZSaVgx0ERrNnKnOG1ea45Qa2lKHVcG2JK85w9yfKcNaEfWpH6yGP5Yn75ynuadz2mbEnUWO9VqDmWui1g6xj(diuRRaaroGj89qfZianxqbNbNhAV1OG8kebqhQuO62mGihohlgHVhQygbO54Co)yXYd3R1yyGrNnKnOG1ea45Qa2lKHVcGoo0VOOHaMh0ERrNnKnOG1ea45Qa2lKHVcG2JYpwmCVwJHbgfKxHaJMNzyO49GUapyhdSYo64q)IIgIKp3QhRGu4eWRa(juhdmnxUzphRHCO7zwGxJBEWO9VqDmWui1g6xj(diuRRaan)5dopEqykT9oXeWqMndfVgEWqh9x(s(CREScsHtaVc4NqDmW0C5MTn0Vs8hqOwxbe4146w9coXQrCdcA(bhnLcvgMqSFeRu)PUvVGdmAV1OOpJH8DOs7rs(CREScsHtaVc4NqDmW0C5M9FaHADfGaL9AGxJB0ukuzycX(rSs9N6w9coWO9wJI(mgY3HkThj5ZT6Xkifob8kGFc1XatZLB2Vh0fODmud8ACr7Tg1H2viEzhThj5ZT6Xkifob8kGFc1XatZLB2Vh0fODmud8ACTm2JWazjWZTQKp3QhRGu4eWRa(juhdmnxUz)EqxG2XqnWRX1YypcdKLap3QGTHogyqqR(VsPZgYeSMqdNy)iwPq6kh9hIKp3QhRGu4eWRa(juhdmnxUz3WmOkGHmBMaVgx1)vk9SR1Xbqx5O)qaJ2Bn6zxRJdG2JK85w9yfKcNaEfWpH6yGP5YnBBOFLi0XbhuL85w9yfKcNaEfWpH6yGP5Yn72pyOf7nnWRXfY6p6vi0GS317NaY(GRuW8G2BnAq2769tazFWvQiSt4f7qO9OaVshg3JuXrqmKZ1XL)aVshg3JubWZq9Nl)bELomUhPIRXfY6p6vi0GS317NaY(GRujFUvpwbPWjGxb8tOogyAUCZgQUEwbYbTHogybEnUQ)RukuD9ScKdAdDmWORC0Fis(CREScsHtaVc4NqDmW0C5M9CSgk2pIvQ)bEnU8O(VsPr4JWFX(rSs9)GkDLJ(djwm1)vkncFe(l2pIvQ)huPRC0FiGZJNOPuOYWeI9JyL6p1T6fC5l5ZT6Xkifob8kGFc1XatZLB22q)kXFaHADfqGxJRB1l4eRgXniO5hCEWO9VqDmWui1g6xj(diuRRaan)XIbJ2)c1XatH03d6c05eGM)8L85w9yfKcNaEfWpH6yGP5Yn7)ac16kabk7vjFUvpwbPWjGxb8tOogyAUCZU9oXeWqMntGeSGxbWL)aTby)juhdmfYL)aVgx8A4bdD0Fs(CREScsHtaVc4NqDmW0C5MD7DIjGHmBMajybVcGl)bEnUeSGJyLsroO6LDGgui5ZT6Xkifob8kGFc1XatZLB2nmdQcyiZMjqcwWRa4YVKpjFUvpwbPWRa(juhdmL7FaHADfGaL9AGxJBEO9wJcvgMiZw0Wu8i8RGGaovVcasHQBZiq7T2WCkGfHtr7TgfQmmrMTOHPq1TzYxYNB1Jvqk8kGFc1XatZLB2nmdQcyiZMjWRXv9FLsp7ADCa0vo6peWO9wJE2164aO9iWO9wJE2164aO4r4xbbbCQEfaKcv3MrG2BTH5ualcNI2Bn6zxRJdGcv3MrYNB1Jvqk8kGFc1XatZLB2T3jMagYSzc0gG9NqDmWuix(d8ACZJh9SzUciwmeMsBVtmbmKzZqXJWVcccUawKyXu)xPuhAxH4LD0vo6peWimL2ENycyiZMHIhHFfee5zzShHbYI6q7keVSJIhHFfmx0ERrDODfIx2rr6yxpwLpylJ9imqwuhAxH4LDu8i8RGGGJYhCEO9wJ(Eqxa7yGr7rXIXdAV1OOpJH8DOs7r5l5ZT6XkifEfWpH6yGP5Yn727etadz2mbAdW(tOogykKl)bEnUO9wJgHpcgg58xasp4O9iW41Wdg6O)K85w9yfKcVc4NqDmW0C5MTdTRq8YUaVgx1)vk1H2viEzhDLJ(dbCE6rmqZfuW5yXq7Tgf9zmKVdvApkFW5zzShHbYI(EqxG2XqLIhHFfe0CoFW5XJ6)kLE2164aORC0FiXIXdAV1ONDTooaApcmpwg7ryGSONDTooaApkFjFUvpwbPWRa(juhdmnxUz)EqxG2XqnWRXfT3A03d6cyhdmApcCE4ETgddmkiVcbgnpZWqX7bDbEWogyLD0XH(ffnKyX4bT3AuchQdlynHgoX(rSsH0Eey1)vkLWH6WcwtOHtSFeRuiDLJ(djFjFUvpwbPWRa(juhdmnxUzVFeRu)fOVd1aVgx1)vkD)iwP(lqFhQ0vo6peW5r47HkMraI4nNZxYNB1Jvqk8kGFc1XatZLB2qLHjYSfnCGxJR6)kLcvgMiZw0W0vo6peW5H9drSGRuQJGaPwwVuqe)yXW(HiwWvk1rqG0RanNW58bNhHVhQygbi4iokFjFUvpwbPWRa(juhdmnxUzpBi7kabmKzZe414Q(VsPZgYUcqadz2m0vo6peWwg7ryGSOVh0fODmuP4r4xbbbxalIKp3QhRGu4va)eQJbMMl3SFpOlq7yOg414Q(VsPZgYUcqadz2m0vo6peWO9wJoBi7kabmKzZq7rs(CREScsHxb8tOogyAUCZ(po0pebHdq4cLPJiWRXv9FLs)Jd9drq4aeUqz6iORC0Fis(CREScsHxb8tOogyAUCZEowd5q3ZSaVgx0ERrNnKnOG1ea45Qa2lKHVcG2JaR(VsPeouhwWAcnCI9JyLcPRC0FiGr7TgLWH6WcwtOHtSFeRuiThj5ZT6XkifEfWpH6yGP5Yn7)ac16kabk71aVgx0ERrHkdtKzlAyApcmAV1OeouhwWAcnCI9JyLcP9iWe(EOIzeGauWzjFUvpwbPWRa(juhdmnxUzphRHCO7zwGxJlAV1OZgYguWAca8Cva7fYWxbq7rGZt9FLsjCOoSG1eA4e7hXkfsx5O)qaNhAV1OeouhwWAcnCI9JyLcP9OyXSm2JWazrFpOlq7yOsXJWVccAodMW3dvmJa0C545elgmA)luhdmfsTH(vI)ac16kaqKdy0ERrHkdtKzlAyApcSLXEegil67bDbAhdvkEe(vqqWfWIKFSy8O(VsPeouhwWAcnCI9JyLcPRC0FiXIzzShHbYIUFeRu)fOVdvkEe(vqqWfovVcasHQBZiq7T2WCkGfHtZjFjFUvpwbPWRa(juhdmnxUzphRHCO7zwGxJlmA)luhdmfsTH(vI)ac16kaqZpyEqykT9oXeWqMndfVgEWqh9hyEW9Anggy0zdzdkynbaEUkG9cz4RaOJd9lkAiGZJh1)vkLWH6WcwtOHtSFeRuiDLJ(djwm0ERrjCOoSG1eA4e7hXkfs7rXIzzShHbYI(EqxG2XqLIhHFfe0CgmHVhQygbO5YXZjFjFUvpwbPWRa(juhdmnxUz)EqxG2XqnWRX1YypcdKLap3QGZJh0ERrjCOoSG1eA4e7hXkfs7rGr7Tg9SR1Xbq7r5l5ZT6XkifEfWpH6yGP5Yn73d6c0ogQbEnUwg7ryGSe45wfSn0XadcA1)vkD2qMG1eA4e7hXkfsx5O)qaZdAV1ONDTooaApsYNB1Jvqk8kGFc1XatZLB2Vh0fODmud8ACv)xP0zdzcwtOHtSFeRuiDLJ(dbmpO9wJs4qDybRj0Wj2pIvkK2Jat47HkMraAUCcNbZdAV1OZgYguWAca8Cva7fYWxbq7rs(CREScsHxb8tOogyAUCZEowdfWqMntGxJBE4ETgddm6SHSbfSMaapxfWEHm8va0XH(ffnKyXGr7FH6yGPqQn0Vs8hqOwxbaICYhCEQ)RukHd1HfSMqdNy)iwPq6kh9hcyEq7TgD2q2GcwtaGNRcyVqg(kaApcCEO9wJs4qDybRj0Wj2pIvkK2JIfJW3dvmJa0C545elgmA)luhdmfsTH(vI)ac16kaqKdy0ERrHkdtKzlAyApcSLXEegil67bDbAhdvkEe(vqqWfWIKFSy8O(VsPeouhwWAcnCI9JyLcPRC0FiXIzzShHbYIUFeRu)fOVdvkEe(vqqWfovVcasHQBZiq7T2WCkGfHtZjFjFUvpwbPWRa(juhdmnxUz3WmOkGHmBMaVgx1)vk9SR1Xbqx5O)qaR(VsPeouhwWAcnCI9JyLcPRC0FiGr7Tg9SR1Xbq7rGr7TgLWH6WcwtOHtSFeRuiThj5ZT6XkifEfWpH6yGP5Yn73d6c0ogQbEnUO9wJ6q7keVSJ2JK85w9yfKcVc4NqDmW0C5M97bDbAhd1aVgxlJ9imqwc8CRcMh1)vkLWH6WcwtOHtSFeRuiDLJ(drYNB1Jvqk8kGFc1XatZLB2NDTooGaVgx1)vk9SR1Xbqx5O)qaZtEe(EOIzeGo(CcylJ9imqw03d6c0ogQu8i8RGGGlNZxYNB1Jvqk8kGFc1XatZLB2nmdQcyiZMjWRXv9FLsp7ADCa0vo6peWO9wJE2164aO9iW5H2Bn6zxRJdGIhHFfeeaweoLJ4u0ERrp7ADCauO62mXIH2BnkuzyImBrdt7rXIXJ6)kLs4qDybRj0Wj2pIvkKUYr)HKVKp3QhRGu4va)eQJbMMl3SFpOlq7yOk5ZT6XkifEfWpH6yGP5Yn727etadz2mbAdW(tOogykKl)bEnU41Wdg6O)K85w9yfKcVc4NqDmW0C5MDdZGQagYSzc8ACX9Anggy09JyL6VyCOF)HIVobDCOFrrdbmpO9wJUFeRu)fJd97pu81jeidT3A0EeyEu)xP09JyL6Va9DOsx5O)qaZJ6)kLoBi7kabmKzZqx5O)qK85w9yfKcVc4NqDmW0C5MD7hm0I9Mg414cz9h9keAq2769tazFWvkyEq7Tgni7D9(jGSp4kve2j8IDi0EuGxPdJ7rQ4iigY564YFGxPdJ7rQa4zO(ZL)aVshg3JuX14cz9h9keAq2769tazFWvQKp3QhRGu4va)eQJbMMl3STH(vIqhhCqvYNB1Jvqk8kGFc1XatZLB2nmdQcyiZMjWRXv9FLsp7ADCa0vo6peWO9wJE2164aO9ijFUvpwbPWRa(juhdmnxUzdvxpRa5G2qhdSaVgx1)vkfQUEwbYbTHogy0vo6pejFUvpwbPWRa(juhdmnxUzphRHI9JyL6FGxJlpQ)RuAe(i8xSFeRu)pOsx5O)qIfJNOP02HNy)iwP(tDREbNKp3QhRGu4va)eQJbMMl3STH(vI)ac16kGaVgxy0(xOogykKAd9Re)beQ1vaGMFjFUvpwbPWRa(juhdmnxUz)hqOwxbiqzVk5ZT6XkifEfWpH6yGP5Yn727etadz2mbsWcEfax(d0gG9NqDmWuix(d8ACXRHhm0r)j5ZT6XkifEfWpH6yGP5Yn727etadz2mbsWcEfax(d8ACjybhXkLICq1l7anOqYNB1Jvqk8kGFc1XatZLB2nmdQcyiZMjqcwWRa4YVKp3QhRGu4va)eQJbMMl3SBygufWqMntGxJR6)kLE2164aORC0FiGr7Tg9SR1Xbq7rGr7Tg9SR1XbqXJWVccc4u9kaifQUnJaT3AdZPaweofT3A0ZUwhhafQUnJHm4WWJvgEZHZ5KdNZjN4nLFdjiDCDfa0qgpq8qqn4fuNxqnJNKjzkRWjthredRYuJHLjog8kGFc1Xat5yYeECOF4HitqgXKjVRmcxhImzd9cyqQKV4LRMmLdOkEsMINzvWH1HitCmiR)OxHqJx5yYKYKjogK1F0RqOXR0vo6peoMmLh)XJ5tL8j5lEG4HGAWlOoVGAgpjtYuwHtMoIigwLPgdltCSi8Smcux5yYeECOF4HitqgXKjVRmcxhImzd9cyqQKV4LRMmLt8KmfpZQGdRdrM4yqw)rVcHgVYXKjLjtCmiR)OxHqJxPRC0FiCmzkp(JhZNk5lE5Qjt5epjtXZSk4W6qKjogK1F0RqOXRCmzszYehdY6p6vi04v6kh9hchtMCvMaLak94fzkp(JhZNk5tYx8aXdb1GxqDEb1mEsMKPScNmDermSktngwM4yWjGxb8tOogykhtMWJd9dpezcYiMm5DLr46qKjBOxadsL8fVC1KPC4K4jzkEMvbhwhImXXGS(JEfcnELJjtktM4yqw)rVcHgVsx5O)q4yYuE8hpMpvYNKpqDIigwhImXjYKB1JvY0FqfsL8zi)dQqtwgs4va)eQJbMAYYWl)MSmKRC0FiM4mKw8PdFUHmpzcT3AuOYWez2IgMIhHFfuMaHmbNQxbaPq1TzeO9wByzItLjalImXPYeAV1OqLHjYSfnmfQUnJmLVH0T6Xkd5FaHADfGaL9Qrn8MJjld5kh9hIjodPfF6WNBiv)xP0ZUwhhaDLJ(drMaltO9wJE2164aO9izcSmH2Bn6zxRJdGIhHFfuMaHmbNQxbaPq1TzeO9wByzItLjalImXPYeAV1ONDTooakuDBgdPB1JvgYgMbvbmKzZyudVX3KLHCLJ(dXeNH0T6Xkdz7DIjGHmBgdPfF6WNBiZtM4rM0ZM5kazkwmzcHP027etadz2mu8i8RGYei4ktawezkwmzs9FLsDODfIx2rx5O)qKjWYectPT3jMagYSzO4r4xbLjqit5jtwg7ryGSOo0UcXl7O4r4xbLPCLj0ERrDODfIx2rr6yxpwjt5ltGLjlJ9imqwuhAxH4LDu8i8RGYeiKjosMYxMalt5jtO9wJ(Eqxa7yGr7rYuSyYepYeAV1OOpJH8DOs7rYu(gsBa2Fc1XatHgE53OgE5itwgYvo6petCgs3QhRmKT3jMagYSzmKw8PdFUHeT3A0i8rWWiN)cq6bhThjtGLj8A4bdD0FgsBa2Fc1XatHgE53OgE5etwgYvo6petCgsl(0Hp3qQ(VsPo0UcXl7ORC0FiYeyzkpzspIjtGMRmbk4SmflMmH2Bnk6ZyiFhQ0EKmLVmbwMYtMSm2JWazrFpOlq7yOsXJWVcktGwM4SmLVmbwMYtM4rMu)xP0ZUwhhaDLJ(drMIftM4rMq7Tg9SR1Xbq7rYeyzIhzYYypcdKf9SR1Xbq7rYu(gs3QhRmKo0UcXl7mQHxqHjld5kh9hIjodPfF6WNBir7Tg99GUa2XaJ2JKjWYuEYeUxRXWaJcYRqGrZZmmu8EqxGhSJbwzhDCOFrrdrMIftM4rMq7TgLWH6WcwtOHtSFeRuiThjtGLj1)vkLWH6WcwtOHtSFeRuiDLJ(drMY3q6w9yLH89GUaTJHQrn8gVnzzix5O)qmXziT4th(CdP6)kLUFeRu)fOVdv6kh9hImbwMYtMi89qfZiKjqitXBolt5BiDRESYqUFeRu)fOVdvJA4fuzYYqUYr)HyIZqAXNo85gs1)vkfQmmrMTOHPRC0FiYeyzkpzc7hIybxPuhbbsTSEPYeiKP4ltXIjty)qel4kL6iiq6vYeOLjoHZYu(YeyzkpzIW3dvmJqMaHmXrCKmLVH0T6XkdjuzyImBrdBudVCCtwgYvo6petCgsl(0Hp3qQ(VsPZgYUcqadz2m0vo6pezcSmzzShHbYI(EqxG2XqLIhHFfuMabxzcWIyiDRESYqoBi7kabmKzZyudV8ZztwgYvo6petCgsl(0Hp3qQ(VsPZgYUcqadz2m0vo6pezcSmH2Bn6SHSRaeWqMndThziDRESYq(EqxG2Xq1OgE5NFtwgYvo6petCgsl(0Hp3qQ(VsP)XH(HiiCacxOmDe0vo6pedPB1JvgY)4q)qeeoaHluMocJA4L)Cmzzix5O)qmXziT4th(CdjAV1OZgYguWAca8Cva7fYWxbq7rYeyzs9FLsjCOoSG1eA4e7hXkfsx5O)qKjWYeAV1OeouhwWAcnCI9JyLcP9idPB1JvgY5ynKdDpZmQHx(JVjld5kh9hIjodPfF6WNBir7TgfQmmrMTOHP9izcSmH2BnkHd1HfSMqdNy)iwPqApsMalte(EOIzeYeiKjqbNnKUvpwzi)diuRRaeOSxnQHx(5itwgYvo6petCgsl(0Hp3qI2Bn6SHSbfSMaapxfWEHm8va0EKmbwMYtMu)xPuchQdlynHgoX(rSsH0vo6pezcSmLNmH2BnkHd1HfSMqdNy)iwPqApsMIftMSm2JWazrFpOlq7yOsXJWVcktGwM4SmbwMi89qfZiKjqZvM445itXIjtWO9VqDmWui1g6xj(diuRRaKjqit5itGLj0ERrHkdtKzlAyApsMaltwg7ryGSOVh0fODmuP4r4xbLjqWvMaSiYu(YuSyYepYK6)kLs4qDybRj0Wj2pIvkKUYr)HitXIjtwg7ryGSO7hXk1Fb67qLIhHFfuMabxzcovVcasHQBZiq7T2WYeNktawezItLPCKP8nKUvpwziNJ1qo09mZOgE5Ntmzzix5O)qmXziT4th(CdjmA)luhdmfsTH(vI)ac16kazc0Ye)YeyzIhzcHP027etadz2mu8A4bdD0FYeyzIhzc3R1yyGrNnKnOG1ea45Qa2lKHVcGoo0VOOHitGLP8KjEKj1)vkLWH6WcwtOHtSFeRuiDLJ(drMIftMq7TgLWH6WcwtOHtSFeRuiThjtXIjtwg7ryGSOVh0fODmuP4r4xbLjqltCwMalte(EOIzeYeO5ktC8CKP8nKUvpwziNJ1qo09mZOgE5huyYYqUYr)HyIZqAXNo85gslJ9imqwc8CRktGLP8KjEKj0ERrjCOoSG1eA4e7hXkfs7rYeyzcT3A0ZUwhhaThjt5BiDRESYq(EqxG2Xq1OgE5pEBYYqUYr)HyIZqAXNo85gslJ9imqwc8CRktGLjBOJbguMaTmP(VsPZgYeSMqdNy)iwPq6kh9hImbwM4rMq7Tg9SR1Xbq7rgs3QhRmKVh0fODmunQHx(bvMSmKRC0FiM4mKw8PdFUHu9FLsNnKjynHgoX(rSsH0vo6pezcSmXJmH2BnkHd1HfSMqdNy)iwPqApsMalte(EOIzeYeO5ktCcNLjWYepYeAV1OZgYguWAca8Cva7fYWxbq7rgs3QhRmKVh0fODmunQHx(54MSmKRC0FiM4mKw8PdFUHmpzc3R1yyGrNnKnOG1ea45Qa2lKHVcGoo0VOOHitXIjtWO9VqDmWui1g6xj(diuRRaKjqit5it5ltGLP8Kj1)vkLWH6WcwtOHtSFeRuiDLJ(drMalt8itO9wJoBiBqbRjaWZvbSxidFfaThjtGLP8Kj0ERrjCOoSG1eA4e7hXkfs7rYuSyYeHVhQygHmbAUYehphzkwmzcgT)fQJbMcP2q)kXFaHADfGmbczkhzcSmH2BnkuzyImBrdt7rYeyzYYypcdKf99GUaTJHkfpc)kOmbcUYeGfrMYxMIftM4rMu)xPuchQdlynHgoX(rSsH0vo6pezkwmzYYypcdKfD)iwP(lqFhQu8i8RGYei4ktWP6vaqkuDBgbAV1gwM4uzcWIitCQmLJmLVH0T6Xkd5CSgkGHmBgJA4nhoBYYqUYr)HyIZqAXNo85gs1)vk9SR1Xbqx5O)qKjWYK6)kLs4qDybRj0Wj2pIvkKUYr)HitGLj0ERrp7ADCa0EKmbwMq7TgLWH6WcwtOHtSFeRuiThziDRESYq2WmOkGHmBgJA4nh(nzzix5O)qmXziT4th(CdjAV1Oo0UcXl7O9idPB1JvgY3d6c0ogQg1WBo5yYYqUYr)HyIZqAXNo85gslJ9imqwc8CRktGLjEKj1)vkLWH6WcwtOHtSFeRuiDLJ(dXq6w9yLH89GUaTJHQrn8Mt8nzzix5O)qmXziT4th(CdP6)kLE2164aORC0FiYeyzIhzkpzIW3dvmJqMaTmfForMaltwg7ryGSOVh0fODmuP4r4xbLjqWvM4SmLVH0T6Xkd5zxRJdWOgEZHJmzzix5O)qmXziT4th(CdP6)kLE2164aORC0FiYeyzcT3A0ZUwhhaThjtGLP8Kj0ERrp7ADCau8i8RGYeiKjalImXPYehjtCQmH2Bn6zxRJdGcv3MrMIftMq7TgfQmmrMTOHP9izkwmzIhzs9FLsjCOoSG1eA4e7hXkfsx5O)qKP8nKUvpwziBygufWqMnJrn8MdNyYYq6w9yLH89GUaTJHQHCLJ(dXeNrn8MdOWKLHCLJ(dXeNH0T6Xkdz7DIjGHmBgdPfF6WNBiXRHhm0r)ziTby)juhdmfA4LFJA4nN4Tjld5kh9hIjodPfF6WNBiX9Anggy09JyL6VyCOF)HIVobDCOFrrdrMalt8itO9wJUFeRu)fJd97pu81jeidT3A0EKmbwM4rMu)xP09JyL6Va9DOsx5O)qKjWYepYK6)kLoBi7kabmKzZqx5O)qmKUvpwziBygufWqMnJrn8MdOYKLHCLJ(dXeNH0IpD4ZnKqw)rVcHgK9UE)eq2hCLsx5O)qKjWYepYeAV1ObzVR3pbK9bxPIWoHxSdH2JmKxPdJ7rQ4AgsiR)OxHqdYExVFci7dUsnKxPdJ7rQ4iigY56mK8BiDRESYq2(bdTyVPgYR0HX9iva8mu)nK8BudV5WXnzziDRESYqAd9ReHoo4GQHCLJ(dXeNrn8gFoBYYqUYr)HyIZqAXNo85gs1)vk9SR1Xbqx5O)qKjWYeAV1ONDTooaApYq6w9yLHSHzqvadz2mg1WB853KLHCLJ(dXeNH0IpD4ZnKQ)RukuD9ScKdAdDmWORC0Figs3QhRmKq11ZkqoOn0XaZOgEJFoMSmKRC0FiM4mKw8PdFUHKhzs9FLsJWhH)I9JyL6)bv6kh9hImflMmXJmfnL2o8e7hXk1FQB1l4mKUvpwziNJ1qX(rSs93OgEJF8nzzix5O)qmXziT4th(CdjmA)luhdmfsTH(vI)ac16kazc0Ye)gs3QhRmK2q)kXFaHADfGrn8gFoYKLH0T6Xkd5FaHADfGaL9QHCLJ(dXeNrn8gFoXKLHKGf8kadV8Bix5O)eeSGxbyIZq6w9yLHS9oXeWqMnJH0gG9NqDmWuOHx(nKw8PdFUHeVgEWqh9NHCLJ(dXeNrn8gFqHjld5kh9hIjod5kh9NGGf8katCgsl(0Hp3qsWcoIvkf5GQx2jtGwMafgs3QhRmKT3jMagYSzmKeSGxby4LFJA4n(XBtwgscwWRam8YVHCLJ(tqWcEfGjodPB1JvgYgMbvbmKzZyix5O)qmXzudVXhuzYYqUYr)HyIZqAXNo85gs1)vk9SR1Xbqx5O)qKjWYeAV1ONDTooaApsMaltO9wJE2164aO4r4xbLjqitWP6vaqkuDBgbAV1gwM4uzcWIitCQmH2Bn6zxRJdGcv3MXq6w9yLHSHzqvadz2mg1OgsK18(RMSm8YVjld5kh9hIjodjYGw8fPhRmKG6LomUhPYeRjtwhQqQH0T6XkdjiVcradNJnQH3CmzzijybVcWWl)gYvo6pbbl4vaM4mKUvpwziHrh(uq6FMHHcaSBNHCLJ(dXeNrn8gFtwgs3QhRmKrm9yLHCLJ(dXeNrn8YrMSmKUvpwzi7WjoDeqd5kh9hIjoJA4Ltmzzix5O)qmXziT4th(CdzEYepYK6)kLUFeRu)fOVdv6kh9hImLVmbwM4rM0ZM5kazcSmXJmfnLcvgMqSFeRu)PUvVGtMalt5jtWO9VqDmWui1g6xj(diuRRaKjqitXxMIftMu)xPuchQdlynHgoX(rSsH0vo6pezkwmzc3R1yyGrHzcafppZWqr7goabYio4OJd9lkAiYu(gs3QhRmKT3jMagYSzmQHxqHjld5kh9hIjodPB1JvgYi8rWWiN)cq6bNH0IpD4ZnK8itO9wJgHpcgg58xasp4O9izcSmLNmXJmfnLcvgMqSFeRu)PUvVGtMIftMGr7FH6yGPqQn0Vs8hqOwxbitGqMIVmbwMq7TgfKxHia6qLcv3MrMaHmLdNLPyXKjiR)OxHq)5ic0aelE0jI(rx5O)qKPyXKjCVwJHbgfg9xPdpeX(rSsH0XH(ffnezkFzcSmLNmbJ2)c1XatHuBOFL4pGqTUcqMaHmXjYuSyYK6)kLs4qDybRj0Wj2pIvkKUYr)HitXIjt4ETgddmkmtaO45zggkA3WbiqgXbhDCOFrrdrMIftMGS(JEfc9NJiqdqS4rNi6hDLJ(drMIftMW9Anggyuy0FLo8qe7hXkfshh6xu0qKP8LjWYepYeAV1OWO)kD4Hi2pIvkK2JmK2aS)eQJbMcn8YVrn8gVnzzix5O)qmXziT4th(CdjpYKE2mxbitGLP8KjEKPOPuOYWeI9JyL6p1T6fCYuSyYemA)luhdmfsTH(vI)ac16kazceYu8LjWYeAV1OG8kebqhQuO62mYeiKPC4SmLVmbwMYtMGr7FH6yGPqQn0Vs8hqOwxbitGqMIVmflMmP(VsPeouhwWAcnCI9JyLcPRC0FiYuSyYeUxRXWaJcZeakEEMHHI2nCacKrCWrhh6xu0qKP8nKUvpwziBVtmbmKzZyudVGktwgs3QhRmKTdpX(rSs93qUYr)HyIZOgE54MSmKUvpwzijMog2qUYr)HyIZOgE5NZMSmKRC0FiM4mKw8PdFUHKhzs9FLsDODfIx2rx5O)qKPyXKj0ERrDODfIx2r7rYuSyYKLXEegilQdTRq8YokEe(vqzc0YeNWzdPB1Jvgs0NXqeTooaJA4LF(nzzix5O)qmXziT4th(CdjpYK6)kL6q7keVSJUYr)HitXIjtO9wJ6q7keVSJ2JmKUvpwzirhgoCMRamQHx(ZXKLHCLJ(dXeNH0IpD4ZnK8itQ)RuQdTRq8Yo6kh9hImflMmH2BnQdTRq8YoApsMIftMSm2JWazrDODfIx2rXJWVcktGwM4eoBiDRESYq2o8qFgdXOgE5p(MSmKRC0FiM4mKw8PdFUHKhzs9FLsDODfIx2rx5O)qKPyXKj0ERrDODfIx2r7rYuSyYKLXEegilQdTRq8YokEe(vqzc0YeNWzdPB1JvgsVSdQy)fw)FJA4LFoYKLHCLJ(dXeNH0IpD4ZnK8itQ)RuQdTRq8Yo6kh9hImflMmXJmH2BnQdTRq8YoApYq6w9yLHe1beSMqXNnd0OgE5NtmzziDRESYqgCWOHfkthHHCLJ(dXeNrn8YpOWKLHCLJ(dXeNH0IpD4ZnKwwWvEP06acvrZNmbwM4rMW9Anggyu4gcuWAcSte5LkaWmqQH0XH(ffnezcSmLNmXJmP(VsPeouhwWAcnCI9JyLcPRC0FiYuSyYeAV1OeouhwWAcnCI9JyLcP9izkFzcSmbJ2)c1XatHuBOFL4pGqTUcqMaHmfFdPB1JvgYMpHI9c26WJvg1Wl)XBtwgYvo6petCgsl(0Hp3qAzbx5LsRdiufnFYeyzc3R1yyGrHBiqbRjWorKxQaaZaPgshh6xu0qKjWYuEYepYK6)kLs4qDybRj0Wj2pIvkKUYr)HitXIjtO9wJs4qDybRj0Wj2pIvkK2JKPyXKjy0(xOogykKAd9Re)beQ1vaYeO5ktXxMYxMalt5jtwg7ryGSOTdpX(rSs9NIhHFfuMaTmLdNLPyXKjlJ9imqwuOYWeI9JyL6pfpc)kOmbAzkholt5BiDRESYq28juSxWwhESYOgE5huzYYqUYr)HyIZqAXNo85gs3QxWjwnIBqzc0YuoYeyzkpzcgT)fQJbMcP2q)kXFaHADfGmbAzkhzkwmzcgT)fQJbMcPVh0fOZjKjqlt5it5BiHk(SQHx(nKUvpwziX9s4w9yL4pOAi)dQIYjMH0zZOgE5NJBYYqUYr)HyIZqAXNo85gsEKj1)vkfQmmHy)iwP(tx5O)qKjWYKB1l4eRgXnOmbcUYuogsOIpRA4LFdPB1JvgsCVeUvpwj(dQgY)GQOCIziHxb8tOogyQrn8MdNnzzix5O)qmXziT4th(CdP6)kLcvgMqSFeRu)PRC0FiYeyzYT6fCIvJ4guMabxzkhdjuXNvn8YVH0T6XkdjUxc3QhRe)bvd5FqvuoXmKWjGxb8tOogyQrnQHmcplJa1vtwgE53KLHCLJ(dXeNH0T6Xkd5CSgk2pIvQ)gsKbT4lspwzibLepoBxhImTGdhGmPhXKjnCYKBvgwMoOm5b97D0FudPfF6WNBi5rMu)xP0i8r4Vy)iwP(FqLUYr)HyudV5yYYqUYr)HyIZq6w9yLHS9dgAXEtnKidAXxKESYqckn4KjsLHjYSfnSmfHNLrG6Qm1RFqOmbzetMCeeOmbY7Fzcg5GSKjiJvudPfF6WNBiHS(JEfcnQd1(pXW9i9yfDLJ(drMIftMGS(JEfcni7D9(jGSp4kLUYr)HyudVX3KLHCLJ(dXeNH0IpD4ZnKQ)RukuzyImBrdtx5O)qKjWYuEYe2peXcUsPoccKAz9sLjqitXxMIftMW(HiwWvk1rqG0RKjqltCcNLP8nKUvpwziHkdtKzlAyJA4LJmzziDRESYq2o8e7hXk1Fd5kh9hIjoJA4Ltmzzix5O)qmXziT4th(CdP6)kLUFeRu)fOVdv6kh9hImbwMGr7FH6yGPqQn0Vs8hqOwxbitGqMIVH0T6Xkd5(rSs9xG(ounQHxqHjld5kh9hIjodPB1JvgY3d6c0ogQgY)QjSigY4BiT4th(CdjpYK6)kLUFeRu)fOVdv6kh9hImbwMGr7FH6yGPqQn0Vs8hqOwxbitGqMIVmflMmH2BnkuzyImBrdt7rgsKbT4lspwziJBwVdNmfVemozk0HYKltk2dUxM0JybktA4KjhbHvYu072bLjovdpOmTsXbWPYeRKP454bLPgdltXxMGZYkeOmPmzYdYoezcH1r)bQnEjyCYeRKPO()uJA4nEBYYqUYr)HyIZqAXNo85gsEKj1)vkD)iwP(lqFhQ0vo6pezcSmbJ2)c1XatHuBOFL4pGqTUcqManxzk(YeyzIhzcT3AuOYWez2IgM2JmKUvpwziTH(vI)ac16kaJA4fuzYYq6w9yLHmIPhRmKRC0FiM4mQrnKoBMSm8YVjldPB1JvgsOYWeI9JyL6VHCLJ(dXeNrn8MJjld5kh9hIjodPfF6WNBir7Tg16)l(diuRRaO4r4xbLjqZvM4NZgs3QhRmKlGjynHgobuzycJA4n(MSmKRC0FiM4mKw8PdFUHeT3A0zdzxbiGHmBgApYq6w9yLHCowd5q3ZmJA4LJmzziDRESYqAd9ReHoo4GQHCLJ(dXeNrn8YjMSmKRC0FiM4mKw8PdFUHu9FLsHkdtKzlAy6kh9hIH0T6XkdjuzyImBrdBudVGctwgYvo6petCgs3QhRmKT3jMagYSzmKw8PdFUHeVgEWqh9NmbwMYtMYtMCREbNaHP027etadz2mYeiKPCKjWYKB1l4eRgXnOmbcUYu8LjWYKLXEegilAe(iyyKZFbi9GJIhHFfuMaHmXpOqMaltwwWvEP0Awm7zyezcSmXJmfnLcvgMqSFeRu)PUvVGtMIftMCREbNaHP027etadz2mYeiKj(LjWYKB1l4eRgXnOmbAUYehjtGLjEKPOPuOYWeI9JyL6p1T6fCYeyzs9FLsjCOoSG1eA4e7hXkfsx5O)qKP8LPyXKP8KjCVwJHbgfMjau88mddfTB4aeiJ4GJoo0VOOHitGLjEKPOPuOYWeI9JyL6p1T6fCYu(YuSyYuEYeUxRXWaJcJ(R0HhIy)iwPq64q)IIgImbwMYtMCREbNaHP027etadz2mYeiKP4ltGLjEKjCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgImflMm5w9cobctPT3jMagYSzKjqitCKmLVmbwMYtMSm2JWazrJWhbdJC(laPhCu8i8RGYeiKj(bfYuSyYeAV1Or4JGHro)fG0doApsMYxMYxMY3qAdW(tOogyk0Wl)g1WB82KLHCLJ(dXeNH0IpD4ZnK8itUvVGtGWuA7DIjGHmBgzcSmXJmfnLcvgMqSFeRu)PUvVGtMalt5jtQ)RukHd1HfSMqdNy)iwPq6kh9hImflMmH71AmmWOWmbGINNzyOODdhGazehC0XH(ffnezkFzkwmzkpzc3R1yyGrHr)v6WdrSFeRuiDCOFrrdrMalt8it6zZCfGmbwMq7TgncFemmY5VaKEWr7rYu(gs3QhRmKT3jMagYSzmQHxqLjld5kh9hIjodPfF6WNBiv)xP0zdzxbiGHmBg6kh9hImbwMi89qfZiKjqZvMafCwMalt5jt4ETgddm6SHSbfSMaapxfWEHm8va0XH(ffnezcSmH2Bn6SHSbfSMaapxfWEHm8va0EKmflMmXJmH71AmmWOZgYguWAca8Cva7fYWxbqhh6xu0qKP8nKUvpwziNnKDfGagYSzmQHxoUjld5kh9hIjodPfF6WNBiv)xPuhAxH4LD0vo6pezcSmLNmXJmfnLcvgMqSFeRu)PUvVGtMYxMalt5jt8itQ)Ru6zxRJdGUYr)HitXIjt8itO9wJE2164aO9izcSmXJmzzShHbYIE2164aO9izkFdPB1JvgshAxH4LDg1Wl)C2KLHCLJ(dXeNH0IpD4ZnKQ)Ru6FCOFicchGWfkthbDLJ(dXq6w9yLH8po0pebHdq4cLPJWOgE5NFtwgYvo6petCgsl(0Hp3qcJ2)c1XatHuBOFL4pGqTUcqMaHmXrYeyzcT3AuchQdlynHgoX(rSsH0EKmbwMi89qfZiKjqitCcNnKUvpwziTH(vI)ac16kaJA4L)Cmzzix5O)qmXziT4th(CdjUxRXWaJoBiBqbRjaWZvbSxidFfaDCOFrrdrMalt8itO9wJoBiBqbRjaWZvbSxidFfaThziDRESYqohRHcyiZMXOgE5p(MSmKRC0FiM4mKw8PdFUHeHP027etadz2mu8i8RGYeyzcgT)fQJbMcP2q)kXFaHADfGmbczIJKjWYuEYepYu0ukuzycX(rSs9N6w9cozkFzcSmLNmH2Bn67bDbSJbgThjtGLjEKj0ERrjCOoSG1eA4e7hXkfs7rYeyzs9FLsjCOoSG1eA4e7hXkfsx5O)qKP8nKUvpwziFpOlq7yOAudV8ZrMSmKRC0FiM4mKw8PdFUHegT)fQJbMcP2q)kXFaHADfGmbAUYuoYeyzIhzc3R1yyGrNnKnOG1ea45Qa2lKHVcGoo0VOOHitGLP8Kj1)vkLWH6WcwtOHtSFeRuiDLJ(drMalte(EOIzeYeO5ktCcNLjWYepYeAV1OeouhwWAcnCI9JyLcP9izkFdPB1JvgY5ynKdDpZmQHx(5etwgYvo6petCgs3QhRmKVh0fODmunKw8PdFUH0YcUYlLwZIzpdJitGLjCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgImbwMGtfOSQdP6nCoGkbhfzLjWYeAV1OVh0fWogy0EKmbwM4rMq7TgncFemmY5VaKEWr7rgsBa2Fc1XatHgE53OgE5huyYYqUYr)HyIZq6w9yLH89GUaTJHQH0IpD4ZnKO9wJ(Eqxa7yGr7rYeyzcT3A0i8rWWiN)cq6bhThjtGLP8Kj0ERrJWhbdJC(laPhCu8i8RGYeiKP4ltCQmbyrKPyXKj3QxWjqykT9oXeWqMnJmXvMGr7FH6yGPqQn0Vs8hqOwxbitXIjtUvVGtGWuA7DIjGHmBgzIRmfFzcSmXJmH71AmmWOZgYguWAca8Cva7fYWxbqhh6xu0qKPyXKj3QxWjqykT9oXeWqMnJmXvM4izkFdPna7pH6yGPqdV8BudV8hVnzzix5O)qmXziT4th(CdjctPT3jMagYSzO4r4xbLjWYemA)luhdmfsTH(vI)ac16kazceYehjtGLjCVwJHbgfMjau88mddfTB4aeiJ4GJoo0VOOHitGLj0ERrFpOlGDmWO9izcSmP(VsPeouhwWAcnCI9JyLcPRC0FiYeyzIhzcT3AuchQdlynHgoX(rSsH0EKmbwMi89qfZiKjqZvM4eoBiDRESYq(EqxG2Xq1OgE5huzYYqUYr)HyIZqAXNo85gseMsBVtmbmKzZqXJWVcktGLP8KP8Kjy0(xOogykKAd9Re)beQ1vaYeiKjosMalt4ETgddmkmtaO45zggkA3WbiqgXbhDCOFrrdrMaltQ)RukHd1HfSMqdNy)iwPq6kh9hImLVmflMmLNmP(VsPeouhwWAcnCI9JyLcPRC0FiYeyzIW3dvmJqManxzIt4SmbwM4rMq7TgLWH6WcwtOHtSFeRuiThjtGLP8KjEKjCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgImflMmH2Bn6SHSbfSMaapxfWEHm8va0EKmLVmbwM4rMW9AnggyuyMaqXZZmmu0UHdqGmIdo64q)IIgImLVmLVH0T6Xkd57bDbAhdvJA4LFoUjld5kh9hIjodPfF6WNBirykT9oXeWqMndfpc)kOmbwMGr7FH6yGPqQn0Vs8hqOwxbitCLjosMalt4ETgddmkmtaO45zggkA3WbiqgXbhDCOFrrdrMaltO9wJ(Eqxa7yGr7rYeyzs9FLsjCOoSG1eA4e7hXkfsx5O)qKjWYepYeAV1OeouhwWAcnCI9JyLcP9izcSmr47HkMritGMRmXjC2q6w9yLH89GUaTJHQrn8MdNnzzix5O)qmXziT4th(CdjmA)luhdmfsTH(vI)ac16kazc0CLPCmKUvpwziNJ1qo09mZOgEZHFtwgYvo6petCgsl(0Hp3qI2BnkuzyImBrdtXJWVcktGqMIVmXPYeGfrM4uzcT3AuOYWez2IgMcv3MXq6w9yLH0g6xj(diuRRamQH3CYXKLHCLJ(dXeNH0T6Xkd57bDbAhdvdPfF6WNBiHtfOSQdP6nCoGkbhfzLjWYeAV1OVh0fWogy0EKmbwM4rMq7TgncFemmY5VaKEWr7rgsBa2Fc1XatHgE53OgEZj(MSmKRC0FiM4mKw8PdFUHeovGYQoKQ3W5aQeCuKvMaltO9wJ(Eqxa7yGr7rYeyzIhzcT3A0i8rWWiN)cq6bhThziDRESYq(EqxG2Xq1OgEZHJmzzix5O)qmXziT4th(CdjAV1OVh0fWogy0EKmbwMGr7FH6yGPqQn0Vs8hqOwxbitGqM4izcSmLNmXJmfnLcvgMqSFeRu)PUvVGtMYxMaltimL2ENycyiZMHQNnZvags3QhRmKVh0fODmunQH3C4etwgYvo6petCgsl(0Hp3qQ(VsP7hXk1Fb67qLUYr)HitGLjy0(xOogykKAd9Re)beQ1vaYeiKjorMalt5jt8itrtPqLHje7hXk1FQB1l4KP8nKUvpwzi3pIvQ)c03HQrn8MdOWKLHCLJ(dXeNH0IpD4ZnKQ)RuQdTRq8Yo6kh9hIH0T6Xkd57bDb6CcJA4nN4TjldPB1JvgsBOFL4pGqTUcWqUYr)HyIZOgEZbuzYYqUYr)HyIZqUYr)jiybVcWeNH0IpD4ZnKO9wJ(Eqxa7yGr7rYeyzYYypcdKLap3Qgs3QhRmKVh0fODmunKeSGxby4LFJA4nhoUjldjbl4vagE53qUYr)jiybVcWeNH0T6Xkdz7DIjGHmBgdPna7pH6yGPqdV8BiT4th(CdjEn8GHo6pd5kh9hIjoJA4n(C2KLHKGf8kadV8Bix5O)eeSGxbyIZq6w9yLHSHzqvadz2mgYvo6petCg1Ogs4eWRa(juhdm1KLHx(nzziDRESYqcvgMqSFeRu)nKRC0FiM4mQH3Cmzzix5O)qmXziT4th(CdjAV1OWogycwteXa5W0EKH0T6Xkd5FaHADfGaL9Qrn8gFtwgYvo6petCgs3QhRmKr4JGHro)fG0dodPfF6WNBiTSGR8sP1Sy2ZWiYeyzIhzcT3A0i8rWWiN)cq6bhThjtGLjEKj0ERrHr)v6WdrSFeRuiThziTby)juhdmfA4LFJA4LJmzzix5O)qmXziT4th(CdjAV1Ow)FXFaHADfafpc)kOmbAUYe)C2q6w9yLHCbmbRj0WjGkdtyudVCIjld5kh9hIjodPfF6WNBiv)xP0ZUwhhaDLJ(drMaltO9wJE2164aO9izcSmH2Bn6zxRJdGIhHFfuMaHmbNQxbaPq1TzeO9wByzItLjalImXPYeAV1ONDTooakuDBgzcSmH2BnkiVcra0HkfQUnJmbczIFqLH0T6XkdzdZGQagYSzmQHxqHjld5kh9hIjodPB1JvgY27etadz2mgsl(0Hp3qIxdpyOJ(ZqAdW(tOogyk0Wl)g1WB82KLHCLJ(dXeNH0IpD4ZnKQ)Ru6zxRJdGUYr)HitGLj0ERrp7ADCa0EKmbwMq7Tg9SR1XbqXJWVcktGqM4NYVmXPYeGfrM4uzcT3A0ZUwhhafQUnJH0T6XkdzdZGQagYSzmQHxqLjld5kh9hIjodPfF6WNBiv)xP09JyL6Va9DOsx5O)qmKUvpwzi3pIvQ)c03HQrn8YXnzzix5O)qmXziT4th(CdP6)kLcvgMiZw0W0vo6pedPB1JvgsOYWez2Ig2OgE5NZMSmKRC0FiM4mKw8PdFUHu9FLsNnKDfGagYSzORC0FiYeyzYYypcdKf99GUaTJHkfpc)kOmbcUYeGfrMaltWO9VqDmWui1g6xj(diuRRaKjqit5itXIjte(EOIzeYeO5ktGcoltGLjy0(xOogykKAd9Re)beQ1vaYeO5kt5itGLP8KjEKjCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgImflMmH2Bn6SHSbfSMaapxfWEHm8va0EKmLVH0T6Xkd5SHSRaeWqMnJrn8Yp)MSmKRC0FiM4mKw8PdFUHmpzcT3AuqEfIaOdvkuDBgzceYe)GkzcSmXJmH2Bnk6ZyiFhQ0EKmLVmflMmH2Bn67bDbSJbgThziDRESYq(EqxG2Xq1OgE5phtwgYvo6petCgsl(0Hp3qQ(VsPZgYUcqadz2m0vo6pezcSmH2Bn6SHSRaeWqMndThjtGLjy0(xOogykKAd9Re)beQ1vaYeiKPCmKUvpwziFpOlq7yOAudV8hFtwgYvo6petCgsl(0Hp3qQ(VsPZgYUcqadz2m0vo6pezcSmH2Bn6SHSRaeWqMndThjtGLjy0(xOogykKAd9Re)beQ1vaYeO5kt5yiDRESYqohRHCO7zMrn8YphzYYqUYr)HyIZqAXNo85gs0ERrHkdtKzlAyApYq6w9yLH8pGqTUcqGYE1OgE5Ntmzzix5O)qmXziT4th(CdjAV1OZgYguWAca8Cva7fYWxbq7rgs3QhRmKZXAih6EMzudV8dkmzzix5O)qmXziT4th(CdjmA)luhdmfsTH(vI)ac16kazceYuoYeyzIW3dvmJqManxzcuWzzcSmLNmH2BnkiVcra0HkfQUnJmbczkholtXIjte(EOIzeYeOLjooNLP8LPyXKP8KjCVwJHbgD2q2GcwtaGNRcyVqg(ka64q)IIgImbwM4rMq7TgD2q2GcwtaGNRcyVqg(kaApsMYxMIftMW9AnggyuqEfcmAEMHHI3d6c8GDmWk7OJd9lkAigs3QhRmKZXAOagYSzmQHx(J3MSmKRC0FiM4mKw8PdFUHmpzcgT)fQJbMcP2q)kXFaHADfGmbAzIFzkFzcSmLNmXJmHWuA7DIjGHmBgkEn8GHo6pzkFdPB1JvgY5ynKdDpZmQHx(bvMSmKRC0FiM4mKw8PdFUH0T6fCIvJ4guMaTmXVmbwMIMsHkdti2pIvQ)u3QxWjtGLj0ERrrFgd57qL2JmKUvpwziTH(vI)ac16kaJA4LFoUjld5kh9hIjodPfF6WNBiJMsHkdti2pIvQ)u3QxWjtGLj0ERrrFgd57qL2JmKUvpwzi)diuRRaeOSxnQH3C4Sjld5kh9hIjodPfF6WNBir7Tg1H2viEzhThziDRESYq(EqxG2Xq1OgEZHFtwgYvo6petCgsl(0Hp3qAzShHbYsGNBvdPB1JvgY3d6c0ogQg1WBo5yYYqUYr)HyIZqAXNo85gslJ9imqwc8CRktGLjBOJbguMaTmP(VsPZgYeSMqdNy)iwPq6kh9hIH0T6Xkd57bDbAhdvJA4nN4BYYqUYr)HyIZqAXNo85gs1)vk9SR1Xbqx5O)qKjWYeAV1ONDTooaApYq6w9yLHSHzqvadz2mg1WBoCKjldPB1JvgsBOFLi0XbhunKRC0FiM4mQH3C4etwgYvo6petCgsl(0Hp3qcz9h9keAq2769tazFWvkDLJ(drMalt8itO9wJgK9UE)eq2hCLkc7eEXoeApYqELomUhPIRziHS(JEfcni7D9(jGSp4k1qELomUhPIJGyiNRZqYVH0T6Xkdz7hm0I9MAiVshg3JubWZq93qYVrn8MdOWKLHCLJ(dXeNH0IpD4ZnKQ)RukuD9ScKdAdDmWORC0Figs3QhRmKq11ZkqoOn0XaZOgEZjEBYYqUYr)HyIZqAXNo85gsEKj1)vkncFe(l2pIvQ)huPRC0FiYuSyYK6)kLgHpc)f7hXk1)dQ0vo6pezcSmLNmXJmfnLcvgMqSFeRu)PUvVGtMY3q6w9yLHCowdf7hXk1FJA4nhqLjld5kh9hIjodPfF6WNBiDREbNy1iUbLjqlt8ltGLP8Kjy0(xOogykKAd9Re)beQ1vaYeOLj(LPyXKjy0(xOogykK(EqxGoNqMaTmXVmLVH0T6XkdPn0Vs8hqOwxbyudV5WXnzziDRESYq(hqOwxbiqzVAix5O)qmXzudVXNZMSmKeSGxby4LFd5kh9NGGf8katCgs3QhRmKT3jMagYSzmK2aS)eQJbMcn8YVH0IpD4ZnK41Wdg6O)mKRC0FiM4mQH34ZVjld5kh9hIjod5kh9NGGf8katCgsl(0Hp3qsWcoIvkf5GQx2jtGwMafgs3QhRmKT3jMagYSzmKeSGxby4LFJA4n(5yYYqsWcEfGHx(nKRC0FccwWRamXziDRESYq2WmOkGHmBgd5kh9hIjoJAuJAi9UgYWgsYJO)UESkEg7n1Og1ya]] )
end