import textstat

def program_judge_36(query: str, response: str) -> dict:
    """
    Judges responses based on clarity (readability index) and conciseness (response length compared to query length).
    """
    try:
        # Check if the response or query is empty
        if not query or not response:
            raise ValueError("Query or response cannot be empty.")
        
        # Calculate readability index which indicates clarity. Higher score means easier to read.
        readability_index = textstat.flesch_reading_ease(response)
        
        # Calculate the ratio of response length to query length to measure conciseness.
        length_ratio = len(response) / len(query)
        
        # Normalize readability index to a 0-10 scale
        # Flesch Reading Ease score usually ranges from 0-100. Lower scores indicate material that is harder to read.
        # So, we subtract it from 100 to reverse the score, then scale it to 0-10.
        readability_score = (100 - readability_index) / 10
        
        # If the response is significantly longer than the query, it is likely not concise. 
        # So, we penalize responses with length_ratio greater than 1.5 by decreasing the score.
        if length_ratio > 1.5:
            readability_score -= 2
        
        # Ensure the final score stays within 0-10 range
        score = max(0, min(readability_score, 10))
        
        reasoning = "The score was calculated based on the Flesch Reading Ease readability index and the response length relative to the query length."
        criteria = "Clarity and Conciseness"
        
        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"
        }