<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>Mixture of Contexts for Long Video Generation</title>

  <!-- ----------  STYLES (unchanged)  ---------- -->
  <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}

    /* call-to-action buttons */
    .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 layout */
    .media-grid{display:flex;gap:20px;margin:40px 0;align-items:stretch;flex-wrap:nowrap;justify-content:center}
    .media-grid.wrap{flex-wrap:wrap}
    /* grid showing 3 at a time (wrapping) */
    .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)}
    /* grid showing 4 at a time (wrapping) */
    .media-grid.four-cols-4{display:flex;gap:20px;justify-content:flex-start;flex-wrap:wrap;overflow:visible}
    .media-grid.four-cols-4 .media-item{flex:0 0 calc((100% - 80px)/4)}
    /* extra gutter between column 2 and 3 (desktop only) */
    .media-grid.four-cols-4 .media-item:nth-child(4n+3){margin-left:20px}
    .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 styling */
    .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 */
    .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}}

    /* variable column helpers */
    .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}

    /* mobile tweaks */
    @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-grid.four-cols-4 .media-item{flex:0 0 calc((100% - 20px)/2)}
      .media-grid.four-cols-4 .media-item:nth-child(4n+3){margin-left:0}
    }
    @media (max-width:480px){
      .media-grid.four-cols .media-item{flex:0 0 100%}
      .media-grid.four-cols-4 .media-item{flex:0 0 100%}
      .media-grid.four-cols-4 .media-item:nth-child(4n+3){margin-left:0}
    }

    /* clickable previews */
    .media-item video.preview{cursor:pointer}

    /* lightbox modal */
    .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}

    /* slider styles removed */
  </style>
</head>
<body>
  <div class="container">
    <!-- HEADER -->
    <header>
      <h1>Mixture of Contexts for Long Video Generation</h1>
      <div class="tagline">“Minute-long context memory with short-video cost”</div>
      <div class="authors">
        Anonymous Authors
      </div>
    </header>

    <!-- ROUTING OVERVIEW FIGURE -->
    <div class="section-title">Learnable&nbsp;Sparse&nbsp;Attention&nbsp;Routing</div>
    <p>
      A non-parametric yet learnable router selects informative history chunks to calculate attention. The routing is implicitly differentiable and optimized end-to-end from large-scale long video data.
    </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>
  
    <!-- ===================================================== -->
    <!-- 1)  MULTI-SHOT  QUALITATIVE RESULTS                   -->
    <!-- ===================================================== -->
    <div class="section-title">Multi-shot&nbsp;Long&nbsp;Video&nbsp;Generation</div>
    <p>
      For 8-shot, minute-long videos (~180k tokens), MoC prunes&nbsp;≈&nbsp;85 % of token pairs
      and cuts FLOPs by 7× while delivering minute-long context coherence.
    </p>
    <p class="footnotes"><em>Some prompts are from Twitter artworks.</em></p>

    <div class="media-grid four-cols">
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_0.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_1.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_6.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_12.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_13.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_11.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_2.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_8.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_9.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
    </div>

    <!-- ===================================================== -->
    <!-- 2)  SINGLE-SHOT  QUALITATIVE RESULTS                  -->
    <!-- ===================================================== -->
    <div class="section-title">Single-shot&nbsp;Short&nbsp;Video&nbsp;Generation</div>
    <p>
      On 8-second, 320×192 clips (~6.5k tokens), MoC routing prunes&nbsp;≈&nbsp;83 % of token pairs,
      while maintaining or even improving video quality.
    </p>
    <div class="media-grid four-cols">
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/0_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/1_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/2_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/3_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/4_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/5_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/6_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/7_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/8_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/9_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/10_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/11_ours.mp4" type="video/mp4" />
          </video>
        </div>
      </div>
    </div>

    <!-- ===================================================== -->
    <!--     QUALITATIVE COMPARISONS (Baseline vs Ours)        -->
    <!-- ===================================================== -->
    <div class="section-title">Qualitative&nbsp;Comparisons</div>
    <p>Side-by-side comparisons between dense attention and our Mixture of Contexts.</p>

    <div class="section-title">Multi-shot&nbsp;Comparisons</div>
    <div class="media-grid wrap">
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_0.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_0.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_1.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_1.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_2.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_2.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_6.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_6.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_7.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_7.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_8.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_8.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/lct_multishot/lct_multishot_9.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/ours_multishot/ours_multishot_9.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>
    </div>

    <div class="section-title">Single-shot&nbsp;Comparisons</div>
    <div class="media-grid wrap four-cols-4">
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/0_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/0_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/1_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/1_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/2_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/2_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/3_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/3_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/4_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/4_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/5_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/5_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/6_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/6_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/7_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/7_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/8_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/8_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/9_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/9_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/10_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/10_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>

      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/11_base.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption">Dense Attention</div>
      </div>
      <div class="media-item">
        <div class="image-container">
          <video autoplay loop muted playsinline class="preview">
            <source src="videos/singleshot/11_ours.mp4" type="video/mp4" />
          </video>
        </div>
        <div class="media-caption emph">Mixture of Contexts (ours)</div>
      </div>
    </div>
  
  <!-- Lightbox Modal -->
  <div class="lightbox" id="lightbox" aria-hidden="true">
    <div class="lightbox-content" role="dialog" aria-modal="true">
      <button class="close-btn" id="lightboxClose" aria-label="Close">×</button>
      <video id="lightboxVideo" controls 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';
        // attempt autoplay after user gesture
        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();
      });

      // slider logic removed

      // Copy BibTeX
      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>
</body>
</html>
