body{
  font-family: "Jost", serif;
  padding-top: 10rem;
  background-color: #f5f5f5 !important;
  color: #353839
}
html {scroll-padding-top: 9rem}
.stating-video
{
  background-color: #f5f5f5 !important;
  display: flex;
  height: 100%;
  width: 100%;
  justify-content: center;
  align-items: center;
}
.stating-video video
{
  background-color: #f5f5f5 !important;
  width: 50%
}
.stating-video  video::-webkit-media-controls {
  display: none !important;
}
.stating-video video::-webkit-media-controls-enclosure {
  display: none !important;
}
#main-content {
  display: none;
  transition: opacity 1s ease-in-out;
}

#main-content.show {
  display: block;
  opacity: 1 !important;
}
header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1000;
  transition: top 0.5s; /* Smooth transition for the header */
  background-color: #f5f5f5 !important;
  border-color: #f5f5f5 !important;
  padding:40px 0;
}
header.hidden {
  top: -200px; /* Adjust this value based on your header height */
}
.navbar-nav .nav-item
{
  margin: 0 20px;
}
.navbar-nav .nav-item .nav-link {
  color: #373737;
  letter-spacing: 1px;
  font-size: 14px;
  padding: 0 0px;
  text-transform: uppercase;
  font-weight: 500;
  position: relative; /* Required for positioning the ::after element */
  overflow: hidden; /* Ensures the line doesn't overflow */
}

.navbar-nav .nav-item .nav-link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0; /* Position the line at the bottom */
  width: 100%; /* Full width */
  height: 2px; /* Height of the line */
  background-color: #373737; /* Color of the line */
  transform: translateX(-100%); /* Start off-screen to the left */
  transition: transform 0.3s ease-in-out; /* Animation for the line */
}

.navbar-nav .nav-item .nav-link:hover::after {
  transform: translateX(0); /* Move the line into view on hover */
}

/* imagine-logo-section */
.imagine-logo-section
{
  margin-bottom: 150px;
}
.grid-container
{
  display: grid;
    grid-template-columns: auto auto auto;
    padding: 10px 0;
    background: radial-gradient(40% 40% at 50% 50%, hsla(0, 0%, 100%, 0) 0, #f5f5f5 100%);
    position: relative;
    margin-top: -50px;
    width: 100%;
    align-items: center;
}
.grid-item:first-child, .grid-item:nth-child(2), .grid-item:nth-child(3) {
  border-top: none !important;
}
.grid-item {
  border: 3px solid hsla(0, 0%, 82.4%, .14901960784313725);
  border-left: none;
  border-bottom: none;
  padding: 60px 50px;
  text-align: center;
  z-index: 0;
}
.band-imgWrapper{
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
}
.band-imgWrapper img
{
  height:151.797px
}
.top-title
{
  padding: 50px 0 150px 0;
  position: relative; /* Positioning for the cursor */
    overflow: hidden; /* Ensures the text is hidden until it is typed out */
    min-height: 500px;
}
.top-title h1 {
  width: 780px;
  font-size: 64px;
  font-weight: 500;
  line-height: 1.5;
  color: #353839;
  display: inline-block; /* Allows the width to be respected */
  margin: 0; /* Remove default margin */
}

.cursor {
  display: inline-block;
  width: 4px; /* Width of the cursor */
  background-color: #353839; /* Cursor color */
  animation: blink 0.75s step-end infinite; /* Blinking effect */
  margin-left: 2px; /* Space between text and cursor */
}

@keyframes blink {
  50% {
      opacity: 0; /* Cursor disappears */
  }
}

.landing-scroll-bar {
  position: relative; /* Ensure the ball is positioned relative to the bar */
  width: 6px; /* Width of the scroll bar */
  height: 150px; /* Height of the scroll bar */
  background: rgba(53, 56, 57, .7); /* Color of the scroll bar */
  margin: 0 auto; /* Center the scroll bar */
}

.landing-scroll-ball {
  position: absolute;
  top: -10px; /* Start position */
  left: calc(50% - 10px); /* Center the ball horizontally */
  width: 20px; /* Width of the scroll ball */
  height: 20px; /* Height of the scroll ball */
  background: #edd46f; /* Color of the scroll ball */
  border-radius: 50%; /* Make it circular */
  animation: scroll-ball 3s ease infinite; /* Apply the animation */
}

/* Keyframes for the scroll ball animation */
@keyframes scroll-ball {
  0% {
      top: -10px; /* Start position */
      opacity: 1; /* Fully visible */
  }
  40% {
      top: 130px; /* Move down to the bottom of the scroll bar */
      opacity: 1; /* Fully visible */
  }
  50% {
      opacity: 0; /* Hide the ball */
  }
  60% {
      top: -10px; /* Move back to the start position */
      opacity: 1; /* Still hidden */
  }
  100% {
      top: -10px; /* Ensure it stays at the top */
      opacity: 1; /* Fully visible again */
  }
}

h2
{
  font-size: 40px;
    color: #353839;
    font-weight: 500;
    line-height: 1.5;
}
.mb-150
{
  margin-bottom: 150px;
}
.acdde h2 span
{
  margin-right: 10px;
}
.custom-hr
{
  background: #edd46f;
  border-color: #edd46f;
    height: 2px;
    opacity: 1;
}
.P-text p
{
  font-size: 24px;
  padding: 30px 0 30px;
  color: #353839;
  font-weight: 400;
}
.P-text span
{
  font-weight: 600;
  background: rgb(237, 212, 111);
}
.osde .boxes
{
  gap: 50px;
}
.osde .boxes .services-boxes .hover-text
{
display: none;
}
.osde .boxes .services-boxes:hover .hover-text
{
  display: flex;
  flex-wrap:wrap;
    width: 100%;
    background: #1a1a1a;
    position: absolute;
    top: 0;
    height: 100%;
    padding: 0px 10px;
}
.osde .boxes .services-boxes:hover .hover-text ul
{
  color: #fff;
    width: 100%;
    /* columns: 2; */
    font-size: 14px;
    padding: 14px 7px 17px 30px;
    /* column-gap: 43px; */
}
.osde .boxes .services-boxes:hover .hover-text ul li
{
  margin-bottom: 3px;
}
.osde .boxes p
{
  font-size: 18px;
  font-weight: 500;
  color: #353839;
  padding: 8px 0;
}
.osde .boxes p span
{
  border-bottom: 2px solid #edd46f;
}
.solutions-list
{
  columns: 2;
  column-gap: 30px;
  list-style: none;
  padding-left: 0;
  font-size: 28px;
  font-weight: 500;
}
.solutions-list li
{
display: flex;
gap: 20px;
align-items: center;
margin-bottom: 20px;
}
.solutions-list li img {
  height: 27px;
  background: #edd46f;
}

/* Footer */
footer
{
  background: #353839;
  padding: 80px  0 0 0;
}
footer .f-copyright p
{
  font-size: 14px;
  text-align: center;
  color: #f5f5f5;
  font-weight: 300;
}
footer .f-copyright
{
  border-top:1px solid #edd46f;
  padding: 20px 0 0  0;
  margin-top: 30px;
}
.footer-logo
{
  justify-content: start;
  flex-direction: column;
  gap: 15px;
}
.footer-logo p
{
  font-size: 14px;
  font-style: normal;
  font-weight: 300;
  line-height: 21px;
  color: #edd46f;
  width: 149px;
}
footer .address a
{
  color: #f5f5f5;
  font-size: 14px;
    font-style: normal;
    font-weight: 300;
    line-height: 21px;
    text-decoration: none;
}
footer .address a:hover, footer .footer-links a:hover
{
  text-decoration: underline;
}
footer .footer-links ul
{
  padding-left: 0;
}
footer .footer-links ul li
{
  margin-bottom: 10px;
}
footer .footer-links a
{
  color: var(--imagine-brand-color, #edd46f);
    font-family: Jost;
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px;
    text-decoration: none;
}
.footer-menu-wrap
{
  justify-content: space-between;
}
.sm-footer-links p
{
  color: var(--imagine-brand-color, #edd46f);
  font-family: Jost;
  font-size: 16px;
  font-style: normal;
  font-weight: 300;
  line-height: 24px;
  text-decoration: none; 
}
.sm-footer-links .sm-icons
{
  gap: 20px;
}
.sm-footer-links .sm-icons img
{
  height: 20px;
}
.sm-footer-links .sm-icons a
{
  color: var(--imagine-brand-color, #edd46f);
  align-items: center;
  display: inline-flex;
  font-feature-settings: "liga";
  font-size: 24px;
  justify-content: center;
  letter-spacing: normal;
  line-height: 1;
  position: relative;
  text-indent: 0;
  transition: .3s cubic-bezier(.25,.8,.5,1), visibility 0s;
  vertical-align: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  height: 24px;
    font-size: 24px;
    width: 24px;
}
.sm-footer-links .sm-icons a:hover
{
  text-shadow: 0 0 20px rgba(246, 193, 194, .6);
  /* box-shadow: 0 0 20px rgba(246, 193, 194, .6);
  background:none; */
}
/* hs contact form */
.hs-contact-form
{
  padding: 50px 0 100px 0;
}
.hs-contact-form h2
{
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: 36px;
  margin:0 0 60px 0;
}
.hs-contact-form .whatHappensNxt-line
{
  border-right: 1px solid rgb(102, 102, 102); 
  opacity: 0.248; 
  height: 440px;
}
.hs-contact-form .whatHappensNxt-wrapper {
  width: 290px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 40px;
  display: inline-flex;
  margin-left: 20px;
}
.whatHappensNxt-title {
  color: #121212;
  font-size: 24px;
  font-family: Jost;
  font-weight: 500;
  word-wrap: break-word;
}
.nxtSteps-wrapper {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 57px;
  display: flex;
}
.nxt-section {
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  display: inline-flex;
}
.nxt-wrapper-container {
  width: 40px;
  height: 40px;
  padding: 10px;
  background: #edd46f;
  border-radius: 4px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  display: inline-flex;
}
.list-content-section {
  color: #000;
  font-size: 18px;
  font-family: Jost;
  font-weight: 700;
  word-wrap: break-word;
}
.nxtSteps-content-info {
  color: #000;
  font-size: 16px;
  font-family: Jost;
  font-weight: 400;
  line-height: 26px;
  word-wrap: break-word;
}
.form-wrap
{
  display: flex;
  justify-content: center;
  gap: 40px;
  align-items: center;
  padding: 40px 0;
}
.nxt-step-divider {
  width: 215.71px;
  height: 0;
  transform: rotate(90deg);
  transform-origin: 0 0;
  opacity: .25;
  border: .5px solid #edd46f;
  position: absolute;
  margin-left: 20px;
}
/* PP-page */
.PP-page h1
{
  font-size: 70px;
  font-weight: 700;
}
.my-15 {
  margin-top: 60px !important;
  margin-bottom: 60px !important;
}
.theme--light .v-divider {
  border-color: rgba(0, 0, 0, .12);
}
.v-divider {
  display: block;
  flex: 1 1 0px;
  max-width: 100%;
  height: 0;
  max-height: 0;
  border: solid;
  border-width: thin 0 0;
  transition: inherit;
}
.pp-content-wrap
{
  gap: 20px;
  margin: 0 0 50px 0;
}
.pp-content-wrap .pp-number, .pp-content-wrap h2
{
  font-size: 28px;
  color: #353839;
  font-weight: 500;
}
.pp-content-wrap p
{
  font-size: 18px;
  color: #353839;
  font-weight: 400;
}
.pp-content-wrap .ul-disimal
{
  font-size: 18px;
  color: #353839;
  font-weight: 400;
  padding-left: 15px;
  list-style:lower-roman;
}
.pp-content-wrap .table-striped
{
  font-size: 18px;
  color: #353839;
  font-weight: 400;
}
table.table-striped tr td:nth-child(1) {
  width: 300px;background: none;border: none;
}
table.table-striped tr td:nth-child(2) {
  background: none;border: none;
}
.ul-lower-alpha
{
  list-style: lower-alpha;
  padding-left: 20px;
}
.ml-30
{
  margin-left: -30px;
}
.tou-page h1
{
  font-size: 70px;
  font-weight: 700;
}
.tou-page .my-15 {
  margin: 100px 0 !important;
}
.tou-page{
  color: #353839;
}
.tou-page h2
{
  font-size: 26px;
  margin-bottom: 20px;
  font-weight: 400;
}
.tou-page p
{
  font-size: 18px;
  margin-bottom: 20px;
  font-weight: 400;
}
.tou-page ul
{
  padding-left: 15px;
}
.tou-page ul li
{
  font-size: 18px;
  font-weight: 400;
  padding-left: 10px;
}

/* Solutions */

.imagine-solutions .imagine-solutions-wrap
{
  display: flex;
  gap: 40px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 60px;
  width: 900px;
}
.imagine-solutions .solutions-box
{
  border-radius: 14px;
  border: 2px solid var(--imagine-brand-color, #3d3d3d);
  background: #1a1a1a;
  height: 430px;
  width: 370px;
}
.imagine-solutions .solutions-box .product-logo
{
  border-bottom: 1px solid #3d3d3d;
  padding: 24px;
}
.imagine-solutions .solutions-box .product-logo img
{
  height: 36px;
}
.imagine-solutions .solutions-box .logo-content
{
  color: #fff;
  font-style: normal;
  font-weight: 400;
  display: flex;
  flex-direction: column;
  padding: 24px 24px 0 24px;
  height: 75%;
}
.imagine-solutions .solutions-box .logo-content p
{
  font-size: 18px;
  line-height: 28px;
}
.imagine-solutions .solutions-box .view-btn
{
  color: #edd46f;
  font-style: normal;
  font-weight: 400;
  font-size: 20px;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
}
.imagine-solutions .solutions-box .view-btn i
{
  font-size: 22px;
  margin-top: 4px;
  font-weight: 700 !important;
}
.imagine-solutions .solutions-box:hover .logo-content
{
  display: none;
}
.imagine-solutions .solutions-box:hover .logo-content-2
{
  display: flex;
  flex-direction: column;
  padding: 24px 24px 0 24px;
  height: 75%;
}
.imagine-solutions .solutions-box .logo-content-2
{
  display: none;
}
.imagine-solutions .solutions-box .logo-content-2 .products-suite-logos
{
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: start;
  align-items: start;
}
.imagine-solutions .solutions-box .logo-content-2 .products-suite-logos .suite-details-logo
{
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: start;
  align-items: start;
}
.imagine-solutions .solutions-box .logo-content-2 .products-suite-logos img
{
  height: 33px;
}
.cs-logo img
{
  height: 26px !important;
}
.imagine-solutions .solutions-box .logo-content-2 .products-suite-logos i
{
  font-size: 14px;
  color: #fff;
}
.imagine-solutions .solutions-box .logo-content-2 a.leanmore-btn
{
  color: #fff;
  font-style: normal;
  font-weight: 400;
  font-size: 20px;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #fff;
  width: 140px;
  padding: 8px 20px;
  border-radius: 8px;
  margin-bottom: 20px;
}
.aide-solutions
{
  padding-left: 22px;
  font-size: 24px;
  color: #353839;
  font-weight: 400;
}
.aide-solutions li
{
  margin-bottom: 10px;
}
.cta-explore-products
{
    margin: 0 auto;
    display: flex;
    padding: 12px 40px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 2px;
    border: 1px solid var(--imagine-brand-dark, #847021);
    background: #edd46f;
    text-decoration: none;
    color: #000;
    font-family: Jost;
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
    line-height: 160%;
    flex-direction: row;
    margin: 100px 0;
}


/* Breakpoints */
/* // `xxl` applies to x-large devices (large desktops, less than 1400px) */
@media (max-width: 1399.98px) { 
  /* Start */

/* End */
}

/* // `xl` applies to large devices (desktops, less than 1200px) */
@media (max-width: 1199.98px) { 
/* Start */
.top-title h1 {
  width: 680px;
  font-size: 55px;
}
.osde .boxes p {
  font-size: 16px;
}
.solutions-list {
  font-size: 22px;
}
.PP-page h1, .tou-page h1 {
  font-size: 54px;
}

/* End */
}

/* // `lg` applies to medium devices (tablets, less than 992px) */
@media (max-width: 991.98px) { 
/* Start */
.band-imgWrapper img {
  height: 100.797px;
}
h2 {
  font-size: 28px;
}
.row.mt-4.boxes {
  gap: 40px 0;
}
.imagine-solutions .solutions-box {
  height: 460px;
  width: 327px;
}
.hs-contact-form .whatHappensNxt-wrapper, .hs-contact-form .whatHappensNxt-line
{
  display: none;
}
/* End */
}
/* // `md` applies to small devices (landscape phones, less than 768px) */
@media (max-width: 767.98px) { 
/* Start */
.top-title h1 {
  width: 100%;
  font-size: 54px;
}
.top-title {
  padding: 30px 0 150px 10px;
}
.footer-menu-wrap {
  margin-top: 30px;
}
.offcanvas-title img {
  width: 43%;
  margin: 20px;
}
.pp-content-wrap {
  gap: 20px;
  margin: 0 0 20px 0;
}
.pp-content-wrap .pp-number, .pp-content-wrap h2 {
  font-size: 20px;
}
.PP-page h1, .tou-page h1 {
  font-size: 36px;
}
.tou-page .my-15 {
  margin: 50px 0 !important;
}
/* End */
}
/* // `sm` applies to x-small devices (portrait phones, less than 576px) */
@media (max-width: 575.98px) { 
/* Start */
.top-title h1 {
  font-size: 38px;
}
.band-imgWrapper img {
  height: 66.797px;
}
.solutions-list {
  columns: 1;
}
/* End */
}