/* ===================== GLOBAL STYLES ===================== */

.section {
  padding-top: 5vh;
  padding-bottom: 5vh;
}

#request-form-heading,
#our-motion-services,
#team-cards,
#how-it-works-section {
  scroll-margin-top: 15vh;
}

@media (max-width: 1024px) {
  #request-form-heading,
  #our-motion-services,
  #team-cards,
  #how-it-works-section {
    scroll-margin-top: 80px;
  }
}

html,
body {
  font-family: 'Didact Gothic', Arial, sans-serif;
  color: #25007D;
  background: #fff;
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Kumbh Sans', 'Didact Gothic', Arial, sans-serif !important;
  color: #0027EB;
  margin-top: 0;
  font-weight: 600;
  letter-spacing: 0.01em;
}

@media (min-width: 1025px) {
  h2 {
    font-size: 52px !important;
  }
}

/* Privacy Policy Page - Smaller H2s */
.privacy-policy-page h2 {
  font-size: 28px !important;
  line-height: 1.2;
  margin-top: 48px !important;
}

.privacy-policy-banner-wrap {
  margin: 10px 0 36px;
}

.privacy-policy-banner {
  width: 60%;
  height: auto;
  display: block;
  border-radius: 18px;
}

@media (max-width: 1024px) {
  .privacy-policy-banner {
    width: 70%;
    margin: 0 auto;
  }
}

@media (max-width: 600px) {
  .privacy-policy-banner {
    width: 90%;
    margin: 0 auto;
  }
}

/* ===================== Boxed Layout ===================== */

.container {
  width: 64.7vw;
  max-width: 1540px;
  min-width: 320px;
  margin: 0 auto 48px auto;
  box-sizing: border-box;
}

@media (max-width: 1440px) {
  .container {
    width: 72vw;
    max-width: 1050px;
  }
}

@media (max-width: 1024px) {
  .container {
    width: 90%;
    
  }
}

.section-title {
  font-family: 'Kumbh Sans', 'Didact Gothic', Arial, sans-serif !important;
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.1;
  margin: 10px 0 0 0;
  text-align: left;
}

@media (max-width: 1024px) {
  .section-title {
    text-align: center;
  }
}

.section-title-purple {
  color: #25007D;
}

.section-title-blue {
  color: #0027EB;
}

.mobile-nav-spacer {
  display: none;
}

@media (max-width: 1024px) {
  .mobile-nav-spacer {
    display: block;
    height: 60px;
    width: 100%;
  }
}

/* =====================    DESKTOP HEADER & NAVIGATION ===================== */

.main-nav {
  display: flex;
  align-items: center;
  justify-content: space-around;
  background: #fff;
  position: relative;
  padding: 0 20px 20px 20px;
  z-index: 1000;
  width: 88vw;
  margin-left: auto;
  left: auto;
  box-sizing: border-box;
  margin-top: 0;
 
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  height: 100px;
  border-radius: 0 0 0 100px;
  border-left: 1px solid #B5A3F9;
  border-bottom: 1px solid #B5A3F9;
  transition: position 0.3s ease;
}

.main-nav.main-nav-scrolled {
  position: fixed !important;
  top: 0;
  right: 0;
  left: auto;
  width: 88vw;
  z-index: 10010;
}

@media (max-width: 1024px) {
  .main-nav {
    display: none !important;
  }
}

@media (max-width: 900px) {
  .main-nav {
    flex-direction: column;
    gap: 18px;
    padding: 18px 10px;
  }
}

@media (max-width: 600px) {
  .main-nav {
    flex-direction: column;
    gap: 10px;
    padding: 10px 5px;
  }
}

.nav-logo img {
  height: 48px;
}

@media (max-width: 600px) {
  .nav-logo img {
    height: 36px;
  }
}

.nav-links {
  list-style: none;
  display: flex;
  gap: 32px;
  margin: 0;
}

.nav-links li a {
  color: #0027EB;
  text-decoration: none;
  font-weight: 600;
  font-size: 1.1rem;
  transition: color 0.2s;
}

.nav-links li a:hover {
  color: #5BFFD8;
}



/* =====================    MOBILE HEADER & NAVIGATION ===================== */



.custom-mobile-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0 10px 10px;
  margin-top: 0;
  background-color: #fff;
  position: fixed;
  width: 100%;
  box-sizing: border-box;
  z-index: 1000;
  border-bottom: 1px solid #B5A3F9;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

@media (min-width: 1025px) {
  .custom-mobile-header {
    display: none !important;
  }
}

@media (max-width: 1024px) {
  .custom-mobile-header {
    display: flex !important;
  }
}

.website-logo {
  height: 40px;
  width: auto;
}

.hamburger-icon,
.close-menu {
  background: none;
  border: none;
  font-size: 33px;
  cursor: pointer;
  position: absolute;
  color: #25007D;
  right: 35px;
}

.close-menu {
  display: none;
}

.custom-mobile-menu {
  display: none;
  position: fixed;
  top: 60px;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
  z-index: 999;
  padding-top: 60px;
}

.custom-mobile-menu.active {
  display: block;
}

@media (min-width: 1025px) {
  .custom-mobile-menu {
    display: none !important;
  }
}

.custom-menu a {
  display: block;
  padding: 15px;
  font-size: 20px;
  font-weight: bold;
  color: #25007D;
  text-decoration: none;
  text-align: center;
  border-bottom: solid 1px #D9D9D9;
}

.social-icons {
  display: flex;
  justify-content: center;
  margin-top: 10px;
  padding-top: 20px;
  padding-bottom: 10vh;
}

.mobile-menu-contact-info {
  color: #fff;
  background-color: #000A89;
  text-align: center;
  padding-top:20px;
  padding-bottom:20px;
}

.sidebar-social {
  position: fixed;
  top: 20px;
  left: 0;
  width: 100px;
  background: #fff;
  border-radius: 0 100px 0 0;
  box-shadow: 0 2px 6px 2px #B5A3F9;
  z-index: 9999;
  padding-top: 50px;
  padding-bottom: 30px;
  margin-top: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  border: 1px solid #ccc;
}

@media (max-width: 1024px) {
  .sidebar-social {
    display: none !important;
  }
}

.sidebar-icon {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
   background-color: #f9f7fe;
   border-radius:50%;
}

.sidebar-icon img {
  width: 40px;
  height: 40px;
  transition: transform 0.2s;
 
}

.sidebar-icon:hover  {
  
  background-color:#3400f3;
 
}



/* ===================== INTRO CTA SECTION ===================== */

.intro-mission-svg {
  padding-top: 0;
}

@media (max-width: 1024px) {
  .intro-mission-svg {
    padding-top: 20px;
  }
}

.intro-cta-bgwrap {
  position: relative;
  width: 100%;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;

}

@media (max-width: 1024px) {
  .intro-cta-bgwrap {
    align-items: center;
  }
}

.intro-cta-blob-bg {
  position: absolute;
  top: 0;
  left: -2.5vw;
  transform: none;
  width: 401px;
  height: 155px;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}

@media (max-width: 1024px) {
  .intro-cta-blob-bg {
    left: 50%;
    transform: translateX(-50%);
    top: 30px !important;
  }
}

.intro-cta-row,
.intro-cta-bgwrap .section-title {
  position: relative;
  z-index: 1;
}

.intro-cta-row {
  max-width: 1050px;
  margin: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

@media (max-width: 1024px) {
  .intro-cta-row {
    margin: 20px auto 0 auto;
    justify-content: center;
  }
}

.intro-cta-row img,
.intro-cta-row svg {
  display: block;
  margin-left: 0;
  max-width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .intro-cta-row img,
  .intro-cta-row svg {
    margin-left: auto;
    margin-right: auto;
  }
}

.intro-cta-desc {
  margin: 18px 0 0 0;
  font-size: 1.25rem;
  color: #25007D;
  font-family: 'Didact Gothic', Arial, sans-serif;
  line-height: 1.5;
  text-align: left;
}

@media (min-width: 1025px) {
  .intro-cta-desc {
    max-width: 360px;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    text-align: left;
    padding-top: 0;
  }
}

@media (min-width: 601px) and (max-width: 1024px) {
  .intro-cta-desc {
    width: 65vw;
    max-width: 100%;
    margin: 18px auto 0 auto;
    text-align: center;
    padding-top: 30px;
  }
}

@media (max-width: 600px) {
  .intro-cta-desc {
    width: 90vw;
    max-width: 100%;
    margin: 18px auto 0 auto;
    text-align: center;
    padding-top: 30px;
  }
}

.intro-cta-highlight {
  color: #3400F3;
  font-family: 'Kumbh Sans', Arial, sans-serif;
 font-weight: 300;
  font-size: 36px;
  margin: 32px 0 0 0;
  text-align: left;
  line-height: 1.1;
  letter-spacing: 0.8px;
}

@media (max-width: 1024px) {
  .intro-cta-highlight {
    font-size: 36px;
    text-align: center;
    margin: 32px auto 0 auto;
  }
}

@media (max-width: 600px) {
  .intro-cta-highlight {
    font-size: 33px;
    text-align: center;
    margin: 32px auto 0 auto;
  }
}

.two-buttons {
  display: flex;
  margin-top: 35px;
}

@media (max-width: 768px) {
  .two-buttons {
    flex-direction: column;
    align-items: center;
  }
}

.two-buttons a {
  text-decoration: none !important;
}

.request-button {
  width: 200px;
  height: 50px;
  background-color: #25007D;
  color: #fff;
  font-size: 20px;
  font-family: 'Kumbh Sans', Arial, sans-serif;
  font-weight: bold;
  border-style: none;
  border-radius: 8px;
}

.request-button:hover {
  background-color: #3400F3;
  color: #5BFFD8;
}

.centered-text {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 20px;
  padding-right: 20px;
}

@media (max-width: 768px) {
  .centered-text {
    padding-top: 20px;
  }
}

.play-button {
  padding: 10px 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  width: 200px;
  height: 50px;
  font-size: 20px;
  font-weight: bold;
  border-style: none;
  border-radius: 8px;
  background-color: #F3F3FB !important;
  gap: 8px;
}

.play-button:hover {
  background-color: #5BFFD8 !important;
}

.play-button svg {
  width: 44px;
  height: 44px;
  margin-right: 8px;
  display: block;
}

.how-it-works {
  display: inline-flex;
  align-items: center;
  align-self: center;
  padding-top: 7%;
  padding-bottom: 7%;
  width: 200px;
  color: #25007D;
  font-family: 'Kumbh Sans', Arial, sans-serif;
  font-weight: bold;
  font-size: 20px;
  border-style: none;
  border-radius: 8px;
  line-height: 1.1;
  text-decoration: none !important;
}

/* ===================== MODERN APPROACH SECTION ===================== */

.modern-approach {
  background-color: #fafafa;
  padding-top: 30px;
}

.modern-header-wrap {
  position: relative;
  min-height: auto;
  margin-bottom: 10px;
  
  padding-top:30px;
  padding-bottom:30px;
 
}

.modern-header-blob {
  position: absolute;
  top: 30px;
  left: -2.5vw;
  transform: none;
  width: 401px;
  height: 155px;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}




.modern-header-row,
.modern-title {
  position: relative;
  z-index: 1;
}

.modern-header-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0;
}

.modern-svg {
  display: block;
  max-width: 100%;
  height: auto;
  
}

.modern-title {
  margin: 10px 0 0 0;
}

.modern-two-column {
  display: grid;
  grid-template-columns: 40% 60%;
  gap: 32px;
  align-items: center;
  margin-top: 0;
}

@media (max-width: 1024px) {
  .modern-header-wrap {
    text-align: center;
    margin-bottom: 6px;
  }

  .modern-header-row {
    justify-content: center;
    margin: 20px auto 0 auto;
  }

  .modern-header-blob {
    left: 50%;
    transform: translateX(-50%);
    top: 30px !important;
    
  }

  .modern-title {
    margin-top: 6px;
    padding-bottom: 0;
  }
}

@media (max-width: 900px) {
  .modern-two-column {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.modern-left-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}

.modern-right-col {
  display: flex;
  
  align-items: center;
}

.modern-paragraph {
  margin: 18px auto 0px;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #25007D;
  width: 100%;
  max-width: 360px;
  padding-top: 0;
}

@media (max-width: 1024px) {
  .modern-left-col {
    align-items: center;
  }

  .modern-right-col {
    justify-content: center;
  }

  .modern-paragraph {
    text-align: center;
    margin: 0 auto;
  }
}

@media (min-width: 601px) and (max-width: 1024px) {
  .modern-paragraph {
    width: 65vw;
    max-width: 100%;
  }
}

@media (max-width: 600px) {
  .modern-paragraph {
    width: 90vw;
    max-width: 100%;
  }
}

.modern-lottie {
  width: 100%;
  max-width: 595px;
  height: 260px;
  overflow: hidden;
  touch-action: pan-y;
}

.modern-lottie svg {
  width: 100% !important;
  height: 100% !important;
  display: block;
}

.modern-three-lotties {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 20px;
}

@media (max-width: 900px) {
  .modern-three-lotties {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.modern-mini-lottie {
  width: 100%;
  height: 320px;
  border-radius: 10px;
  overflow: hidden;
  touch-action: pan-y;
}

.modern-mini-lottie svg {
  width: 100% !important;
  height: 100% !important;
  display: block;
}

@media (max-width: 600px) {
  .modern-mini-lottie {
    max-width: 92vw;
    margin: 0 auto;
    height: 260px;
  }
}

@media (min-width: 601px) and (max-width: 1024px) {
  .modern-mini-lottie {
    max-width: 78vw;
    margin: 0 auto;
    height: 320px;
  }
}

@media (max-width: 1024px) {
  .modern-lottie {
    max-width: 90%;
    min-height: 90%;
  }
}


/* ===================== MOTION SERVICES SECTION ===================== */

.services-header-wrap {
  position: relative;
  min-height: auto;
  margin-bottom: 10px;
  padding-top:30px;
  padding-bottom:30px;
}

.services-header-row,
.services-title {
  position: relative;
  z-index: 1;
}


.services-header-blob {
  position: absolute;
  top: 10px;
  left: -2.5vw;
  transform: none;
  width: 401px;
  height: 155px;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}

@media (max-width: 1024px) {
  .services-header-blob {
    left: 50%;
    transform: translateX(-50%);
    top: 0px !important;
  }
}

.services-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .services-svg {
    margin: 0 auto;
  }
}


/* ===================== VIDEO MASONRY STYLES ===================== */


.video-gallery-desktop {
 display:flex;

gap:5px;
margin-top:7vh; 

}

@media (max-width: 1024px) {
  .video-gallery-desktop {
    display: none;
  }
}


.gallery-vertical {

display:flex;
flex-direction:column;
gap:5px;

}

.grid-gallery {
  display:flex;
  flex-direction:column;
  gap:5px;

 
}

.gallery2, .gallery3 {
display:flex;
align-items: stretch; /* Ensures videos stretch to the same height */
gap:5px;
}

.gallery-item {
  height: 100%;
  position: relative;
  min-width: 0;

}

.video-title {
position:absolute;
top: 70%;
right:15%;
color:white;
}

video {
  border-radius:5px;
  display: block;
  width: 100%;
  height:auto;
}

/* ===================== VIDEO GALLERY MASONRY STYLES MOBILE ===================== */

.video-gallery-mobile {
 display: flex;
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  margin-top:7vh;
}

@media (min-width: 1025px) {
  .video-gallery-mobile {
    display: none;
  }
}

.mobile-gallery {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px; /* Adjusts space between items */
}

.mobile-gallery .gallery-item {
  position:relative;
  height:auto;
  width:100% !important;
  min-width: 0;
}


.video-title-mobile {
  position:absolute;
  left: 10px;
  bottom: 10px;
  right: auto;
  top: auto;
  color:white;
}

video {
  border-radius:5px;
}

.mobile-gallery video {
  display: block;
  width: 100%;
  height: auto;
}

/* ===================== CARD CAROUSEL SECTION ===================== */

.card-carousel-section {
  background: #f7f7fb;
}

.card-carousel {
  position: relative;
}

.card-carousel-track {
  display: grid;
  overflow: hidden;
}

.card-carousel-arrow {
  position: absolute;
  top: 50%;
  z-index: 4;
  width: 52px;
  height: 52px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: #25007D;
  box-shadow: 0 10px 24px rgba(37, 0, 125, 0.18);
  transform: translateY(-50%);
  cursor: pointer;
}

.card-carousel-arrow:hover {
  background: #ffffff;
}

.card-carousel-arrow span {
  font-size: 1.5rem;
  line-height: 1;
}

.card-carousel-arrow-prev {
  left: 6px;
}

.card-carousel-arrow-next {
  right: 16px;
}

@media (min-width: 1025px) {
  .card-carousel-arrow-prev {
    left: -28px;
  }

  .card-carousel-arrow-next {
    right: -28px;
  }
}

.card-carousel-item {
  grid-area: 1 / 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 32px;
  align-items: center;
  padding: 32px;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 16px 40px rgba(37, 0, 125, 0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateX(100%);
  transition: transform 0.65s ease, opacity 0.65s ease, visibility 0.65s ease;
  pointer-events: none;
}

.card-carousel-item.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
  pointer-events: auto;
  z-index: 2;
}

.card-carousel-item.is-next {
  opacity: 1;
  visibility: visible;
  transform: translateX(100%);
  z-index: 3;
}

.card-carousel-item.is-prev {
  opacity: 1;
  visibility: visible;
  transform: translateX(-100%);
  z-index: 3;
}

.card-carousel-item.is-entering {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
  z-index: 3;
}

.card-carousel-item.is-leaving {
  opacity: 1;
  visibility: visible;
  transform: translateX(-100%);
  z-index: 2;
}

.card-carousel-item.is-leaving-right {
  opacity: 1;
  visibility: visible;
  transform: translateX(100%);
  z-index: 2;
}

.card-carousel-content h3 {
  margin: 0 0 16px;
  font-family: 'Kumbh Sans', 'Didact Gothic', Arial, sans-serif;
  font-size: 2rem;
  line-height: 1.1;
  color: #0027EB;
}

.card-carousel-content p {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.6;
  color: #25007D;
}

.card-carousel-media img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 20px;
}

@media (max-width: 900px) {
  .card-carousel-arrow {
    width: 46px;
    height: 46px;
  }

  .card-carousel-item {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 24px;
  }
}

@media (max-width: 600px) {
  .card-carousel {
    padding-bottom: 68px;
  }

  .card-carousel-arrow {
    top: auto;
    bottom: 0;
    transform: none;
  }

  .card-carousel-arrow-prev {
    left: calc(50% - 58px);
  }

  .card-carousel-arrow-next {
    right: calc(50% - 58px);
  }

  .card-carousel-item {
    padding: 24px 20px 20px;
  }

  .card-carousel-content h3,
  .card-carousel-content p {
    text-align: center;
  }
}


/****************************OUR  MODEL - HOW IT WORKS  *****************************/

.how-it-works-container {
width: 64.7vw;
  max-width: 1540px;
  min-width: 320px;
  margin: 0 auto -50px auto;

  box-sizing: border-box;

}

.model-header-wrap {
  position: relative;
  min-height: auto;
  margin-bottom: 10px;
  padding-top:30px;
  padding-bottom:30px;
 
}
.model-header-row,
.model-title {
  position: relative;
  z-index: 1;
}

.model-header-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0;
}

.model-header-blob {
  position: absolute;
  top: 10px;
  left: -2.5vw;
  transform: none;
  width: 401px;
  height: 155px;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}

.model-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .model-header-blob {
    left: 50%;
    transform: translateX(-50%);
    top: 0px !important;
    
  }

  .model-header-row {
    justify-content: center;
    margin: 20px auto 0 auto;
  }

  .model-svg {
    margin: 0 auto;
  }
}


/****Model Button ***/

.model-row {
  display: flex;
  justify-content: flex-start;
  gap: 60px;
  align-items: center;
  margin-top: 35px;
  padding-bottom:40px;
  
}

@media (max-width: 1024px) {
  .model-row {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 30px;
  }
}

.model-button-div a {
  text-decoration: none !important;
}


.model-button {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 20px;
  border: solid 1px #3400F3 !important;
  border-radius: 4px;
  background-color: #ffffff !important;
  padding:8px 8px 8px 12px;
}



.model-button svg{
  width: 34px;
  height: 34px;
  margin-left: 8px;
  display: block;
}

.read-below {
  color:#000A89;
}



/*************************ACCORDION CODE ***********************/

.accordion-container {
  background-color: #fafafa;
  padding-top: 80px;
  padding-bottom: 30px;
}

.accordion {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap; /* Ensure items are in one line */
  overflow: hidden; /* Hide overflow to keep items in one line */
  width: 64.7vw;
  max-width: 1540px;
  min-width: 320px;
  margin: 0 auto 48px auto;
  box-sizing: border-box;
  
  
}


.accordion-item {
  position: relative;
  flex: 0 0 15%; /* Ensure each item takes up 25% of the container */
  transition: all 0.3s ease;
  overflow: hidden;
  cursor: pointer;
  height: 500px; /* Set a fixed height for closed items */
margin-left:6px;
margin-right:6px;
border-radius:10px;
 
}

.accordion-icons-container {
  display: flex;
  width:70%;
  justify-content:center;
 margin:50px auto;
  
}

.accordion-item .closed-content {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  background-color: lightgray;
}

.accordion-item .expanded-content {
  display: none;
  padding: 20px;
  color: white;
  box-sizing: border-box;
}

.accordion-item.expanded {
  flex: 1 1 100%; /* Ensure expanded item takes up full width */
  height: auto; /* Adjust height for expanded items */
}


.attachment-icon {
  height: 68px;
  width:auto;
}

.accordion-item h2  {
text-align:center;
margin-top:60px;
color:#000000;
}

.work-accordion-h2 {
  font-size: 30px !important;
  line-height: 1.1;
  margin-top: 0;
}


.accordion-item li  {

color:#323232;
  margin: 0 auto;
  max-width: 400px; /* or any width */

}

.icon {
display:block;
margin-left:auto;
margin-right:auto;
  
}

.accordion-item.expanded .closed-content {
  display: none;
}

.accordion-item.expanded .expanded-content {
  display: block;
  background-size: cover;
  background-position: center;
}

#item1.expanded .expanded-content {
  background-color:#ffe9b1;
  height:500px;
}

#item2.expanded .expanded-content {
background-color:#ffe9b1;
height:500px;
}

#item3.expanded .expanded-content {
background-color:#ffe9b1;
height:500px;
}

#item4.expanded .expanded-content {
background-color:#ffe9b1;height:500px;
}

#item1 .closed-content {
  background-color: #F8F7FF;
}

#item2 .closed-content {
  background-color: #F4F1FF;
}

#item3 .closed-content {
  background-color: #E3DDFF;
}

#item4 .closed-content {
  background-color: #CCC0FF;
}

.icon {
  width: 100px;
  height: 100px;
}

/* ===================== COOKIE BANNER ===================== */

.cookie-banner {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(420px, calc(100vw - 40px));
  aspect-ratio: 1 / 1;
  background-color: #fff;
  border: 2px solid #3400F3;
  box-shadow: 10px 10px 24px rgba(37, 0, 125, 0.38);
  border-radius: 41px;
  z-index: 12000;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 20px 14px;
}

.cookie-banner.is-hidden {
  display: none;
}

.cookie-banner-close {
  position: absolute;
  top: 16px;
  right: 16px;
  border: 0;
  background: transparent;
  color: #25007D;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 4px;
}

.cookie-banner-icon {
  width: 180px;
  height: 180px;
  margin-bottom: 10px;
}

.cookie-banner-title {
  margin: 0 0 8px 0;
  font-size: 28px !important;
  font-family: kumbh sans, 'Didact Gothic', Arial, sans-serif;
  line-height: 1.15;
  color: #323232;
  letter-spacing: 1.5px;
}

.cookie-banner-text {
  margin: 0;
  font-size: 17px;
  letter-spacing:1.2px;
  font-weight:500;
  color: #323232;
}

.cookie-banner-accept {
  margin-top: 20px;
  
  border: 0;
  border-radius: 8px;
  background-color: #25007D;
  color: #fff;
  font-family: 'Kumbh Sans', 'Didact Gothic', Arial, sans-serif;
  font-size: 26px;
  font-weight: 500;
  cursor: pointer;
  padding:2px 40px 4px 40px;
}

.cookie-banner-accept:hover {
  background-color: #3400F3;
}

.cookie-banner-or {
  margin-top: 10px;
  font-size: 22px;
  letter-spacing:1.2px;
  color: #25007D;
}

.cookie-banner-policy {
  margin: 6px 0 0 0;
  display: inline-block;
  font-size: 22px;
  letter-spacing:1.2px;
  color: #25007D;
  text-decoration: none;
}

.cookie-banner-policy-emphasis {
  text-decoration: underline;
}

.cookie-banner-policy:hover {
  text-decoration: none;
}

@media (max-width: 480px) {
  .cookie-banner {
    width: calc(100vw - 24px);
    padding: 24px 18px;
  }

  .cookie-banner-icon {
    width: 94px;
    height: 94px;
  }

  .cookie-banner-title {
    font-size: 21px !important;
  }
}

/* Media Queries */
@media (max-width: 768px) {
  .accordion {
    flex-direction: column;
  }

  .accordion-item {
    flex: 1 1 auto;
height:200px;
margin-top:6px;
margin-bottom:6px;
border-radius:10px;
  }

.accordion-item.expanded  {
  height: 500px;
}
}


/************************CONTACT FORM CODE ***********************/

/*STYLE CONTACT FORM */

.contact-section {
  position: relative;
  overflow: visible;
}

.contact-section .container {
  position: relative;
  overflow: visible;
}

.contact-header-blob {
  position: absolute;
  top: 20px;
  left:50%;
  transform:translateX(-50%);
  width: 75vw;
  height: auto;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}



.contact-header-wrap,
.form-feedback,
.customform {
  position: relative;
  z-index: 1;
}

.contact-header-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0;
}

.contact-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .contact-header-row {
    justify-content: center;
    margin: 20px auto 0 auto;
  }

  .contact-svg {
    margin: 0 auto;
  }
}

/* Feedback messages */
.form-feedback {
    width: 90%;
    margin: 0 auto 16px auto;
    padding: 14px 20px;
    border-radius: 8px;
    font-size: 1rem;
    font-family: 'Didact Gothic', Arial, sans-serif;
    font-weight: 600;
}

.form-feedback--success {
    background-color: #d4f9ec;
    color: #0a5c3a;
    border: 1px solid #5BFFD8;
}

.form-feedback--error {
    background-color: #fde8e8;
    color: #8b0000;
    border: 1px solid #f5a5a5;
}

/* Required field highlight */
.customform input:invalid:not(:placeholder-shown),
.customform textarea:invalid:not(:placeholder-shown) {
    border-color: #e53e3e !important;
}

/* Submit button loading state */
.button-form:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.customform {
	background-color:#ffffff;
	border:solid 1px rgba(52, 0, 243, 0.5);
	padding:40px 20px 10px 20px !important;
	border-radius:10px;
	width:100%;
	max-width:100%;
	box-sizing:border-box;
	margin-left:auto;
	margin-right:auto;
  margin-top:30px;
	overflow:hidden;
}
.customform input  {
background-color:#f5f5f5 !important;
border-style:none;
margin-top:0px !important;
}


.name-fields {
    display: flex;
    justify-content: space-between;
    gap: 30px;
}

.input-group {
    width: 48%; /* Adjust this to control spacing */
}

.inputgap {
    margin-top: 5px; /* Space between label and input */
}

/* checkbox styles */


.checkbox-label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top:50px;
}

.checkbox-label input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  width: 26px;
  height: 26px;
  border: 2px solid #25007D;
  border-radius: 6px;
  background-color: #ffffff !important;
  
  position: relative;
  cursor: pointer;
}

.checkbox-label input[type="checkbox"]:checked {
  background-color: #ffffff !important;
  border-color: #25007D;
}

.checkbox-label input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background-color: #63FFDA;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}




/*second column form styles */
.second-column-form {
	width:50%;
	min-width:0;
	box-sizing:border-box;
}


textarea  {
margin-top:0px !important;
background-color:#f5f5f5 !important;
border-style:none;

}

.two-column {
	display:flex;
	justify-content:space-evenly;
	gap:40px;
	box-sizing:border-box;
	width:100%;
}

.labelmessage {
	color:black;
}


.inputgap input {
	margin-bottom: 10px;
	margin-top:10px;
	padding:8px;
	font-size:16px;
	width:100%;
	box-sizing:border-box;
}

.fields {
	width:50%;
	min-width:0;
	box-sizing:border-box;
}

textarea {
	width:100%;
height:265px !important;
	font-size: 16px;
margin-top:10px;
margin-bottom: 2px;
}

.button-form {
	
background-color:#25007D !important;
	color:#ffffff;
	padding:7px 45px !important;
	font-size:16px;
	font-weight:bold;
font-family:Kumbh Sans;
border-radius:5px;
	margin-top:10px;
	border-style:none;
}


.button-form:hover {
padding:7px 45px !important;
border-radius:5px !important;
font-size:16px;
border-style:none;
background-color:#63FFDA !important;
color:#25007D;

} 

/* Force cursor in CF7 to change to pointer */
input[type="submit"],  button[type="submit"] {
    cursor: pointer;
}

.form-privacy-message {
  margin-top:50px;
}

/* Make contact form responsive */

@media (max-width: 1024px) {
  .contact-header-blob {
   top:80px;
    width: 99vw;
  }
}

@media only screen and (max-width: 1024px) {

  .contact-header-blob {
    top: -30px;
    width:50%;
    height: auto;
  }

	.two-column {
		flex-direction: column;
		gap: 0;
		width: 100%;
	}

	.fields {
		width: 100%;
	}

	.second-column-form {
		width: 100%;
		margin-top: 20px;
	}

	.name-fields {
		flex-direction: column;
		width: 100%;
		gap: 0;
	}

	.input-group {
		width: 100%;
		margin-bottom: 10px;
	}

	.inputgap input {
		margin-bottom: 10px;
		font-size: 16px;
		width: 100%;
		box-sizing: border-box;
	}

	textarea {
		font-size: 16px;
		width: 100%;
		box-sizing: border-box;
	}

	.button-form {
		width: 100%;
		box-sizing: border-box;
	}
}

@media only screen and (max-width: 600px) {
  .contact-header-blob {
    top: -30px;
    width: 80vw;
    height: auto;
  }
  
  .two-column {
    flex-direction: column;
    gap: 0;
    width: 100%;
  }

  .fields {
    width: 100%;
  }

  .second-column-form {
    width: 100%;
    margin-top: 20px;
  }

  .name-fields {
    flex-direction: column;
    width: 100%;
    gap: 0;
  }

  .input-group {
    width: 100%;
    margin-bottom: 10px;
  }

  .inputgap input {
    margin-bottom: 10px;
    font-size: 16px;
    width: 100%;
    box-sizing: border-box;
  }

  textarea {
    font-size: 16px;
    width: 100%;
    box-sizing: border-box;
  }

  .button-form {
    width: 100%;
    box-sizing: border-box;
  }
}



/***************************FAQ CODE ***********************/

.faq-section {
  position: relative;
  overflow: visible;
  background-color:#FAFAFA;
}

.faq-header-wrap {
  position: relative;
}

.faq-header-blob {
  position: absolute;
  top: 50px;
  left:-2%;
  
  width: 48vw;
  height: auto;
  z-index: 0;
  pointer-events: none;
  user-select: none;
  opacity: 0.95;
}

@media (max-width: 1024px) {
  .faq-header-blob {
    
    width: 90vw;
  }
}

.faq-header-row,
.faq-title {
  position: relative;
  z-index: 2;
}

.faq-header-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0;
}

.faq-header-row .faq-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

.faq-accordion {
  position: relative;
  z-index: 2;
  margin-top: 24px;
  border: 1px solid #D9D9D9;
  border-radius: 12px;
  overflow: hidden;
  background-color: #ffffff;
}

.faq-item + .faq-item {
  border-top: 1px solid #D9D9D9;
}

.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border: 0;
  background: #ffffff;
  color: #000A89;
  text-align: left;
  cursor: pointer;
  padding: 18px 22px;
  font-family: 'Kumbh Sans', 'Didact Gothic', Arial, sans-serif;
  font-size: 1.08rem;
  font-weight: 600;
}

.faq-question-text {
  color: #000A89;
}

.faq-arrow {
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.faq-item.is-open .faq-arrow {
  transform: rotate(180deg);
}

.faq-answer {
  padding: 0 22px 18px;
  color: #25007D;
  line-height: 1.55;
  font-size: 1rem;
}

.faq-answer[hidden] {
  display: none;
}

@media (max-width: 768px) {
  .faq-header-row {
    justify-content: center;
    margin: 20px auto 0 auto;
  }

 

  .faq-question {
    padding: 16px;
    font-size: 1rem;
  }

  .faq-answer {
    padding: 0 16px 16px;
  }
}



/************************OUR TEAM CODE ***********************/




.faq-wrap{
  position:relative;
}

.faq-blob {
  position:absolute;
  top:10px;
  left:-2%;
  width:401px;
  height:auto;
  z-index:0;
  pointer-events:none;
  user-select:none;
  opacity:0.95;
}

.faq-row,
.faq-wrap > .section-title {
  position: relative;
  z-index: 1;
}

.faq-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0;
}

.faq-row .faq-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .faq-blob {
    left: 50%;
    transform: translateX(-50%);
  }

  .faq-row {
    justify-content: center;
    margin: 20px auto 0 auto;
  }

  .faq-row .faq-svg {
    margin: 0 auto;
  }
}
  



/********************** TEAM CARDS **********************/

.team-cards {
  display: flex;
  flex-direction: row;
  gap: 32px;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 80px;
}

.team-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  height:auto;
  width: auto;
}

.team-card-img-wrap {
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  aspect-ratio: 8 / 9;
}

.team-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-card-info {
  text-align: center;
}

.team-card-name {
  font-family: 'Kumbh Sans', Arial, sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #25007D;
  margin: 0 0 4px;
}

.team-card-role {
  font-family: 'Kumbh Sans', Arial, sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: #0027EB;
  margin: 0;
}

.team-card-socials {
  display: flex;
  flex-direction: row;
  gap: 12px;
  align-items: center;
  justify-content: center;
}

.team-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid #D9D9D9;
  background: #ffffff;
  transition: background 0.2s, border-color 0.2s;
  text-decoration: none;
}

.team-social-link:hover {
  background: #E7DEFE;
  border-color: #25007D;
}

@media (max-width: 768px) {
  .team-cards {
    flex-direction: column;
    align-items: center;
  }

  .team-card {
    width: 100%;
    max-width: 320px;
  }
}


.team-bottom-round {
  background-color: #ffffff;
  border-bottom-left-radius: 50px;
  border-bottom-right-radius: 50px;
  height: 50px;
  margin-bottom: -40px;
  position: relative;
  z-index: 20;
  pointer-events: none;
}


/********************** FOOTER and COPYRIGHT GENERAL **********************/

.footer-container {
	display: grid;
  grid-template-columns: 1fr 0.4fr 0.6fr;
width:100%;
max-width:none;
height:auto;
  margin-top:0;
margin-bottom:0px;
}

.footer-container > section {
  min-width: 0;
}

footer.footer-container {
  max-width: none;
  width:100%;
height:auto;
	
}

.copyright-footer {
	display:grid;
	grid-template-columns: 1fr 1fr 1fr; 
  width:100%;
background-color:#000000;
color:white;
width:100%;
padding-top:15px;
padding-bottom:15px;
	height: 5vh;
}

.copyright-column {
    text-align: center; 
}


.form-container {
    position: relative; 
}

.newsletter-signup-form {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}


.lottie-bird {
display:block;
top:10%;
right:25%;
 transform: translate(-25%, -100%); 
    z-index: 1; 
  position:absolute;
  pointer-events:none;

}

@media (max-width: 1024px) {
  .lottie-bird {
    top: 10%;
    right: 20%;
    transform: translate(50%, -100%);
  }
}



/* FOOTER  NEWSLETTER */
.column-a {
	background-color:#5BFFD8;
	padding:50px 30px 60px 260px;
}

@media (max-width: 1024px) {
  .column-a {
    padding: 50px 30px 60px 30px;
  }
}

.column-a input[type=email] {
	
	width:25vw;
	border-style:none;
	border-radius:4px;
	padding:15px;
	margin:10px 10px 20px 0px;
	font-size:18px;

}

.newsletter-submit-button {
  background-color: #25007D;
  color: #ffffff;
  border: none;
  border-radius: 4px;
  padding: 13px 22px;
  font-size: 18px;
  font-family: 'Didact Gothic', Arial, sans-serif;
  cursor: pointer;
}

.newsletter-submit-button:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.column-a p  {
	color:#0038FF;
	font-size:18px;
	margin-bottom:10px;
}

.newsletter-grid {
	display:grid;
	grid-template-columns: 50% 50%;
	padding-bottom:0px;
margin-bottom:0px;
}

.lottie-player {
	display:flex;
	flex-direction:column;
	justify-content:flex-end;
	padding-left:5vw;
	margin-bottom:-10px;
}





/* FOOTER  INFO */
.column-b {
	background-color: #FFE9B1;
	padding:50px 30px;
	
}

.column-b span{
	color:#25007D;
	font-size:18px;
   
}

.footer-info {
	display:flex;
	margin-bottom:10px;
	align-items: center;
}

.footer-info img {
  padding-right:20px;
}

.footer-info span,
.footer-info a {
  overflow-wrap: anywhere;
}

.footer-info a {
	text-decoration: none;
  color:#25007D;
  
}

.info-container {
	padding-top:0;
  font-style:normal;
}


/* FOOTER  SOCIAL MEDIA */

.column-c {
	background-color:#000A89;
	padding:50px 130px;

}


.footer-icon-buttons {
  margin-top:90px;
}

.social-icons-footer {
	background-color:#FFE9B1;
  border-radius:50%;
  padding:5px;
  margin-right:10px;
	
}

.social-icons-footer:hover{
 background-color:#ffeeee;
}






/* FOOTER  TITLES  */
.footer-titles {
	font-size:52px;
	color:#000A89;
	font-weight:600;
	padding-top:40px;
}

.some-title {
font-size:52px;
	color:#FFE9B1;
		font-weight:600;
padding-top:40px;

}
.newsletter-cta {
	font-size:18px;
}




/* FOOTER RESPONSIVE */

/* 1024 px */

@media screen and (max-width: 1024px) {
	.footer-container {
	display: flex;
  flex-direction: column;
    height:auto;
	}
	
  .column-a input[type=submit] {
		width:20vw;
	}

.column-c {
	
	padding:50px 30px;

}
	
}

/* 820  px */

@media screen and (max-width: 820px) {

	
  .column-a input[type=email] {
		width: 30vw;
	}
	
  .column-a input[type=submit] {
		width:20vw;
	}
	
  .column-b {
	padding:50px 20px;
	}
	
	.footer-info {
		padding-left:10px;
	}

	.footer-info-title {
		padding-left:10px;
	}
	
  .column-c {
	padding:50px 30px;

}


.footer-icon-buttons {
  margin-top:60px;
}
	
}

/* 768 px */

@media screen and (max-width: 768px)

{


	.copyright-footer {
grid-template-columns:100%;
	height: 12vh;
}

	
  .column-a input[type=email] {
		width: 80vw;
	}
	
  .column-a input[type=submit] {
		width:50vw;
	}

  .column-c {
	padding:50px 30px;

}

	.footer-info {
		padding-left:10px;
	}
		.footer-info-title {
		padding-left:10px;
	}

.footer-icon-buttons {
  margin-top:60px;
}
	
}


/****END OF FOOTER  GENERAL *******/