[{"command":"settings","settings":{"pluralDelimiter":"\u0003","suppressDeprecationErrors":true,"user":{"uid":0,"permissionsHash":"85d70ff5c59258123846295729decb835a5bed491a3a7e109f48f8ed54760113"}},"merge":true},{"command":"add_css","data":[{"rel":"stylesheet","media":"all","href":"\/sites\/default\/files\/css\/css_s_1GmMDVKilGqTybuDKAE7Jawuom3ouFgrtQF1sZ0q0.css?delta=0\u0026language=en\u0026theme=luv_theme\u0026include=eJzLz4hPzkgsSkwuSS0q1i_LTEnN181JrKrUzclPTMnMSwcA0MIMlQ\u0026exclude=eJxtj1luwzAMRC_kWkcSaImRWUsiQUpx3NPXS5MCQX44nDcAl8CKLmoXyGMkyJxG-IbHEA5eWQtk-sEBuw_MC-EuRTJBDeg-QT-B4sCzh4Q-QUP3bE4o5C7xUCFvjYKdvLfZTWD4MnGrUCgcPsygEBqqOVG-UcYvYenyltlKgvoHm7M-WVCSRlz9SjFhOzJ8SD5eu8Gdla6rnux_guI-9MUvNyPEK237yiWiLe7sqKbBNmtYrhfuhKu5s46FY8_4C1b5i8M"}]},{"command":"add_js","selector":"body","data":[{"src":"\/core\/assets\/vendor\/jquery\/jquery.min.js?v=3.7.1"},{"src":"\/core\/assets\/vendor\/once\/once.min.js?v=1.0.1"},{"src":"\/core\/misc\/drupalSettingsLoader.js?v=10.6.2"},{"src":"\/core\/misc\/drupal.js?v=10.6.2"},{"src":"\/core\/misc\/drupal.init.js?v=10.6.2"},{"src":"\/modules\/custom\/oh_characters\/assets\/video-lazy-loading.c4ea404e.js?v=20260203.135522"}]},{"command":"insert","method":"append","selector":"#images_list","data":"  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/7872610282345764930.png?VersionId=FCpYKUiiEjkc9n5MzFyDMd5QTisLoCPV\u0026amp;itok=aXL9EEME\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/7872610282345764930.png?VersionId=XAVrdpss3VF4zm1HFeXCf0CxG3ahfAJg\u0026amp;itok=lN2oaE4U\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Channeling my inner princess in the city of dreams. \u2728\ud83d\udc57 #bubblyvibes #curiousheart\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022\u0022                   data-video-id=\u00221913\u0022         data-post=\u00220\u0022\n        data-post-id=\u00229037\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Channeling my inner \u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/-2780328970351861139.png?VersionId=2X50wHHi7C88FDxEn5_UKg4QQWc4pURH\u0026amp;itok=QJ698xCu\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/-2780328970351861139.png?VersionId=QxRRGF2o_6J0ghefUWi_vOQmT0_X1Pel\u0026amp;itok=YgOojUVt\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Sunset vibes on the rooftop, feeling on top of the world! \ud83c\udf07\u2728 #Blessed\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022\u0022                   data-video-id=\u00221881\u0022         data-post=\u00221\u0022\n        data-post-id=\u00229005\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Sunset vibes on the \u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/6006180736050474906.png?VersionId=hIapfZGMSkw8Wu.lFIW5zNpNK7caPn3f\u0026amp;itok=Mh1GyD-1\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/6006180736050474906.png?VersionId=vpukG31eW8MuZO4LZKF_dFxmqli3n4uo\u0026amp;itok=J3trHhQR\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Radiating energy under the sun, ready to take on the world! \u2600\ufe0f\u2728 #Vibes\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022\u0022                   data-video-id=\u00221849\u0022         data-post=\u00222\u0022\n        data-post-id=\u00228971\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Radiating energy und\u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/8227708502741591991.png?VersionId=EnAfhUxTj2u2q7he7J6siytRWZT7MeiS\u0026amp;itok=whxQT3De\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/8227708502741591991.png?VersionId=BEKkiMa9IsH.ht8zVzMlSFB5PqmGlRAc\u0026amp;itok=SnmPHCoD\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Sunsets and sparkles, just me living my best life \u2728\ud83d\udc99\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022\u0022                   data-video-id=\u00221210\u0022         data-post=\u00223\u0022\n        data-post-id=\u00228311\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Sunsets and sparkles\u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item video \u0022\u003E\n                \u003Cdiv class=\u0022video-wrapper\u0022 data-video-state=\u0022thumbnail\u0022\u003E\n                                  \u003Cimg\n            class=\u0022thumbnail-image video-thumbnail\u0022\n            src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/video-thumbnails\/video-1744188280_thumbnail.png?VersionId=i.aU_DuiJ_.TWpiawJKpX8QVnXNaZPf0\u0022\n            data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/video-thumbnails\/video-1744188280_thumbnail.png?VersionId=EYc2XJPUxDw.IPoKzfoteMZCwns9NPMe\u0026amp;itok=k8NbmcO9\u0022\n            data-post-description=\u0022Chasing dreams and sunsets - life\u0026#039;s too short to sit still! \ud83c\udf05\ud83d\udcab #SunsetChaser\u0022\n            data-character=\u002298\u0022\n            data-type=\u0022video\u0022\n            data-video-url=\u0022https:\/\/oh-platform-prod.s3.amazonaws.com\/char-post-videos\/98\/video-1744188280.mp4\u0022\n            data-video-id=\u00221003\u0022\n            data-post=\u00224\u0022\n            data-post-id=\u00228093\u0022\n            data-is-multiple=\u0022\u0022\n            alt=\u0022Chasing dreams and s\u0022\n            loading=\u0022lazy\u0022\n            onerror=\u0022console.log(\u0027Thumbnail failed to load:\u0027, this.src); this.style.display=\u0027none\u0027; this.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n          \/\u003E\n                \u003Cvideo class=\u0022thumbnail-image video-player\u0022 loop muted playsinline\n               preload=\u0022none\u0022\n               poster=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/video-thumbnails\/video-1744188280_thumbnail.png?VersionId=i.aU_DuiJ_.TWpiawJKpX8QVnXNaZPf0\u0022               data-post-description=\u0022Chasing dreams and sunsets - life\u0026#039;s too short to sit still! \ud83c\udf05\ud83d\udcab #SunsetChaser\u0022\n               data-character=\u002298\u0022\n               data-type=\u0022video\u0022\n               data-video-url=\u0022https:\/\/oh-platform-prod.s3.amazonaws.com\/char-post-videos\/98\/video-1744188280.mp4\u0022\n               data-video-id=\u00221003\u0022\n               data-post=\u00224\u0022\n               data-post-id=\u00228093\u0022\n               data-is-multiple=\u0022\u0022\n               data-video-index=\u00224\u0022\n               data-auto-play-group=\u0022video-group\u0022\u003E\n          \u003Csource src=\u0022https:\/\/oh-platform-prod.s3.amazonaws.com\/char-post-videos\/98\/video-1744188280.mp4\u0022 type=\u0022video\/mp4\u0022\u003E\n        \u003C\/video\u003E\n        \u003Cdiv class=\u0022video-loading-indicator\u0022\u003E\n          \u003Cdiv class=\u0022loading-spinner\u0022\u003E\u003C\/div\u003E\n        \u003C\/div\u003E\n        \u003Cdiv class=\u0022video-icon\u0022\u003E\n        \u003Csvg width=\u002240\u0022 height=\u002240\u0022 viewBox=\u00220 0 40 40\u0022 fill=\u0022none\u0022 xmlns=\u0022http:\/\/www.w3.org\/2000\/svg\u0022\u003E\n          \u003Crect opacity=\u00220.6\u0022 x=\u00228.33325\u0022 y=\u00228.33337\u0022 width=\u002223.3333\u0022 height=\u002223.3333\u0022 fill=\u0022#302132\u0022\/\u003E\n          \u003Cpath d=\u0022M3.33325 11.25C3.33325 9.17893 5.01218 7.5 7.08325 7.5H32.9166C34.9877 7.5 36.6666 9.17893 36.6666 11.25V28.75C36.6666 30.8211 34.9877 32.5 32.9166 32.5H7.08325C5.01218 32.5 3.33325 30.8211 3.33325 28.75V11.25ZM18.817 13.4129C17.138 12.3394 14.936 13.5452 14.936 15.5379V24.4621C14.936 26.4548 17.138 27.6606 18.817 26.5871L25.7959 22.1251C27.3474 21.1331 27.3474 18.8669 25.7959 17.8749L18.817 13.4129Z\u0022 fill=\u0022white\u0022\/\u003E\n        \u003C\/svg\u003E\n        \u003C\/div\u003E\n      \u003C\/div\u003E\n              \u003Cdiv class=\u0022overlay-video\u0022\u003E\u003C\/div\u003E\n      \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/-375327546731625725.png?VersionId=RdwY9K1pOcl6JNEOaMnbVwwabH3WnL5f\u0026amp;itok=fhDwCtnw\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/-375327546731625725.png?VersionId=2DjeYdItaRlXuP_cuRZTj2kt2NWMrKXf\u0026amp;itok=JmekVTiA\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Glitter and glam backstage vibes \ud83c\udf1f\u2728\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022https:\/\/oh-platform-prod.s3.amazonaws.com\/char-post-videos\/98\/video-1744188280.mp4\u0022                   data-video-id=\u0022575\u0022         data-post=\u00225\u0022\n        data-post-id=\u00227657\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Glitter and glam bac\u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image blurred-item\u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_blurred_small\/s3\/char-post-images\/-4446361665671897649.png?VersionId=nqigXMzXAV24rfKW9N.XAL2MeguJTqPz\u0026amp;itok=eyh9527a\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_blurred\/s3\/char-post-images\/-4446361665671897649.png?VersionId=rkSEvWnV78Lg_jOtpvanAZHuKWUWyCpu\u0026amp;itok=t6uycvrP\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Living for the music, dancing through the sunset! \ud83c\udfb6\u2728\ud83d\ude0d #Vibes\u0022\n        data-secured=\u00221\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                        data-post=\u00226\u0022\n        data-post-id=\u00227530\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Living for the music\u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n  \u003Cdiv\n    class=\u0022image-item image \u0022\u003E\n          \u003Cimg\n        class=\u0022thumbnail-image\u0022\n        src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal_small\/s3\/char-post-images\/-8215698852320597671.png?VersionId=L2BrAB0UKnItlm.PRkBnt4jeJnL4MkFP\u0026amp;itok=55dpx8Bv\u0022\n        data-src=\u0022https:\/\/d3mpf1svyo6ceu.cloudfront.net\/styles\/profile_normal\/s3\/char-post-images\/-8215698852320597671.png?VersionId=8gxB4caFi1gcnu.oa6am3rSDkStPszH7\u0026amp;itok=ayoCDb7K\u0022\n        data-description=\u0022\u0022\n        data-post-description=\u0022Sunset vibes in the city, feeling alive and vibrant! \ud83c\udf06\u2728\u0022\n        data-secured=\u00220\u0022\n        data-character=\u002298\u0022\n        data-type=\u0022image\u0022\n                  data-video-url=\u0022https:\/\/oh-platform-prod.s3.amazonaws.com\/char-post-videos\/98\/video-1744188280.mp4\u0022                   data-video-id=\u0022264\u0022         data-post=\u00227\u0022\n        data-post-id=\u00227327\u0022\n        data-is-multiple=\u0022\u0022\n        alt=\u0022Sunset vibes in the \u0022\n        loading=\u0022lazy\u0022\n        onerror=\u0022this.style.display=\u0027none\u0027; this.nextElementSibling.nextElementSibling.style.display=\u0027flex\u0027;\u0022\n      \/\u003E\n      \u003Cdiv class=\u0022image-icon\u0022\u003E\u003C\/div\u003E\n          \u003C\/div\u003E\n\n\u003Cscript\u003E\n  (function () {\n    \/\/ Auto-play sequence for mobile devices\n    let currentVideoIndex = 0;\n    let videoElements = [];\n    let autoPlayTimer = null;\n    let isAutoPlaying = false;\n\n    \/\/ Check if device is mobile\n    function isMobileDevice() {\n      return \/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini\/i.test(navigator.userAgent);\n    }\n    \n    \/\/ Check if device is iOS\n    function isIOSDevice() {\n      return \/iPad|iPhone|iPod\/.test(navigator.userAgent);\n    }\n\n    \/\/ Initialize video elements\n    function initVideoElements() {\n      videoElements = Array.from(document.querySelectorAll(\u0027.video-wrapper\u0027));\n\n      videoElements.forEach((wrapper, index) =\u003E {\n        const video = wrapper.querySelector(\u0027.video-player\u0027);\n        const thumbnail = wrapper.querySelector(\u0027.video-thumbnail\u0027);\n        const videoIcon = wrapper.querySelector(\u0027.video-icon\u0027);\n\n\n        if (!video) {\n          return;\n        }\n\n        \/\/ iOS-specific: Ensure video is visible and has proper dimensions\n        if (isIOSDevice()) {\n          video.style.display = \u0027block\u0027;\n          video.style.width = \u0027100%\u0027;\n          video.style.height = \u0027auto\u0027;\n          video.style.objectFit = \u0027cover\u0027;\n          \n          \/\/ Force video to show poster or first frame\n          video.addEventListener(\u0027loadstart\u0027, function() {\n            video.style.opacity = \u00271\u0027;\n          });\n          \n          video.addEventListener(\u0027error\u0027, function(e) {\n            \/\/ Show video icon if video fails\n            if (videoIcon) {\n              videoIcon.style.display = \u0027block\u0027;\n            }\n          });\n        }\n\n        \/\/ Add click handler for video icon to start video\n        if (videoIcon) {\n          videoIcon.addEventListener(\u0027click\u0027, function () {\n            currentVideoIndex = index;\n            if (isMobileDevice()) {\n              startAutoPlay();\n            } else {\n              playVideo(index);\n            }\n          });\n        }\n\n        \/\/ For mobile - show play buttons and allow manual start\n        if (isMobileDevice()) {\n          \/\/ Keep play buttons visible for mobile\n          wrapper.style.cursor = \u0027pointer\u0027;\n\n          video.addEventListener(\u0027ended\u0027, function () {\n            showNextVideo();\n          });\n\n          \/\/ Click to start auto-play sequence from any video\n          wrapper.addEventListener(\u0027click\u0027, function () {\n            currentVideoIndex = index;\n            startAutoPlay();\n          });\n        } else {\n          \/\/ Desktop - direct hover to play\/stop without complex state tracking\n          let isVideoPlaying = false;\n\n          wrapper.addEventListener(\u0027mouseenter\u0027, function () {\n            if (!isAutoPlaying \u0026\u0026 !isVideoPlaying) {\n              isVideoPlaying = true;\n              playVideo(index);\n            }\n          });\n\n          wrapper.addEventListener(\u0027mouseleave\u0027, function () {\n            if (!isAutoPlaying \u0026\u0026 isVideoPlaying) {\n              isVideoPlaying = false;\n              stopVideo(index);\n            }\n          });\n\n          \/\/ Click to start auto-play sequence\n          wrapper.addEventListener(\u0027click\u0027, function () {\n            currentVideoIndex = index;\n            startAutoPlay();\n          });\n        }\n      });\n    }\n\n    function playVideo(index) {\n      if (index \u003E= videoElements.length) {\n        return;\n      }\n\n      const wrapper = videoElements[index];\n      const video = wrapper.querySelector(\u0027.video-player\u0027);\n      const thumbnail = wrapper.querySelector(\u0027.video-thumbnail:not(.video-player)\u0027);\n      const videoIcon = wrapper.querySelector(\u0027.video-icon\u0027);\n      const loader = wrapper.querySelector(\u0027.video-loading-indicator\u0027);\n\n\n      if (!video) {\n        return;\n      }\n\n      \/\/ Show loader and fade play button\n      if (loader) {\n        loader.style.display = \u0027block\u0027;\n      }\n      if (videoIcon) {\n        videoIcon.style.opacity = \u00270\u0027;\n        setTimeout(() =\u003E {\n          videoIcon.style.display = \u0027none\u0027;\n        }, 200);\n      }\n\n      \/\/ Load and play video (iOS requires loading on user interaction)\n      const videoUrl = video.dataset.videoUrl;\n      \n      if (!video.src \u0026\u0026 videoUrl) {\n        video.querySelector(\u0027source\u0027).src = videoUrl;\n        video.load();\n      }\n\n      \/\/ Hide thumbnail, show video with smooth transition\n      if (thumbnail) {\n        thumbnail.style.opacity = \u00270\u0027;\n        setTimeout(() =\u003E {\n          thumbnail.style.display = \u0027none\u0027;\n        }, 100);\n      }\n      video.style.display = \u0027block\u0027;\n      video.style.opacity = \u00271\u0027;\n      video.currentTime = 0; \/\/ Reset to start\n\n      \/\/ Add event listeners for iOS video loading\n      video.addEventListener(\u0027loadeddata\u0027, function() {\n        if (loader) {\n          loader.style.display = \u0027none\u0027;\n        }\n        video.play().catch(e =\u003E {\n          showThumbnail(index);\n        });\n      }, { once: true });\n      \n      video.addEventListener(\u0027canplay\u0027, function() {\n        if (loader) {\n          loader.style.display = \u0027none\u0027;\n        }\n      }, { once: true });\n      \n      \/\/ Try to play immediately if already loaded\n      if (video.readyState \u003E= 3) { \/\/ HAVE_FUTURE_DATA\n        if (loader) {\n          loader.style.display = \u0027none\u0027;\n        }\n        video.play().catch(e =\u003E {\n          showThumbnail(index);\n        });\n      }\n    }\n\n    function showThumbnail(index) {\n      if (index \u003E= videoElements.length) {\n        return;\n      }\n\n      const wrapper = videoElements[index];\n      const video = wrapper.querySelector(\u0027.video-player\u0027);\n      const thumbnail = wrapper.querySelector(\u0027.video-thumbnail:not(.video-player)\u0027);\n      const videoIcon = wrapper.querySelector(\u0027.video-icon\u0027);\n      const loader = wrapper.querySelector(\u0027.video-loading-indicator\u0027);\n\n      \/\/ Pause video with smooth transition\n      if (video) {\n        \/\/ video.pause();\n        \/\/ video.style.opacity = \u00270\u0027;\n        setTimeout(() =\u003E {\n          \/\/ video.style.display = \u0027none\u0027;\n        }, 100);\n      }\n\n      \/\/ Show thumbnail and play button with smooth transition\n      if (thumbnail) {\n        thumbnail.style.display = \u0027block\u0027;\n        thumbnail.style.opacity = \u00271\u0027;\n      }\n      if (videoIcon) {\n        videoIcon.style.display = \u0027block\u0027;\n        videoIcon.style.opacity = \u00271\u0027;\n      }\n      if (loader) {\n        loader.style.display = \u0027none\u0027;\n      }\n    }\n\n    function stopVideo(index) {\n      \/\/ stopVideo is just an alias for showThumbnail for clearer intent\n      showThumbnail(index);\n    }\n\n    function startAutoPlay() {\n      isAutoPlaying = true;\n      playVideo(currentVideoIndex);\n    }\n\n    function showNextVideo() {\n      \/\/ Show current video\u0027s thumbnail\n      showThumbnail(currentVideoIndex);\n\n      \/\/ Move to next video\n      currentVideoIndex = (currentVideoIndex + 1) % videoElements.length;\n\n      \/\/ Auto-play next video after delay\n      setTimeout(() =\u003E {\n        if (isAutoPlaying) {\n          playVideo(currentVideoIndex);\n        }\n      }, 500);\n    }\n\n    function stopAutoPlay() {\n      isAutoPlaying = false;\n      showThumbnail(currentVideoIndex);\n      if (autoPlayTimer) {\n        clearTimeout(autoPlayTimer);\n      }\n    }\n\n\n    \/\/ Initialize when DOM is ready\n    if (document.readyState === \u0027loading\u0027) {\n      document.addEventListener(\u0027DOMContentLoaded\u0027, function () {\n        initVideoElements();\n      });\n    } else {\n      initVideoElements();\n    }\n\n    \/\/ Stop auto-play when user scrolls away\n    let lastScrollTime = Date.now();\n    window.addEventListener(\u0027scroll\u0027, function () {\n      lastScrollTime = Date.now();\n      if (isAutoPlaying) {\n        setTimeout(function () {\n          if (Date.now() - lastScrollTime \u003E 2000) { \/\/ 2 seconds of no scrolling\n            \/\/ User stopped scrolling, continue auto-play\n          }\n        }, 2000);\n      }\n    });\n\n  })();\n\u003C\/script\u003E\n\n","settings":null},{"command":"css","selector":".gradient-overlay","argument":{"display":"none"}},{"command":"insert","method":"replaceWith","selector":"#load-more-all","data":"","settings":null}]