<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>UP2You</title>
    <link rel="icon" type="image/svg+xml" href="public/favicon.svg">
    
    <!-- Google Fonts -->
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap" rel="stylesheet">
    
    <!-- Tailwind CSS -->
    <script src="https://cdn.tailwindcss.com"></script>
    
    <style>
        @media (prefers-color-scheme: dark) {
            .astro-code,
            .astro-code span {
                color: var(--shiki-dark) !important;
                font-style: var(--shiki-dark-font-style) !important;
                font-weight: var(--shiki-dark-font-weight) !important;
                text-decoration: var(--shiki-dark-text-decoration) !important;
            }
        }

        body {
            font-family: "Inter", "Noto Sans", sans-serif;
            background: #ffffff;
            min-height: 100vh;
        }

        .dark body {
            background: #ffffff;
        }

        a {
            color: #3b82f6;
            text-decoration: none;
        }

        a:hover {
            text-decoration: underline;
        }

        p {
            font-size: 1.125rem;
            width: 100%;
        }

        h1 {
            font-size: 3rem;
            text-align: center;
            font-weight: 500;
        }

        .gradient-title {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 25%, #f093fb 50%, #f5576c 75%, #4facfe 100%);
            background-size: 300% 300%;
            -webkit-background-clip: text;
            background-clip: text;
            -webkit-text-fill-color: transparent;
            animation: gradientShift 8s ease-in-out infinite;
            font-family: 'Inter', 'Noto Sans', sans-serif;
            font-weight: 700;
            font-size: 4rem !important;
            letter-spacing: -0.02em;
            line-height: 1.1;
            text-align: center;
            max-width: 1000px;
            margin: 0 auto;
        }

        @keyframes gradientShift {
            0%, 100% {
                background-position: 0% 50%;
            }
            50% {
                background-position: 100% 50%;
            }
        }

        @media (max-width: 768px) {
            .gradient-title {
                font-size: 4rem !important;
                line-height: 1.2;
            }
        }

        @media (max-width: 480px) {
            .gradient-title {
                font-size: 3rem !important;
                line-height: 1.3;
            }
        }

        .highlighted-section {
            background: #ffffff;
            backdrop-filter: blur(10px);
            border-radius: 24px;
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
            border: 1px solid rgba(255, 255, 255, 0.2);
            margin: 2rem 0;
            position: relative;
            overflow: hidden;
        }

        .highlighted-section::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(90deg, #667eea, #764ba2, #f093fb, #f5576c, #4facfe);
            background-size: 300% 100%;
            animation: gradientShift 8s ease-in-out infinite;
        }

        h2 {
            width: 100%;
            font-size: 1.5rem !important;
            font-weight: 900 !important;
            background: linear-gradient(135deg, #1e293b 0%, #475569 100%);
            -webkit-background-clip: text;
            background-clip: text;
            -webkit-text-fill-color: transparent;
            font-family: 'Inter', sans-serif;
            letter-spacing: -0.01em;
            margin-bottom: 1.5rem;
        }

        .conference-title {
            background: linear-gradient(135deg, #1e293b 0%, #475569 50%, #64748b 100%);
            -webkit-background-clip: text;
            background-clip: text;
            -webkit-text-fill-color: transparent;
            font-family: 'Inter', sans-serif;
            font-weight: 600;
            font-size: 1.2rem;
            letter-spacing: 0.02em;
            text-transform: uppercase;
            margin: 1rem 0;
            position: relative;
            text-align: center;
        }

        .conference-title::after {
            content: '';
            position: absolute;
            bottom: -8px;
            left: 50%;
            transform: translateX(-50%);
            width: 60px;
            height: 3px;
            background: linear-gradient(90deg, #667eea, #764ba2, #f093fb);
            border-radius: 2px;
        }

        .carousel-btn {
            flex-shrink: 0;
            background: rgba(0, 0, 0, 0.5);
            color: white;
            border-radius: 50%;
            padding: 12px;
            transition: all 0.2s;
            border: none;
            cursor: pointer;
        }

        .carousel-btn:hover {
            background: rgba(0, 0, 0, 0.7);
        }

        video {
            width: 100%;
            height: auto;
            aspect-ratio: 16/9;
            border-radius: 8px;
        }


        img {
            max-width: 100%;
            height: auto;
        }


        .image-container {
            position: relative;
            width: 100%;
            height: 360px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .image-container img,
        .image-container video {
            width: 100%;
            height: 100%;
            object-fit: contain;
        }

        .image-caption {
            position: absolute;
            bottom: 8px;
            left: 8px;
            background: rgba(0, 0, 0, 0.7);
            color: white;
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 0.875rem;
        }


        .carousel-counter {
            text-align: center;
            margin-top: 8px;
            font-size: 0.875rem;
            color: #6b7280;
        }
    </style>
</head>
<body class="flex flex-col gap-6 items-center pt-8 pb-8 w-full text-zinc-900 dark:text-zinc-50">

    <header class="flex flex-col gap-10 items-center mb-6 px-6 max-w-[60rem]">
        <h1 class="gradient-title">UP2You</h1>
        <h2 class="text-2xl text-center text-gray-600 dark:text-gray-400 font-bold">Fast Reconstruction of Yourself from Unconstrained Photo Collections</h2>
        <div class="flex flex-col gap-6 items-center">
            <div class="flex flex-row gap-x-8 gap-y-4 flex-wrap justify-center">
                <div class="flex flex-col items-center text-center">
                    <span class="text-xl flex flex-row">Anonymous authors</span>
                </div>
            </div>
            <p class="conference-title text-center">International Conference on Learning Representations (ICLR) 2026</p>
        </div>
    </header>

   
    <main class="px-6 max-w-[60rem] w-full">
     
        <div class="w-full flex justify-center mb-6">
            <video class="w-full h-auto aspect-video rounded-lg" autoplay controls muted loop playsinline>
                <source src="src/assets/teaser1.mp4" type="video/mp4" />
            </video>
        </div>

        
        <p class="text-lg w-full mb-6">
            <b>UP2You</b> reconstructs high-quality textured meshes from unconstrained photos. Our approach effectively handles extremely unconstrained photo collections by rectifying them into orthogonal multi-view images and corresponding normal maps, enabling the reconstruction of detailed 3D clothed portraits.
        </p>

       
        <figure class="w-full flex flex-col gap-2 items-center mb-6">
            <div class="max-h-[35rem] object-contain flex justify-center w-full">
                <img src="src/assets/teaser2.png" alt="" style="max-height: 35rem; object-fit: contain;" />
            </div>
        </figure>

        
        <section class="highlighted-section !max-w-full !px-0 py-12 w-full mx-0 flex justify-center">
            <div class="flex flex-col gap-6 items-center w-full max-w-[60rem] px-8">
                <h2>Paradigm Differences Between Previous Works and UP2You </h2>
                <div class="w-full flex justify-center">
                    <video class="w-full h-auto aspect-video rounded-lg" autoplay controls muted loop playsinline>
                        <source src="src/assets/difference.mp4" type="video/mp4" />
                    </video>
                </div>
                <p class="text-lg w-full">
                    <b>Top:</b> Previous works like PuzzleAvatar and AvatarBooth compress unconstrained photos into implicit personal tokens and DreamBooth weights through fine-tuning, then generate 3D humans via SDS optimization. <br>
                     <b>Bottom:</b> <b>UP2You</b> directly rectifies unconstrained photo collections into orthogonal view images and normals, then reconstructs textured human meshes, achieving superior quality while reducing processing time from 4 hours to 1.5 minutes.
                </p>

                <div style="width: 100%; height: 2px; background: linear-gradient(90deg, #667eea, #764ba2, #f093fb, #f5576c, #4facfe); background-size: 300% 100%; animation: gradientShift 8s ease-in-out infinite; margin: 2rem 0;"></div>
                <h2>Our Results</h2>
                
               
                <div id="carousel1" class="w-full">
                    <div class="flex items-center gap-4">
                        <button id="prev-btn-1" class="carousel-btn" aria-label="Previous image set">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M15 18l-6-6 6-6"/>
                            </svg>
                        </button>
                        <div class="flex-1">
                            <div id="current-item-1" class="flex flex-wrap gap-4 items-center w-full">
                                
                            </div>
                        </div>
                        <button id="next-btn-1" class="carousel-btn" aria-label="Next image set">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M9 18l6-6-6-6"/>
                            </svg>
                        </button>
                    </div>
                    <div id="counter-1" class="carousel-counter"></div>
                </div>

                
                <div id="carousel2" class="w-full">
                    <div class="flex items-center gap-4">
                        <button id="prev-btn-2" class="carousel-btn" aria-label="Previous image set">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M15 18l-6-6 6-6"/>
                            </svg>
                        </button>
                        <div class="flex-1">
                            <div id="current-item-2" class="flex flex-wrap gap-4 items-center w-full">
                                
                            </div>
                        </div>
                        <button id="next-btn-2" class="carousel-btn" aria-label="Next image set">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M9 18l6-6-6-6"/>
                            </svg>
                        </button>
                    </div>
                    <div id="counter-2" class="carousel-counter"></div>
                </div>

                <h2>Pose-Dependent Correlation Maps</h2>
                
           
                <div id="video-carousel" class="w-full">
                    <div class="flex items-center gap-4">
                        <button id="prev-btn-video" class="carousel-btn" aria-label="Previous video">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M15 18l-6-6 6-6"/>
                            </svg>
                        </button>
                        <div class="flex-1">
                            <div id="current-video" class="w-full">
                                
                            </div>
                        </div>
                        <button id="next-btn-video" class="carousel-btn" aria-label="Next video">
                            <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
                                <path d="M9 18l6-6-6-6"/>
                            </svg>
                        </button>
                    </div>
                    <div id="counter-video" class="carousel-counter"></div>
                </div>
            </div>
        </section>

       
        <section class="highlighted-section !max-w-full !px-0 py-12 w-full mx-0 flex justify-center">
            <div class="flex flex-col gap-6 items-center w-full max-w-[60rem] px-8">
                <h2>Related Work</h2>
                <div class="w-full">
                    <ul class="space-y-3 text-lg">
                        <li>
                            <a href="https://github.com/YuliangXiu/PuzzleAvatar" class="text-blue-600 hover:text-blue-800 hover:underline">
                                PuzzleAvatar: Assembly of Avatar from Unconstrained Photo Collections
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/zeng-yifei/AvatarBooth" class="text-blue-600 hover:text-blue-800 hover:underline">
                                AvatarBooth: High-Quality and Customizable 3D Human Avatar Generation
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/huanngzh/MV-Adapter" class="text-blue-600 hover:text-blue-800 hover:underline">
                                MV-Adapter: Multi-view Consistent Image Generation Made Easy
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/pengHTYX/PSHuman" class="text-blue-600 hover:text-blue-800 hover:underline">
                                PSHuman: Photorealistic Single-image 3D Human Reconstruction using Cross-Scale Multiview Diffusion
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/eth-ait/4d-dress" class="text-blue-600 hover:text-blue-800 hover:underline">
                                4D-DRESS: A 4D Dataset of Real-world Human Clothing with Semantic Annotations
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/ytrock/THuman2.0-Dataset" class="text-blue-600 hover:text-blue-800 hover:underline">
                                Function4D: Real-time Human Volumetric Capture from Very Sparse RGBD Sensors
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/DSaurus/Human4DiT" class="text-blue-600 hover:text-blue-800 hover:underline">
                                Human4DiT: 360-degree Human Video Generation with 4D Diffusion Transformer
                            </a>
                        </li>
                        <li>
                            <a href="https://custom-humans.github.io/" class="text-blue-600 hover:text-blue-800 hover:underline">
                                Learning Locally Editable Virtual Humans
                            </a>
                        </li>
                        <li>
                            <a href="https://github.com/SangHunHan92/2K2K" class="text-blue-600 hover:text-blue-800 hover:underline">
                                High-fidelity 3D Human Digitization from Single 2K Resolution Images
                            </a>
                        </li>


                    </ul>
                </div>
            </div>
        </section>
    </main>

    <script src="carousel.js"></script>
</body>
</html>
