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

{% block title %}{{ question.title|default:"Question" }} - IMProofBench{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item">
                <a href="{% url 'questions:list' %}" class="text-decoration-none">
                    <i class="bi bi-file-earmark-text me-1"></i>
                    Questions
                </a>
            </li>
            <li class="breadcrumb-item active">
                {{ question.title|default:"Question Details"|truncatechars:50 }}
            </li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}
<div class="row">
    <div class="col-lg-8">
        <!-- Question Content -->
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <div class="d-flex justify-content-between align-items-start">
                    <div>
                        <h3 class="card-title mb-2">{{ question.title|default:"Untitled Question" }}</h3>
                        <div class="d-flex align-items-center text-muted">
                            <div class="avatar bg-secondary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 24px; height: 24px; font-size: 0.7rem;">
                                {{ question.author.name|first|upper|default:"?" }}
                            </div>
                            <span class="me-3">{{ question.author.name|default:"Unknown Author" }}</span>
                            <i class="bi bi-calendar me-1"></i>
                            <span>{{ question.last_modified|date:"F j, Y" }}</span>
                        </div>
                    </div>
                    <div class="text-end">
                        <!-- Status Badge -->
                        {% if question.status.status == 'draft' %}
                            <span class="badge bg-warning text-dark mb-2">
                                <i class="bi bi-pencil-square me-1"></i>
                                {{ question.status.status|title }}
                            </span>
                        {% elif question.status.status == 'under_review' %}
                            <span class="badge bg-info text-dark mb-2">
                                <i class="bi bi-clock me-1"></i>
                                Under Review
                            </span>
                        {% elif question.status.status == 'approved' %}
                            <span class="badge bg-success mb-2">
                                <i class="bi bi-check-circle me-1"></i>
                                {{ question.status.status|title }}
                            </span>
                        {% elif question.status.status == 'active' %}
                            <span class="badge badge-purple mb-2">
                                <i class="bi bi-activity me-1"></i>
                                Active
                            </span>
                        {% elif question.status.status == 'retracted' %}
                            <span class="badge bg-danger mb-2">
                                <i class="bi bi-x-circle me-1"></i>
                                {{ question.status.status|title }}
                            </span>
                        {% else %}
                            <span class="badge bg-secondary mb-2">
                                {{ question.status.status|title }}
                            </span>
                        {% endif %}
                        <div>
                            <a href="{% url 'questions:edit' question.pk %}" class="btn btn-outline-primary btn-sm">
                                <i class="bi bi-pencil me-1"></i>
                                Edit
                            </a>
                        </div>
                    </div>
                </div>
            </div>
            <div class="card-body">
                <!-- Question Text and Solution -->
                <div class="question-content">
                    {% include 'includes/question_display.html' with question=question show_solution=True border_color='#0d6efd' %}
                </div>

                <!-- Latest AI Solution Attempt -->
                {% if latest_ai_test %}
                <div class="ai-solution-content mt-4">
                    <h5 class="text-info mb-3">
                        <i class="bi bi-robot me-2"></i>
                        Latest AI Solution Attempt
                        <small class="text-muted ms-2">({{ latest_ai_test.created_at|date:"M j, Y \a\t g:i A" }})</small>
                    </h5>
                    {% include 'includes/model_answer_display.html' with answer_text=latest_ai_test.response show_toggle=True title="" border_style="border-left: 3px solid #0dcaf0;" container_class="ai-test-display" %}
                    <div class="mt-2">
                        <small class="text-muted">
                            <i class="bi bi-clock me-1"></i>{{ latest_ai_test.response_time_ms }}ms |
                            <i class="bi bi-currency-dollar me-1"></i>${{ latest_ai_test.cost_estimate|floatformat:4 }} |
                            <i class="bi bi-cpu me-1"></i>{{ latest_ai_test.model_name }} with web search and code interpreter
                        </small>
                    </div>
                </div>
                {% endif %}

                <!-- Tags -->
                {% if question.tags %}
                <div class="mt-4">
                    <h6 class="text-muted mb-2">Tags</h6>
                    <div>
                        {% for tag in question.tags|split:"," %}
                            {% if tag.strip %}
                                <span class="badge bg-light text-dark me-1 mb-1">{{ tag.strip }}</span>
                            {% endif %}
                        {% endfor %}
                    </div>
                </div>
                {% endif %}
            </div>
        </div>

        <!-- Subquestions -->
        {% if subquestions %}
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <h5 class="mb-0">
                    <i class="bi bi-list-ol me-2"></i>
                    Subquestions
                </h5>
            </div>
            <div class="card-body">
                {% for subquestion in subquestions %}
                <div class="subquestion mb-4 {% if not forloop.last %}border-bottom pb-4{% endif %}">
                    <div class="d-flex justify-content-between align-items-start mb-2">
                        <h6 class="text-primary mb-0">
                            Subquestion {{ subquestion.subquestion_order }}
                        </h6>
                        {% if subquestion.points %}
                            <span class="badge bg-primary">{{ subquestion.points }} pts</span>
                        {% endif %}
                    </div>
                    
                    <div class="mathematical-content mb-3">
                        {% if subquestion.text %}
                            {{ subquestion.text|markdown_latex }}
                        {% else %}
                            <p class="text-muted">No text provided.</p>
                        {% endif %}
                    </div>
                    
                    {% if subquestion.answer %}
                    <div class="mb-2">
                        <strong class="text-success">Answer:</strong>
                        <code class="bg-light px-2 py-1 rounded">{{ subquestion.answer }}</code>
                    </div>
                    {% endif %}
                    
                    {% if subquestion.rationale %}
                    <div class="small text-muted">
                        <strong>Rationale:</strong> {{ subquestion.rationale }}
                    </div>
                    {% endif %}
                </div>
                {% endfor %}
            </div>
        </div>
        {% endif %}


        <!-- Open Reviews -->
        {% if open_reviews %}
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <h5 class="mb-0">
                    <i class="bi bi-chat-left-text me-2"></i>
                    Open Reviews
                    <span class="badge bg-info ms-2">{{ open_reviews|length }}</span>
                    <small class="text-muted ms-3">Active conversations</small>
                </h5>
            </div>
            <div class="card-body">
                {% for review in open_reviews %}
                <div class="review mb-4 {% if not forloop.last %}border-bottom pb-4{% endif %}">
                    <div class="d-flex justify-content-between align-items-start mb-3">
                        <div class="d-flex align-items-center">
                            <div class="avatar bg-primary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 32px; height: 32px; font-size: 0.8rem;">
                                {% if review.is_anonymous %}
                                    ?
                                {% else %}
                                    {{ review.reviewer.name|first|upper|default:"?" }}
                                {% endif %}
                            </div>
                            <div>
                                <div class="fw-medium">
                                    {{ review.get_reviewer_display }}
                                </div>
                                <small class="text-muted">
                                    <i class="bi bi-clock me-1"></i>
                                    {{ review.time|date:"F j, Y g:i A" }}
                                </small>
                            </div>
                        </div>
                        
                        {% if review.decision %}
                        <div>
                            {% if review.decision == 'accept' %}
                                <span class="badge bg-success">
                                    <i class="bi bi-check-circle me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% elif review.decision == 'revise' %}
                                <span class="badge bg-warning text-dark">
                                    <i class="bi bi-pencil me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% elif review.decision == 'reject' %}
                                <span class="badge bg-danger">
                                    <i class="bi bi-x-circle me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% else %}
                                <span class="badge bg-secondary">
                                    {{ review.get_decision_display }}
                                </span>
                            {% endif %}
                        </div>
                        {% endif %}
                    </div>
                    
                    {% if review.comment %}
                    <div class="review-content mathematical-content">
                        {{ review.comment|markdown_latex_reviews }}
                    </div>
                    {% else %}
                    <div class="text-muted fst-italic">
                        No comment provided.
                    </div>
                    {% endif %}
                    
                    <!-- Replies to this review -->
                    {% if review.replies.all %}
                    <div class="ms-5 mt-3">
                        {% for reply in review.replies.all %}
                        <div class="reply bg-light p-3 rounded mb-2">
                            <div class="d-flex align-items-center mb-2">
                                <div class="avatar bg-secondary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 24px; height: 24px; font-size: 0.7rem;">
                                    {{ reply.author.name|first|upper|default:"?" }}
                                </div>
                                <div>
                                    <small class="fw-medium">{{ reply.author.name }}</small>
                                    <small class="text-muted ms-2">
                                        <i class="bi bi-clock"></i>
                                        {{ reply.creation_time|date:"M j, Y g:i A" }}
                                    </small>
                                </div>
                            </div>
                            <div class="reply-content mathematical-content">
                                {{ reply.comment|markdown_latex_reviews }}
                            </div>
                        </div>
                        {% endfor %}
                    </div>
                    {% endif %}
                    
                    <!-- Reply form (only for authors on reviews without author replies) -->
                    {% if review.can_reply %}
                    <div class="mt-3">
                        <button class="btn btn-sm btn-outline-primary" onclick="showReplyForm({{ review.id }})">
                            <i class="bi bi-reply me-1"></i>
                            Reply
                        </button>
                        <div id="reply-form-{{ review.id }}" class="mt-3" style="display: none;">
                            <form onsubmit="submitReply(event, {{ review.id }}); return false;">
                                {% csrf_token %}
                                <div class="mb-2">
                                    <textarea 
                                        class="form-control" 
                                        name="comment" 
                                        rows="3" 
                                        placeholder="Write your reply here..."
                                        required
                                    ></textarea>
                                </div>
                                <div class="d-flex gap-2">
                                    <button type="submit" class="btn btn-primary btn-sm">
                                        <i class="bi bi-send me-1"></i>
                                        Submit Reply
                                    </button>
                                    <button type="button" class="btn btn-secondary btn-sm" onclick="hideReplyForm({{ review.id }})">
                                        Cancel
                                    </button>
                                </div>
                            </form>
                        </div>
                    </div>
                    {% endif %}
                    
                    <!-- Reviewer action buttons for revise reviews with replies -->
                    {% if review.can_accept or review.can_close or review.can_add_review %}
                    <div class="mt-3 pt-3 border-top">
                        <div class="d-flex flex-wrap gap-2 mb-2">
                            {% if review.can_accept %}
                            <form method="post" action="{% url 'questions:recommend_acceptance' question.pk %}" class="d-inline">
                                {% csrf_token %}
                                <button type="submit" class="btn btn-success btn-sm">
                                    <i class="bi bi-check-circle me-1"></i>
                                    Recommend for Acceptance
                                </button>
                            </form>
                            {% endif %}
                            
                            {% if review.can_add_review %}
                            <a href="{% url 'questions:review' question.pk %}?responding_to={{ review.id }}" class="btn btn-primary btn-sm">
                                <i class="bi bi-plus-circle me-1"></i>
                                Add Review
                            </a>
                            {% endif %}
                            
                            {% if review.can_close %}
                            <form method="post" action="{% url 'questions:close_review' review.id %}" class="d-inline">
                                {% csrf_token %}
                                <button type="submit" class="btn btn-secondary btn-sm">
                                    <i class="bi bi-x-circle me-1"></i>
                                    Close Review
                                </button>
                            </form>
                            {% endif %}
                        </div>
                        <div class="text-muted small">
                            {% if review.can_accept %}
                                <div><strong>Recommend for Acceptance:</strong> Recommend this question for inclusion in the benchmark (author addressed your feedback)</div>
                            {% endif %}
                            {% if review.can_add_review %}
                                <div><strong>Add Review:</strong> Give additional comments in new review</div>
                            {% endif %}
                            {% if review.can_close %}
                                <div><strong>Close Review:</strong> Conclude conversation (question remains as "Under Review")</div>
                            {% endif %}
                        </div>
                    </div>
                    {% endif %}
                </div>
                {% endfor %}
            </div>
        </div>
        {% endif %}
        
        <!-- Closed Reviews -->
        {% if closed_reviews %}
        <div class="card shadow-sm mb-4 closed-reviews-section">
            <div class="card-header bg-white">
                <h5 class="mb-0">
                    <i class="bi bi-check-circle me-2"></i>
                    Closed Reviews
                    <span class="badge bg-secondary ms-2">{{ closed_reviews|length }}</span>
                    <small class="text-muted ms-3">Conversation complete</small>
                </h5>
            </div>
            <div class="card-body">
                {% for review in closed_reviews %}
                <div class="review mb-4 {% if not forloop.last %}border-bottom pb-4{% endif %}">
                    <div class="d-flex justify-content-between align-items-start mb-3">
                        <div class="d-flex align-items-center">
                            <div class="avatar bg-primary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 32px; height: 32px; font-size: 0.8rem;">
                                {% if review.is_anonymous %}
                                    ?
                                {% else %}
                                    {{ review.reviewer.name|first|upper|default:"?" }}
                                {% endif %}
                            </div>
                            <div>
                                <div class="fw-medium">
                                    {{ review.get_reviewer_display }}
                                </div>
                                <small class="text-muted">
                                    <i class="bi bi-clock me-1"></i>
                                    {{ review.time|date:"F j, Y g:i A" }}
                                </small>
                            </div>
                        </div>
                        
                        {% if review.decision %}
                        <div>
                            {% if review.decision == 'accept' %}
                                <span class="badge bg-success">
                                    <i class="bi bi-check-circle me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% elif review.decision == 'revise' %}
                                <span class="badge bg-warning text-dark">
                                    <i class="bi bi-pencil me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% elif review.decision == 'reject' %}
                                <span class="badge bg-danger">
                                    <i class="bi bi-x-circle me-1"></i>
                                    {{ review.get_decision_display }}
                                </span>
                            {% else %}
                                <span class="badge bg-secondary">
                                    {{ review.get_decision_display }}
                                </span>
                            {% endif %}
                        </div>
                        {% endif %}
                    </div>
                    
                    {% if review.comment %}
                    <div class="review-content mathematical-content">
                        {{ review.comment|markdown_latex_reviews }}
                    </div>
                    {% else %}
                    <div class="text-muted fst-italic">
                        No comment provided.
                    </div>
                    {% endif %}
                    
                    <!-- Replies to this review -->
                    {% if review.replies.all %}
                    <div class="ms-5 mt-3">
                        {% for reply in review.replies.all %}
                        <div class="reply bg-light p-3 rounded mb-2">
                            <div class="d-flex align-items-center mb-2">
                                <div class="avatar bg-secondary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 24px; height: 24px; font-size: 0.7rem;">
                                    {{ reply.author.name|first|upper|default:"?" }}
                                </div>
                                <div>
                                    <small class="fw-medium">{{ reply.author.name }}</small>
                                    <small class="text-muted ms-2">
                                        <i class="bi bi-clock"></i>
                                        {{ reply.creation_time|date:"M j, Y g:i A" }}
                                    </small>
                                </div>
                            </div>
                            <div class="reply-content mathematical-content">
                                {{ reply.comment|markdown_latex_reviews }}
                            </div>
                        </div>
                        {% endfor %}
                    </div>
                    {% endif %}
                    
                </div>
                {% endfor %}
            </div>
        </div>
        {% endif %}
        
        <!-- Empty state when no reviews yet -->
        {% if not open_reviews and not closed_reviews and question.status.status == 'under_review' and is_author %}
        <div class="card shadow-sm mb-4">
            <div class="card-body text-center py-4">
                <i class="bi bi-clock text-muted mb-2" style="font-size: 2rem;"></i>
                <h6 class="text-muted">Waiting for Reviews</h6>
                <p class="text-muted mb-0">Your question is currently under review. You'll see feedback here once reviewers submit their comments.</p>
            </div>
        </div>
        {% endif %}
    </div>

    <!-- Sidebar -->
    <div class="col-lg-4">
        <!-- Difficulty Ratings -->
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <h6 class="mb-0">
                    <i class="bi bi-speedometer2 me-2"></i>
                    Difficulty Ratings
                </h6>
            </div>
            <div class="card-body">
                <div class="row g-3">
                    <div class="col-6">
                        <div class="text-center">
                            <div class="difficulty-badge {% if question.difficulty_background %}bg-primary text-white{% else %}bg-light text-muted{% endif %} rounded-circle d-inline-flex align-items-center justify-content-center mb-2" style="width: 40px; height: 40px;">
                                {% if question.difficulty_background %}{{ question.difficulty_background }}{% else %}—{% endif %}
                            </div>
                            <div class="small text-muted">Background</div>
                        </div>
                    </div>
                    <div class="col-6">
                        <div class="text-center">
                            <div class="difficulty-badge {% if question.difficulty_reasoning %}bg-success text-white{% else %}bg-light text-muted{% endif %} rounded-circle d-inline-flex align-items-center justify-content-center mb-2" style="width: 40px; height: 40px;">
                                {% if question.difficulty_reasoning %}{{ question.difficulty_reasoning }}{% else %}—{% endif %}
                            </div>
                            <div class="small text-muted">Reasoning</div>
                        </div>
                    </div>
                    <div class="col-6">
                        <div class="text-center">
                            <div class="difficulty-badge {% if question.difficulty_insight %}bg-warning text-dark{% else %}bg-light text-muted{% endif %} rounded-circle d-inline-flex align-items-center justify-content-center mb-2" style="width: 40px; height: 40px;">
                                {% if question.difficulty_insight %}{{ question.difficulty_insight }}{% else %}—{% endif %}
                            </div>
                            <div class="small text-muted">Insight</div>
                        </div>
                    </div>
                    <div class="col-6">
                        <div class="text-center">
                            <div class="difficulty-badge {% if question.difficulty_compute %}bg-info text-dark{% else %}bg-light text-muted{% endif %} rounded-circle d-inline-flex align-items-center justify-content-center mb-2" style="width: 40px; height: 40px;">
                                {% if question.difficulty_compute %}{{ question.difficulty_compute }}{% else %}—{% endif %}
                            </div>
                            <div class="small text-muted">Compute</div>
                        </div>
                    </div>
                </div>
                <div class="mt-3 small text-muted text-center">
                    Scale: 1 (Easy) to 5 (Very Hard)
                </div>
            </div>
        </div>

        <!-- Metadata -->
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <h6 class="mb-0">
                    <i class="bi bi-info-circle me-2"></i>
                    Metadata
                </h6>
            </div>
            <div class="card-body">
                <div class="row g-3 small">
                    <div class="col-12">
                        <div class="text-muted">Question ID</div>
                        <div class="fw-medium">#{{ question.id }}</div>
                    </div>
                    <div class="col-12">
                        <div class="text-muted">Created</div>
                        <div class="fw-medium">{{ question.creation_time|date:"F j, Y g:i A" }}</div>
                    </div>
                    <div class="col-12">
                        <div class="text-muted">Last Modified</div>
                        <div class="fw-medium">{{ question.last_modified|date:"F j, Y g:i A" }}</div>
                    </div>
                    {% if subquestions %}
                    <div class="col-12">
                        <div class="text-muted">Subquestions</div>
                        <div class="fw-medium">{{ subquestions|length }} item{{ subquestions|length|pluralize }}</div>
                    </div>
                    {% endif %}
                </div>
            </div>
        </div>

        <!-- Actions -->
        <div class="card shadow-sm">
            <div class="card-body">
                <div class="d-grid gap-2">
                    {% if can_submit_for_review %}
                    <form method="post" action="{% url 'questions:submit_review' question.pk %}">
                        {% csrf_token %}
                        <button type="submit" class="btn btn-success w-100">
                            <i class="bi bi-send me-2"></i>
                            Submit for Review
                        </button>
                    </form>
                    {% endif %}
                    
                    {% if is_author and question.status.status == 'under_review' %}
                    <form method="post" action="{% url 'questions:revert_to_draft' question.pk %}">
                        {% csrf_token %}
                        <button type="submit" class="btn btn-outline-warning w-100" 
                                onclick="return confirm('Are you sure you want to revert this question to draft status? This will allow you to make changes but will require resubmission for review.')">
                            <i class="bi bi-arrow-counterclockwise me-2"></i>
                            Revert to Draft
                        </button>
                    </form>
                    {% endif %}
                    
                    
                    {% comment %} Revert from Retracted Button {% endcomment %}
                    {% if is_author or is_admin %}
                        {% if question.status.status == 'retracted' %}
                        <form method="post" action="{% url 'questions:revert_from_retracted' question.pk %}">
                            {% csrf_token %}
                            <button type="submit" class="btn btn-outline-success w-100" 
                                    data-bs-toggle="tooltip" 
                                    data-bs-placement="top" 
                                    title="Revert question back to draft status so you can edit and resubmit for review"
                                    onclick="return confirm('Are you sure you want to revert this question to draft status? You will be able to edit and resubmit for review.')">
                                <i class="bi bi-arrow-counterclockwise me-2"></i>
                                Revert to Draft Status
                            </button>
                        </form>
                        {% endif %}
                    {% endif %}
                    
                    {% if can_review %}
                    <a href="{% url 'questions:review' question.pk %}" class="btn btn-primary w-100">
                        <i class="bi bi-chat-left-text me-2"></i>
                        {% if user_review_count > 0 %}
                            Add Another Review
                        {% else %}
                            Review Question
                        {% endif %}
                    </a>
                    {% if user_review_count > 0 %}
                    <small class="text-muted text-center d-block mt-1">
                        You've submitted {{ user_review_count }} review{{ user_review_count|pluralize }}
                    </small>
                    {% endif %}
                    {% endif %}
                    
                    {% if has_accepted_invitation %}
                    <button type="button" class="btn btn-outline-danger w-100 mt-2" 
                            onclick="confirmDeclineReview({{ question.pk }})">
                        <i class="bi bi-x-circle me-2"></i>
                        Decline Review Request
                    </button>
                    {% endif %}

                    {% comment %} Evaluation Results Button - Show for all active questions (everyone can see) {% endcomment %}
                    {% if question.status.status == 'active' %}
                    <a href="{% url 'questions:evaluation_results' question.pk %}" class="btn btn-info w-100">
                        <i class="bi bi-bar-chart-line me-2"></i>
                        Evaluation Results
                    </a>
                    {% endif %}

                    {% comment %} Grading Button - Show when released answers exist (for authors, assigned reviewers, or admins) {% endcomment %}
                    {% if can_grade %}
                    <a href="{% url 'questions:grading_overview' question.pk %}" class="btn btn-warning w-100">
                        <i class="bi bi-clipboard-check me-2"></i>
                        Grade Model Answers
                    </a>
                    {% endif %}

                    {% if is_author or is_admin %}
                    <a href="{% url 'questions:edit' question.pk %}" class="btn btn-primary">
                        <i class="bi bi-pencil me-2"></i>
                        Edit Question
                    </a>

                    <a href="{% url 'questions:history' question.pk %}" class="btn btn-outline-secondary">
                        <i class="bi bi-clock-history me-2"></i>
                        View History
                    </a>

                    {% comment %} Assign Reviewer Button - Admin only, when under review {% endcomment %}
                    {% if is_admin and question.status.status == 'under_review' %}
                    <a href="{% url 'review_invitations:send' question.pk %}" class="btn btn-info w-100">
                        <i class="bi bi-person-plus me-2"></i>
                        Assign Reviewer
                        {% if reviewer_count > 0 %}
                        <span class="badge bg-light text-dark ms-2">{{ reviewer_count }} assigned</span>
                        {% endif %}
                    </a>

                    {% comment %} Admin Approve Button - Admin only, when under review {% endcomment %}
                    <form method="post" action="{% url 'questions:admin_approve' question.pk %}" class="mt-2">
                        {% csrf_token %}
                        <button type="submit" class="btn btn-success w-100"
                                onclick="return confirm('Are you sure you want to approve this question for the benchmark?');">
                            <i class="bi bi-check-circle-fill me-2"></i>
                            Approve Question
                        </button>
                    </form>
                    {% endif %}

                    {% comment %} Inspect Grading Button - Show for admins when grading sessions exist {% endcomment %}
                    {% if is_admin and has_grading_sessions %}
                    <div class="dropdown w-100 mt-2">
                        <button class="btn btn-outline-danger dropdown-toggle w-100" type="button" id="inspectGradingDropdown" data-bs-toggle="dropdown" aria-expanded="false">
                            <i class="bi bi-eye me-2"></i>
                            Inspect Grading Sessions
                        </button>
                        <ul class="dropdown-menu w-100" aria-labelledby="inspectGradingDropdown">
                            {% if active_grading_sessions %}
                            <li><h6 class="dropdown-header">Active Sessions</h6></li>
                            {% for session_info in active_grading_sessions %}
                            <li>
                                <a class="dropdown-item" href="{% url 'questions:grading_overview' question_id=question.pk %}?inspect_session={{ session_info.session.pk }}">
                                    <i class="bi bi-hourglass-split text-success me-2"></i>
                                    {{ session_info.grader_email }}
                                </a>
                            </li>
                            {% endfor %}
                            {% endif %}
                            {% if active_grading_sessions and finalized_grading_sessions %}
                            <li><hr class="dropdown-divider"></li>
                            {% endif %}
                            {% if finalized_grading_sessions %}
                            <li><h6 class="dropdown-header">Finalized Sessions</h6></li>
                            {% for session_info in finalized_grading_sessions %}
                            <li>
                                <a class="dropdown-item" href="{% url 'questions:grading_overview' question_id=question.pk %}?inspect_session={{ session_info.session.pk }}">
                                    <i class="bi bi-check-circle text-primary me-2"></i>
                                    {{ session_info.grader_email }}
                                </a>
                            </li>
                            {% endfor %}
                            {% endif %}
                        </ul>
                    </div>
                    {% endif %}

                    {% comment %} Activate Question Button {% endcomment %}
                    {% if question.status.status == 'approved' and user.participant.is_admin %}
                    <button type="button" class="btn btn-success w-100 activate-question-btn"
                            data-question-id="{{ question.pk }}"
                            data-question-title="{{ question.title|default:'Untitled Question' }}"
                            title="Activate for evaluation by all models">
                        <i class="bi bi-play-fill me-2"></i>
                        Activate
                    </button>
                    {% endif %}

                    {% comment %} Publish Question Button - Admin only, for active unpublished questions {% endcomment %}
                    {% if question.status.status == 'active' and user.participant.is_admin and not question.published %}
                    <button type="button" class="btn w-100 publish-question-btn"
                            style="background-color: #fd7e14; border-color: #fd7e14; color: white;"
                            data-question-id="{{ question.pk }}"
                            data-question-title="{{ question.title|default:'Untitled Question' }}"
                            title="Make question publicly visible (irreversible)">
                        <i class="bi bi-globe me-2"></i>
                        Publish Question
                    </button>
                    {% endif %}

                    {% comment %} Retract Question Button {% endcomment %}
                    {% if question.status.status != 'retracted' %}
                    <form method="post" action="{% url 'questions:retract' question.pk %}">
                        {% csrf_token %}
                        <button type="submit" class="btn btn-secondary w-100" 
                                data-bs-toggle="tooltip" 
                                data-bs-placement="top" 
                                title="Remove problem from pool of questions considered for the benchmark (can edit and revert to Draft status at later point)"
                                onclick="return confirm('Are you sure you want to retract this question from benchmark consideration? You can revert to draft status later to make changes.')">
                            <i class="bi bi-archive me-2"></i>
                            Retract Question
                        </button>
                    </form>
                    {% endif %}
                    
                    <a href="{% url 'questions:delete' question.pk %}" class="btn btn-danger">
                        <i class="bi bi-trash me-2"></i>
                        Delete Question
                    </a>
                    {% endif %}
                    
                    <a href="{% url 'questions:list' %}" class="btn btn-outline-secondary">
                        <i class="bi bi-arrow-left me-2"></i>
                        Back to Questions
                    </a>
                </div>
            </div>
        </div>
    </div>
</div>
{% endblock %}

{% block extra_css %}
<style>
    .mathematical-content {
        line-height: 1.8;
        font-size: 1.05rem;
    }
    
    .difficulty-badge {
        font-weight: 600;
        font-size: 1.1rem;
    }
    
    /* Custom badge colors */
    .badge-purple { 
        background-color: #6f42c1 !important; 
        color: white !important;
    }
    
    .avatar {
        font-weight: 600;
    }
    
    .question-content .mathematical-content {
        border-left: 4px solid #0d6efd;
    }
    
    .solution-content .mathematical-content {
        border-left: 4px solid #198754;
    }
    
    .subquestion {
        position: relative;
    }
    
    .subquestion:before {
        content: '';
        position: absolute;
        left: -15px;
        top: 0;
        bottom: 0;
        width: 3px;
        background: #dee2e6;
        border-radius: 2px;
    }
    
    code {
        font-size: 0.9rem;
    }
    
    .breadcrumb {
        background: none;
        padding: 0;
        margin: 0;
        font-size: 0.9rem;
    }
    
    .breadcrumb-item + .breadcrumb-item::before {
        content: "›";
        color: #6c757d;
    }
    
    .review {
        position: relative;
    }
    
    .review-content {
        background: #f8f9fa;
        border-left: 3px solid #dee2e6;
        padding: 1rem;
        border-radius: 0.375rem;
        margin-top: 0.75rem;
    }
    
    .avatar {
        font-weight: 600;
    }
    
    .reply {
        border-left: 3px solid #6c757d;
        position: relative;
    }
    
    .reply-content {
        font-size: 0.95rem;
    }
    
    /* Style for closed reviews section */
    .card-header .bi-check-circle {
        color: #6c757d;
    }
    
    /* Slightly muted closed reviews */
    .closed-reviews-section {
        opacity: 0.9;
    }
</style>
{% endblock %}

{% block extra_js %}
<script>
function showReplyForm(reviewId) {
    document.getElementById('reply-form-' + reviewId).style.display = 'block';
}

function hideReplyForm(reviewId) {
    document.getElementById('reply-form-' + reviewId).style.display = 'none';
    // Clear the textarea
    document.querySelector('#reply-form-' + reviewId + ' textarea').value = '';
}

function confirmDeclineReview(questionId) {
    if (confirm('Are you sure you want to decline this review request? This will remove the question from your review assignments.')) {
        // Create form and submit
        const form = document.createElement('form');
        form.method = 'POST';
        form.action = '{% url "review_invitations:decline_after_accept" 0 %}'.replace('0', questionId);
        
        // Add CSRF token
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
        const csrfInput = document.createElement('input');
        csrfInput.type = 'hidden';
        csrfInput.name = 'csrfmiddlewaretoken';
        csrfInput.value = csrfToken;
        form.appendChild(csrfInput);
        
        document.body.appendChild(form);
        form.submit();
    }
}

function submitReply(event, reviewId) {
    event.preventDefault();
    
    const form = event.target;
    const textarea = form.querySelector('textarea');
    const comment = textarea.value.trim();
    
    if (!comment) {
        alert('Please enter a reply.');
        return;
    }
    
    // Get CSRF token
    const csrfToken = form.querySelector('[name=csrfmiddlewaretoken]').value;
    
    // Disable form while submitting
    const submitBtn = form.querySelector('button[type=submit]');
    const originalText = submitBtn.innerHTML;
    submitBtn.disabled = true;
    submitBtn.innerHTML = '<i class="bi bi-hourglass-split me-1"></i> Submitting...';
    
    // Submit via AJAX
    fetch("{% url 'questions:submit_reply' review_id=0 %}".replace('0', reviewId), {
        method: 'POST',
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded',
            'X-CSRFToken': csrfToken,
            'X-Requested-With': 'XMLHttpRequest'
        },
        body: 'comment=' + encodeURIComponent(comment)
    })
    .then(response => response.json())
    .then(data => {
        if (data.success) {
            // Reload the page to show the new reply
            location.reload();
        } else {
            alert('Error: ' + (data.error || 'Unable to submit reply.'));
            // Re-enable form
            submitBtn.disabled = false;
            submitBtn.innerHTML = originalText;
        }
    })
    .catch(error => {
        alert('Network error: Unable to submit reply.');
        // Re-enable form
        submitBtn.disabled = false;
        submitBtn.innerHTML = originalText;
    });
}

// Initialize Bootstrap tooltips
document.addEventListener('DOMContentLoaded', function() {
    var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
    var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
        return new bootstrap.Tooltip(tooltipTriggerEl);
    });
    
    // Handle activate question button clicks
    const activateButtons = document.querySelectorAll('.activate-question-btn');
    const modal = document.getElementById('activateQuestionModal');

    if (modal && activateButtons.length > 0) {
        const form = document.getElementById('activate-question-form');
        const titlePlaceholder = document.getElementById('question-title-placeholder');

        activateButtons.forEach(button => {
            button.addEventListener('click', function() {
                const questionId = this.getAttribute('data-question-id');
                const questionTitle = this.getAttribute('data-question-title');

                // Update modal content
                titlePlaceholder.textContent = `"${questionTitle}"`;

                // Update form action
                form.action = `/questions/${questionId}/activate/`;

                // Show modal
                const modalInstance = new bootstrap.Modal(modal);
                modalInstance.show();
            });
        });
    }

    // Handle publish question button clicks
    const publishButtons = document.querySelectorAll('.publish-question-btn');
    const publishModal = document.getElementById('publishQuestionModal');

    if (publishModal && publishButtons.length > 0) {
        const publishForm = document.getElementById('publish-question-form');
        const publishTitlePlaceholder = document.getElementById('publish-question-title-placeholder');

        publishButtons.forEach(button => {
            button.addEventListener('click', function() {
                const questionId = this.getAttribute('data-question-id');
                const questionTitle = this.getAttribute('data-question-title');

                // Update modal content
                publishTitlePlaceholder.textContent = `"${questionTitle}"`;

                // Update form action
                publishForm.action = `/questions/${questionId}/publish/`;

                // Show modal
                const modalInstance = new bootstrap.Modal(publishModal);
                modalInstance.show();
            });
        });
    }
});
</script>

<!-- Activation Confirmation Modal -->
<div class="modal fade" id="activateQuestionModal" tabindex="-1" aria-labelledby="activateQuestionModalLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <h5 class="modal-title" id="activateQuestionModalLabel">
                    <i class="bi bi-play-fill me-2"></i>
                    Activate Question
                </h5>
                <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
            </div>
            <div class="modal-body">
                <div class="alert alert-info">
                    <i class="bi bi-info-circle me-2"></i>
                    <strong>This will:</strong>
                    <ul class="mb-0 mt-2">
                        <li>Change question status from "Approved" to "Active"</li>
                        <li>Queue evaluations for all active models in the system</li>
                        <li>Begin automatic evaluation processing</li>
                    </ul>
                </div>
                <p class="mb-0">
                    Are you sure you want to activate 
                    <strong id="question-title-placeholder">this question</strong> 
                    for evaluation?
                </p>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
                <form id="activate-question-form" method="post" style="display: inline;">
                    {% csrf_token %}
                    <button type="submit" class="btn btn-primary">
                        <i class="bi bi-play-fill me-1"></i>
                        Activate Question
                    </button>
                </form>
            </div>
        </div>
    </div>
</div>

<!-- Publish Question Confirmation Modal -->
<div class="modal fade" id="publishQuestionModal" tabindex="-1" aria-labelledby="publishQuestionModalLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header bg-warning">
                <h5 class="modal-title" id="publishQuestionModalLabel">
                    <i class="bi bi-globe me-2"></i>
                    Publish Question
                </h5>
                <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
            </div>
            <div class="modal-body">
                <div class="alert alert-danger">
                    <i class="bi bi-exclamation-triangle-fill me-2"></i>
                    <strong>Warning: This action is IRREVERSIBLE!</strong>
                </div>
                <div class="alert alert-info">
                    <i class="bi bi-info-circle me-2"></i>
                    <strong>Publishing this question will:</strong>
                    <ul class="mb-0 mt-2">
                        <li>Make the question visible to all logged-in users</li>
                        <li>Exclude it from official benchmark results and leaderboard</li>
                        <li>Prevent grading of model answers from models released after publication</li>
                        <li><strong>This action cannot be undone</strong></li>
                    </ul>
                </div>
                <p class="mb-0">
                    Are you sure you want to publish
                    <strong id="publish-question-title-placeholder">this question</strong>?
                </p>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
                <form id="publish-question-form" method="post" style="display: inline;">
                    {% csrf_token %}
                    <button type="submit" class="btn" style="background-color: #fd7e14; border-color: #fd7e14; color: white;">
                        <i class="bi bi-globe me-1"></i>
                        Publish Question
                    </button>
                </form>
            </div>
        </div>
    </div>
</div>
{% endblock %}
