.elementor-33 .elementor-element.elementor-element-84ab1f8{--display:flex;--overlay-opacity:0.5;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-33 .elementor-element.elementor-element-84ab1f8::before, .elementor-33 .elementor-element.elementor-element-84ab1f8 > .elementor-background-video-container::before, .elementor-33 .elementor-element.elementor-element-84ab1f8 > .e-con-inner > .elementor-background-video-container::before, .elementor-33 .elementor-element.elementor-element-84ab1f8 > .elementor-background-slideshow::before, .elementor-33 .elementor-element.elementor-element-84ab1f8 > .e-con-inner > .elementor-background-slideshow::before, .elementor-33 .elementor-element.elementor-element-84ab1f8 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{--background-overlay:'';}.elementor-33 .elementor-element.elementor-element-03970d1{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-33 .elementor-element.elementor-element-22aed27{--display:flex;}.elementor-33 .elementor-element.elementor-element-dd15bff{--display:grid;--e-con-grid-template-columns:repeat(2, 1fr);--e-con-grid-template-rows:repeat(1, 1fr);--grid-auto-flow:row;}.elementor-33 .elementor-element.elementor-element-dd15bff:not(.elementor-motion-effects-element-type-background), .elementor-33 .elementor-element.elementor-element-dd15bff > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-text );}.elementor-33 .elementor-element.elementor-element-f273015{--display:flex;--padding-top:52px;--padding-bottom:52px;--padding-left:52px;--padding-right:52px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );text-transform:var( --e-global-typography-primary-text-transform );font-style:var( --e-global-typography-primary-font-style );text-decoration:var( --e-global-typography-primary-text-decoration );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );color:var( --e-global-color-primary );}.elementor-33 .elementor-element.elementor-element-f99f91f .elementor-heading-title{color:var( --e-global-color-c696dce );}.elementor-33 .elementor-element.elementor-element-b2f218e{--display:flex;--padding-top:73px;--padding-bottom:73px;--padding-left:73px;--padding-right:73px;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );text-decoration:var( --e-global-typography-text-text-decoration );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-33 .elementor-element.elementor-element-2c16eaf{color:var( --e-global-color-c696dce );}.elementor-widget-icon-list .elementor-icon-list-item:not(:last-child):after{border-color:var( --e-global-color-text );}.elementor-widget-icon-list .elementor-icon-list-icon i{color:var( --e-global-color-primary );}.elementor-widget-icon-list .elementor-icon-list-icon svg{fill:var( --e-global-color-primary );}.elementor-widget-icon-list .elementor-icon-list-item > .elementor-icon-list-text, .elementor-widget-icon-list .elementor-icon-list-item > a{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );text-decoration:var( --e-global-typography-text-text-decoration );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-widget-icon-list .elementor-icon-list-text{color:var( --e-global-color-secondary );}.elementor-33 .elementor-element.elementor-element-5c96c40 .elementor-icon-list-icon i{transition:color 0.3s;}.elementor-33 .elementor-element.elementor-element-5c96c40 .elementor-icon-list-icon svg{transition:fill 0.3s;}.elementor-33 .elementor-element.elementor-element-5c96c40{--e-icon-list-icon-size:14px;--icon-vertical-offset:0px;}.elementor-33 .elementor-element.elementor-element-5c96c40 .elementor-icon-list-text{color:var( --e-global-color-c696dce );transition:color 0.3s;}@media(max-width:1024px){.elementor-33 .elementor-element.elementor-element-dd15bff{--grid-auto-flow:row;}.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-widget-text-editor{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-widget-icon-list .elementor-icon-list-item > .elementor-icon-list-text, .elementor-widget-icon-list .elementor-icon-list-item > a{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}@media(max-width:767px){.elementor-33 .elementor-element.elementor-element-dd15bff{--e-con-grid-template-columns:repeat(1, 1fr);--grid-auto-flow:row;}.elementor-33 .elementor-element.elementor-element-f273015{--padding-top:23px;--padding-bottom:23px;--padding-left:23px;--padding-right:23px;}.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-33 .elementor-element.elementor-element-b2f218e{--padding-top:25px;--padding-bottom:25px;--padding-left:25px;--padding-right:25px;}.elementor-widget-text-editor{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-widget-icon-list .elementor-icon-list-item > .elementor-icon-list-text, .elementor-widget-icon-list .elementor-icon-list-item > a{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}/* Start custom CSS for html, class: .elementor-element-03970d1 *//* =========================
   CONTACT HERO + MAP BG
   ========================= */

.vc-contact-hero-map {
  position: relative;
  width: 100%;
  padding: 140px 5vw 220px;         /* extra bottom space for X */
  background-color: #FF611C;
  overflow: hidden;
  text-align: center;
  color: #fff;
  font-family: "Onest", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* MAP PATTERN LAYER – 1 big map, no tiling */
.vc-contact-hero-map::before {
  content: "";
  position: absolute;
  inset: -20%;  /* lebih besar dari section supaya cover semua bila animate */
  background-image: url("https://upload.wikimedia.org/wikipedia/commons/thumb/8/80/World_map_-_low_resolution.svg/2048px-World_map_-_low_resolution.svg.png");
  background-repeat: no-repeat;
  background-size: cover;        /* FOCUS: fill whole area */
  background-position: center;
  opacity: 0.2;                  /* 50% opacity */
  filter: brightness(0) contrast(1.1);  /* jadikan hitam */
  animation: vcMapDrift 35s linear infinite;
  z-index: 0;
}

/* Slow subtle movement – sedikit zoom supaya sentiasa cover */
@keyframes vcMapDrift {
  0% {
    transform: translate(0, 0) scale(1.05);
  }
  50% {
    transform: translate(-3%, -3%) scale(1.15);
  }
  100% {
    transform: translate(0, 0) scale(1.05);
  }
}

/* Content wrapper */
.vc-contact-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1100px;
  margin: 0 auto;
}

/* Title */
.vc-contact-hero-title {
  font-size: clamp(2.4rem, 4vw, 4.5rem);
  font-weight: 800;
  line-height: 1.1;
  margin: 0 0 40px;
}

/* =========================
   BUTTON + WIPE-UP HOVER
   ========================= */

.vc-contact-hero-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 40px;
  border-radius: 16px;
  background: #ffffff;
  color: #111827;
  text-decoration: none;
  font-weight: 600;
  font-size: 1.1rem;
  box-shadow: 0 14px 40px rgba(0,0,0,0.18);
  overflow: hidden;
  transition: color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

/* Wipe layer */
.vc-contact-hero-btn::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: #000000;
  transform: translateY(100%);
  transition: transform 0.25s ease;
  z-index: 0;
}

.vc-contact-hero-btn .btn-label,
.vc-contact-hero-btn .btn-arrow {
  position: relative;
  z-index: 1;
}

.vc-contact-hero-btn:hover::before {
  transform: translateY(0);              /* wipe up */
}

.vc-contact-hero-btn:hover {
  color: #ffffff;                        /* text turns white */
  transform: translateY(-2px);
  box-shadow: 0 18px 48px rgba(0,0,0,0.22);
}

.btn-arrow {
  font-size: 1.2rem;
}

/* =========================
   X-LOOP EMAIL MARQUEE
   ========================= */

.vc-email-x-stack {
  position: relative;
  margin-top: 80px;
  height: 220px;                         /* space for X */
  overflow: visible;
  z-index: 2;                            /* above map bg */
}
/* DOT BULAT ANIMATED UNTUK EMAIL X */
.vc-email-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #00eaff;              /* neon blue macam sebelum ni */
  margin-right: 60px;
  flex-shrink: 0;
  animation: vcEmailDotPulse 1.1s ease-in-out infinite;
}

/* Pulse animation */
@keyframes vcEmailDotPulse{
  0%   { transform: scale(0.5); opacity: 0.4; }
  45%  { transform: scale(1.6); opacity: 1; }
  100% { transform: scale(0.5); opacity: 0.4; }
}

/* RESPONSIVE TWEAK DOT – ikut text */
@media (max-width: 1024px){
  .vc-email-dot{
    width: 8px;
    height: 8px;
    margin-right: 40px;
  }
}

@media (max-width: 768px){
  .vc-email-dot{
    width: 6px;
    height: 6px;
    margin-right: 28px;
  }
}


/* Base tape */
.vc-email-marquee {
  position: absolute;
  left: 50%;
  width: 180%;                           /* longer so edges not visible */
  transform-origin: center;
  padding: 20px 0;
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(0,0,0,0.18);
  white-space: nowrap;
}

/* Top & bottom tape (X) */
.vc-email-top {
  top: 50%;
  transform: translateX(-50%) rotate(-5deg);
  z-index: 3;
}
.vc-email-bottom {
  top: 50%;
  transform: translateX(-50%) rotate(5deg);
  z-index: 2;
}

/* Track scrolling */
.vc-email-track {
  display: inline-flex;
  align-items: center;
  animation: vcEmailLeft 40s linear infinite;
}

.vc-email-bottom .vc-email-track {
  animation-name: vcEmailRight;
}

/* Email text style */
.vc-email-track span {
  font-size: 26px;
  font-weight: 700;
  text-transform: uppercase;
  margin-right: 60px;
  color: #000;
}

/* Loop animations */
@keyframes vcEmailLeft {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes vcEmailRight {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 1024px) {
  .vc-contact-hero-map {
    padding: 120px 6vw 200px;
  }

  .vc-email-x-stack {
    margin-top: 70px;
    height: 200px;
  }

  .vc-email-marquee {
    width: 200%;
    padding: 18px 0;
  }

  .vc-email-track span {
    font-size: 20px;
    margin-right: 40px;
  }
}

@media (max-width: 768px) {
  .vc-contact-hero-map {
    padding: 100px 7vw 180px;
  }

  .vc-contact-hero-title {
    font-size: clamp(2rem, 7vw, 2.6rem);
  }

  .vc-contact-hero-btn {
    padding: 14px 32px;
    font-size: 1rem;
  }

  .vc-email-x-stack {
    margin-top: 60px;
    height: 180px;
  }

  .vc-email-marquee {
    width: 230%;
    padding: 14px 0;
  }

  .vc-email-top {
    transform: translateX(-50%) rotate(-7deg);
  }
  .vc-email-bottom {
    transform: translateX(-50%) rotate(7deg);
  }

  .vc-email-track span {
    font-size: 16px;
    margin-right: 28px;
  }
  @media (max-width: 1024px) {
  .vc-contact-hero-map::before {
    inset: -25%;
    background-size: cover;
    background-position: center top;
  }
}

@media (max-width: 768px) {
  .vc-contact-hero-map::before {
    inset: -30%;
    background-size: cover;
    background-position: center;
  }
}

}/* End custom CSS */