<!DOCTYPE html>

<html data-wf-page="658acfc5822f338b47edbc52" data-wf-site="658acfc5822f338b47edbc4e"
    class="w-mod-js w-mod-ix wf-opensans-n7-active wf-opensans-n3-active wf-opensans-n8-active wf-opensans-n4-active wf-opensans-n6-active wf-opensans-i3-active wf-opensans-i4-active wf-opensans-i7-active wf-opensans-i6-active wf-opensans-i8-active wf-active">

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <style>
        h1.heading-7 {
            font-size: 2.2em !important; 
            margin: 0.5em 0 !important;
        }
        
        h4.fancy-heading {
            font-size: 1.4em; 
        }

 .paragraph-2 {
    font-size: 1.2rem !important;
    line-height: 1.7;
    color: #444;
    /* text-align: center; */
    margin: 25px 0;
    padding: 15px 20px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-radius: 10px;
    border-left: 4px solid #4facfe;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.paragraph-2 a {
    color: #4facfe;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s ease;
    padding: 2px 4px;
    border-radius: 4px;
}

        .wf-force-outline-none[tabindex="-1"]:focus {
            outline: none;
        }

        @media (max-width: 430px) {
            .carousel {
                height: auto;
            }

            .output-video.active {
                width: 110% !important;
                height: auto !important;
                left: 50% !important;
                transform: translate(-50%, -80%) scale(1) !important;
            }

            .output-video.left,
            .output-video.right {
                transform: translate(-50%, -80%) scale(0.8) !important;
                width: 50% !important;
                height: auto !important;
            }

            .input-container {
                display: flex;
                flex-wrap: wrap;
                /* Allow wrapping into multiple rows */
                justify-content: center;
                /* Center the videos */
                gap: 1rem;
                /* Spacing between videos */
                margin: 1rem 0;
            }

            .input-video {
                width: calc(33.33% - 0.67rem);
                /* Three videos per row on both desktop and mobile */
                height: auto;
                border-radius: 8px;
                box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
                opacity: 0.5;
                transition: opacity 0.5s ease, transform 0.5s ease;
                margin-bottom: 1rem;
                /* Add margin between rows */
            }

            /* Adjust for larger screens */

        }

        @media (max-width: 768px) {

            /* Reduce gap between 'Compose' text and output video in mobile */
            .output-carousel h4 {
                margin: -100rem 0 0rem !important;
            }
        }

        @media (max-width: 768px) {

            /* Adjust dots spacing on mobile */
            .dots-container {
                margin-top: -5.0rem !important;
            }
        }

        @media (max-width: 768px) {
            .video-caption {
                font-size: 0.9rem;
                padding: 3px 8px;
                bottom: 5px;
            }
        }
    </style>


    <title>CoMo</title>
    <meta content="width=device-width, initial-scale=1" name="viewport">
    <meta content="Webflow" name="generator">

    <meta name="description" content="Dynamic Concepts - Snap Research.">

    <meta property="og:type" content="website">
    <meta property="og:site_name" content="Dynamic Concepts - Snap Research">
    <meta property="og:title" content="Dynamic Concepts - Snap Research">
    <meta property="og:description" content="Dynamic Concepts - Snap Research.">

    <meta property="twitter:card" content="summary">
    <meta property="twitter:site" content="SnapResearch">
    <meta property="twitter:title" content="Dynamic Concepts - Snap Research">
    <meta property="twitter:description" content="Dynamic Concepts - Snap Research.">

    <link href="./dynamic_files/normalize.css" rel="stylesheet" type="text/css">
    <link href="./dynamic_files/webflow.css" rel="stylesheet" type="text/css">
    <link href="./dynamic_files/style.css" rel="stylesheet" type="text/css">
    <link href="https://fonts.googleapis.com/" rel="preconnect">
    <link href="https://fonts.gstatic.com/" rel="preconnect" crossorigin="anonymous">
    <script src="./dynamic_files/webfont.js" type="text/javascript"></script>
    <link rel="stylesheet" href="./dynamic_files/css" media="all">
    <script
        type="text/javascript">WebFont.load({ google: { families: ["Open Sans:300,300italic,400,400italic,600,600italic,700,700italic,800,800italic"] } });</script>
    <link href="test/icon.png" rel="shortcut icon" type="image/x-icon">
    <script
        type="text/javascript">!function (o, c) { var n = c.documentElement, t = " w-mod-"; n.className += t + "js", ("ontouchstart" in o || o.DocumentTouch && c instanceof DocumentTouch) && (n.className += t + "touch") }(window, document);</script>


    <script>
        document.addEventListener("DOMContentLoaded", function () {
            // Use innerWidth directly if needed:
            const isMobile = window.innerWidth <= 1024;
            const targetFolder = isMobile ? "dynamic_files_mobile" : "dynamic_files";
            console.log("isMobile:", isMobile, "targetFolder:", targetFolder);

            document.querySelectorAll("video").forEach(video => {
                const sourceEl = video.querySelector("source");
                if (sourceEl) {
                    let src = sourceEl.getAttribute("src");
                    console.log("Before replacement:", src);
                    // Replace if it starts with 'dynamic_files'
                    if (src && src.indexOf("dynamic_files") === 0) {
                        src = src.replace(/^dynamic_files/, targetFolder);
                        console.log("After replacement:", src);
                        sourceEl.setAttribute("src", src);
                        video.load();
                    }
                }
            });
        });
    </script>




    <style>

        
        .sectionwhite {
            background-color: #ffffff;
            padding: 50px 0;
            margin: 0;
            width: 100%;
        }
        .sectiongrey {
            background-color: #f8f9fa;
            padding: 50px 0;
            margin: 0;
            width: 100%;
            background-image: linear-gradient(to bottom right, #f8f9fa, #e9ecef);
        }

        .text_block_authors {
            margin: 1.0rem auto;
            /* Reduces the vertical space significantly */
            padding: 0.2rem;
            border-radius: 2px;
            text-align: center;
            color: #00bcd4;
            font-weight: 500;
            text-decoration: none;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }

        .text_block_authors:hover {
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
        }

        .hero-heading-left {
            position: relative;
            padding: 30px 20px;
            background: linear-gradient(to right, #2d3748, #1a202c);
            color: #ffffff;
            text-align: center;
            border-radius: 0px;
            box-shadow: 0 0px 0px rgba(0, 0, 0, 0.5);
            margin: 0rem auto;
            overflow: hidden;
        }

        .hero-heading-left .bg-video {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            opacity: 0.2;
            /* Adjust transparency */
            z-index: 0;
            transition: opacity 1s ease-in-out;
            display: block;
        }

        .hero-heading-left h1,
        .hero-heading-left p,
        .hero-heading-left a {
            position: relative;
            z-index: 1;
            /* Ensure content stays above the video */
        }



        .hero-heading-left h1 {
            font-size: 2.5rem;
            font-weight: bold;
            color: linear-gradient(to right, #0555e0, #ffffff);
            margin: 0rem 0;
        }

        .hero-heading-left p {
            font-size: 1.25rem;
            margin: 0rem 0;
            color: #cbd5e0;
        }

        .hero-heading-left .button-primary {
            padding: 0.75rem 1.5rem;
            background: linear-gradient(to right, #2d3748, #1a202c);
            color: #ffffff;
            font-weight: bold;
            border-radius: 6px;
            text-decoration: none;
            transition: background 0.3s ease;
            margin: 2rem auto;
        }

        .hero-heading-left .button-primary:hover {
            background: #0288d1;
        }

        .video-container {
            display: flex;
            justify-content: center;
            margin: 2rem auto;
        }

        .video-container video {
            width: 100%;
            max-width: 500px;
            height: auto;
            border-radius: 8px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
        }


        .video-wrapper {
            max-width: 1000px;
            margin: 0 auto;
        }

        .input-container {
            display: flex;
            justify-content: space-around;
            align-items: center;
            gap: 0.0rem;
            margin: 1rem 0;
        }

        .input-video {
            width: auto;
            height: 150px;
            border-radius: 8px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
            opacity: 0.5;
            transition: opacity 0.5s ease, transform 0.5s ease;
        }

        .input-video.active {
            opacity: 1;
            transform: scale(1.1);
            border: 2px solid #00bcd4;
            box-shadow: 0 0 20px 5px rgba(0, 188, 212, 0.6);
        }

        .input-container {
            display: flex;
            flex-wrap: wrap;
            /* Allow wrapping into multiple rows */
            justify-content: center;
            /* Center the videos */
            gap: 1rem;
            /* Spacing between videos */
            margin: 1rem 0;
        }


        .carousel {
            position: relative;
            width: 100%;
            height: 400px;
            margin: 0 auto;
            perspective: 1200px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .output-video {
            position: absolute;
            top: 50%;
            left: 50%;
            transform-style: preserve-3d;
            transform: translate(-50%, -50%) scale(0.0);
            opacity: 0.5;
            transition: transform 1s ease, opacity 1s ease;
            width: auto;
            height: 60%;
            border-radius: 8px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
        }

        .output-video.active {
            transform: translate(-50%, -50%) scale(1);
            opacity: 1;
            z-index: 2;
        }

        /* Left and Right videos: Cropped to always fit properly */
        .output-video.left,
        .output-video.right {
            width: 512px;
            /* Half of the original width */
            height: 512px;
            /* Keep same height */
            object-fit: cover;
            /* Ensures cropping instead of shrinking */
        }

        .output-video.left {
            transform: translate(-140%, -50%) scale(0.6);
        }

        .output-video.right {
            transform: translate(40%, -50%) scale(0.6);
        }


        .dots-container {
            display: flex;
            justify-content: center;
            gap: 0.5rem;
            margin-top: 1rem;
        }

        .dot {
            width: 12px;
            height: 12px;
            border-radius: 50%;
            background-color: #cbd5e0;
            cursor: pointer;
            transition: background-color 0.3s ease, transform 0.3s ease;
        }

        .dot.active {
            background-color: #00bcd4;
            transform: scale(1.2);
        }

        .output-video {
            width: 50%;
            /* Increase this value for larger output videos */
            height: auto;
        }

        .output-video.active {
            transform: translate(-50%, -50%) scale(1.2);
            /* Increase scale value for larger center video */
        }

        .output-video-container {
            display: flex;
            justify-content: center;
            /* Center the videos within the container */
            gap: 1rem;
            /* Add spacing between the videos */
        }

        .output-video {
            width: 50%;
            /* Adjust width to fit within the container */
            height: auto;
            border-radius: 8px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
            transition: transform 1s ease, opacity 1s ease;
        }

        .background-section {
            position: relative;
            width: 100%;
            height: 300px;
            /* Adjust height as needed */
            overflow: hidden;
        }

        .background-section video {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            opacity: 0.3;
            /* Adjust for blending effect */
            z-index: -1;
        }

        @keyframes captionPulse {
            0% {
                transform: translateX(-50%) translateY(-100%) scale(1);
            }

            50% {
                transform: translateX(-50%) translateY(-100%) scale(1.05);
            }

            100% {
                transform: translateX(-50%) translateY(-100%) scale(1);
            }
        }



        @keyframes gradientChange {
            0% {
                background: linear-gradient(135deg, rgba(0, 100, 200, 0.7), rgba(0, 200, 100, 0.4));
            }

            50% {
                background: linear-gradient(135deg, rgba(0, 100, 200, 0.7), rgba(0, 200, 100, 0.4));
            }

            100% {
                background: linear-gradient(135deg, rgba(0, 100, 200, 0.7), rgba(0, 200, 100, 0.4));
            }

        }

        .video-caption {
            position: absolute;
            bottom: 355px;
            /* Keeps caption at the top */
            left: 50%;
            transform: translateX(-50%) translateY(-100%);
            color: #fff;
            /* The background will now be animated */
            padding: 5px 12px;
            border-radius: 8px;
            pointer-events: none;
            z-index: 2;
            font-family: "Poppins", Arial, Helvetica, sans-serif;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 80%;
            font-size: 1.3em;
            text-align: center;
            font-weight: 600;
            letter-spacing: 0.8px;
            box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.3);
            transition: all 0.3s ease-in-out;
            opacity: 0.9;
            animation: captionPulse 3s ease-in-out infinite, gradientChange 5s linear infinite;
        }



        /* Hover effect for subtle interactivity */
        .video-caption:hover {
            transform: translateX(-50%) translateY(-110%) scale(1.05);
            opacity: 1;
            background: linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.6));
            box-shadow: 0px 6px 18px rgba(0, 0, 0, 0.4);
        }




        /* Position each caption horizontally */
        .caption1 {
            left: 30%;
            /* Left side */
            transform: translateX(-50%) translateY(-100%);
        }

        .caption2 {
            left: 50%;
            /* Center */
            transform: translateX(-50%) translateY(-100%);
        }

        .caption3 {
            left: 70%;
            /* Right side */
            transform: translateX(-50%) translateY(-100%);
        }

        /* Hide all captions by default */
        .output-video:not(.active)~.video-caption {
            display: none;
        }

        /* Show all captions when the video is active */
        .output-video.active~.video-caption {
            display: block;
        }


        /* Hide all captions by default */
        .video-item .video-caption {
            display: none;
        }

        /* Show only captions of the active video */
        .video-item:has(.output-video.active) .video-caption {
            display: block;
        }



        /* Mobile-Specific Fix */
        @media (max-width: 600px) {
            .video-caption {
                bottom: 370px;
                /* Adjust position for mobile */
                font-size: 1em;
                /* Slightly smaller font */
                padding: 4px 10px;
                /* Adjusted padding */
                letter-spacing: 0.5px;
            }

            /* Adjust horizontal positions for mobile */
            .caption1 {
                left: 20%;
                transform: translateX(-50%) translateY(-120%);
            }

            .caption2 {
                left: 50%;
                transform: translateX(-50%) translateY(-120%);
            }

            .caption3 {
                left: 80%;
                transform: translateX(-50%) translateY(-120%);
            }
        }




        .fancy-heading {
            text-align: center;
            color: #222;
            /* Darker shade for elegance */
            margin-bottom: 2rem;
            font-size: 1.4em;
            /* Slightly larger */
            font-weight: 700;
            /* Bold for emphasis */
            letter-spacing: 1px;
            /* Refined letter spacing */
            text-transform: uppercase;
            /* Striking effect */
            font-family: "Poppins", Arial, sans-serif;
            /* Modern font */
            background: linear-gradient(135deg, #222, #555);
            /* Subtle gradient */
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            /* Gradient text effect */
            position: relative;
            display: flex;
            /* Ensures it stays centered */
            justify-content: center;
            align-items: center;
            width: 100%;
            /* Ensures full-width alignment */
            padding-bottom: 5px;
        }

        /* Underline effect */
        .fancy-heading::after {
            content: "";
            position: absolute;
            left: 50%;
            bottom: -5px;
            width: 60%;
            height: 3px;
            background: linear-gradient(135deg, rgba(0, 100, 200, 0.7), rgba(0, 200, 100, 0.4));
            /* Warm gradient underline */
            transform: translateX(-50%);
            border-radius: 3px;
        }

        /* Hover effect */
        .fancy-heading:hover {
            background: linear-gradient(135deg, rgba(0, 100, 200, 0.7), rgba(0, 200, 100, 0.4));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            transform: scale(1.05);
            transition: all 0.3s ease-in-out;
        }

        /* Mobile adjustments */
        @media (max-width: 600px) {
            .fancy-heading {
                font-size: 1.2em;
                /* Slightly smaller on mobile */
                letter-spacing: 0.8px;
            }

            .fancy-heading::after {
                width: 50%;
                height: 2px;
            }
        }

        @media (min-width: 768px) {
            .input-video {
                width: auto;
                height: 100px;
                border-radius: 8px;
                box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
                opacity: 0.5;
                transition: opacity 0.5s ease, transform 0.5s ease;
            }
        }

        @media (max-width: 430px) {
            .input-video {
                width: auto;
                height: 100px;
                border-radius: 8px;
                box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
                opacity: 0.5;
                transition: opacity 0.5s ease, transform 0.5s ease;
            }
        }


        .video-section2 {
            display: flex;
            gap: 50px;
        }

        .video-item2 {
            text-align: center;
            position: relative;
        }

        .video-card2 {
            position: relative;
            width: 1500px;
            /* Fixed width on large screens */
            height: 512px;
            /* Fixed height on large screens */
            border-radius: 20px;
            overflow: hidden;
            box-shadow: 0px 8px 20px rgba(2, 196, 250, 0.2);
            transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            background-color: black;
            /* Black padding if needed */
        }

        .video-card2 img {
            max-width: 150%;
            max-height: 150%;
            width: auto;
            height: auto;
            object-fit: contain;
            /* Fits without cutting anything */
            display: block;
        }

        /* Retained original hover effect */
        .video-card2:hover {
            box-shadow: 0px 12px 30px rgba(8, 191, 237, 0.8);
            /* Enhanced blue glow */
        }


        /* Enhanced play button with your original blue theme */
        .play-button2 {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 70px;
            height: 70px;
            background: rgba(8, 191, 237, 0.9);
            /* Your blue color */
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s ease;
            box-shadow: 0 4px 15px rgba(0, 187, 255, 0.3);
        }

        .play-button2::after {
            content: '';
            width: 0;
            height: 0;
            border-style: solid;
            border-width: 15px 0 15px 25px;
            border-color: transparent transparent transparent #fff;
            margin-left: 5px;
        }

        /* Hover effects for play button */
        .video-card2:hover .play-button2 {
            background: rgba(8, 191, 237, 1);
            transform: translate(-50%, -50%) scale(1.1);
            box-shadow: 0 6px 20px rgba(0, 187, 255, 0.5);
        }


        .video-caption2 {
            margin-top: 15px;
            font-size: 1.3em;
            font-weight: bold;
            text-align: center;
            /* Ensures text is centered */
            color: white;
            text-transform: uppercase;
            letter-spacing: 1px;
            background: linear-gradient(135deg, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.4));
            padding: 10px 20px;
            border-radius: 10px;
            display: flex;
            justify-content: center;
            /* Centers text horizontally */
            align-items: center;
            /* Centers text vertically */
            width: fit-content;
            /* Fits text width without excess space */
            max-width: 100%;
            box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.3);
            transition: transform 0.3s ease-in-out;
            margin-left: auto;
            margin-right: auto;
            /* ✅ Ensures full centering */
        }




        @media (max-width: 1024px) {
            .video-card2 {
                width: 100vw !important;
                /* fill viewport width */
                height: auto !important;
                /* let height be determined by aspect ratio */
                position: relative;
                /* required for absolutely positioned children */
                padding-top: calc((512 / 700) * 100vw) !important;
                /* reserve space to preserve aspect ratio */
                margin: 0 auto;
            }

            /* Make sure the video/image fills the container without cropping */
            .video-card2>img,
            .video-card2>video,
            .video-card2 iframe {
                position: absolute;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                object-fit: contain;
                /* or 'cover' if you prefer */
            }

            .play-button2 {
                width: 50px;
                height: 50px;
            }

            .play-button2::after {
                border-width: 10px 0 10px 17px;
            }

            .video-caption2 {
                font-size: 1.1em;
                padding: 6px 12px;
                width: 100%;
                margin: 0;
                /* Ensure no extra margin causing gap */
            }
        }


        /* Retained your original fade overlay */
        .fade-overlay2 {
            position: absolute;
            bottom: 0;
            width: 100%;
            height: 50px;
            background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, black 100%);
            border-bottom-left-radius: 20px;
            border-bottom-right-radius: 20px;
        }

        /* Retained title styling */
        .video-title2 {
            font-size: 1.2em;
            font-weight: 600;
            margin-top: 10px;
            letter-spacing: 0.8px;
            text-transform: uppercase;
        }


        /* Section container styling */
        .section-box {
            background-color: #ffffff;
            /* Dark background for contrast */
            border-radius: 20px;
            /* Matches your video card style */
            padding: 30px;
            margin: 40px auto;
            max-width: 1400px ;
            /* Adjust based on your layout */
            box-shadow: 0 8px 30px rgba(48, 48, 48, 0.4);
            /* Blue shadow to match your theme */
            transition: box-shadow 0.3s ease-in-out;
        }

        /* Hover effect for section boxes */
        .section-box:hover {
            box-shadow: 0 12px 40px rgba(48, 48, 48, 0.4);
            /* Enhanced glow on hover */
        }


        /* ✅ Main container for logo + text */
        .snap-container {
            display: flex;
            /* Aligns image and text side by side */
            align-items: center;
            /* Ensures vertical alignment */
            gap: 8px;
            /* Adds space between the logo and text */
            padding-top: 30px;
            justify-content: center;
            /* Centers everything */
        }

        /* ✅ Snap Logo Styling */
        .snap-logo {
            height: 30px;
            width: auto;
            object-fit: contain;
            /* Ensures the image maintains proportions */
        }

        /* ✅ Snap Research Text Styling */
        .snap-text {
            color: #eddcdc;
            font-size: 1.2em;
            font-weight: bold;
            background: transparent;
            box-shadow: none;
        }

        /* ✅ Mobile Fix */
        @media (max-width: 600px) {
            .snap-container {
                flex-direction: column;
                /* Stacks logo and text in mobile */
                gap: 5px;
            }

            .snap-logo {
                height: 30px;
                /* Slightly smaller for mobile */
            }

            .snap-text {
                font-size: 1em;
                /* Adjusts text size for better readability */
            }
        }


        .play-me-btn {
            position: relative;
            display: block;
            margin: 0px auto;
            padding: 10px 20px;
            font-size: 1.5em;
            color: white;
            background: #0288d1;
            /* Solid background color */
            border: none;
            border-radius: 50px;
            text-decoration: none;
            cursor: pointer;
            overflow: hidden;
            /* Ensures pseudo-element stays within border */
        }

        /* Pseudo-element creates an animated border strip */

        .play-me-btn::before {
            content: "";
            position: absolute;
            top: -3px;
            left: -3px;
            right: -3px;
            bottom: -3px;
            border-radius: inherit;
            background: linear-gradient(45deg, rgb(0, 200, 255), rgb(164, 164, 164), rgb(0, 200, 255));
            background-size: 400%;
            z-index: -1;
            animation: borderAnimation 6s linear infinite;
        }

        /* Keyframes for the border animation */
        @keyframes borderAnimation {
            0% {
                background-position: 0% 50%;
            }

            100% {
                background-position: 400% 50%;
            }
        }

        /* Modal overlay with blurred background */


        .modal {
            display: none;
            /* Hidden by default */
            position: fixed;
            z-index: 1000;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.8);
            backdrop-filter: blur(5px);
            justify-content: center;
            align-items: center;
        }

        .modal-content {
            position: relative;
            width: 100%;
            max-width: 1200px;
        }

        .modal video {
            width: 100%;
            height: auto;
            display: block;
        }

        .close {
            position: absolute;
            top: -20px;
            right: -20px;
            background: #fff;
            border-radius: 50%;
            padding: 5px 10px;
            cursor: pointer;
            font-size: 1.5em;
            font-weight: bold;
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
        }

        /* Prevent page scrolling when modal is open */
        body.modal-open {
            overflow: hidden;
        }


        .gradient-text2 {
            font-weight: bold;
            background: linear-gradient(90deg, rgba(0, 51, 102, 1), rgba(0, 153, 255, 1));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }


        .gradient-text {
            font-weight: bold;
            background: linear-gradient(90deg, rgba(0, 153, 255, 1), rgba(0, 51, 102, 1));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .gradient-text3 {
            font-weight: bold;
            background: linear-gradient(90deg, rgba(80, 80, 80, 1), rgba(0, 153, 255, 1), rgba(0, 153, 255, 1), rgb(17, 16, 16));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }


        .gradient-text4 {
            font-weight: bold;
            background: linear-gradient(90deg, rgb(0, 0, 0), rgb(0, 0, 0));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }



        section {
            opacity: 0;
            transform: translateY(50px);
            transition: opacity 0.6s ease-out, transform 0.6s ease-out;
        }

        /* Revealed state: section becomes fully visible and slides into place */
        section.revealed {
            opacity: 1;
            transform: translateY(0);
        }



        .gesture-instructions {
            text-align: center;
            margin: 20px 0;
        }

        /* Fancy Instructional Text */
        .instruction-text {
            font-size: 1em;
            font-weight: 700;
            letter-spacing: 0.05em;
            background: linear-gradient(to right, #000, #333);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
            margin-top: 15px;
        }

        .gesture-demo {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 30px;
            flex-wrap: wrap;
        }

        /* Desktop Demo Styles */
        .desktop-demo .monitor {
            width: 200px;
            height: 140px;
            background: #444;
            border: 4px solid #333;
            border-radius: 6px;
            margin: 0 auto;
            position: relative;
        }

        .desktop-demo .screen {
            width: 100%;
            height: 100%;
            background: #fff;
            border-radius: 4px;
            position: relative;
            overflow: hidden;
        }

        /* Ripple Effect: a big circle at the top of dots */
        .desktop-demo .ripple-effect {
            position: absolute;
            bottom: 30px;
            /* slightly above the dots */
            left: 50%;
            transform: translateX(-50%);
            width: 40px;
            height: 40px;
            border: 2px solid #00cbf9;
            border-radius: 50%;
            opacity: 0;
            animation: rippleClick 1.5s infinite;
        }

        @keyframes rippleClick {
            0% {
                transform: translateX(-50%) scale(0.5);
                opacity: 0.8;
            }

            50% {
                transform: translateX(-50%) scale(1.5);
                opacity: 0;
            }

            100% {
                transform: translateX(-50%) scale(1.5);
                opacity: 0;
            }
        }

        .desktop-demo .nav-dots {
            position: absolute;
            bottom: 8px;
            left: 50%;
            transform: translateX(-50%);
            display: flex;
            gap: 6px;
        }

        .desktop-demo .dot {
            position: relative;
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: radial-gradient(circle, #00cbf9, #00cbf9);
            animation: dotPulse 1.5s infinite ease-in-out;
        }

        .desktop-demo .dot:nth-child(1) {
            animation-delay: 0s;
        }

        .desktop-demo .dot:nth-child(2) {
            animation-delay: 0.3s;
        }

        .desktop-demo .dot:nth-child(3) {
            animation-delay: 0.6s;
        }

        @keyframes dotPulse {

            0%,
            100% {
                transform: scale(1);
                opacity: 0.8;
            }

            50% {
                transform: scale(1.3);
                opacity: 1;
            }
        }

        .desktop-demo .stand {
            width: 40%;
            height: 8px;
            background: #444;
            margin: 6px auto 0;
            border-radius: 2px;
        }

        /* Mobile Demo Styles - Fancy Phone */
        .mobile-demo .phone {
            width: 80px;
            height: 160px;
            position: relative;
            margin: 0 auto;
            border-radius: 20px;
            background: linear-gradient(135deg, #fdfdfd, #eaeaea);
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
            overflow: hidden;
            border: 2px solid #000;
        }

        .mobile-demo .phone-notch {
            position: absolute;
            top: 5px;
            left: 50%;
            transform: translateX(-50%);
            width: 30px;
            height: 4px;
            background: #333;
            border-radius: 2px;
            z-index: 2;
        }

        .mobile-demo .phone-screen {
            width: 100%;
            height: 100%;
            background: linear-gradient(135deg, #f9f9f9, #ffffff);
            border-radius: 15px;
            position: relative;
            overflow: hidden;
            box-shadow: inset 0 0 8px rgba(0, 0, 0, 0.2);
        }

        .mobile-demo .swipe-trail {
            font-size: 2em;
            position: absolute;
            top: 50%;
            left: 10%;
            transform: translateY(-50%);
            animation: swipeTrail 2s infinite;
            color: #00cbf9;
            text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
        }

        @keyframes swipeTrail {
            0% {
                left: 10%;
                opacity: 1;
            }

            50% {
                left: 50%;
                opacity: 1;
            }

            100% {
                left: 10%;
                opacity: 1;
            }
        }

        @media (max-width: 430px) {
            .gesture-demo {
                transform: scale(0.5);
            }
        }

        /* Ensure the video scales up on mobile devices */
        @media (max-width: 430px) {
            .comparison-video {
                width: 100% !important;
            }
        }


        .videos-container {
            display: grid;
            grid-template-columns: 1fr auto 1fr;
            align-items: center;
            gap: 20px;
        }

        .vs-separator {
            width: 60px;
            height: 60px;
            line-height: 60px;
            text-align: center;
            font-size: 2em;
            font-weight: bold;
            color: #ffffff;
            background: #007BFF;
            border-radius: 50%;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
        }

        /* Mobile styles: Stack vertically and reduce VS size */
        @media (max-width: 430px) {
            .videos-container {
                grid-template-columns: 1fr;
                grid-template-rows: auto auto auto;
            }

            .vs-separator {
                width: 40px;
                height: 40px;
                line-height: 40px;
                font-size: 1.2em;
                margin: 10px auto;
            }
        }


        @keyframes pulse {
            0% {
                transform: scale(1);
            }

            50% {
                transform: scale(1.2);
            }

            100% {
                transform: scale(1);
            }
        }

        .modal .close {
            position: absolute;
            top: 10px;
            right: 10px;
            background: #02c5fb72;
            border: none;
            padding: 10px;
            font-size: 28px;
            cursor: pointer;
            z-index: 10;
            animation: pulse 2s infinite;
        }

        .modal-content {
            position: relative;
            max-width: 50%;
            max-height: 50%;
            margin: auto;
            top: 0%;
            transform: translateY(-0%);
        }

        /* Mobile adjustments: make the video pane larger on small screens */
        @media (max-width: 430px) {
            .modal-content {
                max-width: 100% !important;
                max-height: 100% !important;
            }

            .modal .close {
                font-size: 24px;
                padding: 8px;
            }
        }

        @media (min-width: 768px) {
            .modal-content {
                max-width: 50% !important;
                max-height: 50% !important;
            }

            .modal .close {
                font-size: 24px;
                padding: 8px;
            }
        }

        @media (max-width: 430px) {
            .authors-container {
                display: flex;
                flex-wrap: wrap;
                margin: 0;
                padding: 0;
            }
        }

        @media only screen and (max-width: 600px) {
            #videoModal .modal-content {
                position: fixed !important;
                top: 0 !important;
                left: 0 !important;
                transform: none !important;
                width: 100% !important;
                height: 100% !important;
                max-width: 100% !important;
                max-height: 100% !important;
                padding: 0 !important;
                margin: 0 !important;
                border: none !important;
            }

            #videoModal .modal-content video {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }


.prompt-text {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 10px;
    z-index: 10;
    border-radius: 0 0 8px 8px;
    box-sizing: border-box;
    font-size: 0.85em;
    line-height: 1.3;
    max-height: 40%;
    overflow-y: auto;
    opacity: 0;
    transform: translateY(100%);
    transition: all 0.3s ease;
    pointer-events: none;
    display: none; /* 初始隐藏 */
}

.highlight-red {
    color: #ff6b6b; 
    font-weight: bold;
}

.highlight-blue {
    color: #4ecdc4; 
}

.highlight-green { 
    color: #0bda51;
    font-weight: bold;
}



@media (max-width: 768px) {
    .prompt-text {
        display: none !important;
    }
}
    </style>




</head>


<!-- Google tag (gtag.js) -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-XD86TWLXLB"></script>
<script>
    window.dataLayer = window.dataLayer || [];
    function gtag() { dataLayer.push(arguments); }
    gtag('js', new Date());

    gtag('config', 'G-XD86TWLXLB');
</script>



<body class="body">



<!-- Single-motion results  upside-->
<section id="section_composition" class="sectionwhite">
    <div class="w-layout-blockcontainer containterbody w-container">

    

 

        <div class="section-box">
            <div class="video-wrapper">
                <!-- Input Videos -->
                <div class="input-videos">
                    <!-- Input Videos  paper name-->
                    <h1 class="heading-7"><span class="gradient-text3">COMO: Compositional Motion Customization for Text-to-Video Models</span></h1>
                    <p style="text-align: center;"> 
                    <span style="font-size: 36px">
                    <a href=" " target="_blank">[Anonymous]</a> &nbsp;&nbsp;&nbsp;&nbsp;
            
                    </span>
                    </p>

                    <h4 class="text-align: center; fancy-heading">Input Videos</h4>


                    <div class="input-container">
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/burpee/burpee.mp4" type="video/mp4">
                        </video>

                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/dance_swing/dance_swing.mp4" type="video/mp4">
                        </video>

                    </div>
                </div>
                <br>

                <div class="output-carousel">
                    <!-- Existing output videos -->
                    <div class="carousel">
                        <!-- Video 1 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                                data-prompt="A majestic <span class='highlight-red'>lion</span> wearing glasses in a crisp red dress shirt, red tie, and navy blue pants <span class='highlight-red'>is performing a burpee exercise</span> in a <span class='highlight-red'>sleek corporate office</span>.
                                 Its mane ruffles as it moves, and its body posture suggests fluid motion. The background features floor-to-ceiling windows overlooking a city skyline, with modern office furniture 
                                and a glass conference table. The polished marble floor reflects the warm glow of recessed lighting.">
                                <source src="test/burpee/burpee_3.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Single-Motion (burpee) </div>

                        </div>
                        <!-- Video 2 -->
                        <div class="video-item">

                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="1"
                                data-prompt="A <span class='highlight-blue'>monkey</span> wearing glasses  <span class='highlight-blue'> is joyfully dancing </span>, suggesting a playful and fluid motion on the <span class='highlight-blue'>beach</span>,
                                    with turquoise waves crashing nearby.">
                                <source src="test/dance_swing/monkey_beach_1008.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Single-Motion (dance) </div>

                        </div>
                        <!-- Video 3 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0" 
                                data-prompt="A <span class='highlight-red'>majestic lion</span>  in a red jacket and jeans and an <span class='highlight-red'>astronaut</span>  in a white spacesuit <span class='highlight-red'>are performing burpee exercises</span> together on a <span class='highlight-red'>farm with fields, a barn, and farm animals in the background.</span>"
                                >

                                <source src="test/burpee/lion_astronaut_farm.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Multi-Motion (Compose burpee)</div>

                        </div>


                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="1"
                                data-prompt="A <span class='highlight-blue'>majestic lion</span> in a velvet robe and a playful <span class='highlight-blue'>monkey</span> in overalls are <span class='highlight-blue'>joyfully dancing</span>, suggesting a playful and fluid motion together in a <span class='highlight-blue'>cozy living room with a fireplace</span>."
                                >
                                <source src="test/dance_swing/lion_monkey_indoor.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Multi-Motion (Compose dance)</div>

                        </div>

                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0,1"
                                 data-prompt="On African savanna under midday sun, a <span class='highlight-red'>lion</span> in safari vest <span class='highlight-red'>performs burpee exercises</span> 
                                 while a <span class='highlight-blue'>monkey</span> in ranger hat <span class='highlight-blue'>dance</span> fluidly. Acacia trees cast short shadows across golden grasslands where heat haze distorts the horizon."
                                >
                                <source src="test/burpee_dance_swing/lion_monkey_savanna.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Multi-Motion (Compose burpee and dance)</div>

                        </div>


                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0,1"
                                data-prompt="In a sun-dappled forest, a determined <span class='highlight-red'>brown bear</span> in blue tank top <span class='highlight-red'>performs burpee exercises</span> while a playful while 
                                a <span class='highlight-blue'>monkey</span> in red vest <span class='highlight-blue'>dance</span> joyfully nearby. Both stand on a mossy path surrounded by ancient oaks and ferns, with sunlight piercing through the dense canopy."
                                >
                                <source src="test/burpee_dance_swing/bear_monkey_forest_480.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Compose </div>

                        </div>

 



                    </div>


                    <!-- Dots Navigation -->
                    <div class="dots-container">
                        <span class="dot active" data-index="0"></span>
                        <span class="dot" data-index="1"></span>
                        <span class="dot" data-index="2"></span>
                        <span class="dot" data-index="3"></span>
                        <span class="dot" data-index="4"></span>
                        <span class="dot" data-index="5"></span>
 
                    </div>
                </div>
                <br>
                  <p style="text-align: center;"> 
                    <span style="font-size: 36px">
                    <a href=" " target="_blank">[Paper]</a> &nbsp;&nbsp;&nbsp;&nbsp;
                    <a href=" " target="_blank">[Code]</a> &nbsp;&nbsp;&nbsp;&nbsp;
                    </span>
                   </p>
             
            </div>
            
</section>

</div>


<!-- TL DR -->
<section id="section_abstract" class="sectiongrey">
    <div class="w-layout-blockcontainer containterbody w-container">
        <div class="w-layout-layout quick-stack-3 wf-layout-layout">
            <div class="w-layout-cell cell-2">
                <!-- <h1 class="heading-7" style="text-align: center ;"><span class="gradient-text3">TL;DR</span></h1> -->
            </div>
            <div class="section-box" style="margin-top: -40px;">
                <div class="w-layout-cell">
                    <p class="paragraph-2">
                        <span class="gradient-text4">TL;DR</span></h1>- We introduces CoMo, a novel framework for <span
                        class="gradient-text">compositional motion customization </span> in text-to-video generation, enabling the synthesis of multiple, distinct motions within a single video.  
                </div>

            </div>
</section>

<!-- Abstract -->
<section id="section_abstract" class="sectiongrey" style="margin-top: 0px;">
    <div class="w-layout-blockcontainer containterbody w-container">
        <div class="w-layout-layout quick-stack-3 wf-layout-layout">
            <div class="w-layout-cell cell-2">
                <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">Abstract</span></h1>
            </div>
            <div class="section-box">
                <div class="w-layout-cell">
                    <p class="paragraph-2">
                    While recent text-to-video models excel at generating diverse scenes, they struggle with precise motion control,
                    particularly for complex, multi-subject motions. Although methods for single-motion customization have been developed to
                    address this gap, they fail in compositional scenarios due to two primary challenges: <em>motion-appearance 
                    entanglement</em> and ineffective <em> multi-motion blending </em>. This paper introduces CoMo, a novel framework for
                    <span class="gradient-text">compositional motion customization</span> in text-to-video generation, enabling the synthesis of multiple, distinct
                    motions within a single video. CoMo addresses these issues through a two-phase approach. First, in the single-motion
                    learning phase, a static-dynamic decoupled tuning paradigm disentangles motion from appearance to learn a
                    motion-specific module. Second, in the multi-motion composition phase, a plug-and-play divide-and-merge strategy
                    composes these learned motions without additional training by spatially isolating their influence during the denoising
                    process. To facilitate research in this new domain, we also introduce a new benchmark and a novel evaluation metric
                    designed to assess multi-motion fidelity and blending. Extensive experiments demonstrate that CoMo achieves
                    state-of-the-art performance, significantly advancing the capabilities of controllable video generation.
                     </p>
                </div>

            </div>
        </div>
    </div>
</section>

<!-- An overview of our proposed CoMo framework -->
<section id="section_abstract" class="sectionwhite" style="margin-top: 0px;">
    <div class="w-layout-blockcontainer containterbody w-container">
        <div class="w-layout-layout quick-stack-3 wf-layout-layout">
            <div class="w-layout-cell cell-2">
                <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">An overview of our proposed CoMo framework</span>
                </h1>
            </div>
            <div class="section-box">
                <div class="w-layout-cell">
         

                    <p class="paragraph-2">
                        Our method consists of two phase: <br>
                        <span class="gradient-text2">Decoupled single-motion learning </span>– we
                        first train a static LoRA module on random frame to learn the appearance of the reference video.
                        Then, we freeze the static LoRA and train a dynamic LoRA module on the complete video to exclusively capture its motion patterns. 
                        focusing solely on learning appearance. <br>
                        <span class="gradient-text">plug-and-play multi-motion composition</span> – we introduce a divide-and-merge strategy for
                        compositional motion generation, while all the weights are frozen.
                    </p>
                </div>

                <div style="display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));">
                    <!-- Video 2 Container -->
                    <div style="text-align: center; display: flex; flex-direction: column; align-items: center;">
                        <!-- <h7 class="gradient-text3" style="font-size: clamp(1.2em, 2vw, 2em); line-height: 2; text-align: center;">
                How Does it Work?
              </h7> -->
                        <img src="test/pipeline.png" class="comparison-video"
                            style="width: 100%; border-radius: 30px; box-shadow: 0 4px 15px rgba(0,0,0,0.3); margin: 0 auto;"
                            alt="Static graphic">
                    </div>
                </div>
            </div>
        </div>
    </div>
</section>




<!-- Merge process -->
<section id="section_abstract" class="sectiongrey" style="margin-top: 0px;">
    <div class="w-layout-blockcontainer containterbody w-container">
        <div class="w-layout-layout quick-stack-3 wf-layout-layout">
            <div class="w-layout-cell cell-2">
                <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">Merge process</span>
                </h1>
            </div>
            <div class="section-box">
    
                <p class="paragraph-2">
                    The final velocity prediction is generated by merging regional velocities with
                    a Gaussian Smooth Transition for local blending, followed by a Global Blending step to ensure overall
                    consistency.
                </p>


                <div style="display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));">
                    <!-- Video 2 Container -->
                    <div style="text-align: center; display: flex; flex-direction: column; align-items: center;">
                        <!-- <h7 class="gradient-text3" style="font-size: clamp(1.2em, 2vw, 2em); line-height: 2; text-align: center;">
                  Set-and-Sequence
                </h7> -->
                        <img src="test/pipeline2.png" class="comparison-video"
                            style="width: 60%; border-radius: 30px; box-shadow: 0 4px 15px rgba(0,0,0,0.3); margin: 0 auto;"
                            alt="Static graphic">
                    </div>

                </div>


            </div>


        </div>
    </div>

    </div>


    </div>
    </div>

</section>
</div>





<!-- Single-motion results  fancy dance-->
<section id="section_single-motion" class="sectionwhite">
    <div class="w-layout-blockcontainer containterbody w-container">

        <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">Single Motion Customization Results</span></h1>


        <div class="gesture-instructions">
            <div class="gesture-demo">
                <!-- Desktop Demo: Monitor with navigation dots and a water ripple click effect -->
                <div class="desktop-demo">
                    <div class="monitor">
                        <div class="screen">
                            <!-- Ripple effect container (positioned above dots) -->
                            <div class="ripple-effect"></div>
                            <div class="nav-dots">
                                <div class="dot"></div>
                                <div class="dot"></div>
                                <div class="dot"></div>
                            </div>
                        </div>
                        <div class="stand"></div>
                    </div>
                </div>
                <!-- Mobile Demo: Fancy mini phone with double-sided swipe arrow -->
                <div class="mobile-demo">
                    <div class="phone">
                        <!-- Pseudo-notch for a modern phone look -->
                        <div class="phone-notch"></div>
                        <div class="phone-screen">
                            <div class="swipe-trail">↔</div>
                        </div>
                    </div>
                </div>
            </div>
            <br>
            <p>
                *Tap the navigation dots above or swipe left/right on your mobile device to browse the videos.
            </p>
        </div>

        <div class="section-box">
            <div class="video-wrapper">
                <!-- Input Videos -->
                <div class="input-videos">
                    <h4 class="text-align: center; fancy-heading">Reference Video (dance)</h4>


                    <div class="input-container">
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/fancy_dance/fancy_dance.mp4" type="video/mp4">
                        </video>
         
                    </div>
                </div>
                <br>

                <div class="output-carousel">
                    <!-- Existing output videos -->
                    <div class="carousel">
                        <!-- video 1 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0" data-prompt="A <span class='highlight-red'>monkey</span> in a graffiti-print hoodie and ripped jeans 
                                is <span class='highlight-red'>performing a dynamic breakdancing move</span>  
                                on a rain-slicked city sidewalk. Neon signs and brick buildings line the street, with passing cars blurred in the
                                background. Its nimble body posture suggests fluid motion, and its mischievous facial expression is focused. Puddles
                                reflect the urban lights, creating a vibrant, nighttime scene."
                                >
                                <source src="test/fancy_dance/monkey_city_1008.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                monkey dance </div>

                        </div>
                        <!-- video 2 -->
                        <div class="video-item">

                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0" 
                                data-prompt="A <span class='highlight-red'>alien</span> is with bioluminescent green skin, wearing quick-dry swim trunks <span class='highlight-red'>is performing a dynamic breakdancing move </span> 
                                on a large lily pad in a tranquil pond. on a wooden pier by the ocean. Turquoise waves crash against the pillars below, and seagulls circle overhead. Its
                                flexible body posture suggests fluid motion, and its glowing eyes show focused expression. The background features
                                sailboats on the horizon and a setting sun casting orange hues. <br> 

                                A <span class='highlight-red'>bear</span> in a faded Hawaiian-print shirt and quick-dry board shorts with palm tree patterns <span class='highlight-red'>is performing a dynamic breakdancing move </span> on a sun-bleached wooden pier. 
                                The coastal scene features turquoise waves breaking over coral reefs in
                                the midground, with thatched beach umbrellas and hammocks swaying in the background. The pier's alternating light/dark
                                woodgrain creates rhythmic visual stripes echoing urban crossings. Golden hour sunlight filters through coconut palms,
                                casting elongated shadows across the salt-crusted timber. Its wet nose glistens during a windmill freeze pose, sea spray
                                misting the air. <br> 

                                A <span class='highlight-red'>lion</span> with a neon-dyed mane, wearing a light blue t-shirt and dark athletic pants with a white stripe down the side,  
                                <span class='highlight-red'>is performing a dynamic breakdancing move </span> on a pedestrian zebra crossing. in an urban environment featuring a blurred,
                                elevated dark gray bridge structure dominating the background and classic black lampposts with ornate detailing standing
                                to the left. Its powerful hind legs propel it into acrobatic flares, tail acting as a counterweight. The zebra crossing
                                has stark white stripes against the dark asphalt, leading towards the massive bridge. The overcast sky provides a
                                diffused light, casting soft shadows. Its golden eyes reflect streetlight glares.
                                "
                                > 
                                <source src="test/fancy_dance/assets.mp4" type="video/mp4">
                            </video>

                        <div class="video-caption caption1"
                        style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                        alien dance</div>
                        <div class="video-caption caption2"
                        style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                        bear dance</div>
                        <div class="video-caption caption3"
                        style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                        lion dance</div>

                        </div>
                        <!-- video 3 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                                data-prompt="A <span class='highlight-red'>chrome-plated robot</span> with glowing blue joints, wearing a light blue t-shirt 
                                and dark athletic pants with a white stripe down the side, <span class='highlight-red'>is performing a dynamic breakdancing move </span>
                                 on the dusty lunar surface. Earth hangs large in the star-filled black sky, and scattered moon rocks dot the grey regolith. 
                                 Its mechanical body posture suggests fluid motion, and its visor display shows a focused expression. 
                                 Craters and a distant lunar lander frame the desolate background."
                                
                                >
                                <source src="test/fancy_dance/robot_moon_1008.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                robot dance</div>

                        </div>

                        <!-- video 4 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                                 data-prompt="A  <span class='highlight-red'>monkey</span>  in durable hiking gear, including a red vest and khaki shorts, 
                                 <span class='highlight-red'>is performing a dynamic breakdancing move </span> on a rocky mountain trail. Towering pine trees and 
                                 jagged peaks dominate the background, with mist clinging to the higher elevations. Its agile body posture suggests fluid motion, 
                                 and its playful facial expression is focused. The trail is lined with wildflowers and loose stones, creating a natural, uneven surface."
                                >
                                <source src="test/fancy_dance/monkey_mountain_1008.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                monkey dance</div>

                        </div>
                        <!-- video 5 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                                data-prompt="A <span class='highlight-red'>bear </span> in a flannel shirt and denim overalls 
                                <span class='highlight-red'>is performing a dynamic breakdancing move </span> in a dense, mossy forest.
                                 Sunlight filters through towering trees, and ferns cover the ground. Its powerful body posture suggests fluid motion,
                                  and its snout twitches with focused expression. The background features a babbling brook and fallen logs, 
                                  creating a serene, natural setting."
                                >
                                <source src="test/fancy_dance/bear_forest_42.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                bear dance</div>

                        </div>

                        <!-- video 6 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                    
                            data-prompt="A <span class='highlight-red'> polar bear </span> in a stretched light blue t-shirt and dark athletic pants with a white stripe down the side,
                             <span class='highlight-red'>is performing a dynamic breakdancing move </span> on a pedestrian zebra crossing. in an urban environment featuring a blurred, elevated dark
                            gray bridge structure dominating the background and classic black lampposts with ornate detailing standing to the left.
                            Despite its bulk, it executes rapid headspins, claws retracted to avoid scratching the asphalt. The zebra crossing has
                            stark white stripes against the dark asphalt, leading towards the massive bridge. The overcast sky provides a diffused
                            light, casting soft shadows. Its black nose twitches mid-freeze.
"
                            >
                                <source src="test/fancy_dance/dynamic_bear_1008.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                polar bear dance </div>

                        </div>


 


                    </div>


                    <!-- Dots Navigation -->
                    <div class="dots-container">
                        <span class="dot active" data-index="0"></span>
                        <span class="dot" data-index="1"></span>
                        <span class="dot" data-index="2"></span>
                        <span class="dot" data-index="3"></span>
                        <span class="dot" data-index="4"></span>
                        <span class="dot" data-index="5"></span>
                    </div>
                </div>
            </div>
</section>

</div>

<!-- Compositional Motion Customization results  fancy dance-->
<section id="section_composition" class="sectiongrey">
    <div class="w-layout-blockcontainer containterbody w-container">

        <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">Compositional Motion Customization Results</span></h1>


 

        <div class="section-box">
            <div class="video-wrapper">
                <!-- Input Videos -->
                <div class="input-videos">
                    <h4 class="text-align: center; fancy-heading">Reference Videos (burpee, dance, exercise)</h4>


                    <div class="input-container">
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/burpee/burpee.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/dance_swing/dance_swing.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/man_exercise/man_exercise.mp4" type="video/mp4">
                        </video>
                    </div>
                </div>
                <br>

                <div class="output-carousel">
                    <!-- Existing output videos -->
                    <div class="carousel">


                        <!-- video 1 -->
                        <div class="video-item">

                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0,1,2" data-prompt="Inside a vast, abandoned factory,  <span class='highlight-red'>a muscular human is performing a burpee exercise</span>  
                                and <span class='highlight-blue'>a rusty robot is joyfully dancing</span>. 
                                <span class='highlight-green'>A gritty bear is engaging in a workout</span>, while <span class='highlight-green'>a nimble monkey</span> is performing a choreographed routine amidst rusted machinery and dusty shafts of light.
                                ">
                                <source src="test/burpee_dance_swing_man_exercise/abandoned_factory_activity.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose burpee ,dance and exercise</div>
                        </div>
                        <!-- video 4 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="0,2"
                                data-prompt=" <span class='highlight-red'>A woman in pink leggings is engaging in a workout</span> 
                                                        while <span class='highlight-green'>a capuchin monkey is performing a burpee exercise </span> in a gym room with a treadmill.">
                                <source src="test/man_exercise_burpee/human_monkey_wb_gym_room.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose burpee and exercise</div>
                        
                        </div>

                        <!-- video 2 -->
                        <div class="video-item">
                        
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="0,1,2"
                             data-prompt="Inside a modern gym with large windows overlooking a city,  <span class='highlight-red'>a muscular man is performing a burpee exercise,</span>  
                                                        <span class='highlight-blue'>a monkey in a tracksuit is joyfully dancing, suggesting a playful and fluid motion,</span>  and
                                                        <span class='highlight-green'>a brown bear with a sweatband is engaging </span> in a workout among the equipment
                                                        ">
                                <source src="test/burpee_dance_swing_man_exercise/human_monkey_bear_gym_42.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose burpee ,dance and exercise</div>
                        </div>
                        
                        <!-- video 3 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="0,1"
                                data-prompt="In a brightly lit gym with mirrored walls, a <span class='highlight-red'>human</span> in sweatpants 
                                                        <span class='highlight-red'>performs burpee exercises </span> while a <span class='highlight-blue'>hydraulic robot</span>  
                                                        <span class='highlight-blue'>dances</span> fluidly nearby. Weight machines surround them on blue rubber flooring as their motions create mirrored reflections.">
                                <source src="test/burpee_dance_swing/human_robot_gym.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Compose burpee and dance </div>
                        
                        </div>


                        <!-- video 5 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="1,2"
                                data-prompt="In a modern gym with mirrored walls and weightlifting equipment, <span class='highlight-blue'>an astronaut in white is engaging in a workout </span> while <span class='highlight-green'> a human in red leggings is joyfully dancing </span> , suggesting a playful and fluid motion.">
                                <source src="test/man_exercise_dance_swing/astronaut_human_gym.mp4" type="video/mp4">
                            </video>

                               <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose dance and exercise</div>

                        </div>
                        <!-- video 6 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0" data-prompt=" <span class='highlight-red'> A brown bear </span> in a blue t-shirt and shorts and <span class='highlight-red'> a majestic lion </span> in a red jacket and jeans <span class='highlight-red'> are performing burpee exercises </span> together on a sandy beach with turquoise waves and palm trees in the background under a sunny sky.">
                                <source src="test/burpee/bear_lion_beach.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Compose burpee</div>

                        </div>

                        <!-- video 7 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="1" data-prompt=" <span class='highlight-blue'> A playful monkey </span> in an orange suit and <span class='highlight-blue'>an astronaut </span>  
                                near a rover <span class='highlight-blue'> are joyfully dancing, suggesting a playful and fluid motion </span> together on Mars with red soil and distant hills.
                            ">
                                <source src="test/dance_swing/monkey_astronaut_mars.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Compose dance </div>

                        </div>

                        <!-- video 8 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="2" data-prompt=" <span class='highlight-green'> A green alien </span> in an orange jumpsuit and <span class='highlight-green'> an astronaut </span>  in a white suit <span class='highlight-green'> are engaging in a workout </span>  together on a rocky mountain trail. Snow-capped peaks and pine trees in the background. Adapting to terrain.
                                                    ">
                                <source src="test/man_exercise/alien_astronaut_mountain.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style=" font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Compose exercise </div>
                        
                        </div>




                    </div>


                    <!-- Dots Navigation -->
                    <div class="dots-container">
                        <span class="dot active" data-index="0"></span>
                        <span class="dot" data-index="1"></span>
                        <span class="dot" data-index="2"></span>
                        <span class="dot" data-index="3"></span>
                        <span class="dot" data-index="4"></span>
                        <span class="dot" data-index="5"></span>
                        <span class="dot" data-index="6"></span>
                        <span class="dot" data-index="7"></span>
                    </div>
                </div>
            </div>
</section>
</div>
 
 
<!-- Experiments -->
<section id="section_experiments" class="sectionwhite">
    <div class="w-layout-blockcontainer containterbody w-container">
        <!-- <h1 class="heading-7">Experiments</h1> -->

        <h1 class="heading-7" style="text-align: center;"><span class="gradient-text3">Experiments</span></h1>

        <!-- <div class="section-box"> -->
        <!-- single- motion customization -->
        <div class="input-videos">
            <h4 class="text-align: center; fancy-heading">single motion customizatio Comparison</h4>
            <div>
                <br>
                <video autoplay loop muted playsinline class="comparison-video"
                    style="max-width: 100%; border-radius: 15px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); display: block; margin: 0 auto;">
                    <source src="test/compare/single-motion.mp4" type="video/mp4">
                </video>

                <br>
            </div>
        </div>

        

        <!-- Compositional  compare-->
        <div class="input-videos">
            <h4 class="text-align: center; fancy-heading">Compositional motion customization Comparison</h4>
            <div>
                <br>
                <video autoplay loop muted playsinline class="comparison-video"
                    style="max-width: 100%; border-radius: 15px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); display: block; margin: 0 auto;">
                    <source src="test/compare/compose-same-motion.mp4" type="video/mp4">
                </video>
                <br><br>
                <video autoplay loop muted playsinline class="comparison-video"
                    style="max-width: 100%; border-radius: 15px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); display: block; margin: 0 auto;">
                    <source src="test/compare/compose-multi-motion.mp4" type="video/mp4">
                </video>
        
                <br>
            </div>
        <!-- Ablation-->
        <div class="input-videos">
            <h4 class="text-align: center; fancy-heading">Ablation</h4>
            <div>
                <br>
                <video autoplay loop muted playsinline class="comparison-video"
                    style="max-width: 100%; border-radius: 15px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); display: block; margin: 0 auto;">
                    <source src="test/compare/ablation.mp4" type="video/mp4">
                </video>

                <!-- </div> -->
            </div>
</section>


<!-- More results   -->
<section id="section_composition" class="sectiongrey">
    <div class="w-layout-blockcontainer containterbody w-container">

        <h1 class="heading-7" style = "text-align: center; "><span class="gradient-text3">More results</span></h1>




        <div class="section-box">
            <div class="video-wrapper">
                <!-- Input Videos -->
                <div class="input-videos">
                    <h4 class="text-align: center; fancy-heading">Reference Videos</h4>


                    <div class="input-container">
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/reference/reference.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/upside/upside.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/dance_up/dance_up.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/run_front/run_front.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/camera_round/camera_round.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/car_turn/car_turn.mp4" type="video/mp4">
                        </video>
                        <video autoplay="" loop="" muted="" playsinline="" class="input-video">
                            <source src="test/riding_horse/riding_horse.mp4" type="video/mp4">
                        </video>
 

                    </div>
                </div>
                <br>

                <div class="output-carousel">
                    <!-- Existing output videos -->
                    <div class="carousel">


                        <!-- motion 1 -->
                        <div class="video-item">

                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0" data-prompt=" 
                               An <span class='highlight-red'>astronaut</span> in blue-trimmed spacesuit is <span class='highlight-red'>dancing energetically</span>, performing a choreographed routine inside a moon crater. lunar rover tracks mark the background. <br>

                                A brown <span class='highlight-red'>bear</span> in a tailored white dress shirt, black tie, and navy blue pants is <span class='highlight-red'>dancing energetically</span>, performing a choreographed routine in an indoor setting. <br>

                                A mischievous <span class='highlight-red'>monkey</span> wearing glasses in a red dress shirt, black tie, and navy blue pants <span class='highlight-red'>dancing energetically</span>, performing a choreographed routine in an indoor setting.  <br> 

                                A majestic <span class='highlight-red'>lion</span  wearing glasses in a crisp red dress shirt, red tie, and navy blue pants <span class='highlight-red'>dancing energetically</span>, performing a choreographed routine on sun-baked African savanna soil Golden dawn light illuminates his body.

                                ">
                                <source src="test/reference/assets.mp4"
                                    type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                dance</div>
                        </div>
                        <!-- motion 1 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="0"
                                data-prompt=" A <span class='highlight-red'>lion</span>  in a leather jacket, an <span class='highlight-red'>astronaut</span> in a black spacesuit, 
                                and a <span class='highlight-red'>bear</span> in a hoodie are<span class='highlight-red'>dancing energetically</span>, 
                                performing a choreographed routine on a wet Tokyo street. The scene is illuminated by vibrant, glowing neon signs, 
                                casting colorful reflections on the damp pavement as crowds of people walk by.">
                                <source src="test/reference/tokyo_night_dancers_our.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose dance</div>

                        </div>

                        <!-- motion 2 video 3-->
                        <div class="video-item">
                        <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="1"
                            data-prompt="A <span class='highlight-red'>lion</span> is <span class='highlight-red'>performing a dynamic handstand</span>  
                                            on wet sand near <span class='highlight-red'>ocean waves</span>.">
                            <source src="test/upside/lion_beach.mp4" type="video/mp4">
                        </video>

                        <div class="video-caption caption2"
                            style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                            handstand </div>

                        </div>

                        <!-- motion 2 video 4-->
                        <div class="video-item">
                        
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="1"
                                data-prompt="A <span class='highlight-red'>frog</span> is <span class='highlight-red'>performing a dynamic handstand</span> on a large lily pad in a tranquil pond.  
                                                        <br> A <span class='highlight-red'>monkey</span> is <span class='highlight-red'>performing a dynamic handstand</span> on a mossy rock near a waterfall. 
                                                        <br> A <span class='highlight-red'> squirrel </span> is <span class='highlight-red'>performing a dynamic handstand</span> on a high tree branch.">
                                <source src="test/upside/assets.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption1"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                frog</div>
                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                monkey</div>
                            <div class="video-caption caption3"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                susqirrel</div>
                        
                        </div>

                        <!-- motion3 video 5 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="2"
                                data-prompt="">
                                <source src="test/dance_up/assets.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                handstand </div>

                        </div>


                        <!-- motion3 video 6 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="2"
                                data-prompt="A rusty robot and a lion in a safari hat are performing energized handstands together on sandy desert dunes. Cacti and a hot sun are in the background.">
                                <source src="test/dance_up/robot_lion_desert.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif;  transform: translateX(-50%) translateY(-10%);">
                                Compose handstand</div>

                        </div>

                        <!-- motion4 video 7 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="3" data-prompt=" 
                            ">
                                <source src="test/run_front/assets.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                run</div>

                        </div>

                        <!--motion4 video 8 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active"
                                data-combination="3" data-prompt="      ">
                                <source src="test/run_front/forest_morning_mist_2_no_global.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style=" font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Compose run </div>

                        </div>
                        <!--motion4 video 9 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="3" data-prompt="  
                                                                            ">
                                <source src="test/run_front/grand_hallway_chase_no_global.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style=" font-family: 'Bradley Hand', 'Bradley Hand ITC', cursive, Arial, sans-serif; transform: translateX(-50%) translateY(-10%);">
                                Compose run </div>
                        </div>

                        <!--motion5 video 10 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="4" data-prompt="A colorful plastic toy robot, about a foot tall with movable joints, is placed on a wooden table in a child's room.
                             The view is fastly circling counterclockwise around the toy robot. 
                            The surrounding background includes scattered toys, a rug, and a window showing a sunny day outside. 
                            As time passes, the scene remains focused on the toy, highlighting its bright paint and simple design.  ">
                                <source src="test/camera_round/2000_toy_robot_indoor_42.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Circling counterclockwise </div>
                        </div>

                        <!--motion5 video 11 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="4" data-prompt="A majestic lion with a golden mane is resting under an acacia tree on the African savanna. 
                            The view is fastly circling counterclockwise around the lion.
                            The surrounding landscape features golden grasslands stretching to the horizon, with scattered bushes and a partly cloudy sky. 
                            As time passes, the scene remains focused on the lion, highlighting its powerful build and regal presence.  ">
                                <source src="test/camera_round/2000_lion_savanna_42.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Circling counterclockwise </div>
                        </div>

                        <!--motion6 video 11 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="5" data-prompt="A icebreaker-style sailboat with heated carbon-fiber sails and sonar-guided runners is 
                            slicing through pancake ice formations in synchronized motion.   Snowdrifts recreate the mountain road's curvature, while icebergs with wind-sculpted grooves stand as organic barriers.   
                            The vessel's hull leaves temporary melt channels mirroring tire tracks, maintaining identical velocity patterns.">
                                <source src="test/car_turn/1600_blizzard_ship_42.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Run </div>
                        </div>

                        <!--motion6 video 12 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="5" data-prompt="A STOL-equipped bush plane with frost-resistant composite wings and ski landing gear 
                            is gliding effortlessly along glacial moraine patterns.   The frozen tundra displays pressure ridges mimicking road curves, flanked by ice stalagmites serving as natural barriers.   
                            Aurora-lit contrails trace the aircraft's path where coniferous forests transform into jagged ice spires. 
                            Retained motion dynamics manifest in the plane's precise altitude adjustments matching original road undulations, its shadow skating across blue ice fields.">
                                <source src="test/car_turn/1600_arctic_airplane_42.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Run </div>
                        </div>

                        <!--motion6 video 13 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="6"
                                data-prompt="An astronaut in a bulky white space suit and helmet incongruously is riding a large, determined pig, galloping energetically across a muddy, cratered lunar outpost field.  
                                The sturdy pig, its skin wrinkled and coarse,   charges forward with surprising speed, snout lowered.  
                                The background is covered with stars and the Earth in space can also be seen">
                                <source src="test/riding_horse/1800_astronaut_pig_moon_42.mp4" type="video/mp4">
                            </video>
                        
                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Riding</div>
                        </div>

                        <!--motion6 video 14 -->
                        <div class="video-item">
                            <video autoplay="" loop="" muted="" playsinline="" class="output-video active" data-combination="6"
                                data-prompt="A knight in shining silver armor is riding a towering giraffe, galloping energetically across a sunlit savanna. 
                                The giraffe's long neck sways rhythmically as it moves with surprising speed, its hooves kicking up dust. The knight clings to the reins, focused and steady, 
                                as they traverse the grassland dotted with bushes under a vast sky.">
                                <source src="test/riding_horse/1800_knight_giraffe_42.mp4" type="video/mp4">
                            </video>

                            <div class="video-caption caption2"
                                style="text-align: center; font-family: Arial, Helvetica, sans-serif;  font-size: 1.5em;">
                                Riding</div>
                        </div>




                    </div>


                    <!-- Dots Navigation -->
                    <div class="dots-container">
                        <span class="dot active" data-index="0"></span>
                        <span class="dot" data-index="1"></span>
                        <span class="dot" data-index="2"></span>
                        <span class="dot" data-index="3"></span>
                        <span class="dot" data-index="4"></span>
                        <span class="dot" data-index="5"></span>
                        <span class="dot" data-index="6"></span>
                        <span class="dot" data-index="7"></span>
                        <span class="dot" data-index="8"></span>
                        <span class="dot" data-index="9"></span>
                        <span class="dot" data-index="10"></span>
                        <span class="dot" data-index="11"></span>
                        <span class="dot" data-index="12"></span>
                        <span class="dot" data-index="13"></span>
                        <span class="dot" data-index="14"></span>
                    </div>
                </div>
            </div>
</section>
</div>


<!-- TL DR -->
<section id="section_abstract" class="sectionwhite">
    <div class="w-layout-blockcontainer containterbody w-container">
        <div class="w-layout-layout quick-stack-3 wf-layout-layout">
            <div class="w-layout-cell cell-2">
                <!-- <h1 class="heading-7" style="text-align: center ;"><span class="gradient-text3">TL;DR</span></h1> -->
            </div>
            <div class="section-box" style="margin-top: -20px;">
                <div class="w-layout-cell">
                    <p class="paragraph-2">
                        Our project page is borrowed from <a href="https://snap-research.github.io/dynamic_concepts/">Dynamic Concepts</a>. Thanks for their great work!
                    </p>
                    </div>

            </div>
</section>
</div>

<section class="bibtex-citation"
    style="padding: 25px; text-align: center; background-color: #1f2937; border: 1px solid #4b5563; border-radius: 12px; margin: 2rem auto; max-width: 800px; box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3); font-family: sans-serif;">

    <h2 style="font-size: 1.6rem; color: #0ea5e9; margin-bottom: 1.5rem; font-weight: 600;">
        BibTeX Citation
    </h2>

    <pre
        style="background-color: #111827; color: #d1d5db; padding: 1.5rem; border-radius: 8px; text-align: left; overflow-x: auto; border: 1px solid #374151; font-family: 'Courier New', monospace; line-height: 1.6; font-size: 0.9em;">
    @misc{,
      title={},
      author={},
      year={},
      eprint={},
      archivePrefix={},
      primaryClass={}
  }
  </pre>
</section>

<script>
    document.addEventListener('DOMContentLoaded', function() {
     
        const videos = document.querySelectorAll('.output-video');

     
        videos.forEach(video => {
 
            const promptText = document.createElement('p');
            promptText.className = 'prompt-text';
            promptText.innerHTML = video.getAttribute('data-prompt'); 

   
            video.parentNode.insertBefore(promptText, video.nextSibling);

 
            video.addEventListener('mouseenter', function() {
                promptText.style.display = 'block';
                setTimeout(() => {
                    promptText.style.opacity = '1';
                    promptText.style.transform = 'translateY(0)';
                }, 10);
            });

   
            video.addEventListener('mouseleave', function() {
                promptText.style.opacity = '0';
                promptText.style.transform = 'translateY(100%)';
                setTimeout(() => {
                    promptText.style.display = 'none';
                }, 300);
            });
        });
    });
</script>

    <!-- <script src="./Lumiere_files/jquery-3.5.1.min.dc5e7f18c8.js" type="text/javascript" integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
  <script src="./Lumiere_files/webflow.js" type="text/javascript"></script> -->

    <!-- <div style="text-align: center; margin: 20px auto; font-size: 1rem; color: #1a1b1b;">
    <p>Number of Hits: <span id="hits" style="color: #00bcd4;">0</span></p>
  </div> -->

    <script>
        document.querySelectorAll('.carousel').forEach(carousel => {
            // Cache related elements as arrays
            const outputVideos = Array.from(carousel.querySelectorAll('.output-video'));
            const section = carousel.closest('.sectiongrey, .sectionwhite');
            const dots = section.querySelector('.dots-container')
                ? Array.from(section.querySelector('.dots-container').querySelectorAll('.dot'))
                : [];
            const inputVideos = Array.from(section.querySelectorAll('.input-video'));

            let currentIndex = 0;
            let autoplayInterval;
            let autoplayEnabled = true;

            // Update only the current, next, and previous videos
            function updateDisplay() {
                const total = outputVideos.length;
                outputVideos.forEach((video, index) => {
                    // Clear all helper classes
                    video.classList.remove('active', 'left', 'right');

                    if (index === currentIndex) {
                        // Active video: reset and play from start
                        video.classList.add('active');
                        video.currentTime = 0;
                        video.play().catch(() => { });
                    } else if (index === (currentIndex + 1) % total) {
                        // Next video: add 'right' and ensure playback
                        video.classList.add('right');
                        video.play().catch(() => { });
                    } else if (index === (currentIndex - 1 + total) % total) {
                        // Previous video: add 'left' and ensure playback
                        video.classList.add('left');
                        video.play().catch(() => { });
                    } else {
                        // Pause all other videos
                        video.pause();
                    }
                });

                // Update input video highlights based on the active video's data-combination attribute
                const comb = outputVideos[currentIndex].getAttribute('data-combination');
                const combination = comb ? comb.split(',').map(Number) : [];
                inputVideos.forEach(video => video.classList.remove('active'));
                combination.forEach(idx => {
                    if (inputVideos[idx]) inputVideos[idx].classList.add('active');
                });

                // Update dot navigation if present
                dots.forEach((dot, idx) => dot.classList.toggle('active', idx === currentIndex));
            }

            function switchTo(index) {
                currentIndex = index;
                updateDisplay();
                if (autoplayEnabled) resetAutoplay();
            }

            function startAutoplay() {
                autoplayInterval = setInterval(() => {
                    currentIndex = (currentIndex + 1) % outputVideos.length;
                    updateDisplay();
                }, 5000);
            }

            function resetAutoplay() {
                clearInterval(autoplayInterval);
                startAutoplay();
            }

            function disableAutoplay() {
                autoplayEnabled = false;
                clearInterval(autoplayInterval);
            }

            // Initialize and start autoplay
            updateDisplay();
            startAutoplay();

            // Dot navigation click handler
            dots.forEach((dot, idx) => {
                dot.addEventListener('click', () => {
                    switchTo(idx);
                    disableAutoplay();
                });
            });

            // Swipe detection for mobile devices
            let touchStartX = 0;
            carousel.addEventListener('touchstart', e => {
                touchStartX = e.changedTouches[0].screenX;
            }, false);

            carousel.addEventListener('touchend', e => {
                const touchEndX = e.changedTouches[0].screenX;
                if (touchEndX < touchStartX - 50) { // swipe left
                    switchTo((currentIndex + 1) % outputVideos.length);
                    disableAutoplay();
                } else if (touchEndX > touchStartX + 50) { // swipe right
                    switchTo((currentIndex - 1 + outputVideos.length) % outputVideos.length);
                    disableAutoplay();
                }
            }, false);
        });
    </script>





    <script>
        document.addEventListener("DOMContentLoaded", () => {
            // Run only on mobile devices (viewport ≤1024px)
            if (!window.matchMedia("(max-width:1024px)").matches) return;

            let activeSection = null;
            const sections = Array.from(document.querySelectorAll(".sectionwhite, .sectiongrey"));

            sections.forEach(section => {
                const outputCarouselContainer = section.querySelector(".output-carousel");
                if (!outputCarouselContainer) return;

                const carousel = outputCarouselContainer.querySelector(".carousel");
                if (!carousel) return;

                // Cache output videos and "unload" them by clearing the src attribute.
                const videos = Array.from(carousel.querySelectorAll(".output-video"));
                videos.forEach(video => {
                    const sourceEl = video.querySelector("source");
                    if (sourceEl && !video.dataset.origSrc) {
                        video.dataset.origSrc = sourceEl.getAttribute("src");
                        // Clear the source to prevent immediate loading.
                        sourceEl.src = "";
                        video.load();
                    }
                    video.style.display = "none";
                });
                carousel.style.display = "none";

                // Create the "Generate Outputs" button if it doesn't already exist.
                let genBtn = section.querySelector(".generate-output-btn");
                if (!genBtn) {
                    genBtn = document.createElement("div");
                    genBtn.className = "generate-output-btn";
                    genBtn.textContent = "▶ Generate Outputs";
                    genBtn.style.cssText =
                        "display: block; text-align: center; margin-top: 1.5rem; padding: 12px 20px; background: linear-gradient(135deg, #444, #888); border-radius: 12px; color: #fff; font-size: 1rem; cursor: pointer; animation: pulsate 1.5s infinite;";
                    const dotsContainer = section.querySelector(".dots-container");
                    if (dotsContainer) {
                        dotsContainer.insertAdjacentElement("afterend", genBtn);
                    } else {
                        carousel.parentNode.insertBefore(genBtn, carousel.nextSibling);
                    }
                }

                genBtn.addEventListener("click", () => {
                    if (activeSection && activeSection !== section) {
                        deactivateSection(activeSection);
                    }
                    activeSection = section;
                    activateSection(section);
                    genBtn.style.display = "none";
                });
            });

            function deactivateSection(section) {
                const carousel = section.querySelector(".output-carousel .carousel");
                if (carousel) {
                    carousel.style.display = "none";
                    const videos = Array.from(carousel.querySelectorAll(".output-video"));
                    videos.forEach(video => {
                        video.pause();
                        video.style.display = "none";
                        const sourceEl = video.querySelector("source");
                        if (sourceEl) {
                            // Clear the src to free resources.
                            sourceEl.src = "";
                        }
                    });
                }
                const btn = section.querySelector(".generate-output-btn");
                if (btn) btn.style.display = "block";
            }

            function activateSection(section) {
                const carousel = section.querySelector(".output-carousel .carousel");
                if (!carousel) return;
                const videos = Array.from(carousel.querySelectorAll(".output-video"));
                videos.forEach(video => {
                    const sourceEl = video.querySelector("source");
                    // Always restore the original src.
                    if (sourceEl && video.dataset.origSrc) {
                        sourceEl.src = video.dataset.origSrc;
                        video.load();
                    }
                    video.style.display = "block";
                    video.muted = true;
                    video.playsInline = true;
                    video.currentTime = 0;
                    video.play().catch(err => console.error("Play error:", err));
                });
                carousel.style.display = "block";
            }

            // Append pulsate keyframe animation if not already defined.
            if (!document.querySelector("style[data-pulsate]")) {
                const s = document.createElement("style");
                s.setAttribute("data-pulsate", "true");
                s.innerHTML = `
            @keyframes pulsate {
              0% { transform: scale(1); }
              50% { transform: scale(1.15); }
              100% { transform: scale(1); }
            }
          `;
                document.head.appendChild(s);
            }
        });
    </script>





    <script>
        function openModal(videoURL) {
            var videoSource = document.getElementById('modalVideoSource');
            videoSource.src = videoURL;

            var modal = document.getElementById('videoModal');
            modal.style.display = "flex";
            document.body.classList.add('modal-open');

            var video = modal.querySelector('video');
            video.load();
            video.play();
        }

        function closeModal() {
            var modal = document.getElementById('videoModal');
            modal.style.display = "none";
            document.body.classList.remove('modal-open');

            var video = modal.querySelector('video');
            video.pause();
            video.currentTime = 0;
        }

        // Allow closing modal by clicking outside the modal content
        document.getElementById('videoModal').addEventListener('click', function (e) {
            if (e.target === this) {
                closeModal();
            }
        });
    </script>







    <!-- HAMBURGER SCRIPT (Near end of <body>) -->
    <script>
        /**
         * On smaller screens, we hide #topNav by default
         * and show #hamburgerIcon. On larger screens, do the opposite.
         * Toggling the hamburger displays the nav vertically.
         */
        function toggleMenu() {
            const nav = document.getElementById('topNav');
            // If hidden, show it as a vertical dropdown
            if (window.getComputedStyle(nav).display === 'none') {
                nav.style.display = 'flex';
                nav.style.flexDirection = 'column';
                nav.style.position = 'absolute';
                nav.style.top = '60px';   // below the header
                nav.style.right = '20px'; // or left:0 if you prefer
                nav.style.background = '#000';
                nav.style.padding = '10px';
                nav.style.gap = '10px';
                nav.style.borderRadius = '4px';
                nav.style.zIndex = '999';
            } else {
                // Hide it again
                nav.style.display = 'none';
            }
        }

        function handleResize() {
            const nav = document.getElementById('topNav');
            const hamburger = document.getElementById('hamburgerIcon');
            if (window.innerWidth < 768) {
                // Mobile - show hamburger, hide nav
                hamburger.style.display = 'flex';
                nav.style.display = 'none';
            } else {
                // Desktop - show nav row, hide hamburger
                hamburger.style.display = 'none';
                nav.style.display = 'flex';
                nav.style.position = 'static';
                nav.style.flexDirection = 'row';
                nav.style.background = 'transparent';
                nav.style.padding = '0';
                nav.style.borderRadius = '0';
                nav.style.gap = '20px';
            }
        }

        window.addEventListener('resize', handleResize);
        document.addEventListener('DOMContentLoaded', handleResize);
    </script>


    <!-- <script>
      document.addEventListener('DOMContentLoaded', () => {
        // Get the current hits from localStorage, or 0 if not set
        let hits = localStorage.getItem('myLocalHits') || 0;
        hits = parseInt(hits, 10) + 1; // convert to number, increment
    
        // Store the updated hits back into localStorage
        localStorage.setItem('myLocalHits', hits);
    
        // Display the count in the <span id="hits">
        document.getElementById('hits').textContent = hits;
      });
      </script> -->

    <script>
        const sections = document.querySelectorAll('section');
        const observer = new IntersectionObserver((entries, observer) => {
            entries.forEach(entry => {
                if (entry.isIntersecting) {
                    entry.target.classList.add('revealed');
                    observer.unobserve(entry.target); // Stop observing after first reveal
                }
            });
        }, { threshold: 0.05 });

        sections.forEach(section => observer.observe(section));
    </script>






    <style>
        /* Increase font size for author links */
        .text_block_authors {
            font-size: 1.1rem;
            /* adjust as needed */
        }

        /* On mobile devices (max-width: 768px), add extra spacing between heading and authors */
        @media (max-width: 430px) {

            /* Assuming the authors are inside a container, for example: */
            .authors-grid,
            .text_block_authors {
                margin-top: 2rem;
                /* increase vertical space */
            }
        }
    </style>



    <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
    <script>
        // Array of tweet objects with tweet ID and URL (using the new X domain)
        const tweets = [
            { id: "1884617501054468419", url: "https://x.com/AbdalRameen/status/1884617501054468419" },
            { id: "1884617501054468419", url: "https://x.com/AbdalRameen/status/1884617501054468419" }
        ];

        let currentTweetIndex = 0;
        const tweetCarousel = document.getElementById('tweetCarousel');

        function loadTweet(tweetObj) {
            tweetCarousel.innerHTML = ""; // Clear previous tweet
            twttr.widgets.createTweet(
                tweetObj.id,
                tweetCarousel,
                { theme: "light", align: "center" }
            ).then(function (el) {
                // Make the tweet clickable so that clicking opens the tweet on X in a new tab.
                tweetCarousel.onclick = () => window.open(tweetObj.url, "_blank");
            }).catch(function (error) {
                console.error("Error loading tweet:", error);
            });
        }

        function rotateTweet() {
            loadTweet(tweets[currentTweetIndex]);
            currentTweetIndex = (currentTweetIndex + 1) % tweets.length;
        }

        // Use twttr.ready if available, otherwise fallback to window load.
        if (window.twttr && twttr.widgets && twttr.ready) {
            twttr.ready(function () {
                rotateTweet();
                setInterval(rotateTweet, 10000);
            });
        } else {
            window.addEventListener("load", function () {
                if (window.twttr && twttr.widgets && twttr.widgets.createTweet) {
                    rotateTweet();
                    setInterval(rotateTweet, 10000);
                } else {
                    console.error("Twitter widgets are not available.");
                }
            });
        }
    </script>


    <script>
        document.querySelector('.play-me-btn').addEventListener('click', function (e) {
            if (window.innerWidth <= 600) {
                // Prevent any default behavior and further event handling
                e.preventDefault();
                e.stopImmediatePropagation();
                // Open the video URL in a new window or tab
                window.open(this.getAttribute('href'), '_blank');
                return false;
            }
        }, true); // using capture phase to intercept early
    </script>








 