import textstat

def program_judge_10(query: str, response: str) -> dict:
    """
    Judges responses based on clarity and conciseness. The function measures readability 
    and length of the response to determine score.
    """
    try:
        # Calculate readability score using Flesch Reading Ease formula
        readability = textstat.flesch_reading_ease(response)
        
        # Calculate length of the response
        length = len(response.split())
        
        # Initialize score
        score = 0.0  
        
        # Reasoning
        reasoning = ""
        
        # Criteria
        criteria = "Clarity and Conciseness"
        
        # Assign score based on readability
        if readability >= 90.0:
            score += 5.0
            reasoning += "The response is very easy to read. "
        elif readability >= 80.0:
            score += 4.0
            reasoning += "The response is easy to read. "
        elif readability >= 70.0:
            score += 3.0
            reasoning += "The response is fairly easy to read. "
        elif readability >= 60.0:
            score += 2.0
            reasoning += "The response is standard to read. "
        else:
            score += 1.0
            reasoning += "The response is difficult to read. "
        
        # Assign score based on length
        if length <= 10:
            score += 5.0
            reasoning += "The response is very concise. "
        elif length <= 20:
            score += 4.0
            reasoning += "The response is concise. "
        elif length <= 30:
            score += 3.0
            reasoning += "The response is fairly concise. "
        elif length <= 40:
            score += 2.0
            reasoning += "The response is somewhat concise. "
        else:
            score += 1.0
            reasoning += "The response is not concise. "
        
        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"
        }