<!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <meta name="viewport" content="width=device-width, initial-scale=1.0">
     <title>EditVerse Project Page</title>
     <link rel="preconnect" href="https://fonts.googleapis.com">
     <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap" rel="stylesheet">
     <style>
         :root {
             --background-color: #0a0a0a;
             --text-color: #cccccc;
             --heading-color: #ffffff;
             --accent-color: #2563eb;
             --container-width: 1100px;
         }

         body {
             background-color: var(--background-color);
             color: var(--text-color);
             font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
             line-height: 1.7;
             margin: 0;
             padding: 0;
             font-size: 16px;
         }

         .container {
             max-width: var(--container-width);
             margin: 0 auto;
             padding: 20px;
         }

         header {
             text-align: center;
             padding: 30px 0 30px;
         }

         header h2 {
             margin-bottom: 20px;
             line-height: 1.2; 
         }

         h1 {
             font-size: 3.5rem;
             font-weight: 700;
             color: var(--heading-color);
             margin-bottom: 0.5em;
             letter-spacing: -1.5px;
         }

         .authors {
             display: flex;
             justify-content: center;
             flex-wrap: wrap;
             gap: 0.5em;
             font-size: 1.1rem;
             margin: 15px 0;
             color: #b0b0b0;
             padding: 0 20px;
         }
         
         .authors a {
             color: var(--heading-color);
             text-decoration: none;
         }
         
         .authors a:hover {
             text-decoration: underline;
         }

         .affiliations {
             display: flex;
             justify-content: center;
             flex-wrap: wrap;
             gap: 1.5em;
             font-size: 1rem;
             color: #888;
             margin-top: -10px;
         }

         .links {
             margin-top: 10px;
             margin-bottom: -60px;
             display: flex;
             justify-content: center;
             flex-wrap: wrap;
             gap: 15px;
         }

         .links a {
             background-color: #1a1a1a;
             color: var(--heading-color);
             text-decoration: none;
             border: 1px solid #333;
             padding: 12px 24px;
             border-radius: 999px;
             font-weight: 600;
             transition: all 0.2s ease-in-out;
             display: inline-flex;
             align-items: center;
         }

         .links a:hover {
             background-color: #555555;
             border-color: #555555;
             color: var(--heading-color);
             transform: translateY(-2px);
             box-shadow: 0 4px 20px rgba(180, 180, 180, 0.2);
         }
         
         .links a img {
             height: 1.6em; 
             margin-right: 8px; 
         }

         section {
             padding: 50px 0;
         }
         
         h2 {
             font-size: 2.5rem;
             font-weight: 700;
             text-align: center;
             color: var(--heading-color);
             margin-top: 30px;
             margin-bottom: 30px;
         }

         h3 {
             font-size: 1.5rem;
             font-weight: 500;
             text-align: center;
             color: var(--heading-color);
             margin-top: 20px;
             margin-bottom: 20px;
         }

         h4 {
             text-align: center;
             color: var(--heading-color);
             margin-top: 5px;
             margin-bottom: 5px;
         }

         p, li {
             font-size: 1.1rem;
             max-width: 800px;
             margin-left: auto;
             margin-right: auto;
             margin-bottom: 1em;
             text-align: justify;
         }

         #method p {
             max-width: 1100px;
         }

         .teaser-video {
             width: 90%;
             max-width: 900px;
             margin: 0 auto 20px auto;
             display: block;
             border-radius: 12px;
             box-shadow: 0 8px 30px rgba(0,0,0,0.7);
         }
         
         .caption {
             display: block;
             text-align: center;
             font-size: 1rem;
             color: #888;
             margin-top: 15px;
         }

         .gallery {
             display: grid;
             grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
             gap: 25px;
         }

         .gallery-item {
             position: relative; 
         }

         .gallery-item video, .gallery-item img {
             width: 100%;
             border-radius: 8px;
             display: block;
         }
         
         .gallery-item::before,
         .gallery-item::after {
             position: absolute;
             background-color: rgba(30, 30, 30, 0.7); 
             backdrop-filter: blur(4px); 
             color: #f0f0f0;
             padding: 4px 10px;
             border-radius: 6px;
             font-size: 13px;
             font-weight: 500;
             z-index: 1;
             pointer-events: none; 
             opacity: 0; 
             transition: opacity 0.3s;
         }

         .gallery-item[data-tag-top]::before {
             content: attr(data-tag-top); 
             top: 10px;
             left: 10px; 
             opacity: 1; 
         }
         
         .gallery-item[data-tag-bottom]::after {
             content: attr(data-tag-bottom); 
             bottom: 10px;
             right: 10px; 
             opacity: 1; 
         }

         .gallery-item .prompt {
             background-color: #181818;
             padding: 12px;
             border-radius: 6px;
             margin-top: 12px;
             font-size: 0.95rem;
             border: 1px solid #2a2a2a;
         }

         .comparison-grid {
             display: grid;
             grid-template-columns: 1fr 1fr 1fr;
             gap: 20px;
             align-items: start;
         }

         .comparison-grid h3 {
             text-align: center;
             color: #aaa;
             font-weight: 400;
             margin-bottom: 10px;
         }

         pre {
             background-color: #161616;
             color: #e0e0e0;
             padding: 25px;
             border-radius: 8px;
             border: 1px solid #2a2a2a;
             white-space: pre-wrap;
             word-wrap: break-word;
             font-family: 'SF Mono', 'Courier New', Courier, monospace;
             max-width: 800px;
             margin-left: auto;
             margin-right: auto;
         }

         b, strong {
             color: var(--heading-color);
             font-weight: 600;
         }
         
         #main-comparison-viewer {
             max-width: 550px;
             margin: 0 auto;
         }

         .comparison-slider {
             position: relative;
             overflow: hidden;
             border-radius: 12px;
             box-shadow: 0 8px 30px rgba(0,0,0,0.7);
             line-height: 0;
         }

         .comparison-slider .video-container {
             position: absolute;
             top: 0;
             left: 0;
             width: 100%;
             height: 100%;
             overflow: hidden;
         }

         .comparison-slider .video-before {
             position: relative;
             z-index: 1;
         }

         .comparison-slider .video-after {
             z-index: 2;
             width: 100%; /* Ensure the container is full width */
             clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%); /* Clip to show the left 50% initially */
         }

         .comparison-slider video {
             width: 100%;
             height: 100%;
             object-fit: cover;
             display: block;
         }
         
         #main-comparison-viewer .prompt {
             background-color: #181818;
             padding: 12px;
             border-radius: 6px;
             margin: 12px auto 0 auto;
             font-size: 0.95rem;
             border: 1px solid #2a2a2a;
             max-width: 100%;
             text-align: center;
         }

         .slider-handle {
             position: absolute;
             top: 0;
             left: 50%;
             transform: translateX(-50%);
             width: 4px;
             height: 100%;
             background-color: rgba(255, 255, 255, 0.8);
             cursor: ew-resize;
             z-index: 3;
             display: flex;
             align-items: center;
             justify-content: center;
         }

         .slider-grabber {
             width: 40px;
             height: 40px;
             background-color: rgba(255, 255, 255, 0.8);
             border-radius: 50%;
             border: 2px solid #0a0a0a;
             position: relative;
         }
         
         .slider-grabber::before,
         .slider-grabber::after {
             content: '';
             position: absolute;
             top: 50%;
             width: 0;
             height: 0;
             border-style: solid;
             transform: translateY(-50%);
         }
         .slider-grabber::before {
             border-width: 6px 8px 6px 0;
             border-color: transparent #0a0a0a transparent transparent;
             left: 8px;
         }
         .slider-grabber::after {
             border-width: 6px 0 6px 8px;
             border-color: transparent transparent transparent #0a0a0a;
             right: 8px;
         }
         
         .slider-tag {
             position: absolute;
             top: 10px;
             background-color: rgba(30, 30, 30, 0.7);
             backdrop-filter: blur(4px);
             color: #f0f0f0;
             padding: 4px 10px;
             border-radius: 6px;
             font-size: 13px;
             font-weight: 500;
             z-index: 4;
             pointer-events: none;
             line-height: normal;
         }

         .video-before .slider-tag { right: 10px; }
         .video-after .slider-tag { left: 10px; }

         #thumbnail-gallery {
             display: flex;
             justify-content: center;
             flex-wrap: wrap;
             gap: 15px;
             margin-top: 40px;
         }

         .thumbnail-item {
             width: 80px;
             border: 3px solid #333;
             border-radius: 8px;
             cursor: pointer;
             overflow: hidden;
             transition: all 0.2s ease-in-out;
             opacity: 0.6;
         }

         .thumbnail-item:hover {
             border-color: #777;
             transform: translateY(-3px);
             opacity: 1;
         }

         .thumbnail-item.active {
             border-color: var(--heading-color);
             box-shadow: 0 0 15px rgba(255, 255, 255, 0.4);
             opacity: 1;
             transform: translateY(-3px);
         }

         .thumbnail-item video {
             width: 100%;
             height: 100%;
             object-fit: cover;
             display: block;
         }
        .table-container {
            max-width: 1100px;
            margin: 40px auto;
            overflow-x: auto; 
        }
        table.comparison-table {
            width: 100%;
            border-collapse: collapse;
            color: var(--text-color);
            font-size: 1rem;
            text-align: center;
            white-space: nowrap;
        }
        .comparison-table th, .comparison-table td {
            padding: 12px 15px;
            border-top: 1px solid #2a2a2a;
            border-bottom: 1px solid #2a2a2a;
        }
        .comparison-table thead {
            background-color: #1a1a1a;
            border-bottom: 2px solid #444;
        }
        .comparison-table th {
            color: var(--heading-color);
            font-weight: 600;
        }
        .comparison-table tbody tr:nth-child(even) {
            background-color: #101010;
        }
        .comparison-table tr.section-header td {
            background-color: #202020;
            font-weight: 600;
            text-align: center;
            color: var(--heading-color);
            padding: 10px;
            border-top: 2px solid #444;
            border-bottom: 1px solid #333;
        }
        .comparison-table .grayed-out {
            color: #888;
        }
        .comparison-table .grayed-out strong {
            color: #999;
        }
        .table-caption {
            max-width: 900px;
            margin: 20px auto 0 auto;
            text-align: justify;
            font-size: 1rem;
            color: #aaa;
            line-height: 1.6;
        }
        .dual-cta-container {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 30px;
            max-width: 1000px;
            margin: 60px auto;
            align-items: stretch;
        }

        #comparison-cta {
            margin: 0;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }

        #comparison-cta, #user-study-container {
            background: #1c1c1c;
            border: 1px solid #333;
            border-radius: 12px;
            transition: all 0.3s ease-in-out;
        }
        
        #comparison-cta:hover, #user-study-container:hover {
            transform: translateY(-5px);
            box-shadow: 0 8px 40px rgba(90, 160, 255, 0.25);
            border-color: #4a90e2;
        }

        #comparison-cta a {
            display: flex;
            align-items: center;
            justify-content: center;
            flex-grow: 1;
            padding: 25px 30px;
            color: var(--heading-color);
            font-size: 1.4rem;
            font-weight: 600;
            text-decoration: none;
            letter-spacing: 0.5px;
            transition: color 0.3s ease-in-out;
            text-align: center;
        }
        #comparison-cta:hover a {
            color: #fff;
        }

        #user-study-container {
            padding: 20px 25px;
            box-sizing: border-box;
        }
        #user-study-container h3 {
            margin-top: 0;
            margin-bottom: 18px;
            font-size: 1.3rem;
        }
        
        .user-study-chart-area {
            display: flex;
            align-items: stretch;
            gap: 15px;
        }

        .y-axis-label {
            writing-mode: vertical-rl;
            transform: rotate(180deg);
            text-align: center;
            font-size: 0.9rem;
            color: #aaa;
        }

        .chart-bars-container {
            width: 100%;
            display: flex;
            flex-direction: column;
            gap: 8px;
        }

        .chart-row {
            display: flex;
            align-items: center;
            gap: 10px;
            font-size: 0.9rem;
        }

        .chart-bar {
            flex-grow: 1;
            display: flex;
            height: 24px;
            border-radius: 4px;
            overflow: hidden;
            font-size: 0.8rem;
            font-weight: 600;
        }
        .bar-segment {
            display: flex;
            align-items: center;
            justify-content: center;
            color: #111;
        }
        .bar-segment.win  { background-color: #FFD7BA; } 
        .bar-segment.tie  { background-color: #eeeeee; } 
        .bar-segment.fail { background-color: #bababa; } 

        .method-label {
            color: #ccc;
            white-space: nowrap;
            width: 110px; 
        }
        
        .chart-legend {
            display: flex;
            justify-content: center;
            gap: 15px;
            margin-top: 15px;
            font-size: 0.85rem;
        }
        .legend-item { display: flex; align-items: center; gap: 6px; }
        .legend-color { width: 12px; height: 12px; border-radius: 3px; }

        @media (max-width: 900px) {
            .dual-cta-container {
                grid-template-columns: 1fr;
                gap: 20px;
            }
            #comparison-cta a { min-height: 100px; }
        }

     </style>
 </head>
 <body>

 <div class="container">

     <header>
         <h2>EditVerse: Unifying Image and Video Editing and Generation with In-Context Learning</h2>
     </header>

     <main>

         <section id="gallery">
             <h2>Video Editing</h2>
             <h3>Single Input</h3>
             <div id="main-comparison-viewer">
                 <div class="comparison-slider">
                     <div class="video-container video-before">
                         <video id="main-after-video" autoplay muted loop playsinline poster="https://via.placeholder.com/900x506.png/000000?text=Loading..."></video>
                         <div class="slider-tag">After</div>
                     </div>
                     <div class="video-container video-after">
                         <video id="main-before-video" autoplay muted loop playsinline poster="https://via.placeholder.com/900x506.png/000000?text=Loading..."></video>
                         <div class="slider-tag">Before</div>
                     </div>
                     <div class="slider-handle"><div class="slider-grabber"></div></div>
                 </div>
                 <div class="prompt" id="main-prompt"></div>
             </div>
             
             <div id="thumbnail-gallery">
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_0/video1.mp4"
                      data-after-src="./video/comparison_0/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Add an intense magical golden glow around the rabbit, with soft ethereal light rays emanating from behind it, creating a mystical aura.&quot;">
                     <video src="./video/comparison_0/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_1/video1.mp4"
                      data-after-src="./video/comparison_1/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Change the turtle's shell material to crystal, reflecting light beautifully.&quot;">
                     <video src="./video/comparison_1/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_2/video1.mp4"
                      data-after-src="./video/comparison_2/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Remove all background people, including the blurred figures and anyone not in sharp focus.&quot;">
                     <video src="./video/comparison_2/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_3/video1.mp4"
                      data-after-src="./video/comparison_3/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Inpaint this video. A bright orange rose slowly blooms in the middle of the scene.&quot;">
                     <video src="./video/comparison_3/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_4/video1.mp4"
                      data-after-src="./video/comparison_4/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Detect the mask of the bee.&quot;">
                     <video src="./video/comparison_4/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
                 <div class="thumbnail-item"
                      data-before-src="./video/comparison_5/video1.mp4"
                      data-after-src="./video/comparison_5/generate.mp4"
                      data-prompt="<b>Instruction:</b> &quot;Generate video based on depth map. A colorful bird perches on a branch, carefully inspecting clusters of dark purple berries around it.&quot;">
                     <video src="./video/comparison_5/video1.mp4" autoplay muted loop playsinline poster="https://via.placeholder.com/180x101.png/000000?text=..."></video>
                 </div>
             </div>
         
         <br/>
         <h3>Multiple Input</h3>
            <div class="gallery-item" style="max-width: 900px; margin: auto;">
                 <div class="comparison-grid">
                     <div>
                         <h4>Source Video</h4>
                         <video controls autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Source+Video"><source src="./video/comparison_6/video1.mp4" type="video/mp4"></video>
                     </div>
                     <div>
                         <h4>Reference Image</h4>
                         <img src="./video/comparison_6/image1.png" alt="Source Image" style="width: 100%; border-radius: 8px;">
                     </div>
                     <div>
                         <h4>Edited Video</h4>
                         <video controls autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Edited+Video"><source src="./video/comparison_6/generate.mp4" type="video/mp4"></video>
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "[Source Video] edit the video following the first frame [Reference Image]"</div>
                 <div class="comparison-grid">
                     <div>
                         <h4>Source Video</h4>
                         <video controls autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Source+Video"><source src="./video/comparison_7/video1.mp4" type="video/mp4"></video>
                     </div>
                     <div>
                         <h4>Reference Image</h4>
                         <img src="./video/comparison_7/image1.png" alt="Source Image" style="width: 100%; border-radius: 8px;">
                     </div>
                     <div>
                         <h4>Edited Video</h4>
                         <video controls autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Edited+Video"><source src="./video/comparison_7/generate.mp4" type="video/mp4"></video>
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "[Source Video] Insert a paper boat in the water [Reference Image] A graceful white swan glides silently across the still surface of a clear lake...Beside it, an orange paper boat drifts lightly."</div>
             
             </div>

         </section>

        

         <section id="gallery">
         <h2>Video Generation</h2>
         <div class="gallery">
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+1">
                     <source src="./video/generation_1.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A person is laughing."</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+2">
                     <source src="./video/generation_2.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A yellow bird."</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+3">
                     <source src="./video/generation_3.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A shark is swimming in the ocean, pixel art."</div>
             </div>
         </div>

         <div class="gallery">
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+1">
                     <source src="./video/generation_4.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A panda standing on a surfboard in the ocean in sunset."</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+2">
                     <source src="./video/generation_5.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A squirrel eating a burger."</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+3">
                     <source src="./video/generation_6.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "Slow motion cropped closeup of roasted coffee beans falling into an empty bowl."</div>
             </div>
         </div>

         <div class="gallery">
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+1">
                     <source src="./video/generation_7.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A raccoon is playing the electronic guitar."</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+2">
                     <source src="./video/generation_8.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A cat wearing sunglasses at a pool"</div>
             </div>
             <div class="gallery-item">
                 <video autoplay muted loop playsinline poster="https://via.placeholder.com/500x300.png/000000?text=Generated+Video+3">
                     <source src="./video/generation_9.mp4" type="video/mp4">
                 </video>
                 <div class="prompt"><b>Instruction:</b> "A banana on the bottom of an apple, front view."</div>
             </div>
         </div>
         </section>



         <section id="gallery">

         <h2>Image Editing & Generation</h2>
         
         <div class="gallery">
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr 1fr;">
                     <div>
                         <h4>Before</h4>
                         <img src="./images/source_1.png" alt="Before">
                     </div>
                     <div>
                         <h4>After</h4>
                         <img src="./images/edit_1.png" alt="After">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "Change the beach in the picture to a mountain landscape."</div>
             </div>
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr 1fr;">
                     <div>
                         <h4>Before</h4>
                         <img src="./images/source_2.png" alt="Before">
                     </div>
                     <div>
                         <h4>After</h4>
                         <img src="./images/edit_2.png" alt="After">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "Make the person raise her right arm."</div>
             </div>
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr 1fr;">
                     <div>
                         <h4>Before</h4>
                         <img src="./images/source_3.png" alt="Before">
                     </div>
                     <div>
                         <h4>After</h4>
                         <img src="./images/edit_3.png" alt="After">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "Transfer the image into a faceted low-poly 3D render style"</div>
             </div>
         </div>
        
         <br/>

         <div class="gallery" style="grid-template-columns: repeat(4, 1fr);">
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr;">
                     <div>
                         <img src="./images/generation_1.png">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "A photo of four chairs."</div>
             </div>
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr;">
                     <div>
                         <img src="./images/generation_2.png">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "A photo of a blue elephant."</div>
             </div>
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr;">
                     <div>
                         <img src="./images/generation_3.png">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "A photo of a stop sign above a fork."</div>
             </div>
             <div class="gallery-item">
                 <div class="comparison-grid" style="grid-template-columns: 1fr;">
                     <div>
                         <img src="./images/generation_4.png">
                     </div>
                 </div>
                 <div class="prompt"><b>Instruction:</b> "A photo of a green suitcase and a blue boat."</div>
             </div>
         </div>

         </section>
     </main>
 </div>

 <script>
 document.addEventListener('DOMContentLoaded', () => {
     const mainBeforeVideo = document.getElementById('main-before-video');
     const mainAfterVideo = document.getElementById('main-after-video');
     const mainPrompt = document.getElementById('main-prompt');
     const thumbnails = document.querySelectorAll('.thumbnail-item');

     function updateViewer(thumbnail) {
         const beforeSrc = thumbnail.dataset.beforeSrc;
         const afterSrc = thumbnail.dataset.afterSrc;
         const promptText = thumbnail.dataset.prompt;

         mainBeforeVideo.src = beforeSrc;
         mainAfterVideo.src = afterSrc;

         mainBeforeVideo.load();
         mainAfterVideo.load();

         mainPrompt.innerHTML = promptText;

         thumbnails.forEach(item => item.classList.remove('active'));
         thumbnail.classList.add('active');
     }

     thumbnails.forEach(thumbnail => {
         thumbnail.addEventListener('click', () => {
             updateViewer(thumbnail);
         });
     });

     if (thumbnails.length > 0) {
         updateViewer(thumbnails[0]);
     }


     const slider = document.querySelector('.comparison-slider');
     if (slider) {
         const handle = slider.querySelector('.slider-handle');
         const videoAfter = slider.querySelector('.video-after');
         let isDragging = false;

         const startDrag = (e) => {
             isDragging = true;
             e.preventDefault();
         };

         const onDrag = (e) => {
             if (!isDragging) return;
             const clientX = e.clientX || (e.touches && e.touches[0].clientX);
             if (clientX === undefined) return;

             const rect = slider.getBoundingClientRect();
             let offsetX = clientX - rect.left;

             if (offsetX < 0) offsetX = 0;
             if (offsetX > rect.width) offsetX = rect.width;
             
             const percentage = (offsetX / rect.width) * 100;
             handle.style.left = `${percentage}%`;
             
             videoAfter.style.clipPath = `polygon(0 0, ${percentage}% 0, ${percentage}% 100%, 0 100%)`;
         };

         const stopDrag = () => {
             isDragging = false;
         };
         
         handle.addEventListener('mousedown', startDrag);
         document.addEventListener('mousemove', onDrag);
         document.addEventListener('mouseup', stopDrag);
         
         handle.addEventListener('touchstart', startDrag, { passive: false });
         document.addEventListener('touchmove', onDrag);
         document.addEventListener('touchend', stopDrag);
     }
 });
 </script>
 </body>
 </html>