{"version":3,"file":"studio-BuU05kRD.js","sources":["../../src/javascripts/studio.js"],"sourcesContent":["document.addEventListener(\"DOMContentLoaded\", () => {\n gsap.registerPlugin(ScrollToPlugin);\n gsap.registerPlugin(TextPlugin);\n // Initialize Lenis\n function smoothScroll() {\n const lenis = new Lenis({\n duration: 2,\n smooth: true,\n autoRaf: true,\n easing: (t) => Math.min(1, 1.001 - Math.pow(2, -10 * t))\n });\n\n // Call scrollTo once\n lenis.scrollTo(0);\n\n // Define the RAF loop\n function raf(time) {\n lenis.raf(time);\n requestAnimationFrame(raf);\n }\n\n // Start the animation frame loop\n requestAnimationFrame(raf);\n }\n\n smoothScroll();\n\n\n\n const clientData = [\n {\n \"name\": \"THR India\",\n \"logo\": \"/Logos/thr_logo.webp\",\n \"image\": \"/brands/thr_our_studio.webp\"\n },\n {\n \"name\": \"Esquire India\",\n \"logo\": \"/Logos/esquire_logo.webp\",\n \"image\": \"/brands/esquire_our_studio.webp\"\n },\n {\n \"name\": \"Manifest\",\n \"logo\": \"/Logos/manifest.webp\",\n \"image\": \"/brands/manifest_our_studio.webp\"\n },\n {\n \"name\": \"RPSG Group\",\n \"logo\": \"/Logos/RPSG_group_logo.webp\",\n \"image\": \"/brands/rpsg_group_our_studio.webp\"\n },\n {\n \"name\": \"RPSG Lifestyle Media\",\n \"logo\": \"/Logos/RPSG_media_logo.webp\",\n \"image\": \"/brands/rpsg_media_our_studio.webp\"\n },\n {\n \"name\": \"Point Of\",\n \"logo\": \"/Logos/point.png\",\n \"image\": \"/brands/po_our_studio.webp\"\n },\n {\n \"name\": \"Wealth Fusion\",\n \"logo\": \"/Logos/wf_logo.webp\",\n \"image\": \"/brands/wealth_fusion_our_studio.webp\"\n },\n {\n \"name\": \"Casa Carigar\",\n \"logo\": \"/Logos/cc_logo_2.webp\",\n \"image\": \"/brands/cc_our_studio.webp\"\n },\n {\n \"name\": \"WineeMedia\",\n \"logo\": \"/Logos/wineemedia_logo_2.webp\",\n \"image\": \"/brands/wineemedia_our_studio.webp\"\n },\n {\n \"name\": \"JustNosh\",\n \"logo\": \"/Logos/justnosh_logo.webp\",\n \"image\": \"/brands/just_nosh_our_studio.webp\"\n },\n {\n \"name\": \"Hefty Art\",\n \"logo\": \"/Logos/hefty_art_logo.webp\",\n \"image\": \"/brands/hefty_art_our_studio.webp\"\n },\n {\n \"name\": \"Khelo Esports\",\n \"logo\": \"/Logos/khelo_esport_logo_2.webp\",\n \"image\": \"/brands/khelo_esports_our_studio.webp\"\n },\n {\n \"name\": \"The Senseis Store\",\n \"logo\": \"/Logos/sensei_store_logo.webp\",\n \"image\": \"/brands/sensei_store_our_studio.webp\"\n },\n {\n \"name\": \"Mr. & Mrs.\",\n \"logo\": \"/Logos/mr_and_mrs_films_logo.webp\",\n \"image\": \"/brands/mr_and_mrs_our_studio.webp\"\n },\n {\n \"name\": \"Rage\",\n \"logo\": \"/Logos/rage_media_logo_2.webp\",\n \"image\": \"/brands/rage_our_studio.webp\"\n },\n {\n \"name\": \"Dhamaka\",\n \"logo\": \"/Logos/dhamaka_record_logo.webp\",\n \"image\": \"/brands/dhamaka_records_our_studio.webp\"\n },\n {\n \"name\": \"Indian Gaming League\",\n \"logo\": \"/Logos/the_greek_life_logo_2.webp\",\n \"image\": \"/brands/IGL_our_studio.webp\"\n },\n {\n \"name\": \"The Greek Life\",\n \"logo\": \"/Logos/the_greek_life_logo_2.webp\",\n \"image\": \"/brands/greek_life_our_studio.webp\"\n },\n {\n \"name\": \"I White Korea\",\n \"logo\": \"/Logos/i_white_korea_logo.webp\",\n \"image\": \"/brands/iWhiteKorea_our_studio.webp\"\n },\n {\n \"name\": \"ResideInBeing\",\n \"logo\": \"/Logos/rib.avif\",\n \"image\": \"/brands/reside_in_being_our_studio.webp\"\n },\n ]\n\n function homeLoader() {\n var loader = gsap.timeline()\n loader\n .from(\".upper\", {\n opacity: 0,\n duration: .8,\n ease: \"ease-in-out\",\n delay: 2,\n stagger: {\n from: \"center\",\n amount: .2\n }\n }, \"a\")\n\n .from(\".lower\", {\n opacity: 0,\n duration: .8,\n ease: \"ease-in-out\",\n stagger: {\n amount: .2\n },\n delay: 2.1,\n }, \"a\")\n\n .from(\"#toph\", {\n top: \"50%\",\n duration: .8,\n ease: \"power3.out\",\n }, \"b\")\n .from(\".banner-studio\", {\n opacity: 0,\n duration: 1,\n delay: -.5,\n ease: \"power3.out\",\n }, \"c\")\n .from(\"nav\", {\n opacity: 0,\n duration: 1,\n delay: -.5,\n ease: \"power3.out\",\n }, \"c\")\n .to(\".btmwrap\", {\n opacity: 1,\n duration: 1,\n delay: -.5,\n ease: \"power3.out\",\n }, \"c\")\n }\n homeLoader()\n\n\n function textEffectAnimation() {\n document.querySelectorAll(\".text-effect .effect\").forEach(function (element) {\n var clutter2 = \"\"\n element.textContent.split(\"\").forEach(function (letter) {\n if (letter === \" \") {\n clutter2 += \" \"\n } else {\n clutter2 += `${letter}`\n }\n })\n element.innerHTML = clutter2\n })\n\n document.querySelectorAll(\".text-effect\").forEach(function (elem) {\n elem.addEventListener(\"mouseenter\", function (e) {\n gsap.fromTo(e.currentTarget.children[0].querySelectorAll(\"span\"), {\n y: \"0%\",\n }, {\n y: \"-100%\",\n // duration: .8,\n stagger: {\n amount: .2\n },\n })\n gsap.fromTo(e.currentTarget.children[1].querySelectorAll(\"span\"), {\n y: \"0%\",\n }, {\n y: \"-100%\",\n // duration: .8,\n stagger: {\n amount: .2\n },\n })\n })\n })\n }\n textEffectAnimation()\n\n function serviceListingAnimation() {\n const serviceDets = [\n \"Digging deep to define your audience, vision, and what sets you apart.\",\n \"Positioning your brand with a clear mission and a bold identity.\",\n \"Crafting a voice and visual language that actually speaks to people.\",\n \"Designing logos, color palettes, and typography that make you instantly recognizable.\",\n \"Creating high-impact visuals that bring your brand to life.\",\n \"Writing words that don’t just fill space but make people feel something.\",\n \"Designing everything from business cards to billboards—cohesive, striking, and unforgettable.\",\n \"Designing experiences that feel intuitive, effortless, and built for engagement.\",\n \"Crafting sleek, high-end visuals that make your brand look like a million bucks.\",\n \"Fast, fluid, and pixel-perfect—our websites don’t just work; they impress.\",\n \"This is our playground. We craft mind-blowing GSAP animations that make websites feel alive.\",\n \"Powering your site with solid, scalable, and headache-free architecture.\",\n \"From technical SEO to on-page magic, we help you rank higher and get seen by the right people.\",\n \"Rock-solid hosting that keeps your website lightning-fast and always online.\",\n \"No compromises—enterprise-grade security to keep your data locked down.\",\n \"Because the internet never sleeps, and neither do we when it comes to keeping your site running.\",\n \"Powering high-performance Shopify stores with custom design, seamless UX, and rock-solid scalability.\",\n \"Ditch the templates—our tailor-made GSAP-enhanced stores deliver next-level design, freedom, and immersive shopping experiences.\",\n \"Building dynamic platforms where multiple vendors, customers, and cutting-edge features come together for a seamless ecosystem.\",\n \"Fine-tuning online stores with intuitive UX, frictionless checkouts, and data-driven strategies to boost conversions.\",\n \"Designing and developing sleek, high-performance apps that people actually love using.\",\n \"We don’t do cookie-cutter solutions—we build CMS platforms tailored to your needs.\",\n \"Whether it's niche or mass-market, we build digital marketplaces that stand out and scale up.\",\n \"High-traffic, high-functionality platforms designed for brands that want to be heard.\",\n \"Analyzing speed, security, and infrastructure to keep your platform fast, safe, and ahead of the game.\",\n \"Expert guidance on bespoke digital solutions, from choosing the right tech stack to building scalable, future-ready systems.\",\n \"A squad of elite developers, designers, and strategists working as an extension of your in-house team.\"\n ]\n\n document.querySelectorAll(\".service-wrap .text-effect\").forEach(function (textEffect) {\n textEffect.addEventListener(\"mouseenter\", function (e) {\n const text = serviceDets[e.target.dataset.index]\n\n gsap.to(document.querySelector(\"#about-service-text\"), {\n text: text,\n duration: 1,\n ease: \"power3.out\",\n overwrite: \"auto\"\n })\n })\n textEffect.addEventListener(\"mouseleave\", function () {\n gsap.to(document.querySelector(\"#about-service-text\"), {\n text: \"\",\n duration: 1,\n ease: \"power3.out\",\n overwrite: \"auto\"\n })\n })\n })\n }\n serviceListingAnimation()\n var isMenuService = false;\n var isService = false;\n function serviceAnimation() {\n var previousLink = \"\"\n\n document.querySelectorAll(\".service-open-btn\").forEach(function (btn) {\n btn.addEventListener(\"click\", function (e) {\n document.querySelector(\"#nav-service\").classList.add(\"active\");\n document.querySelector(\"#studio-btn\").classList.remove(\"active\");\n isService = !isService;\n openService()\n })\n })\n document.querySelector(\"#closeService\").addEventListener(\"click\", function () {\n isService = !isService;\n openService()\n document.querySelector(\"#menu-button\").textContent = \"close\"\n isMenuService = false;\n this.classList.remove(\"active\");\n document.querySelector(\"#studio-btn\").classList.add(\"active\");\n })\n\n\n }\n function openService() {\n if (isService) {\n gsap.set(\"nav\", { backgroundColor: \"#fff\" })\n gsap.to(\"#main\", {\n top: \"calc(100% - 40px)\",\n ease: \"power3.out\",\n duration: 1.2\n })\n gsap.to(\"#service-page\", {\n top: \"-40px\",\n ease: \"power3.out\",\n duration: 1.2,\n onComplete: () => {\n gsap.set(\"body\", { overflow: \"hidden\" })\n }\n })\n } else {\n document.querySelector(\"#nav-service\").classList.remove(\"active\")\n gsap.set(\"nav\", { backgroundColor: \"transparent\" })\n gsap.to(\"#main\", {\n top: \"0%\",\n ease: \"power3.out\",\n duration: 1.2\n })\n gsap.to(\"#service-page\", {\n top: \"-100%\",\n ease: \"power3.out\",\n duration: 1.2,\n onComplete: () => {\n gsap.set(\"body\", { overflow: \"auto\" })\n // setTimeout(() => {\n // ScrollTrigger.refresh();\n // }, 200);\n }\n })\n }\n }\n serviceAnimation()\n\n function studioSection1Animation() {\n var tlh = gsap.timeline({\n scrollTrigger: {\n trigger: \"#section1-studio\",\n scroller: \"body\",\n start: \"top top\",\n end: \"top -100%\",\n pin: true,\n scrub: 1\n }\n })\n tlh\n .to(\".banner-studio\", {\n clipPath: \"polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%)\"\n }, \"a\")\n .to(\".banner-studio img\", {\n objectPosition: \"50% 10%\"\n }, \"a\")\n .to(\"#toph\", {\n y: -70,\n opacity: 0,\n duration: .3\n }, \"a\")\n .to(\"#btmh\", {\n y: 70,\n opacity: 0,\n duration: .3\n }, \"a\")\n }\n studioSection1Animation()\n\n function brandListingAnimtion() {\n var clutter = \"\"\n clientData.forEach(function (data, i) {\n clutter += `
${i + 1 > 9 ? i + 1 : `0${i + 1}`}.
\n${data.name}
\n