<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="robots" content="noindex,nofollow" />

    <meta name="description" content="A self-bootstrapping, context-rich visual dubbing framework that reframes lip editing from inpainting to editing.">
    
    <meta name="keywords" content="visual dubbing, lip sync, diffusion transformer, video editing">
    
    <title>From Inpainting to Editing: Context-Rich Visual Dubbing (Anonymous)</title>
    
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: 'Inter', sans-serif;
            line-height: 1.6;
            color: #333;
            background: linear-gradient(135deg, #404a77 0%, #6a476d 100%);
            min-height: 100vh;
        }

        .container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 20px;
        }

        /* Header */
        .header {
            background: rgba(255, 255, 255, 0.95);
            backdrop-filter: blur(10px);
            padding: 60px 0;
            text-align: center;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
        }

        .title {
            font-size: 4.5rem;
            font-weight: 700;
            margin-bottom: 20px;
            background: linear-gradient(
                90deg,                        /* ← 从左到右 */
                rgb(18, 194, 233) 0%,         /* 青色起点 */
                rgb(196, 113, 237) 50%,       /* 紫色占据中间大部分 */
                rgb(246, 79, 89) 110%         /* 粉红色延伸到文字外一点 */
            );
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }


         .subtitle {
            font-size: 1.3rem;         /* 稍小于主标题 */
            font-weight: 600;
            color: #555;                /* 柔和的深灰 */
            line-height: 1.5;
            text-align: center;
            margin-bottom: 25px;
            max-width: 800px;           /* 防止太宽 */
            margin-left: auto;
            margin-right: auto;
        }

         .authors {
            font-size: 1.2rem;
            font-weight: 500;
            color: #888;       /* 比原来的 #555 更浅 */
            margin-bottom: 15px;
        }

        .affiliations {
            font-size: 1rem;
            color: #777;
            margin-bottom: 30px;
        }

        .links {
            display: flex;
            justify-content: center;
            gap: 20px;
            flex-wrap: wrap;
        }

        .link-btn {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 12px 24px;
            background: linear-gradient(135deg, #667eea, #764ba2);
            color: white;
            text-decoration: none;
            border-radius: 50px;
            font-weight: 500;
            transition: all 0.3s ease;
            box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3);
        }

        .link-btn:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 25px rgba(102, 126, 234, 0.4);
        }

        /* Main Content */
        .main-content {
            background: white;
            margin: 40px auto;
            border-radius: 20px;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
            overflow: hidden;
        }

        .section {
            padding: 60px 40px;
            border-bottom: 1px solid #eee;
        }

        .section:last-child {
            border-bottom: none;
        }

        .section-title {
            font-size: 2.5rem;
            font-weight: 600;
            margin-bottom: 30px;
            text-align: center;
            color: #333;
        }

        .section-title-small {
            font-size: 2.0rem;
            font-weight: 600;
            margin-bottom: 5px;
            text-align: center;
            color: #333;
        }

        .section-subtitle {
            font-size: 1.8rem;
            font-weight: 500;
            margin-bottom: 20px;
            color: #555;
        }

        /* Video Sections */
        .main-video {
            text-align: center;
            margin-bottom: 40px;
        }

        .main-video video {
            width: 100%;
            max-width: 1100px;
            border-radius: 15px;
            box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
        }

        .demo-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 30px;
            margin-top: 40px;
        }

        .demo-item {
            background: #f8f9fa;
            border-radius: 15px;
            padding: 20px;
            text-align: center;
            transition: transform 0.3s ease;
        }

        .demo-item:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
        }

        .demo-video {
            width: 100%;
            border-radius: 10px;
            margin-bottom: 15px;
        }

        .demo-title {
            font-weight: 600;
            color: #333;
            margin-bottom: 10px;
        }

        .demo-description {
            color: #666;
            font-size: 0.9rem;
        }

        .deployment-notice {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            border-radius: 20px;
            padding: 25px 30px;
            margin: 30px auto;
            max-width: 600px;
            color: white;
            display: flex;
            align-items: center;
            gap: 20px;
            box-shadow: 0 8px 32px rgba(102, 126, 234, 0.3);
            position: relative;
            overflow: hidden;
        }

        .deployment-notice::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: linear-gradient(45deg, transparent, rgba(255,255,255,0.1), transparent);
            transform: rotate(45deg);
            animation: shimmer 3s infinite;
        }

        @keyframes shimmer {
            0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
            100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
        }

        .notice-icon {
            font-size: 2.5rem;
            flex-shrink: 0;
            animation: bounce 2s infinite;
        }

        @keyframes bounce {
            0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
            40% { transform: translateY(-10px); }
            60% { transform: translateY(-5px); }
        }

        .notice-content {
            flex: 1;
            z-index: 1;
        }

        .notice-title {
            font-size: 1.4rem;
            font-weight: 700;
            margin-bottom: 8px;
            color: white;
        }

        .notice-description {
            font-size: 1rem;
            line-height: 1.5;
            margin: 0;
            opacity: 0.95;
        }

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

        .link-btn {
            padding: 12px 24px;
            background: linear-gradient(135deg, #495586 0%, #684d84 100%);
            color: white;
            text-decoration: none;
            border-radius: 25px;
            font-weight: 500;
            transition: all 0.3s ease;
            box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3);
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 0.95rem;
        }

        .link-btn:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 20px rgba(102, 126, 234, 0.4);
        }

        .try-btn-cn {
            background: linear-gradient(135deg, #e53e3e 0%, #c53030 100%);
            box-shadow: 0 4px 15px rgba(229, 62, 62, 0.3);
        }

        .try-btn-cn:hover {
            box-shadow: 0 6px 20px rgba(229, 62, 62, 0.4);
        }

        .try-btn-global {
            background: linear-gradient(135deg, #38a169 0%, #2f855a 100%);
            box-shadow: 0 4px 15px rgba(56, 161, 105, 0.3);
        }

        .try-btn-global:hover {
            box-shadow: 0 6px 20px rgba(56, 161, 105, 0.4);
        }

        /* 响应式设计 */
        @media (max-width: 768px) {
            .deployment-notice {
                flex-direction: column;
                text-align: center;
                padding: 20px;
                margin: 20px auto;
            }
            
            .notice-icon {
                font-size: 2rem;
            }
            
            .notice-title {
                font-size: 1.2rem;
            }
            
            .notice-description {
                font-size: 0.9rem;
            }
            
            .links {
                gap: 10px;
            }
            
            .link-btn {
                padding: 10px 18px;
                font-size: 0.85rem;
            }
        }

        @media (max-width: 480px) {
            .links {
                flex-direction: column;
                align-items: center;
            }
            
            .link-btn {
                width: 200px;
                justify-content: center;
            }
        }

        /* Features */
        .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 30px;
            margin-top: 40px;
        }

        .feature-card {
            background: linear-gradient(135deg, #f8f9fa, #e9ecef);
            padding: 30px;
            border-radius: 15px;
            text-align: center;
            transition: transform 0.3s ease;
        }
        

        .feature-card:hover {
            transform: translateY(-5px);
        }

        .feature-icon {
            font-size: 3rem;
            margin-bottom: 20px;
            background: linear-gradient(135deg, #495799, #6c4891);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .feature-title {
            font-size: 1.3rem;
            font-weight: 600;
            margin-bottom: 15px;
            color: #333;
        }

        .feature-description {
            color: #666;
            line-height: 1.6;
            text-align: left;
        }

        .demo-category {
            margin-bottom: 60px;
        }

        .category-title {
            font-size: 24px;
            font-weight: 600;
            color: #333;
            margin-bottom: 10px;
            text-align: center;
        }

        .category-description {
            color: #666;
            text-align: center;
            margin-bottom: 30px;
            font-size: 16px;
        }

        .demo-slider {
            position: relative;
            overflow: hidden;
            border-radius: 12px;
        }

        .demo-track {
            display: flex;
            transition: transform 0.3s ease;
            gap: 20px;
            padding: 0 20px;
        }

        .demo-item {
            flex: 0 0 300px;
            background: white;
            border-radius: 12px;
            overflow: hidden;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
            transition: transform 0.3s ease;
        }

        .demo-item:hover {
            transform: translateY(-5px);
        }

        .demo-video {
            width: 250px;
            height: 350px;
            object-fit: cover;
            border-radius: 12px;
            transition: object-fit 0.3s ease;
        }
        .demo-video:fullscreen {
            object-fit: contain;
            border-radius: 0;
        }
        .demo-video:-webkit-full-screen {
            object-fit: contain;
            border-radius: 0;
        }
        .demo-video:-moz-full-screen {
            object-fit: contain;
            border-radius: 0;
        }
        .demo-video:-ms-fullscreen {
            object-fit: contain;
            border-radius: 0;
        }

        .slider-btn {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: rgba(255, 255, 255, 0.9);
            border: none;
            border-radius: 50%;
            width: 40px;
            height: 40px;
            font-size: 20px;
            cursor: pointer;
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
            transition: all 0.3s ease;
            z-index: 10;
        }

        .slider-btn:hover {
            background: white;
            transform: translateY(-50%) scale(1.1);
        }

        .prev-btn {
            left: 10px;
        }

        .next-btn {
            right: 10px;
        }

        /* Abstract */
        .abstract-text {
            font-size: 1.1rem;
            line-height: 1.8;
            color: #555;
            text-align: justify;
        }

        /* Method Overview */
        .method-image {
            width: 100%;
            border-radius: 0;
            margin: 20px 0 10px 0;
            box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
        }

        .method-overview-text {
            max-width: 1050px;
            margin: 10px auto 0 auto;  /* 紧跟图片，居中块，但文本左对齐 */
            color: #666;
            line-height: 1.6;
            text-align: left;
        }

        /* Results */
        .results-table {
            width: 100%;
            border-collapse: collapse;
            margin: 30px 0;
            font-size: 0.9rem;
        }

        .results-table th,
        .results-table td {
            padding: 12px;
            text-align: center;
            border: 1px solid #ddd;
        }

        .results-table th {
            background: linear-gradient(135deg, #667eea, #764ba2);
            color: white;
            font-weight: 600;
        }

        .results-table tr:nth-child(even) {
            background: #f8f9fa;
        }

        .best-score {
            background: #d4edda !important;
            font-weight: 600;
            color: #155724;
        }
        
        /* Responsive */
        @media (max-width: 768px) {
            .title {
                font-size: 2.5rem;
            }

            .section {
                padding: 40px 20px;
            }

            .demo-grid {
                grid-template-columns: 1fr;
            }

            .features-grid {
                grid-template-columns: 1fr;
            }

            .links {
                flex-direction: column;
                align-items: center;
            }
        }

        /* Animation */
        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .animate-on-scroll {
            animation: fadeInUp 0.8s ease-out;
        }

        .narrow-left {
            max-width: 900px;
            margin: 0 auto;
            text-align: left;
            line-height: 1.6;
        }

    </style>
</head>
<body>
    <!-- Header -->
    <div class="header">
        <div class="container">
            <h1 class="title">X-Dub</h1>
            <p class="subtitle">From Inpainting to Editing:<br>
            Unlocking Robust Mask-Free Visual Dubbing via Generative Bootstrapping</p>
            
            <div class="authors">
                <strong>Anonymous Authors</strong>
            </div>
            
            
            
            <div class="links">
                <!-- <a href="#" class="link-btn">
                    <i class="fas fa-file-pdf"></i> Paper
                </a> -->
                <a href="#" class="link-btn">
                    <i class="fab fa-github"></i> Code (Coming Soon)
                </a>
                <!-- <a href="#" class="link-btn">
                    <i class="fas fa-database"></i> Benchmark (Coming Soon)
                </a> -->
            </div>
        </div>
    </div>

    <!-- Main Content -->
    <div class="container">
        <div class="main-content">
            
            <!-- Main Video Demo -->
            <div class="section">
                <h2 class="section-title">Demo Video</h2>
                <p style="margin: 20px auto 30px auto; max-width: 650px; color: #444; text-align: left; font-style: normal; line-height: 1.6; font-size: 1.1rem;">
                <strong>TL;DR:</strong> We propose a generative bootstrapping framework that unlocks a high-quality mask-free video dubber.
It achieves precise, natural lip-sync editing with strong identity preservation—robust even under occlusions, lighting changes, and stylized characters.
                </p>
                <div class="main-video">
                    <video controls preload="auto" playsinline webkit-playsinline="true" x5-playsinline="true" x5-video-player-type="h5" x5-video-player-fullscreen="false" >
                        <source src="./video/demo_video.mp4" type="video/mp4">
                        Your browser does not support the video tag.
                    </video>
                </div>
            </div>
            
            
            <!-- ==================== NEW SECTION: HDTF Results (Reviewer LNYW) ==================== -->
            <div class="section">
                <h2 class="section-title-small">Qualitative Results on the HDTF dataset<br>

                </h2>
                
                <!-- Sample 1: 一行一个，宽度拉满 -->
                <div class="main-video" style="margin-bottom: 50px;">
                    <h3 class="demo-title" style="margin-bottom: 15px; font-size: 1.2rem;">HDTF Sample 1</h3>
                    <video controls preload="metadata" style="box-shadow: 0 4px 20px rgba(0,0,0,0.1);">
                        <source src="./video/hdtf_1.mp4" type="video/mp4">
                        Your browser does not support the video tag.
                    </video>
                </div>

                <!-- Sample 2 -->
                <div class="main-video" style="margin-bottom: 50px;">
                    <h3 class="demo-title" style="margin-bottom: 15px; font-size: 1.2rem;">HDTF Sample 2</h3>
                    <video controls preload="metadata" style="box-shadow: 0 4px 20px rgba(0,0,0,0.1);">
                        <source src="./video/hdtf_21.mp4" type="video/mp4">
                    </video>
                </div>

                <!-- Sample 3 -->
                <div class="main-video" style="margin-bottom: 50px;">
                    <h3 class="demo-title" style="margin-bottom: 15px; font-size: 1.2rem;">HDTF Sample 3</h3>
                    <video controls preload="metadata" style="box-shadow: 0 4px 20px rgba(0,0,0,0.1);">
                        <source src="./video/hdtf_34.mp4" type="video/mp4">
                    </video>
                </div>

                <!-- Sample 4 -->
                <div class="main-video">
                    <h3 class="demo-title" style="margin-bottom: 15px; font-size: 1.2rem;">HDTF Sample 4</h3>
                    <video controls preload="metadata" style="box-shadow: 0 4px 20px rgba(0,0,0,0.1);">
                        <source src="./video/hdtf_39.mp4" type="video/mp4">
                    </video>
                </div>
            </div>

            <!-- ==================== NEW SECTION: Long Video (Reviewer h2PZ) ==================== -->
            <div class="section">
                <h2 class="section-title-small">Long Video Generation<br>
                </h2>
                
                <!-- 翻译后的解释文本 -->
                <p class="narrow-left" style="text-align: center; max-width: 800px; margin: 0 auto 30px auto; color: #555;">
                    Our mask-free video dubber demonstrates the capability to generate extended lip-sync videos (exceeding 1 min) while maintaining consistency, with no observable color or identity drift between the initial and final frames.
                </p>

                <!-- 横屏视频容器 -->
                <div class="main-video">
                    <!-- width: 80% 设置宽度占比 -->
                    <!-- height: auto 保持宽高比 -->
                    <!-- display: block; margin: 0 auto; 用于让视频在容器内水平居中 -->
                    <video controls preload="metadata" 
                        style="width: 80%; max-width: 1200px; height: auto; display: block; margin: 0 auto; border-radius: 15px; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);">
                        <source src="./video/long_video.mp4" type="video/mp4">
                        Your browser does not support the video tag.
                    </video>
                </div>
            </div>

            <!-- ==================== NEW SECTION: Compression Noise (Reviewer h2PZ) ==================== -->
            <div class="section">
                <h2 class="section-title-small">Robustness to In-the-Wild Artifacts<br>
                </h2>
                
                <p class="narrow-left" style="text-align: center; max-width: 800px; margin: 0 auto 30px auto; color: #555;">
                    Trained to map potentially imperfect synthetic inputs to high-quality real video targets, our mask-free dubber effectively learns to suppress visual artifacts. It demonstrates strong robustness to in-the-wild scenarios—maintaining precise lip synchronization even when the input suffers from severe compression noise.
                </p>

                <div class="main-video">
                    <!-- width: 80% 设置宽度占比 -->
                    <!-- height: auto 保持宽高比 -->
                    <!-- display: block; margin: 0 auto; 用于让视频在容器内水平居中 -->
                    <video controls preload="metadata" 
                        style="width: 80%; max-width: 1200px; height: auto; display: block; margin: 0 auto; border-radius: 15px; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);">
                        <source src="./video/noise_video.mp4" type="video/mp4">
                        Your browser does not support the video tag.
                    </video>
                </div>
            </div>




            <div class="section">
            <h2 class="section-title">Key Features</h2>
            <div class="features-grid">
                
                <!-- 1. Self-bootstrapping & Context-rich -->
                <div class="feature-card">
                <div class="feature-icon">
                    <i class="fas fa-layer-group"></i>
                </div>
                <h3 class="feature-title">Self-Bootstrapping, Context-Rich Dubbing</h3>
                <p class="feature-description">
                    Learns from self-generated pairs and edits videos directly without explicit masks or reference frames, leveraging full-frame temporal context to cast dubbing as a complete editing task rather than partial inpainting.
                </p>
                </div>

                <!-- 2. Precise, Natural Lip-Sync (Leakage-Resistant) -->
                <div class="feature-card">
                <div class="feature-icon">
                    <i class="fas fa-wave-square"></i>
                </div>
                <h3 class="feature-title">Accurate, Natural Lip-Sync</h3>
                <p class="feature-description">
                    Produces speech-aligned lip movements while avoiding leakage and off-target edits, delivering accurate, artifact-free synchronization that reads naturally on frame and in motion.
                </p>
                </div>

                <!-- 3. Identity & Pose Stability + Long Video -->
                <div class="feature-card">
                <div class="feature-icon">
                    <i class="fas fa-user-shield"></i>
                </div>
                <h3 class="feature-title">Identity-Faithful, Duration-Unlimited</h3>
                <p class="feature-description">
                    Preserves face identity and head pose across extended sequences by exploiting rich video context, maintaining temporal consistency without drift or identity collapse even in unlimited-duration dubbing.
                </p>
                </div>

                <!-- 4. Robustness & Style Generalization -->
                <div class="feature-card">
                <div class="feature-icon">
                    <!-- fa-sparkles (FA6) → fa-magic (FA5 Free) to avoid missing icon -->
                    <i class="fas fa-magic"></i>
                </div>
                <h3 class="feature-title">Robust to Occlusions, Lighting, and Styles</h3>
                <p class="feature-description">
                    Handles occlusions and challenging lighting, and generalizes to stylized, non-human, and AI-generated characters, extending beyond traditional face-dependent methods.
                </p>
                </div>

            </div>
            </div>


           

            <!-- Acknowledgments -->
            <div class="section" style="text-align: left; border-bottom: none;">
            <h2 class="section-title">Acknowledgments</h2>
            <p class="narrow-left" style="color:#666; margin-bottom:20px;">
                We gratefully acknowledge the open resources provided by 
                <a href="https://civitai.com" style="color: #444; text-decoration: none; font-weight: 500;">Civitai</a>, 
                <a href="https://mixkit.co/" style="color: #444; text-decoration: none; font-weight: 500;">Mixkit</a>, and 
                <a href="https://www.pexels.com/" style="color: #444; text-decoration: none; font-weight: 500;">Pexels</a>.  
                The demonstration videos include both real-world and generative materials sourced from these platforms, 
                which help illustrate the generality and robustness of our dubbing system.  
                All materials are used for research and demonstration purposes only.
            </p>
            </div>

            <!-- Ethical Considerations -->
            <div class="section" style="text-align: center; border-bottom: none;">
            <h2 class="section-title">Ethical Considerations</h2>
            <p class="narrow-left" style="color:#666; margin-bottom:20px;">
                All video and audio materials presented on this page are either publicly available or synthetically generated.  
                They are used solely for academic research and peer review to illustrate the technical scope of visual dubbing and lip-sync editing.  
                The materials are non-commercial and provided only for demonstration under fair use.  
                No identity, likeness, or content ownership beyond research illustration is implied.
            </p>
            </div>

        </div>
    </div>


    <script>
        // Smooth scrolling for anchor links
        document.querySelectorAll('a[href^="#"]').forEach(anchor => {
            anchor.addEventListener('click', function (e) {
                e.preventDefault();
                document.querySelector(this.getAttribute('href')).scrollIntoView({
                    behavior: 'smooth'
                });
            });
        });

        // Add animation on scroll
        const observerOptions = {
            threshold: 0.1,
            rootMargin: '0px 0px -50px 0px'
        };

        const observer = new IntersectionObserver((entries) => {
            entries.forEach(entry => {
                if (entry.isIntersecting) {
                    entry.target.classList.add('animate-on-scroll');
                }
            });
        }, observerOptions);

        document.querySelectorAll('.section').forEach(section => {
            observer.observe(section);
        });
        
        let currentPosition = {
            'identity-track': 0,
            'occlusion-track': 0,
            'stylistic-track': 0
        };

        function slideLeft(trackId) {
            const track = document.getElementById(trackId);
            const itemWidth = 320; // 300px + 20px gap
            
            currentPosition[trackId] = Math.min(currentPosition[trackId] + itemWidth, 0);
            track.style.transform = `translateX(${currentPosition[trackId]}px)`;
        }

        function slideRight(trackId) {
            const track = document.getElementById(trackId);
            const itemWidth = 320; // 300px + 20px gap
            const maxScroll = -(track.children.length - 3) * itemWidth; // 显示3个视频
            
            currentPosition[trackId] = Math.max(currentPosition[trackId] - itemWidth, maxScroll);
            track.style.transform = `translateX(${currentPosition[trackId]}px)`;
        }

        // 支持触摸滑动（移动端）
        document.addEventListener('DOMContentLoaded', function() {
            document.querySelectorAll('.demo-track').forEach(track => {
                let startX = 0;
                let currentX = 0;
                let isDragging = false;
                
                track.addEventListener('touchstart', (e) => {
                    startX = e.touches[0].clientX;
                    isDragging = true;
                });
                
                track.addEventListener('touchmove', (e) => {
                    if (!isDragging) return;
                    e.preventDefault();
                    currentX = e.touches[0].clientX - startX;
                    track.style.transform = `translateX(${currentPosition[track.id] + currentX}px)`;
                });
                
                track.addEventListener('touchend', () => {
                    if (!isDragging) return;
                    isDragging = false;
                    
                    if (Math.abs(currentX) > 50) {
                        if (currentX > 0) {
                            slideLeft(track.id);
                        } else {
                            slideRight(track.id);
                        }
                    } else {
                        track.style.transform = `translateX(${currentPosition[track.id]}px)`;
                    }
                    currentX = 0;
                });
            });
        });

        // 鼠标拖拽支持（桌面端）
        document.addEventListener('DOMContentLoaded', function() {
            document.querySelectorAll('.demo-track').forEach(track => {
                let startX = 0;
                let currentX = 0;
                let isDragging = false;
                
                track.addEventListener('mousedown', (e) => {
                    startX = e.clientX;
                    isDragging = true;
                    track.style.cursor = 'grabbing';
                    e.preventDefault();
                });
                
                document.addEventListener('mousemove', (e) => {
                    if (!isDragging) return;
                    currentX = e.clientX - startX;
                    track.style.transform = `translateX(${currentPosition[track.id] + currentX}px)`;
                });
                
                document.addEventListener('mouseup', () => {
                    if (!isDragging) return;
                    isDragging = false;
                    track.style.cursor = 'grab';
                    
                    if (Math.abs(currentX) > 50) {
                        if (currentX > 0) {
                            slideLeft(track.id);
                        } else {
                            slideRight(track.id);
                        }
                    } else {
                        track.style.transform = `translateX(${currentPosition[track.id]}px)`;
                    }
                    currentX = 0;
                });
            });
        });
    </script>
</body>
</html>