<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>WE'LL FIX IT IN POST - Qualitative Results</title>
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap" rel="stylesheet">
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            line-height: 1.6;
            color: #333;
            background: #f8f9fa;
            padding: 40px 20px;
            min-height: 100vh;
        }

        .container {
            max-width: 1600px;
            margin: 0 auto;
            background: white;
            border-radius: 30px;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
            overflow: hidden;
        }

        header {
            background: #000;
            color: white;
            padding: 50px 40px;
            text-align: center;
            border-radius: 30px 30px 0 0;
        }

        h1 {
            font-size: 2.2em;
            margin-bottom: 10px;
            font-weight: 700;
        }

        .subtitle {
            font-size: 1.6em;
            opacity: 0.9;
            font-weight: 500;
        }

        .content {
            padding: 40px;
        }

        .example {
            margin-bottom: 60px;
            border: none;
            border-radius: 25px;
            overflow: hidden;
            background: white;
            box-shadow: 
                0 8px 30px rgba(0, 0, 0, 0.08),
                0 3px 12px rgba(0, 0, 0, 0.05),
                0 1px 4px rgba(0, 0, 0, 0.04);
        }

        .prompt-section {
            background: #fafafa;
            padding: 40px;
            border-bottom: none;
            border-radius: 25px 25px 0 0;
            text-align: center;
        }

        .prompt-text {
            font-size: 1.8em;
            font-weight: 600;
            color: #000;
            text-align: center;
            line-height: 1.4;
        }

        .prompt-text::before {
            content: '📜 ';
            margin-right: 10px;
        }

        .model-badge {
            display: inline-block;
            background: #000;
            color: white;
            padding: 8px 20px;
            border-radius: 20px;
            font-size: 0.9em;
            font-weight: 600;
            margin-top: 15px;
            text-align: center;
        }

        .tl-spec {
            padding: 12px 0;
            margin-top: 18px;
            font-family: 'Courier New', monospace;
            font-size: 0.95em;
            color: #333;
            text-align: center;
            border-top: 1px solid #e0e0e0;
            border-bottom: 1px solid #e0e0e0;
        }

        .tl-spec-label {
            font-weight: 500;
            color: #666;
            font-family: 'DM Sans', sans-serif;
            font-style: italic;
            margin-right: 6px;
        }

        .tl-spec-value {
            color: #000;
            font-weight: 400;
        }

        .video-comparison {
            display: grid;
            grid-template-columns: 1fr auto 1fr;
            gap: 0;
            align-items: stretch;
        }

        .video-side {
            padding: 40px;
            position: relative;
            display: flex;
            flex-direction: column;
            justify-content: flex-start;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
        }

        .video-side.left {
            background: linear-gradient(135deg, #ffffff 0%, #fafafa 100%);
            border-right: none;
            box-shadow: 
                2px 0 12px -4px rgba(0, 0, 0, 0.08),
                1px 0 4px -2px rgba(0, 0, 0, 0.05);
        }

        .video-side.right {
            background: linear-gradient(135deg, #fafafa 0%, #ffffff 100%);
            border-left: none;
            box-shadow: 
                -2px 0 12px -4px rgba(0, 0, 0, 0.08),
                -1px 0 4px -2px rgba(0, 0, 0, 0.05);
        }

        .video-label {
            font-size: 1.3em;
            font-weight: 600;
            margin-bottom: 25px;
            text-align: center;
            color: #000;
            text-transform: none;
            letter-spacing: 0;
        }

        video {
            width: 100%;
            border-radius: 20px;
            box-shadow: 
                0 10px 30px rgba(0, 0, 0, 0.15),
                0 4px 12px rgba(0, 0, 0, 0.1),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
            background: #000;
            border: 2px solid #d1d5db;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            display: block;
        }

        video:hover {
            transform: translateY(-4px);
            box-shadow: 
                0 15px 40px rgba(0, 0, 0, 0.2),
                0 6px 16px rgba(0, 0, 0, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
        }

        .scores-section {
            background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
            padding: 25px;
            margin-top: 20px;
            border-radius: 16px;
            text-align: center;
            border: 1px solid #e8e8e8;
            height: 160px;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            box-shadow: 
                0 4px 12px rgba(0, 0, 0, 0.06),
                0 2px 4px rgba(0, 0, 0, 0.04),
                inset 0 1px 2px rgba(255, 255, 255, 0.8);
        }

        .score-display {
            font-size: 0.95em;
            margin: 8px 0;
            color: #666;
            font-weight: 500;
            letter-spacing: 0.3px;
        }

        .score-value {
            font-weight: 700;
            color: #000;
            font-size: 2em;
            display: block;
            margin-top: 8px;
        }

        .score-improvement {
            display: inline-block;
            background: linear-gradient(135deg, #10b981 0%, #059669 100%);
            color: white;
            padding: 6px 14px;
            border-radius: 20px;
            font-weight: 600;
            font-size: 0.9em;
            margin-top: 12px;
            box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
        }

        .process-flow {
            padding: 50px 30px;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            align-self: stretch;
            background: linear-gradient(180deg, #f9fafb 0%, #f3f4f6 100%);
            border-left: none;
            border-right: none;
            min-width: 320px;
            max-width: 360px;
            box-shadow: 
                inset 0 0 20px rgba(0, 0, 0, 0.02),
                -4px 0 16px -4px rgba(0, 0, 0, 0.08),
                4px 0 16px -4px rgba(0, 0, 0, 0.08);
        }

        .process-arrow {
            font-size: 2.5em;
            color: #9ca3af;
            margin: 20px 0;
            animation: pulse 2s ease-in-out infinite;
            opacity: 0.6;
        }

        @keyframes pulse {
            0%, 100% {
                transform: scale(1);
                opacity: 0.6;
            }
            50% {
                transform: scale(1.08);
                opacity: 0.8;
            }
        }

        .edit-instructions {
            width: 100%;
        }

        .edit-instructions-title {
            font-size: 0.8em;
            font-weight: 600;
            color: #6b7280;
            margin-bottom: 18px;
            text-align: center;
            letter-spacing: 1px;
            text-transform: uppercase;
        }

        .edit-instructions ul {
            list-style: none;
            padding: 0;
            margin: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        .edit-instructions li {
            background: linear-gradient(145deg, #ffffff 0%, #f9fafb 100%);
            padding: 14px 20px;
            margin-bottom: 10px;
            border-radius: 10px;
            font-size: 0.88em;
            color: #4b5563;
            line-height: 1.6;
            box-shadow: 
                0 3px 6px rgba(0, 0, 0, 0.08),
                0 1px 3px rgba(0, 0, 0, 0.06),
                inset 0 1px 0 rgba(255, 255, 255, 0.8);
            border: 1.5px solid #d1d5db;
            position: relative;
            width: 100%;
            text-align: center;
            transition: all 0.2s ease;
        }

        .edit-instructions li:hover {
            box-shadow: 
                0 6px 12px rgba(0, 0, 0, 0.12),
                0 2px 6px rgba(0, 0, 0, 0.08),
                inset 0 1px 0 rgba(255, 255, 255, 0.8);
            transform: translateY(-2px);
            border-color: #9ca3af;
        }

        .edit-instructions li::before {
            content: '→';
            color: #9ca3af;
            font-weight: 600;
            margin-right: 10px;
            font-size: 1.1em;
        }

        @media (max-width: 1200px) {
            .video-comparison {
                grid-template-columns: 1fr;
            }

            .process-flow {
                max-width: 100%;
                border: none;
                padding: 30px 40px;
                box-shadow: 
                    inset 0 0 20px rgba(0, 0, 0, 0.02),
                    0 -4px 16px -4px rgba(0, 0, 0, 0.08),
                    0 4px 16px -4px rgba(0, 0, 0, 0.08);
            }

            .video-side.left {
                border: none;
                box-shadow: 
                    0 2px 12px -4px rgba(0, 0, 0, 0.08),
                    0 1px 4px -2px rgba(0, 0, 0, 0.05);
            }

            .video-side.right {
                border: none;
                box-shadow: 
                    0 -2px 12px -4px rgba(0, 0, 0, 0.08),
                    0 -1px 4px -2px rgba(0, 0, 0, 0.05);
            }

            .process-arrow {
                transform: rotate(90deg);
                font-size: 2em;
            }

            .edit-instructions li {
                font-size: 0.9em;
                padding: 14px 18px;
            }

            h1 {
                font-size: 2em;
            }

            .prompt-text {
                font-size: 1.4em;
            }
        }

        @media (max-width: 768px) {
            .content {
                padding: 20px;
            }

            header {
                padding: 30px 20px;
            }

            h1 {
                font-size: 1.6em;
            }

            .prompt-section {
                padding: 20px;
            }

            .prompt-text {
                font-size: 1.2em;
            }

            .tl-spec {
                font-size: 0.8em;
                padding: 10px 0;
            }

            .video-side {
                padding: 20px;
            }

            .video-label {
                font-size: 1.1em;
            }

            .process-flow {
                padding: 20px;
                min-width: auto;
            }

            .edit-instructions li {
                font-size: 0.85em;
                padding: 12px 16px;
            }

            .score-value {
                font-size: 1.8em;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <header>
            <h1>WE'LL FIX IT IN POST: IMPROVING TEXT-TO-VIDEO GENERATION WITH ZERO TRAINING</h1>
            <div class="subtitle">NeuS-E's Qualitative Results</div>
        </header>

        <div class="content" id="content">
            <p style="text-align: center; padding: 40px; color: #666;">Loading results...</p>
        </div>
    </div>

    <script>
        // Auto-generated examples from videos folder
        const examples = [
            {
                        "folder": "example_1",
                        "prompt": "A bus stopping and passengers boarding from the curb",
                        "T2V Model": "Pika 2.2",
                        "tl_spec": "(bus_stopping & passengers_boarding_from_the_curb)",
                        "scores": {
                                    "original": {
                                                "neus_v_score": 0.03,
                                                "edit_instructions": [
                                                            "Passengers board the bus from the curb."
                                                ]
                                    },
                                    "improved": {
                                                "neus_v_score": 0.97
                                    }
                        }
            },
            {
                        "folder": "example_2",
                        "prompt": "A person jogging and a bird flying overhead",
                        "T2V Model": "Cogvideox-5b",
                        "tl_spec": "(person_jogging & bird_flying_overhead)",
                        "scores": {
                                    "original": {
                                                "neus_v_score": 0.05,
                                                "edit_instructions": [
                                                            "Add a bird flying overhead during the jog."
                                                ]
                                    },
                                    "improved": {
                                                "neus_v_score": 0.99
                                    }
                        }
            },
            {
                        "folder": "example_3",
                        "prompt": "Always a conveyor belt moving products along the line, until a sensor detects an error, and then the entire system comes to a halt",
                        "T2V Model": "Pika 2.2",
                        "tl_spec": "G ((conveyor_belt_moving_products_along_the_line) U sensor_detects_an_error) & F system_comes_to_a_halt",
                        "scores": {
                                    "original": {
                                                "neus_v_score": 0.1,
                                                "edit_instructions": [
                                                            "The system comes to a halt after detecting an error"
                                                ]
                                    },
                                    "improved": {
                                                "neus_v_score": 0.83
                                    }
                        }
            },
            {
                        "folder": "example_4",
                        "prompt": "Always stars twinkling in the night sky, and crickets chirping in the grass",
                        "T2V Model": "Pika 2.2",
                        "tl_spec": "G (stars_twinkling_in_the_night_sky & crickets_chirping_in_the_grass)",
                        "scores": {
                                    "original": {
                                                "neus_v_score": 0.03,
                                                "edit_instructions": [
                                                            "Crickets chirping in the grass.",
                                                            "Stars twinkle in the night sky."
                                                ]
                                    },
                                    "improved": {
                                                "neus_v_score": 0.62
                                    }
                        }
            },
            {
                        "folder": "example_5",
                        "prompt": "A traffic officer directing vehicles until rush hour ends, and then they return to base",
                        "T2V Model": "Pika 2.2",
                        "tl_spec": "(traffic_officer_directing_vehicles U rush_hour_ends) & F traffic_officer_returns_to_base",
                        "scores": {
                                    "original": {
                                                "neus_v_score": 0.01,
                                                "edit_instructions": [
                                                            "Rush hour ends, and the officer returns to base."
                                                ]
                                    },
                                    "improved": {
                                                "neus_v_score": 0.82
                                    }
                        }
            }
];

        function loadData() {
            const content = document.getElementById('content');
            content.innerHTML = '';

            if (examples.length === 0) {
                content.innerHTML = '<p style="text-align: center; padding: 40px; color: #666;">No examples found.</p>';
                return;
            }

            examples.forEach(example => {
                const exampleDiv = createExampleElement(example);
                content.appendChild(exampleDiv);
            });
        }

        function createExampleElement(example) {
            const exampleContainer = document.createElement('div');
            exampleContainer.className = 'example';

            // Build scores for each video if scores exist
            let originalScoresHTML = '';
            let improvedScoresHTML = '';
            let processFlowHTML = '<div class="process-arrow">→</div>';
            
            if (example.scores) {
                const original = example.scores.original;
                const improved = example.scores.improved;
                const improvement = (improved.neus_v_score - original.neus_v_score).toFixed(2);
                
                // Original video scores
                originalScoresHTML = `
                    <div class="scores-section">
                        <div class="score-display">
                            NeuS-V Score
                            <span class="score-value">${original.neus_v_score.toFixed(2)}</span>
                        </div>
                    </div>
                `;

                // Improved video scores
                improvedScoresHTML = `
                    <div class="scores-section">
                        <div class="score-display">
                            NeuS-V Score
                            <span class="score-value">${improved.neus_v_score.toFixed(2)}</span>
                        </div>
                        <span class="score-improvement">↑ +${improvement} Improvement</span>
                    </div>
                `;

                // Process flow with edit instructions in the middle
                if (original.edit_instructions && original.edit_instructions.length > 0) {
                    const instructionsList = original.edit_instructions.map(inst => `<li>${inst}</li>`).join('');
                    processFlowHTML = `
                        <div class="process-flow">
                            <div class="edit-instructions">
                                <div class="edit-instructions-title">Improvements Applied</div>
                                <ul>${instructionsList}</ul>
                            </div>
                            <div class="process-arrow">→</div>
                        </div>
                    `;
                }
            }

            exampleContainer.innerHTML = `
                <div class="prompt-section">
                    <div class="prompt-text">${example.prompt}</div>
                    ${example['T2V Model'] ? `<div class="model-badge">🎨 T2V Model: ${example['T2V Model']}</div>` : ''}
                    ${example.tl_spec ? `<div class="tl-spec"><span class="tl-spec-label">Temporal Logic Specification (Φ) =</span><span class="tl-spec-value">${example.tl_spec}</span></div>` : ''}
                </div>
                <div class="video-comparison">
                    <div class="video-side left">
                        <div class="video-label">🎬 Original</div>
                        <video controls loop preload="metadata">
                            <source src="videos/${example.folder}/original.mp4" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>
                        ${originalScoresHTML}
                    </div>
                    ${processFlowHTML}
                    <div class="video-side right">
                        <div class="video-label">⭐ Improved by NeuS-E</div>
                        <video controls loop preload="metadata">
                            <source src="videos/${example.folder}/improved.mp4" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>
                        ${improvedScoresHTML}
                    </div>
                </div>
            `;

            return exampleContainer;
        }

        // Load data when page loads
        window.addEventListener('DOMContentLoaded', loadData);
    </script>
</body>
</html>
