<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>3DGS Rendering Comparison Tool</title>
    <!-- Load Tailwind CSS -->
    <script src="https://cdn.tailwindcss.com"></script>
    <style>
        /* Custom styles for the comparison clip effect */
        .js-comparison-container {
            position: relative;
            /* Maintain aspect ratio - 16:9 example */
            aspect-ratio: 16 / 9;
            max-width: 100%;
            height: auto;
            cursor: ew-resize; /* Indicate horizontal resizing */
        }
        /* The clipping container: sets the visible width */
        .js-comparison-video-top {
            position: absolute;
            top: 0;
            left: 0;
            height: 100%;
            overflow: hidden; /* This is key to clipping the video */
            width: 50%; /* Initial width set by JS */
        }
        /* The actual video element styles */
        .comparison-video {
            display: block;
            /* CRITICAL FIX: Dimensions must be controlled ONLY by JS in precise pixel values
               to prevent scaling relative to the shrinking parent clip container. */

            /* Ensures maximum coverage and identical scaling across both videos */
            object-fit: cover;
            /* Pins the video content to the top-left corner to prevent centering shifts */
            object-position: top left;
            /* Ensure the video content is perfectly overlaid */
            position: absolute;
            top: 0;
            left: 0;
        }

        /* Styling for the draggable handle */
        .js-slider-handle {
            position: absolute;
            top: 0;
            width: 4px;
            height: 100%;
            background: #f87171; /* Tailwind red-500 */
            z-index: 20;
            transform: translateX(-50%);
            cursor: ew-resize;
            border-radius: 9999px;
            box-shadow: 0 0 10px rgba(248, 113, 113, 0.8);
        }
        /* Add a visible circle/dot on the handle for better grip */
        .js-slider-handle::after {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 30px;
            height: 30px;
            background-color: #f87171; /* Match handle color */
            border: 3px solid white;
            border-radius: 50%;
            box-shadow: 0 0 8px rgba(0, 0, 0, 0.4);
        }
        /* Style for the button container inside each comparison block */
        .js-controls-container {
            position: absolute;
            bottom: 1rem;
            left: 50%;
            transform: translateX(-50%);
            z-index: 30; /* Above videos and handle */
            background: rgba(0, 0, 0, 0.5);
            padding: 8px 16px;
            border-radius: 9999px;
        }
    </style>
</head>
<body class="bg-gray-50 text-gray-800 p-4 sm:p-8 min-h-screen flex flex-col items-center justify-center font-sans">

    <div class="max-w-5xl w-full mx-auto">
        <h1 class="text-3xl sm:text-5xl font-extrabold text-center mb-2 text-indigo-700">
            Qonvolution: Towards Learning of High-Frequency Signals with Queried Convolutions
        </h1>
        <p class="text-2xl text-left text-black-500 mb-8">
            Novel view reconstructions for conventional 3D Gaussian Splatting (3DGS) <b>(left)</b> and our proposed method with adding QNN <b>(right)</b> with SfM initializations on the Mip-NeRF 360 dataset. 
            Our method of adding QNN, faithfully reconstructs the scene providing higher quality renderings.
            <text class="text-2xl text-center text-gray-500 mb-8">
                Slide the handles to compare the baseline 3DGS vs. proposed 3DGS+QNN rendering.
            </text>
        </p>


        <!-- === Scene 1 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/bicycle.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/bicycle.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 1. Bicycle</p>
        </div>
        <br><br>

        <!-- === Scene 2 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/stump.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/stump.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 2. Stump</p>
        </div>
        <br><br>
        

        <!-- === Scene 3 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/garden.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/garden.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 3. Garden</p>
        </div>
        <br><br>


        <!-- === Scene 4 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/bonsai.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/bonsai.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 4. Bonsai</p>
        </div>
        <br><br>

        <!-- === Scene 5 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/counter.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/counter.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 5. Counter</p>
        </div>
        <br><br>


        <!-- === Scene 6 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/kitchen.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/kitchen.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 6. Kitchen</p>
        </div>
        <br><br>

        <!-- === Scene 7 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/room.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/room.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 7. Room</p>
        </div>
        <br><br>


        <!-- === Scene 8 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/flowers.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/flowers.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 8. Flowers</p>
        </div>
        <br><br>


        <!-- === Scene 9 === -->
        <div class="js-comparison-container rounded-xl shadow-2xl overflow-hidden bg-gray-900 border-4 border-gray-900 mb-4">
            <!-- Bottom Video (Proposed) -->
            <video class="js-video-baseline comparison-video" loop muted playsinline preload="auto">
                <source src="./mip_3dgs_qnn_videos/treehill.mp4" type="video/mp4">
                Your browser does not support the video tag.
            </video>
            <!-- Top Video (Baseline) - Clipped by its parent div -->
            <div class="js-comparison-video-top">
                <video class="js-video-proposed comparison-video" loop muted playsinline preload="auto">
                    <source src="./mip_3dgs_videos/treehill.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <!-- Draggable Handle -->
            <div class="js-slider-handle" style="left: 50%;"></div>
            <!-- Controls (Placed inside the container to be relative) -->
            <div class="js-controls-container flex items-center space-x-4">
                <button class="js-play-pause-button px-4 py-1 bg-indigo-600 hover:bg-indigo-700 text-white font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Play
                </button>
                <button class="js-restart-button px-4 py-1 bg-gray-200 hover:bg-gray-300 text-gray-800 font-semibold rounded-full shadow-lg transition duration-150 ease-in-out text-sm">
                    Restart
                </button>
            </div>
            <!-- Information Labels -->
            <div class="absolute top2 left-2 px-3 py-1 bg-gray-800 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS</div>
            <div class="absolute top2 right-2 px-3 py-1 bg-indigo-600 text-white rounded-full text-3xl font-mono shadow-md opacity-80 z-40">3DGS+QNN</div>
        </div>
        <div class="text-center mt-4 px-2 text-2xl font-mono text-black-1000">
            <p>Scene 9. Treehill</p>
        </div>
        <br><br>


    </div>

    <script>
        document.addEventListener('DOMContentLoaded', () => {

            // Find all comparison blocks on the page
            const comparisonContainers = document.querySelectorAll('.js-comparison-container');

            // Iterate over each container and initialize the comparison logic
            comparisonContainers.forEach(container => {
                const proposedClipContainer = container.querySelector('.js-comparison-video-top');
                const baselineVideo = container.querySelector('.js-video-baseline');
                const proposedVideo = container.querySelector('.js-video-proposed');
                const sliderHandle = container.querySelector('.js-slider-handle');
                const playPauseButton = container.querySelector('.js-play-pause-button');
                const restartButton = container.querySelector('.js-restart-button');

                let isDragging = false;
                let containerRect;
                let isPlaying = false;
                const videos = [baselineVideo, proposedVideo];


                // --- Geometry Fix for Clipping Alignment (CRITICAL for alignment) ---

                const setProposedVideoGeometry = () => {
                    // FIX: Use getBoundingClientRect() for floating-point precision
                    const baselineRect = baselineVideo.getBoundingClientRect();

                    if (baselineRect.width > 0) {
                        // CRITICAL: Set explicit pixel dimensions on the proposed video element.
                        // This prevents the video from scaling down when its clipping parent shrinks.
                        proposedVideo.style.width = `${baselineRect.width}px`;
                        proposedVideo.style.height = `${baselineRect.height}px`;
                    }
                };

                // --- Synchronization and Control ---

                // Master time sync function: continuously forces proposed video to match baseline time
                const synchronizeTime = () => {
                    // Only sync if the difference is noticeable (avoids unnecessary setting)
                    if (Math.abs(proposedVideo.currentTime - baselineVideo.currentTime) > 0.05) {
                        proposedVideo.currentTime = baselineVideo.currentTime;
                    }
                };

                // Listen to the baseline video's time updates for frame-by-frame sync
                baselineVideo.addEventListener('timeupdate', synchronizeTime);


                const syncPlay = () => {
                    if (isPlaying) return;

                    // Set time before playing to ensure both start at the same frame
                    proposedVideo.currentTime = baselineVideo.currentTime;

                    videos.forEach(v => v.play());
                    isPlaying = true;
                    playPauseButton.textContent = 'Pause';
                };

                const syncPause = () => {
                    if (!isPlaying) return;
                    videos.forEach(v => v.pause());
                    isPlaying = false;
                    playPauseButton.textContent = 'Play';
                };

                const updateSliderPosition = (clientX) => {
                    containerRect = container.getBoundingClientRect();

                    // Calculate the position relative to the container's left edge
                    let x = clientX - containerRect.left;

                    // Clamp the position within the container bounds
                    x = Math.max(0, Math.min(x, containerRect.width));

                    // Calculate percentage (0% to 100%)
                    const percent = (x / containerRect.width) * 100;

                    // Update the clipping width for the proposed video
                    proposedClipContainer.style.width = `${percent}%`;

                    // Update the handle position
                    sliderHandle.style.left = `${percent}%`;
                };

                const syncRestart = () => {
                    videos.forEach(v => {
                        v.currentTime = 0;
                        v.pause();
                    });
                    isPlaying = false;
                    playPauseButton.textContent = 'Play';
                    // Reset slider position to 50%
                    updateSliderPosition(container.offsetWidth / 2 + container.getBoundingClientRect().left);
                };

                playPauseButton.addEventListener('click', () => {
                    if (isPlaying) {
                        syncPause();
                    } else {
                        syncPlay();
                    }
                });

                restartButton.addEventListener('click', syncRestart);

                // Handle metadata load to ensure both videos are ready and in sync
                let videosLoaded = 0;
                videos.forEach(v => {
                    v.addEventListener('loadedmetadata', () => {
                        videosLoaded++;
                        if (videosLoaded === 2) {
                            // Set proposed video to the baseline's current time after loading
                            proposedVideo.currentTime = baselineVideo.currentTime;
                            setProposedVideoGeometry(); // Ensure geometry is set after load
                        }
                    });
                    // When one video pauses (e.g., user interaction), pause the other
                    v.addEventListener('pause', syncPause);
                });


                // --- Sliding Logic ---

                // Start dragging handler (for touch and mouse)
                const startDrag = (e) => {
                    // Prevent default touch actions like scrolling
                    e.preventDefault();
                    isDragging = true;
                    // Recalculate container dimensions in case of resize
                    containerRect = container.getBoundingClientRect();
                    container.classList.add('grabbing');
                };

                // Drag handler (for touch and mouse)
                const handleMove = (e) => {
                    if (!isDragging) return;

                    // Use clientX for mouse events, or the first touch point for touch events
                    const clientX = e.touches ? e.touches[0].clientX : e.clientX;
                    updateSliderPosition(clientX);
                };

                // End dragging handler
                const stopDrag = () => {
                    isDragging = false;
                    container.classList.remove('grabbing');
                };

                // Attach event listeners to the handle
                sliderHandle.addEventListener('mousedown', startDrag);
                sliderHandle.addEventListener('touchstart', startDrag, { passive: false });

                // Attach event listeners to the whole document to allow dragging outside the handle
                document.addEventListener('mousemove', handleMove);
                document.addEventListener('touchmove', handleMove, { passive: false });

                document.addEventListener('mouseup', stopDrag);
                document.addEventListener('touchend', stopDrag);
                document.addEventListener('touchcancel', stopDrag);


                // Initial setup: Ensure videos are loaded and slider is centered
                const initialSetup = () => {
                    setProposedVideoGeometry();
                    // Set initial slider position to 50%
                    updateSliderPosition(container.offsetWidth / 2 + container.getBoundingClientRect().left);
                };

                // Run initial setup
                initialSetup();

                // Add resize listener to the window, but we only need to call setup functions
                window.addEventListener('resize', initialSetup);
            });
        });
    </script>
</body>
</html>
