from collections import Counter

def program_judge_41(query: str, response: str) -> dict:
    """
    Judges responses based on the completeness/coverage of answer. 
    The scoring is done based on the proportion of unique words in the query that are also in the response.
    """
    try:
        # Normalize both query and response to lower case
        query, response = query.lower(), response.lower()

        # Split into words
        query_words, response_words = query.split(), response.split()

        # Count unique words
        query_counter, response_counter = Counter(query_words), Counter(response_words)

        # Calculate score based on the proportion of unique words in the query that are also in the response.
        score = 0.0
        for word in query_counter.keys():
            if word in response_counter:
                score += 1.0
        score = (score / len(query_counter.keys())) * 10

        reasoning = "The response covered {:.2f}% of unique words in the query.".format(score)
        criteria = "Completeness/Coverage of Answer"

        return {
            'score': score,
            'reasoning': reasoning,
            'criteria': criteria
        }
    except Exception as e:
        return {
            'score': 0.0,
            'reasoning': f"Error in evaluation: {str(e)}",
            'criteria': "Error occurred"
        }