/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 13 2026 | 08:46:56 */
/* General */
:root {
  font-size: 16px;
  --c-primary: #212a5c;
  --c-secondary: #574be9;
  --c-text: #0d2b2b;
  --c-accent: #f29140;
  --transition: all 0.4s ease;
}

body {
  overflow-x: hidden;
}

.h-100 {
  height: 100%;
}

/* Display Utilities */
.d-none {
  display: none !important;
}
.d-block {
  display: block !important;
}

@media (min-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
  .d-sm-block {
    display: block !important;
  }
}

@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-block {
    display: block !important;
  }
}

@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-block {
    display: block !important;
  }
}

@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
  .d-xl-block {
    display: block !important;
  }
}
/* ---------Button---------- */
.btn-general {
  display: inline-block;
  padding: 8px 25px 8px 25px;
  font-size: 1rem !important;
  color: #fff !important;
  background: var(--c-secondary) !important;
  border-color: var(--c-secondary) !important;
  transition: var(--transition);
}
.btn-general:hover {
  opacity: 0.9;
}
.btn-view .elementor-button-link {
  position: relative;
}
.btn-view .elementor-button-link:after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  border: 1px solid var(--c-primary);
  border-width: 0 1px 1px 0;
  display: inline-block;
  padding: 2px;
  transform: rotate(-45deg) translateY(-50%);
  -webkit-transform: rotate(-45deg) translateY(-50%);
  transition: var(--transition);
}

.btn-view:hover .elementor-button-link {
  color: var(--c-accent) !important;
  font-weight: 500 !important;
}
.btn-view:hover .elementor-button-link:after {
  border-color: var(--c-accent);
  right: -5px;
}

.btn-img-link img {
  transition: var(--transition);
}

.btn-img-link:hover img {
  filter: drop-shadow(2px 4px 6px rgba(0 0 0 /20%));
  transform: translateY(-5px);
}

/* Accodion */
.e-n-accordion-item-title-header {
  width: calc(100% - 40px);
}
.e-n-accordion p:last-child {
  margin-bottom: 0 !important;
}
.e-n-accordion > .e-n-accordion-item > .e-con {
  margin-top: -4px;
}

/*------- Header --------*/
.sticky-header .main-header {
  box-shadow: 0 0 10px rgba(0 0 0/10%);
}

/*-------  General --------*/
.elementor-heading-title {
  line-height: 1.4 !important;
}
.elementor-widget-text-editor ol,
.elementor-widget-text-editor ul {
  padding-left: 20px;
  line-height: normal;
}
.elementor-widget-text-editor ol li,
.elementor-widget-text-editor ul li {
  margin-bottom: 5px;
}
.elementor-widget-text-editor ol(:last-child),
.elementor-widget-text-editor ul(:last-child) {
  margin-bottom: 20px;
}

.hidden-item {
  display: none !important;
}

.elementor-element p {
  line-height: 1.8 !important;
}

@media (max-width: 767px) {
  .elementor-heading-title {
    line-height: 1.3 !important;
  }
}

/* ---------- Reuse ------------ */
.translateCenter {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.translateXCenter {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.translateYCenter {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

/*------- Breadcrumb --------*/
.breadcrumb-wrap {
  font-size: 1.125rem;
  color: var(--c-primary);
}
.breadcrumb-wrap a:hover {
  color: var(--c-accent);
}

@media (max-width: 767px) {
  .breadcrumb-wrap {
    font-size: 0.9375rem;
  }
}

/*------- Footer --------*/
.box-enquiry-wrap {
  position: relative;
}

.box-enquiry-wrap::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  background: #2c23a4;
  height: 50%;
  z-index: 0;
}

.ql-menu-wrap .e-n-menu-item {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
}

/* ------------- Slider ------------------ */
/* Swiper button */
.e-widget-swiper .elementor-swiper-button {
  width: 44px;
  height: 44px;
  background: #ffffff;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
  border-radius: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.e-widget-swiper .elementor-swiper-button svg {
  font-size: 20px;
}
.e-widget-swiper .elementor-swiper-button:not(.swiper-button-disabled):hover {
  background: var(--c-accent);
}
.e-widget-swiper .elementor-swiper-button-prev {
  left: -25px !important;
}
.e-widget-swiper .elementor-swiper-button-next {
  right: -25px !important;
}

@media (max-width: 1024px) {
  .e-widget-swiper .elementor-swiper-button-prev {
    left: 7px !important;
  }
  .e-widget-swiper .elementor-swiper-button-next {
    right: 7px !important;
  }
}

/* swiper pagination */
.e-widget-swiper {
  position: relative;
}
.e-widget-swiper .swiper-pagination {
  left: unset !important;
  transform: unset !important;
  top: unset !important;
  bottom: unset !important;
  width: auto !important;
  z-index: 1 !important;
  position: relative !important;
  justify-content: center !important;
  margin: 20px 10px 5px;
  gap: 0;
}
.e-widget-swiper .swiper-pagination-bullet {
  width: 10px !important;
  height: 10px !important;
  background: #ffffff !important;
  border: 1px solid #d2d9de !important;
  border-radius: 20px;
  opacity: 1;
  transition: var(--transition);
}
.e-widget-swiper .swiper-pagination-bullet:hover {
  background: #3b32a3 !important;
}
.e-widget-swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
  width: 60px !important;
  background: #3b32a3 !important;
}
.e-widget-swiper .swiper-pagination.swiper-pagination-lock {
  margin: 0 !important;
}

/* ------------- Home------------------ */
/* Banner */
.hero-banner-wrapper {
  position: relative;
}
.left-ctn-wrap,
.right-ctn-wrap {
  position: unset !important;
}
.desktop-wrap {
  position: unset !important;
  padding-bottom: 250px;
}
.deco-phone {
  position: absolute;
  left: 50%;
  bottom: 0;
  z-index: 0;
  opacity: 0;
  transform: translateX(-50%) translateY(40px) scale(0.96);
  animation: phoneIn 1s ease-out forwards;
}
[id^="b_text_"] {
  position: absolute;
  z-index: 2;
  opacity: 0;
  animation:
    bubbleIn 1s ease-out forwards,
    bubbleFloat 3.8s ease-in-out infinite;
  will-change: transform, opacity;
  animation-fill-mode: forwards, both;
}
#b_text_1 {
  position: absolute;
  bottom: 29.5%;
  left: 24.5%;
}
#b_text_2 {
  bottom: 22%;
  left: 11.5%;
}
#b_text_3 {
  bottom: 17.5%;
  left: 30%;
}
#b_text_4 {
  bottom: 7.5%;
  left: 18.3%;
}
#b_text_5 {
  bottom: 23.5%;
  left: 63.2%;
}
#b_text_6 {
  bottom: 17.5%;
  left: 76.2%;
}
#b_text_7 {
  bottom: 7.5%;
  left: 70%;
}

#b_text_1,
#b_text_2,
#b_text_3,
#b_text_4 {
  transform: translateX(-24px) translateY(12px) scale(0.92);
}

#b_text_5,
#b_text_6,
#b_text_7 {
  transform: translateX(24px) translateY(12px) scale(0.92);
}

/* Animation Delays */
#b_text_1 {
  animation-delay: 0.65s, 1.25s;
}
#b_text_2 {
  animation-delay: 0.8s, 1.4s;
}
#b_text_3 {
  animation-delay: 0.95s, 1.55s;
}
#b_text_4 {
  animation-delay: 1.1s, 1.7s;
}
#b_text_5 {
  animation-delay: 1.25s, 1.85s;
}
#b_text_6 {
  animation-delay: 1.4s, 2s;
}
#b_text_7 {
  animation-delay: 1.55s, 2.15s;
}

@media (max-width: 1280px) {
  #b_text_1 {
    left: 19.5%;
  }
  #b_text_2 {
    left: 4%;
  }
  #b_text_3 {
    left: 25%;
  }
}

.hero-banner-wrapper .bg-deco {
  position: unset !important;
}
.hero-banner-wrapper > .elementor-element,
.hero-banner-wrapper > .elementor-element > .e-con-inner {
  position: unset !important;
}

[id^="deco_circle_"] {
  position: absolute;
  z-index: 0;
  width: 100%;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%) scale(0);
  transform-origin: bottom;
  background-size: cover;
  background-position: bottom;
  pointer-events: none;
  will-change: transform, opacity, filter;
  opacity: 0;
  animation: circleRipple 6s ease-out infinite;
}
#deco_circle_2 {
  animation-delay: 2s;
}

/* New Market */
.sec-newMarket {
  position: relative;
}

.bg-deco {
  width: 100%;
  height: 100% !important;
}

.dc-right-triangle {
  top: 26% !important;
  right: 8% !important;
  left: unset !important;
  bottom: unset !important;
  z-index: 0 !important;
}

.dc-bottom-triangle {
  top: unset !important;
  bottom: 10px !important;
  left: 53% !important;
  transform: translateX(-50%);
}

.dc-bottom-circle {
  bottom: 0 !important;
  left: 15% !important;
  z-index: 0 !important;
}

/* Animation */
.dc-right-triangle,
.dc-bottom-triangle,
.dc-bottom-circle,
.dc-left-circle {
  animation: float 6s ease-in-out infinite;
}

.dc-right-triangle {
  animation-duration: 5s;
  animation-delay: 0.5s;
}

.dc-bottom-triangle {
  animation-duration: 4s;
  animation-delay: -2s;
}

.dc-bottom-circle {
  animation-duration: 3s;
  animation-delay: 1s;
}

.dc-left-circle {
  animation-duration: 4s;
  animation-delay: -1s;
}

@media (max-width: 1366px) {
  .dc-right-triangle {
    right: 0 !important;
  }
}

/* Services */
.slide-services .swiper-slide > .e-con {
  transition: var(--transition);
}
.slide-services .swiper-slide > .e-con:hover {
  background: #3b32a3;
  box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.2);
}
.slide-services .swiper-slide > .e-con:hover .elementor-heading-title,
.slide-services .swiper-slide > .e-con:hover .elementor-widget-text-editor {
  color: #fff;
}
.slide-services .swiper-slide > .e-con:hover .btn-view .elementor-button-link {
  color: var(--c-accent) !important;
  font-weight: 500 !important;
}
.slide-services
  .swiper-slide
  > .e-con:hover
  .btn-view
  .elementor-button-link:after {
  border-color: var(--c-accent);
  right: -5px;
}
.slide-services .swiper-backface-hidden {
  padding: 0 10px;
}
.slide-services .elementor-swiper-button-prev {
  left: -15px !important;
}
.slide-services .elementor-swiper-button-next {
  right: -15px !important;
}
@media (max-width: 767px) {
  .slide-services .elementor-swiper-button-prev {
    left: 7px !important;
  }
  .slide-services .elementor-swiper-button-next {
    right: 7px !important;
  }
}
/* News */
.sec-news {
  overflow: hidden;
}

.sec-news .swiper-slide {
  display: flex;
  height: auto;
}

/* Testimonial */
.list-testi-wrap {
  display: flex;
  height: 100%;
  justify-content: space-between;
}
.list-testi-wrap .ctn-wrap {
  position: relative;
  padding-top: 40px !important;
}
.list-testi-wrap .ctn-wrap::before {
  content: "";
  position: absolute;
  background: url("https://staging.reninnovation.com/wp-content/uploads/2026/03/quote.svg")
    no-repeat;
  background-size: 24px;
  top: 0;
  left: 0;
  z-index: 0;
}
.list-testi-wrap .ctn-info {
  position: relative;
  padding-top: 25px;
}
.list-testi-wrap .ctn-info::before {
  content: "";
  position: absolute;
  background: url("https://staging.reninnovation.com/wp-content/uploads/2026/03/line-arrow-down.svg")
    no-repeat;
  background-size: 100%;
  top: 0;
  left: 0;
  z-index: 0;
}

.list-testi-wrap .elementor-heading-title {
  line-height: 24px !important;
}

@media (max-width: 767px) {
  .list-testi-wrap {
    justify-content: center;
  }
  .slide-testimonial.elementor-element.elementor-pagination-position-outside
    .swiper {
    width: 100%;
  }
  .slide-testimonial .elementor-swiper-button {
    display: none !important;
  }
}
/* ------------ Gallery --------------*/
.sec-gallery .swiper {
  padding-bottom: 0 !important;
}

/* ------------ Contact Us --------------*/
.frm_form_field select {
  -webkit-appearance: none;
  appearance: none;
  padding-right: 30px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23AAAAAA' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 15px;
}

.list-contact-info .social-icon .elementor-icon:hover {
  filter: brightness(0) saturate(100%) invert(23%) sepia(88%) saturate(3364%)
    hue-rotate(241deg) brightness(97%) contrast(89%);
}

/* ---------- Menu -  -------- */
/* Desktop */
.e-n-menu-title:hover .e-n-menu-dropdown-icon svg {
  filter: brightness(0) saturate(100%) invert(67%) sepia(97%) saturate(1699%)
    hue-rotate(332deg) brightness(101%) contrast(90%);
}
.mb-menu-wrap .sub-menu[aria-hidden="false"] {
  display: block !important;
  margin: 0 !important;
  position: relative !important;
}

/* Mobile */
@media (max-width: 1024px) {
  .menu-wrapper {
    max-height: 80vh;
    overflow: auto;
  }
}

/* Milestone */
.milestone-wrapper {
  position: relative;
  display: flex;
  flex-wrap: wrap;
}

.milestone-wrapper .milestone-media {
  position: relative;
  width: 43%;
}
.milestone-media-item {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease;
}
.milestone-media-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.milestone-media-item.show {
  opacity: 1;
  visibility: visible;
}
.milestone-years-swiper {
  height: 100%;
}
.milestone-year-slide {
  height: 45px !important;
}
.milestone-years-wrap {
  position: relative;
  width: 15%;
  padding-left: 50px;
  height: 350px;
  overflow: hidden;
}
.milestone-years-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  right: 1.5px;
  width: 1px;
  height: 100%;
  background: #aaa;
}
.milestone-years-wrap .title-year {
  font-family: "Outfit", sans-serif;
  font-size: 1.5rem;
  font-weight: 300;
  color: #aaa;
  transition: var(--transition);
  text-align: right;
  padding-right: 25px;
  position: relative;
  cursor: pointer;
  line-height: 1.2;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.milestone-years-wrap .is-active .title-year {
  color: #5a6ba5;
  font-size: 2.25rem;
  font-weight: 600;
}
.milestone-years-wrap .title-year::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0.5px;
  width: 3px;
  height: 100%;
  background: transparent;
}
.milestone-years-wrap .is-active .title-year::after {
  background: #5a6ba5;
}

.milestone-content-wrap {
  position: relative;
  width: 42%;
  padding-left: 54px;
  display: flex;
  flex-wrap: wrap;
}
.milestone-content-item .heading {
  font-size: 2rem;
  font-weight: 500;
  color: #5a6ba5;
  margin: 0 0 12px;
}
.milestone-content-item .body {
  font-size: 1.25rem;
  margin-bottom: 20px;
}
.milestone-media-item img {
  border-radius: 10px;
}
.milestone-nav {
  margin-top: auto;
  margin-bottom: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}
.milestone-nav button {
  position: relative;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  padding: 10px;
  background: #5a6ba5;
  border-color: #5a6ba5;
  font-size: 0;
}
.milestone-nav button::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 12px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-repeat: no-repeat;
  background-size: contain;
  filter: brightness(0) invert(1);
}

.milestone-prev::before {
  background-image: url("https://staging.reninnovation.com/wp-content/uploads/2026/03/slide-arrow-left.svg");
}
.milestone-next::before {
  background-image: url("https://staging.reninnovation.com/wp-content/uploads/2026/03/slide-arrow-right.svg");
}
.milestone-nav button:hover {
  background: #5a6ba5;
  border-color: #5a6ba5;
  opacity: 0.9;
}
.milestone-nav .swiper-button-disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

@media (max-width: 1024px) {
  .milestone-years-wrap {
    padding-left: 30px;
  }
}
@media (max-width: 991px) {
  .milestone-wrapper .milestone-media {
    width: 100%;
    height: auto;
    aspect-ratio: 492 / 345;
    margin-bottom: 30px;
  }
  .milestone-years-wrap {
    padding-left: 0px;
  }
  .milestone-years-wrap {
    width: 20%;
  }
  .milestone-content-wrap {
    width: 80%;
  }
}
@media (max-width: 767px) {
  .milestone-wrapper .milestone-media {
    margin-bottom: 10px;
  }
  .milestone-years-wrap {
    width: 100%;
  }
  .milestone-content-wrap {
    width: 100%;
    padding-left: 0;
  }
  .milestone-years-wrap {
    height: unset;
  }
  .milestone-years-wrap::after {
    top: unset;
    bottom: 1px;
    right: 0;
    width: 100%;
    height: 1px;
  }
  .milestone-years-wrap .title-year {
    justify-content: center;
    padding: 0;
    font-size: 1.25rem;
  }
  .milestone-years-wrap .title-year::after {
    width: 100%;
    height: 3px;
    bottom: 0;
    top: unset;
    right: 0;
  }
  .milestone-years-wrap .is-active .title-year {
    font-size: 1.5rem;
  }
  .milestone-content-item {
    padding: 20px 0;
  }
  .milestone-content-item .heading {
    font-size: 1.5rem;
  }
  .milestone-content-item .body {
    font-size: 1rem;
  }
  .milestone-nav {
    width: 100%;
  }
}

/* Our Story - Map */
/* Map Dots */
.about-map-wrapper {
  position: relative;
}
.about-map-wrapper .map-bottom img {
  width: 100%;
}
.map-wrapper {
  position: unset !important;
}
.map-dot-wrapper .dot-wrap {
  position: absolute;
  z-index: 2;
}
.map-dot-wrapper .dot {
  width: 21px;
  height: 21px;
  background: var(--c-secondary);
  border-radius: 50%;
  border: 1px solid var(--c-secondary);
  background-clip: content-box;
  padding: 3px;
  animation: pulse 1.8s infinite ease-in-out;
}
.map-dot-wrapper .dot-wrap .text {
  position: absolute;
  right: 28px;
  top: 50%;
  transform: translateY(-50%);
  color: #000;
  font-size: 1rem;
  font-family: "Outfit", sans-serif;
}
.map-dot-wrapper .d-singapore {
  top: 65%;
  transform: translateY(-50%);
  right: unset;
  left: 22%;
}
.map-dot-wrapper .d-singapore .text {
  top: -13px;
  right: unset;
  left: 5px;
}
.map-dot-wrapper .d-philippines {
  top: 8%;
  right: unset;
  left: 54%;
}
.map-dot-wrapper .d-philippines .text {
  left: unset;
  right: 28px;
}
.map-dot-wrapper .d-malaysia {
  top: 45%;
  left: 14%;
}
.map-dot-wrapper .d-indonesia {
  bottom: 8%;
  right: unset;
  left: 26%;
}
/* Map bottom */
.about-map-wrapper .map-bottom {
  opacity: 0;
  clip-path: inset(0 0 100% 0);
}
.about-map-wrapper.show .map-bottom {
  animation: heightShow 2s ease-in-out forwards;
}

@media (max-width: 767px) {
  .map-dot-wrapper .dot {
    width: 15px;
    height: 15px;
  }
  .map-dot-wrapper .dot-wrap .text {
    font-size: 0.75rem;
    right: 20px;
  }
}

/* Back to top */
#back-to-top {
  position: fixed;
  display: inline-block;
  right: 35px;
  bottom: 30px;
  width: 55px;
  height: 55px;
  border-radius: 4px;
  background: var(--c-secondary);
  padding: 5px;
  display: none;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
  z-index: 8;
  cursor: pointer;
  text-decoration: none;
}

#back-to-top img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  transform: translate(-50%, -50%);
}
#back-to-top:hover {
  background: var(--c-secondary);
  opacity: 0.9;
}

@media (max-width: 767px) {
  #back-to-top {
    width: 45px;
    height: 45px;
    right: 15px;
  }

  #back-to-top img {
    width: 15px;
  }
}
