/* ----------------------------------------------------------------------- */
/* ----------------------------------------------------------------------- */
/* ----------------------------------------------------------------------- */
/* ---- Safety Save 260406-1230pm-ai-at-betanxt.css ---- */
/* ----------------------------------------------------------------------- */
/* ----------------------------------------------------------------------- */
/* ----------------------------------------------------------------------- */


/* ============== PAGE LEVEL ================ */

.anchor-link  {
  font-size: 0px;
}

h1  {
  font-size: 128px;
  line-height: 140px;
  letter-spacing: 1px;
}

@media (max-width: 1031px) {
    #hs_cos_wrapper_module_16969754408574 .hhs-rich-text h1 {
    font-size: 98px;
    line-height: 124px;
    letter-spacing: 1px;
    }
}

h2 {
    margin-block-start: 0em;
    margin-block-end: 0em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
}


.special-header  {
  font-size: 96px;
  line-height: 96px;
  color: #1F1E1C;
}

.special-header2  {
  font-size: 96px;
  line-height: 84px;
  color: #1F1E1C;
}

.special-header2-dkmode  {
  font-size: 96px;
  line-height: 84px;
  color: #ffffff;
  padding-bottom: 24px;
}

.gray600 {color: #8a8884;}
.turquoise {color: #51C8EC;}
.gray50 {color: #FAFAFA;}
.gray100  {color: #F5F5F5;}
.paper-gold {color: #FDFBF5;}
.persimmon  {color: #ff7400;}

.spacer-68  {
  height: 68px;
  width: 0px; 
}

.spacer-8  {
  height: 8px;
  width: 0px; 
}

.p2-dkmode {
  font-size: 24px;
  line-height: 36px;
  color: #ffffff;
}


.p2,
.p2 p,
.p2 li  {
  font-size: 24px;
  line-height: 36px;
  color: #1F1E1C;
}

/* ===== tablet (max 1281px) — horizontal layout ===== */
@media (max-width: 1281px) {  
  .p2-dkmode {
    font-size: 18px;
    line-height: 1.55em;
    color: #ffffff;
  }
}
/* ============ MOBILE =============== */

@media (max-width: 736px) {
 
    #hs_cos_wrapper_module_17745475417214 .first-title.headline h2  {
    font-size: 56px !important;
    line-height: 48px !important;
    color: #1F1E1C;
  }
    
    #hs_cos_wrapper_widget_1774878989460 .first-title.headline h2,
    #hs_cos_wrapper_module_17745475575474 .first-title.headline h2  {
    font-size: 56px !important;
    line-height: 48px !important;
    color: #1F1E1C;
  }
  
   #hs_cos_wrapper_module_17745475472894 .first-title.headline h2,
   #hs_cos_wrapper_module_17745495872614 .first-title.headline h2 {
    font-size: 56px !important;
    line-height: 48px !important;
    color: #ffffff;
    padding-bottom: 24px;
  }

}


/* ============== VISION ================ */
.vision-card-top  {
  margin: 0 16px;
  border-radius: 24px 24px 0 0;
  border-top: 1px solid var(--Gray-400, #BDBDBD);
  border-left: 1px solid var(--Gray-400, #BDBDBD);
  border-right: 1px solid var(--Gray-400, #BDBDBD);
  background: var(--Gray-200, #EDEDED);
}

.vision-card-bottom  {
  margin: 0 16px;
  border-radius: 0 0 24px 24px;
  border-left: 1px solid var(--Gray-400, #BDBDBD);
  border-right: 1px solid var(--Gray-400, #BDBDBD);
  border-bottom: 1px solid var(--Gray-400, #BDBDBD);
  background: var(--Gray-200, #EDEDED);
}

.outcome-quote  {
  font-size: 32px;
  line-height: 48px;
  font-weight: 600;
/*   width: 300px;
  display: block;
  margin-right: 0px !important;
  margin-left: 0px !important; */
}

@media (max-width: 670px) {
.outcome-quote  {
  font-size: 24px;
  line-height: 32px;
}
}

@media (max-width: 500px) {
.outcome-quote  {
  font-size: 18px;
  line-height: 24px;
}
}

/* ============ Approach Header ============ */

/* Desktop: heading group + summary side by side */
.approach-wrapper {
  display: flex;
  align-items: center;
  gap: 54px;
}

/* Grid container — overlays circle and h2 in the same cell */
.header-blue-circle {
  display: inline-grid;
  grid-template-columns: max-content;
  grid-template-rows: max-content;
  line-height: 0;
  flex-shrink: 0;
}

/* Light blue circle offset to sit behind the text */
.header-blue-circle::before {
  content: "";
  grid-area: 1 / 1;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: #d8e6e8;
  margin-left: 102px;
  align-self: start;
}

.approach-header-text {
  grid-area: 1 / 1;
  font-weight: 500;
  font-size: 96px;
  line-height: 64px;
  color: #424242;
  white-space: nowrap;
  margin-top: 68px;
  margin-bottom: 0;
}

.approach-summary { flex: 1; }

.approach-summary-text {
  font-family: 'Tungsten';
  font-weight: 300;
  font-size: 45px;
  line-height: 48px;
  color: #212121;
  text-align: left !important;
  margin-bottom: 0;
}

/* Tablet/Mobile: stack vertically, center */
@media (max-width: 992px) {
  .approach-wrapper {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }

  .header-blue-circle::before {
  margin-left: 0;
  justify-self: center;
  width: 100px;
  height: 100px;
  }
  
  .approach-header-text {
  margin-top: 34px;
  font-size: 42px;
  line-height: 32px;
  }
  .approach-summary {
    width: 100%;
  }
  
    /* Reset desktop offset — center circle over the heading text */
  .header-blue-circle::before {
    margin-left: 0;
    justify-self: center;
  }
}

/* ===== Partner Header / Summary ===== */

.partner-wrapper  {
  display: flex;
  gap: 0px;
  padding-top: 24px;
}

.partner-row-icon  {
  flex: 1 0 auto;
}

.partner-row-text p,
.partner-row-text h2 {
  flex: 0 1 auto;
  text-align: left !important;
}


.icon-partner-desktop {
  height: auto; 
  max-width: 100%; 
  width: 175px;
}

.icon-partner-mobile {
  display: none;
}
  

@media (max-width: 1024px) {
  .icon-partner-desktop {
    height: auto; 
    max-width: 100%; 
    width: 150px;
  }

  .partner-row-text h2 {
    font-size: 56px;
    line-height: 56px;
    padding-bottom: 8px;
  }
}

@media (max-width: 600px) {

  .icon-partner-desktop {
    display: none;
  }
  .header-row {
    display: flex; 
    flex-direction: row;
  }
  .header-row-text {
    flex-basis: 50%;
  }
  .header-row-mobileicon {
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    flex-basis: 50%;
  }
  
 .icon-partner-mobile {
    display: flex;
    height: auto; 
    max-width: 100%; 
    width: 200px;
  }
}

/* ============== INSIGHTX ================ */


.sub-text {
  text-align: center !important;
}

.insightx-pull-steps  {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 24px;
}

.turquoise-pull-quote {
  flex: 1 0 50%;
  border-left: 8px solid #51C8EC;
  padding-left: 24px;
}

.turquoise-pull-quote p {
  font-size: 32px;
  line-height: 48px;
  font-weight: 300;
  text-align: left !important;
  color: #ffffff;
}

.steps  {
  flex: 1 1 50%;
}

.subhead-underline-dkmode  {
  font-family: 'Open Sans', sans-serif !important;
  font-weight: 400 !important;
  font-size: 32px;
  line-height: 32px;
  color: #ffffff;
}

.subhead-underline-dkmode:after {
    content: '';
    display: block;
    height: 2px;
    margin-top: 0rem;
    background-color: #51C8EC;
    margin-bottom: 24px;
}

.special-header3-dkmode  {
  font-family: "Tungsten", sans-serif;
  font-size: 56px;
  line-height: 64px;
  color: #ffffff;
  font-style: normal;
  font-weight: 300;
}

.insightx-card-top  {
  margin: 0 16px;
  border-radius: 24px 24px 0 0;
  border-top: 1px solid #ffffff;
  border-left: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
}

.insightx-card-bottom  {
  margin: 0 16px;
  border-radius: 0 0 24px 24px;
  border-left: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
}

.center-cta {
  text-align: center !important;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 1024px) {
.insightx-pull-steps  {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
  
.turquoise-pull-quote {
  flex: 1 0 50%;
  border-left: 0px solid #51C8EC;
  padding-left: 0px;
  max-width: 600px;
}
  
.turquoise-pull-quote p {
  text-align: center !important;
  color: #51C8EC;
}

  .steps  {
  max-width: 450px;
  }
  
  .subhead-underline-dkmode  {
  font-size: 24px;
  line-height: 32px;
}

.special-header3-dkmode  {
  font-size: 48px;
  line-height: 56px;
}
}


@media (max-width: 767px) {
.sub-text {
  text-align: left !important;
}
}

/* ============== Innovation Lab ================ */

/* ============== Initiative Tab ================ */

.initiative-tab-wrapper {
  background: #fafafa;
  width: 100%;
}

.initiative-bar {
  height: 8px;
  background: #ff7400;
}

.initiative-tab {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 44px;
  width: fit-content;
  margin-left: auto;
  border-bottom: 1px solid #ff7400;
  border-left: 1px solid #ff7400;
  border-right: 1px solid #ff7400;
  border-radius: 0 0 4px 4px;
  margin-right: 5%;
}

.initiative-icon {
  width: 42px;
  height: 42px;
}

.initiative-tab span {
  font-family: 'Tungsten';
  font-weight: 500;
  font-size: 36px;
  line-height: 48px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #ff7400;
  white-space: nowrap;
}

/* ============== END Initiative Tab ================ */

.persimmon  {
  color: #FF7400;
}

.persimmon-pull-quote {
  border-left: 8px solid #FF7400;
  padding: 0 0 0 24px;
  margin: 36px 0 32px 56px;
  font-family: 'Open Sans', sans-serif !important;
  font-weight: 700 !important;
  font-size: 32px;
  line-height: 48px;
}

/* ============== Innovation Lab Schedule ================ */

.lab-wrapper  {
  Display: flex;
  align-items: center;
}

.innovation-lab-copy {
  flex: 1;
}
.innovation-lab-copy p {
  font-size: 24px;
  line-height: 36px;
}
/* ===== Card ===== */
.lab-schedule {
/*   display: flex; */
/*   flex: 1; */
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid #ffc799;
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  height: max-content;
  margin: 0 0 0 24px;
/*   width: 100%; */
}

.lab-schedule__bar {
  background: #ff7400;
  height: 16px;
  border-radius: 8px 8px 0 0;
  width: 100%;
/*   flex-shrink: 0; */
}

.lab-schedule__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 16px 16px;
  width: fit-content%;
  box-sizing: border-box;
}

/* ===== Header ===== */
.lab-schedule__header {
  display: flex;
  flex-direction: column;
/*   width: 238px; */
}

.lab-schedule__title {
  font-family: 'Tungsten', sans-serif;
  font-weight: 500;
  font-size: 42px;
  line-height: 48px;
  color: #053f5a;
  margin: 0;
  letter-spacing: 0;
}

.lab-schedule__rule {
  height: 1px;
  background: #053f5a;
  width: 100%;
  margin-top: 2px;
}

/* ===== Steps — vertical on desktop ===== */
.lab-schedule__steps {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.lab-schedule__step {
  font-family: 'Open Sans', sans-serif;
  font-weight: 400;
  font-size: 24px;
  line-height: 36px;
  color: #1f1e1c;
  text-align: center;
}

/* Arrow: rotate 90° to point downward */
.lab-schedule__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 70px;
}

.lab-schedule__arrow svg {
  width: 70px;
  height: auto;
  transform: rotate(90deg);
}


@media (max-width: 991px) {

.lab-title  {
  padding-bottom: 36px;
  }
}
  
  
/* ===== Mobile (max 767px) — horizontal layout ===== */
@media (max-width: 767px) {

  .lab-wrapper  {
    Display: flex;
    flex-direction: column;
    align-items: center;
  }
 
  .ls-demo-grid {
    grid-template-columns: 1fr;
  }

  .lab-schedule__header {
    width: 100%;
  }

  .lab-schedule {
    display: flex;
    flex: 1;
    width: 100%;
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid #ffc799;
    border-radius: 8px;
    flex-direction: column;
    align-items: center;
    height: max-content;
    margin: 0;
    max-width: 550px;
  }
  
  .lab-schedule__wrapper {
    width: 100%;
  }

  
  .lab-schedule__title {
    text-align: center;
    font-size: 42px;
  }

  .lab-schedule__steps {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: 0;           /* remove gap so arrows can fill freely */
    width: 100%;      /* ← this is what was missing */
  }

  .lab-schedule__step {
    font-size: 18px;
    line-height: 28px;
    white-space: nowrap;
    padding
  }

  /* "Proof of Concept" wraps to 2 lines on mobile */
  .lab-schedule__step--poc {
    white-space: normal;
    width: 70px;
    text-align: center;
    line-height: 18px;
  }

.lab-schedule__arrow {
  flex: 1;
  height: auto;
  display: flex;
  align-items: center;
  padding: 0 8px;
}

.lab-schedule__arrow svg {
  display: none;
}

.lab-schedule__arrow::before {
  content: '';
  flex: 1;
  height: 1px;
  background: #739399;
}

.lab-schedule__arrow::after {
  content: '';
  border: 4px solid transparent;
  border-left-color: #739399;
  margin-left: -1px;
}

}

/* ============== Solutions / Focus Area ================ */

.focus-area-dkmode  {
  margin: 0 0 68px 0;
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
  }
  

.focus-area-wrapper {
  display: flex;
  gap: 24px;
  flex-direction: row;
  justify-content: flex-start;
  align-self: stretch;
}  
  
.focus-area-title {
  flex: 0 0 calc(33.333% - 12px);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-self: stretch;
}  
  
.title-content-block {
  padding: 68px 0;
  padding-right: 60px; 
  align-self: stretch;
}

.vertical-white-line  {
  width: 1px;
  background-color: #ffffff;
  border-right: 0px solid #ffffff;
  align-self: stretch;
}

.focus-content-wrapper  {
  flex: 0 0 calc(66.666% - 12px);
  padding: 68px 0 0 0;
  gap: 16px;
}
  
.focus-content-row  {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.noline {
  display: none;
}


/* ===== Mobile (max 1281px) — horizontal layout ===== */
@media (max-width: 1281px) {
    
  .focus-area-title {
    flex: 0 0 40%;
  }  

  .focus-content-wrapper  {
    flex: 0 0 56%;
  }
  .focus-content-row  {
    flex-direction: column;
  }
}

/* ===== Mobile (max 936px) — horizontal layout ===== */
@media (max-width: 936px) {
  .focus-area-wrapper {
    display: flex;
    gap: 24px;
    flex-direction: column;
    justify-content: flex-start;
    align-self: stretch;
  }  

  .vertical-white-line  {
     width: 0px;
     display: none;
   }
  
  .title-content-block {
    padding: 68px 0 0 0;
    align-self: stretch;
  }
  
  .focus-content-wrapper  {
    padding: 0 0 16px 0;
    gap: 16px;
    display: flex;
    flex-direction: column;
  }

}

/* ============== Governance ================ */

.gov-wrapper  {
  display: flex;
  flex-direction: row;
  gap: 24px;
}

.gov-left {
  flex: 1;
}

.gov-right {
  flex: 1;
}

.check-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0px;
}

.check-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-family: 'Open Sans', sans-serif;
  font-size: 24px;
  font-weight: 400;
  line-height: 36px;
  color: #1f1e1c;
}

.check-list li::before {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background-image: url('/hubfs/web/media/icons/icon-check-circle.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}


@media (max-width: 991px) {  
.gov-shield {
  display: none
  }
}
  
@media (max-width: 767px) {
.gov-wrapper  {
  display: flex;
  flex-direction: column;
}

.gov-right {
  flex: 1;
  align-self: center;
  max-width: 450px;
  padding-top: 24px;
}

}


/* ============== Blog Card Component ================ */

.blog {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.blog-row {
  display: flex;
  gap: 24px;
}

.blog-card {
  flex: 1;
}

/* Image container — locks height, clips overflow */
.blog-img {
  display: block;
  height: 220px;
  overflow: hidden;
}

/* !important required — HubSpot applies img { height: auto !important } globally */
.blog-img img {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
  display: block;
}

.blog-body {
  padding-top: 16px;
}

/* h4 inherits Tungsten from child.css — only override size/color/weight */
.blog-body h4 {
  font-size: 28px;
  line-height: 32px;
  font-weight: 600;
  margin-bottom: 8px;
}

.blog-body h4 a {
  color: #2879af;
  text-decoration: none;
}

.blog-body h4 a:hover {
  text-decoration: underline;
}

.blog-author {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px; 
}

.blog-author img {
  width: 30px;
  height: 30px !important;
  border-radius: 50%;
  object-fit: cover;
}

.blog-author a {
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  color: #2879af;
  text-decoration: none;
}

.blog-body .blog-meta {
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #4d4b46;
  margin-bottom: 4px;
}

.blog-body p {
  font-family: 'Open Sans', sans-serif;
  font-size: 18px;
  line-height: 28px;
  color: #1f1e1c;
  margin: 0;
}

/* Tablet — stack to single column, centered at max 694px */
@media (max-width: 1190px) {
  .blog-row {
    flex-direction: column;
    max-width: 694px;
    margin: 0 auto;
  }

  /* Switch from fixed height to aspect ratio so full-width images aren't cropped */
  .blog-img {
    height: auto;
    aspect-ratio: 16 / 9;
  }
}



  /* ============== AI In the News ================ */

.eyebrow  {
  font-family: 'Open Sans', sans-serif;
  font-size: 18px; 
  line-height: 18px;
  font-weight: 400;
  color: #1f1e1c;
  padding-bottom: 16px;
  }
  
.eyebrow-link  {  
  color: #2879af;
  text-transform: uppercase;
  font-weight: 700;
  }
  
.dklink  {
  color: #2879AF !important;  
  background-color: rgba(255, 255, 255, 0) !important;
  }

.dklink:hover  {
  color: #2879AF !important;  
}

h3.blog-title,
.blog-title a {
  font-size: 36px;
  line-height: 1em !important;
  font-weight: 400;
  letter-spacing: 0;
  text-decoration: none;
  text-transform: none;
  color: rgba(5, 63, 90, 1.0);
}
/* ============== FAQ ================ */

.faq-question h3 {
  font-weight: 700 !important;

}

@media (max-width: 992px) {
.faq-section .container  {
  max-width: 100%;
  padding: 0 0 !important;
}
}



/* ============== TOSS LATER ================ */
/* ============== TOSS LATER ================ */
/* ============== TOSS LATER ================ */

/* Demo content block */
.content-block {
  height: 950px;
  padding: 48px 0 64px 0;
  background-color: #efcc86;
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
}