.elementor-3626 .elementor-element.elementor-element-748335a{--display:flex;--position:fixed;top:16px;--z-index:9999;}body:not(.rtl) .elementor-3626 .elementor-element.elementor-element-748335a{left:16px;}body.rtl .elementor-3626 .elementor-element.elementor-element-748335a{right:16px;}.elementor-3626 .elementor-element.elementor-element-c22a0a5{--display:flex;--position:fixed;top:0px;--z-index:9999;}body:not(.rtl) .elementor-3626 .elementor-element.elementor-element-c22a0a5{left:0px;}body.rtl .elementor-3626 .elementor-element.elementor-element-c22a0a5{right:0px;}.elementor-3626 .elementor-element.elementor-element-738270c{--display:flex;--min-height:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-3626 .elementor-element.elementor-element-738270c:not(.elementor-motion-effects-element-type-background), .elementor-3626 .elementor-element.elementor-element-738270c > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#54595F00;background-image:url("https://geargolem.com/wp-content/uploads/2025/10/Gear_Golem_Background.png");background-position:bottom left;background-size:cover;}.elementor-3626 .elementor-element.elementor-element-3ea7c5b > .elementor-widget-container{--e-transform-translateX:-164px;--e-transform-translateY:-12px;--e-transform-scale:0.7;margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-3626 .elementor-element.elementor-element-3ea7c5b.elementor-element{--align-self:flex-start;}.elementor-3626 .elementor-element.elementor-element-d91d71a{--display:flex;--margin-top:0px;--margin-bottom:110px;--margin-left:0px;--margin-right:0px;--padding-top:110px;--padding-bottom:110px;--padding-left:10px;--padding-right:10px;}.elementor-3626 .elementor-element.elementor-element-d91d71a:not(.elementor-motion-effects-element-type-background), .elementor-3626 .elementor-element.elementor-element-d91d71a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://geargolem.com/wp-content/uploads/2025/05/bg-shape.png");background-position:top center;}.elementor-3626 .elementor-element.elementor-element-564955a > .elementor-widget-container{margin:-54px 0px 0px 0px;}.elementor-3626 .elementor-element.elementor-element-564955a .section-title{text-align:center;}.elementor-3626 .elementor-element.elementor-element-564955a .section-title span{background-color:var( --e-global-color-accent );}.elementor-3626 .elementor-element.elementor-element-564955a .section-title h2{color:#FFFFFF;}.elementor-3626 .elementor-element.elementor-element-564955a .section-title h2 span{color:var( --e-global-color-accent );}.elementor-3626 .elementor-element.elementor-element-18333b5{--display:flex;}.elementor-3626 .elementor-element.elementor-element-267b90d{--e-image-carousel-slides-to-show:3;}.elementor-3626 .elementor-element.elementor-element-267b90d .elementor-swiper-button.elementor-swiper-button-prev, .elementor-3626 .elementor-element.elementor-element-267b90d .elementor-swiper-button.elementor-swiper-button-next{font-size:50px;}.elementor-3626 .elementor-element.elementor-element-267b90d .elementor-image-carousel-wrapper .elementor-image-carousel .swiper-slide-image{border-style:none;}.elementor-3626 .elementor-element.elementor-element-267b90d .elementor-image-carousel-caption{text-align:center;}.elementor-3626 .elementor-element.elementor-element-926bf2b{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:100px;--margin-left:0px;--margin-right:0px;}.elementor-3626 .elementor-element.elementor-element-059013c{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:10px;--padding-bottom:10px;--padding-left:10px;--padding-right:100px;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-3626 .elementor-element.elementor-element-87c82f5{text-align:left;}.elementor-3626 .elementor-element.elementor-element-87c82f5 img{height:500px;}.elementor-3626 .elementor-element.elementor-element-4a974ab{--e-transform-translateX:36px;--e-transform-translateY:-89px;--e-transform-scale:0.9;top:6px;text-align:left;}body:not(.rtl) .elementor-3626 .elementor-element.elementor-element-4a974ab{right:124px;}body.rtl .elementor-3626 .elementor-element.elementor-element-4a974ab{left:124px;}.elementor-3626 .elementor-element.elementor-element-c737f7c{text-align:right;}.elementor-3626 .elementor-element.elementor-element-c737f7c img{max-width:100%;height:356px;}.elementor-3626 .elementor-element.elementor-element-b8035e5{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-3626 .elementor-element.elementor-element-a690aba .section-title{text-align:left;}.elementor-3626 .elementor-element.elementor-element-a690aba .section-title h2{margin:0px 0px 20px 0px !important;}.elementor-3626 .elementor-element.elementor-element-29758a6 > .elementor-widget-container{margin:5px 0px 20px 0px;}.elementor-3626 .elementor-element.elementor-element-ceeeb2f{--display:flex;--min-height:218px;}@media(max-width:1024px){.elementor-3626 .elementor-element.elementor-element-3ea7c5b > .elementor-widget-container{--e-transform-translateX:-60px;}.elementor-3626 .elementor-element.elementor-element-926bf2b{--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-3626 .elementor-element.elementor-element-b8035e5{--margin-top:30px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}}@media(max-width:767px){.elementor-3626 .elementor-element.elementor-element-3ea7c5b > .elementor-widget-container{--e-transform-translateX:1px;}.elementor-3626 .elementor-element.elementor-element-18333b5.e-con{--e-con-transform-translateY:73px;}.elementor-3626 .elementor-element.elementor-element-18333b5{--min-height:0px;}.elementor-3626 .elementor-element.elementor-element-059013c{--width:100%;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-3626 .elementor-element.elementor-element-87c82f5 img{height:250px;}.elementor-3626 .elementor-element.elementor-element-4a974ab{--e-transform-translateY:-79px;--e-transform-scale:0.9;margin:70px -53px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-3626 .elementor-element.elementor-element-4a974ab img{width:200%;max-width:1%;height:400px;}.elementor-3626 .elementor-element.elementor-element-c737f7c img{height:125px;}}@media(min-width:768px){.elementor-3626 .elementor-element.elementor-element-d91d71a{--content-width:1395px;}.elementor-3626 .elementor-element.elementor-element-926bf2b{--content-width:1395px;}.elementor-3626 .elementor-element.elementor-element-059013c{--width:50%;}.elementor-3626 .elementor-element.elementor-element-b8035e5{--width:50%;}}@media(max-width:1024px) and (min-width:768px){.elementor-3626 .elementor-element.elementor-element-059013c{--width:100%;}.elementor-3626 .elementor-element.elementor-element-b8035e5{--width:100%;}}/* Start custom CSS for container, class: .elementor-element-c22a0a5 *//* This targets THIS container only */
.elementor-3626 .elementor-element.elementor-element-c22a0a5{
  position: fixed;      /* pin the host to the viewport */
  top: 16px;
  right: 16px;
  left: auto;
  bottom: auto;
  z-index: 2147483647;  /* practically max; above themes/headers/popups */
  pointer-events: none; /* the host never blocks clicks on page content */
}

/* Re-enable clicks for the interactive children */
.elementor-3626 .elementor-element.elementor-element-c22a0a5 .gg-burger,
.elementor-3626 .elementor-element.elementor-element-c22a0a5 .gg-drawer,
.elementor-3626 .elementor-element.elementor-element-c22a0a5 .gg-overlay{
  pointer-events: auto;
}/* End custom CSS */
/* Start custom CSS for image-carousel, class: .elementor-element-267b90d *//* ───────────────
   CARD BASE STYLE
   ─────────────── */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}

/* Image hover animation */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide img {
  width: 100%;
  display: block;
  transition: transform 0.5s ease;
}
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover img {
  transform: scale(1.05);
}

/* Red gradient overlay */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide::after {
  content: "";
  position: absolute;
  bottom: -100%;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(255, 0, 0, 0.85), rgba(255, 0, 0, 0) 50%);
  opacity: 0;
  transition: all 0.6s ease;
  z-index: 1;
}
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover::after {
  bottom: 0;
  opacity: 1;
}

/* Title (from image caption) */
.elementor-3626 .elementor-element.elementor-element-267b90d .elementor-image-carousel-caption {
  position: absolute;
  bottom: 25px;
  left: 20px;
  right: 20px;
  color: #fff;
  font-family: "Orbitron", sans-serif;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 700;
  text-shadow: 0 0 20px rgba(255, 0, 0, 0.8);
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease;
  z-index: 2;
}
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover .elementor-image-carousel-caption {
  opacity: 1;
  transform: translateY(0);
}

/* Category label — now per-card via data-title */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide::before {
  content: attr(data-title);        /* <-- pulls per-slide title */
  position: absolute;
  bottom: 100px;
  left: 20px;
  padding: 4px 10px;
  background: rgba(255, 0, 0, 0.9);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  border: 1px solid #fff;
  border-radius: 3px;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease;
  z-index: 3;
}
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* ───────────────
   HOVER ARROW PNG
   ─────────────── */

/* Position context for the arrow */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide > figure,
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide > a {
  position: relative;
}

/* The arrow itself (use your PNG file) */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide > figure::after,
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide > a::after {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 44px; /* size of arrow box */
  height: 44px;
  background: url('http://geargolem.com/wp-content/uploads/2025/10/Arrow_01.png')
              center / contain no-repeat;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .35s ease, transform .35s ease, filter .35s ease;
  pointer-events: none;
  z-index: 4; /* above overlay & caption */
}

/* Show on hover */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover > figure::after,
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide:hover > a::after {
  opacity: 1;
  transform: translateY(0);
  filter: drop-shadow(0 0 20px rgba(255,255,255,.25));
}

/* ------------------------------------------------------
   PER-CARD RED LABEL TEXT (NO JS)
   Target each slide by its Swiper index and set the label.
   Replace the example texts with your own.
   ------------------------------------------------------ */

/* Perrito */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide[data-swiper-slide-index="0"]::before {
  content: "Perrito";
}

/* Fps */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide[data-swiper-slide-index="1"]::before {
  content: "Unicycle Man";
}

/* Factory */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide[data-swiper-slide-index="2"]::before {
  content: "Exofactory";
}

/* Anime */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide[data-swiper-slide-index="3"]::before {
  content: "Frog Power";
}

/* Mobile_RPG */
.elementor-3626 .elementor-element.elementor-element-267b90d .swiper-slide[data-swiper-slide-index="4"]::before {
  content: "Racing Game";
}

/* …add more as needed following the same pattern *//* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1f0f684 */<script>
/* Scope to this widget so it won't touch other carousels */
(function(){
  const root = document.currentScript.closest('.elementor-widget');

  function applyTitles() {
    const slides = root.querySelectorAll('.swiper-slide');
    slides.forEach(slide => {
      const img = slide.querySelector('img');
      if (!img) return;

      // Priority: data-title (if you add it to the image), else ALT text, else title attr
      const t = img.getAttribute('data-title') || img.getAttribute('alt') || img.getAttribute('title') || '';
      if (t) slide.setAttribute('data-title', t);
    });
  }

  if (document.readyState === 'loading') {
    document.addEventListener('DOMContentLoaded', applyTitles);
  } else {
    applyTitles();
  }

  // Re-apply if Elementor/Swiper updates slides dynamically
  new MutationObserver(applyTitles).observe(root, {childList:true, subtree:true});
})();
</script>

<style>
/* ------------------------------
   CARD BASE STYLE
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}

/* ------------------------------
   IMAGE HOVER ANIMATION
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide img {
  width: 100%;
  display: block;
  transition: transform 0.5s ease;
}
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide:hover img {
  transform: scale(1.05);
}

/* ------------------------------
   RED GRADIENT OVERLAY
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide::after {
  content: "";
  position: absolute;
  bottom: -100%;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(255, 0, 0, 0.85), rgba(255, 0, 0, 0) 50%);
  opacity: 0;
  transition: all 0.6s ease;
  z-index: 1;
}
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide:hover::after {
  bottom: 0;
  opacity: 1;
}

/* ------------------------------
   TITLE INSIDE RED BOX (PER SLIDE)
   The content is pulled from data-title that the script sets
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide::before {
  content: attr(data-title);   /* <-- per-slide value injected by the script */
  position: absolute;
  bottom: 100px;
  left: 20px;
  padding: 6px 12px;
  background: rgba(255, 0, 0, 0.9);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  border: 1px solid #fff;
  border-radius: 3px;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease;
  z-index: 3;
}
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* ------------------------------
   CAPTION TEXT (DESCRIPTION)
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .elementor-image-carousel-caption {
  position: absolute;
  bottom: 25px;
  left: 20px;
  right: 20px;
  color: #fff;
  font-family: "Orbitron", sans-serif;
  text-transform: uppercase;
  font-size: 13px;   /* smaller text */
  line-height: 1.3;
  font-weight: 600;
  text-shadow: 0 0 15px rgba(255, 0, 0, 0.7);
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease;
  z-index: 2;
}
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide:hover .elementor-image-carousel-caption {
  opacity: 1;
  transform: translateY(0);
}

/* ------------------------------
   TOP-RIGHT ARROW ICON
------------------------------ */
.elementor-3626 .elementor-element.elementor-element-1f0f684 .hover-arrow {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 38px;
  height: 38px;
  border: 2px solid #fff;
  border-radius: 6px;
  box-shadow: 0 0 25px rgba(255, 255, 255, 0.2);
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48"><path d="M16 32 L32 16" stroke="white" stroke-width="3.2" stroke-linecap="round" stroke-linejoin="round" fill="none"/><path d="M24 16h8v8" stroke="white" stroke-width="3.2" stroke-linecap="round" stroke-linejoin="round" fill="none"/></svg>')
    center/22px 22px no-repeat;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .35s ease, transform .35s ease, box-shadow .35s ease;
  pointer-events: none;
  z-index: 4;
}
.elementor-3626 .elementor-element.elementor-element-1f0f684 .swiper-slide:hover .hover-arrow {
  opacity: 1;
  transform: translateY(0);
  box-shadow: 0 0 35px rgba(255, 255, 255, 0.25);
}
</style>/* End custom CSS */