{% extends 'base.html' %}
{% load static %}

{% block title %}IMProofBench - Mathematical Reasoning Benchmark{% endblock %}

{% block extra_css %}
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.0/font/bootstrap-icons.css">
<style>
    @media (min-width: 768px) {
        .stat-item {
            border-right: 1px solid #dee2e6;
            padding-right: 1rem;
        }
        .stat-item-last {
            padding-right: 1rem;
        }
    }
    
    /* Workflow Pipeline Styles */
    .workflow-container {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        gap: 0;
        padding: 1rem 0;
    }
    
    .workflow-stage {
        display: flex;
        align-items: center;
    }
    
    .stage-box {
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
        border-radius: 10px;
        padding: 1rem 1.5rem;
        min-width: 120px;
        text-align: center;
        border: 2px solid;
        transition: all 0.3s ease;
        position: relative;
    }
    
    .stage-box:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    }
    
    .stage-box h4 {
        margin-bottom: 0.25rem !important;
        font-weight: bold;
    }
    
    .stage-box small {
        font-size: 0.75rem;
        text-transform: uppercase;
        font-weight: 600;
        letter-spacing: 0.5px;
    }
    
    /* Stage-specific colors */
    .stage-box.draft {
        border-color: #6c757d;
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    }
    
    .stage-box.draft h4 {
        color: #6c757d;
    }
    
    .stage-box.review {
        border-color: #ffc107;
        background: linear-gradient(135deg, #fff8e1 0%, #fff3cd 100%);
    }
    
    .stage-box.review h4 {
        color: #f39c12;
    }
    
    .stage-box.accepted {
        border-color: #28a745;
        background: linear-gradient(135deg, #e8f5e9 0%, #d4edda 100%);
    }
    
    .stage-box.accepted h4 {
        color: #28a745;
    }
    
    .stage-box.graded {
        border-color: #007bff;
        background: linear-gradient(135deg, #e3f2fd 0%, #cce5ff 100%);
    }
    
    .stage-box.graded h4 {
        color: #007bff;
    }
    
    /* Arrow styles */
    .stage-arrow {
        margin: 0 0.75rem;
        color: #6c757d;
        font-size: 1.5rem;
    }
    
    /* Mobile responsiveness */
    @media (max-width: 767px) {
        .workflow-container {
            flex-direction: column;
            gap: 1rem;
        }

        .workflow-stage {
            flex-direction: column;
            width: 100%;
        }

        .stage-box {
            width: 80%;
            max-width: 250px;
        }

        .stage-arrow {
            margin: 0.5rem 0;
            transform: rotate(90deg);
        }
    }

    /* Top models - desktop horizontal layout */
    .top-models-desktop {
        display: none;
    }

    .top-models-mobile {
        display: block;
    }

    @media (min-width: 576px) {
        .top-models-desktop {
            display: block;
        }
        .top-models-mobile {
            display: none;
        }
    }

    /* Desktop horizontal progress bar */
    .top-model-bar {
        width: 100px;
    }

    @media (min-width: 768px) {
        .top-model-bar {
            width: 120px;
        }
    }

    @media (min-width: 992px) {
        .top-model-bar {
            width: 150px;
        }
    }

    /* Mobile vertical bars */
    .mobile-bar-container {
        display: flex;
        justify-content: space-around;
        align-items: flex-end;
        padding: 0 5px;
    }

    .mobile-bar-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        flex: 1;
        max-width: 70px;
        padding: 0 4px;
    }

    .mobile-bar-wrapper {
        height: 80px;
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        align-items: center;
    }

    .mobile-bar {
        width: 100%;
        max-width: 28px;
        background: rgba(25, 135, 84, 0.7);
        border-radius: 3px 3px 0 0;
    }

    .mobile-bar-label {
        font-size: 0.55rem;
        text-align: center;
        line-height: 1.1;
        max-width: 65px;
        margin-top: 4px;
        height: 22px;
        overflow: hidden;
    }

    .mobile-bar-percent {
        font-size: 0.65rem;
        font-weight: bold;
        color: #198754;
        margin-bottom: 2px;
    }
</style>
{% endblock %}

{% block page_header %}
<div class="text-center mb-5">
    <div class="bg-primary bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
         style="width: 80px; height: 80px;">
        <i class="bi bi-mortarboard text-white fs-1"></i>
    </div>
    <h1 class="display-4 fw-bold text-primary mb-3">IMProofBench</h1>
    <p class="lead text-muted">Informal Mathematical Proof Benchmark</p>
    <p class="text-muted">IMProofBench evaluates the ability of AI systems to create research-level mathematical proofs. We maintain a curated, private repository of PhD-level problems across pure mathematics to measure genuine mathematical reasoning capabilities while preventing data contamination and benchmark overfitting.</p>
</div>
{% endblock %}

{% block content %}

<!-- Benchmark Status Section (Full Width) -->
<div class="row mb-4">
    <div class="col-12">
        <div class="card shadow-sm border-0">
            <div class="card-body">
                <h4 class="card-title text-primary mb-4 text-center">
                    <i class="bi bi-speedometer2 me-2"></i>Benchmark Status
                </h4>
                
                <!-- Question Workflow Pipeline -->
                <div class="workflow-container mb-2">
                    <div class="workflow-stage">
                        <div class="stage-box draft">
                            <h4 class="mb-1">{{ draft_count }}</h4>
                            <small>Draft</small>
                        </div>
                        <div class="stage-arrow">
                            <i class="bi bi-chevron-right"></i>
                        </div>
                    </div>
                    <div class="workflow-stage">
                        <div class="stage-box review">
                            <h4 class="mb-1">{{ under_review_count }}</h4>
                            <small>Under Review</small>
                        </div>
                        <div class="stage-arrow">
                            <i class="bi bi-chevron-right"></i>
                        </div>
                    </div>
                    <div class="workflow-stage">
                        <div class="stage-box accepted">
                            <h4 class="mb-1">{{ accepted_count }}</h4>
                            <small>Accepted</small>
                        </div>
                        <div class="stage-arrow">
                            <i class="bi bi-chevron-right"></i>
                        </div>
                    </div>
                    <div class="workflow-stage">
                        <div class="stage-box graded">
                            <h4 class="mb-1">{{ graded_count }}</h4>
                            <small>Graded</small>
                        </div>
                    </div>
                </div>
                <div class="text-center mb-4">
                    <p class="text-muted mb-0 small">
                        <i class="bi bi-diagram-3 me-1"></i>Question Submission Pipeline
                    </p>
                </div>
                
                <!-- Other Statistics -->
                <div class="row text-center pt-3 border-top">
                    <div class="col-6">
                        <div class="stat-item">
                            <h4 class="text-primary mb-1">{{ participant_count }}</h4>
                            <p class="text-muted mb-0 small">
                                <i class="bi bi-people-fill me-1"></i>Participants
                            </p>
                        </div>
                    </div>
                    <div class="col-6">
                        <div class="stat-item-last">
                            <h4 class="text-warning mb-1">{{ model_count }}</h4>
                            <p class="text-muted mb-0 small">
                                <i class="bi bi-cpu-fill me-1"></i>Models
                            </p>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

<div class="row g-4">
    <!-- Questions Section -->
    <div class="col-md-6">
        <div class="card h-100 shadow-sm border-0">
            <div class="card-body text-center p-5">
                <div class="bg-info bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
                     style="width: 60px; height: 60px;">
                    <i class="bi bi-file-earmark-text text-white fs-3"></i>
                </div>
                <h3 class="card-title text-info mb-3">Questions</h3>
                <p class="card-text text-muted mb-4">
                    Create and review mathematical proof problems to test frontier AI models.
                </p>
                <div class="d-grid gap-2">
                    <a href="{% url 'questions:list' %}" class="btn btn-info">
                        <i class="bi bi-eye me-2"></i>Browse Questions
                    </a>
                    <a href="{% url 'guidelines' %}" class="btn btn-info">
                        <i class="bi bi-book me-2"></i>Problem Guidelines
                    </a>
                    <a href="{% url 'questions:add' %}" class="btn btn-outline-info">
                        <i class="bi bi-plus-circle me-2"></i>Create New Question
                    </a>
                </div>
            </div>
        </div>
    </div>

    <!-- Community Section -->
    <div class="col-md-6">
        <div class="card h-100 shadow-sm border-0">
            <div class="card-body text-center p-5">
                <div class="bg-success bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
                     style="width: 60px; height: 60px;">
                    <i class="bi bi-people text-white fs-3"></i>
                </div>
                <h3 class="card-title text-success mb-3">Community</h3>
                <p class="card-text text-muted mb-4">
                    Connect with mathematical researchers and track contributions.
                </p>
                <div class="d-grid gap-2">
                    <a href="{% url 'participants:list' %}" class="btn btn-success">
                        <i class="bi bi-trophy me-2"></i>Participants & Leaderboard
                    </a>
                    <a href="https://improofbench.zulipchat.com/join/oclqw6wstanvip4t7agk66kj/" target="_blank" class="btn btn-outline-success">
                        <i class="bi bi-chat-dots me-2"></i>Zulip Chatroom
                    </a>
                </div>
            </div>
        </div>
    </div>
</div>

<div class="row g-4 mt-1">
    <!-- Dashboard Section -->
    <div class="col-md-6">
        <div class="card h-100 shadow-sm border-0">
            <div class="card-body text-center p-5">
                <div class="bg-primary bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
                     style="width: 60px; height: 60px;">
                    <i class="bi bi-graph-up text-white fs-3"></i>
                </div>
                <h3 class="card-title text-primary mb-3">Dashboard</h3>
                <p class="card-text text-muted mb-4">
                    Real-time statistics and benchmark performance metrics.
                </p>
                
                <!-- Top Models Section -->
                {% if top_models %}
                <div class="mb-4">
                    <small class="text-uppercase text-muted fw-bold d-block mb-2">
                        Top Models
                        <i class="bi bi-info-circle ms-1" 
                           data-bs-toggle="tooltip" 
                           data-bs-placement="right"
                           title="Models ranked by the percentage of benchmark problems they solved completely with a correct mathematical proof"
                           style="font-size: 0.85rem; cursor: help;"></i>
                    </small>
                    <p class="text-muted small mb-2" style="margin-top: -0.25rem;">Percentage of questions with complete and correct solution</p>
                    <!-- Desktop: horizontal bars -->
                    <div class="bg-light rounded p-3 top-models-desktop">
                        {% for model in top_models %}
                        <div class="d-flex justify-content-between align-items-center {% if not forloop.last %}mb-2 pb-2 border-bottom{% endif %}" style="min-height: 32px;">
                            <span class="text-truncate me-2" style="flex: 1;"
                                  data-bs-toggle="tooltip"
                                  data-bs-placement="left"
                                  title="{{ model.name }}">
                                {{ forloop.counter }}. {{ model.name }}
                            </span>
                            <div class="d-flex align-items-center flex-shrink-0">
                                <div class="top-model-bar" style="height: 24px; position: relative; margin-right: 8px;">
                                    <div style="position: absolute;
                                                top: 0;
                                                right: 0;
                                                height: 100%;
                                                width: {{ model.percentage }}%;
                                                background: linear-gradient(to left, rgba(25, 135, 84, 0.4), rgba(25, 135, 84, 0.2));
                                                border-left: 3px solid rgba(25, 135, 84, 0.8);
                                                border-radius: 3px;">
                                    </div>
                                </div>
                                <span class="badge bg-success" style="min-width: 45px;">
                                    {{ model.percentage }}%
                                </span>
                            </div>
                        </div>
                        {% endfor %}
                    </div>

                    <!-- Mobile: vertical bars -->
                    <div class="bg-light rounded p-3 top-models-mobile">
                        <div class="mobile-bar-container">
                            {% for model in top_models %}
                            <div class="mobile-bar-item" title="{{ model.name }}">
                                <div class="mobile-bar-percent">{{ model.percentage }}%</div>
                                <div class="mobile-bar-wrapper">
                                    <div class="mobile-bar" data-percentage="{{ model.percentage }}"></div>
                                </div>
                                <div class="mobile-bar-label">{{ model.short_name|default:model.name }}</div>
                            </div>
                            {% endfor %}
                        </div>
                    </div>
                </div>
                {% endif %}
                
                <div class="d-grid">
                    <a href="{% url 'questions:leaderboard' %}" class="btn btn-outline-primary">
                        <i class="bi bi-bar-chart me-2"></i>Benchmark Results
                    </a>
                </div>
            </div>
        </div>
    </div>

    <!-- About Section -->
    <div class="col-md-6">
        <div class="card h-100 shadow-sm border-0">
            <div class="card-body text-center p-5">
                <div class="bg-warning bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
                     style="width: 60px; height: 60px;">
                    <i class="bi bi-info-circle text-white fs-3"></i>
                </div>
                <h3 class="card-title text-warning mb-3">About</h3>
                <p class="card-text text-muted mb-4">
                    Learn about the benchmark's goals, methodology, and team.
                </p>
                <div class="d-grid gap-2">
                    <a href="https://arxiv.org/abs/2509.26076" target="_blank" class="btn btn-warning">
                        <i class="bi bi-file-text me-2"></i>Preprint
                    </a>
                    <a href="{% url 'team' %}" class="btn btn-warning">
                        <i class="bi bi-people-fill me-2"></i>Team
                    </a>
                    <a href="{% url 'timeline' %}" class="btn btn-warning">
                        <i class="bi bi-clock-history me-2"></i>Timeline
                    </a>
                    <a href="{% url 'faq' %}" class="btn btn-warning">
                        <i class="bi bi-question-circle me-2"></i>FAQ
                    </a>
                </div>
            </div>
        </div>
    </div>
</div>

{% if user.is_authenticated and is_admin %}
<div class="row g-4 mt-1">
    <!-- Administration Section -->
    <div class="col-md-6">
        <div class="card h-100 shadow-sm border-0">
            <div class="card-body text-center p-5">
                <div class="bg-danger bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-4" 
                     style="width: 60px; height: 60px;">
                    <i class="bi bi-gear-fill text-white fs-3"></i>
                </div>
                <h3 class="card-title text-danger mb-3">Administration</h3>
                <p class="card-text text-muted mb-4">
                    Manage and monitor model evaluations, view results, and control the evaluation queue.
                </p>
                <div class="d-grid gap-2">
                    <a href="{% url 'model_evaluation:index' %}" class="btn btn-danger">
                        <i class="bi bi-cpu me-2"></i>Model Evaluations
                    </a>
                    <a href="{% url 'model_evaluation:model_scores' %}" class="btn btn-danger">
                        <i class="bi bi-graph-up me-2"></i>Model Scores
                    </a>
                    <a href="{% url 'questions:grading_inspection' %}" class="btn btn-danger">
                        <i class="bi bi-clipboard-check me-2"></i>Inspect Grading
                    </a>
                    <a href="{% url 'review_invitations:dashboard' %}" class="btn btn-danger">
                        <i class="bi bi-person-check me-2"></i>Review Invitations
                    </a>
                    <a href="{% url 'questions:grading_comparison_list' %}" class="btn btn-danger">
                        <i class="bi bi-graph-up me-2"></i>Grading Comparison
                    </a>
                    <a href="{% url 'model_evaluation:subquestion_parsing_check' %}" class="btn btn-danger">
                        <i class="bi bi-check2-square me-2"></i>Subquestion Parsing Check
                    </a>
                    <a href="{% url 'admin:index' %}" class="btn btn-outline-danger">
                        <i class="bi bi-database me-2"></i>Database Administration
                    </a>
                </div>
            </div>
        </div>
    </div>
</div>
{% endif %}

<!-- Features Overview -->
<div class="row mt-5">
    <div class="col-12">
        <div class="card border-0 bg-light">
            <div class="card-body p-5">
                <h4 class="text-center mb-4">Key Features</h4>
                <div class="row g-4 text-center">
                    <div class="col-md-3">
                        <i class="bi bi-robot text-primary fs-1 mb-2 d-block"></i>
                        <h6>AI Model Testing</h6>
                        <small class="text-muted">Test problems against frontier models with immediate feedback</small>
                    </div>
                    <div class="col-md-3">
                        <i class="bi bi-people-fill text-info fs-1 mb-2 d-block"></i>
                        <h6>Peer Review System</h6>
                        <small class="text-muted">Expert review ensures problem quality and appropriate difficulty</small>
                    </div>
                    <div class="col-md-3">
                        <i class="bi bi-check2-circle text-success fs-1 mb-2 d-block"></i>
                        <h6>Automated Grading</h6>
                        <small class="text-muted">Subquestions enable objective evaluation alongside proof assessment</small>
                    </div>
                    <div class="col-md-3">
                        <i class="bi bi-shield-lock text-warning fs-1 mb-2 d-block"></i>
                        <h6>Privacy Preservation</h6>
                        <small class="text-muted">Majority private dataset prevents overfitting and gaming</small>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
{% endblock %}

{% block extra_js %}
<script>
document.addEventListener('DOMContentLoaded', function() {
    // Initialize Bootstrap tooltips
    var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
    var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
        return new bootstrap.Tooltip(tooltipTriggerEl);
    });

    // Normalize mobile bar heights - max bar is 75px, min is 10px
    var bars = document.querySelectorAll('.mobile-bar[data-percentage]');
    if (bars.length > 0) {
        var percentages = Array.from(bars).map(function(bar) {
            return parseFloat(bar.getAttribute('data-percentage')) || 0;
        });
        var maxPercent = Math.max.apply(null, percentages);
        if (maxPercent > 0) {
            bars.forEach(function(bar) {
                var pct = parseFloat(bar.getAttribute('data-percentage')) || 0;
                // Scale to pixels: max is 75px, min is 10px
                var scaledHeight = Math.max(10, (pct / maxPercent) * 75);
                bar.style.height = scaledHeight + 'px';
            });
        }
    }
});
</script>
{% endblock %}