<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Focus Mode: {{ alias }} - {{ question.title|default:"Question" }}</title>
    
    <!-- Bootstrap CSS -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
    <!-- Bootstrap Icons -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.1/font/bootstrap-icons.css">
    
    <!-- MathJax for mathematical notation -->
    <script>
        window.MathJax = {
            tex: {
                inlineMath: [['$', '$'], ['\\(', '\\)']],
                displayMath: [['$$', '$$'], ['\\[', '\\]']],
                processEscapes: true,
                processEnvironments: true
            },
            options: {
                skipHtmlTags: ['script', 'noscript', 'style', 'textarea', 'pre']
            }
        };
    </script>
    <script id="MathJax-script" async src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js"></script>
</head>
<body style="margin: 0; padding: 0; overflow: hidden;">

{% load question_extras %}

<div style="width: 100vw; height: 100vh; display: flex; flex-direction: column;">
    <!-- Minimal Tab Navigation -->
    <div style="background-color: #f8f9fa; border-bottom: 1px solid #dee2e6;">
        <div class="d-flex align-items-center px-3 py-1">
            <ul class="nav nav-pills nav-fill flex-grow-1 small">
                {% for tab in tabs %}
                <li class="nav-item">
                    <a class="nav-link py-1 px-2 {% if tab.is_current %}active{% endif %} 
                       {% if tab.status == 'completed' %}text-success{% elif tab.status == 'in_progress' %}text-warning{% elif tab.status == 'given_up' %}text-danger{% endif %}"
                       href="{{ tab.url }}">
                        {{ tab.alias }}
                        {% if tab.tier_group == 1 %}
                            <span class="badge bg-warning text-dark ms-1" style="font-size: 0.65rem;">T1</span>
                        {% elif tab.tier_group == 3 %}
                            <span class="badge bg-info text-dark ms-1" style="font-size: 0.65rem;">T4+</span>
                        {% endif %}
                        {% if tab.status == 'completed' %}
                            <i class="bi bi-check-circle-fill ms-1"></i>
                        {% elif tab.status == 'in_progress' %}
                            <i class="bi bi-hourglass-split ms-1"></i>
                        {% elif tab.status == 'given_up' %}
                            <i class="bi bi-x-circle-fill ms-1"></i>
                        {% endif %}
                    </a>
                </li>
                {% endfor %}
            </ul>
            <a href="{% url 'questions:grading_detail' question.pk alias %}{% if request.GET.inspect_session %}?inspect_session={{ request.GET.inspect_session }}{% endif %}" 
               class="btn btn-outline-secondary btn-sm ms-2" 
               data-bs-toggle="tooltip" title="Exit focus mode">
                <i class="bi bi-fullscreen-exit me-1"></i>
                Exit Focus
            </a>
        </div>
    </div>

    <!-- Grading Notes (Collapsible) -->
    <div style="background-color: #e9ecef; border-bottom: 1px solid #dee2e6; transition: all 0.3s ease;" id="grading-notes-section">
        <div class="px-3 py-1">
            <div class="d-flex align-items-center" id="notes-header" style="cursor: pointer;">
                <label class="mb-0 me-2 small fw-bold" style="white-space: nowrap; cursor: pointer;">
                    <i class="bi bi-chevron-down me-1" id="notes-toggle-icon" style="font-size: 10px; transition: transform 0.2s;"></i>
                    Notes:
                    <i class="bi bi-info-circle text-muted ms-1" data-bs-toggle="tooltip" 
                       title="Record your grading decisions and patterns across all answers. For example, note which false arguments count as Calculation Mistakes vs. Incorrect Logic. These notes persist across all answers for this question."></i>
                </label>
                <div class="text-muted small text-truncate" id="notes-preview" style="max-width: 400px;">
                    {{ session.grader_notes|default:"Click to add grading notes..." }}
                </div>
            </div>
            <div id="notes-content" style="display: none; margin-top: 8px;">
                <textarea class="form-control form-control-sm" id="grading-notes" 
                          rows="2"
                          placeholder="Record grading decisions (e.g., 'Matrix errors = Calculation, Theory errors = Logic')"
                          style="resize: none;"
                          {% if session.is_finalized %}disabled{% endif %}>{{ session.grader_notes|default:'' }}</textarea>
            </div>
        </div>
    </div>

    <!-- Main Content Area -->
    <div class="d-flex flex-grow-1" style="overflow: hidden;">
        <!-- Question Display -->
        <div id="question-column" style="width: 33.33%; transition: all 0.3s; border-right: 1px solid #dee2e6; display: flex; flex-direction: column;">
            <div class="bg-primary text-white d-flex justify-content-between align-items-center" style="padding: 8px 12px;">
                <h6 class="mb-0 flex-grow-1 d-flex align-items-center">
                    <i class="bi bi-question-circle me-2"></i>
                    Question & Solution
                </h6>
                <button class="collapse-btn" id="collapse-question" 
                        data-bs-toggle="tooltip" title="Collapse/Expand (Q)">
                    <i class="bi bi-chevron-left" id="collapse-icon" style="font-size: 12px;"></i>
                </button>
            </div>
            <div class="flex-grow-1 overflow-auto p-3" id="question-body" style="background-color: #ffffff;">
                {% include 'includes/question_display.html' with question=question show_solution=True show_metadata=False %}
            </div>
        </div>

        <!-- Model Answer Display -->
        <div id="answer-column" style="width: 33.33%; transition: all 0.3s; border-right: 1px solid #dee2e6; display: flex; flex-direction: column;">
            <div class="bg-info text-white" style="padding: 8px 12px;">
                <h6 class="mb-0">
                    <i class="bi bi-robot me-2"></i>
                    Model {{ alias|slice:"7:" }} Response
                </h6>
            </div>
            <div class="flex-grow-1 overflow-auto p-3" style="background-color: #ffffff;">
                {% include 'includes/model_answer_display.html' with answer_text=model_answer.answer show_toggle=True %}
            </div>
        </div>

        <!-- Grading Panel -->
        <div style="width: 33.34%; display: flex; flex-direction: column;">
            <div class="bg-warning" style="padding: 8px 12px;">
                <h6 class="mb-0 text-dark">
                    <i class="bi bi-clipboard-check me-2"></i>
                    Grading Panel
                </h6>
            </div>
            <div class="flex-grow-1 overflow-auto p-3" style="background-color: #f8f9fa;">
                    <!-- Auto-save indicator -->
                    <div id="save-indicator" class="alert alert-info py-0 px-2 text-center small mb-2">
                        <i class="bi bi-cloud-check me-1"></i>
                        Auto-save enabled
                    </div>
                    
                    {% if grading.grading_status == 'completed' and not session.is_finalized %}
                    <!-- Completed grading notice -->
                    <div class="alert alert-warning py-1 px-2 text-center mb-2">
                        <i class="bi bi-lock me-1"></i>
                        <small><strong>Completed</strong> - Click "Mark Incomplete" to edit</small>
                    </div>
                    {% endif %}

                    <form id="grading-form">
                        {% csrf_token %}
                        
                        <!-- Part A: AI Mistake Indicators -->
                        <h6 class="mt-2 mb-1 small">AI Mistake Indicators</h6>
                        
                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                1. Incorrect Logic
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Flawed logical steps or invalid reasoning"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_incorrect_logic" 
                                       id="error_incorrect_logic_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_incorrect_logic_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="error_incorrect_logic_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                2. Hallucinated
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="References to non-existent theorems, papers, or results"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_hallucinated" 
                                       id="error_hallucinated_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_hallucinated_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="error_hallucinated_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                3. Calculation
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Arithmetic or algebraic errors"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_calculation" 
                                       id="error_calculation_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_calculation_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="error_calculation_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                4. Conceptual
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Fundamental misunderstanding of mathematical concepts"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_conceptual" 
                                       id="error_conceptual_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_conceptual_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="error_conceptual_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <hr class="my-2">

                        <!-- Part B: AI Achievement Indicators -->
                        <h6 class="mb-1 small">
                            AI Achievements
                        </h6>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                5. Understanding
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Correctly identifies what needs to be proven or calculated"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_understanding" 
                                       id="achievement_understanding_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_understanding_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="achievement_understanding_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <div class="d-flex justify-content-between align-items-center">
                                <label class="form-label small mb-0">
                                    6. Correct Result
                                    <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                       title="Arrives at the correct final answer. Use N/A toggle if the problem doesn't have a definitive answer (e.g., open-ended proofs or construction problems) or if the correct answer is not known"></i>
                                </label>
                                <div class="form-check form-switch form-check-sm">
                                    <input class="form-check-input" type="checkbox" id="na_toggle" style="height: 1rem;"
                                           {% if grading.achievement_correct_result_id == 4 %}checked{% endif %}
                                           {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                    <label class="form-check-label small" for="na_toggle">N/A</label>
                                </div>
                            </div>
                            <div class="btn-group btn-group-sm w-100" role="group" id="correct_result_buttons">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_correct_result" 
                                       id="achievement_correct_result_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_correct_result_id == state.id %}checked{% endif %}
                                       {% if grading.achievement_correct_result_id == 4 or grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0 {% if grading.achievement_correct_result_id == 4 %}disabled{% endif %}" 
                                       for="achievement_correct_result_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                7. Insight
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Shows creative problem-solving or novel approaches"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_insight" 
                                       id="achievement_insight_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_insight_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="achievement_insight_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-1">
                            <label class="form-label small mb-0">
                                8. Usefulness
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Solution would be helpful to someone learning this topic"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_usefulness" 
                                       id="achievement_usefulness_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_usefulness_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary py-0" for="achievement_usefulness_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <hr class="my-2">

                        <!-- Part C: Overall Progress -->
                        <h6 class="mb-1 small">
                            Overall Progress
                            <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                               title="Rate the overall progress toward solving the problem. This is the primary score used for ranking. 0=No Progress, 1=Minor Progress, 2=Major Progress, 3=Complete Solution"></i>
                        </h6>
                        
                        <div class="btn-group btn-group-sm w-100 mb-2" role="group">
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_0" value="0"
                                   {% if grading.progress_grade == 0 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary py-0" for="progress_0" style="flex: 1;">
                                0
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_1" value="1"
                                   {% if grading.progress_grade == 1 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary py-0" for="progress_1" style="flex: 1;">
                                1
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_2" value="2"
                                   {% if grading.progress_grade == 2 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary py-0" for="progress_2" style="flex: 1;">
                                2
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_3" value="3"
                                   {% if grading.progress_grade == 3 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary py-0" for="progress_3" style="flex: 1;">
                                3
                            </label>
                        </div>

                        <!-- Comments -->
                        <div class="mb-2">
                            <label for="comments" class="form-label small mb-0">
                                Comments
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Add any additional observations, notes about edge cases, or explanations for your grading decisions"></i>
                            </label>
                            <textarea class="form-control form-control-sm" id="comments" name="comments" 
                                      rows="2" {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>{{ grading.comments|default:"" }}</textarea>
                        </div>

                        <!-- Flag -->
                        <div class="form-check mb-2">
                            <input class="form-check-input" type="checkbox" id="flag_for_organizers" 
                                   name="flag_for_organizers" {% if grading.flag_for_organizers %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="form-check-label small" for="flag_for_organizers">
                                <i class="bi bi-flag-fill text-danger me-1"></i>
                                Flag for organizers
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Check this if there are serious issues that require organizer attention (e.g., completely nonsensical response or technical problems)"></i>
                            </label>
                        </div>

                        <!-- Action Buttons -->
                        <div class="d-grid gap-1">
                            {% if grading.grading_status == 'completed' %}
                                <button type="button" class="btn btn-warning btn-sm" id="mark-incomplete-btn"
                                        {% if session.is_finalized %}disabled{% endif %}>
                                    <i class="bi bi-arrow-counterclockwise me-1"></i>
                                    Mark Incomplete
                                </button>
                            {% else %}
                                <button type="button" class="btn btn-success btn-sm" id="mark-complete-btn">
                                    <i class="bi bi-check-circle me-1"></i>
                                    Mark Complete
                                </button>
                                <button type="button" class="btn btn-danger btn-sm" id="give-up-btn"
                                        {% if grading.grading_status == 'given_up' %}disabled{% endif %}>
                                    <i class="bi bi-x-circle me-1"></i>
                                    Give Up
                                </button>
                            {% endif %}
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </div>
</div>

<style>
    /* Remove all default spacing */
    * {
        box-sizing: border-box;
    }
    
    body {
        padding: 0 !important;
        margin: 0 !important;
        font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    }
    
    /* Collapsed question column */
    #question-column.collapsed {
        width: 45px !important;
        min-width: 45px !important;
    }
    
    #question-column.collapsed #question-body,
    #question-column.collapsed h6 {
        display: none !important;
    }
    
    #question-column.collapsed > div:first-child {
        justify-content: center !important;
        padding: 8px 12px !important;
        min-height: auto !important;
    }
    
    /* Expanded answer column */
    #answer-column.expanded {
        width: calc(66.66% - 45px) !important;
    }
    
    /* Tab status colors */
    .nav-pills .nav-link.active {
        background-color: transparent !important;
        color: inherit !important;
        border: 2px solid #0d6efd !important;
        font-weight: 600;
    }
    
    .nav-pills .nav-link {
        border: 2px solid transparent;
    }
    
    .nav-pills .nav-link.text-success {
        color: #198754 !important;
    }
    
    .nav-pills .nav-link.text-warning {
        color: #ffc107 !important;
    }
    
    .nav-pills .nav-link.text-danger {
        color: #dc3545 !important;
    }
    
    /* Better button styling */
    .btn-outline-secondary {
        border-color: #ced4da;
    }
    
    .btn-outline-secondary:hover {
        background-color: #e9ecef;
        border-color: #adb5bd;
    }
    
    /* Grading panel styling */
    .btn-group-sm .btn {
        font-size: 0.8rem;
        padding: 0.15rem 0.5rem;
    }
    
    /* Clean form controls */
    .form-control-sm {
        font-size: 0.875rem;
        border-radius: 0.2rem;
    }
    
    /* Alert styling */
    .alert {
        border-radius: 0.25rem;
    }
    
    /* Smooth transitions */
    #question-column, #answer-column {
        transition: width 0.3s ease;
    }
    
    /* Collapse button styling */
    .collapse-btn {
        background-color: white;
        border: none;
        color: #0d6efd;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        font-size: 12px;
        cursor: pointer;
        transition: all 0.2s ease;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        flex-shrink: 0;
    }
    
    .collapse-btn:hover {
        background-color: #f8f9fa;
        transform: scale(1.1);
    }
    
    .collapse-btn:active {
        background-color: #e9ecef;
        transform: scale(0.95);
    }
    
    #question-column.collapsed .collapse-btn {
        writing-mode: horizontal-tb;
    }
</style>

<!-- Bootstrap JS Bundle -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>

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

// Check if grading is disabled
const isGradingDisabled = {% if grading.grading_status == 'completed' or session.is_finalized %}true{% else %}false{% endif %};
const isSessionFinalized = {% if session.is_finalized %}true{% else %}false{% endif %};

// Add visual cues when grading is completed but not finalized
if (isGradingDisabled && !isSessionFinalized) {
    // Add cursor style to all disabled button labels
    document.querySelectorAll('#grading-form label.btn').forEach(label => {
        const forId = label.getAttribute('for');
        if (forId) {
            const input = document.getElementById(forId);
            if (input && input.disabled) {
                label.style.cursor = 'not-allowed';
                label.style.opacity = '0.8';
            }
        }
    });
    
    // Add tooltip to comments textarea (where tooltips work reliably)
    const commentsField = document.getElementById('comments');
    if (commentsField && commentsField.disabled) {
        commentsField.setAttribute('data-bs-toggle', 'tooltip');
        commentsField.setAttribute('data-bs-placement', 'top');
        commentsField.setAttribute('title', 'Click "Mark Incomplete" below to edit');
        commentsField.style.cursor = 'not-allowed';
        new bootstrap.Tooltip(commentsField);
    }
    
    // Add cursor style to N/A toggle area
    const naToggle = document.getElementById('na_toggle');
    if (naToggle && naToggle.disabled) {
        naToggle.style.cursor = 'not-allowed';
    }
    
    const naToggleLabel = document.querySelector('label[for="na_toggle"]');
    if (naToggleLabel) {
        naToggleLabel.style.cursor = 'not-allowed';
    }
    
    // Also add a visual hint to the Mark Incomplete button
    const markIncompleteBtn = document.getElementById('mark-incomplete-btn');
    if (markIncompleteBtn) {
        // Add a pulsing animation to draw attention
        markIncompleteBtn.style.animation = 'pulse 2s infinite';
        
        // Add CSS for the pulse animation
        const style = document.createElement('style');
        style.textContent = `
            @keyframes pulse {
                0% { box-shadow: 0 0 0 0 rgba(255, 193, 7, 0.7); }
                70% { box-shadow: 0 0 0 10px rgba(255, 193, 7, 0); }
                100% { box-shadow: 0 0 0 0 rgba(255, 193, 7, 0); }
            }
        `;
        document.head.appendChild(style);
    }
}

// Question panel collapse functionality
const questionColumn = document.getElementById('question-column');
const answerColumn = document.getElementById('answer-column');
const collapseBtn = document.getElementById('collapse-question');
const collapseIcon = document.getElementById('collapse-icon');

let isQuestionCollapsed = sessionStorage.getItem('focusQuestionCollapsed') === 'true';

// Apply saved state on load (without toggling, just set the state directly)
if (isQuestionCollapsed) {
    applyCollapseState(true);
}

function applyCollapseState(collapsed) {
    if (collapsed) {
        questionColumn.classList.add('collapsed');
        answerColumn.classList.add('expanded');
        collapseIcon.classList.remove('bi-chevron-left');
        collapseIcon.classList.add('bi-chevron-right');
    } else {
        questionColumn.classList.remove('collapsed');
        answerColumn.classList.remove('expanded');
        collapseIcon.classList.remove('bi-chevron-right');
        collapseIcon.classList.add('bi-chevron-left');
    }
}

function toggleQuestionPanel() {
    isQuestionCollapsed = !isQuestionCollapsed;
    applyCollapseState(isQuestionCollapsed);
    sessionStorage.setItem('focusQuestionCollapsed', isQuestionCollapsed);
}

collapseBtn.addEventListener('click', toggleQuestionPanel);

// Keyboard shortcut for collapsing
document.addEventListener('keydown', (e) => {
    if (e.key === 'q' || e.key === 'Q') {
        if (document.activeElement.tagName !== 'INPUT' && 
            document.activeElement.tagName !== 'TEXTAREA') {
            toggleQuestionPanel();
        }
    }
});

// Notes collapse functionality
const notesHeader = document.getElementById('notes-header');
const notesContent = document.getElementById('notes-content');
const notesToggleIcon = document.getElementById('notes-toggle-icon');
const notesPreview = document.getElementById('notes-preview');
let isNotesCollapsed = sessionStorage.getItem('focusNotesCollapsed') !== 'false'; // Default to collapsed

// Apply saved state on load (directly, without toggling)
applyNotesState(isNotesCollapsed);

function applyNotesState(collapsed) {
    if (collapsed) {
        notesContent.style.display = 'none';
        notesToggleIcon.style.transform = 'rotate(0deg)';
        notesPreview.style.display = 'block';
    } else {
        notesContent.style.display = 'block';
        notesToggleIcon.style.transform = 'rotate(90deg)';
        notesPreview.style.display = 'none';
    }
}

function toggleNotes() {
    isNotesCollapsed = !isNotesCollapsed;
    applyNotesState(isNotesCollapsed);
    
    // Focus the textarea when expanding
    if (!isNotesCollapsed && !isSessionFinalized) {
        document.getElementById('grading-notes').focus();
    }
    
    sessionStorage.setItem('focusNotesCollapsed', isNotesCollapsed);
}

notesHeader.addEventListener('click', toggleNotes);

// Auto-save grading notes
const gradingNotesField = document.getElementById('grading-notes');
let notesTimeout;

function saveGradingNotes() {
    const formData = new FormData();
    formData.append('grader_notes', gradingNotesField.value);
    formData.append('csrfmiddlewaretoken', document.querySelector('[name=csrfmiddlewaretoken]').value);
    
    // Update preview text when saving
    const notesValue = gradingNotesField.value.trim();
    notesPreview.textContent = notesValue || 'Click to add grading notes...';
    
    return fetch('{% url "questions:save_grading_notes" question.pk %}', {
        method: 'POST',
        body: formData,
        headers: {
            'X-Requested-With': 'XMLHttpRequest',
        }
    })
    .then(response => response.json());
}

let hasNotesChanges = false;

if (!isSessionFinalized) {
    gradingNotesField.addEventListener('input', function() {
        clearTimeout(notesTimeout);
        hasNotesChanges = true;
        notesTimeout = setTimeout(() => {
            saveGradingNotes();
            hasNotesChanges = false;
        }, 2000);
    });
    
    // Update preview on blur as well
    gradingNotesField.addEventListener('blur', function() {
        const notesValue = gradingNotesField.value.trim();
        notesPreview.textContent = notesValue || 'Click to add grading notes...';
    });
}

// Handle N/A toggle
const naToggle = document.getElementById('na_toggle');
const correctResultButtons = document.getElementById('correct_result_buttons');
const correctResultInputs = correctResultButtons.querySelectorAll('input[type="radio"]');
const correctResultLabels = correctResultButtons.querySelectorAll('label');

function updateNAState() {
    // Don't modify disabled state if grading is already disabled (completed/finalized)
    if (isGradingDisabled) {
        // Just ensure the N/A hidden field exists if needed, but don't change disabled states
        if (naToggle.checked) {
            // Set the hidden N/A value (state id 4)
            let hiddenInput = document.getElementById('achievement_correct_result_4');
            if (!hiddenInput) {
                hiddenInput = document.createElement('input');
                hiddenInput.type = 'hidden';
                hiddenInput.id = 'achievement_correct_result_4';
                hiddenInput.name = 'achievement_correct_result';
                hiddenInput.value = '4';
                correctResultButtons.appendChild(hiddenInput);
            }
        } else {
            // Remove the hidden N/A value
            const hiddenInput = document.getElementById('achievement_correct_result_4');
            if (hiddenInput) {
                hiddenInput.remove();
            }
        }
        return;
    }
    
    // Normal behavior when grading is not disabled
    if (naToggle.checked) {
        correctResultInputs.forEach(input => {
            input.disabled = true;
            input.checked = false;
        });
        correctResultLabels.forEach(label => {
            label.classList.add('disabled');
        });
        
        let hiddenInput = document.getElementById('achievement_correct_result_4');
        if (!hiddenInput) {
            hiddenInput = document.createElement('input');
            hiddenInput.type = 'hidden';
            hiddenInput.id = 'achievement_correct_result_4';
            hiddenInput.name = 'achievement_correct_result';
            hiddenInput.value = '4';
            correctResultButtons.appendChild(hiddenInput);
        }
    } else {
        correctResultInputs.forEach(input => {
            input.disabled = false;
        });
        correctResultLabels.forEach(label => {
            label.classList.remove('disabled');
        });
        
        const hiddenInput = document.getElementById('achievement_correct_result_4');
        if (hiddenInput) {
            hiddenInput.remove();
        }
    }
}

// Only add the change event listener if grading is not disabled
if (!isGradingDisabled) {
    naToggle.addEventListener('change', () => {
        updateNAState();
        
        // Toggle N/A for all other model answers to match this one
        const formData = new FormData();
        formData.append('csrfmiddlewaretoken', document.querySelector('[name=csrfmiddlewaretoken]').value);
        formData.append('toggle_na_action', naToggle.checked ? 'enable' : 'disable');
        
        fetch('{% url "questions:toggle_na_for_all" question.pk %}', {
            method: 'POST',
            body: formData,
            headers: {
                'X-Requested-With': 'XMLHttpRequest',
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success && data.message) {
                // Show a subtle notification that other answers were updated
                const notification = document.createElement('div');
                notification.className = 'alert alert-info py-1 px-2 text-center small position-fixed top-0 start-50 translate-middle-x mt-3';
                notification.style.zIndex = '9999';
                notification.innerHTML = '<i class="bi bi-info-circle me-1"></i> ' + data.message;
                document.body.appendChild(notification);
                setTimeout(() => notification.remove(), 3000);
            }
        })
        .catch(error => console.error('Error toggling N/A for all:', error));
        
        autoSave();
    });
}

updateNAState();

// Auto-save functionality
let saveTimeout;
let hasPendingChanges = false;
let isSaving = false;
const form = document.getElementById('grading-form');
const saveIndicator = document.getElementById('save-indicator');

function showSaveStatus(status, message) {
    saveIndicator.className = 'alert py-0 px-2 text-center small mb-2';
    
    if (status === 'saving') {
        saveIndicator.classList.add('alert-warning');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-arrow-up me-1"></i> Saving...';
    } else if (status === 'saved') {
        saveIndicator.classList.add('alert-success');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-check me-1"></i> ' + message;
    } else if (status === 'error') {
        saveIndicator.classList.add('alert-danger');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-slash me-1"></i> ' + message;
    }
}

function autoSave() {
    clearTimeout(saveTimeout);
    hasPendingChanges = true;
    saveTimeout = setTimeout(() => {
        saveGrading();
    }, 2000);
}

function saveGrading(markComplete = false, giveUp = false, markIncomplete = false) {
    if (isSaving) {
        setTimeout(() => saveGrading(markComplete, giveUp, markIncomplete), 100);
        return Promise.resolve();
    }
    
    isSaving = true;
    hasPendingChanges = false;
    clearTimeout(saveTimeout);
    showSaveStatus('saving', 'Saving...');
    
    const formData = new FormData(form);
    if (markComplete) {
        formData.append('mark_complete', 'true');
    }
    if (giveUp) {
        formData.append('give_up', 'true');
    }
    if (markIncomplete) {
        formData.append('mark_incomplete', 'true');
    }
    
    // Post to the focus grading URL to stay in focus mode
    return fetch('{% url "questions:grading_focus" question.pk alias %}', {
        method: 'POST',
        body: formData,
        headers: {
            'X-Requested-With': 'XMLHttpRequest',
        }
    })
    .then(response => response.json())
    .then(data => {
        isSaving = false;
        if (data.success) {
            showSaveStatus('saved', 'Saved');
            
            if (markComplete && data.next_url) {
                // Use URL as returned by server (already handles focus mode conversion)
                setTimeout(() => {
                    window.location.href = data.next_url;
                }, 500);
            } else if (markComplete || giveUp || markIncomplete) {
                setTimeout(() => {
                    location.reload();
                }, 1000);
            }
        } else {
            showSaveStatus('error', 'Save failed');
        }
    })
    .catch(error => {
        isSaving = false;
        showSaveStatus('error', 'Save failed');
    });
}

// Add event listeners for auto-save
if (!isGradingDisabled) {
    form.querySelectorAll('input, textarea').forEach(element => {
        element.addEventListener('change', autoSave);
        element.addEventListener('input', autoSave);
    });
}

// Button handlers
const markCompleteBtn = document.getElementById('mark-complete-btn');
if (markCompleteBtn) {
    markCompleteBtn.addEventListener('click', () => {
        // Check if all categories have been graded (not NULL)
        const requiredFields = [
            'error_incorrect_logic',
            'error_hallucinated', 
            'error_calculation',
            'error_conceptual',
            'achievement_understanding',
            'achievement_insight',
            'achievement_usefulness',
            'progress_grade'
        ];
        
        // Special handling for achievement_correct_result (can be N/A)
        const correctResultField = naToggle.checked ? 
            document.getElementById('achievement_correct_result_4') : 
            document.querySelector('input[name="achievement_correct_result"]:checked');
        
        const missingFields = [];
        for (const fieldName of requiredFields) {
            const field = document.querySelector(`input[name="${fieldName}"]:checked`);
            if (!field) {
                // Convert field name to readable format
                const readableName = fieldName
                    .replace('error_', '')
                    .replace('achievement_', '')
                    .replace('_', ' ')
                    .replace(/\b\w/g, l => l.toUpperCase());
                missingFields.push(readableName);
            }
        }
        
        // Check correct result separately
        if (!correctResultField) {
            missingFields.push('Correct End Result');
        }
        
        if (missingFields.length > 0) {
            alert('Please complete all grading categories before marking as complete.\n\nMissing categories:\n• ' + 
                  missingFields.join('\n• ') + 
                  '\n\nYou must select at least "Not Sure" for each category.');
            return;
        }
        
        if (confirm('Mark this grading as complete?')) {
            saveGrading(true, false);
        }
    });
}

const markIncompleteBtn = document.getElementById('mark-incomplete-btn');
if (markIncompleteBtn) {
    markIncompleteBtn.addEventListener('click', () => {
        saveGrading(false, false, true);
    });
}

const giveUpBtn = document.getElementById('give-up-btn');
if (giveUpBtn && !giveUpBtn.disabled) {
    giveUpBtn.addEventListener('click', () => {
        if (confirm('Give up on grading this answer?')) {
            saveGrading(false, true);
        }
    });
}

// Save immediately when leaving the page
function saveBeforeLeaving() {
    const promises = [];
    
    // Clear any pending timeouts
    if (saveTimeout) {
        clearTimeout(saveTimeout);
    }
    if (notesTimeout) {
        clearTimeout(notesTimeout);
    }
    
    // Save grading if there are pending changes
    if (hasPendingChanges) {
        promises.push(saveGrading());
    }
    
    // Save notes if there are pending changes
    if (hasNotesChanges) {
        promises.push(saveGradingNotes());
        hasNotesChanges = false;
    }
    
    if (promises.length > 0) {
        return Promise.all(promises);
    }
    return Promise.resolve();
}

// Intercept tab navigation clicks to save before switching
document.querySelectorAll('.nav-pills .nav-link').forEach(link => {
    link.addEventListener('click', (e) => {
        // Only intercept if there are pending changes and it's not the current tab
        if ((hasPendingChanges || hasNotesChanges) && !link.classList.contains('active')) {
            e.preventDefault();
            const targetUrl = link.href;
            
            // Save before navigating
            saveBeforeLeaving().then(() => {
                window.location.href = targetUrl;
            });
        }
    });
});

// Save on blur (when field loses focus) for immediate save
if (!isGradingDisabled) {
    form.querySelectorAll('input, textarea').forEach(element => {
        element.addEventListener('blur', () => {
            if (hasPendingChanges) {
                clearTimeout(saveTimeout);
                saveGrading();
            }
        });
    });
}

// Also save grading notes on blur
if (!isSessionFinalized) {
    gradingNotesField.addEventListener('blur', () => {
        if (hasNotesChanges) {
            clearTimeout(notesTimeout);
            saveGradingNotes();
            hasNotesChanges = false;
        }
    });
}

// Save when leaving the page entirely (browser navigation, closing tab, etc.)
window.addEventListener('beforeunload', (e) => {
    if (hasPendingChanges || hasNotesChanges) {
        // Try to save synchronously (best effort, may not complete)
        const formData = new FormData(form);
        navigator.sendBeacon('', formData);
        
        // Show warning to user (modern browsers show generic message)
        e.preventDefault();
        e.returnValue = 'You have unsaved changes. Are you sure you want to leave?';
        return e.returnValue;
    }
});

// Alternative: Use page visibility API for more reliable saves
document.addEventListener('visibilitychange', () => {
    if (document.hidden && (hasPendingChanges || hasNotesChanges)) {
        // Page is being hidden (tab switch, minimize, etc.)
        saveBeforeLeaving();
    }
});

// Keyboard shortcuts
document.addEventListener('keydown', (e) => {
    if (e.ctrlKey && e.key === 's') {
        e.preventDefault();
        saveGrading();
    }
});
</script>

</body>
</html>