<!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-three {
            gap: 2px;
        }

        .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-three .sync-toggle-btn {
            padding: 8px 12px;
            font-size: 13px;
        }

        .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">
        <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">Anonymous Submission</div>
                        <div class="mt-4 d-flex justify-content-center gap-3 flex-wrap">
                            <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="#sft-comparison">vs SFT</a></li>
                    <li><a href="#failure-cases">Limitations</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. To demonstrate our model, we present examples where the generated video from the original model lacks 3D consistency. 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 VBench metrics, and direct 3D geometry evaluations. For 3D reconstruction (PSNR, SSIM, LPIPS), we measure 3D scene reconstruction quality with Gaussian splatting.</p>
                    </div>
                    
                    <div class="row mt-4">
                        <div class="col-lg-12">
                            <div class="metrics-card fade-up delay-2">
                                <div class="metrics-title">
                                    <i class="fas fa-cube"></i>
                                    3D Consistency & Reconstruction
                                </div>
                                <div class="table-responsive">
                                    <table class="metrics-table">
                                        <thead>
                                            <tr>
                                                <th>Method</th>
                                                <th>Sampson Error ↓</th>
                                                <th>Perspective ↑</th>
                                                <th>PSNR ↑</th>
                                                <th>SSIM ↑</th>
                                                <th>LPIPS ↓</th>
                                                <th>Human Eval</th>
                                            </tr>
                                        </thead>
                                        <tbody>
                                            <tr>
                                                <td>Baseline</td>
                                                <td>0.190</td>
                                                <td>0.426</td>
                                                <td>22.32</td>
                                                <td>0.706</td>
                                                <td>0.343</td>
                                                <td>54.1%</td>
                                            </tr>
                                            <tr>
                                                <td>Ours</td>
                                                <td class="highlight">0.131</td>
                                                <td class="highlight">0.428</td>
                                                <td class="highlight">23.13</td>
                                                <td class="highlight">0.729</td>
                                                <td class="highlight">0.315</td>
                                                <td class="highlight">71.8%</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>

    <!-- SFT Comparison Section -->
    <section class="section" id="sft-comparison">
        <div class="container">
            <div class="row">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h2>Comparison with Direct Fine-Tuning</h2>
                        <p>We compare our epipolar-aware alignment approach to standard supervised fine-tuning (SFT) on multi-view static datasets. While directly fine-tuning on perfectly 3D-consistent static scenes might seem like a viable alternative, it leads to overfitting to dataset-specific characteristics such as narrow camera trajectory distributions and scene types, ultimately hurting generalization to diverse dynamic content.</p>
                    </div>
                    
                    <!-- Three-way Comparison Grid -->
                    <div class="row mt-4">
                        <!-- Comparison Card 1 -->
                        <div class="col-lg-6 mb-4">
                            <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="sft-1">
                                            <source src="videos/sft/baseline_1.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="sft">
                                        <video class="sync-video" data-sync-group="sft-1">
                                            <source src="videos/sft/sft_1.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="ours">
                                        <video class="sync-video" data-sync-group="sft-1">
                                            <source src="videos/sft/ours_1.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-couch"></i>
                                        LA Street Scene
                                    </div>
                                    <div class="result-description">The model finetuned directly on multi-view data overfits to specific camera trajectories. When combined with significant dynamic content, it produces additional artifacts and fails to preserve object geometry.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-sync-group="sft-1">
                                            <i class="fas fa-play"></i>
                                        </button>
                                        <div class="sync-toggle sync-toggle-three">
                                            <button class="sync-toggle-btn active" data-sync-group="sft-1" data-video="baseline">Baseline</button>
                                            <button class="sync-toggle-btn" data-sync-group="sft-1" data-video="sft">SFT</button>
                                            <button class="sync-toggle-btn" data-sync-group="sft-1" data-video="ours">Ours</button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Comparison Card 2 -->
                        <div class="col-lg-6 mb-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="sft-2">
                                            <source src="videos/sft/baseline_2.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="sft">
                                        <video class="sync-video" data-sync-group="sft-2">
                                            <source src="videos/sft/sft_2.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="ours">
                                        <video class="sync-video" data-sync-group="sft-2">
                                            <source src="videos/sft/ours_2.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-store-alt"></i>
                                        Toy Street Scene
                                    </div>
                                    <div class="result-description">
                                        The SFT model degrades the baseline performance in some cases. Notice, the camera trajectory resembles average camera trajectory in the training data which leads to additional artifacts on the end of the video.
                                    </div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-sync-group="sft-2">
                                            <i class="fas fa-play"></i>
                                        </button>
                                        <div class="sync-toggle sync-toggle-three">
                                            <button class="sync-toggle-btn active" data-sync-group="sft-2" data-video="baseline">Baseline</button>
                                            <button class="sync-toggle-btn" data-sync-group="sft-2" data-video="sft">SFT</button>
                                            <button class="sync-toggle-btn" data-sync-group="sft-2" data-video="ours">Ours</button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Failure Cases Section -->
    <section class="section section-alt" id="failure-cases">
        <div class="container">
            <div class="row">
                <div class="col-lg-12">
                    <div class="fade-up">
                        <h2>Limitations and Failure Cases</h2>
                        <p>We present failure cases to provide transparency about the limitations of our approach and areas for future improvement.</p>
                    </div>
                    
                    <!-- Part 1: Data Mining Pipeline Failures -->
                    <div class="fade-up delay-1">
                        <h3>Data Mining Pipeline</h3>
                        <p>Our reward model relies on feature matching and epipolar geometry scoring. However, this pipeline can produce false positives (assigning low error to geometrically inconsistent videos) and false negatives (high error to consistent ones) when scenes have repetitive textures, lack distinctive features, or contain significant motion blur.</p>
                    </div>
                    
                    <div class="row mt-4">
                        <!-- High Score False Positive -->
                        <div class="col-lg-6 mb-4">
                            <div class="result-card fade-up delay-1">
                                <div class="sync-video-container">
                                    <video class="sync-video" loop>
                                        <source src="videos/failcases/metric_1.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-exclamation-triangle" style="color: #f97316;"></i>
                                        False Positive: Low Error
                                    </div>
                                    <div class="result-description">This video received a low average error despite significant geometric artifacts in the first part of the video. Near static second part of the video leads to overally low error.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-video-target="failure-high">
                                            <i class="fas fa-play"></i>
                                        </button>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Low Score False Negative -->
                        <div class="col-lg-6 mb-4">
                            <div class="result-card fade-up delay-2">
                                <div class="sync-video-container">
                                    <video class="sync-video" loop>
                                        <source src="videos/failcases/metric_2.mp4" type="video/mp4">
                                    </video>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-exclamation-triangle" style="color: #f97316;"></i>
                                        False Negative: High Error
                                    </div>
                                    <div class="result-description">This geometrically consistent video received a low score due to repetitive textures affecting feature tracking.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-video-target="failure-low">
                                            <i class="fas fa-play"></i>
                                        </button>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                    
                    <!-- Part 2: Generation Failure Cases -->
                    <div class="fade-up delay-1 mt-5">
                        <h3>Generation Failures</h3>
                        <p>While our method significantly improves geometric consistency, it does not solve all failure modes. Complex dynamic scenes with extreme camera motion or highly ambiguous content remain challenging for both the baseline and our approach.</p>
                    </div>
                    
                    <div class="row mt-4">
                        <!-- Generation Failure 1 -->
                        <div class="col-lg-6 mb-4">
                            <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="fail-1">
                                            <source src="videos/failcases/baseline_1.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="ours">
                                        <video class="sync-video" data-sync-group="fail-1">
                                            <source src="videos/failcases/ours_1.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-times-circle" style="color: #dc2626;"></i>
                                        Near Static Outdoor Scenes
                                    </div>
                                    <div class="result-description">The aligned model occasionally generate static frames for near static drone videos of outdoor scenes.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-sync-group="fail-1">
                                            <i class="fas fa-play"></i>
                                        </button>
                                        <div class="sync-toggle">
                                            <button class="sync-toggle-btn active" data-sync-group="fail-1" data-video="baseline">Baseline</button>
                                            <button class="sync-toggle-btn" data-sync-group="fail-1" data-video="ours">Ours</button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Generation Failure 2 -->
                        <div class="col-lg-6 mb-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="fail-2">
                                            <source src="videos/failcases/baseline_2.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="ours">
                                        <video class="sync-video" data-sync-group="fail-2">
                                            <source src="videos/failcases/ours_2.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-times-circle" style="color: #dc2626;"></i>
                                        Challenging Dynamic Scenes
                                    </div>
                                    <div class="result-description">Extreme illuminations, dynamics and out of distribution content remain challenging for both baseline and our approach.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-sync-group="fail-2">
                                            <i class="fas fa-play"></i>
                                        </button>
                                        <div class="sync-toggle">
                                            <button class="sync-toggle-btn active" data-sync-group="fail-2" data-video="baseline">Baseline</button>
                                            <button class="sync-toggle-btn" data-sync-group="fail-2" data-video="ours">Ours</button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Generation Failure 3 -->
                        <div class="col-lg-6 mb-4">
                            <div class="result-card fade-up delay-3">
                                <div class="sync-video-container">
                                    <div class="video-pane active" data-video="baseline">
                                        <video class="sync-video" data-sync-group="fail-3">
                                            <source src="videos/failcases/baseline_3.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                    <div class="video-pane" data-video="ours">
                                        <video class="sync-video" data-sync-group="fail-3">
                                            <source src="videos/failcases/ours_3.mp4" type="video/mp4">
                                        </video>
                                    </div>
                                </div>
                                <div class="result-info">
                                    <div class="result-title">
                                        <i class="fas fa-times-circle" style="color: #dc2626;"></i>
                                        Complex Interactions
                                    </div>
                                    <div class="result-description">Complex interactions between objects are not addressed by epipolar alignment.</div>
                                    <div class="sync-video-controls">
                                        <button class="sync-play-btn" data-sync-group="fail-3">
                                            <i class="fas fa-play"></i>
                                        </button>
                                        <div class="sync-toggle">
                                            <button class="sync-toggle-btn active" data-sync-group="fail-3" data-video="baseline">Baseline</button>
                                            <button class="sync-toggle-btn" data-sync-group="fail-3" data-video="ours">Ours</button>
                                        </div>
                                    </div>
                                </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>
@article{anonymous2025epipolar,
    title={Epipolar Geometry Improves Video Generation Models},
    author={Anonymous},
    journal={Under Review},
    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 - Please Do Not Distribute</p>
                </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");
            
            // If this is a single video (no panes), just loop it
            if (currentPane.length === 0) {
                video.currentTime = 0;
                playVideoSafely(video);
                return;
            }
            
            const currentVideoType = currentPane.data("video");
            
            // Determine next video type based on available panes
            let nextVideoType;
            const hasSFT = container.find('.video-pane[data-video="sft"]').length > 0;
            
            if (hasSFT) {
                // Three-way toggle: baseline -> sft -> ours -> baseline
                if (currentVideoType === "baseline") {
                    nextVideoType = "sft";
                } else if (currentVideoType === "sft") {
                    nextVideoType = "ours";
                } else {
                    nextVideoType = "baseline";
                }
            } else {
                // Two-way toggle: baseline -> ours -> baseline
                nextVideoType = currentVideoType === "baseline" ? "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");
            
            // Check if this is a video with panes (baseline/ours) or a single video
            const activePane = container.find(".video-pane.active");
            let activeVideo;
            
            if (activePane.length > 0) {
                // Multi-video with toggle
                activeVideo = activePane.find("video")[0];
            } else {
                // Single video (failure cases without panes)
                activeVideo = container.find(".sync-video-container 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");
            }
            // Check if this is part of main video comparison
            if ($(this).closest(".video-comparison").length) {
                $("#main-play-btn i").removeClass("fa-play").addClass("fa-pause");
            }
            // Handle single videos in failure cases section
            const container = $(this).closest(".result-card");
            if (container.length && !$(this).closest(".video-pane").length) {
                container.find(".sync-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");
            }
            // Handle single videos in failure cases section
            const container = $(this).closest(".result-card");
            if (container.length && !$(this).closest(".video-pane").length) {
                container.find(".sync-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>