Como as funções aninhadas funcionam em Python?

def maker(n):
    def action(x):
        return x ** n
    return action

f = maker(2)
print(f)
print(f(3))
print(f(4))

g = maker(3)
print(g(3))

print(f(3)) # still remembers 2

Por que a função aninhada lembra o primeiro valor2 Apesar demaker() retornou e saiu no tempoaction() é chamado?