<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Epipolar Geometry Improves Video Generation Models</title>
    <link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.0/css/bootstrap.min.css" rel="stylesheet">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
    <style>
        @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
        
        :root {
            --primary: #6366f1;
            --primary-light: #818cf8;
            --primary-dark: #4f46e5;
            --accent: #f97316;
            --accent-gradient: linear-gradient(45deg, #f97316, #f43f5e);
            --text: #0f172a;
            --text-light: #64748b;
            --bg: #ffffff;
            --bg-alt: #f8fafc;
            --border: #e2e8f0;
            --card-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.05), 0 8px 10px -6px rgba(0, 0, 0, 0.03);
            --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        }

        body {
            font-family: 'Inter', sans-serif;
            line-height: 1.7;
            color: var(--text);
            background-color: var(--bg);
            overflow-x: hidden;
        }

        /* Decorative elements */
        .bg-pattern {
            position: absolute;
            background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23a5b4fc' fill-opacity='0.05' fill-rule='evenodd'/%3E%3C/svg%3E");
            width: 100%;
            height: 100%;
            z-index: 0;
            opacity: 0.5;
            pointer-events: none;
        }

        .geometric-accent {
            position: absolute;
            background: var(--accent-gradient);
            opacity: 0.05;
            border-radius: 50%;
            pointer-events: none;
            filter: blur(40px);
            z-index: 0;
        }

        .accent-1 {
            width: 400px;
            height: 400px;
            top: -100px;
            left: -150px;
        }

        .accent-2 {
            width: 600px;
            height: 600px;
            right: -300px;
            top: 400px;
            border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
            background: radial-gradient(circle, rgba(79, 70, 229, 0.15) 0%, rgba(99, 102, 241, 0.05) 70%);
        }

        .accent-3 {
            width: 300px;
            height: 300px;
            left: 10%;
            top: 1200px;
            border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
            background: radial-gradient(circle, rgba(249, 115, 22, 0.1) 0%, rgba(244, 63, 94, 0.05) 70%);
        }

        /* Hero Section */
        .hero {
            position: relative;
            min-height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
            color: white;
            overflow: hidden;
            padding: 80px 0;
        }

        .hero::before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: linear-gradient(45deg, rgba(79, 70, 229, 0.2) 0%, rgba(99, 102, 241, 0) 50%);
            z-index: 1;
        }

        .hero-content {
            position: relative;
            z-index: 2;
            text-align: center;
            max-width: 1000px;
            padding: 0 2rem;
            margin-bottom: 2rem;
        }

        .hero-bg {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            opacity: 0.3;
            object-fit: cover;
        }

        .hero-videos {
            position: relative;
            width: 100%;
            max-width: 1000px;
            margin: 0 auto;
            margin-top: 2rem;
            height: 0;
            padding-bottom: 35%;
            z-index: 2;
            perspective: 1000px;
            transform: translateX(-5%); /* Move left by 5% */
        }

        .video-comparison-hero {
            position: absolute;
            width: 100%;
            height: 100%;
            transform-style: preserve-3d;
            transform: perspective(1000px) rotateY(-8deg) rotateX(5deg); /* Reduced rotation angle */
            transition: var(--transition);
        }

        .video-comparison-hero:hover {
            transform: perspective(1000px) rotateY(-4deg) rotateX(2deg) scale(1.02); /* Reduced rotation angle on hover */
        }

        .video-comparison-hero .video-pane {
            position: absolute;
            width: 100%;
            height: 100%;
            border-radius: 16px;
            overflow: hidden;
            box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
            opacity: 0;
            transition: opacity 0.5s ease-in-out;
        }

        .video-comparison-hero .video-pane.active {
            opacity: 1;
        }

        .video-comparison-hero video {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .hero-video-label {
            position: absolute;
            bottom: 25px;
            left: 25px;
            background: rgba(0, 0, 0, 0.7);
            color: white;
            padding: 8px 20px;
            border-radius: 8px;
            font-size: 16px;
            font-weight: 500;
            z-index: 10;
            pointer-events: none;
        }

        .hero-toggle {
            position: absolute;
            bottom: 15px;
            right: 15px;
            background: rgba(255, 255, 255, 0.15);
            backdrop-filter: blur(10px);
            border-radius: 40px;
            padding: 8px;
            z-index: 10;
            display: flex;
            gap: 4px;
        }

        .hero-toggle-btn {
            border: none;
            background: transparent;
            color: white;
            padding: 12px 24px;
            border-radius: 30px;
            font-weight: 600;
            font-size: 16px;
            cursor: pointer;
            transition: var(--transition);
        }

        .hero-toggle-btn.active {
            background: var(--primary);
            box-shadow: 0 4px 15px rgba(99, 102, 241, 0.4);
        }

        h1 {
            font-size: 5rem;
            font-weight: 800;
            line-height: 1.1;
            margin-bottom: 30px;
            background: linear-gradient(to right, #ffffff, #cbd5e1);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            letter-spacing: -0.02em;
        }

        h2 {
            font-weight: 700;
            font-size: 2.5rem;
            margin-bottom: 1.5rem;
            color: var(--text);
            position: relative;
            display: inline-block;
        }

        h2::after {
            content: "";
            position: absolute;
            bottom: -10px;
            left: 0;
            width: 60px;
            height: 4px;
            background: var(--accent-gradient);
            border-radius: 2px;
        }

        h3 {
            font-weight: 600;
            font-size: 1.5rem;
            margin-top: 2rem;
            margin-bottom: 1rem;
            color: var(--text);
        }

        .authors {
            font-size: 1.5rem;
            font-weight: 400;
            margin-bottom: 10px;
            opacity: 0.9;
        }

        .institute {
            font-size: 1.2rem;
            margin-bottom: 3rem;
            opacity: 0.7;
        }

        .btn-primary {
            background: var(--primary);
            border: none;
            font-weight: 600;
            padding: 14px 30px;
            border-radius: 10px;
            transition: var(--transition);
            font-size: 1.1rem;
        }

        .btn-primary:hover {
            background: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: 0 10px 20px rgba(99, 102, 241, 0.3);
        }

        .btn-outline {
            background: transparent;
            border: 1px solid var(--primary-light);
            color: var(--primary-light);
            font-weight: 600;
            padding: 14px 30px;
            border-radius: 10px;
            transition: var(--transition);
            font-size: 1.1rem;
        }

        .btn-outline:hover {
            background: rgba(99, 102, 241, 0.1);
            transform: translateY(-2px);
            box-shadow: 0 10px 20px rgba(99, 102, 241, 0.1);
        }

        .btn-results {
            background: var(--accent-gradient);
            color: white;
            border: none;
            font-weight: 600;
            padding: 14px 30px;
            border-radius: 10px;
            transition: var(--transition);
            display: inline-flex;
            align-items: center;
            gap: 10px;
            font-size: 1.1rem;
        }

        .btn-results:hover {
            transform: translateY(-2px);
            box-shadow: 0 10px 20px rgba(249, 115, 22, 0.3);
            color: white;
        }

        .section {
            padding: 120px 0;
            position: relative;
        }

        .section-alt {
            background-color: var(--bg-alt);
        }

        .abstract {
            font-size: 1.1rem;
            line-height: 1.8;
            max-width: 800px;
            margin: 0 auto;
        }

        /* Video Comparison Component */
        .video-comparison {
            position: relative;
            width: 100%;
            border-radius: 12px;
            overflow: hidden;
            box-shadow: var(--card-shadow);
            margin: 3rem 0;
            background: #000;
            aspect-ratio: 16/9;
        }

        .video-pane {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            opacity: 0;
            transition: opacity 0.5s ease-in-out;
        }

        .video-pane.active {
            opacity: 1;
        }

        .video-pane video {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .video-controls {
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100%;
            padding: 16px;
            background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 100%);
            display: flex;
            justify-content: space-between;
            align-items: center;
            z-index: 10;
        }

        .video-label {
            color: white;
            font-weight: 500;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .video-toggle {
            display: flex;
            background: rgba(255, 255, 255, 0.15);
            backdrop-filter: blur(8px);
            border-radius: 30px;
            padding: 4px;
        }

        .toggle-btn {
            border: none;
            background: transparent;
            color: white;
            padding: 8px 16px;
            border-radius: 20px;
            font-weight: 500;
            font-size: 14px;
            cursor: pointer;
            transition: var(--transition);
        }

        .toggle-btn.active {
            background: white;
            color: var(--text);
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
        }

        .play-control {
            background: white;
            color: var(--text);
            width: 40px;
            height: 40px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            border: none;
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
            transition: var(--transition);
        }

        .play-control:hover {
            transform: scale(1.1);
        }

        /* Results Grid */
        .result-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(500px, 1fr));
            gap: 2.5rem;
            margin-top: 3rem;
        }

        .result-card {
            position: relative;
            background: white;
            border-radius: 16px;
            overflow: hidden;
            box-shadow: var(--card-shadow);
            transition: var(--transition);
        }

        .result-card:hover {
            transform: translateY(-8px);
            box-shadow: 0 20px 30px rgba(0, 0, 0, 0.1);
        }

        .sync-video-container {
            position: relative;
            width: 100%;
            aspect-ratio: 16/9;
            background: #000;
            overflow: hidden;
        }

        .sync-video-container video {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .result-info {
            padding: 1.5rem;
        }

        .result-title {
            font-weight: 600;
            font-size: 1.2rem;
            margin-bottom: 0.8rem;
            color: var(--text);
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .result-title i {
            color: var(--primary);
            font-size: 1rem;
        }

        .result-description {
            color: var(--text-light);
            font-size: 0.95rem;
            margin-bottom: 1.5rem;
        }

        .sync-video-controls {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-top: 1rem;
        }

        .sync-toggle {
            display: flex;
            background: var(--bg-alt);
            border-radius: 30px;
            padding: 4px;
        }

        .sync-toggle-btn {
            border: none;
            background: transparent;
            color: var(--text-light);
            padding: 8px 16px;
            border-radius: 20px;
            font-weight: 500;
            font-size: 14px;
            cursor: pointer;
            transition: var(--transition);
        }

        .sync-toggle-btn.active {
            background: var(--primary);
            color: white;
        }

        .sync-play-btn {
            background: var(--primary);
            color: white;
            width: 36px;
            height: 36px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            border: none;
            transition: var(--transition);
        }

        .sync-play-btn:hover {
            background: var(--primary-dark);
            transform: scale(1.1);
        }

        /* Method Section */
        .method-diagram {
            width: 100%;
            border-radius: 16px;
            overflow: hidden;
            box-shadow: var(--card-shadow);
            margin: 3rem 0;
        }

        .method-steps {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2.5rem;
            margin: 3rem 0;
        }

        .method-step {
            background: white;
            border-radius: 16px;
            padding: 2rem;
            box-shadow: var(--card-shadow);
            position: relative;
            overflow: hidden;
            transition: var(--transition);
            border: 1px solid var(--border);
        }

        .method-step:hover {
            transform: translateY(-8px);
            box-shadow: 0 20px 30px rgba(0, 0, 0, 0.1);
            border-color: var(--primary-light);
        }

        .step-number {
            position: absolute;
            top: -20px;
            right: -20px;
            width: 90px;
            height: 90px;
            background: var(--primary-light);
            opacity: 0.1;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 3.5rem;
            font-weight: 800;
            color: var(--primary-dark);
        }

        .step-title {
            font-weight: 600;
            font-size: 1.2rem;
            margin-bottom: 1rem;
            color: var(--text);
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .step-title i {
            color: var(--primary);
        }

        /* Metrics Section */
        .metrics-card {
            background: white;
            border-radius: 16px;
            padding: 2rem;
            box-shadow: var(--card-shadow);
            margin-bottom: 2.5rem;
            border: 1px solid var(--border);
            transition: var(--transition);
        }

        .metrics-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 20px 30px rgba(0, 0, 0, 0.08);
            border-color: var(--primary-light);
        }

        .metrics-title {
            font-weight: 600;
            font-size: 1.3rem;
            margin-bottom: 1.5rem;
            color: var(--text);
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .metrics-title i {
            color: var(--primary);
        }

        .metrics-table {
            width: 100%;
            border-collapse: separate;
            border-spacing: 0;
            border-radius: 8px;
            overflow: hidden;
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.03);
        }

        .metrics-table th {
            font-weight: 600;
            padding: 12px 16px;
            background: var(--bg-alt);
            text-align: left;
        }

        .metrics-table th:first-child {
            border-top-left-radius: 8px;
        }

        .metrics-table th:last-child {
            border-top-right-radius: 8px;
        }

        .metrics-table td {
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
        }

        .metrics-table tr:last-child td {
            border-bottom: none;
        }

        .metrics-table tr:last-child td:first-child {
            border-bottom-left-radius: 8px;
        }

        .metrics-table tr:last-child td:last-child {
            border-bottom-right-radius: 8px;
        }

        .metrics-table tr:hover {
            background-color: rgba(99, 102, 241, 0.03);
        }

        .highlight {
            background-color: rgba(249, 115, 22, 0.1);
            color: #c2410c;
            font-weight: 600;
        }

        /* Citation Section */
        .citation {
            background: var(--bg-alt);
            padding: 1.5rem;
            border-radius: 8px;
            font-family: monospace;
            font-size: 0.9rem;
            margin: 2rem 0;
            white-space: pre-wrap;
            word-break: break-word;
            border: 1px solid var(--border);
            position: relative;
        }

        .copy-btn {
            position: absolute;
            top: 10px;
            right: 10px;
            background: white;
            border: 1px solid var(--border);
            border-radius: 4px;
            width: 30px;
            height: 30px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: var(--transition);
        }

        .copy-btn:hover {
            background: var(--primary);
            color: white;
        }

        /* Navigation */
        .sticky-nav {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            background: rgba(255, 255, 255, 0.9);
            backdrop-filter: blur(10px);
            border-bottom: 1px solid var(--border);
            z-index: 100;
            padding: 1rem 0;
            transform: translateY(-100%);
            transition: var(--transition);
        }

        .sticky-nav.visible {
            transform: translateY(0);
        }

        .nav-container {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .nav-title {
            font-weight: 600;
            font-size: 1.1rem;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 300px;
            color: var(--text);
        }

        .nav-links {
            display: flex;
            gap: 1.5rem;
            list-style: none;
            margin: 0;
            padding: 0;
            align-items: center;
        }

        .nav-links li a {
            color: var(--text);
            text-decoration: none;
            font-weight: 500;
            transition: color 0.2s;
            position: relative;
        }

        .nav-links li a::after {
            content: "";
            position: absolute;
            bottom: -5px;
            left: 0;
            width: 0;
            height: 2px;
            background: var(--primary);
            transition: width 0.2s;
        }

        .nav-links li a:hover {
            color: var(--primary);
        }

        .nav-links li a:hover::after {
            width: 100%;
        }

        /* Footer */
        .footer {
            background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
            color: white;
            padding: 4rem 0;
            position: relative;
        }

        .footer::before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 8px;
            background: linear-gradient(90deg, var(--primary), var(--accent));
        }

        .footer-links {
            list-style: none;
            padding: 0;
            margin: 2rem 0;
        }

        .footer-links li {
            margin-bottom: 0.8rem;
        }

        .footer-links a {
            color: #cbd5e1;
            text-decoration: none;
            transition: color 0.2s;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .footer-links a:hover {
            color: white;
        }

        .social-links {
            display: flex;
            gap: 1rem;
            margin-top: 1.5rem;
        }

        .social-links a {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            background: rgba(255, 255, 255, 0.1);
            color: white;
            transition: var(--transition);
        }

        .social-links a:hover {
            background: var(--primary);
            transform: translateY(-2px);
        }

        /* Animation */
        .scroll-animations .fade-up {
            opacity: 0;
            transform: translateY(30px);
            transition: opacity 0.8s, transform 0.8s;
        }

        .scroll-animations .fade-up.active {
            opacity: 1;
            transform: translateY(0);
        }

        .scroll-animations .fade-in {
            opacity: 0;
            transition: opacity 1s;
        }

        .scroll-animations .fade-in.active {
            opacity: 1;
        }

        .delay-1 {
            transition-delay: 0.1s;
        }

        .delay-2 {
            transition-delay: 0.2s;
        }

        .delay-3 {
            transition-delay: 0.3s;
        }

        .delay-4 {
            transition-delay: 0.4s;
        }

        /* Responsive Styles */
        @media (max-width: 991.98px) {
            .hero {
                padding: 60px 0;
                min-height: auto;
            }

            .hero-content {
                margin-bottom: 1rem;
            }

            .hero-videos {
                transform: translateX(-2%); /* Less offset on tablets */
                margin-top: 1rem;
                padding-bottom: 56.25%;
                max-width: 90%;
            }

            .video-comparison-hero {
                transform: perspective(1000px) rotateY(-4deg) rotateX(2deg);
            }

            .video-comparison-hero:hover {
                transform: perspective(1000px) rotateY(-2deg) rotateX(1deg) scale(1.01);
            }

            .hero-toggle {
                bottom: 15px;
                right: 15px;
            }
        }

        @media (max-width: 767.98px) {
            .nav-links {
                gap: 1rem;
            }

            .nav-title {
                font-size: 0.9rem;
                max-width: 150px;
            }

            .sticky-nav .btn-results {
                padding: 8px 12px;
                font-size: 0.9rem;
            }
        }

        @media (max-width: 575.98px) {
            .hero {
                padding: 40px 0;
            }

            .hero-videos {
                transform: none; /* Remove offset on mobile */
                margin-top: 0.5rem;
                max-width: 95%;
            }

            .video-comparison-hero {
                transform: none;
            }

            .video-comparison-hero:hover {
                transform: none;
            }

            .hero-toggle {
                bottom: 10px;
                right: 10px;
            }

            .hero-toggle-btn {
                padding: 8px 16px;
                font-size: 14px;
            }
        }
    </style>
</head>
<body class="scroll-animations">
    <!-- Decorative Elements -->
    <div class="geometric-accent accent-1"></div>
    <div class="geometric-accent accent-2"></div>
    <div class="geometric-accent accent-3"></div>
    <div class="bg-pattern"></div>
    
    <!-- Hero Section -->
    <div class="hero">
        <video class="hero-bg" autoplay loop muted playsinline>
            <source src="videos/hero_background.mp4" type="video/mp4">
        </video>
        <div class="container hero-content">
            <div class="row justify-content-center">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h1>Epipolar Geometry Improves<br>Video Generation Models</h1>
                        <div class="authors">Anonymous Authors</div>
                        <div class="institute">Submitted to 39th Conference on Neural Information Processing Systems (NeurIPS 2025)</div>
                        <div class="mt-4 d-flex justify-content-center gap-3">
                            <a href="#results" class="btn btn-results">
                                <i class="fas fa-play-circle"></i>View Results
                            </a>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="hero-videos fade-up delay-2">
            <div class="video-comparison-hero">
                <div class="video-pane active" data-video="baseline">
                    <video autoplay muted playsinline>
                        <source src="videos/baseline/playground.mp4" type="video/mp4">
                    </video>
                </div>
                <div class="video-pane" data-video="ours">
                    <video muted playsinline>
                        <source src="videos/finetuned/playground.mp4" type="video/mp4">
                    </video>
                </div>
                <div class="hero-video-label">Improved 3D Consistency</div>
                <div class="hero-toggle">
                    <button class="hero-toggle-btn active" data-video="baseline">Baseline</button>
                    <button class="hero-toggle-btn" data-video="ours">Ours</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Sticky Navigation -->
    <nav class="sticky-nav" id="navbar">
        <div class="container">
            <div class="nav-container">
                <div class="nav-title">Epipolar Geometry for Video Gen</div>
                <ul class="nav-links">
                    <li><a href="#abstract">Abstract</a></li>
                    <li><a href="#method">Method</a></li>
                    <li><a href="#results">Results</a></li>
                    <li><a href="#evaluation">Evaluation</a></li>
                    <!--<li><a href="#cite">Cite</a></li>-->
                    <li><a href="#results" class="btn btn-results btn-sm">
                        <i class="fas fa-play-circle"></i> View Results
                    </a></li>
                </ul>
            </div>
        </div>
    </nav>

    <!-- Abstract Section -->
    <section class="section" id="abstract">
        <div class="container">
            <div class="row justify-content-center">
                <div class="col-lg-10">
                    <div class="fade-up">
                        <h2>Abstract</h2>
                        <div class="abstract">
                            <p>Video generation models have progressed tremendously through large latent diffusion transformers trained with rectified flow techniques. Yet, despite these advances, these models still struggle with geometric inconsistencies, unstable motion, and visual artifacts that break the illusion of realistic 3D scenes.</p>
                            
                            <p>3D-consistent video generation could significantly impact numerous downstream applications in generation and reconstruction tasks. This work explores how simple epipolar geometry constraints can improve modern video diffusion models trained on internet-scale datasets. Despite their massive training data, these models often fail to capture the fundamental geometric principles underlying all visual content.</p>
                            
                            <p>While traditional computer vision methods are often non-differentiable and computationally expensive, they provide reliable, mathematically grounded signals for 3D consistency evaluation. We demonstrate that aligning diffusion models through a preference-based optimization framework using pairwise epipolar geometry constraints yields videos with superior visual quality, enhanced 3D consistency, and significantly improved motion stability.</p>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Method Section -->
    <section class="section section-alt" id="method">
        <div class="container">
            <div class="row">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h2>Method</h2>
                        <p>Our approach bridges modern video diffusion models with classical computer vision algorithms using epipolar geometry constraints as reward signals in a preference-based finetuning framework.</p>
                    </div>
                    
                    <div class="fade-up delay-1">
                        <img src="images/architecture.svg" alt="Method Diagram" class="method-diagram">
                    </div>
                    
                    <div class="method-steps">
                        <div class="method-step fade-up delay-1">
                            <div class="step-number">1</div>
                            <div class="step-title">
                                <i class="fas fa-video"></i>
                                Generate Paired Videos
                            </div>
                            <p>Generate diverse videos using pretrained generators and compute their epipolar geometry consistency scores using the Sampson distance to identify well-constrained vs. unconstrained examples.</p>
                        </div>
                        
                        <div class="method-step fade-up delay-2">
                            <div class="step-number">2</div>
                            <div class="step-title">
                                <i class="fas fa-balance-scale"></i>
                                Preference-Based Optimization
                            </div>
                            <p>Train policy using Flow-DPO to prefer geometrically consistent outputs by learning from paired examples ranked by epipolar error, without requiring differentiable rewards.</p>
                        </div>
                        
                        <div class="method-step fade-up delay-3">
                            <div class="step-number">3</div>
                            <div class="step-title">
                                <i class="fas fa-cube"></i>
                                Enhanced Generation
                            </div>
                            <p>Apply the updated policy to enhance 3D consistency in the base video diffusion model, leading to more stable camera trajectories and reduced artifacts.</p>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Results Section -->
    <section class="section" id="results">
        <div class="container">
            <div class="row">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h2>Results</h2>
                        <p>Our epipolar-aligned model significantly reduces artifacts and enhances motion smoothness, resulting in more geometrically consistent 3D scenes. Below you can toggle between baseline model results and our approach for direct comparison.</p>
                    </div>
                    
                    <!-- Main Showcase Video -->
                    <div class="video-comparison fade-up delay-1">
                        <div class="video-pane active" data-video="baseline">
                            <video id="main-video-baseline">
                                <source src="videos/baseline/basketball.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-pane" data-video="ours">
                            <video id="main-video-ours">
                                <source src="videos/finetuned/basketball.mp4" type="video/mp4">
                            </video>
                        </div>
                        <div class="video-controls">
                            <div class="video-label">
                                <button class="play-control" id="main-play-btn">
                                    <i class="fas fa-play"></i>
                                </button>
                                <span>Basketball Court</span>
                            </div>
                            <div class="video-toggle">
                                <button class="toggle-btn active" data-target="main" data-video="baseline">Baseline</button>
                                <button class="toggle-btn" data-target="main" data-video="ours">Ours</button>
                            </div>
                        </div>
                    </div>
                    
                    <!-- Results Grid -->
                    <div class="result-grid">
                        <!-- Result Card 1 -->
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="1">
                                        <source src="videos/baseline/chinese_temple.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="1">
                                        <source src="videos/finetuned/chinese_temple.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-landmark"></i>
                                    Chinese Temple
                                </div>
                                <div class="result-description">Notice how our model preserves consistent 3D structure throughout camera movements, maintaining shape and scale of the temple parts.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="1">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="1" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="1" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Result Card 2 -->
                        <div class="result-card fade-up delay-2">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="2">
                                        <source src="videos/baseline/house_entrance.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="2">
                                        <source src="videos/finetuned/house_entrance.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-door-open"></i>
                                    House Front Door
                                </div>
                                <div class="result-description">The epipolar-aligned model generates stable perspective with fewer artifacts during camera movement.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="2">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="2" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="2" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Result Card 3 -->
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="3">
                                        <source src="videos/baseline/house_outside.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="3">
                                        <source src="videos/finetuned/house_outside.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-building"></i>
                                    Residential Complex Exterior
                                </div>
                                <div class="result-description">Our epipolar-aligned model maintains structural integrity of the apartment buildings with consistent perspective as the camera moves. Notice how buildings remain geometrically stable, eliminating the warping and distortion seen in the baseline.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="3">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="3" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="3" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Result Card 4 -->
                        <div class="result-card fade-up delay-2">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="4">
                                        <source src="videos/baseline/living_room_perspective.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="4">
                                        <source src="videos/finetuned/living_room_perspective.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-couch"></i>
                                    Living Room interior
                                </div>
                                <div class="result-description">In the baseline model, the sofa warps unnaturally as the camera moves through, creating a distracting perspective distortion. Our approach maintains proper object proportions and shape consistency throughout the camera trajectory, preserving the realistic appearance of furniture and interior elements.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="4">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="4" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="4" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="5">
                                        <source src="videos/baseline/playground.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="5">
                                        <source src="videos/finetuned/playground.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-child"></i>
                                    Outdoor Playground Climbing Wall
                                </div>
                                <div class="result-description">The baseline model exhibits noticeable distortions, particularly in finer details like climbing holds and netting as the camera moves. Our epipolar alignment preserves the geometric consistency of these small elements and maintains proper perspective relationships between the climbing wall and background trees, creating a more realistic outdoor scene.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="5">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="5" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="5" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="6">
                                        <source src="videos/baseline/red_carpet.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="6">
                                        <source src="videos/finetuned/red_carpet.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-stairs"></i>
                                    Elegant Staircase with Red Carpet
                                </div>
                                <div class="result-description">The baseline model shows noticeable distortion in the staircase geometry as the camera moves. Our approach maintains proper perspective, preserving straight lines and consistent architectural features throughout the camera trajectory.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="6">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="6" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="6" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="7">
                                        <source src="videos/baseline/crowded_street.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="7">
                                        <source src="videos/finetuned/crowded_street.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-store-alt"></i>
                                    Bustling Historical Marketplace
                                </div>
                                <div class="result-description">Even in this highly dynamic scene with numerous people, our method significantly reduces the motion artifacts and temporal inconsistencies seen in the baseline. Building facades maintain proper perspective while moving subjects appear more naturally integrated with the environment, demonstrating our approach's effectiveness beyond just static scenes.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="7">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="7" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="7" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="8">
                                        <source src="videos/baseline/car.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="8">
                                        <source src="videos/finetuned/car.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-car"></i>
                                    Classic Car Show with Motion
                                </div>
                                <div class="result-description"> The baseline model struggles with maintaining the scene consistency during camera movement, creating many warping artifacts. Our approach preserves vehicle geometry and spatial relationships between moving cars, demonstrating how epipolar constraints improve even scenes with moving objects.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="8">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="8" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="8" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="9">
                                        <source src="videos/baseline/cyclist.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="9">
                                        <source src="videos/finetuned/cyclist.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-biking"></i>
                                    Mountain Biking Trail Perspective
                                </div>
                                <div class="result-description">The baseline model struggles with the combined motion of the cyclist and camera, creating unnatural texture warping and geometric distortions in the rocky terrain. Our approach maintains consistent rock textures and landscape features while preserving the sense of motion, demonstrating effectiveness in first-person action sequences.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="9">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="9" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="9" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="result-card fade-up delay-1">
                            <div class="sync-video-container">
                                <div class="video-pane active" data-video="baseline">
                                    <video class="sync-video" data-sync-group="10">
                                        <source src="videos/baseline/car_2.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="video-pane" data-video="ours">
                                    <video class="sync-video" data-sync-group="10">
                                        <source src="videos/finetuned/car_2.mp4" type="video/mp4">
                                    </video>
                                </div>
                            </div>
                            <div class="result-info">
                                <div class="result-title">
                                    <i class="fas fa-truck-loading"></i>
                                    Car Driving Through The Dock
                                </div>
                                <div class="result-description">The baseline struggles to model the collision of the car with the objects and maintain the smooth trajectory causing unnatural warping and perspective distortions of the objects.</div>
                                <div class="sync-video-controls">
                                    <button class="sync-play-btn" data-sync-group="10">
                                        <i class="fas fa-play"></i>
                                    </button>
                                    <div class="sync-toggle">
                                        <button class="sync-toggle-btn active" data-sync-group="10" data-video="baseline">Baseline</button>
                                        <button class="sync-toggle-btn" data-sync-group="10" data-video="ours">Ours</button>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Evaluation Section -->
    <section class="section section-alt" id="evaluation">
        <div class="container">
            <div class="row">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h2>Quantitative Evaluation</h2>
                        <p>We evaluate our approach using multiple metrics including VideoReward benchmark, VBench metrics, and direct 3D geometry evaluations.</p>
                    </div>
                    
                    <div class="row mt-4">
                        <div class="col-lg-6">
                            <div class="metrics-card fade-up delay-1">
                                <div class="metrics-title">
                                    <i class="fas fa-award"></i>
                                    VideoReward Benchmark
                                </div>
                                <div class="table-responsive">
                                    <table class="metrics-table">
                                        <thead>
                                            <tr>
                                                <th>Method</th>
                                                <th>Visual Quality</th>
                                                <th>Motion Quality</th>
                                                <th>Text Alignment</th>
                                                <th>Overall</th>
                                            </tr>
                                        </thead>
                                        <tbody>
                                            <tr>
                                                <td>MET3R</td>
                                                <td>56.5%</td>
                                                <td>64.5%</td>
                                                <td>44.0%</td>
                                                <td>55.0%</td>
                                            </tr>
                                            <tr>
                                                <td>Ours</td>
                                                <td class="highlight">72.0%</td>
                                                <td class="highlight">71.0%</td>
                                                <td class="highlight">55.0%</td>
                                                <td class="highlight">73.0%</td>
                                            </tr>
                                        </tbody>
                                    </table>
                                </div>
                            </div>
                        </div>
                        
                        <div class="col-lg-6">
                            <div class="metrics-card fade-up delay-2">
                                <div class="metrics-title">
                                    <i class="fas fa-cube"></i>
                                    3D Consistency Metrics
                                </div>
                                <div class="table-responsive">
                                    <table class="metrics-table">
                                        <thead>
                                            <tr>
                                                <th>Method</th>
                                                <th>Motion</th>
                                                <th>Perspective</th>
                                                <th>Sampson</th>
                                            </tr>
                                        </thead>
                                        <tbody>
                                            <tr>
                                                <td>Baseline</td>
                                                <td>0.233</td>
                                                <td>0.426</td>
                                                <td>0.190</td>
                                            </tr>
                                            <tr>
                                                <td>DPO-MET3R</td>
                                                <td>0.232</td>
                                                <td>0.438</td>
                                                <td>0.176</td>
                                            </tr>
                                            <tr>
                                                <td>Ours</td>
                                                <td class="highlight">0.223</td>
                                                <td>0.428</td>
                                                <td class="highlight">0.127</td>
                                            </tr>
                                        </tbody>
                                    </table>
                                </div>
                            </div>
                        </div>
                    </div>
                    
                    <div class="row mt-4">
                        <div class="col-lg-12">
                            <div class="metrics-card fade-up delay-3">
                                <div class="metrics-title">
                                    <i class="fas fa-chart-line"></i>
                                    VBench Metrics
                                </div>
                                <div class="table-responsive">
                                    <table class="metrics-table">
                                        <thead>
                                            <tr>
                                                <th>Method</th>
                                                <th>Background Consistency</th>
                                                <th>Aesthetic Quality</th>
                                                <th>Temporal Flickering</th>
                                                <th>Motion Smoothness</th>
                                            </tr>
                                        </thead>
                                        <tbody>
                                            <tr>
                                                <td>Baseline</td>
                                                <td>0.930</td>
                                                <td>0.541</td>
                                                <td>0.958</td>
                                                <td>0.981</td>
                                            </tr>
                                            <tr>
                                                <td>Ours</td>
                                                <td class="highlight">0.942</td>
                                                <td class="highlight">0.551</td>
                                                <td class="highlight">0.969</td>
                                                <td class="highlight">0.984</td>
                                            </tr>
                                        </tbody>
                                    </table>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Conclusion Section -->
    <section class="section" id="conclusion">
        <div class="container">
            <div class="row">
                <div class="col-lg-10 mx-auto">
                    <div class="fade-up">
                        <h2>Conclusion</h2>
                        <p>We presented a novel approach for enhancing 3D consistency in video diffusion models by leveraging classical epipolar geometry constraints as preference signals. Our work demonstrates that aligning modern generative models with fundamental geometric principles can significantly improve the spatial coherence of generated content without requiring complex 3D supervision.</p>
                        
                        <p>The resulting models generate videos with notably fewer geometric inconsistencies and more stable camera trajectories while preserving creative flexibility. This work highlights how classical computer vision algorithms can effectively complement deep learning approaches, addressing limitations in purely data-driven systems.</p>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Citation Section -->
    <section class="section section-alt" id="cite" style="display: none;">
        <div class="container">
            <div class="row">
                <div class="col-lg-10 mx-auto">
                    <div class="fade-up">
                        <h2>Citation</h2>
                        <div class="citation">
                            <button class="copy-btn" id="copy-citation">
                                <i class="fas fa-copy"></i>
                            </button>
@inproceedings{anonymous2025epipolar,
    title={Epipolar Geometry Improves Video Generation Models},
    author={Anonymous},
    booktitle={39th Conference on Neural Information Processing Systems (NeurIPS 2025)},
    year={2025}
}
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Footer -->
    <footer class="footer">
        <div class="container">
            <div class="row">
                <div class="col-md-8">
                    <h3>Epipolar Geometry Improves Video Generation Models</h3>
                    <p>© 2025 Anonymous Authors<br>Under Review - Do Not Distribute</p>
                    <div class="social-links" style="display: none;">
                        <a href="#" aria-label="GitHub">
                            <i class="fab fa-github"></i>
                        </a>
                        <a href="#" aria-label="Twitter">
                            <i class="fab fa-twitter"></i>
                        </a>
                        <a href="#" aria-label="Google Scholar">
                            <i class="fas fa-graduation-cap"></i>
                        </a>
                    </div>
                </div>
                <div class="col-md-4">
                    <h4>Resources</h4>
                    <ul class="footer-links">
                        <li>
                            <a href="#results">
                                <i class="fas fa-play-circle"></i> Video Results
                            </a>
                        </li>
                    </ul>
                </div>
            </div>
        </div>
    </footer>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.0/js/bootstrap.bundle.min.js"></script>
    
    <script>
        // Global state management
        let videoState = {
            currentlyPlaying: null,
            autoToggleEnabled: true
        };
    
        // Stop all videos except the specified one
        function stopAllVideosExcept(exceptVideo) {
            $("video").each(function() {
                if (this !== exceptVideo) {
                    this.pause();
                    this.currentTime = 0;
                }
            });
        }
    
        // Play video with error handling
        function playVideoSafely(video) {
            if (video) {
                const playPromise = video.play();
                if (playPromise !== undefined) {
                    playPromise.catch(error => {
                        console.log("Video play failed:", error);
                    });
                }
            }
        }

        $(".hero-videos").on("mouseenter", function() {
    const activePane = $(this).find(".video-pane.active");
    const activeVideo = activePane.find("video")[0];
    
    if (activeVideo && activeVideo.paused) {
        stopAllVideosExcept(activeVideo);
        videoState.currentlyPlaying = activeVideo;
        playVideoSafely(activeVideo);
    }
}).on("mouseleave", function() {
    const activePane = $(this).find(".video-pane.active");
    const activeVideo = activePane.find("video")[0];
    
    if (activeVideo && !activeVideo.paused) {
        activeVideo.pause();
        activeVideo.currentTime = 0; // Reset to beginning
        if (videoState.currentlyPlaying === activeVideo) {
            videoState.currentlyPlaying = null;
        }
    }
});
    
        // Auto-toggle functionality
        function handleVideoEnd(video) {
            const $video = $(video);
            const container = $video.closest(".result-card, .video-comparison, .video-comparison-hero");
            const currentPane = $video.closest(".video-pane");
            const isBaseline = currentPane.data("video") === "baseline";
            const nextVideoType = isBaseline ? "ours" : "baseline";
            
            // Find next video and toggle
            const nextPane = container.find(`.video-pane[data-video="${nextVideoType}"]`);
            const nextVideo = nextPane.find("video")[0];
            
            if (nextVideo) {
                // Update panes
                container.find(".video-pane").removeClass("active");
                nextPane.addClass("active");
                
                // Update buttons
                container.find(".toggle-btn, .sync-toggle-btn, .hero-toggle-btn").removeClass("active");
                container.find(`[data-video="${nextVideoType}"]`).addClass("active");
                
                // Play next video
                nextVideo.currentTime = 0;
                videoState.currentlyPlaying = nextVideo;
                playVideoSafely(nextVideo);
            }
        }
    
        // Handle main video play/pause
        $("#main-play-btn").on("click", function() {
            const btn = $(this);
            const icon = btn.find("i");
            const activePane = $(".video-comparison .video-pane.active");
            const activeVideo = activePane.find("video")[0];
            
            if (activeVideo) {
                if (activeVideo.paused) {
                    stopAllVideosExcept(activeVideo);
                    videoState.currentlyPlaying = activeVideo;
                    playVideoSafely(activeVideo);
                    icon.removeClass("fa-play").addClass("fa-pause");
                } else {
                    activeVideo.pause();
                    videoState.currentlyPlaying = null;
                    icon.removeClass("fa-pause").addClass("fa-play");
                }
            }
        });
    
        // Sync play/pause controls
        $(".sync-play-btn").on("click", function() {
            const group = $(this).data("sync-group");
            const btn = $(this);
            const icon = btn.find("i");
            const container = btn.closest(".result-card");
            const activePane = container.find(".video-pane.active");
            const activeVideo = activePane.find("video")[0];
            
            if (activeVideo) {
                if (activeVideo.paused) {
                    stopAllVideosExcept(activeVideo);
                    videoState.currentlyPlaying = activeVideo;
                    playVideoSafely(activeVideo);
                    icon.removeClass("fa-play").addClass("fa-pause");
                } else {
                    activeVideo.pause();
                    videoState.currentlyPlaying = null;
                    icon.removeClass("fa-pause").addClass("fa-play");
                }
            }
        });
    
        // Video toggle buttons
        $(".toggle-btn, .sync-toggle-btn, .hero-toggle-btn").on("click", function() {
            const btn = $(this);
            const videoType = btn.data("video");
            const container = btn.closest(".video-comparison, .result-card, .video-comparison-hero");
            
            // Update active states
            container.find(".video-pane").removeClass("active");
            container.find(`.video-pane[data-video="${videoType}"]`).addClass("active");
            
            // Update buttons
            container.find(".toggle-btn, .sync-toggle-btn, .hero-toggle-btn").removeClass("active");
            btn.addClass("active");
            
            // Get and play the selected video
            const activePane = container.find(`.video-pane[data-video="${videoType}"]`);
            const activeVideo = activePane.find("video")[0];
            
            if (activeVideo) {
                stopAllVideosExcept(activeVideo);
                activeVideo.currentTime = 0;
                videoState.currentlyPlaying = activeVideo;
                playVideoSafely(activeVideo);
                
                // Update play button icons
                const group = $(activeVideo).data("sync-group");
                if (group) {
                    $(`.sync-play-btn[data-sync-group="${group}"] i`).removeClass("fa-play").addClass("fa-pause");
                }
                if (container.hasClass("video-comparison")) {
                    $("#main-play-btn i").removeClass("fa-play").addClass("fa-pause");
                }
            }
        });
    
        // Hero video toggle
        $(".hero-toggle-btn").on("click", function() {
            const btn = $(this);
            const videoType = btn.data("video");
            const container = $(".video-comparison-hero");
            
            container.find(".video-pane").removeClass("active");
            container.find(`.video-pane[data-video="${videoType}"]`).addClass("active");
            
            container.find(".hero-toggle-btn").removeClass("active");
            btn.addClass("active");
            
            const activeVideo = container.find(`.video-pane[data-video="${videoType}"] video`)[0];
            if (activeVideo) {
                stopAllVideosExcept(activeVideo);
                activeVideo.currentTime = 0;
                videoState.currentlyPlaying = activeVideo;
                playVideoSafely(activeVideo);
            }
        });
    
        // Video ended event handler
        $("video").on("ended", function() {
            if (videoState.autoToggleEnabled && this === videoState.currentlyPlaying) {
                handleVideoEnd(this);
            }
        });
    
        // Update play button states when videos play/pause
        $("video").on("play", function() {
            const group = $(this).data("sync-group");
            if (group) {
                $(`.sync-play-btn[data-sync-group="${group}"] i`).removeClass("fa-play").addClass("fa-pause");
            }
            if ($(this).closest(".video-comparison").length) {
                $("#main-play-btn i").removeClass("fa-play").addClass("fa-pause");
            }
        });
    
        $("video").on("pause", function() {
            const group = $(this).data("sync-group");
            if (group) {
                $(`.sync-play-btn[data-sync-group="${group}"] i`).removeClass("fa-pause").addClass("fa-play");
            }
            if ($(this).closest(".video-comparison").length) {
                $("#main-play-btn i").removeClass("fa-pause").addClass("fa-play");
            }
        });
    
        // Copy citation
        $("#copy-citation").on("click", function() {
            const citation = $(".citation").text().trim();
            navigator.clipboard.writeText(citation).then(() => {
                const btn = $(this);
                const icon = btn.find("i");
                
                icon.removeClass("fa-copy").addClass("fa-check");
                setTimeout(() => {
                    icon.removeClass("fa-check").addClass("fa-copy");
                }, 2000);
            });
        });
    
        // Scroll animations
        function isElementInViewport(el) {
            const rect = el.getBoundingClientRect();
            return (
                rect.top <= window.innerHeight * 0.85 &&
                rect.bottom >= 0
            );
        }
        
        function checkVisibility() {
            $(".fade-up, .fade-in").each(function() {
                if (isElementInViewport(this) && !$(this).hasClass("active")) {
                    $(this).addClass("active");
                }
            });
        }
        
        // Sticky navbar
        function handleNavbar() {
            const scrollTop = $(window).scrollTop();
            const navbar = $("#navbar");
            
            if (scrollTop > window.innerHeight * 0.8) {
                navbar.addClass("visible");
            } else {
                navbar.removeClass("visible");
            }
        }
        
        // Initialize
        $(document).ready(function() {
            checkVisibility();
            handleNavbar();
            
            $(window).on("scroll", function() {
                checkVisibility();
                handleNavbar();
            });
            
            // Smooth scrolling for anchor links
            $('a[href^="#"]').on("click", function(e) {
                e.preventDefault();
                const target = $($(this).attr("href"));
                
                if (target.length) {
                    $("html, body").animate({
                        scrollTop: target.offset().top - 70
                    }, 800);
                }
            });
    
            // Remove loop attribute from all videos
            $("video").removeAttr("loop");

            // Initialize videos
            $("video:not(.hero-bg)").removeAttr("loop autoplay");
            
            // Reset all videos to beginning and ensure they're paused
            $("video:not(.hero-bg)").each(function() {
                this.pause();
                this.currentTime = 0;
            });

            // Ensure hero video starts with baseline active
            const heroContainer = $(".video-comparison-hero");
            heroContainer.find(".video-pane").removeClass("active");
            heroContainer.find('.video-pane[data-video="baseline"]').addClass("active");
            heroContainer.find(".hero-toggle-btn").removeClass("active");
            heroContainer.find('.hero-toggle-btn[data-video="baseline"]').addClass("active");
        });
    </script>

</body>
</html>