<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Captain Cinema: Towards Short Movie Generation</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=Inter:wght@300;500&family=Marcellus&display=swap" rel="stylesheet">
    
    <!-- AOS Animation Library -->
    <link href="https://unpkg.com/aos@2.3.1/dist/aos.css" rel="stylesheet">
    <script src="https://unpkg.com/aos@2.3.1/dist/aos.js"></script>
    
    <!-- Academicons and Font Awesome -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
    
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        body {
            background-color: #000000;
            color: #cccccc;
            font-family: 'Inter', sans-serif;
            font-weight: 300;
            line-height: 1.6;
            min-height: 100vh;
            overflow-x: hidden;
            position: relative;
            padding-bottom: 60px;
        }

        /* Navigation Bar - Veo3 Style */
        .navigation-container {
            position: fixed;
            top: 1rem;
            left: 50%;
            transform: translateX(-50%);
            z-index: 2147483647;
        }

        .veo-nav {
            background: rgba(18, 18, 18, 0.85);
            -webkit-backdrop-filter: blur(20px);
            backdrop-filter: blur(20px);
            border-radius: 50px;
            padding: 0.5rem;
            border: 1px solid rgba(255, 255, 255, 0.1);
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
        }

        .veo-nav.sticky {
            position: fixed;
            top: 1rem;
            left: 50%;
            transform: translateX(-50%);
            z-index: 2147483647;
            background: rgba(26, 26, 26, 0.95);
            -webkit-backdrop-filter: blur(25px);
            backdrop-filter: blur(25px);
            box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
        }

        .veo-nav.transitioning {
            position: fixed;
            left: 50%;
            transform: translateX(-50%);
            z-index: 2147483647;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .nav-items {
            display: flex;
            gap: 0;
            list-style: none;
            align-items: center;
        }

        .nav-item {
            color: #cccccc;
            text-decoration: none;
            font-size: 1rem;
            font-weight: 500;
            padding: 0.6rem 1.2rem;
            border-radius: 25px;
            transition: all 0.2s ease-in-out;
            cursor: pointer;
            position: relative;
            white-space: nowrap;
        }

        .nav-item:not(.active):hover {
            color: #ffffff;
            background-color: #383838;
        }

        .nav-item.active {
            color: #000000;
            font-weight: 600;
            background: linear-gradient(135deg, #ffd700, #ffb800);
            box-shadow: 0 4px 15px rgba(255, 215, 0, 0.3);
        }

        .nav-item.logo {
            color: #fff;
            font-weight: bold;
            font-size: 1.3rem;
            background: rgba(255, 255, 255, 0.1);
        }

        .nav-item.logo.active, .nav-item.logo:hover {
             background: rgba(255, 255, 255, 0.2);
             color: #fff;
        }

        /* Film strip container */
        .film-strip-container {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            overflow: hidden;
            z-index: -1;
            pointer-events: none;
            background: #000000; /* Solid black background for spacing between stripes */
        }

        /* Film strip wrapper for animation */
        .film-strip-wrapper {
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            left: 0;
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 100px;            /* Fixed 100-px space between stripes */
            pointer-events: none; /* Background interaction-free */
        }

        /* Film strip */
        .film-strip {
            position: relative; /* Participate in flex column flow */
            width: auto;
            height: 300px;
            display: flex;
            transform-origin: top left; /* Anchor rotation at top-left */
            transform: rotate(-30deg);
            animation: rollFilmStrip 60s linear infinite;
            /* Remove glow so gaps remain black */
            filter: none;
            will-change: transform;
        }

        @keyframes rollFilmStrip {
            0% {
                transform: translateX(0) rotate(-30deg); /* Start in view */
            }
            100% {
                transform: translateX(-400vw) rotate(-30deg); /* Travel distance */
            }
        }

        /* Film frame */
        .film-frame {
            width: 600px;           /* Shrink to reduce vertical footprint */
            height: 300px;
            flex-shrink: 0;
            position: relative;
            background: #000000;
            border: 15px solid #000000;
            border-left-width: 30px;
            border-right-width: 30px;
            box-shadow: 
                inset 0 0 20px rgba(0, 0, 0, 0.8),
                0 0 10px rgba(0, 0, 0, 0.5);
            overflow: hidden;
        }

        /* Perforations */
        .film-frame::before,
        .film-frame::after {
            content: '';
            position: absolute;
            width: 100%;
            height: 30px;
            left: 0;
            background-image: repeating-linear-gradient(
                90deg,
                transparent,
                transparent 10px,
                #000 10px,
                #000 20px
            );
        }

        .film-frame::before {
            top: -30px;
            height: 30px;
            background-color: #ffffff;
        }

        .film-frame::after {
            bottom: -30px;
            height: 30px;
            background-color: #ffffff;
        }

        /* Perforation holes */
        .perforations-top,
        .perforations-bottom {
            position: absolute;
            width: 100%;
            height: 30px;
            left: 0;
            overflow: hidden;
        }

        .perforations-top {
            top: -30px;
        }

        .perforations-bottom {
            bottom: -30px;
        }

        .perforation {
            position: absolute;
            width: 15px;
            height: 20px;
            background: #000000;
            border-radius: 2px;
            box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.5);
        }

        /* Frame content area */
        .frame-content {
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 2rem;
            color: #fff;
            background-size: cover;
            background-position: center;
            position: relative;
        }

        /* Individual frame colors for visual distinction */
        .frame-content[data-frame="1"] { background: linear-gradient(135deg, #FF6B6B, #FF5252); }
        .frame-content[data-frame="2"] { background: linear-gradient(135deg, #4ECDC4, #44A3AA); }
        .frame-content[data-frame="3"] { background: linear-gradient(135deg, #45B7D1, #2196F3); }
        .frame-content[data-frame="4"] { background: linear-gradient(135deg, #96CEB4, #4CAF50); }
        .frame-content[data-frame="5"] { background: linear-gradient(135deg, #FECA57, #FF9800); }
        .frame-content[data-frame="6"] { background: linear-gradient(135deg, #48DBFB, #0ABDE3); }
        .frame-content[data-frame="7"] { background: linear-gradient(135deg, #FD79A8, #E91E63); }
        .frame-content[data-frame="8"] { background: linear-gradient(135deg, #A29BFE, #6C5CE7); }
        .frame-content[data-frame="9"] { background: linear-gradient(135deg, #00D2D3, #00BCD4); }
        .frame-content[data-frame="10"] { background: linear-gradient(135deg, #EE5A24, #FF5722); }
        .frame-content[data-frame="11"] { background: linear-gradient(135deg, #F368E0, #9C27B0); }
        .frame-content[data-frame="12"] { background: linear-gradient(135deg, #6C5CE7, #5E35B1); }
        .frame-content[data-frame="13"] { background: linear-gradient(135deg, #74B9FF, #2196F3); }
        .frame-content[data-frame="14"] { background: linear-gradient(135deg, #E17055, #FF7043); }
        .frame-content[data-frame="15"] { background: linear-gradient(135deg, #55A3FF, #448AFF); }
        .frame-content[data-frame="16"] { background: linear-gradient(135deg, #FD79A8, #FF4081); }
        .frame-content[data-frame="17"] { background: linear-gradient(135deg, #636E72, #607D8B); }
        .frame-content[data-frame="18"] { background: linear-gradient(135deg, #00B894, #009688); }
        .frame-content[data-frame="19"] { background: linear-gradient(135deg, #FDCB6E, #FFC107); }
        .frame-content[data-frame="20"] { background: linear-gradient(135deg, #006BA6, #0288D1); }
        .frame-content[data-frame="21"] { background: linear-gradient(135deg, #A29BFE, #7C4DFF); }
        .frame-content[data-frame="22"] { background: linear-gradient(135deg, #FF6B6B, #F44336); }
        .frame-content[data-frame="23"] { background: linear-gradient(135deg, #45B7D1, #03A9F4); }
        .frame-content[data-frame="24"] { background: linear-gradient(135deg, #FECA57, #FFC107); }

        /* Main content styling */
        .main-content {
            position: relative;
            z-index: 1;
            min-height: 100vh;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            text-align: center;
            padding: 6rem 2rem 2rem;
            background: transparent;
        }

        .container {
            max-width: 800px;
            width: 100%;
            animation: fadeIn 2s ease-in-out;
            padding-top: 3rem;
            padding-bottom: 3rem;
        }

        @keyframes fadeIn {
            from { 
                opacity: 0; 
                transform: translateY(30px); 
            }
            to { 
                opacity: 1; 
                transform: translateY(0); 
            }
        }

        @keyframes gradientShift {
            0% {
                background-position: 0% 50%;
            }
            50% {
                background-position: 100% 50%;
            }
            100% {
                background-position: 0% 50%;
            }
        }

        .main-board {
            max-width: 1400px;
            width: 95%;
            margin: 3rem auto;
            background: rgba(18, 18, 18, 0.65);
            -webkit-backdrop-filter: blur(25px);
            backdrop-filter: blur(25px);
            border: 1px solid rgba(255, 255, 255, 0.1);
            border-radius: 25px;
            padding: 1rem;
            box-shadow: 0 16px 60px rgba(0, 0, 0, 0.5);
            transition: all 0.3s ease;
        }

        .main-board:hover {
            border: 1px solid rgba(255, 215, 0, 0.3);
            box-shadow: 0 16px 60px rgba(0, 0, 0, 0.5), 0 0 30px rgba(255, 215, 0, 0.1);
        }

        h1 {
            font-family: 'Marcellus', serif;
            font-size: 4.5rem;
            font-weight: 400;
            margin-bottom: 1rem;
            letter-spacing: -0.02em;
            background: linear-gradient(45deg, #b8860b, #ffd700, #ffb347, #ffd700, #b8860b);
            background-size: 400% 400%;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            text-shadow: 0 0 30px rgba(255, 215, 0, 0.3);
            text-align: center;
            animation: gradientShift 6s ease-in-out infinite;
        }

        .subtitle {
            font-size: 1.8rem;
            font-weight: 400;
            margin-bottom: 2rem;
            background: linear-gradient(45deg, #b8860b, #daa520, #ffd700, #daa520, #b8860b);
            background-size: 400% 400%;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            letter-spacing: 0.5px;
            text-shadow: 0 0 15px rgba(212, 175, 55, 0.4);
            animation: gradientShift 8s ease-in-out infinite;
        }

        .conference-info {
            font-size: 1.1rem;
            color: #998b5a;
            margin-bottom: 2rem;
            padding: 1rem;
            border: 1px solid transparent;
            border-radius: 8px;
            background-color: rgba(26, 22, 18, 0.6);
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            transition: all 0.3s ease;
        }

        .conference-info:hover {
            border: 1px solid rgba(255, 215, 0, 0.3);
            box-shadow: 0 0 20px rgba(255, 215, 0, 0.15);
        }

        .authors {
            font-style: italic;
            color: #8b7d4d;
            margin-top: 0.5rem;
        }

        .research-section {
            padding: 4rem 2rem 10rem 2rem;
            text-align: center;
            background: transparent;
            position: relative;
            z-index: 15;
            margin-bottom: 4rem;
        }

        .research-container {
            max-width: 1000px;
            margin: 0 auto;
        }

        .research-title {
            font-size: 2rem;
            font-weight: 300;
            font-family: 'Inter', sans-serif;
            color: #d7d7d7;
            margin-top: 2rem;
            margin-bottom: 2rem;
            letter-spacing: 0.1em;
        }

        .research-authors {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 0.1rem;
            max-width: 600px;
            margin: 0 auto;
        }

        .research-author-name {
            color: #ffffff;
            font-size: 1.4rem;
            font-weight: 300;
            font-family: 'Inter', sans-serif;
            text-align: center;
            padding: 0.1rem 0.8rem;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
            background: transparent;
            border: 1px solid transparent;
            border-radius: 20px;
            cursor: pointer;
            transition: all 0.3s ease;
            text-decoration: none;
            display: inline-block;
            margin: 0.05rem 0.05rem;
        }

        .research-author-name:hover {
            background: rgba(200, 200, 200, 0.15);
            border: 1px solid rgba(200, 200, 200, 0.3);
            color: #ffffff;
            text-decoration: none;
            transform: translateY(-2px);
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
        }

        .research-author-name:active {
            transform: translateY(0px);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
        }

        .institutions-logos {
            margin-top: 10rem;
            text-align: center;
        }

        .logos-image {
            width: 100%;
            max-width: 800px;
            height: auto;
            filter: brightness(0.9);
        }

        .coming-soon {
            font-size: 1.2rem;
            color: #998b5a;
            margin-top: 3rem;
            padding: 2rem;
            border-top: 1px solid transparent;
            transition: all 0.3s ease;
        }

        .coming-soon:hover {
            border-top: 1px solid rgba(255, 215, 0, 0.3);
        }

        /* Button Container Styles */
        .button-container {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 1.5rem;
            margin: 4rem 2rem;
            flex-wrap: wrap;
        }

        .button {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            margin: 0.5rem 0.5rem;
            padding: 0.3rem 1.5rem;
            background: rgba(26, 22, 18, 0.8);
            border: none;
            border-radius: 25px;
            color: #d5d5d5;
            text-decoration: none;
            font-size: 1.5rem;
            font-weight: 500;
            transition: all 0.3s ease;
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
        }

        .button:hover {
            background: rgba(255, 215, 0, 0.1);
            border: 1px solid rgba(255, 215, 0, 0.6);
            color: #d5d5d5;
            transform: translateY(-2px);
            box-shadow: 0 4px 15px rgba(255, 215, 0, 0.2);
        }

        .button .icon {
            font-size: 1.2rem;
        }

        .paper-link {
            background: rgba(212, 175, 55, 0.1);
            border: none;
        }

        .paper-link:hover {
            background: rgba(255, 215, 0, 0.1);
            border: 1px solid rgba(255, 215, 0, 0.6);
            color: #d5d5d5;
            transform: translateY(-2px);
            box-shadow: 0 4px 15px rgba(255, 215, 0, 0.2);
        }

        /* Research Team Text Link */
        .research-team-link {
            color: #fed345;
            text-decoration: none;
            font-size: 1.4rem;
            font-weight: 400;
            font-family: 'Inter', sans-serif;
            transition: all 0.3s ease;
            margin-top: 4rem;
            cursor: pointer;
        }

        .research-team-link:hover {
            color: #efe7b6;
            text-shadow: 0 0 8px rgba(255, 215, 0, 0.4);
        }

        .footer {
            position: fixed;
            bottom: 0;
            left: 0;
            width: 100%;
            font-size: 0.8rem;
            color: #5c5334;
            text-align: center;
            padding: 0.8rem 2rem;
            background: rgba(0, 0, 0, 0.8);
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
            border-top: 1px solid rgba(255, 215, 0, 0.2);
            z-index: 1000;
        }

        .title-image {
            width: 100%;
            max-width: 300px;
            margin-bottom: 1.5rem;
            filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.3));
        }

        @media (max-width: 768px) {
            h1 {
                font-size: 2.5rem;
                background-size: 300% 300%;
            }
            
            .subtitle {
                font-size: 1rem;
                background-size: 300% 300%;
            }
            
            .container {
                padding: 1.5rem;
            }

            .film-strip {
                transform: translateY(-50%) rotate(-20deg);
            }

            .film-frame {
                width: 300px;
                height: 225px;
            }

            .research-section {
                padding: 3rem 1rem 8rem 1rem;
                margin-bottom: 6rem;
            }

            .research-title {
                font-size: 1.8rem;
                margin-top: 10rem;
            }

            .research-authors {
                gap: 0.6rem;
            }

            .research-author-name {
                font-size: 1rem;
            }

            .institutions-logos {
                margin-top: 2rem;
            }

            .logos-image {
                max-width: 100%;
                padding: 0 1rem;
            }
        }

        /* Additional styles for content sections */
        .content-section {
            min-height: auto;
            padding: 1.5rem 1rem;
            margin-bottom: 10rem;
            position: relative;
            background: transparent !important;
        }

        /* Parallel Universe Section Specific Styling */
        #parallel-universe {
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
        }

        #parallel-universe .section-container {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            width: 110%;
        }

        .content-section.alternate {
            background: transparent !important;
        }

        .section-container {
            max-width: 1200px;
            margin: 0 auto;
            text-align: center;
            width: 110%;
            box-sizing: border-box;
            padding: 0 1rem;
        }

        .content-section h2 {
            font-size: 3rem;
            margin-top: 2rem;
            margin-bottom: 2rem;
            color: #ffffff;
            text-align: center !important;
            text-shadow: 0 0 20px rgba(255, 215, 0, 0.5);
            font-weight: 500;
            width: 100%;
            display: block;
        }

        .content-section p {
            font-size: 1rem;
            line-height: 1.6;
            margin-bottom: 1.5rem;
            color: #cccccc;
            text-align: center;
            max-width: 700px;
            margin-left: auto;
            margin-right: auto;
        }

        /* Figure placeholders */
        .figure-placeholder {
            margin: 3rem auto;
            max-width: 800px;
            background: rgba(26, 22, 18, 0.8);
            border: 2px solid transparent;
            border-radius: 10px;
            padding: 2rem;
            box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);
            transition: all 0.3s ease;
        }

        .figure-placeholder:hover {
            border: 2px solid rgba(212, 175, 55, 0.4);
            box-shadow: 0 0 30px rgba(255, 215, 0, 0.2);
        }

        .figure-placeholder.wide {
            max-width: 1000px;
        }

        .figure-number {
            font-size: 1.5rem;
            color: #d4af37;
            margin-bottom: 1rem;
            font-weight: bold;
        }

        .placeholder-image {
            width: 100%;
            height: 300px;
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 2rem;
            font-weight: bold;
            color: white;
            text-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
            position: relative;
            overflow: hidden;
        }

        .placeholder-image::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: repeating-linear-gradient(
                45deg,
                transparent,
                transparent 10px,
                rgba(255, 255, 255, 0.1) 10px,
                rgba(255, 255, 255, 0.1) 20px
            );
            animation: slidePattern 20s linear infinite;
        }

        @keyframes slidePattern {
            0% { transform: translate(0, 0); }
            100% { transform: translate(50px, 50px); }
        }

        .figure-caption {
            margin-top: 1rem;
            font-style: italic;
            color: #998b5a;
            text-align: center;
        }

        /* Features grid */
        .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2rem;
            margin: 3rem 0;
        }

        .feature-card {
            background: rgba(26, 22, 18, 0.6);
            padding: 2rem;
            border-radius: 10px;
            border: 1px solid transparent;
            text-align: center;
            transition: all 0.3s ease;
        }

        .feature-card:hover {
            transform: translateY(-5px);
            border: 1px solid rgba(255, 215, 0, 0.3);
            box-shadow: 0 10px 30px rgba(255, 215, 0, 0.2);
        }

        .feature-icon {
            font-size: 3rem;
            margin-bottom: 1rem;
        }

        .feature-card h3 {
            color: #d4af37;
            margin-bottom: 1rem;
        }

        /* Stats grid */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
            margin: 3rem 0;
        }

        .stat-item {
            text-align: center;
            padding: 2rem;
            background: rgba(255, 215, 0, 0.05);
            border-radius: 10px;
            border: 1px solid transparent;
            transition: all 0.3s ease;
        }

        .stat-item:hover {
            background: rgba(255, 215, 0, 0.1);
            border: 1px solid rgba(212, 175, 55, 0.4);
            box-shadow: 0 0 20px rgba(255, 215, 0, 0.1);
        }

        .stat-number {
            font-size: 3rem;
            font-weight: bold;
            color: #ffd700;
        }

        .stat-label {
            color: #998b5a;
            margin-top: 0.5rem;
        }

        /* Results grid */
        .results-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
            gap: 2rem;
            margin: 3rem 0;
        }

        /* Applications */
        .applications-list {
            margin: 3rem 0;
        }

        .application-item {
            background: rgba(26, 22, 18, 0.4);
            padding: 2rem;
            margin-bottom: 1.5rem;
            border-left: 4px solid transparent;
            transition: all 0.3s ease;
        }

        .application-item:hover {
            transform: translateX(10px);
            border-left: 4px solid rgba(212, 175, 55, 0.6);
            background: rgba(26, 22, 18, 0.6);
            box-shadow: 0 0 20px rgba(255, 215, 0, 0.1);
        }

        .application-item h3 {
            color: #ffd700;
            margin-bottom: 0.5rem;
        }

        /* Scroll indicator */
        .scroll-indicator {
            position: fixed;
            bottom: 2rem;
            left: 50%;
            transform: translateX(-50%);
            color: #d4af37;
            font-size: 2rem;
            animation: bounce 2s infinite;
            z-index: 10;
        }

        @keyframes bounce {
            0%, 100% { transform: translateX(-50%) translateY(0); }
            50% { transform: translateX(-50%) translateY(-10px); }
        }

        /* Responsive */
        @media (max-width: 768px) {
            .veo-nav {
                padding: 0.4rem;
            }
            
            .nav-items {
                gap: 0;
                flex-wrap: nowrap;
                overflow-x: auto;
            }
            
            .nav-item {
                font-size: 0.9rem;
                padding: 0.5rem 0.8rem;
                white-space: nowrap;
            }
            
            .content-section h2 {
                font-size: 2.2rem;
                font-family: 'Inter', sans-serif;
                font-optical-sizing: auto;
                font-weight: 400;
                font-variation-settings: "wdth" 100;
            }
            .stats-grid {
                grid-template-columns: 1fr;
            }
            
            .results-grid {
                grid-template-columns: 1fr;
            }
        }

        /* Interactive Video Control Styles */
        .video-demo-section {
            background: transparent !important;
            border: none !important;
            box-shadow: none !important;
            padding: 0;
            margin: 3rem auto;
            max-width: 1000px;
        }
        
        /* Prevent any gray backgrounds and overlays on video elements */
        video::-webkit-media-controls-panel {
            background-color: rgba(0, 0, 0, 0.2) !important;
        }
        
        video::-webkit-media-controls {
            background-color: transparent !important;
        }
        
        /* Remove the gray overlay effect when controls appear */
        video::-webkit-media-controls-overlay-enclosure {
            background: transparent !important;
            backdrop-filter: none !important;
            -webkit-backdrop-filter: none !important;
        }
        
        video::-webkit-media-controls-enclosure {
            background: transparent !important;
            backdrop-filter: none !important;
            -webkit-backdrop-filter: none !important;
        }
        
        /* Ensure video content stays visible */
        video::-webkit-media-controls-start-playback-button {
            background: transparent !important;
        }
        
        /* Remove any backdrop filters or overlays */
        video::before,
        video::after {
            display: none !important;
        }
        
        video {
            background-color: #000000 !important;
            filter: none !important;
            opacity: 1 !important;
            transform: none !important;
            position: relative !important;
            z-index: 1 !important;
        }
        
        /* Prevent any overlay or dimming effects */
        video::-webkit-media-controls-overlay-play-button {
            display: none !important;
            background: transparent !important;
            backdrop-filter: none !important;
            -webkit-backdrop-filter: none !important;
        }
        
        /* Remove all video overlay effects that cause darkening */
        video::-webkit-media-controls-overlay-enclosure {
            display: none !important;
        }
        
        video::-webkit-media-controls-overlay {
            display: none !important;
        }
        
        /* Prevent video from being darkened on hover */
        video {
            pointer-events: auto !important;
        }
        
        video:hover {
            filter: none !important;
            opacity: 1 !important;
            background: transparent !important;
        }
        
        /* Disable all video pseudo-element overlays */
        video::-webkit-media-controls-fullscreen-button,
        video::-webkit-media-controls-play-button,
        video::-webkit-media-controls-timeline,
        video::-webkit-media-controls-current-time-display,
        video::-webkit-media-controls-time-remaining-display,
        video::-webkit-media-controls-mute-button,
        video::-webkit-media-controls-volume-slider,
        video::-webkit-media-controls-seek-back-button,
        video::-webkit-media-controls-seek-forward-button,
        video::-webkit-media-controls-rewind-button,
        video::-webkit-media-controls-return-to-realtime-button {
            filter: none !important;
            opacity: 1 !important;
            background: transparent !important;
        }
        
        /* Ensure video containers don't darken */
        .video-wrapper,
        .video-player-section,
        .universe-video-player {
            filter: none !important;
            opacity: 1 !important;
        }
        
        /* Prevent any video state changes that cause darkening */
        video:focus,
        video:active,
        video:hover,
        video[controls]:hover,
        video[controls]:focus,
        video[controls]:active {
            filter: none !important;
            opacity: 1 !important;
            background: transparent !important;
            box-shadow: none !important;
            outline: none !important;
        }
        
        /* Remove any overlay effects on video containers */
        .video-wrapper:hover,
        .video-player-section:hover,
        .universe-video-player:hover {
            filter: none !important;
            opacity: 1 !important;
            background: transparent !important;
        }
        
        /* Demo Introduction Styling */
        .demo-introduction {
            background: transparent !important;
            border: none !important;
            box-shadow: none !important;
            padding: 1rem 0.5rem;
            margin: 0 auto 4rem auto;
            max-width: 95%;
            width: 95%;
            text-align: center;
        }

        .demo-introduction p {
            font-size: 1.4rem;
            color: #cccccc;
            line-height: 1.5;
            margin: 0 auto;
            text-align: center !important;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.6);
            -webkit-hyphens: auto;
            hyphens: auto;
            word-spacing: 0.1em;
            width: 100%;
            display: block;
        }

        .demo-introduction strong {
            color: #ffd700;
            font-weight: 600;
        }

        .demo-introduction em {
            color: #d4af37;
            font-style: italic;
        }

        /* Demo Caption with Wider Line Width */
        .demo-caption {
            background: transparent !important;
            border: none !important;
            box-shadow: none !important;
            padding: 1rem 0.5rem;
            margin: 0 auto 0rem auto;
            max-width: 95%;
            width: 95%;
            text-align: center;
        }

        .demo-caption p {
            font-size: 1.3rem;
            color: #cccccc;
            line-height: 1.6;
            margin: 0 auto;
            text-align: center !important;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.6);
            -webkit-hyphens: auto;
            hyphens: auto;
            word-spacing: 0.1em;
            width: 100%;
            display: block;
            max-width: 1000px;
        }

        .demo-caption strong {
            color: #ffd700;
            font-weight: 600;
        }

        .demo-caption em {
            color: #e0bf51;
            font-style: italic;
        }

        .video-container {
            display: flex;
            flex-direction: column;
            gap: 1.5rem;
            margin-top: 2rem;
        }

        .video-player-section {
            width: 100%;
            position: relative;
            background: #000000;
            border-radius: 10px;
            overflow: hidden;
            min-height: 300px;
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 1;
        }
        
        .video-wrapper {
            width: 100%;
            height: 100%;
            position: relative;
            background: #000000;
            border-radius: 10px;
            overflow: hidden;
        }
        
        .video-player-section video {
            width: 100%;
            height: auto;
            max-height: 600px;
            border-radius: 10px;
            border: 2px solid transparent;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
            background: #000000 !important;
            object-fit: contain;
            display: block;
            filter: none !important;
            opacity: 1 !important;
            transform: none !important;
        }
        
        /* Custom Video Caption Area */
        .video-captions {
            background: rgba(0, 0, 0, 0.8);
            border-radius: 0 0 10px 10px;
            padding: 1rem;
            margin-top: -2px;
            border: 2px solid transparent;
            border-top: none;
            min-height: 60px;
            display: flex;
            align-items: center;
            justify-content: center;
        }



        .caption-text {
            color: white;
            font-size: 2rem;
            font-weight: 500;
            text-align: center;
            line-height: 1.4;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
            max-width: 90%;
        }

        .scenes-list {
            width: 100%;
            max-height: 280px;
            overflow-x: auto;
            overflow-y: hidden;
            background: rgba(0, 0, 0, 0.4);
            border-radius: 10px;
            padding: 1.5rem;
            border: 1px solid transparent;
            display: flex;
            gap: 1.5rem;
        }



        .scenes-list::-webkit-scrollbar {
            height: 6px;
        }

        .scenes-list::-webkit-scrollbar-track {
            background: rgba(0, 0, 0, 0.3);
            border-radius: 4px;
        }

        .scenes-list::-webkit-scrollbar-thumb {
            background: #d4af37;
            border-radius: 4px;
        }

        .scene-item {
            display: flex;
            flex-direction: column;
            gap: 0.8rem;
            padding: 1.2rem;
            background: rgba(26, 22, 18, 0.5);
            border-radius: 8px;
            cursor: pointer;
            border: 1px solid transparent;
            flex-shrink: 0;
            min-width: 200px;
            max-width: 200px;
        }



        .scene-item.active {
            background: rgba(255, 215, 0, 0.2);
            border-color: #d4af37;
            box-shadow: 0 0 15px rgba(255, 215, 0, 0.3);
        }

        .scene-thumbnail {
            width: 100%;
            height: 120px;
            border-radius: 4px;
            overflow: hidden;
            border: 1px solid transparent;
            background: rgba(0, 0, 0, 0.3);
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .scene-thumbnail img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            border-radius: 4px;
        }

        .scene-info {
            width: 100%;
            text-align: center;
        }

        .scene-title {
            font-weight: bold;
            color: #d4af37;
            font-size: 1.1rem;
            margin-bottom: 0.3rem;
        }

        .scene-description {
            color: #cccccc;
            font-size: 0.9rem;
            line-height: 1.3;
            overflow: hidden;
            text-overflow: ellipsis;
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
            height: 3.9rem;
        }

        .video-controls {
            margin-top: 1rem;
            padding: 1rem;
            background: rgba(0, 0, 0, 0.5);
            border-radius: 8px;
            border: 1px solid transparent;
        }



        .video-timeline {
            position: relative;
            height: 6px;
            background: rgba(255, 255, 255, 0.2);
            border-radius: 3px;
            margin-bottom: 0.5rem;
            cursor: pointer;
        }

        .video-progress {
            height: 100%;
            background: linear-gradient(90deg, #d4af37, #ffd700);
            border-radius: 3px;
            width: 0%;
            transition: width 0.1s ease;
        }

        .video-time {
            color: #cccccc;
            font-size: 0.9rem;
            text-align: center;
        }

        @media (max-width: 768px) {
            .scenes-list {
                max-height: 200px;
                padding: 1rem;
                gap: 1rem;
            }
            
            .scene-item {
                min-width: 160px;
                max-width: 160px;
                padding: 1rem;
            }
            
            .scene-thumbnail {
                height: 100px;
            }
            
            .scene-title {
                font-size: 0.95rem;
            }
            
            .scene-description {
                font-size: 0.75rem;
                height: 2.8rem;
            }
            
            .video-demo-section {
                padding: 1rem;
                margin: 1rem;
            }
        }

        .film-strip-track    { animation: scroll 30s linear infinite; }
        @keyframes scroll    { to { transform: translateX(-50%); } }

        /* Universe Flowchart Styles */
        .universe-flowchart-container {
            margin: 3rem auto;
            max-width: 1400px;
        }

        .universe-selector {
            display: flex;
            justify-content: center;
            gap: 3rem;
            margin-bottom: 3rem;
        }

        .universe-option {
            background: rgba(26, 22, 18, 0.6);
            border: 2px solid transparent;
            border-radius: 15px;
            padding: 2rem 3rem;
            cursor: pointer;
            transition: all 0.4s ease;
            text-align: center;
            min-width: 250px;
            -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
        }

        .universe-option:hover {
            border-color: rgba(255, 215, 0, 0.4);
            box-shadow: 0 0 25px rgba(255, 215, 0, 0.2);
            transform: translateY(-5px);
        }

        .universe-option.active {
            border-color: rgba(255, 215, 0, 0.6);
            background: rgba(255, 215, 0, 0.15);
            box-shadow: 0 0 30px rgba(255, 215, 0, 0.3);
            transform: scale(1.05);
        }

        .universe-title {
            font-size: 1.8rem;
            font-weight: bold;
            color: #ffd700;
            margin-bottom: 0.5rem;
        }

        .universe-subtitle {
            color: #d4af37;
            font-size: 1.1rem;
            font-style: italic;
        }

        /* New Dual Universe Styling */
        .universe-container {
            margin: 3rem auto 0rem auto;
            max-width: 100%;
            padding: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        .dual-universe-display {
            display: flex;
            gap: 1rem;
            align-items: stretch;
            justify-content: center;
            margin: 0 auto;
        }

        /* Universe Panel Base Styles */
        .universe-panel {
            flex: 1;
            background: rgba(26, 22, 18, 0.3);
            border: none;
            border-radius: 0;
            overflow: hidden;
            cursor: pointer;
            position: relative;
            transform: scale(1);
            filter: none;
            opacity: 1;
            z-index: 1;
        }

        /* Active Universe State */
        .universe-panel.active {
            transform: scale(1.2);
            filter: none;
            opacity: 1;
            z-index: 2;
        }

        /* Inactive Universe State - only when there's an active sibling */
        .dual-universe-display:has(.universe-panel.active) .universe-panel:not(.active) {
            transform: scale(0.8);
            opacity: 0.6;
            z-index: 1;
        }

        /* Hover Effects - removed to prevent video graying */

        /* Fallback for browsers without :has() support */
        @supports not (selector(:has(*))) {
            /* When there's an active panel, hide inactive ones */
            .dual-universe-display.has-active .universe-panel:not(.active) {
                transform: scale(0.8);
                opacity: 0.6;
                z-index: 1;
            }

            /* Hover effects removed to prevent video graying */
        }

        /* Universe Header */
        .universe-header {
            background: rgba(0, 0, 0, 0.4);
            padding: 1rem 1.5rem;
            text-align: center;
        }

        .universe-panel.active .universe-header {
            background: rgba(0, 0, 0, 0.6);
        }

        .universe-header h3 {
            color: #ffd700;
            font-size: 1.5rem;
            margin-bottom: 0.3rem;
            text-shadow: 0 0 10px rgba(255, 215, 0, 0.6);
            font-weight: 600;
        }

        .universe-header p {
            color: #d4af37;
            font-size: 0.95rem;
            margin: 0;
            line-height: 1.3;
        }

        /* Universe Video Player */
        .universe-video-player {
            position: relative;
        }

        .universe-video-player video {
            width: 100%;
            aspect-ratio: 2 / 1;
            object-fit: cover;
            background: #000;
            filter: none !important;
            opacity: 1 !important;
            transform: none !important;
        }



        .universe-panel.active .universe-video-player video {
            aspect-ratio: 2 / 1;
        }

        /* Make video larger when timeline is hidden */
        .universe-panel.timeline-hidden .universe-video-player {
            transform: scale(1.08);
        }

        .universe-panel.timeline-hidden .universe-video-player video {
            border-radius: 8px;
        }

        /* Smooth transition for video scaling - removed transitions */

        /* Universe Timeline */
        .universe-timeline {
            padding: 1rem;
            background: rgba(0, 0, 0, 0.5);
            opacity: 1;
            transform: translateY(0);
        }

        /* Auto-hide timeline when inactive */
        .universe-panel.timeline-hidden .universe-timeline {
            opacity: 0;
            transform: translateY(20px);
            pointer-events: none;
        }

        /* Enhanced focus when timeline is hidden */
        .universe-panel.timeline-hidden {
            background: rgba(0, 0, 0, 0.8);
        }

        .universe-panel.timeline-hidden .universe-header {
            opacity: 0.7;
        }

        .timeline-segments {
            display: flex;
            gap: 0.4rem;
            align-items: center;
            flex-wrap: wrap;
        }

        .timeline-segment {
            flex: 1;
            min-width: 70px;
            height: 45px;
            background: rgba(255, 215, 0, 0.1);
            border: none;
            border-radius: 4px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            padding: 0;
            position: relative;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
        }

        .timeline-segment::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.3);
            border-radius: 4px;
        }



        .timeline-segment.active::before {
            background: rgba(255, 215, 0, 0.4);
        }

        .segment-label {
            color: #ffffff;
            font-size: 1rem;
            font-weight: bold;
            text-shadow: 0 0 4px rgba(0, 0, 0, 0.8);
            position: relative;
            z-index: 2;
        }

        /* Active timeline gets slightly larger segments */
        .universe-panel.active .timeline-segment {
            height: 50px;
        }

        .universe-panel.active .segment-label {
            font-size: 1.1rem;
        }

        .flowchart-container {
            display: flex;
            gap: 4rem;
            justify-content: center;
            margin-top: 3rem;
        }

        .universe-column {
            flex: 1;
            max-width: 600px;
            position: relative;
        }

        .universe-column.dimmed {
            opacity: 0.3;
            transform: scale(0.95);
        }

        .universe-header {
            text-align: center;
            margin-bottom: 2rem;
            padding: 1.5rem;
            background: rgba(255, 215, 0, 0.05);
            border-radius: 10px;
            border: 1px solid transparent;
        }



        .universe-header h3 {
            color: #ffd700;
            font-size: 1.8rem;
            margin-bottom: 0.5rem;
        }

        .universe-header p {
            color: #d4af37;
            font-size: 1.1rem;
            margin: 0;
        }

        .timeline-flow {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .timeline-node {
            display: flex;
            gap: 1.5rem;
            align-items: center;
            justify-content: center;
            background: rgba(26, 22, 18, 0.8);
            border: 1px solid transparent;
            border-radius: 12px;
            padding: 2rem;
            position: relative;
        }



        .node-video {
            width: 320px;
            height: 180px;
            flex-shrink: 0;
            border-radius: 8px;
            overflow: hidden;
            position: relative;
            border: 2px solid transparent;
            box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
        }

        .node-video video {
            width: 100%;
            height: 100%;
            object-fit: cover;
            background: #000;
        }

        .video-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.4);
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
        }

        .play-button {
            color: #ffd700;
            font-size: 2rem;
            text-shadow: 0 0 10px rgba(255, 215, 0, 0.8);
        }

        .node-info {
            flex: 1;
        }

        .node-title {
            font-size: 1.4rem;
            font-weight: bold;
            color: #ffd700;
            margin-bottom: 0.5rem;
        }

        .node-description {
            color: #cccccc;
            font-size: 1.1rem;
            line-height: 1.4;
        }

        .timeline-arrow {
            display: flex;
            flex-direction: column;
            align-items: center;
            margin: 0.5rem 0;
            opacity: 0.7;
        }

        .arrow-line {
            width: 3px;
            height: 30px;
            background: linear-gradient(180deg, #d4af37, #ffd700);
            border-radius: 2px;
            position: relative;
        }

        .arrow-line::before {
            content: '';
            position: absolute;
            width: 100%;
            height: 100%;
            background: linear-gradient(180deg, #d4af37, #ffd700);
            border-radius: 2px;
            animation: pulseArrow 2s ease-in-out infinite;
        }

        @keyframes pulseArrow {
            0%, 100% { opacity: 0.5; transform: scaleY(1); }
            50% { opacity: 1; transform: scaleY(1.2); }
        }
        .arrow-head {
            color: #ffd700;
            font-size: 1.5rem;
            text-shadow: 0 0 10px rgba(255, 215, 0, 0.6);
            animation: bounce 2s ease-in-out infinite;
            margin-top: -10px;
            margin-left: 22px;
        }

        /* Video playing state */
        .node-video.playing .video-overlay {
            opacity: 0;
            pointer-events: none;
        }

        /* Responsive Design */
        @media (max-width: 1200px) {
            .dual-universe-display {
                flex-direction: column;
                gap: 1.5rem;
            }
            
            .universe-panel {
                transform: none !important;
            }
            
            .universe-panel.active {
                transform: none !important;
            }
            
            .universe-panel:not(.active) {
                transform: none !important;
            }
            
            .universe-video-player video {
                height: 300px;
            }
            
            .universe-panel.active .universe-video-player video {
                height: 350px;
            }
        }

        @media (max-width: 768px) {
            .universe-container {
                margin: 2rem 1rem;
            }
            
            .dual-universe-display {
                gap: 1rem;
            }
            
            .universe-header {
                padding: 1rem 1.5rem;
            }
            
            .universe-header h3 {
                font-size: 1.4rem;
            }
            
            .universe-header p {
                font-size: 0.95rem;
            }
            
            .universe-video-player video {
                height: 250px;
            }
            
            .universe-panel.active .universe-video-player video {
                height: 280px;
            }
            
            .universe-timeline {
                padding: 1rem;
            }
            
            .timeline-segments {
                gap: 0.3rem;
            }
            
            .timeline-segment {
                height: 45px;
                min-width: 70px;
                flex: 1 1 calc(33.333% - 0.2rem);
            }
            
            .universe-panel.active .timeline-segment {
                height: 50px;
            }
            
            .segment-label {
                font-size: 0.7rem;
            }
            
            .universe-panel.active .segment-label {
                font-size: 0.8rem;
            }
        }

        .global-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: linear-gradient(to right, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.9) 12%,rgba(0, 0, 0, 1) 50%, rgba(0, 0, 0, 0.9) 88%, rgba(0, 0, 0, 0.3) 100%);
            z-index: 0;
        }
    </style>
</head>
<body>
    <div class="navigation-container">
        <nav class="veo-nav" id="veoNav">
            <div class="nav-items">
                <a href="#home" class="nav-item">Captain Cinema</a>
                <a href="#movie-remake" class="nav-item">Movie Remake</a>
                <a href="#parallel-universe" class="nav-item">Parallel Universe</a>
                <a href="#method" class="nav-item">Method</a>
                <a href="#eval_robustness" class="nav-item">Advantages</a>
                <a href="#creative-control" class="nav-item">Creative Control</a>
                <a href="#research" class="nav-item">Contact</a>
            </div>
        </nav>
    </div>

    <div class="global-overlay"></div>

    <!-- Film Strip Background -->
    <div class="film-strip-container">
        <div class="film-strip-wrapper" id="filmStripWrapper">
            <!-- Film strips will be generated by JavaScript -->
        </div>
    </div>

    <!-- Main Content -->
    <div class="main-content" id="home">
        <div class="container">
            <img src="figures/title.png" alt="Captain Cinema Title" class="title-image" data-aos="fade-down" data-aos-duration="1200" data-aos-delay="300">
            <h1 data-aos="fade-up" data-aos-duration="1000" data-aos-delay="500">Captain Cinema</h1>
            <p class="subtitle" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="700">Towards Short Movie Generation</p>
            
            <!-- Research Team Link -->
            <div data-aos="fade-up" data-aos-duration="1000" data-aos-delay="800" style="text-align: center; margin: 2rem 0 1rem 0;">
                <a href="#research" class="research-team-link">
                    Captain Cinema Team
                </a>
            </div>
            
            <!-- Paper and Code Buttons -->
            <div class="button-container" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="900">
                <!-- ArXiv -->
                <!-- Paper link removed for anonymous review -->
                <!-- GitHub
                <a href="https://github.com/lambert-x/Captain-Cinema" class="button" target="_blank" rel="noopener">
                    <span class="icon is-small">
                        <i class="fab fa-github"></i>
                    </span>
                    <span>Code (Pe</span>
                </a> -->
            </div>

            
        </div>
        
        </div>
    </div>

    <div>
        <!-- Additional Content Sections -->
        <section class="content-section" id="movie-remake">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000">Remake movies with your story</h2>
                
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="200">
                    <p><strong> Captain Cinema </strong> is designed to create multi-scene movies with professional cinematic quality, while keeping character and <br> scene consistency with super long context memory.  <br>You can be the director to remake any movie  <br> with your story, scenes and characters.</p>


                </div>
                <div class="demo-caption" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="300">
                    <p>This cinematic short film follows the epic interstellar journey of <em>Bruce Wayne, Joker, and Alfred Pennyworth</em> through the cosmos. Given narrative captions, our model firstly renders consistent keyframe scenes, then do interleaved-conditioned video generation and output <br>a seamless multi-scene movie with superior visual consistency.</p>
                </div>
                <div class="video-demo-section" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="400">
                    <div class="video-container">
                        <div class="video-player-section">
                            <div class="video-wrapper">
                                                            <video id="batmanVideoPlayer" controls preload="metadata">
                                <source src="./videos/long_demo_07272025_compressed_v2.mp4" type="video/mp4">
                                <p>Your browser does not support the video tag. The video file may not be properly encoded or accessible.</p>
                            </video>
                                <div id="videoErrorMessage" style="display: none; color: #ff6b6b; text-align: center; padding: 2rem; font-size: 1.2rem;">
                                    Video failed to load. Please check if the video file exists and is properly encoded.
                                </div>
                            </div>
                        </div>
                        
                        <div class="scenes-list" id="scenesList">
                            <div class="scene-item active" data-time="4">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot1.png" alt="Shot 1">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 1</div>
                                    <div class="scene-description">Bruce and Alfred discuss with Joker</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="12">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot2.png" alt="Shot 2">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 2</div>
                                    <div class="scene-description">Joker speaks with Bruce in the control room</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="20">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot3.png" alt="Shot 3">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 3</div>
                                    <div class="scene-description">Hand interacts with fractured holographic display</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="28">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot4.png" alt="Shot 4">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 4</div>
                                    <div class="scene-description">Bruce looks intently at a screen</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="36">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot5.png" alt="Shot 5">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 5</div>
                                    <div class="scene-description">Joker gazes at a colorful nebula</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="44">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot6.png" alt="Shot 6">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 6</div>
                                    <div class="scene-description">Spaceship orbits past a dazzling bright sun</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="52">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot7.png" alt="Shot 7">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 7</div>
                                    <div class="scene-description">Close-up of intricate space station machinery</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="60">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot8.png" alt="Shot 8">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 8</div>
                                    <div class="scene-description">Bruce and Alfred watch a vibrant galaxy</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="70">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot9.png" alt="Shot 9">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 9</div>
                                    <div class="scene-description">Joker observes a vibrant green nebula</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="76">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot10.png" alt="Shot 10">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 10</div>
                                    <div class="scene-description">Screen shows green cosmic entity near planet</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="84">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot11.png" alt="Shot 11">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 11</div>
                                    <div class="scene-description">Joker very happy, seated in control room</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="91">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot12.png" alt="Shot 12">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 12</div>
                                    <div class="scene-description">Bruce looks to Joker, talks to Joker</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="96">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot13.png" alt="Shot 13">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 13</div>
                                    <div class="scene-description">Another day, Joker interacts with Alfred</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="99">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot14.png" alt="Shot 14">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 14</div>
                                    <div class="scene-description">Bruce looks intently at laptop screen</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="103">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot15.png" alt="Shot 15">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 15</div>
                                    <div class="scene-description">Joker stares menacingly at Bruce</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="106">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot16.png" alt="Shot 16">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 16</div>
                                    <div class="scene-description">Bruce looks outside and Joker looks behind</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="114">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot17.png" alt="Shot 17">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 17</div>
                                    <div class="scene-description">Bruce and Alfred share a meal together</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="122">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot18.png" alt="Shot 18">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 18</div>
                                    <div class="scene-description">Bruce in helmet surveys surroundings</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="130">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot19.png" alt="Shot 19">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 19</div>
                                    <div class="scene-description">Joker comes to speak with Bruce</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="138">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot20.png" alt="Shot 20">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 20</div>
                                    <div class="scene-description">Bruce watches monitors and talks to Joker</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="146">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot21.png" alt="Shot 21">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 21</div>
                                    <div class="scene-description">Joker operates controls in space suit</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="154">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot22.png" alt="Shot 22">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 22</div>
                                    <div class="scene-description">Astronaut looks up in dimly lit room</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="162">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot23.png" alt="Shot 23">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 23</div>
                                    <div class="scene-description">Spaceship orbits planet near a black hole</div>
                                </div>
                            </div>
    
                            <div class="scene-item" data-time="170">
                                <div class="scene-thumbnail">
                                    <img src="./videos/long_demo/shot_frames/shot24.png" alt="Shot 24">
                                </div>
                                <div class="scene-info">
                                    <div class="scene-title">Shot 24</div>
                                    <div class="scene-description">Stunning view of a luminous black hole</div>
                                </div>
                            </div>
                        </div>
                    </div>
                    
                    <div class="video-controls">
                        <div class="video-timeline" id="videoTimeline">
                            <div class="video-progress" id="videoProgress"></div>
                        </div>
                        <div class="video-time" id="videoTime">0:00 / 0:00</div>
                    </div>
                </div>
            </div>
        </section>

        <!-- Two Universe Parallel Narrative Section -->
        <section class="content-section alternate" id="parallel-universe">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000">Create Your Own Universe</h2>
                
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="200" style="margin-bottom: 1rem;">
                    <p><strong>Captain Cinema</strong> can branch storylines into completely different paths, each maintaining internal consistency while <br>exploring alternative creative imaginations. <br><br> <br> Click on either <strong>Universe A</strong> or <strong>Universe B</strong> below to explore  entirely different adventures across parallel universes.</p>
                </div>
                
                <div class="universe-container" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="400">
                    <!-- Two Universe Panels Side by Side -->
                    <div class="dual-universe-display">
                        <!-- Left Universe Panel -->
                        <div class="universe-panel left-universe" id="universe-left" data-universe="path1">
                            <div class="universe-header">
                                <h3>Universe A</h3>
                                <p>Massive stars exploding creating a giant red space cloud</p>
                            </div>
                            <div class="universe-video-player">
                                <video id="universe-left-video" controls muted preload="metadata">
                                    <source src="videos/long_demo/additional_path/path1_0.mp4" type="video/mp4">
                                    Your browser does not support the video tag.
                                </video>
                            </div>
                            <div class="universe-timeline">
                                <div class="timeline-segments" id="left-timeline-segments">
                                    <!-- Timeline segments will be populated by JavaScript -->
                                </div>
                            </div>
                        </div>
                        
                        <!-- Right Universe Panel -->
                        <div class="universe-panel right-universe" id="universe-right" data-universe="path2">
                            <div class="universe-header">
                                <h3>Universe B</h3>
                                <p>Green cosmic energy transforming planet</p>
                            </div>
                            <div class="universe-video-player">
                                <video id="universe-right-video" controls muted preload="metadata">
                                    <source src="videos/long_demo/additional_path/path2_0.mp4" type="video/mp4">
                                    Your browser does not support the video tag.
                                </video>
                            </div>
                            <div class="universe-timeline">
                                <div class="timeline-segments" id="right-timeline-segments">
                                    <!-- Timeline segments will be populated by JavaScript -->
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </section>

        <section class="content-section" id="method">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000">You Only Generate Once</h2>
                
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="200">
                    <p>Our model bridges <strong>top-down</strong> keyframes generation to <strong>bottom-up</strong> mutli-frame interleaved-conditioned video generation, making <br>  a unified pipeline  for providing state-of-the-art <br> quality, consistency and controllability.</p>
                </div>

                <div style="width: 60%; margin: 3rem 20% 0 20%; padding: 0;" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="400">
                    <img src="method_bridging_v1.png" alt="Method Overview" style="width: 100%; height: auto; border-radius: 10px; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);">
                </div>
            </div>
        </section>

        <section class="content-section" id="goldenmem">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000">Less tokens but longer context</h2>
                
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="200">
                    <p>Inspired by bounded‑area golden‑ratio squares, we propose <strong>GoldenMem</strong> to downsample history frames for long context memory without increasing tokens, showing <br> strong consistency and visual quality.</p>
                </div>

                <div style="width: 60%; margin: 3rem 20% 0 20%; padding: 0;" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="400">
                    <img src="method_goldenmem_v1.png" alt="GoldenMem Method" style="width: 100%; height: auto; border-radius: 10px; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);">
                </div>
            </div>
        </section>

        <section class="content-section" id="eval_robustness">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000" data-aos-delay="100">Consistent, Robust and Smooth <br> Movie Generation</h2>
                
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="300">
                    <p><strong>Captain Cinema </strong> disentangles the static generation and motion tasks, allowing our video generation model to focus on motion synthesis, making for more consistent, robust, <br> and smooth movie generation.</p>   
                </div>

                <div style="width: 100%; margin: 3rem 0; padding: 0;" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="500">
                    <div style="text-align: center; margin-bottom: 1rem; font-size: 20px; color: #dfcf96;">
                        &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Text-only Long Context Tuning &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Interleaved-conditioned Long Context Tuning
                    </div>
                    <div style="width: 100%; display: flex; justify-content: center;">
                        <video id="comparisonVideoPlayer" controls muted preload="metadata" style="width: 100%; max-width: 80%; height: auto; border: none; border-radius: 0;">
                            <source src="videos/multi_keyframe_condition/comparison.mp4" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>
                    </div>
                    
                    <!-- Comparison Video Timeline -->
                    <div class="comparison-timeline" style="width: 100%; max-width: 80%; margin: 1.5rem auto 0 auto; padding: 1rem; background: rgba(0, 0, 0, 0.4); border-radius: 10px; border: 1px solid transparent; transition: all 0.3s ease;" onmouseover="this.style.borderColor='rgba(255, 215, 0, 0.3)'; this.style.boxShadow='0 0 20px rgba(255, 215, 0, 0.1)'" onmouseout="this.style.borderColor='transparent'; this.style.boxShadow='none'">
                        <div class="timeline-segments" id="comparison-timeline-segments" style="display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; justify-content: center;">
                            <!-- Timeline segments will be populated by JavaScript -->
                        </div>
                    </div>
                </div>

                <div style="width: 100%; margin: 3rem 0; padding: 0;" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="700">
                    <div style="width: 100%; display: flex; justify-content: center;">
                        <video id="robustVideoPlayer" autoplay loop muted playsinline style="width: 100%; max-width: 80%; height: auto; border-radius: 10px; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);">
                            <source src="./robust_video_generation_website.mp4" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>
                    </div>
                </div>
            </div>
        </section>

        <section class="content-section" id="creative-control">
            <div class="section-container">
                <h2 data-aos="fade-up" data-aos-duration="1000" data-aos-delay="100">Keyframe‑Level Creative Control</h2>
                <div class="demo-introduction" data-aos="fade-up" data-aos-duration="1000" data-aos-delay="300">
                    <p><strong>Captain Cinema</strong>, armed with powerful image‑editing models, turns every keyframe into a fully editable canvas—giving you precise control to restyle outfits, refine characters, or <br>brand objects, and then propagating those edits <br> flawlessly  through the entire shot.</p>
                </div>

                <div style="width: 60%; margin: 3rem 20% 0 20%; padding: 0;" data-aos="fade-up" data-aos-duration="1200" data-aos-delay="500">
                    <video id="editDemoVideo" loop muted playsinline style="width: 100%; height: auto; border-radius: 10px; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);">
                        <source src="edit_demo_preview_v3.mp4" type="video/mp4">
                        Your browser does not support the video tag.
                    </video>
                </div>
            </div>
        </section>

    </div>

    <!-- Research Team Section -->
    <section class="research-section" id="research">
        <div class="research-container">
            <h2 class="research-title">Research</h2>
            <div class="research-authors">
                <div class="research-author-name">Anonymous Authors</div>
            </div>
            <div class="institutions-logos">
                <!-- Institutional logos removed for anonymous review -->
            </div>
            

        </div>
    </section>

    <script>
        // Navigation functionality
        document.addEventListener('DOMContentLoaded', function() {
            const veoNav = document.getElementById('veoNav');
            const allNavItems = document.querySelectorAll('.nav-item');
            const sections = document.querySelectorAll('section[id], div#home');
            const navigationContainer = document.querySelector('.navigation-container');
            
            let isClickScrolling = false;
            let clickScrollTimeout;
            let lastActiveSectionId = 'home'; // Track the last active section

            // --- CLICK HANDLER ---
            allNavItems.forEach(item => {
                item.addEventListener('click', function(e) {
                    e.preventDefault();
                    
                    isClickScrolling = true;

                    allNavItems.forEach(nav => nav.classList.remove('active'));
                    this.classList.add('active');
                    
                    const targetId = this.getAttribute('href').substring(1);
                    lastActiveSectionId = targetId; // Update the last active section
                    const targetSection = document.getElementById(targetId);
                    
                    if (targetSection) {
                        const navBarHeight = document.getElementById('veoNav').offsetHeight;
                        const offset = navBarHeight + 40;
                        
                        let targetPosition = targetSection.getBoundingClientRect().top + window.pageYOffset - offset;

                        if (targetId === 'home') {
                            targetPosition = 0;
                        }

                        window.scrollTo({
                            top: targetPosition,
                            behavior: 'smooth'
                        });
                    }

                    clearTimeout(clickScrollTimeout);
                    clickScrollTimeout = setTimeout(() => {
                        isClickScrolling = false;
                    }, 1000); 
                });
            });

            // --- SCROLL HANDLER ---
            let isTransitioning = false;
            const scrollHandler = function() {
                const navPosition = navigationContainer.offsetTop;
                const scrollPosition = window.pageYOffset;
                const triggerPoint = navPosition - 20;

                // Sticky Logic
                if (scrollPosition >= triggerPoint && !veoNav.classList.contains('sticky')) {
                    if (!isTransitioning) {
                        isTransitioning = true;
                        veoNav.classList.add('transitioning');
                        const currentTop = navPosition - scrollPosition;
                        veoNav.style.top = currentTop + 'px';
                        veoNav.offsetHeight; 
                        setTimeout(() => { veoNav.style.top = '1rem'; }, 10);
                        setTimeout(() => {
                            veoNav.classList.remove('transitioning');
                            veoNav.classList.add('sticky');
                            veoNav.style.top = '';
                            isTransitioning = false;
                        }, 200);
                    }
                } else if (scrollPosition < triggerPoint && veoNav.classList.contains('sticky')) {
                    if (!isTransitioning) {
                        veoNav.classList.remove('sticky');
                        veoNav.classList.remove('transitioning');
                        veoNav.style.top = '';
                    }
                }

                // Highlight Logic
                if (isClickScrolling) {
                    return; 
                }

                let currentSectionId = lastActiveSectionId; // Start with the last known section
                const highlightTriggerY = window.innerHeight * 0.4;
                let sectionDetected = false;

                // Check each section to see if we're clearly in one
                sections.forEach(section => {
                    const rect = section.getBoundingClientRect();
                    // Use a more generous detection area to avoid gaps
                    if (rect.top <= highlightTriggerY && rect.bottom > highlightTriggerY) {
                        currentSectionId = section.getAttribute('id');
                        sectionDetected = true;
                    }
                    // Also check if we're clearly past the middle of a section
                    else if (rect.top < 0 && rect.bottom > window.innerHeight * 0.6) {
                        currentSectionId = section.getAttribute('id');
                        sectionDetected = true;
                    }
                });
                
                // Special case: if we're at the very top, always show home
                if (window.pageYOffset < 100) {
                    currentSectionId = 'home';
                    sectionDetected = true;
                }
                
                // Special case: if we're at the very bottom, show the last section
                if ((window.innerHeight + window.pageYOffset) >= document.body.offsetHeight - 5) {
                    currentSectionId = sections[sections.length - 1].getAttribute('id');
                    sectionDetected = true;
                }

                // Map goldenmem section to method navigation item
                if (currentSectionId === 'goldenmem') {
                    currentSectionId = 'method';
                }

                // Only update if we detected a clear section change
                if (sectionDetected) {
                    lastActiveSectionId = currentSectionId;
                }

                allNavItems.forEach(item => {
                    item.classList.remove('active');
                    const itemHref = item.getAttribute('href');
                    if (itemHref && itemHref.substring(1) === currentSectionId) {
                        item.classList.add('active');
                    }
                });
            };

            window.addEventListener('scroll', scrollHandler);
            scrollHandler();
        });

        // Wait for DOM to be fully loaded
        document.addEventListener('DOMContentLoaded', function() {
            const filmStripWrapper = document.getElementById('filmStripWrapper');
            const stripeCount = 40;
            const framesPerStripe = 6;

            // Available keyframe images
            const keyframeImages = [
                'keyframe_02.png', 'keyframe_03.png', 'keyframe_06.png', 'keyframe_07.png',
                'keyframe_10.png', 'keyframe_14.png', 'keyframe_16.png', 'keyframe_21.png',
                'keyframe_23.png', 'keyframe_24.png', 'keyframe_25.png', 'keyframe_26.png',
                'keyframe_27.png', 'keyframe_29.png', 'keyframe_30.png', 'keyframe_31.png',
                'keyframe_32.png', 'keyframe_33.png', 'keyframe_35.png', 'keyframe_36.png',
                'keyframe_38.png', 'keyframe_39.png', 'keyframe_40.png', 'keyframe_41.png',
                'keyframe_42.png', 'keyframe_43.png', 'keyframe_44.png', 'keyframe_45.png',
                'keyframe_46.png', 'keyframe_47.png', 'keyframe_48.png', 'keyframe_49.png',
                'keyframe_50.png', 'keyframe_51.png', 'keyframe_52.png', 'keyframe_53.png',
                'keyframe_54.png', 'keyframe_55.png', 'keyframe_56.png', 'keyframe_57.png',
                'keyframe_58.png', 'keyframe_59.png', 'keyframe_60.png', 'keyframe_61.png',
                'keyframe_62.png', 'keyframe_63.png', 'keyframe_64.png', 'keyframe_65.png',
                'keyframe_66.png', 'keyframe_67.png', 'keyframe_68.png', 'keyframe_69.png',
                'keyframe_70.png', 'keyframe_71.png', 'keyframe_72.png', 'keyframe_73.png',
                'keyframe_74.png', 'keyframe_75.png', 'keyframe_76.png', 'keyframe_77.png',
                'keyframe_78.png', 'keyframe_79.png', 'keyframe_80.png', 'keyframe_81.png',
                'keyframe_82.png', 'keyframe_83.png', 'keyframe_84.png', 'keyframe_85.png'
            ];

            // Shuffle array to ensure randomness
            function shuffleArray(array) {
                const shuffled = [...array];
                for (let i = shuffled.length - 1; i > 0; i--) {
                    const j = Math.floor(Math.random() * (i + 1));
                    [shuffled[i], shuffled[j]] = [shuffled[j], shuffled[i]];
                }
                return shuffled;
            }

            // Create a usage counter for equal distribution
            const imageUsageCount = {};
            keyframeImages.forEach(img => imageUsageCount[img] = 0);
            
            // Function to get next available image with minimum usage
            function getNextImages(count, previousStripeImages = []) {
                const selectedImages = [];
                const availableImages = [...keyframeImages];
                
                // First, shuffle available images
                const shuffled = shuffleArray(availableImages);
                
                // Sort by usage count (ascending) and then by whether they were in previous stripe
                shuffled.sort((a, b) => {
                    const usageDiff = imageUsageCount[a] - imageUsageCount[b];
                    if (usageDiff !== 0) return usageDiff;
                    
                    // Deprioritize images from previous stripe
                    const aInPrev = previousStripeImages.includes(a) ? 1 : 0;
                    const bInPrev = previousStripeImages.includes(b) ? 1 : 0;
                    return aInPrev - bInPrev;
                });
                
                // Select images ensuring variety
                for (let i = 0; i < count && i < shuffled.length; i++) {
                    selectedImages.push(shuffled[i]);
                    imageUsageCount[shuffled[i]]++;
                }
                
                // Shuffle selected images to randomize order within stripe
                return shuffleArray(selectedImages);
            }

            console.log(`Generating ${stripeCount} film strips with ${framesPerStripe} frames each...`);

            let previousStripeImages = [];

            for (let s = 0; s < stripeCount; s++) {
                const filmStrip = document.createElement('div');
                filmStrip.className = 'film-strip';

                filmStripWrapper.appendChild(filmStrip);

                // Select 6 images for this stripe, avoiding previous stripe's images
                const stripeImages = getNextImages(framesPerStripe, previousStripeImages);
                previousStripeImages = [...stripeImages];

                // Duplicate frames for seamless looping
                for (let loop = 0; loop < 4; loop++) {
                    for (let i = 0; i < framesPerStripe; i++) {
                        const frame = document.createElement('div');
                        frame.className = 'film-frame';

                        // Add perforations
                        const perforationsTop = document.createElement('div');
                        perforationsTop.className = 'perforations-top';

                        const perforationsBottom = document.createElement('div');
                        perforationsBottom.className = 'perforations-bottom';

                        // Add perforation holes
                        for (let j = 0; j < 35; j++) {
                            const perfTop = document.createElement('div');
                            perfTop.className = 'perforation';
                            perfTop.style.left = `${j * 22 + 10}px`;
                            perforationsTop.appendChild(perfTop);

                            const perfBottom = document.createElement('div');
                            perfBottom.className = 'perforation';
                            perfBottom.style.left = `${j * 22 + 10}px`;
                            perforationsBottom.appendChild(perfBottom);
                        }

                        frame.appendChild(perforationsTop);
                        frame.appendChild(perforationsBottom);

                        // Add frame content
                        const content = document.createElement('div');
                        content.className = 'frame-content';
                        
                        // Use actual keyframe image
                        const imagePath = `figures/background_keyframes/renamed_keyframes/${stripeImages[i]}`;
                        content.style.backgroundImage = `url('${imagePath}')`;
                        content.style.backgroundSize = 'cover';
                        content.style.backgroundPosition = 'center';
                        
                        frame.appendChild(content);

                        filmStrip.appendChild(frame);
                    }
                }
            }

            console.log('Completed generating film strips.');
        });

        // Interactive Video Control JavaScript
        document.addEventListener('DOMContentLoaded', function() {
            const videoPlayer = document.getElementById('batmanVideoPlayer');
            const sceneItems = document.querySelectorAll('.scene-item');
            const videoProgress = document.getElementById('videoProgress');
            const videoTimeline = document.getElementById('videoTimeline');
            const videoTime = document.getElementById('videoTime');
            const captionText = document.getElementById('captionText');

            if (!videoPlayer) return;
            
            // Ensure video starts unmuted for manual playback
            videoPlayer.muted = false;
            console.log('Batman video initialized with sound enabled');

            // Shot data for captions
            const shotData = [
                { time: 0, description: "Bruce and Alfred observe a space object" },
                { time: 9, description: "Joker poses mischievously in the control room" },
                { time: 17, description: "Hand interacts with fractured holographic display" },
                { time: 25, description: "Bruce looks intently at a screen" },
                { time: 33, description: "Joker gazes at a colorful nebula" },
                { time: 41, description: "Spaceship orbits past a dazzling bright sun" },
                { time: 49, description: "Close-up of intricate space station machinery" },
                { time: 57, description: "Bruce and Alfred watch a vibrant galaxy" },
                { time: 67, description: "Joker observes a vibrant green nebula" },
                { time: 73, description: "Screen shows green cosmic entity near planet" },
                { time: 81, description: "Joker very happy, seated in control room" },
                { time: 88, description: "Bruce looks to Joker, talks to Joker" },
                { time: 93, description: "Another day, Joker interacts with Alfred" },
                { time: 96, description: "Bruce looks intently at laptop screen" },
                { time: 100, description: "Joker stares menacingly at Bruce" },
                { time: 103, description: "Bruce looks outside and Joker looks behind" },
                { time: 111, description: "Bruce and Alfred share a meal together" },
                { time: 119, description: "Bruce in helmet surveys surroundings" },
                { time: 127, description: "Joker comes to speak with Bruce" },
                { time: 135, description: "Bruce watches monitors and talks to Joker" },
                { time: 143, description: "Joker operates controls in space suit" },
                { time: 151, description: "Astronaut looks up in dimly lit room" },
                { time: 159, description: "Spaceship orbits planet near a black hole" },
                { time: 167.1, description: "Stunning view of a luminous black hole" }
            ];

            // Function to update captions
            function updateCaption(currentTime) {
                let currentCaption = shotData[0].description;
                for (let i = shotData.length - 1; i >= 0; i--) {
                    if (currentTime >= shotData[i].time) {
                        currentCaption = shotData[i].description;
                        break;
                    }
                }
                if (captionText) {
                    captionText.textContent = currentCaption;
                }
            }

            // Scene click handlers
            sceneItems.forEach(item => {
                item.addEventListener('click', function() {
                    const timeSeconds = parseFloat(this.getAttribute('data-time'));
                    videoPlayer.currentTime = timeSeconds;
                    
                    // Update active scene
                    sceneItems.forEach(scene => scene.classList.remove('active'));
                    this.classList.add('active');
                    
                    // Update caption immediately
                    updateCaption(timeSeconds);
                    
                    // Scroll active scene into view
                    this.scrollIntoView({ behavior: 'smooth', block: 'nearest' });
                });
            });

            // Ensure batman video has sound on manual play
            videoPlayer.addEventListener('play', function() {
                if (!autoPlayedVideos.has('batmanVideoPlayer') || videoPlayer.currentTime > 0) {
                    // This is manual play or user has interacted with the video
                    videoPlayer.muted = false;
                    console.log('Batman video sound enabled for manual play');
                }
            });
            
            // Ensure sound is on when user clicks play
            videoPlayer.addEventListener('click', function() {
                if (videoPlayer.paused) {
                    videoPlayer.muted = false;
                    console.log('Batman video sound enabled on click');
                }
            });

            // Video time update handler
            videoPlayer.addEventListener('timeupdate', function() {
                const currentTime = videoPlayer.currentTime;
                const duration = videoPlayer.duration;

                // Update progress bar
                if (duration > 0) {
                    const progressPercent = (currentTime / duration) * 100;
                    videoProgress.style.width = progressPercent + '%';
                }

                // Update time display
                const currentMinutes = Math.floor(currentTime / 60);
                const currentSeconds = Math.floor(currentTime % 60);
                const durationMinutes = Math.floor(duration / 60);
                const durationSeconds = Math.floor(duration % 60);
                
                videoTime.textContent = 
                    `${currentMinutes}:${currentSeconds.toString().padStart(2, '0')} / ` +
                    `${durationMinutes}:${durationSeconds.toString().padStart(2, '0')}`;

                // Update captions
                updateCaption(currentTime);

                // Update active scene based on current time
                let activeSceneFound = false;
                for (let i = sceneItems.length - 1; i >= 0; i--) {
                    const sceneTime = parseFloat(sceneItems[i].getAttribute('data-time'));
                    if (currentTime >= sceneTime && !activeSceneFound) {
                        sceneItems.forEach(scene => scene.classList.remove('active'));
                        sceneItems[i].classList.add('active');
                        activeSceneFound = true;
                        break;
                    }
                }
            });

            // Timeline click handler
            videoTimeline.addEventListener('click', function(e) {
                const rect = this.getBoundingClientRect();
                const clickPosition = (e.clientX - rect.left) / rect.width;
                const newTime = clickPosition * videoPlayer.duration;
                videoPlayer.currentTime = newTime;
            });

            // Enhanced video loading state handling
            videoPlayer.addEventListener('loadstart', function() {
                console.log('Video loading started...');
                document.getElementById('videoErrorMessage').style.display = 'none';
            });

            videoPlayer.addEventListener('canplay', function() {
                console.log('Video can start playing');
                document.getElementById('videoErrorMessage').style.display = 'none';
                
                // Enable captions/subtitles
                const tracks = videoPlayer.textTracks;
                if (tracks.length > 0) {
                    tracks[0].mode = 'showing';
                    console.log('Captions enabled');
                }
            });

            videoPlayer.addEventListener('loadeddata', function() {
                console.log('Video data loaded successfully');
                document.getElementById('videoErrorMessage').style.display = 'none';
            });

            videoPlayer.addEventListener('stalled', function() {
                console.warn('Video loading stalled');
            });

            videoPlayer.addEventListener('suspend', function() {
                console.warn('Video loading suspended');
            });

            videoPlayer.addEventListener('abort', function() {
                console.error('Video loading aborted');
                document.getElementById('videoErrorMessage').style.display = 'block';
            });

            // Configure caption display and add video diagnostic
            videoPlayer.addEventListener('loadedmetadata', function() {
                const duration = videoPlayer.duration;
                const durationMinutes = Math.floor(duration / 60);
                const durationSeconds = Math.floor(duration % 60);
                videoTime.textContent = `0:00 / ${durationMinutes}:${durationSeconds.toString().padStart(2, '0')}`;
                
                console.log('✅ Video metadata loaded successfully');
                console.log('Video duration:', duration);
                console.log('Video dimensions:', videoPlayer.videoWidth, 'x', videoPlayer.videoHeight);
                
                // Enable captions if available
                const tracks = videoPlayer.textTracks;
                for (let i = 0; i < tracks.length; i++) {
                    if (tracks[i].kind === 'captions' || tracks[i].kind === 'subtitles') {
                        tracks[i].mode = 'showing';
                        console.log('Caption track enabled:', tracks[i].label);
                        break;
                    }
                }
            });

            // Add diagnostic test for video accessibility
            function testVideoAccessibility() {
                const testPaths = [
                    './videos/long_demo_07272025_compressed.mp4',
                    'videos/long_demo_07272025_compressed.mp4',
                    window.location.origin + '/videos/long_demo_07272025_compressed.mp4'
                ];
                
                console.log('🔍 Testing video file accessibility...');
                testPaths.forEach((path, index) => {
                    fetch(path, { method: 'HEAD' })
                        .then(response => {
                            console.log(`Path ${index + 1} (${path}):`, response.status === 200 ? '✅ Accessible' : `❌ ${response.status} ${response.statusText}`);
                            if (response.status === 200) {
                                console.log('Content-Type:', response.headers.get('content-type'));
                                console.log('Content-Length:', response.headers.get('content-length'));
                            }
                        })
                        .catch(error => {
                            console.log(`Path ${index + 1} (${path}): ❌ ${error.message}`);
                        });
                });
            }
            
            // Run accessibility test
            testVideoAccessibility();

            videoPlayer.addEventListener('error', function(e) {
                console.error('Video error:', e);
                console.error('Video src:', videoPlayer.src);
                console.error('Video readyState:', videoPlayer.readyState);
                console.error('Video networkState:', videoPlayer.networkState);
                
                // Show error message to user
                const errorMsg = document.getElementById('videoErrorMessage');
                if (errorMsg) {
                    errorMsg.style.display = 'block';
                    errorMsg.innerHTML = `
                        <strong>Video Loading Error</strong><br>
                        The video file could not be loaded. This might be due to:<br>
                        • File not found on server<br>
                        • Video encoding incompatible with browser<br>
                        • Server CORS or MIME type configuration<br>
                        • Network connectivity issues<br><br>
                        <small>Check browser console for detailed error information.</small>
                    `;
                }

                // Try to get more specific error information
                if (videoPlayer.error) {
                    const error = videoPlayer.error;
                    console.error('Video error code:', error.code);
                    console.error('Video error message:', error.message);
                    
                    switch(error.code) {
                        case error.MEDIA_ERR_ABORTED:
                            console.error('Video playback aborted');
                            break;
                        case error.MEDIA_ERR_NETWORK:
                            console.error('Network error while loading video');
                            break;
                        case error.MEDIA_ERR_DECODE:
                            console.error('Video decoding error - file may be corrupted or incompatible');
                            break;
                        case error.MEDIA_ERR_SRC_NOT_SUPPORTED:
                            console.error('Video format not supported or file not found');
                            break;
                        default:
                            console.error('Unknown video error');
                    }
                }
            });
        });

        // Dual Universe Interactive JavaScript
        document.addEventListener('DOMContentLoaded', function() {
            const leftPanel = document.getElementById('universe-left');
            const rightPanel = document.getElementById('universe-right');
            const leftVideo = document.getElementById('universe-left-video');
            const rightVideo = document.getElementById('universe-right-video');
            const leftTimeline = document.getElementById('left-timeline-segments');
            const rightTimeline = document.getElementById('right-timeline-segments');
            
            // Universe data
            const universeData = {
                path1: {
                    videos: [
                        'videos/long_demo/additional_path/path1_0.mp4',
                        'videos/long_demo/additional_path/path1_1.mp4',
                        'videos/long_demo/additional_path/path1_2.mp4',
                        'videos/long_demo/additional_path/path1_3.mp4',
                        'videos/long_demo/additional_path/path1_4.mp4',
                        'videos/long_demo/additional_path/path1_5.mp4'
                    ]
                },
                path2: {
                    videos: [
                        'videos/long_demo/additional_path/path2_0.mp4',
                        'videos/long_demo/additional_path/path2_1.mp4',
                        'videos/long_demo/additional_path/path2_2.mp4',
                        'videos/long_demo/additional_path/path2_3.mp4',
                        'videos/long_demo/additional_path/path2_4.mp4',
                        'videos/long_demo/additional_path/path2_5.mp4'
                    ]
                }
            };
            
            let leftCurrentSegment = 0;
            let rightCurrentSegment = 0;
            let leftAutoplayInterval = null;
            let rightAutoplayInterval = null;
            
            // Auto-hide timeline variables
            let timelineHideTimeout = null;
            let isTimelineVisible = true;
            const TIMELINE_HIDE_DELAY = 2500; // Hide after 2.5 seconds of no mouse movement
            
            // Video preloading cache
            const preloadedVideos = new Map();
            const videoThumbnails = new Map();
            
            // Timeline auto-hide functionality
            function showTimeline() {
                if (!isTimelineVisible) {
                    leftPanel.classList.remove('timeline-hidden');
                    rightPanel.classList.remove('timeline-hidden');
                    isTimelineVisible = true;
                }
                
                // Clear existing timeout
                if (timelineHideTimeout) {
                    clearTimeout(timelineHideTimeout);
                }
                
                // Set new timeout to hide timeline
                timelineHideTimeout = setTimeout(() => {
                    hideTimeline();
                }, TIMELINE_HIDE_DELAY);
            }
            
            function hideTimeline() {
                // Don't hide timeline if a universe is active (user is watching)
                const hasActiveUniverse = leftPanel.classList.contains('active') || rightPanel.classList.contains('active');
                
                if (isTimelineVisible && !hasActiveUniverse) {
                    leftPanel.classList.add('timeline-hidden');
                    rightPanel.classList.add('timeline-hidden');
                    isTimelineVisible = false;
                }
            }
            
            function resetTimelineTimer() {
                showTimeline();
            }
            
            // Preload video function for smoother transitions
            function preloadVideo(videoSrc) {
                if (!preloadedVideos.has(videoSrc)) {
                    const video = document.createElement('video');
                    video.preload = 'metadata';
                    video.src = videoSrc;
                    preloadedVideos.set(videoSrc, video);
                }
            }
            
            // Generate thumbnail from video first frame
            function generateVideoThumbnail(videoSrc) {
                return new Promise((resolve, reject) => {
                    if (videoThumbnails.has(videoSrc)) {
                        resolve(videoThumbnails.get(videoSrc));
                        return;
                    }
                    
                    const video = document.createElement('video');
                    video.muted = true;
                    video.preload = 'metadata';
                    video.currentTime = 0;
                    
                    let seekAttempted = false;
                    
                    video.addEventListener('loadedmetadata', () => {
                        console.log('Video metadata loaded for:', videoSrc);
                        if (!seekAttempted && video.duration > 0) {
                            seekAttempted = true;
                            video.currentTime = Math.min(0.5, video.duration * 0.1); // Get frame from early in video
                        }
                    });
                    
                    video.addEventListener('loadeddata', () => {
                        console.log('Video data loaded for:', videoSrc);
                        if (!seekAttempted && video.duration > 0) {
                            seekAttempted = true;
                            video.currentTime = Math.min(0.5, video.duration * 0.1);
                        }
                    });
                    
                    video.addEventListener('canplay', () => {
                        console.log('Video can play:', videoSrc);
                        if (!seekAttempted && video.duration > 0) {
                            seekAttempted = true;
                            video.currentTime = Math.min(0.5, video.duration * 0.1);
                        }
                    });
                    
                    video.addEventListener('seeked', () => {
                        try {
                            const canvas = document.createElement('canvas');
                            const ctx = canvas.getContext('2d');
                            
                            // Set canvas size to match video dimensions
                            canvas.width = video.videoWidth || 320;
                            canvas.height = video.videoHeight || 180;
                            
                            // Draw the video frame to canvas
                            ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
                            
                            // Convert to data URL
                            const thumbnailDataUrl = canvas.toDataURL('image/jpeg', 0.8);
                            
                            videoThumbnails.set(videoSrc, thumbnailDataUrl);
                            console.log('Generated thumbnail for:', videoSrc);
                            resolve(thumbnailDataUrl);
                        } catch (error) {
                            console.error('Error generating thumbnail:', error);
                            reject(error);
                        }
                    });
                    
                    video.addEventListener('error', (e) => {
                        console.error('Video loading error for thumbnail:', e);
                        reject(e);
                    });
                    
                    // Set the video source last
                    video.src = videoSrc;
                });
            }
            
            // Create timeline segments for a universe
            function createTimelineSegments(universe, container) {
                container.innerHTML = '';
                universeData[universe].videos.forEach((video, index) => {
                    const segment = document.createElement('div');
                    segment.className = 'timeline-segment';
                    if (index === 0) segment.classList.add('active');
                    segment.dataset.index = index;
                    segment.innerHTML = `<div class="segment-label">${index + 1}</div>`;
                    
                    // Set a default background while loading
                    segment.style.background = 'rgba(255, 215, 0, 0.1)';
                    
                    // Generate and set thumbnail background
                    generateVideoThumbnail(video)
                        .then(thumbnailUrl => {
                            segment.style.backgroundImage = `url("${thumbnailUrl}")`;
                            console.log('Set thumbnail for segment', index + 1, 'in universe', universe);
                        })
                        .catch(error => {
                            console.error('Failed to generate thumbnail for segment', index + 1, ':', error);
                            // Keep the default background if thumbnail fails
                            segment.style.background = 'rgba(255, 215, 0, 0.15)';
                        });
                    
                    segment.addEventListener('click', () => {
                        if (universe === 'path1') {
                            playLeftSegment(index);
                        } else {
                            playRightSegment(index);
                        }
                    });
                    
                    container.appendChild(segment);
                });
            }
            
            // Play specific segment for left universe
            function playLeftSegment(index) {
                leftCurrentSegment = index;
                const videoSrc = universeData.path1.videos[index];
                
                // Clear autoplay
                if (leftAutoplayInterval) {
                    clearTimeout(leftAutoplayInterval);
                }
                
                // Update video source and play immediately
                leftVideo.src = videoSrc;
                leftVideo.currentTime = 0;
                leftVideo.load(); // Force reload for faster switching
                
                // Play as soon as ready for smoother transition
                const playWhenReady = () => {
                    leftVideo.play().catch(error => {
                        console.log('Left video play prevented:', error);
                    });
                };
                
                if (leftVideo.readyState >= 2) {
                    playWhenReady();
                } else {
                    leftVideo.addEventListener('canplay', playWhenReady, { once: true });
                }
                
                // Preload next video for smoother transition
                const nextIndex = (index + 1) % universeData.path1.videos.length;
                preloadVideo(universeData.path1.videos[nextIndex]);
                
                // Update active segment
                leftTimeline.querySelectorAll('.timeline-segment').forEach(seg => {
                    seg.classList.remove('active');
                });
                const activeSegment = leftTimeline.querySelector(`.timeline-segment[data-index="${index}"]`);
                if (activeSegment) {
                    activeSegment.classList.add('active');
                }
            }
            
            // Play specific segment for right universe
            function playRightSegment(index) {
                rightCurrentSegment = index;
                const videoSrc = universeData.path2.videos[index];
                
                // Clear autoplay
                if (rightAutoplayInterval) {
                    clearTimeout(rightAutoplayInterval);
                }
                
                // Update video source and play immediately
                rightVideo.src = videoSrc;
                rightVideo.currentTime = 0;
                rightVideo.load(); // Force reload for faster switching
                
                // Play as soon as ready for smoother transition
                const playWhenReady = () => {
                    rightVideo.play().catch(error => {
                        console.log('Right video play prevented:', error);
                    });
                };
                
                if (rightVideo.readyState >= 2) {
                    playWhenReady();
                } else {
                    rightVideo.addEventListener('canplay', playWhenReady, { once: true });
                }
                
                // Preload next video for smoother transition
                const nextIndex = (index + 1) % universeData.path2.videos.length;
                preloadVideo(universeData.path2.videos[nextIndex]);
                
                // Update active segment
                rightTimeline.querySelectorAll('.timeline-segment').forEach(seg => {
                    seg.classList.remove('active');
                });
                const activeSegment = rightTimeline.querySelector(`.timeline-segment[data-index="${index}"]`);
                if (activeSegment) {
                    activeSegment.classList.add('active');
                }
            }
            
            // Switch active universe
            function switchToUniverse(targetUniverse) {
                // Clear all autoplay intervals
                if (leftAutoplayInterval) clearTimeout(leftAutoplayInterval);
                if (rightAutoplayInterval) clearTimeout(rightAutoplayInterval);
                
                const dualDisplay = document.querySelector('.dual-universe-display');
                
                if (targetUniverse === 'left') {
                    // Activate left, deactivate right
                    leftPanel.classList.add('active');
                    rightPanel.classList.remove('active');
                    dualDisplay.classList.add('has-active'); // For fallback CSS
                    
                    // Pause right video, play left video
                    rightVideo.pause();
                    playLeftSegment(leftCurrentSegment);
                    
                } else if (targetUniverse === 'right') {
                    // Activate right, deactivate left
                    rightPanel.classList.add('active');
                    leftPanel.classList.remove('active');
                    dualDisplay.classList.add('has-active'); // For fallback CSS
                    
                    // Pause left video, play right video
                    leftVideo.pause();
                    playRightSegment(rightCurrentSegment);
                }
            }
            
            // Auto-play next segment for left universe
            function autoplayLeftNext() {
                const nextSegment = (leftCurrentSegment + 1) % universeData.path1.videos.length;
                leftAutoplayInterval = setTimeout(() => {
                    playLeftSegment(nextSegment);
                }, 100); // Reduced delay to 100ms for smoother transition
            }
            
            // Auto-play next segment for right universe
            function autoplayRightNext() {
                const nextSegment = (rightCurrentSegment + 1) % universeData.path2.videos.length;
                rightAutoplayInterval = setTimeout(() => {
                    playRightSegment(nextSegment);
                }, 100); // Reduced delay to 100ms for smoother transition
            }
            
            // Event listeners
            leftPanel.addEventListener('click', () => {
                switchToUniverse('left');
            });
            
            rightPanel.addEventListener('click', () => {
                switchToUniverse('right');
            });
            
            // Video interaction event listeners - ensure universe activation when video is played/clicked
            leftVideo.addEventListener('play', () => {
                if (!leftPanel.classList.contains('active')) {
                    switchToUniverse('left');
                }
            });
            
            rightVideo.addEventListener('play', () => {
                if (!rightPanel.classList.contains('active')) {
                    switchToUniverse('right');
                }
            });
            
            leftVideo.addEventListener('click', () => {
                switchToUniverse('left');
            });
            
            rightVideo.addEventListener('click', () => {
                switchToUniverse('right');
            });
            
            // Video ended events
            leftVideo.addEventListener('ended', () => {
                if (leftPanel.classList.contains('active')) {
                    autoplayLeftNext();
                }
            });
            
            rightVideo.addEventListener('ended', () => {
                if (rightPanel.classList.contains('active')) {
                    autoplayRightNext();
                }
            });
            
            // Error handling
            leftVideo.addEventListener('error', (e) => {
                console.error('Left video loading error:', e);
            });
            
            rightVideo.addEventListener('error', (e) => {
                console.error('Right video loading error:', e);
            });
            
            // Initialize
            createTimelineSegments('path1', leftTimeline);
            createTimelineSegments('path2', rightTimeline);
            
            // Keep timeline visible when hovering over it
            [leftTimeline, rightTimeline].forEach(timeline => {
                timeline.addEventListener('mouseenter', () => {
                    if (timelineHideTimeout) {
                        clearTimeout(timelineHideTimeout);
                    }
                    showTimeline();
                });
                
                timeline.addEventListener('mouseleave', () => {
                    resetTimelineTimer();
                });
            });
            
            // Optimize video elements for smoother playback
            [leftVideo, rightVideo].forEach(video => {
                video.preload = 'metadata';
                video.setAttribute('playsinline', '');
                video.muted = true; // Ensure autoplay works
            });
            
            // Preload first few videos of each universe for immediate playback
            universeData.path1.videos.slice(0, 3).forEach(preloadVideo);
            universeData.path2.videos.slice(0, 3).forEach(preloadVideo);
            
            // Mouse movement detection for timeline auto-hide
            document.addEventListener('mousemove', resetTimelineTimer);
            document.addEventListener('mouseenter', resetTimelineTimer);
            document.addEventListener('click', resetTimelineTimer);
            document.addEventListener('keydown', resetTimelineTimer);
            
            // Start timeline auto-hide timer
            showTimeline();
            
            // Both universes start neutral - user must click to select
        });

        // Auto-play videos when first scrolled into view
document.addEventListener('DOMContentLoaded', function() {
    const batmanVideo = document.getElementById('batmanVideoPlayer');
    const comparisonVideoElement = document.getElementById('comparisonVideoPlayer');
    const editDemoVideo = document.getElementById('editDemoVideo');
    const robustVideo = document.getElementById('robustVideoPlayer');
    
    // Track which videos have been auto-played
    const autoPlayedVideos = new Set();
    
    // Track user interaction for enabling sound
    let userHasInteracted = false;
    const enableSoundOnInteraction = () => {
        if (!userHasInteracted) {
            userHasInteracted = true;
            console.log('User interaction detected - enabling sound');
            
            // Unmute batman video if it's currently playing and muted
            if (batmanVideo && !batmanVideo.paused && batmanVideo.muted) {
                batmanVideo.muted = false;
                console.log('Batman video unmuted after user interaction');
            }
            
            // Remove sound toggle button if it exists
            const soundToggle = document.querySelector('.sound-toggle-btn');
            if (soundToggle) {
                soundToggle.remove();
            }
            
            // Enable sound for all videos
            const allVideos = document.querySelectorAll('video');
            allVideos.forEach(v => {
                if (v.muted) {
                    v.muted = false;
                    console.log('Sound enabled for video via interaction:', v.id);
                }
            });
        }
    };
    
    // Listen for various user interactions - be more aggressive about enabling sound
    ['click', 'scroll', 'keydown', 'touchstart', 'mousedown', 'touchend', 'wheel'].forEach(eventType => {
        document.addEventListener(eventType, enableSoundOnInteraction, { once: true });
    });
    
    // Also try to enable sound immediately if possible
    setTimeout(() => {
        if (batmanVideo && batmanVideo.muted && !batmanVideo.paused) {
            // Try to unmute after a short delay
            batmanVideo.muted = false;
            batmanVideo.play().catch(() => {
                // If it fails, go back to muted
                batmanVideo.muted = true;
                console.log('Browser blocked sound autoplay - user interaction required');
            });
        }
    }, 1000);
    
    // Global function to show sound toggle button
    window.showSoundToggle = function() {
        if (!document.querySelector('.sound-toggle-btn') && !userHasInteracted) {
            const soundToggle = document.createElement('div');
            soundToggle.className = 'sound-toggle-btn';
            soundToggle.innerHTML = `
                <div style="display: flex; align-items: center; gap: 8px;">
                    <span style="font-size: 18px;">🔇</span>
                    <span>Click to Enable Sound</span>
                </div>
            `;
            soundToggle.style.cssText = `
                position: fixed;
                bottom: 20px;
                right: 20px;
                background: #ff6b6b;
                color: white;
                padding: 12px 20px;
                border-radius: 25px;
                font-size: 14px;
                font-weight: bold;
                cursor: pointer;
                z-index: 10000;
                box-shadow: 0 4px 12px rgba(0,0,0,0.3);
                transition: all 0.3s ease;
                animation: pulse 2s infinite;
            `;
            
            // Add CSS animation if not already added
            if (!document.querySelector('#sound-toggle-style')) {
                const style = document.createElement('style');
                style.id = 'sound-toggle-style';
                style.textContent = `
                    @keyframes pulse {
                        0% { transform: scale(1); }
                        50% { transform: scale(1.05); }
                        100% { transform: scale(1); }
                    }
                    .sound-toggle-btn:hover {
                        background: #ff5252 !important;
                        transform: scale(1.05);
                    }
                `;
                document.head.appendChild(style);
            }
            
            document.body.appendChild(soundToggle);
            
            // Make the sound toggle button functional
            const enableSound = () => {
                // Enable sound for all videos
                const allVideos = document.querySelectorAll('video');
                allVideos.forEach(v => {
                    if (v.muted) {
                        v.muted = false;
                        console.log('Sound enabled for video:', v.id);
                    }
                });
                
                // Remove the toggle button
                soundToggle.remove();
                
                // Update the global interaction flag
                userHasInteracted = true;
                
                console.log('Sound enabled for all videos');
            };
            
            soundToggle.addEventListener('click', enableSound);
        }
    };
            
                // Auto-play observer options
    const autoPlayObserverOptions = {
        root: null,
        rootMargin: '0px',
        threshold: 0.3 // Trigger when 30% of the video is visible (lowered for better UX)
    };
            
            // Auto-play observer callback
            const autoPlayObserver = new IntersectionObserver((entries) => {
                entries.forEach(entry => {
                    if (entry.isIntersecting) {
                        const video = entry.target;
                        const videoId = video.id || video.src || 'unknown';
                        
                        // Only auto-play if this video hasn't been auto-played before
                        if (!autoPlayedVideos.has(videoId)) {
                            console.log('Auto-playing video:', videoId);
                            autoPlayedVideos.add(videoId);
                            
                            // Special handling for batman video - always try with sound first
                            if (videoId === 'batmanVideoPlayer') {
                                video.muted = false; // Always try with sound first
                                video.currentTime = 0;
                                
                                // Attempt to autoplay with sound
                                video.play().then(() => {
                                    console.log('Batman video autoplay with sound successful');
                                }).catch(error => {
                                    console.log('Autoplay with sound blocked, trying muted:', error);
                                    // If autoplay with sound fails, try muted autoplay
                                    video.muted = true;
                                    video.play().then(() => {
                                        console.log('Batman video autoplay muted successful');
                                        // Show the sound toggle button
                                        window.showSoundToggle();
                                        
                                        // Also enable sound on video click
                                        const videoClickHandler = () => {
                                            // Enable sound for all videos
                                            const allVideos = document.querySelectorAll('video');
                                            allVideos.forEach(v => {
                                                if (v.muted) {
                                                    v.muted = false;
                                                    console.log('Sound enabled for video:', v.id);
                                                }
                                            });
                                            
                                            // Remove the toggle button
                                            const soundToggle = document.querySelector('.sound-toggle-btn');
                                            if (soundToggle) {
                                                soundToggle.remove();
                                            }
                                            
                                            // Update the global interaction flag
                                            userHasInteracted = true;
                                            
                                            console.log('Sound enabled via video click');
                                        };
                                        video.addEventListener('click', videoClickHandler, { once: true });
                                    }).catch(muteError => {
                                        console.log('All autoplay prevented for batman video:', muteError);
                                    });
                                });
                            } else {
                                // For other videos, try with sound first, then fallback to muted
                                video.muted = false;
                                video.currentTime = 0;
                                
                                // Attempt to play the video with sound
                                video.play().then(() => {
                                    console.log('Video autoplay with sound successful:', videoId);
                                }).catch(error => {
                                    console.log('Autoplay with sound blocked for', videoId, 'trying muted:', error);
                                    // If autoplay with sound fails, try muted autoplay
                                    video.muted = true;
                                    video.play().then(() => {
                                        console.log('Video autoplay muted successful:', videoId);
                                        // Show the sound toggle button
                                        window.showSoundToggle();
                                    }).catch(muteError => {
                                        console.log('All autoplay prevented for video:', videoId, muteError);
                                    });
                                });
                            }
                        }
                    }
                });
            }, autoPlayObserverOptions);
            
            // Observe the batman video
            if (batmanVideo) {
                autoPlayObserver.observe(batmanVideo);
                console.log('Set up auto-play observer for batman video');
            }
            
            // Observe the comparison video
            if (comparisonVideoElement) {
                autoPlayObserver.observe(comparisonVideoElement);
                console.log('Set up auto-play observer for comparison video');
            }
            
            // Observe the edit demo video
            if (editDemoVideo) {
                autoPlayObserver.observe(editDemoVideo);
                console.log('Set up auto-play observer for edit demo video');
            }
            
            // Observe the robust video
            if (robustVideo) {
                autoPlayObserver.observe(robustVideo);
                console.log('Set up auto-play observer for robust video');
            }
        });

        // Comparison Video Timeline Functionality
        document.addEventListener('DOMContentLoaded', function() {
            const comparisonVideo = document.getElementById('comparisonVideoPlayer');
            const comparisonTimeline = document.getElementById('comparison-timeline-segments');
            
            if (!comparisonVideo || !comparisonTimeline) return;
            
            // Create 8 timeline segments (every 8 seconds for 64-second video)
            const segmentCount = 8;
            const segmentDuration = 8.1; // seconds
            
            function createComparisonTimelineSegments() {
                comparisonTimeline.innerHTML = '';
                
                for (let i = 0; i < segmentCount; i++) {
                    const segment = document.createElement('div');
                    segment.className = 'timeline-segment';
                    if (i === 0) segment.classList.add('active');
                    segment.dataset.index = i;
                    segment.dataset.time = i * segmentDuration;
                    
                    // Create segment label
                    const label = document.createElement('div');
                    label.className = 'segment-label';
                    label.textContent = (i + 1).toString();
                    segment.appendChild(label);
                    
                    // Add click handler
                    segment.addEventListener('click', () => {
                        const targetTime = i * segmentDuration;
                        comparisonVideo.currentTime = targetTime;
                        
                        // Update active segment
                        comparisonTimeline.querySelectorAll('.timeline-segment').forEach(seg => {
                            seg.classList.remove('active');
                        });
                        segment.classList.add('active');
                    });
                    
                    comparisonTimeline.appendChild(segment);
                }
            }
            
            // Update active segment based on current time
            function updateComparisonActiveSegment(currentTime) {
                const currentSegment = Math.floor(currentTime / segmentDuration);
                
                comparisonTimeline.querySelectorAll('.timeline-segment').forEach((seg, index) => {
                    seg.classList.remove('active');
                    if (index === currentSegment) {
                        seg.classList.add('active');
                    }
                });
            }
            
            // Video time update handler
            comparisonVideo.addEventListener('timeupdate', function() {
                const currentTime = comparisonVideo.currentTime;
                updateComparisonActiveSegment(currentTime);
            });
            
            // Initialize timeline segments
            createComparisonTimelineSegments();
            
            console.log('Comparison video timeline initialized with', segmentCount, 'segments');
        });

        // Universe selection reset on scroll away functionality
        document.addEventListener('DOMContentLoaded', function() {
            const parallelUniverseSection = document.getElementById('parallel-universe');
            const leftPanel = document.getElementById('universe-left');
            const rightPanel = document.getElementById('universe-right');
            const leftVideo = document.getElementById('universe-left-video');
            const rightVideo = document.getElementById('universe-right-video');
            const dualDisplay = document.querySelector('.dual-universe-display');
            
            let hasBeenViewed = false;
            let wasActiveBeforeLeaving = false;
            
            // Function to reset universe selection to neutral state
            function resetUniverseSelection() {
                // Remove active classes from both panels
                leftPanel.classList.remove('active');
                rightPanel.classList.remove('active');
                dualDisplay.classList.remove('has-active');
                
                // Pause both videos
                leftVideo.pause();
                rightVideo.pause();
                
                // Clear any autoplay intervals
                if (typeof leftAutoplayInterval !== 'undefined' && leftAutoplayInterval) {
                    clearTimeout(leftAutoplayInterval);
                    leftAutoplayInterval = null;
                }
                if (typeof rightAutoplayInterval !== 'undefined' && rightAutoplayInterval) {
                    clearTimeout(rightAutoplayInterval);
                    rightAutoplayInterval = null;
                }
                
                // Reset video positions to beginning
                leftVideo.currentTime = 0;
                rightVideo.currentTime = 0;
                
                // Reset timeline segments to first segment
                const leftTimeline = document.getElementById('left-timeline-segments');
                const rightTimeline = document.getElementById('right-timeline-segments');
                
                if (leftTimeline) {
                    leftTimeline.querySelectorAll('.timeline-segment').forEach(seg => {
                        seg.classList.remove('active');
                    });
                    const firstLeftSegment = leftTimeline.querySelector('.timeline-segment[data-index="0"]');
                    if (firstLeftSegment) {
                        firstLeftSegment.classList.add('active');
                    }
                }
                
                if (rightTimeline) {
                    rightTimeline.querySelectorAll('.timeline-segment').forEach(seg => {
                        seg.classList.remove('active');
                    });
                    const firstRightSegment = rightTimeline.querySelector('.timeline-segment[data-index="0"]');
                    if (firstRightSegment) {
                        firstRightSegment.classList.add('active');
                    }
                }
                
                console.log('Universe selection reset to neutral state');
            }
            
            // Intersection Observer to detect when parallel universe section is in/out of viewport
            const observerOptions = {
                root: null,
                rootMargin: '-20px',
                threshold: 0.3 // Trigger when 30% of the section is visible
            };
            
            const universeObserver = new IntersectionObserver((entries) => {
                entries.forEach(entry => {
                    if (entry.isIntersecting) {
                        // Section is coming into view
                        if (hasBeenViewed && wasActiveBeforeLeaving) {
                            // User is returning to the section after having an active selection
                            // Reset to neutral state
                            setTimeout(() => {
                                resetUniverseSelection();
                                wasActiveBeforeLeaving = false;
                            }, 100);
                        }
                        hasBeenViewed = true;
                    } else {
                        // Section is going out of view
                        if (hasBeenViewed) {
                            // Check if any universe was active before leaving
                            wasActiveBeforeLeaving = leftPanel.classList.contains('active') || rightPanel.classList.contains('active');
                        }
                    }
                });
            }, observerOptions);
            
            // Start observing the parallel universe section
            if (parallelUniverseSection) {
                universeObserver.observe(parallelUniverseSection);
            }
        });

        // Initialize AOS animations
        AOS.init({
            duration: 1000,
            easing: 'ease-in-out',
            once: false,
            mirror: false,
            offset: 120,
            delay: 0,
            anchorPlacement: 'top-bottom'
        });
        
        // Refresh AOS on window load to ensure all elements are detected
        window.addEventListener('load', function() {
            AOS.refresh();
        });
        
        // Additional AOS refresh to handle any conflicts with video intersection observers
        setTimeout(function() {
            AOS.refresh();
            console.log('AOS refreshed after timeout');
        }, 1000);
        
        // Refresh AOS when scrolling to ensure animations work properly with other scroll-based interactions
        let aosRefreshTimeout;
        window.addEventListener('scroll', function() {
            clearTimeout(aosRefreshTimeout);
            aosRefreshTimeout = setTimeout(() => {
                AOS.refresh();
            }, 100);
        }, { passive: true });
    </script>

    <!-- Footer -->
    <div class="footer">
        © 2025 Captain Cinema | Anonymous Submission Under Review
    </div>
</body>
</html> 