<!DOCTYPE html>
<html lang="en">
 <head>
  <meta charset="utf-8"/>
  <meta content="width=device-width, initial-scale=1.0" name="viewport"/>
  <meta content="light dark" name="color-scheme"/>
  <title>
    Video-As-Prompt: Unified Semantic Control for Video Generation
  </title>
  <style>
   *{margin:0;padding:0;box-sizing:border-box} body{ font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif; background:#000;color:#fff;line-height:1.6} .container{max-width:1200px;margin:0 auto;padding:0 20px} header{text-align:center;padding:48px 0 24px} .date{font-size:14px;color:#aaa;margin-bottom:12px} h1{font-size:48px;margin:60px 0 16px;font-weight:500;line-height:1} .tagline{font-size:24px;color:#fff;margin:24px 0 0;font-style:italic;font-weight:600} .authors{margin-top:24px;font-size:20px;color:#aaa} .authors sup{font-size:0.7em;margin-left:2px;margin-right:0} .authors a{color:inherit;text-decoration:none} .authors a:hover{text-decoration:underline} .authors .author{display:inline-block;white-space:nowrap;margin-right:16px} .authors .author:last-child{margin-right:0} .affiliations{font-size:14px;color:#aaa;margin-top:18px} .affiliations sup{margin-left:16px} .affiliations sup:first-child{margin-left:0} .footnotes{font-size:12px;color:#888;margin-top:14px} .cta-buttons{margin-top:28px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap} .btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;border:1px solid #333;background:#151515;color:#fff;text-decoration:none;font-weight:600;font-size:14px} @media(hover:hover){.btn:hover{background:#1f1f1f;border-color:#3a3a3a}} .btn .icon{font-size:16px;opacity:0.85} .media-grid{display:flex;gap:20px;margin:40px 0;align-items:stretch;flex-wrap:nowrap;justify-content:center} .media-grid.wrap{flex-wrap:wrap} .media-grid.four-cols{display:flex;gap:6px 20px;justify-content:flex-start;flex-wrap:wrap;overflow:visible} .media-grid.four-cols .media-item{flex:0 0 calc((100% - 40px)/3)} .media-item{display:flex;flex-direction:column;align-items:center} .image-container{height:240px;width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden;margin-bottom:0} .media-item video,.media-item img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px} .media-caption{margin-top:15px;font-size:14px;color:#aaa;text-align:center;width:100%} .section-title{font-size:28px;margin:60px 0 30px;font-weight:500;text-align:center} p{margin-bottom:20px;font-size:16px;color:#ddd} .emph{color:#fff !important} .figure{margin:30px 0} .figure img,.figure video{width:100%;height:auto;border-radius:8px;display:block} .figure .fig-caption{margin-top:12px;font-size:14px;color:#aaa;text-align:center} .bibtex-block{position:relative;background:#0f0f0f;border:1px solid #222;border-radius:8px;padding:16px;margin:50px 0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;color:#ddd} .bibtex-block pre{white-space:pre;overflow:auto;margin:0} .copy-btn{position:absolute;top:10px;right:10px;border:none;border-radius:6px;padding:6px 10px;background:#222;color:#ddd;cursor:pointer;font-size:12px} @media(hover:hover){.copy-btn:hover{background:#2f2f2f}} .media-grid.different-widths .media-item:nth-child(1){flex:1.8} .media-grid.different-widths .media-item:nth-child(2){flex:2} .media-grid.different-widths .media-item:nth-child(3), .media-grid.different-widths .media-item:nth-child(4){flex:1} @media (max-width:992px){ } @media (max-width:768px){ h1{font-size:32px} .authors{font-size:18px} .media-grid{flex-direction:column} .media-grid.four-cols{flex-direction:row} .media-grid.four-cols .media-item{flex:0 0 calc((100% - 20px)/2)} .image-container{height:auto;max-height:360px} .section-title{font-size:24px} } @media (max-width:480px){ .media-grid.four-cols .media-item{flex:0 0 100%} } .media-item video.preview{cursor:pointer} .lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.9);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px} .lightbox.show{display:flex} .lightbox-content{max-width:90vw;max-height:90vh;position:relative} .lightbox video{width:100%;height:auto;max-height:90vh;border-radius:8px} .lightbox .close-btn{position:absolute;top:-12px;right:-12px;width:40px;height:40px;border:none;border-radius:50%;background:rgba(255,255,255,0.15);color:#fff;font-size:28px;line-height:40px;text-align:center;cursor:pointer}
  

.compare{display:flex;position:relative;overflow:hidden;justify-content:left;width:100%;height:100%;}
.slidervideo{display:flex;position:relative;width:100%;height:100%;transition:0.2s ease;object-fit:contain;background:#000;}
.slider{position:absolute;cursor:ew-resize;height:100%;width:0px;background-color:rgba(255,255,255,0.6);z-index:10}
.prompt-wrap{position:relative}
.prompt{max-width:calc(100% - 20px);position:absolute;background:rgba(0,0,0,0.5);color:rgba(255,255,255,0.9);font-size:10px;backdrop-filter:blur(10px);bottom:10px;left:10px;padding:5px 10px;border-radius:15px;opacity:0;pointer-events:none;transition:opacity .5s;box-sizing:border-box}
@media(hover:hover){.prompt-wrap:hover .prompt{opacity:1;pointer-events:auto}}


.prompt-wrap .container{
  display:flex;position:relative;overflow:hidden;justify-content:left;width:100%;height:100%;
}
.prompt-wrap .slidervideo{
  display:flex;position:relative;width:100%;height:100%;transition:0.2s ease;object-fit:contain;background:#000;
  aspect-ratio:16/9;
}
.prompt-wrap .slider{
  position:absolute;cursor:ew-resize;height:100%;background-color:rgba(255,255,255,0.5);z-index:10;

  width: 0px;}

.prompt-wrap .prompt{
  max-width:calc(100% - 20px);position:absolute;background:rgba(0,0,0,0.5);color:rgba(255,255,255,0.9);font-size:10px;
  backdrop-filter:blur(10px);bottom:10px;left:10px;padding:5px 10px;border-radius:15px;opacity:0;pointer-events:none;
  transition:opacity .5s;box-sizing:border-box;
}
@media(hover:hover){.prompt-wrap:hover .prompt{opacity:1;pointer-events:auto}}


.media-grid .image-container{height:auto;max-height:none}


.prompt {
  
  max-width: calc(100% - 20px);
  position: absolute;
  background: rgba(0,0,0,0.5);
  color: rgba(255,255,255,0.9);
  font-size: 10px;
  backdrop-filter: blur(10px);
  bottom: 10px;
  left: 10px;
  padding: 5px 10px;
  border-radius: 15px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s;
  box-sizing: border-box;
  
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.4;
}
@media (hover: hover) {
  .prompt-wrap:hover .prompt { opacity: 1; pointer-events: auto; }
}


.prompt-wrap { position: relative; }
.prompt-wrap .prompt { z-index: 20; }

.prompt-wrap .slider { z-index: 15; width: 0px !important; }

.prompt-wrap .container:hover + .prompt,
.prompt-wrap:hover .prompt { opacity: 1 !important; pointer-events: auto !important; }


.media-grid .subsection-header{flex:0 0 100%; margin:22px 0 10px; padding-top:8px; border-top:1px solid #1e1e1e}
.subsection-title{font-size:20px; font-weight:600; color:#fff; line-height:1.25}
.subsection-desc{font-size:14px; color:#aaa; margin-top:6px}
@media (max-width:768px){
  .subsection-title{font-size:18px}
  .subsection-desc{font-size:13px}
}


.media-grid .image-container {
  
  aspect-ratio: 3 / 2;
  width: 100%;
  height: auto;          
  position: relative;
  overflow: hidden;      
}


.prompt-wrap .container {
  width: 100%;
  height: 100%;
}


.prompt-wrap .slidervideo {
  width: 100%;
  height: 100%;
  object-fit: cover;     
}


.prompt-wrap { --prompt-w: 540px; }   

.prompt-wrap .prompt{
  
  left: 50% !important;
  transform: translateX(-50%);   
  width: var(--prompt-w);        
  max-width: calc(100% - 32px);  
  box-sizing: border-box;        
  text-align: center;
  
}


@media (max-width: 640px){
  .prompt-wrap { --prompt-w: 88vw; }   
}

.prompt-wrap .container{
  position: relative;
  
  --cut: 40%; 
}


.prompt-wrap .container #media1{
  position: relative;
  z-index: 0;
}
.prompt-wrap .container #media2{
  position: relative;
  z-index: 2;
  margin-left: -100%; 
  clip-path: inset(0 var(--cut) 0 0) !important; 
}


.prompt-wrap .container .slider{
  position: absolute;
  z-index: 15;
}


.prompt-wrap .container::before,
.prompt-wrap .container::after{ content: none !important; }


.prompt-wrap .container .gen-clip,
.prompt-wrap .container .ref-clip{
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;                   
  transition: opacity .2s ease;
  z-index: 12;                  
}
@media (hover:hover){
  .prompt-wrap .container:hover .gen-clip,
  .prompt-wrap .container:hover .ref-clip{ opacity: 1; }
}


.prompt-wrap .container .ref-clip{
  clip-path: inset(0 var(--cut) 0 0);
}
.prompt-wrap .container .ref-clip .ref-badge{
  position: absolute;
  top: 8px;
  left: 20px;
  padding: 4px 8px;
  font-size: 12px;
  line-height: 1;
  background: rgba(128,128,128,.5);
  color: #fff;
  border-radius: 6px;
  white-space: nowrap;
}


.prompt-wrap .container .gen-clip{
  
  clip-path: inset(0 0 0 calc(100% - var(--cut)));
}
.prompt-wrap .container .gen-clip .gen-badge{
  position: absolute;
  top: 8px;
  right: 20px;
  padding: 4px 8px;
  font-size: 12px;
  line-height: 1;
  background: rgba(128,128,128,.5);
  color: #fff;
  border-radius: 6px;
  white-space: nowrap;
}


@media (hover:none){
  .prompt-wrap .container .gen-clip,
  .prompt-wrap .container .ref-clip{ opacity: 1; }
}


.media-grid.cols-4 .media-item { 
  flex: 0 0 calc((100% - 60px) / 4); 
}


.col-heads {
  display: flex;
  gap: 20px;
  margin: 6px 0 10px;
  font-size: 14px;
  color: #bbb;
}
.col-heads.cols-4 .col-head {
  flex: 0 0 calc((100% - 60px) / 4);
  text-align: center;
  font-weight: 600;
}


.image-container .fill-video {
  width: 100%;
  height: 100%;
  object-fit: cover;   
  border-radius: 8px;
}


.no-badges .gen-clip,
.no-badges .ref-clip { display: none !important; }


#same-ref-video-diff-img{
  
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: 20px;
  row-gap: 20px;
}


#same-ref-video-diff-img .subsection-header{
  grid-column: 1 / -1;
  margin-bottom: 4px;
}


#same-ref-video-diff-img .col-heads{
  display: contents !important; 
}


#same-ref-video-diff-img .col-head{
  text-align: center;
  font-weight: 600;
  font-size: 20px;
  color: #ffffff;
  padding-bottom: 6px;
}


#same-ref-video-diff-img .media-item{
  margin: 0;          
  width: auto;
  flex: initial !important;
}




.media-grid .overlay-card .overlay-frame {
  position: relative;
  width: 100%;
  height: 100%;
}

.media-grid .overlay-card .gen-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;
  display: block;
}


.media-grid .overlay-card .ref-thumb-wrap {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 33%;
  z-index: 3;
  pointer-events: auto; 
}

.media-grid .overlay-card .ref-thumb {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 12px;
  opacity: .5;                   
  transition: opacity .2s ease;
  display: block;
}


.media-grid .overlay-card .ref-thumb-wrap:hover .ref-thumb {
  opacity: 1;
}


.media-grid .overlay-card .corner-badge {
  position: absolute;
  z-index: 4;
  padding: 4px 8px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  border-radius: 999px;
  background: rgba(0,0,0,.6);
  color: #fff;
  user-select: none;
  pointer-events: none; 
}

.media-grid .overlay-card .corner-badge.gen {
  top: 10px;
  right: 10px;
}

.media-grid .overlay-card .corner-badge.ref {
  top: 2px;
  left: 25px;
  font-size: 12px;
  background: rgba(0,0,0,.65);
}





#srviump-block .ref-pair{
  
  flex: 0 0 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin: 10px 0 4px;
}
#srviump-block .ref-card .ref-title{
  text-align: center;
  font-weight: 600;
  color: #ffffff;
  margin-bottom: -50px;
  font-size: 20px;
}
#srviump-block .ref-card .image-container{
  aspect-ratio: 3 / 2;
}
#srviump-block .ref-card .image-container video,
#srviump-block .ref-card .image-container img{
  width: 70%;
  height: 70%;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}


#srviump-block .prompt-block{
  margin-top: 10px;
  font-size: 14px;
  color: #bbb;
  text-align: left;
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.5;
}


@media (max-width: 768px){
  #srviump-block .ref-pair{ grid-template-columns: 1fr; }
}

.yt-wrapper {
  position: relative;
  width: 100%;
  max-width: 1600px;      
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}
.yt-wrapper #player, .yt-wrapper iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}


</style>
 </head>
 <body>
  <div class="container">
   <header>
    <h1>
      Video-As-Prompt: Unified Semantic Control for 
      <br/>
      Video Generation
    </h1>
    <div class="authors">
     <span class="author">
      <a href="https://Video-As-Prompt.github.io/" rel="noopener noreferrer" target="_blank">
       Anonymous Authors
      </a>
     </span>
    </div>
    <div class="affiliations">
      <sup>
       *
      </sup>
      This page contains many high-fidelity video demonstrations; we recommend waiting until all videos have completely loaded to ensure smooth and accurate visualization.
     </div>
   </header>
   <div class="section-title">
    This offline project page is used for the ICLR 2026 submission. Due to supplementary size limit, we only provide the application section and the zero-shot section.
    Please visit the online project page for the full version: https://video-as-prompt.github.io/
   </div>

   <div class="section-title">
    Treating&nbsp;Reference&nbsp;Videos&nbsp;As&nbsp;In-Context&nbsp;Prompts
   </div>
   <p>
    By treating a reference video with the wanted semantic as a video prompt and achieving plug-and-play in-context generation via mixture-of-transformers structure, we can generate videos that are semantically consistent with the reference videos.
   </p>
   <!-- <div class="figure">
    <video autoplay="" loop="" muted="" playsinline="">
     <source src="videos/overview_video.mp4" type="video/mp4"/>
     Your browser does not support the video tag.
    </video>
   </div> -->
   <div class="figure">
    <img alt="Method overview" src="method.png"/>
   </div>


   

   <div class="section-title">
    
    Applications
   </div>
   <p>Our Video-as-Prompt model supports various downstream applications: 
    <br>
    (1) Different reference videos (different semantic) &rarr; same reference images: generate the video aligned with each semantics consistently; 
    <br>
    (2) Different reference videos (same semantic) &rarr; same reference images: generate the video aligned with the provided semantics consistently; 
    <br>
    (3) Same reference videos &rarr; different reference images: transfer the same semantic (concept/style/motion/camera) to different reference images; 
    <br>
    (4) Same reference video &amp; image + user-modified prompt: preserve semantics and identity while using prompt to adjust fine-grained attributes.
   </p>

  
  

  <div class="media-grid four-cols">


    <div class="subsection-header">
      <div class="subsection-title dvsi-enabled">Different Reference Video (different semantic) and Same Reference Images</div>
      <p class="footnotes">
        <em>
          Given different reference videos with the different semantic and a reference image, our model can also generate videos aligned with each semantics in the given reference videos.
        </em>
      </p>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_cloning--man-19--man-315.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_cloning--man-19--man-315.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_couple_arrival--man-19--woman-566.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_couple_arrival--man-19--woman-443.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_gender_swap--man-19--man-443.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_gender_swap--man-19--man-303.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_ghibli--man-19--man-780.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_ghibli--man-19--man-780.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_ladudu_me--man-19--man-926.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_ladudu_me--man-19--man-926.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_mecha_x--man-19--man-16.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_mecha_x--man-19--man-16.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_paperman--man-19--man-773.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_paperman--man-19--man-773.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_shake_it_dance--man-19--woman-575.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_shake_it_dance--man-19--woman-575.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_spin360--man-19--man-419.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_spin360--man-19--man-419.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/vidu_hitchcock_zoom--man-19--man-1007.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/vidu_hitchcock_zoom--man-19--man-1007.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/zoom_in--man-19--woman-14.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/zoom_in--man-19--woman-14.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ours/zoom_out--man-19--animal-21.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_multi_kind/ref/zoom_out--man-19--animal-21.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>



    <div class="subsection-header">
      <!-- <div class="subsection-title">Different Reference Video (same semantic) and Same Reference Images</div> -->
      <div class="subsection-title dvsi-enabled">Different Reference Video (same semantic) and Same Reference Images</div>
      <p class="footnotes">
        <em>
          Given different reference videos with the same semantic and a reference image, our model can consistently generate videos aligned with the provided semantics in the given reference videos.
        </em>
      </p>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ladudu_me--man-6--man-347.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ladudu_me--man-6--man-347.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ladudu_me--man-6--man-692.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ladudu_me--man-6--man-692.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ladudu_me--man-6--woman-14.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ladudu_me--man-6--woman-14.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ghibli--man-65--child-26.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ghibli--man-65--child-26.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ghibli--man-65--man-614.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ghibli--man-65--man-614.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_ghibli--man-65--woman-677.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_ghibli--man-65--woman-677.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/kling_expansion--animal-15--animal-88.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/kling_expansion--animal-15--animal-88.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/kling_expansion--animal-15--child-69.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/kling_expansion--animal-15--child-69.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/kling_expansion--animal-15--object-1088.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/kling_expansion--animal-15--object-1088.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_cloning--child-1--man-2.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_cloning--child-1--man-2.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_cloning--child-1--object-11.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_cloning--child-1--object-11.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_cloning--child-1--woman-162.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_cloning--child-1--woman-162.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_covered_liquid_metal--animal-490--animal-36.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_covered_liquid_metal--animal-490--animal-36.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_covered_liquid_metal--animal-490--woman-39.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_covered_liquid_metal--animal-490--woman-39.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_covered_liquid_metal--animal-490--cartoon-16.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_covered_liquid_metal--animal-490--cartoon-16.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_minecraft--woman-41--animal-24.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_minecraft--woman-41--animal-24.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_minecraft--woman-41--child-47.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_minecraft--woman-41--child-47.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_minecraft--woman-41--woman-825.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_minecraft--woman-41--woman-825.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_shake_it_dance--woman-116--man-218.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_shake_it_dance--woman-116--man-218.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_shake_it_dance--woman-116--woman-235.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_shake_it_dance--woman-116--woman-235.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ours/vidu_shake_it_dance--woman-116--woman-339.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/application/same_ref_img_diff_ref_video_single_kind/ref/vidu_shake_it_dance--woman-116--woman-339.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    
  </div>

  <div class="media-grid four-cols cols-4 no-badges" id="same-ref-video-diff-img">
    <div class="subsection-header">
      <div class="subsection-title">Same Reference Video and Different Reference Images</div>
      <p class="footnotes">
        <em>
          Given a reference video, our model can generate new videos based on different reference images that are semantically consistent with the reference video.
        </em>
      </p>
    </div>  
    
  
    <!-- 列名（与四列视频一一对应） -->
    <div class="col-heads cols-4">
      <div class="col-head">Reference Video</div>
      <div class="col-head">Generated Video 1</div>
      <div class="col-head">Generated Video 2</div>
      <div class="col-head">Generated Video 3</div>
    </div>
  
  
    <!-- Row 1: ladudu_me, ref: man-926（取第一个例子的 ref） -->
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_ladudu_me--man-179--man-926.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ladudu_me--man-179--man-926.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ladudu_me--man-531--man-926.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ladudu_me--man-19--man-926.mp4" type="video/mp4"/>
      </video>
    </div></div>

     <!-- Row 5: ghibli, ref: man-275 -->
     <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_ghibli--man-23--man-275.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ghibli--man-23--man-275.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ghibli--man-27--man-275.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_ghibli--man-119--man-275.mp4" type="video/mp4"/>
      </video>
    </div></div>

    <!-- Row 6: kling_expansion, ref: animal-2 -->
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/kling_expansion--animal-12--animal-2.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/kling_expansion--animal-12--animal-2.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/kling_expansion--animal-15--animal-2.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/kling_expansion--animal-24--animal-2.mp4" type="video/mp4"/>
      </video>
    </div></div>
  
    <!-- Row 2: cloning, ref: animal-56 -->
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_cloning--animal-4--animal-56.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_cloning--animal-4--animal-56.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_cloning--animal-9--animal-56.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_cloning--animal-393--animal-56.mp4" type="video/mp4"/>
      </video>
    </div></div>
  
    <!-- Row 3: covered_liquid_metal, ref: animal-358 -->
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_covered_liquid_metal--animal-4--animal-358.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_covered_liquid_metal--animal-14--animal-358.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_covered_liquid_metal--animal-42--animal-358.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_covered_liquid_metal--animal-4--animal-358.mp4" type="video/mp4"/>
      </video>
    </div></div>

    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_hitchcock_zoom--man-10--man-1007.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_hitchcock_zoom--man-10--man-1007.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_hitchcock_zoom--man-16--man-1007.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_hitchcock_zoom--man-266--man-1007.mp4" type="video/mp4"/>
      </video>
    </div></div>



    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_mecha_x--man-23--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_mecha_x--man-23--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_mecha_x--man-182--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_mecha_x--man-692--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>



  
    <!-- Row 4: shake_it_dance, ref: man-16 -->
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ref/vidu_shake_it_dance--man-34--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_shake_it_dance--man-34--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_shake_it_dance--man-456--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
    <div class="media-item"><div class="image-container">
      <video class="preview fill-video" autoplay loop muted playsinline>
        <source src="videos/application/same_ref_video_diff_img/ours/vidu_shake_it_dance--man-529--man-16.mp4" type="video/mp4"/>
      </video>
    </div></div>
  
   
  
    
  
  </div>

  <div class="media-grid four-cols">

    <div class="media-grid four-cols no-badges" id="srviump-block">
      <div class="subsection-header">
        <div class="subsection-title srviump-enabled">
          Same Reference Video & Image and User-Modified Prompt
        </div>
        <p class="footnotes">
          <em>
            Given a reference video and a reference image, our model can preserve semantics and identity while using prompt to adjust some fine-grained attributes.
          </em>
        </p>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--black.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--black.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>black</strong> fur...
          </div>
        </div>
        </div>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--golden.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--golden.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>golden</strong> fur...
          </div>
        </div>
        </div>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--green.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--green.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>green</strong> fur...
          </div>
        </div>
        </div>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--purple.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--purple.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>purple</strong> fur...
          </div>
        </div>
        </div>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--red.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--red.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>red</strong> fur...
          </div>
        </div>
        </div>
      </div>

      <div class="media-item">
        <div class="image-container">
        <div class="prompt-wrap full-screen-wrap" style="position: relative;">
          <div class="container">
          <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ours/vidu_ladudu_me--woman-7--man-534--white.mp4" type="video/mp4"/>
          </video>
          <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
            <source src="videos/application/same_ref_img_ref_video_edit_caption/ref/vidu_ladudu_me--woman-7--man-534--white.mp4" type="video/mp4"/>
          </video>
          <div class="slider" id="slider" style="left: 40%;">
          </div>
          </div>
          <div class="prompt">
          ... a Ladudu toy character with <strong>white</strong> fur...
          </div>
        </div>
        </div>
      </div>

    </div>



   </div>



   <div class="section-title">
    
    Zero-Shot&nbsp;Semantic-Guided&nbsp;Generation
   </div>
   <p>
    Given reference videos with unseen semantics, our model can generate videos that are semantically consistent with the reference videos in a zero-shot manner.
   </p>

   <div class="media-grid four-cols">
    
    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/crumble_res1.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/crumble_ref1.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/crumble_res2.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/crumble_ref2.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/desslove_res1.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/desslove_ref1.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/levitate_res1.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/levitate_ref1.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/levitate_res2.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/levitate_ref2.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

    <div class="media-item">
      <div class="image-container">
      <div class="prompt-wrap full-screen-wrap" style="position: relative;">
        <div class="container">
        <video class="slidervideo lazy-video" id="media1" preload="none" muted playsinline loop data-autoplay="true">
          <source src="videos/benchmark_cog_vap/zero_shot/melt_res1.mp4" type="video/mp4"/>
        </video>
        <video class="slidervideo lazy-video" id="media2" preload="none" muted playsinline loop data-autoplay="true" style="clip-path: inset(0px 40% 0px 0px); margin-left: -100%;">
          <source src="videos/benchmark_cog_vap/zero_shot/melt_ref1.mp4" type="video/mp4"/>
        </video>
        <div class="slider" id="slider" style="left: 40%;">
        </div>
        </div>
        <!-- <div class="prompt">
        Prompt: (add here)
        </div> -->
      </div>
      </div>
    </div>

   </div>





   

   

   
   



  </div>
  </div>
  <div aria-hidden="true" class="lightbox" id="lightbox">
   <div aria-modal="true" class="lightbox-content" role="dialog">
    <button aria-label="Close" class="close-btn" id="lightboxClose">
     &times;
    </button>
    <video controls="" id="lightboxVideo" playsinline="">
    </video>
   </div>
  </div>
  <script>
   (function(){ const previews = document.querySelectorAll('video.preview'); const lightbox = document.getElementById('lightbox'); const lightboxVideo = document.getElementById('lightboxVideo'); const closeBtn = document.getElementById('lightboxClose'); function openLightbox(src){ if(!src) return; lightboxVideo.src = src; lightbox.classList.add('show'); document.body.style.overflow = 'hidden'; const playPromise = lightboxVideo.play(); if (playPromise && typeof playPromise.catch === 'function') { playPromise.catch(() => {/* ignore */}); } } function closeLightbox(){ if(!lightbox.classList.contains('show')) return; lightboxVideo.pause(); lightboxVideo.removeAttribute('src'); lightbox.classList.remove('show'); document.body.style.overflow = ''; } previews.forEach(v => { v.addEventListener('click', () => { const sourceEl = v.querySelector('source'); const src = sourceEl ? sourceEl.getAttribute('src') : v.getAttribute('src'); openLightbox(src); }); }); closeBtn.addEventListener('click', closeLightbox); lightbox.addEventListener('click', (e) => { if (e.target === lightbox) closeLightbox(); }); document.addEventListener('keydown', (e) => { if (e.key === 'Escape') closeLightbox(); }); const copyBtn = document.getElementById('copyBib'); if(copyBtn){ copyBtn.addEventListener('click', () => { const pre = document.querySelector('#bibtex pre'); if(!pre) return; const text = pre.textContent; navigator.clipboard.writeText(text).then(() => { const old = copyBtn.textContent; copyBtn.textContent = 'Copied!'; setTimeout(() => { copyBtn.textContent = old; }, 1200); }).catch(() => {/* ignore */}); }); } })();
  </script>
  <script>

(function(){
  const containers = document.querySelectorAll('.prompt-wrap .container');
  containers.forEach(container => {
    let isDragging = true;
    const slider = container.querySelector('.slider');
    const media2 = container.querySelector('#media2');
    container.addEventListener('mousedown', () => { isDragging = true; });
    container.addEventListener('mouseup', () => { isDragging = true; });
    container.addEventListener('mousemove', (event) => {
      if (!isDragging) return;
      const {clientX} = event;
      const {left, width} = container.getBoundingClientRect();
      let percentage = (clientX - left) / width * 100;
      percentage = Math.max(0, Math.min(100, percentage));
      media2.style.clipPath = `inset(0 ${100 - percentage}% 0 0)`;
      container.style.setProperty('--cut', `${100 - percentage}%`);
      slider.style.left = `${percentage}%`;
      container.style.setProperty('--cut', `${100 - percentage}%`);

    });
    slider.style.left = '40%';
    container.style.setProperty('--cut', '40%'); 
  });
})();
  </script>
  <script>
    (function(){
      document.querySelectorAll('.prompt-wrap .container').forEach(container=>{
        /* Generation 角标层（在两段视频之间） */
        if(!container.querySelector('.gen-clip')){
          const genClip = document.createElement('div');
          genClip.className = 'gen-clip';
          const g = document.createElement('div');
          g.className = 'gen-badge';
          g.textContent = 'Generation';
          genClip.appendChild(g);
          container.appendChild(genClip);
        }
    
        /* Reference 角标层（在 #media2 上方，随同裁切） */
        if(!container.querySelector('.ref-clip')){
          const refClip = document.createElement('div');
          refClip.className = 'ref-clip';
          const r = document.createElement('div');
          r.className = 'ref-badge';
          r.textContent = 'Reference';
          refClip.appendChild(r);
          container.appendChild(refClip);
        }
    
        /* 初始化 --cut 与当前 slider 一致（默认为 40% 左 / 40% 右） */
        const slider = container.querySelector('.slider');
        const leftPct = slider && slider.style.left ? parseFloat(slider.style.left) : 60;
        container.style.setProperty('--cut', (100 - leftPct) + '%');
      });
    })();
    </script>
  
  <script>


    
    (function(){
      function transformSection(sectionTitleEl){
        const header = sectionTitleEl.closest('.subsection-header');
        if (!header) return;
    

        let node = header.nextElementSibling;
        const items = [];
        while (node && !node.classList.contains('subsection-header')) {
          if (node.classList && node.classList.contains('media-item')) items.push(node);
          node = node.nextElementSibling;
        }
    

        items.forEach(item => {
          const container = item.querySelector('.image-container');
          if (!container) return;
    

          const vSources = item.querySelectorAll('video source');
          if (vSources.length < 2) return;
          const oursSrc = vSources[0].getAttribute('src');
          const refSrc  = vSources[1].getAttribute('src');
    

          const overlay = document.createElement('div');
          overlay.className = 'image-container overlay-frame';
          overlay.innerHTML = `
            <video class="gen-video fill-video" autoplay muted loop playsinline>
              <source src="${oursSrc}" type="video/mp4"/>
            </video>
            <div class="ref-thumb-wrap" title="Hover to hide the reference video">
              <video class="ref-thumb" autoplay muted loop playsinline>
                <source src="${refSrc}" type="video/mp4"/>
              </video>
              <div class="corner-badge ref">Reference</div>
            </div>
            <div class="corner-badge gen">Generation</div>
          `;
    

          const old = container.querySelector('.prompt-wrap') || container.firstElementChild;
          if (old) {
            container.replaceChild(overlay, old);
          } else {
            container.innerHTML = overlay.outerHTML;
          }
          item.classList.add('overlay-card');
        });
      }
    
      document.addEventListener('DOMContentLoaded', () => {

        document.querySelectorAll('.subsection-title.dvsi-enabled').forEach(transformSection);
    

        function tryPlayAll(scope){
          scope.querySelectorAll('.overlay-card video').forEach(v => {
            v.muted = true;
            const p = v.play();
            if (p && typeof p.catch === 'function') { p.catch(()=>{}); }
          });
        }
        tryPlayAll(document);
        window.addEventListener('click', () => tryPlayAll(document), { once: true });
      });
    })();
    </script>
  
  <script>
    (function(){

      const TEMP_REF_IMAGE_SRC = 'videos/application/same_ref_img_ref_video_edit_caption/ref.png';
    
      function setupSRVIUMP(){
        const grid = document.getElementById('srviump-block');
        if (!grid) return;
    

        const header = grid.querySelector('.subsection-header');
        if (header && !grid.querySelector('.ref-pair')) {

          const firstItem = grid.querySelector('.media-item');
          let refSrc = null;
          if (firstItem) {
            const vids = firstItem.querySelectorAll('video source');
            if (vids.length >= 2) {
              refSrc = vids[1].getAttribute('src'); 
            }
          }
          const pair = document.createElement('div');
          pair.className = 'ref-pair';
          pair.innerHTML = `
            <div class="ref-card">
              <div class="ref-title">Reference Video</div>
              <div class="image-container">
                ${refSrc ? `
                  <video class="fill-video" autoplay muted loop playsinline>
                    <source src="${refSrc}" type="video/mp4"/>
                  </video>` : `
                  <div class="media-caption">Reference video missing</div>`}
              </div>
            </div>
            <div class="ref-card">
              <div class="ref-title">Reference Image</div>
              <div class="image-container">
                <img src="${TEMP_REF_IMAGE_SRC}" alt="Reference Image"/>
              </div>
            </div>`;
          grid.insertBefore(pair, header.nextSibling);
        }
    

        grid.querySelectorAll('.media-item').forEach(item => {
          const wrapper = item.querySelector('.image-container');
          if (!wrapper) return;
    

          let oursSrc = null;
          const ours = item.querySelector('video#media1 source') || item.querySelectorAll('video source')[0];
          if (ours) oursSrc = ours.getAttribute('src');
    

          const promptEl = item.querySelector('.prompt');
          const promptText = promptEl ? promptEl.textContent.trim() : '';
    

          if (oursSrc) {
            wrapper.innerHTML = `
              <video class="fill-video" autoplay muted loop playsinline>
                <source src="${oursSrc}" type="video/mp4"/>
              </video>`;
          } else {

            wrapper.innerHTML = '';
          }
    

          item.querySelectorAll('.prompt-wrap,.container,.slider,.gen-clip,.ref-clip').forEach(n => n.remove());
    

          if (promptText) {
            let block = item.querySelector('.prompt-block');
            if (!block) {
              block = document.createElement('div');
              block.className = 'prompt-block';
              item.appendChild(block);
            }
            const promptHTML = promptEl ? promptEl.innerHTML.trim() : '';

            block.innerHTML = promptHTML;

          }
        });
      }
    
      document.addEventListener('DOMContentLoaded', setupSRVIUMP);
    })();
    </script>
  <script>
    (function(){
      const inView = new IntersectionObserver((entries)=>{
        for (const e of entries){
          const v = e.target;
          if (e.isIntersecting){

            const sources = v.querySelectorAll('source[data-src]');
            sources.forEach(s=>{
              s.src = s.dataset.src;
              s.removeAttribute('data-src');
            });

            if (v.preload === 'none') v.preload = 'metadata';
            v.load();
            v.addEventListener('canplay', ()=>{
              if (v.dataset.autoplay === 'true' || v.autoplay){

                v.play().catch(()=>{ /* 忽略自动播放失败 */ });
              }
            }, { once:true });
          }else{

            if (!v.paused) v.pause();
          }
        }
      }, { rootMargin: '200px 0px' }); 
    

      document.querySelectorAll('video.lazy-video').forEach(v=>{

        v.preload = 'none';
        inView.observe(v);
      });
    

    })();
    </script>
    
 </body>
</html>
