.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

html {
  scroll-behavior: smooth;
}

.top-strip-mobile-hide {
  --utility-start: rgb(22, 72, 132);
  --utility-end: rgb(18, 48, 100);
  background:
    repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.05) 0 10px, transparent 10px 20px),
    linear-gradient(90deg, var(--utility-start) 0%, var(--utility-end) 100%);
}

.dgx-utility-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(4px);
  color: rgba(255, 255, 255, 0.9);
  font-family: Inter, sans-serif;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  line-height: 1;
  padding: 0.25rem 0.75rem;
  text-transform: uppercase;
  transition: border-color 180ms ease, background-color 180ms ease;
}

.dgx-utility-link:hover,
.dgx-utility-link:focus-visible {
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.2);
}

.dgx-nav-summary {
  list-style: none;
}

.dgx-main-menu {
  align-items: center;
  gap: 1rem;
  height: 65px;
  font-family: Inter, sans-serif;
  font-size: 16px;
  font-weight: 600;
  line-height: 24px;
}

.dgx-nav-row {
  height: 65px !important;
}

.dgx-mobile-menu-button {
  align-items: center;
  display: inline-flex;
  justify-content: center;
}

.dgx-mobile-menu-panel {
  max-height: calc(100vh - 4rem);
  overflow-y: auto;
}

.dgx-mobile-nav-details {
  color: #153b63;
}

.dgx-mobile-nav-summary {
  align-items: center;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  list-style: none;
  padding: 0.5rem 0.75rem;
}

.dgx-mobile-nav-summary::-webkit-details-marker {
  display: none;
}

.dgx-mobile-nav-summary svg {
  transition: transform 180ms ease;
}

.dgx-mobile-nav-details[open] .dgx-mobile-nav-summary svg {
  transform: rotate(180deg);
}

.dgx-mobile-nav-submenu {
  border-left: 2px solid #d9e4f0;
  margin: 0.15rem 0 0.5rem 0.75rem;
  padding: 0.25rem 0 0.4rem;
}

.dgx-mobile-nav-group-title {
  color: #55708c;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.55rem 0.85rem 0.25rem;
  text-transform: uppercase;
}

.dgx-mobile-nav-link {
  color: #355575;
  display: block;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.9rem;
  line-height: 1.35rem;
  padding: 0.38rem 0.85rem;
}

.dgx-mobile-nav-link:hover,
.dgx-mobile-nav-link:focus-visible {
  background: #f6f9fc;
  color: #153b63;
  outline: none;
}

.dgx-mobile-nav-link--all {
  border-top: 1px solid #e5e7eb;
  font-weight: 700;
  margin-top: 0.35rem;
  padding-top: 0.55rem;
}

@media (min-width: 1024px) {
  .dgx-mobile-menu-button,
  .dgx-mobile-menu-panel {
    display: none !important;
  }
}

@media (min-width: 1200px) {
  .dgx-main-menu {
    gap: 1.55rem;
  }
}

.dgx-main-menu > a {
  align-items: center;
  display: flex;
  height: 2.5rem;
  align-self: center;
}

.dgx-main-menu > a:not(.dgx-nav-cta),
.dgx-main-menu > details > .dgx-nav-summary {
  position: relative;
}

.dgx-main-menu > a:not(.dgx-nav-cta)::after,
.dgx-main-menu > details > .dgx-nav-summary::after {
  background: #4a7ab8;
  bottom: 0.15rem;
  content: "";
  height: 3px;
  left: 0;
  position: absolute;
  transition: width 150ms ease-out;
  width: 0;
}

.dgx-main-menu > a:not(.dgx-nav-cta):hover::after,
.dgx-main-menu > a:not(.dgx-nav-cta):focus-visible::after,
.dgx-main-menu > details:hover > .dgx-nav-summary::after,
.dgx-main-menu > details:focus-within > .dgx-nav-summary::after,
.dgx-main-menu > details[open] > .dgx-nav-summary::after {
  width: 100%;
}

.service-detail-page .expertise-feature-card-title {
  line-height: 1.12;
  margin-bottom: 1rem;
}

.service-detail-page .expertise-feature-card-copy,
.service-detail-page .expertise-card-note-copy {
  text-align: left !important;
  text-justify: auto !important;
  text-align-last: left !important;
}

@media (min-width: 768px) {
  .service-detail-page .expertise-feature-card-title {
    min-height: 3.35rem;
  }

  .service-detail-page .expertise-feature-card-copy {
    min-height: 5.75rem;
    max-width: 14rem;
  }

  .service-detail-page .expertise-card-note-copy {
    min-height: 4rem;
    max-width: 13rem;
  }
}

.dgx-main-menu > details {
  align-items: center;
  display: flex;
  height: 100%;
}

.dgx-main-menu > details {
  padding-bottom: 0;
  padding-top: 0;
}

.dgx-main-menu > details > .dgx-nav-summary {
  align-items: center;
  display: inline-flex;
  height: 2.5rem;
}

.dgx-main-menu > .dgx-nav-cta {
  padding-bottom: 0;
  padding-top: 0;
}

.dgx-nav-cta {
  background: transparent !important;
  border-color: #143361 !important;
  border-radius: 999px;
  height: 2.5rem;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.dgx-nav-cta:hover,
.dgx-nav-cta:focus-visible {
  background: transparent !important;
  border-color: #38bdf8 !important;
  color: #143361 !important;
}

.hero-guide-button:hover,
.hero-guide-button:focus-visible {
  border-color: #38bdf8 !important;
  background: transparent !important;
}

.ebook-modal-backdrop[hidden],
.ebook-confirmation[hidden],
.ebook-modal-form[hidden] {
  display: none !important;
}

body.ebook-modal-open {
  overflow: hidden;
}

.ebook-modal-status {
  color: #153b63;
  font-family: Inter, sans-serif;
  font-size: 0.86rem;
  line-height: 1.45;
  margin-top: 0.85rem;
  min-height: 1.25rem;
}

.ebook-modal-status.is-error {
  color: #9f2f2f;
}

.ebook-modal-close {
  z-index: 4;
  cursor: pointer;
  pointer-events: auto;
  touch-action: manipulation;
}

.ebook-honeypot {
  height: 1px;
  left: -10000px;
  overflow: hidden;
  position: absolute;
  top: auto;
  width: 1px;
}

.dgx-nav-summary::-webkit-details-marker {
  display: none;
}

.dgx-nav-summary {
  border-bottom: 0;
  padding-bottom: 0;
  position: relative;
}

details[open] > .dgx-nav-summary {
  color: #153b63;
}

details[open] > .dgx-nav-summary svg {
  transform: rotate(180deg);
}

.dgx-nav-dropdown {
  animation: dgx-dropdown-in 180ms ease-out;
  border-color: #e5e7eb;
  border-radius: 0.5rem;
  overflow: hidden;
  text-align: left;
}

.dgx-nav-dropdown--industries {
  width: 20rem !important;
}

.dgx-nav-dropdown--industries .dgx-nav-dropdown-link {
  white-space: nowrap;
}

@keyframes dgx-dropdown-in {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.dgx-nav-group-title {
  background: rgba(229, 231, 235, 0.55);
  color: #355575;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1rem;
  padding: 0.25rem 1rem;
  text-transform: uppercase;
}

.dgx-nav-group-title:not(:first-child) {
  margin-top: 0.75rem;
}

.dgx-nav-dropdown-link {
  display: block;
  color: #355575;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.96875rem;
  font-weight: 500;
  line-height: 1.5rem;
  padding: 0.5rem 1rem;
  transition: background-color 0.18s ease, color 0.18s ease;
}

.dgx-nav-dropdown-link:hover,
.dgx-nav-dropdown-link:focus-visible {
  background: #f6f9fc;
  color: #153b63;
  outline: none;
}

.dgx-nav-dropdown-all {
  border-top: 1px solid #e5e7eb;
  font-weight: 700;
  margin-top: 0.25rem;
  padding-bottom: 0.5rem;
  padding-top: 0.5rem;
}

#contact,
#contact-form,
#contact-form-title,
#careers-form {
  scroll-margin-top: 108px;
}

@media (max-width: 1023px) {
  #contact,
  #contact-form,
  #contact-form-title,
  #careers-form {
    scroll-margin-top: 100px;
  }
}

.dgx-footer-grid > div {
  display: flex;
  flex-direction: column;
}

.dgx-footer-logo {
  filter: brightness(0) invert(1);
  object-fit: contain;
}

@media (min-width: 768px) {
  .dgx-footer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dgx-footer-brand {
    grid-column: 1 / -1;
  }
}

@media (min-width: 1024px) {
  .dgx-footer-grid {
    grid-template-columns: minmax(260px, 1.15fr) minmax(160px, 0.55fr) minmax(180px, 0.7fr) minmax(210px, 0.9fr);
    align-items: start;
  }

  .dgx-footer-brand {
    grid-column: auto;
  }

  .dgx-footer-services a,
  .dgx-footer-services li,
  .dgx-footer-industries a,
  .dgx-footer-industries li {
    white-space: nowrap;
  }
}

.title-underline {
  position: relative;
}

.title-underline::after {
  content: "";
  display: block;
  width: 120px;
  height: 4px;
  border-radius: 999px;
  background: #007ebb;
  margin-top: 14px;
}

.index-list-page .index-list-hero {
  padding-top: 2.75rem !important;
  padding-bottom: 2.75rem !important;
}

.index-list-page .index-list-title {
  display: inline-block !important;
  width: fit-content;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 0 0.06em 0.08em !important;
  border-radius: 4px;
  background-image: linear-gradient(transparent 66%, #eaf3ff 66%) !important;
  background-position: left top !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  font-size: clamp(1.75rem, 2.45vw, 2.18rem) !important;
  line-height: 1.14 !important;
}

.index-list-page .index-list-title::after {
  content: none !important;
}

.index-list-page .index-list-lead {
  font-size: clamp(1rem, 1.4vw, 1.12rem) !important;
  line-height: 1.68 !important;
}

.index-list-page .index-card-section {
  padding-top: 3.25rem !important;
  padding-bottom: 4rem !important;
}

.index-list-page .index-card-grid > a {
  height: 100%;
}

.index-list-page .index-card {
  display: grid !important;
  grid-template-rows: 3.25rem 0.125rem minmax(7.2rem, 1fr) auto;
  align-items: start;
  min-height: 15.5rem;
  gap: 1rem;
  padding: 1.35rem !important;
}

.index-list-page .index-card-title {
  display: block !important;
  min-height: 0 !important;
  margin: 0 !important;
  font-family: Inter, Montserrat, sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(1.08rem, 1.28vw, 1.28rem) !important;
  line-height: 1.16 !important;
  letter-spacing: -0.01em;
}

.index-list-page .index-card-copy {
  margin: 0 !important;
  color: #153b63 !important;
  font-size: 0.92rem !important;
  line-height: 1.58 !important;
}

.index-list-page .services-list-card-rule {
  width: 3rem;
  margin: 0;
}

.index-list-page .services-list-card-action {
  margin-top: 0;
  padding-top: 0.25rem !important;
}

@media (min-width: 1024px) {
  .index-list-page .index-card-grid {
    gap: 1.25rem !important;
  }

  .index-list-page .index-card {
    min-height: 17.5rem;
  }
}

@media (max-width: 767px) {
  .index-list-page .index-list-hero {
    padding-top: 2.25rem !important;
    padding-bottom: 2.25rem !important;
  }

  .index-list-page .index-card-section {
    padding-top: 2.5rem !important;
    padding-bottom: 3rem !important;
  }

  .index-list-page .index-card {
    display: flex !important;
    flex-direction: column;
    min-height: 0;
  }
}

.service-packages-hero h1.title-underline {
  display: inline-block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  background-image: linear-gradient(transparent 66%, #eaf3ff 66%) !important;
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  box-shadow: none;
  color: #153b63;
  font-family: "Playfair Display", "Merriweather", Georgia, serif !important;
  font-size: clamp(1.8rem, 2.85vw, 2.45rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  line-height: 1.12 !important;
  padding: 0 0.06em 0.08em !important;
  border-radius: 4px;
}

.service-packages-hero h1.title-underline::after {
  content: none;
}

.mission-hero .mission-page-title {
  display: block;
  width: fit-content;
  margin: 0 auto 1.45rem;
  padding: 0 0.06em 0.08em;
  background-image: linear-gradient(transparent 68%, #eaf3ff 68%);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border-radius: 4px;
  font-family: Canela, "Playfair Display", serif !important;
  font-size: clamp(2rem, 3.7vw, 2.7rem) !important;
  font-weight: 700;
  line-height: 1.2;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.mission-hero .mission-page-title::after {
  content: none !important;
}

.mission-card-points {
  margin-top: 1rem;
}

@media (min-width: 768px) {
  .mission-pillar-card {
    min-height: 35rem;
  }

  .mission-card-lead {
    min-height: 11rem !important;
  }

  .mission-card-points {
    margin-top: 1.4rem;
  }
}

body:has(.service-packages-page) .top-strip-mobile-hide {
  position: fixed !important;
  top: 0 !important;
  z-index: 50 !important;
}

body:has(.service-packages-page) .main-nav-mobile-top {
  position: fixed !important;
  top: 36px !important;
  z-index: 50 !important;
}

body:has(.service-packages-page) #footer {
  margin-top: 0 !important;
}

.home-hero-title > span {
  display: block;
  font-weight: 560 !important;
}

.home-hero-title {
  font-family: "Instrument Sans", Arial, sans-serif !important;
  font-weight: 560 !important;
  letter-spacing: -0.03em;
  max-width: 100%;
}

.home-hero-title-desktop {
  font-size: clamp(1.82rem, 2.45vw, 2.03rem) !important;
  line-height: 1.1 !important;
}

.home-hero-title-mobile {
  font-size: clamp(1.42rem, 6.35vw, 1.68rem) !important;
  line-height: 1.1 !important;
}

.home-hero-title-mobile > span + span {
  margin-top: 0.38em;
}

.home-hero-title-desktop > span {
  white-space: nowrap !important;
}

.home-hero-copy {
  font-family: "Instrument Sans", Arial, sans-serif !important;
  font-weight: 500;
  letter-spacing: -0.01em;
}

.home-hero-title-mobile > span {
  white-space: nowrap !important;
}

.home-hero-title .hero-animated-slot,
.home-hero-title .hero-animated-word,
.home-hero-title .hero-animated-char {
  font-family: "Instrument Sans", Arial, sans-serif !important;
  font-weight: 700 !important;
}

.home-hero-title .hero-animated-slot {
  display: inline-block;
  isolation: isolate;
  position: relative;
  vertical-align: baseline;
  white-space: nowrap;
}

.home-hero-title .hero-animated-width-reference {
  display: inline-block;
  visibility: hidden;
  white-space: nowrap;
}

.home-hero-title .hero-animated-current {
  display: inline-block;
  overflow: hidden;
  left: 0;
  position: absolute;
  top: 0;
  will-change: width;
  white-space: nowrap;
  width: 0;
}

.home-hero-title .hero-animated-word {
  display: inline-block;
  position: relative;
  white-space: nowrap;
  z-index: 2;
}

.home-hero-title .hero-animated-char {
  position: relative;
  z-index: 2;
}

.home-hero-title .hero-highlight-line {
  position: absolute;
  left: 0;
  bottom: 0.07em;
  z-index: 1;
  width: 100%;
  height: 0.24em;
  border-radius: 2px;
  background: rgba(212, 175, 55, 0.58);
  pointer-events: none;
  transform: scaleX(1);
  transform-origin: left center;
  will-change: transform;
}

.home-hero-title-desktop .italic,
.home-hero-cfo-emphasis {
  font-style: normal !important;
  font-weight: 580 !important;
}

@media (max-width: 360px) {
  .home-hero-title-mobile {
    font-size: 1.38rem !important;
    line-height: 1.12 !important;
  }
}

@media (max-width: 335px) {
  .home-hero-title-mobile {
    font-size: 1.29rem !important;
  }
}

.contact-success-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 1.25rem;
  background: rgba(3, 22, 46, 0.42);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  animation: contact-success-backdrop-in 0.24s ease both;
}

.contact-success-backdrop[hidden] {
  display: none;
}

body.contact-success-open {
  overflow: hidden;
}

.contact-success-card {
  position: relative;
  display: flex;
  width: min(100%, 31rem);
  min-height: 24rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px solid #d8e4f2;
  border-bottom: 4px solid #002d72;
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 12px 28px rgba(21, 59, 99, 0.12);
  padding: 3rem;
  text-align: center;
  animation: contact-success-in 0.5s ease both;
}

.contact-success-close {
  position: absolute;
  top: 0.85rem;
  right: 0.95rem;
  display: grid;
  width: 2.25rem;
  height: 2.25rem;
  place-items: center;
  border: 0;
  border-radius: 9999px;
  background: transparent;
  color: #153b63;
  font-family: Inter, sans-serif;
  font-size: 1.65rem;
  line-height: 1;
  cursor: pointer;
}

.contact-success-close:hover,
.contact-success-close:focus-visible {
  background: #eef5fc;
  outline: none;
}

.contact-success-icon {
  display: flex;
  width: 5rem;
  height: 5rem;
  align-items: center;
  justify-content: center;
  margin-bottom: 2rem;
  border-radius: 9999px;
  background: #fffbea;
}

.contact-success-icon img {
  width: 2.5rem;
  height: 2.5rem;
  filter: invert(68%) sepia(62%) saturate(604%) hue-rotate(5deg) brightness(91%) contrast(86%);
}

.contact-success-card h3 {
  margin: 0 0 1.5rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.2;
}

.contact-success-card p {
  max-width: 24rem;
  margin: 0;
  color: #355b7d;
  font-family: Inter, sans-serif;
  font-size: 1.05rem;
  line-height: 1.65;
}

@keyframes contact-success-in {
  from {
    opacity: 0;
    transform: scale(0.97);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes contact-success-backdrop-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

.home-services-section {
  padding-top: 3.5rem !important;
  padding-bottom: 4rem !important;
}

.home-services-section > .max-w-7xl {
  margin-top: 2rem;
}

@media (min-width: 768px) {
  .home-services-section {
    padding-top: 4rem !important;
    padding-bottom: 4.5rem !important;
  }
}

@media (min-width: 1024px) {
  .home-services-section {
    padding-top: 4.5rem !important;
    padding-bottom: 4.75rem !important;
  }
}

.home-hero-section {
  background-image: url("/images/hero-network-background-1200.png?v=1");
  background-image: -webkit-image-set(url("/images/hero-network-background-1200.png?v=1") 1x, url("/images/hero-network-background.png?v=2") 2x);
  background-image: image-set(url("/images/hero-network-background-1200.png?v=1") 1x, url("/images/hero-network-background.png?v=2") 2x);
  background-size: 90% auto;
  background-position: left -34% top 46%;
}

.home-hero-overlay {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.64) 0%, rgba(255, 255, 255, 0.83) 46%, rgba(255, 255, 255, 0.96) 100%);
  pointer-events: none;
}

@media (min-width: 1024px) {
  .home-hero-overlay {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.08) 78%, #fff 100%),
      linear-gradient(90deg, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.74) 38%, rgba(255, 255, 255, 0.3) 58%, rgba(255, 255, 255, 0.16)) !important;
  }

  .home-hero-split-panel {
    display: none !important;
  }

  .home-hero-section > .relative > .grid {
    align-items: stretch;
  }

  .home-hero-section > .relative {
    padding-bottom: 4.75rem !important;
  }

  .home-hero-section > .relative > .grid > div:first-child {
    justify-content: flex-end;
  }

  .home-hero-dashboard-column {
    align-items: flex-start;
  }

  .home-hero-dashboard-stage {
    display: flex;
    align-items: flex-start;
  }

  .home-hero-dashboard-surface {
    width: 100%;
    padding: 8px;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.25);
    box-shadow: 0 32px 70px rgba(20, 51, 97, 0.16);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  .home-hero-dashboard-surface > div:first-child {
    overflow: hidden;
    border: 1px solid #d8e4f2;
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 20px 45px rgba(20, 51, 97, 0.12);
  }
}

.service-package-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-top: 4px solid var(--service-line);
  border-bottom: 4px solid var(--service-line);
  transition: background-color 0.3s ease-out, border-color 0.3s ease-out, box-shadow 0.3s ease-out;
}

.expertise-metric-icon img {
  display: block;
  height: 3rem;
  width: 3rem;
}

.service-package-card:hover {
  border-top-color: var(--service-line-strong);
  border-bottom-color: var(--service-line-strong);
  background-color: #fff !important;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.1);
}

.service-package-card .service-package-eyebrow,
.service-package-card .service-package-title,
.service-package-card .service-package-rule,
.service-package-card .service-package-included-label,
.service-package-card .service-package-card-description,
.service-package-card .service-package-best-for,
.service-package-card .service-package-support-label,
.service-package-card .service-package-list,
.service-package-card .service-package-outcome,
.service-package-card .service-package-card-button {
  transition: transform 0.22s ease, color 0.22s ease, background-color 0.22s ease;
  will-change: transform;
}

.service-package-card:hover .service-package-eyebrow,
.service-package-card:hover .service-package-title,
.service-package-card:hover .service-package-rule,
.service-package-card:hover .service-package-included-label,
.service-package-card:hover .service-package-card-description,
.service-package-card:hover .service-package-best-for,
.service-package-card:hover .service-package-support-label,
.service-package-card:hover .service-package-list,
.service-package-card:hover .service-package-outcome,
.service-package-card:hover .service-package-card-button {
  transform: translateY(-2px);
}

.service-package-card--short-term {
  --service-line: #2f6ea5;
  --service-line-strong: #225985;
  --service-title-line: #d4af37;
  --service-title-line-strong: #b79322;
}

.service-package-card--retainer {
  --service-line: rgba(212, 175, 55, 0.58);
  --service-line-strong: rgba(183, 147, 34, 0.76);
  --service-title-line: #2f6ea5;
  --service-title-line-strong: #225985;
}

.service-package-title {
  margin-bottom: 1rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif !important;
  font-size: clamp(1.65rem, 2.05vw, 2.05rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0;
  line-height: 1.16;
}

.service-package-card.sg-card .service-package-title {
  font-family: "Playfair Display", Georgia, serif !important;
}

.service-package-rule {
  margin-bottom: 1.15rem;
  background-color: var(--service-title-line);
}

.service-package-card:hover .service-package-rule {
  background-color: var(--service-title-line-strong);
}

.service-package-title-text {
  display: inline;
  padding: 0 0.06em 0.08em;
  background-image: linear-gradient(transparent 66%, color-mix(in srgb, var(--service-title-line) 22%, white) 66%);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border-radius: 4px;
  box-shadow: none;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.service-package-card--short-term .service-package-title-text {
  background-image: linear-gradient(transparent 66%, color-mix(in srgb, var(--service-title-line) 22%, white) 66%);
}

.service-package-card--retainer .service-package-title-text {
  background-image: linear-gradient(transparent 58%, color-mix(in srgb, var(--service-title-line) 38%, white) 58%);
}

.service-package-title::after {
  content: none;
}

.service-packages-page h2,
.service-packages-cta h2 {
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif !important;
}

.service-package-eyebrow {
  margin-bottom: 0.75rem;
  color: #7b90bd;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-package-included-label {
  margin: 0.85rem 0 0.7rem;
  color: #2f6ea5;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.service-package-card-description,
.service-package-best-for,
.service-package-outcome,
.service-package-list li {
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: clamp(16px, 1.1vw, 17px);
  line-height: 1.6;
}

.service-package-list {
  display: grid;
  gap: 0.55rem;
  margin: 0 0 1.25rem;
  padding: 0;
  list-style: none;
}

.service-package-list li {
  position: relative;
  padding-left: 1.05rem;
  color: #153b63;
}

.service-package-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: var(--service-line);
}

.service-packages-section-intro {
  max-width: 52rem;
  margin: 0 auto 2.5rem;
  text-align: center;
}

.service-packages-offer-highlight {
  display: inline;
  margin: 0;
  color: #153b63;
  font-weight: 700;
  background: rgba(212, 175, 55, 0.28);
  border-radius: 2px;
  padding: 0.05em 0.22em 0.08em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.service-packages-section-eyebrow {
  margin: 0 0 0.65rem;
  color: #6f83aa;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.service-packages-section-intro h2 {
  margin: 0 0 0.85rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif !important;
  font-size: clamp(1.8rem, 2.5vw, 2.25rem);
  font-weight: 700;
  line-height: 1.2;
}

.service-packages-section-intro > p:last-child {
  margin: 0;
  color: rgba(21, 59, 99, 0.82);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.service-package-card--retainer .service-package-support-label {
  font-size: 0.68rem;
}

.service-package-card--retainer .service-package-list {
  gap: 0.28rem;
  align-content: start;
  grid-auto-rows: max-content;
}

.service-package-card--retainer .service-package-list li {
  font-size: 0.92rem;
  line-height: 1.42;
}

.service-package-card--retainer .service-package-list li::before {
  background: rgba(212, 175, 55, 0.58);
}

.service-package-outcome {
  margin-top: auto;
  margin-bottom: 1.1rem;
  border-top: 1px solid #e5edf6;
  padding-top: 1rem;
  color: #153b63;
}

.service-package-card-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  border-radius: 999px;
  border: 1px solid #75b7ff;
  background: #fff;
  color: #153b63 !important;
  padding: 0.8rem 1.25rem;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  text-align: center;
  text-transform: none;
  box-shadow: none;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.service-package-card--short-term .service-package-card-button {
  gap: 0.85rem;
  border-color: #72b8ff;
  background-image:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0 2px, transparent 2px 9px),
    linear-gradient(135deg, #0d6190 0%, #174a7c 100%);
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(21, 59, 99, 0.18);
}

.service-package-card--short-term .service-package-card-button::after,
.service-package-card--retainer .service-package-card-button::after {
  content: "\2192";
  font-size: 1.05rem;
  line-height: 1;
}

.service-package-card--retainer .service-package-card-button {
  gap: 0.85rem;
  border-color: var(--service-line-strong);
  background-image:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 2px, transparent 2px 9px),
    linear-gradient(135deg, var(--retainer-button-start, #d4af37) 0%, var(--retainer-button-end, #b79322) 100%);
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(183, 147, 34, 0.2);
}

.service-package-card--retainer .service-package-card-button:hover,
.service-package-card--retainer .service-package-card-button:focus-visible {
  border-color: var(--retainer-button-end, #a9841c);
  background-image:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0 2px, transparent 2px 9px),
    linear-gradient(135deg, var(--retainer-button-start, #c8a12b) 0%, var(--retainer-button-end, #a9841c) 100%);
  color: #fff !important;
}

.service-package-card-button:hover {
  border-color: #8fa8ff;
  background-color: #f5f9ff;
  transform: translateY(-1px);
}

.service-package-card--short-term .service-package-card-button:hover {
  background-image:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 2px, transparent 2px 9px),
    linear-gradient(135deg, #0b5b88 0%, #123f70 100%);
}

.service-package-outcome + .service-package-card-button {
  margin-top: 0;
}

.service-packages-ongoing {
  margin-top: 4rem;
  padding-bottom: 3.5rem !important;
}

.service-package-add-on-card {
  max-width: 56rem;
  margin: 2.25rem auto 0;
  padding: 1.35rem 1.6rem;
  border: 1px solid rgba(212, 175, 55, 0.42);
  border-top: 4px solid rgba(212, 175, 55, 0.58);
  border-bottom: 4px solid rgba(212, 175, 55, 0.58);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(21, 59, 99, 0.07);
}

.service-package-add-on-card p {
  margin: 0;
  color: rgba(21, 59, 99, 0.82);
  font-size: 0.96rem;
  line-height: 1.65;
}

.service-packages-pricing {
  padding-top: 4.5rem !important;
  padding-bottom: 7rem !important;
  border-top: 1px solid #d7dde7;
  background-color: #fff !important;
  background-image: none !important;
}

.service-packages-pricing .service-packages-cta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  margin-top: 0;
  border-radius: 8px;
  box-shadow: 0 18px 40px rgba(21, 59, 99, 0.16);
}

.service-packages-pricing .pricing-shell {
  display: grid;
  gap: 2rem;
  align-items: stretch;
}

.service-packages-pricing .pricing-copy {
  border: 1px solid #d7dde7;
  border-left: 4px solid #d4af37;
  border-radius: 8px;
  background: #fff;
  padding: 2rem;
  backdrop-filter: none;
}

.service-packages-pricing .pricing-eyebrow {
  margin-bottom: 0.8rem;
  color: #2f6ea5;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.service-packages-pricing .pricing-note-list {
  display: grid;
  gap: 0.8rem;
  margin-top: 1.3rem;
  color: #153b63;
}

.service-packages-pricing .pricing-note-list li {
  position: relative;
  padding-left: 1.05rem;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.55;
}

.service-packages-pricing .pricing-note-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: #d4af37;
}

@media (min-width: 1024px) {
  .service-package-title {
    min-height: 0;
  }

  .service-packages-pricing .pricing-shell {
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.82fr);
  }

  .service-package-card .service-package-card-description {
    min-height: 7.2rem;
  }

  .service-package-card--retainer .service-package-card-description {
    min-height: 6.4rem;
  }

  .service-package-card--short-term .service-package-list {
    min-height: 12.4rem;
  }

  .service-package-card .service-package-outcome {
    min-height: 8.8rem;
  }

  .service-package-card--retainer .service-package-best-for {
    min-height: 7.2rem;
  }

  .service-package-card--retainer .service-package-support-label {
    min-height: 1rem;
  }

  .service-package-card--retainer .service-package-list {
    min-height: 11.2rem;
    margin-bottom: 0;
  }

  .service-package-card--retainer {
    min-height: 49rem;
  }
}

.article-content p {
  max-width: 72ch;
}

.article-content h2 {
  line-height: 1.2;
}

/* Live-site editorial blog layout. */
.blog-page {
  color: #153b63;
  padding: 108px 32px 40px;
}

.blog-list {
  width: 100%;
  max-width: clamp(880px, 80vw, 1080px);
  margin: 0 auto;
  padding: 0 32px;
}

.blog-header {
  margin-bottom: 3rem;
}

.blog-header h1 {
  margin: 0 0 10px;
  color: #153b63;
  font-family: Merriweather, Georgia, serif;
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  line-height: 1.2;
}

.blog-header-rule {
  height: 1px;
  margin: 0 0 18px;
  border: 0;
  background: rgba(21, 59, 99, 0.35);
}

.blog-item {
  padding: 18px 0;
  border-radius: 8px;
}

.blog-item + .blog-item {
  border-top: 1px solid rgba(21, 59, 99, 0.25);
}

.blog-item-link {
  display: flex;
  align-items: flex-start;
  border-radius: 8px;
  color: inherit;
}

.blog-item-link:focus-visible {
  outline: 2px solid rgba(74, 122, 184, 0.7);
  outline-offset: 4px;
}

.blog-lead-icon {
  position: relative;
  flex: 0 0 52px;
  width: 52px;
  height: 52px;
  margin-right: 12px;
  color: #153b63;
}

.blog-lead-icon::after {
  content: "";
  position: absolute;
  top: -6px;
  right: -6px;
  width: 10px;
  height: 10px;
  background: currentColor;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
  opacity: 0.18;
}

.blog-lead-icon img {
  display: block;
  width: 100%;
  height: 100%;
}

.blog-item-copy {
  min-width: 0;
  flex: 1 1 auto;
}

.blog-item-title {
  margin: 0 0 6px;
  color: #153b63;
  font-family: Merriweather, Georgia, serif;
  font-size: 27px;
  font-weight: 700;
  line-height: 1.2;
  transition: color 180ms ease;
}

.blog-item-link:hover .blog-item-title {
  color: #0f2f5b;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.blog-item-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 8px;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.4;
}

.blog-item-meta img {
  width: 16px;
  height: 16px;
}

.blog-item-excerpt {
  display: -webkit-box;
  max-width: 70ch;
  margin: 0;
  overflow: hidden;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 18px;
  font-style: normal;
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.editorial-article {
  padding: 112px 0 64px;
  color: #153b63;
}

.editorial-article .article-shell {
  width: 100%;
  max-width: clamp(920px, 84vw, 1120px);
  margin-inline: auto;
  padding-inline: 32px;
}

.editorial-article .article-content {
  width: 100%;
  max-width: 47.75rem;
  margin-inline: auto;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
}

.article-back-wrap {
  margin-bottom: 2rem;
}

.article-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
}

.article-page.editorial-article .article-back-link {
  font-weight: 400 !important;
}

.article-back-link:hover,
.editorial-article .article-content a:hover {
  color: #0f2f5b;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.editorial-article .article-title {
  display: inline;
  max-width: 100%;
  margin: 0 0 1.15rem !important;
  padding: 0 0.06em 0.08em !important;
  border-radius: 4px;
  background-image: linear-gradient(transparent 66%, #eaf3ff 66%) !important;
  background-position: left top !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  color: #153b63;
  font-family: Canela, "Playfair Display", serif !important;
  font-size: clamp(1.7rem, 2.35vw, 2.15rem) !important;
  font-weight: 700 !important;
  line-height: 1.12 !important;
  white-space: normal !important;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.editorial-article .article-title::after {
  content: none !important;
}

.editorial-article .article-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0.25rem 0 1.65rem !important;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.4;
}

.editorial-article .article-meta img {
  width: 16px;
  height: 16px;
}

.article-divider {
  height: 1px;
  margin: 0 0 1rem;
  border: 0;
  background: rgba(21, 59, 99, 0.35);
}

.article-page.editorial-article .article-content p,
.article-page.editorial-article .article-content .blog-body {
  max-width: none;
  margin: 0;
  color: #333;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px !important;
  font-weight: 400;
  line-height: 1.5 !important;
}

.editorial-article .article-intro {
  margin-bottom: 1.5rem;
  color: #153b63;
}

.editorial-article .article-section h2,
.article-page.editorial-article .article-content h2.section {
  display: inline-block;
  margin: 2.1rem 0 1.05rem !important;
  padding: 0 !important;
  color: #153b63;
  font-family: "Playfair Display", "Times New Roman", serif !important;
  font-size: 26px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
}

.article-page.editorial-article .article-content .article-paragraph {
  margin-bottom: 0 !important;
}

.article-page.editorial-article .article-content > .space-y-3 > :not([hidden]) ~ :not([hidden]) {
  margin-top: 0.75rem;
}

.article-page.editorial-article .article-content > .space-y-4 > :not([hidden]) ~ :not([hidden]) {
  margin-top: 1rem;
}

.article-page.editorial-article .article-content blockquote.article-quote,
.article-page.editorial-article .article-content > blockquote {
  display: block;
  width: 100% !important;
  max-width: none !important;
  margin: 1.5rem 0 2rem !important;
  border: 0 !important;
  border-left: 3px solid #cbd5e1 !important;
  background: transparent !important;
  padding: 0.05rem 0 0.05rem 0.875rem !important;
  color: #002d72 !important;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif !important;
  font-size: 17px !important;
  font-style: normal !important;
  font-weight: 500 !important;
  line-height: 1.55 !important;
  text-align: left !important;
  text-justify: auto !important;
  hyphens: none !important;
}

.article-page.editorial-article .article-content blockquote.article-quote::before,
.article-page.editorial-article .article-content blockquote.article-quote::after,
.article-page.editorial-article .article-content > blockquote::before,
.article-page.editorial-article .article-content > blockquote::after {
  content: none !important;
}

.article-page.editorial-article .article-content blockquote.article-quote--editorial {
  margin: 1.75rem 0 2.1rem !important;
  border-left-color: #d4af37 !important;
  padding: 0.08rem 0 0.08rem 1rem !important;
  font-style: italic !important;
  font-weight: 500 !important;
  line-height: 1.55 !important;
}

.article-page.editorial-article .article-list {
  display: block;
  margin: 0.95rem 0 1.35rem !important;
  padding: 0;
  list-style: none;
}

.article-page.editorial-article .article-list li {
  margin-bottom: 0.9rem;
  color: #333;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.article-page.editorial-article .article-list li:last-child {
  margin-bottom: 0;
}

.article-page.editorial-article .article-list strong {
  color: #153b63;
  font-weight: 700;
  background-image: linear-gradient(transparent 54%, #fff3c7 54%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: left top;
  border-radius: 3px;
  padding: 0 0.08em;
}

.article-page.editorial-article .blog-highlight {
  border-radius: 3px;
  background-image: linear-gradient(transparent 54%, #fff3c7 54%);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  color: #153b63;
  padding: 0 0.08em;
}

.article-conclusion-start {
  margin-top: 1.75rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid rgba(21, 59, 99, 0.2);
}

.article-page.editorial-article .article-content a {
  color: #153b63;
  font-weight: 500;
}

.article-related {
  display: block;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(21, 59, 99, 0.2);
}

.article-related h3 {
  margin: 0 0 1.5rem;
  color: #153b63;
  font-family: Canela, "Playfair Display", serif;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.35;
}

.article-related a {
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .blog-page {
    padding: 108px 20px 32px;
  }

  .blog-list {
    padding: 0;
  }

  .blog-header {
    margin-bottom: 1.5rem;
  }

  .blog-lead-icon {
    flex-basis: 44px;
    width: 44px;
    height: 44px;
  }

  .blog-item-title {
    font-size: 22px;
  }

  .blog-item-meta {
    font-size: 15px;
  }

  .blog-item-excerpt {
    font-size: 17px;
  }

  .editorial-article .article-shell {
    padding-inline: 20px;
  }
}

.industry-page--manufacturing .industry-hero-section {
  background: linear-gradient(135deg, #f5f8fc 0%, #ffffff 58%, #eaf1f8 100%);
}

.manufacturing-finance-band {
  color: #ffffff;
  background: linear-gradient(112deg, #102b4d 0%, #153b63 53%, #22557c 100%);
}

.manufacturing-finance-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 86% 25%, rgba(212, 175, 55, 0.22) 0 2px, transparent 3px);
  background-size: 22px 22px;
  opacity: 0.6;
  mask-image: linear-gradient(to left, #000 0%, transparent 32%);
}

.manufacturing-finance-band__eyebrow {
  color: #dfbc57;
}

.manufacturing-finance-band__copy {
  color: #ffffff;
}

.industry-page--manufacturing .service-accent-card {
  border-top: 3px solid #153b63;
}

.line-shimmer {
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.1), rgba(212, 175, 55, 0.85), rgba(255, 255, 255, 0.1));
  background-size: 240% 100%;
  animation: shimmer 3.2s linear infinite;
}

@keyframes shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* Production-aligned Careers page. */
.careers-page {
  padding: 128px 0 80px;
  color: #153b63;
}

.careers-hero {
  margin-bottom: 5rem;
}

.careers-hero h1.title-underline {
  display: block;
  width: fit-content;
  margin: 0 auto 1.5rem;
  padding: 0 0.06em 0.08em;
  border-radius: 4px;
  background-image: linear-gradient(transparent 66%, #eaf3ff 66%);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  color: #153b63;
  font-family: Canela, "Playfair Display", serif !important;
  font-size: clamp(2.1rem, 4vw, 3rem) !important;
  font-weight: 700;
  line-height: 1.12;
}

.careers-hero h1.title-underline::after {
  content: none !important;
}

.careers-lead {
  max-width: 48rem;
  margin: 0 auto;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 1.125rem;
  line-height: 1.625;
}

.careers-benefits {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.75rem;
  margin-top: 3rem;
}

.careers-benefits span {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 500;
}

.careers-benefits svg {
  width: 1.25rem;
  height: 1.25rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.careers-openings h2 {
  margin: 0 0 2.5rem;
  border-bottom: 1px solid #e3e8ee;
  padding-bottom: 1rem;
  color: #153b63;
  font-family: Merriweather, Georgia, serif;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.25;
}

.careers-job-list {
  display: grid;
  gap: 1.5rem;
}

.careers-job-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 2.5rem;
  overflow: hidden;
  border: 1px solid #edf0f4;
  border-radius: 0.75rem;
  background: #fff;
  padding: 2rem 2rem 2.3rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.careers-job-card:hover {
  border-color: #d9e4ee;
  box-shadow: 0 16px 32px rgba(21, 59, 99, 0.1);
  transform: translateY(-2px);
}

.careers-job-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.careers-job-type {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin: 0 0 0.75rem;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.careers-job-type svg {
  width: 1.25rem;
  height: 1.25rem;
  fill: none;
  stroke: #d4af37;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.careers-job-card h3 {
  margin: 0 0 0.75rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.55rem;
  font-weight: 700;
  line-height: 1.25;
}

.careers-job-description {
  max-width: 42rem;
  margin: 0;
  color: rgba(21, 59, 99, 0.8);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.98rem;
  line-height: 1.7;
}

.careers-apply-button {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  min-width: 11.75rem;
  border-radius: 999px;
  background: #143361;
  color: #fff;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  padding: 0.9rem 1.5rem;
  text-transform: uppercase;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.careers-apply-button:hover,
.careers-apply-button:focus-visible {
  background: #0f224b;
  transform: translateY(-1px);
}

.careers-job-accent {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 0.5rem;
}

.careers-culture {
  margin-top: 8rem;
}

.careers-culture-panel {
  position: relative;
  overflow: hidden;
  min-height: 19.75rem;
  border-radius: 1.5rem;
  background: #152432;
  color: #fff;
  padding: 3rem;
}

.careers-culture-copy {
  position: relative;
  z-index: 1;
  max-width: 44rem;
}

.careers-culture-panel h2 {
  margin: 0 0 1.5rem;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 1.875rem;
  font-weight: 700;
}

.careers-culture-panel p {
  margin: 0 0 2rem;
  color: #fff;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.62;
}

.careers-culture-panel a {
  display: inline-flex;
  border-radius: 999px;
  background: #fff;
  color: #153b63;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.7rem 1rem;
}

.careers-culture-icon {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  width: 33.333%;
  height: 100%;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 0.1;
}

.careers-culture-icon img {
  width: 16rem;
  height: 16rem;
  filter: brightness(0) invert(1);
}

/* Production-aligned Careers detail and application pages. */
.career-detail-page,
.careers-contact-page {
  color: #153b63;
}

.career-detail-hero {
  padding: 128px 0 5rem;
}

.career-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 2rem;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
}

.career-detail-eyebrow,
.career-section-eyebrow {
  margin: 0 0 1rem;
  color: #bf9b30;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.career-detail-hero h1.title-underline {
  display: block;
  width: fit-content;
  max-width: 58rem;
  margin: 0 auto;
  padding: 0 0.06em 0.08em;
  border-radius: 4px;
  background-image: linear-gradient(transparent 66%, #eaf3ff 66%);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  color: #153b63;
  font-family: Canela, "Playfair Display", serif !important;
  font-size: clamp(2.15rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.12;
}

.career-detail-hero h1.title-underline::after {
  content: none !important;
}

.career-detail-lead {
  max-width: 48rem;
  margin: 1.5rem auto 0;
  color: rgba(21, 59, 99, 0.84);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 1.08rem;
  line-height: 1.65;
}

.career-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.75rem;
  justify-content: center;
}

.career-detail-meta span {
  border-radius: 999px;
  background: #f3f6fa;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 0.55rem 0.95rem;
  text-transform: uppercase;
}

.career-detail-body {
  background: #fff;
  padding: 4rem 0 5.5rem;
}

.career-detail-grid {
  display: grid;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .career-detail-grid {
    grid-template-columns: minmax(0, 1fr) 320px;
  }
}

.career-responsibilities,
.career-apply-panel {
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  background: #fff;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.04);
}

.career-responsibilities {
  padding: 2rem;
}

.career-role-section + .career-role-section {
  margin-top: 2.5rem;
  border-top: 1px solid #e2e8f0;
  padding-top: 2.5rem;
}

.career-role-impact {
  border-left: 3px solid #bf9b30;
  padding-left: 1.25rem;
}

.career-responsibilities h2,
.career-apply-panel h2 {
  margin: 0 0 1rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.25;
}

.career-responsibilities p,
.career-apply-panel p {
  color: rgba(21, 59, 99, 0.8);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.career-responsibilities ul {
  display: grid;
  gap: 1rem;
  margin-top: 1.5rem;
}

.career-responsibilities li {
  position: relative;
  padding-left: 1.2rem;
  color: #153b63;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.98rem;
  line-height: 1.6;
}

.career-responsibilities li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: #bf9b30;
}

.career-apply-panel {
  align-self: start;
  border-top: 4px solid #153b63;
  padding: 1.6rem;
}

.career-apply-panel a {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: 1.5rem;
  border-radius: 999px;
  background: #143361;
  color: #fff;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  padding: 0.9rem 1.3rem;
  text-transform: uppercase;
}

.careers-contact-page {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)),
    url("/images/certification-pattern-background.png");
  background-position: center top;
  background-size: cover;
  padding: 128px 0 5rem;
}

.careers-contact-shell {
  max-width: 1100px;
}

.careers-contact-header {
  margin-bottom: 1.5rem;
  text-align: center;
}

.careers-contact-header h1 {
  margin: 0 0 0.75rem;
  color: #153b63;
  font-family: Canela, "Playfair Display", serif !important;
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1.12;
}

.careers-contact-header p {
  max-width: 48rem;
  margin: 0 auto;
  color: rgba(21, 59, 99, 0.84);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.careers-contact-grid {
  display: grid;
  gap: 1.25rem;
  align-items: stretch;
}

@media (min-width: 1024px) {
  .careers-contact-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

.careers-application-card {
  border: 1px solid rgba(21, 59, 99, 0.12);
  border-bottom: 4px solid #153b63;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.05);
  padding: 1.55rem;
  height: 100%;
}

.careers-success {
  display: flex;
  min-height: 38rem;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  text-align: center;
}

.careers-success[hidden] {
  display: none;
}

.careers-success-icon {
  display: flex;
  width: 4rem;
  height: 4rem;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  border-radius: 999px;
  background: #dcfce7;
}

.careers-success-icon img {
  width: 2rem;
  height: 2rem;
  filter: invert(18%) sepia(39%) saturate(1845%) hue-rotate(174deg) brightness(85%) contrast(97%);
}

.careers-success h2 {
  margin: 0 0 1rem;
  color: #153b63;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.5rem;
  font-weight: 600;
}

.careers-success p {
  max-width: 24rem;
  margin: 0;
  color: #426482;
  font-family: Inter, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.careers-application-heading h2,
.careers-reach h2 {
  margin: 0 0 0.35rem;
  color: #152432;
  font-family: Canela, "Playfair Display", serif;
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 1;
}

.careers-reach h2 {
  font-size: 1.125rem;
  line-height: 1.55;
}

.careers-application-heading p,
.careers-reach p {
  margin: 0 0 1.25rem;
  color: rgba(21, 59, 99, 0.72);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.45;
}

.careers-application-card form {
  display: grid;
  gap: 1rem;
}

.careers-field-row {
  display: grid;
  gap: 1rem;
}

@media (min-width: 640px) {
  .careers-field-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.careers-application-card label {
  display: grid;
  gap: 0.42rem;
  color: #153b63;
  font-family: Inter, sans-serif;
  font-size: 0.875rem;
  font-weight: 400;
}

.careers-application-card input,
.careers-application-card textarea {
  width: 100%;
  border: 1px solid #dbe6f0;
  border-radius: 6px;
  background: #fff;
  color: #2b4764;
  font-family: Inter, sans-serif;
  font-size: 0.875rem;
  line-height: 1.45;
  padding: 0.5rem 0.75rem;
}

.careers-application-card input[type="file"] {
  background: transparent;
  font-size: 0.75rem;
}

.careers-application-card textarea {
  min-height: 6.1rem;
  resize: vertical;
}

.careers-application-card button {
  justify-self: stretch;
  width: 100%;
  border-radius: 999px;
  background: #143361;
  color: #fff;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  padding: 0.85rem 1.6rem;
  text-transform: uppercase;
}

.careers-application-card button:disabled {
  cursor: wait;
  opacity: 0.7;
}

#careers-status {
  min-height: 1.2rem;
  font-family: Inter, sans-serif;
  font-size: 0.86rem;
}

#careers-status.is-success {
  color: #137b3f;
}

#careers-status.is-error {
  color: #9f2f2f;
}

.careers-contact-side {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  height: 100%;
}

.careers-reach {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 4px 10px rgba(21, 59, 99, 0.05);
  padding: 1.55rem;
}

.careers-contact-line {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-top: 0.75rem;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

.careers-contact-line img {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
  margin-top: 0.2rem;
  filter: invert(34%) sepia(18%) saturate(1171%) hue-rotate(167deg) brightness(93%) contrast(88%);
}

.careers-why {
  border-radius: 8px;
  background: #132857;
  color: rgba(255, 255, 255, 0.9);
  padding: 1.55rem;
  flex: 1 1 auto;
}

.careers-why h2 {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.9);
  font-family: Canela, "Playfair Display", serif;
  font-size: 0.9rem;
  font-weight: 300;
  letter-spacing: 0.15em;
  line-height: 1.4;
  text-transform: uppercase;
}

.careers-why-grid {
  display: grid;
  gap: 1rem;
}

.careers-why-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.careers-why-item > img {
  flex: 0 0 auto;
  width: 1.25rem;
  height: 1.25rem;
  margin-top: 0.08rem;
  filter: invert(74%) sepia(45%) saturate(908%) hue-rotate(174deg) brightness(103%) contrast(101%);
}

.careers-why strong {
  display: block;
  color: #fff;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
}

.careers-why p {
  margin: 0.25rem 0 0;
  color: rgba(255, 255, 255, 0.8);
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.86rem;
  line-height: 1.5;
}

/* Match the spacing and two-column rhythm used by the live contact section. */
#contact {
  padding-top: 6rem !important;
  padding-bottom: 5rem !important;
}

#contact .contact-intro {
  margin-bottom: 4rem !important;
}

#contact .contact-intro h2 {
  margin-bottom: 1.5rem !important;
}

#contact .contact-grid {
  gap: 3rem !important;
}

#contact .contact-side {
  width: 100%;
  max-width: 31.75rem;
  align-items: flex-start;
  gap: 1.5rem !important;
}

#contact .contact-side > div {
  width: 100%;
}

#contact .contact-why {
  width: 100%;
  max-width: none;
  align-self: flex-start;
  flex: 0 0 auto !important;
  border-radius: 8px;
  background: #132857;
  color: rgba(255, 255, 255, 0.9);
  padding: 1.55rem;
}

#contact .contact-side > div:first-child {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 4px 10px rgba(21, 59, 99, 0.05);
  padding: 1.55rem;
}

#contact .contact-side > div:first-child h3 {
  margin: 0 0 0.95rem;
  color: #152432;
  font-family: Canela, "Playfair Display", serif;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.55;
}

#contact .contact-side > div:first-child .space-y-4 {
  display: grid;
  gap: 0.75rem;
}

#contact .contact-side > div:first-child .space-y-4 > div {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0 !important;
  color: #426482;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.5;
}

#contact .contact-side > div:first-child .space-y-4 > div span {
  color: #426482 !important;
  font-weight: 400;
}

#contact .contact-side > div:first-child .space-y-4 > div svg {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
  margin-top: 0.2rem;
}

#contact .contact-side > div:first-child .space-y-4 > div:nth-child(1) svg {
  color: #d98a8a !important;
}

#contact .contact-side > div:first-child .space-y-4 > div:nth-child(1) span {
  color: #153b63 !important;
  font-weight: 700;
}

#contact .contact-side > div:first-child .space-y-4 > div:nth-child(2) svg {
  color: #1a4e8a !important;
}

#contact textarea {
  min-height: 5.75rem;
}

#contact .contact-why > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

#contact .contact-why > div > div {
  margin: 0 !important;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

#contact .contact-why h4 {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.9);
  font-family: Canela, "Playfair Display", serif;
  font-size: 0.9rem;
  font-weight: 300;
  letter-spacing: 0.15em;
  line-height: 1.4;
  text-transform: uppercase;
}

#contact .contact-why > div > div svg {
  flex: 0 0 auto;
  width: 1.25rem;
  height: 1.25rem;
  margin-top: 0.08rem;
}

#contact .contact-why > div > div span {
  display: block;
  color: #fff !important;
  font-family: Montserrat, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.35;
}

@media (max-width: 1023px) {
  .careers-page {
    padding-top: 116px;
  }

  .careers-job-card {
    min-height: 0;
    align-items: flex-start;
    flex-direction: column;
  }

  #contact .contact-why > div {
    grid-template-columns: 1fr;
  }

  #contact .contact-side {
    max-width: none;
  }

  #contact .contact-why {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .careers-hero {
    margin-bottom: 3.5rem;
  }

  .careers-benefits {
    align-items: flex-start;
    flex-direction: column;
    margin-top: 2rem;
  }

  .careers-job-card {
    padding: 1.5rem 1.25rem 2rem;
  }

  .careers-apply-button {
    width: 100%;
  }

  .careers-culture {
    margin-top: 4rem;
  }

  .careers-culture-panel {
    padding: 2rem 1.5rem;
  }

  .careers-culture-icon {
    right: -2rem;
    width: 55%;
  }

  .careers-culture-icon img {
    width: 11rem;
    height: 11rem;
  }
}
