.elementor-kit-15{--e-global-color-primary:#0D1730;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-color-9897f4b:#FF8000;--e-global-color-8642f72:#0D1730;--e-global-color-3f65efa:#54595F;--e-global-color-b73e966:#FFFFFF;--e-global-color-2bf3d1d:#FFFFFF;--e-global-color-5d17e29:#F3F3F3;--e-global-color-d98dfaa:#D8D8D8;--e-global-color-a7491e4:#FFD800;--e-global-color-5f87528:#0D1730;--e-global-color-e11a7e9:#0D1730E0;--e-global-color-f5a3d6b:#1F386A;--e-global-color-dcf8939:#0A101FE0;--e-global-typography-primary-font-family:"Montserrat";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Montserrat";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Montserrat";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Montserrat";--e-global-typography-accent-font-weight:500;--e-global-typography-6bf534d-font-family:"Montserrat";--e-global-typography-6bf534d-font-size:42px;--e-global-typography-6bf534d-font-weight:700;--e-global-typography-6bf534d-letter-spacing:-2.4px;--e-global-typography-f1d5dad-font-family:"Montserrat";--e-global-typography-f1d5dad-font-size:1rem;--e-global-typography-f1d5dad-font-weight:400;--e-global-typography-f1d5dad-line-height:1.9rem;--e-global-typography-19831a6-font-family:"Montserrat";--e-global-typography-19831a6-font-size:3.4rem;--e-global-typography-19831a6-font-weight:700;--e-global-typography-19831a6-line-height:3.9rem;--e-global-typography-19831a6-letter-spacing:-2.8px;--e-global-typography-c20cc74-font-family:"Montserrat";--e-global-typography-c20cc74-font-size:4.4rem;--e-global-typography-c20cc74-font-weight:700;--e-global-typography-c20cc74-letter-spacing:-0.2rem;--e-global-typography-034f283-font-family:"Montserrat";--e-global-typography-034f283-font-size:1.3rem;--e-global-typography-034f283-font-weight:400;--e-global-typography-034f283-line-height:1.9rem;--e-global-typography-034f283-letter-spacing:0px;--e-global-typography-9e65d69-font-family:"Montserrat";--e-global-typography-9e65d69-font-size:1rem;--e-global-typography-9e65d69-font-weight:500;--e-global-typography-9e65d69-text-transform:uppercase;--e-global-typography-9e65d69-line-height:1.2rem;--e-global-typography-fdb1645-font-family:"Montserrat";--e-global-typography-fdb1645-font-size:2rem;--e-global-typography-fdb1645-font-weight:700;--e-global-typography-fdb1645-line-height:2.2rem;--e-global-typography-fdb1645-letter-spacing:-1.9px;--e-global-typography-50f26b8-font-family:"Montserrat";--e-global-typography-50f26b8-font-size:1.5rem;--e-global-typography-50f26b8-font-weight:700;--e-global-typography-50f26b8-line-height:1.8rem;--e-global-typography-50f26b8-letter-spacing:-1.2px;--e-global-typography-9897560-font-family:"Montserrat";--e-global-typography-9897560-font-size:2rem;--e-global-typography-9897560-font-weight:600;--e-global-typography-9897560-line-height:1.3em;--e-global-typography-9897560-letter-spacing:-1px;--e-global-typography-c1ee144-font-family:"Montserrat";--e-global-typography-c1ee144-font-size:1.1rem;--e-global-typography-c1ee144-font-weight:700;--e-global-typography-c1ee144-line-height:1.4rem;--e-global-typography-c1ee144-letter-spacing:-1.1px;}.elementor-kit-15 e-page-transition{background-color:#FFBC7D;}.elementor-kit-15 a{color:var( --e-global-color-9897f4b );}.elementor-kit-15 h3{font-family:var( --e-global-typography-fdb1645-font-family ), Sans-serif;font-size:var( --e-global-typography-fdb1645-font-size );font-weight:var( --e-global-typography-fdb1645-font-weight );line-height:var( --e-global-typography-fdb1645-line-height );letter-spacing:var( --e-global-typography-fdb1645-letter-spacing );}.elementor-kit-15 h4{font-family:var( --e-global-typography-50f26b8-font-family ), Sans-serif;font-size:var( --e-global-typography-50f26b8-font-size );font-weight:var( --e-global-typography-50f26b8-font-weight );line-height:var( --e-global-typography-50f26b8-line-height );letter-spacing:var( --e-global-typography-50f26b8-letter-spacing );word-spacing:var( --e-global-typography-50f26b8-word-spacing );}.elementor-kit-15 h5{font-family:var( --e-global-typography-c1ee144-font-family ), Sans-serif;font-size:var( --e-global-typography-c1ee144-font-size );font-weight:var( --e-global-typography-c1ee144-font-weight );line-height:var( --e-global-typography-c1ee144-line-height );letter-spacing:var( --e-global-typography-c1ee144-letter-spacing );word-spacing:var( --e-global-typography-c1ee144-word-spacing );}.elementor-kit-15 h6{font-family:var( --e-global-typography-034f283-font-family ), Sans-serif;font-size:var( --e-global-typography-034f283-font-size );font-weight:var( --e-global-typography-034f283-font-weight );line-height:var( --e-global-typography-034f283-line-height );letter-spacing:var( --e-global-typography-034f283-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1440px;}.e-con{--container-max-width:1440px;}.elementor-widget:not(:last-child){margin-block-end:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1500px){.elementor-kit-15{--e-global-typography-f1d5dad-font-size:0.9rem;--e-global-typography-f1d5dad-line-height:1.5rem;--e-global-typography-19831a6-font-size:2rem;--e-global-typography-19831a6-line-height:2.4rem;--e-global-typography-19831a6-letter-spacing:-1.6px;--e-global-typography-c20cc74-font-size:3rem;--e-global-typography-034f283-font-size:1.2rem;--e-global-typography-9e65d69-font-size:0.8rem;--e-global-typography-fdb1645-font-size:1.6rem;--e-global-typography-fdb1645-line-height:1.7rem;--e-global-typography-50f26b8-font-size:1.3rem;--e-global-typography-50f26b8-line-height:1.4rem;--e-global-typography-9897560-font-size:1.5rem;--e-global-typography-c1ee144-font-size:1.1rem;--e-global-typography-c1ee144-line-height:1.4rem;}.elementor-kit-15 h3{font-size:var( --e-global-typography-fdb1645-font-size );line-height:var( --e-global-typography-fdb1645-line-height );letter-spacing:var( --e-global-typography-fdb1645-letter-spacing );}.elementor-kit-15 h4{font-size:var( --e-global-typography-50f26b8-font-size );line-height:var( --e-global-typography-50f26b8-line-height );letter-spacing:var( --e-global-typography-50f26b8-letter-spacing );word-spacing:var( --e-global-typography-50f26b8-word-spacing );}.elementor-kit-15 h5{font-size:var( --e-global-typography-c1ee144-font-size );line-height:var( --e-global-typography-c1ee144-line-height );letter-spacing:var( --e-global-typography-c1ee144-letter-spacing );word-spacing:var( --e-global-typography-c1ee144-word-spacing );}.elementor-kit-15 h6{font-size:var( --e-global-typography-034f283-font-size );line-height:var( --e-global-typography-034f283-line-height );letter-spacing:var( --e-global-typography-034f283-letter-spacing );}}@media(max-width:890px){.elementor-kit-15{--e-global-typography-6bf534d-font-size:58px;--e-global-typography-034f283-font-size:1.2rem;--e-global-typography-fdb1645-font-size:1.5rem;--e-global-typography-fdb1645-line-height:1.7rem;--e-global-typography-50f26b8-font-size:1.2rem;--e-global-typography-9897560-font-size:1.3rem;--e-global-typography-9897560-letter-spacing:-0.5px;--e-global-typography-c1ee144-font-size:1.1rem;}.elementor-kit-15 h3{font-size:var( --e-global-typography-fdb1645-font-size );line-height:var( --e-global-typography-fdb1645-line-height );letter-spacing:var( --e-global-typography-fdb1645-letter-spacing );}.elementor-kit-15 h4{font-size:var( --e-global-typography-50f26b8-font-size );line-height:var( --e-global-typography-50f26b8-line-height );letter-spacing:var( --e-global-typography-50f26b8-letter-spacing );word-spacing:var( --e-global-typography-50f26b8-word-spacing );}.elementor-kit-15 h5{font-size:var( --e-global-typography-c1ee144-font-size );line-height:var( --e-global-typography-c1ee144-line-height );letter-spacing:var( --e-global-typography-c1ee144-letter-spacing );word-spacing:var( --e-global-typography-c1ee144-word-spacing );}.elementor-kit-15 h6{font-size:var( --e-global-typography-034f283-font-size );line-height:var( --e-global-typography-034f283-line-height );letter-spacing:var( --e-global-typography-034f283-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-15{--e-global-typography-6bf534d-font-size:38px;--e-global-typography-f1d5dad-font-size:0.9rem;--e-global-typography-19831a6-font-size:2rem;--e-global-typography-19831a6-line-height:2.4rem;--e-global-typography-19831a6-letter-spacing:-1.4px;--e-global-typography-c20cc74-font-size:2.2rem;--e-global-typography-c20cc74-line-height:1em;--e-global-typography-034f283-font-size:1.1rem;--e-global-typography-034f283-line-height:1.5em;--e-global-typography-fdb1645-font-size:1.5rem;--e-global-typography-fdb1645-line-height:1.8rem;--e-global-typography-fdb1645-letter-spacing:-1.4px;--e-global-typography-50f26b8-font-size:1.1rem;--e-global-typography-50f26b8-line-height:1.6rem;--e-global-typography-50f26b8-letter-spacing:-1.4px;--e-global-typography-9897560-font-size:1.2rem;--e-global-typography-c1ee144-font-size:1.1rem;--e-global-typography-c1ee144-line-height:2.4rem;--e-global-typography-c1ee144-letter-spacing:-1.4px;}.elementor-kit-15 h3{font-size:var( --e-global-typography-fdb1645-font-size );line-height:var( --e-global-typography-fdb1645-line-height );letter-spacing:var( --e-global-typography-fdb1645-letter-spacing );}.elementor-kit-15 h4{font-size:var( --e-global-typography-50f26b8-font-size );line-height:var( --e-global-typography-50f26b8-line-height );letter-spacing:var( --e-global-typography-50f26b8-letter-spacing );word-spacing:var( --e-global-typography-50f26b8-word-spacing );}.elementor-kit-15 h5{font-size:var( --e-global-typography-c1ee144-font-size );line-height:var( --e-global-typography-c1ee144-line-height );letter-spacing:var( --e-global-typography-c1ee144-letter-spacing );word-spacing:var( --e-global-typography-c1ee144-word-spacing );}.elementor-kit-15 h6{font-size:var( --e-global-typography-034f283-font-size );line-height:var( --e-global-typography-034f283-line-height );letter-spacing:var( --e-global-typography-034f283-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS */html {scroll-behavior: smooth!important;}
/* #region 🔷 Older rollover case study boxes */

.image-box {
  position: relative;
  overflow: hidden; /* Keeps zoomed image within bounds */
    isolation: isolate; /* ensures blending stays inside */

}

.image-box img {
  display: block;
  width: 100%;
  filter: grayscale(20%);
  transition: transform 0.6s cubic-bezier(.4,0,.2,1), filter 0.6s ease;
  transform-origin: center center;
}

.image-box .overlay {
  position: absolute;
  inset: 0;
  background-color: #2221ff55;
  transition: background-color 0.6s ease;
  z-index: 2;
  pointer-events: none;
  mix-blend-mode: overlay; /* ✅ Only applied to image overlay */
}


/* Image-box2 keeps original colour */
.image-box2 {
  position: relative;
  overflow: hidden;
}

.image-box2 img {
  display: block;
  width: 100%;
  transition: transform 0.6s cubic-bezier(.4,0,.2,1);
  transform-origin: center center;
}

.image-box2 .overlay {
  position: absolute;
  inset: 0;
  background-color: #2221ff55;
  transition: background-color 0.6s ease;
  z-index: 2;
  pointer-events: none;
  mix-blend-mode: overlay; /* ✅ Only applied to image overlay */
}

/* Base state for text/icon (no blend mode here) */
.play svg {
  fill: #1f386a;
  transition: fill 0.6s ease;
}

.driver {
  color: #1f386a;
  transition: color 0.6s ease;
}

/* Hover states (shared) */
.hover-wrapper:hover .image-box img,
.hover-wrapper:hover .image-box2 img {
  transform: scale(1.05);
}

/* Only affect overlays on hover */
.hover-wrapper:hover .image-box .overlay,
.hover-wrapper:hover .image-box2 .overlay {
  background-color: rgba(0,0,0,0.5);
}

/* Change icon/text color on hover, but no blend mode */
.hover-wrapper:hover .play svg {
  fill: #ffffff !important;
}

.hover-wrapper:hover .driver {
  color: #ffffff !important;
}

/* White box background without blend mode */
.block {
  background-color: #FFFFFFd4 !important;
  transition: background-color 0.6s ease;
}

.hover-wrapper:hover .block {
  background-color: #00000000 !important;
}


.clean-list ul {
  margin: 1em 0;
  padding-left: 1em;
  list-style-position: outside;
}
.clean-list ul li {
  margin-bottom: 0.5em;
  padding-left: .6em;
  text-indent: 0em;
}

.hover-wrapper2 {
  border-radius: 20px !important;
  background-color: #0000003A !important;
}

.hover-wrapper2:hover {
  background-color: #0000005A !important;
  transform: translateY(-5px) ;
}

.hover-wrapper2:hover .cell2 {
  background-color: #0000005A !important;
}

.hover-wrapper2:hover .cstitle,
.hover-wrapper:hover .cstitle .elementor-heading-title {
      transition: color 0.3s ease, font-size 0.3s ease;

  color: white !important;
}

.hover-wrapper2:hover .readmore {
      transition: background-color 0.3s ease;

  background-color: white !important;
  border-radius: 20px
}

.hover-wrapper2:hover .readmore .elementor-heading-title {
  color: #1f386a;
}
.contactnav {background-color:#ffffff; border-style:solid;border-width:1px;}

/* ... other styles ... */
/* #endregion */
.hover-wrapper3 {
  border-radius: 0px !important;
  background-color: #0000003A !important;
}

.hover-wrapper3:hover {
  background-color: #0000005A !important;
  transform: translateY(-5px) ;
}

.hover-wrapper3:hover .cell2 {
  background-color: #0000005A !important;
}

.hover-wrapper3:hover .cstitle,
.hover-wrapper:hover .cstitle .elementor-heading-title {
      transition: color 0.3s ease, font-size 0.3s ease;

  color: white !important;
}

.hover-wrapper3:hover .readmore {
      transition: background-color 0.3s ease;

  background-color: white !important;
  border-radius: 20px
}

.hover-wrapper3:hover .readmore .elementor-heading-title {
  color: #1f386a;
}
/* -------------------------------
   🔷 ROLLOVER BANNER WRAPPER
--------------------------------*/
.rollover-banner {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  cursor: pointer;
  min-height: 400px; /* adjust overall height */
}
.rollover-banner2 {
  position: relative;
  overflow: hidden;
  border-radius: 0px;
  cursor: pointer;
  min-height: 400px; /* adjust overall height */
}

/* -------------------------------
   🖼️ IMAGE BACKGROUND
--------------------------------*/
.rollover-banner .banner-image {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.6s cubic-bezier(.4,0,.2,1);
  z-index: 1;
}

/* -------------------------------
   🔹 BLUE INFO OVERLAY PANEL
--------------------------------*/
.rollover-banner .banner-info {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #1F386A;
  color: #ffffff;
  padding: 1em 1.5em 1.5em 1.5em;
  transition: transform 0.6s cubic-bezier(.4,0,.2,1);
  transform: translateY(calc(100% - 5em)); /* only title visible initially */
  z-index: 2;
  display: flex;
  flex-direction: column;
}

/* -------------------------------
   🏷️ TITLE CONTAINER + TEXT
--------------------------------*/
.rollover-banner .banner-title-wrap {
  padding-top: 0px;
  padding-bottom: 0.5em;
  position: relative;
  z-index: 3;
}

.rollover-banner .banner-title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.2;
}

/* -------------------------------
   🧩 HIDDEN CONTENT AREA
--------------------------------*/
.rollover-banner .banner-content {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease 0.2s, transform 0.4s ease 0.2s;
  z-index: 2;
}

/* -------------------------------
   ✨ HOVER EFFECTS
--------------------------------*/
.rollover-banner:hover .banner-image {
  transform: scale(1.05);
}

.rollover-banner:hover .banner-info {
  transform: translateY(0); /* slide up */
}

.rollover-banner:hover .banner-content {
  opacity: 1;
  transform: translateY(0);
}

/* -------------------------------
   📱 MOBILE + TABLET BEHAVIOUR
   (show all content on touch devices)
--------------------------------*/
@media (max-width: 890px) {
  .rollover-banner {
    height: auto;
  }
  .rollover-banner .banner-image {
    position: relative;
    height: 250px; /* adjust image height for mobile/tablet */
  }
  .rollover-banner .banner-info {
    position: relative;
    transform: translateY(0);
  }
  .rollover-banner .banner-content {
    opacity: 1;
    transform: none;
  }
}

/* -------------------------------
   📱 Absolute not
   (remove absolute on tablet and mobile)
--------------------------------*/

/* Desktop (default) */
.my-grid {
  position: absolute;
  top: 0;
  left: 0;
}

/* Tablet & below */
@media (max-width: 1024px) {
  .my-grid {
    position: static; /* or relative */
    top: auto;
    left: auto;
    transform: none;
  }
}

/* Base animation for each bullet */
.stagger-scope .stagger-bullets li {
  opacity: 0;
  transform: translateX(-16px);
  animation: fadeInLeftItem 0.55s ease forwards;
  animation-play-state: paused; /* don't run until revealed */
}

/* Stagger the delays (extend if you add more bullets) */
.stagger-scope .stagger-bullets li:nth-child(1) { animation-delay: 0.10s; }
.stagger-scope .stagger-bullets li:nth-child(2) { animation-delay: 0.25s; }
.stagger-scope .stagger-bullets li:nth-child(3) { animation-delay: 0.40s; }
.stagger-scope .stagger-bullets li:nth-child(4) { animation-delay: 0.55s; }
.stagger-scope .stagger-bullets li:nth-child(5) { animation-delay: 0.70s; }
.stagger-scope .stagger-bullets li:nth-child(6) { animation-delay: 0.85s; }

/* Start the animations once Elementor reveals the widget (i.e., on scroll into view) */
.elementor-widget-text-editor.stagger-scope:not(.elementor-invisible) .stagger-bullets li {
  animation-play-state: running;
}

@keyframes fadeInLeftItem {
  from { opacity: 0; transform: translateX(-16px); }
  to   { opacity: 1; transform: translateX(0); }
}/* End custom CSS */