<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>MotionStream: Real-Time Video Generation with Interactive Motion Controls</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
            background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
            color: #2c3e50;
            line-height: 1.6;
            min-height: 100vh;
        }

        .container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 20px;
        }

        .header {
            text-align: center;
            margin-bottom: 30px;
            padding: 40px 20px;
            background: linear-gradient(135deg, #0093E9 0%, #80D0C7 100%);
            color: white;
            border-radius: 16px;
            box-shadow: 0 10px 40px rgba(0, 147, 233, 0.2);
        }

        .header h1 {
            font-size: 2.2rem;
            margin-bottom: 15px;
            font-weight: 600;
            letter-spacing: -0.5px;
        }

        .header-subtitle {
            font-size: 1.1rem;
            opacity: 0.95;
            margin-bottom: 20px;
        }

        .header-note {
            font-size: 0.95rem;
            opacity: 0.85;
            font-style: italic;
        }

        .tab-container {
            background: white;
            border-radius: 16px;
            box-shadow: 0 4px 25px rgba(0, 0, 0, 0.1);
            overflow: hidden;
        }

        .tab-header {
            display: flex;
            background: #f8f9fa;
            border-bottom: 2px solid #e9ecef;
        }

        .tab-button {
            flex: 1;
            background: none;
            border: none;
            padding: 20px 24px;
            cursor: pointer;
            font-size: 15px;
            font-weight: 500;
            color: #6c757d;
            transition: all 0.3s ease;
            border-bottom: 3px solid transparent;
            position: relative;
        }

        .tab-button:hover {
            background: #e9ecef;
            color: #495057;
        }

        .tab-button.active {
            color: #0093E9;
            background: white;
            border-bottom-color: #0093E9;
        }

        .tab-button.active::after {
            content: '';
            position: absolute;
            bottom: -2px;
            left: 0;
            right: 0;
            height: 3px;
            background: linear-gradient(90deg, #0093E9 0%, #80D0C7 100%);
        }

        .tab-content {
            display: none;
            padding: 35px;
            animation: fadeIn 0.4s ease-in-out;
        }

        .description-box {
            background: #f0f8ff;
            border: 1px solid #d1e7ff;
            border-radius: 10px;
            padding: 20px;
            margin-bottom: 30px;
            color: #2c3e50;
            font-size: 0.95rem;
            line-height: 1.6;
        }

        .description-box strong {
            color: #0093E9;
            font-weight: 600;
        }

        .tab-content.active {
            display: block;
        }

        @keyframes fadeIn {
            from {
                opacity: 0;
                transform: translateY(10px);
            }

            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* Streaming Demo Grid */
        .streaming-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
            margin-bottom: 25px;
        }

        .streaming-long {
            width: 100%;
            margin-top: 25px;
            padding: 20px;
            background: #f8f9fa;
            border-radius: 12px;
        }

        .streaming-long video {
            width: 100%;
            max-height: 400px;
            object-fit: contain;
        }

        .comparison-row {
            margin-bottom: 35px;
        }

        .comparison-title {
            font-size: 1.1rem;
            font-weight: 600;
            color: #495057;
            margin-bottom: 15px;
            padding-bottom: 8px;
            border-bottom: 2px solid #e9ecef;
        }

        .comparison-grid {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            gap: 12px;
        }

        /* Motion Transfer - 3 columns */
        .motion-transfer-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 20px;
            margin-bottom: 35px;
        }

        /* Guidance Ablation - 4 columns */
        .guidance-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 15px;
            margin-bottom: 35px;
        }

        /* Long Video Grid */
        .long-video-row {
            margin-bottom: 35px;
        }

        .long-video-title {
            font-size: 1.1rem;
            font-weight: 600;
            color: #495057;
            margin-bottom: 15px;
            padding-bottom: 8px;
            border-bottom: 2px solid #e9ecef;
        }

        .long-video-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 20px;
        }

        .video-container {
            background: #f8f9fa;
            border-radius: 12px;
            overflow: hidden;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }

        .video-container:hover {
            transform: translateY(-4px);
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
        }

        .video-label {
            padding: 10px;
            background: white;
            font-size: 0.85rem;
            font-weight: 500;
            color: #495057;
            text-align: center;
            border-top: 1px solid #e9ecef;
        }

        video {
            width: 100%;
            height: auto;
            display: block;
        }

        .method-label {
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: #6c757d;
            background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
            padding: 8px;
            text-align: center;
            border-bottom: 1px solid #dee2e6;
        }

        .track-viz-label {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            color: white;
        }

        .ours-label {
            background: linear-gradient(135deg, #0093E9 0%, #80D0C7 100%);
            color: white;
        }

        /* Responsive Design */
        @media (max-width: 1200px) {
            .streaming-grid {
                grid-template-columns: repeat(3, 1fr);
            }

            .comparison-grid {
                grid-template-columns: repeat(4, 1fr);
                gap: 10px;
            }
        }

        @media (max-width: 768px) {
            .streaming-grid {
                grid-template-columns: repeat(2, 1fr);
            }

            .comparison-grid {
                grid-template-columns: repeat(2, 1fr);
            }

            .long-video-grid {
                grid-template-columns: 1fr;
            }

            .tab-button {
                font-size: 13px;
                padding: 15px 10px;
            }
        }

        .loading {
            display: flex;
            justify-content: center;
            align-items: center;
            padding: 40px;
            color: #6c757d;
        }

        .loading::after {
            content: '';
            width: 40px;
            height: 40px;
            border: 4px solid #f8f9fa;
            border-top-color: #0093E9;
            border-radius: 50%;
            animation: spin 1s linear infinite;
            margin-left: 15px;
        }

        @keyframes spin {
            to {
                transform: rotate(360deg);
            }
        }

        .footer {
            text-align: center;
            padding: 30px 20px;
            color: #6c757d;
            font-size: 0.9rem;
            margin-top: 40px;
        }

        .footer a {
            color: #0093E9;
            text-decoration: none;
        }

        .footer a:hover {
            text-decoration: underline;
        }
    </style>
</head>

<body>
    <div class="container">
        <div class="header">
            <h1>MotionStream</h1>
            <p class="header-subtitle">Real-Time Video Generation with Interactive Motion Controls</p>
            <p class="header-note">Supplementary Material - Anonymous Submission</p>
            <p class="header-note" style="margin-top: 10px; font-size: 0.85rem;">Best viewed in Chrome • Click videos
                for fullscreen</p>
        </div>

        <div class="tab-container">
            <div class="tab-header">
                <button class="tab-button active" onclick="showTab('streaming')">Streaming Demo</button>
                <button class="tab-button" onclick="showTab('longvideo')">Long Video Extrapolation</button>
                <button class="tab-button" onclick="showTab('sora')">Qualitative Comparison</button>
                <button class="tab-button" onclick="showTab('motion-transfer')">Motion Transfer</button>
                <button class="tab-button" onclick="showTab('guidance')">Guidance Ablation</button>
            </div>

            <!-- Streaming Demo Tab -->
            <div id="streaming" class="tab-content active">
                <div class="description-box">
                    <strong>Real-time Interactive Streaming Demo on a single H100 GPU:</strong> Using simple drag and mouse motions, MotionStream
                    enables real-time control of diverse scenarios including both object motion and camera movement with
                    various grid configurations. Network latency plays an important role in streaming performance (some
                    demo samples may exhibit slightly higher latency due to intercontinental connections). Our method
                    maintains stable streaming with constant attention context. The system demonstrates robust
                    long-video generation capabilities: by anchoring to the clean first chunk with a single attention
                    window (keeping minimal drifted chunks within the attention context), the model often recovers
                    quality even after disruptions, showcasing its resilience in long video streaming scenarios.
                </div>
                <div class="streaming-grid">
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/cute-monster.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Cute Monster</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/elephant.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Elephant</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/border-collie.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Border Collie</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/shiba-dog.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Shiba Dog</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/anime.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Anime</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/tokyo-girl.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Tokyo Girl</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/rocket.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Rocket Launch</div>
                    </div>
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/chess-demo.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Chess Demo</div>
                    </div>
                </div>

                <div class="streaming-long">
                    <div class="video-container">
                        <video controls autoplay loop muted>
                            <source src="streaming_demo/long.mp4" type="video/mp4">
                        </video>
                        <div class="video-label">Long Streaming Demo</div>
                    </div>
                </div>
            </div>

            <!-- Long Video Extrapolation Tab -->
            <div id="longvideo" class="tab-content">
                <div class="description-box">
                    <strong>Notation:</strong> <strong>C</strong> = chunk size, <strong>S</strong> = number of sink
                    chunks, <strong>W</strong> = local window size. Results demonstrate that maintaining at least one
                    sink chunk is crucial for stable long-video generation. All experiments use our 1.3B causal
                    distilled model, showing the effectiveness of our attention sink mechanism for extended temporal
                    extrapolation.
                </div>
                <div class="long-video-row">
                    <h3 class="long-video-title">Sample 1: Extrapolation Comparison</h3>
                    <div class="long-video-grid">
                        <div class="video-container">
                            <div class="method-label">c3s0w1</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample1_3_0_1.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">c3s0w6</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample1_3_0_6.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">c3s1w1</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample1_3_1_1.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>

                <div class="long-video-row">
                    <h3 class="long-video-title">Sample 2: Extrapolation Comparison</h3>
                    <div class="long-video-grid">
                        <div class="video-container">
                            <div class="method-label">c3s0w1</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample2_3_0_1.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">c3s0w6</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample2_3_0_6.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">c3s1w1</div>
                            <video controls autoplay loop muted>
                                <source src="long_video/sample2_3_1_1.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>
            </div>

            <!-- Sora Comparison Tab -->
            <div id="sora" class="tab-content">
                <div class="description-box">
                    <strong>Comparison with Other Baselines:</strong> We compare our methods with recent
                    motion-controlled video generation approaches using samples from Sora demos. We denote our models as
                    <strong>1.3B-T</strong> (1.3B parameter teacher model), <strong>1.3B-S</strong> (1.3B parameter
                    student/distilled model), <strong>5B-T</strong> (5B parameter teacher model), and
                    <strong>5B-S</strong> (5B parameter student/distilled model). Our methods consistently demonstrate
                    high video quality and motion adherence compared to baseline approaches, with the student models
                    achieving real-time performance.
                </div>
                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 1</h3>
                    <div class="comparison-grid">
                        <div class="video-container">
                            <div class="method-label track-viz-label">Track Viz</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/000002_vis.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">GWTF</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/gwtf_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">DAS</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/das_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">ATI</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ati_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_teacher_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_student_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_teacher_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_student_000002.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 2</h3>
                    <div class="comparison-grid">
                        <div class="video-container">
                            <div class="method-label track-viz-label">Track Viz</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/000014_vis.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">GWTF</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/gwtf_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">DAS</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/das_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">ATI</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ati_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_teacher_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_student_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_teacher_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_student_000014.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 3</h3>
                    <div class="comparison-grid">
                        <div class="video-container">
                            <div class="method-label track-viz-label">Track Viz</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/000017_vis.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">GWTF</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/gwtf_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">DAS</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/das_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">ATI</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ati_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_teacher_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 1.3B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_21_student_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-T</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_teacher_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Ours 5B-S</div>
                            <video controls autoplay loop muted>
                                <source src="sora_comparison/ours_22_student_000017.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>
            </div>

            <!-- Motion Transfer Tab -->
            <div id="motion-transfer" class="tab-content">
                <div class="description-box">
                    <strong>Motion Transfer:</strong> Given an initial image of similar structure, MotionStream can naturally transfer motions of arbitrarily long videos (can be done in real-time with online trackers).
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 1</h3>
                    <div class="motion-transfer-grid">
                        <div class="video-container">
                            <div class="method-label">Source</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample1_source.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label track-viz-label">Motion Track</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample1_track.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Result</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample1_result.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 2</h3>
                    <div class="motion-transfer-grid">
                        <div class="video-container">
                            <div class="method-label">Source</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample2_source.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label track-viz-label">Motion Track</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample2_track.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Result</div>
                            <video controls autoplay loop muted>
                                <source src="motion_transfer/sample2_result.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>
            </div>

            <!-- Guidance Ablation Tab -->
            <div id="guidance" class="tab-content">
                <div class="description-box">
                    <strong>Guidance Ablation Study:</strong> Using high motion guidance leads to overly rigid translations due to strict track adherence and ignores text cues (below sample is prompted with "rainbow appearing at the back"). While prompt guidance alone shows inferior quantitative metrics for motion reconstruction, it enables flexible text-based control. Our proposed joint guidance strategy effectively balances these two. 
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 1</h3>
                    <div class="guidance-grid">
                        <div class="video-container">
                            <div class="method-label track-viz-label">Motion Track</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample1_viz.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">Motion Only</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample1_motion_only.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Joint Guidance</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample1_joint.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">Prompt Only</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample1_prompt_only.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>

                <div class="comparison-row">
                    <h3 class="comparison-title">Sample 2</h3>
                    <div class="guidance-grid">
                        <div class="video-container">
                            <div class="method-label track-viz-label">Motion Track</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample2_viz.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">Motion Only</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample2_motion_only.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label ours-label">Joint Guidance</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample2_joint.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-container">
                            <div class="method-label">Prompt Only</div>
                            <video controls autoplay loop muted>
                                <source src="guidance_abl/sample2_prompt_only.mp4" type="video/mp4">
                            </video>
                        </div>
                    </div>
                </div>
            </div>
        </div>

        <div class="footer">
            <p>MotionStream: Real-Time Video Generation with Interactive Motion Controls</p>
        </div>
    </div>

    <script>
        function showTab(tabName) {
            // Hide all tabs
            const tabs = document.querySelectorAll('.tab-content');
            tabs.forEach(tab => tab.classList.remove('active'));

            // Remove active class from all buttons
            const buttons = document.querySelectorAll('.tab-button');
            buttons.forEach(button => button.classList.remove('active'));

            // Show selected tab
            document.getElementById(tabName).classList.add('active');

            // Add active class to clicked button
            event.target.classList.add('active');
        }

        // Add keyboard navigation
        document.addEventListener('keydown', function (e) {
            if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {
                const buttons = Array.from(document.querySelectorAll('.tab-button'));
                const activeIndex = buttons.findIndex(btn => btn.classList.contains('active'));
                let newIndex;

                if (e.key === 'ArrowLeft') {
                    newIndex = activeIndex > 0 ? activeIndex - 1 : buttons.length - 1;
                } else {
                    newIndex = activeIndex < buttons.length - 1 ? activeIndex + 1 : 0;
                }

                buttons[newIndex].click();
            }
        });

        if ('IntersectionObserver' in window) {
            const videos = document.querySelectorAll('video');
            const videoObserver = new IntersectionObserver((entries, observer) => {
                entries.forEach(entry => {
                    if (entry.isIntersecting) {
                        const video = entry.target;
                        if (video.dataset.src) {
                            video.src = video.dataset.src;
                            delete video.dataset.src;
                        }
                        observer.unobserve(video);
                    }
                });
            });

            videos.forEach(video => {
                videoObserver.observe(video);
            });
        }
    </script>
</body>

</html>