* {
} 


.about-hero {
  position: relative;
}

.about-hero .bg-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-image: url(/wp-content/uploads/2023/06/circuits.webp);
  background-size: cover;
  background-position: center center;
  background-color: rgba(51, 0, 51, 0.5);
  background-blend-mode: overlay;
  opacity: 0.95;
}

.hero-container {
  margin: auto;
  display: flex;
  position: relative;
  min-height: 512px;
  justify-content: center;
}

.desc-container {
  width: 100%;
  max-width: 550px;
  min-width: 350px;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  z-index: 1;
}

.desc-cta {
  width: 350px;
  margin-bottom: 2rem;
}

.desc-cta .button {
  width: 100%;
  border: 2px solid white;
}

.hero-image {
  width: 100%;
}

.company-header {
  font-size: 4.5rem;
  padding: 1rem;
  text-align: center;
  color: white;
  font-weight: 800;
}

.desc-header {
  font-size: 2rem;
  padding: 1rem;
  text-align: center;
  text-transform: uppercase;
  line-height: 1.2;
}

.desc-subtext {
  font-size: 1.2rem;
  padding: 1rem;
  text-align: center;
}

.company-component {
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin: auto;
  max-width: 1200px;
}

.company {
  font-size: 3rem;
  font-weight: 600;
  margin-left: 4rem;
  margin-bottom: 2rem;
  align-self: flex-start;
}

.company-component .desc-container {
  margin-left: 7rem;
  width: 350px;
  min-width: 350px;
}

.company-component .description {
  font-size: 1.5rem;
  line-height: 2rem;
  margin-bottom: 1.5rem;
}

.company-component .img-container {
  width: 50%;
}

.company-component img {
  width: 256px;
}

.about-component {
  color: white;
  margin: 2rem 4rem;
}

.title-numbered {
  color: gray;
}

.hr {
  border-bottom: 1px solid #d9d9d9;
  margin-bottom: 1.5rem;
}

.square {
  padding: 2rem;
}

.container .title,
.square .title {
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 2rem;
}

.square.solution {
  color: #cecdcd;
}

.solution ul {
  margin: 2.5em 0 0 3.5em;
}

.purple-line {
  border-bottom: 2px solid #330033;
}

.purple-lt .purple-line {
  border-bottom: 2px solid rgb(98, 0, 98);
}

.cto ul {
  margin-left: 5.8em;
}

.solution .title,
.cto .title {
  max-width: 450px;
}

.solution a,
.cto a {
  width: 100%;
  max-width: 375px;
}

.solution button,
.cto button {
  max-width: 375px;
  width: 100%;
}

ul {
  display: block;
}

ul li {
  display: block;
  position: relative;
}

ul li:not(:last-child) {
  margin-bottom: 16px;
}

ul li:before {
  content: "";
  position: absolute;
  top: 1.2em;
  left: -30px;
  margin-top: -.9em;
  background: #330033;
  height: 12px;
  width: 12px;
  border-radius: 50%;
}

.purple-lt ul li:before {
  background: rgb(98, 0, 98)
}

.container.tdd {
  color: #cecdcd;
  padding: 2rem;
}

.tfb p,
.tdd p,
.cto p {
  max-width: 600px;
  margin: 1rem 0;
  line-height: 1.4rem;
}

.container.tfb {
  padding: 2rem;
  background-color: white;
}

.services-blocks {
  min-height: 400px;
  width: 100%;
  position: relative;
}

.services-blocks .square {
  width: 50%;
}

.services-blocks .square .square-inside {
  max-width: 600px;
  height: 100%;
}

.tfb-buttons {
  gap: 1rem;
}

.square.solution .title,
.square.cto .title {
  height: 64px;
}

@media only screen and (max-width: 966px) {
  div.hero-container.container {
    flex-direction: column;
    align-items: center;
  }
}

@media only screen and (max-width: 768px) {
  .company-header {
    font-size: 3.3rem;
  }

  .hero-container .desc-header {
    font-size: 1.5rem;
  }

  .mob-flex-aic {
    align-items: center;
  }

  .hide-on-small-screen {
    display: none;
  }

  .services-blocks {
    flex-direction: column;
  }

  .services-blocks .square {
    width: 100%;
    justify-content: center;
    padding: 2rem 0;
  }

  .services-blocks button {
    margin-top: 2rem;
  }

  .services-blocks .square ul {
    margin: 2rem 0 0 0;
  }

  .services-blocks .square .square-inside {
    max-width: none;
    height: 100%;
  }

  .services-blocks .title {
    padding: 0 2rem;
  }

  .container.tfb .tfb-inside {
    flex-direction: column;
  }

  .company {
    font-size: 2rem;
    font-weight: 600;
    margin-left: 1rem;
    margin-bottom: 2rem;
    align-self: flex-start;
  }

  .company-component .desc-container {
    margin-left: 4rem;
    width: 350px;
    min-width: 350px;
  }

  .company-component .description {
    font-size: 1.5rem;
    line-height: 2rem;
    margin-bottom: 1.5rem;
  }

  .company-component {
    margin-bottom: 2rem;
  }

  .tfb-buttons {
    justify-content: center;
    flex-wrap: wrap;
  }

  .tfb-buttons .tfb-results-button {
    width: 100%;
    max-width: 375px;
    flex: 100%;
  }

  .tfb-buttons .tfb-results-button .button-on-gray {
    width: 100%;
    max-width: 375px;
  }

  .tfb-buttons .tfb-social-button {
    flex: calc(50% - 1rem);
  }

  .tfb-buttons .tfb-social-button.github-button {
    text-align: right;
  }
}

@media only screen and (max-width: 430px) {
  .desc-cta {
    width: 80%;
  }

  .company-header {
    font-size: 3rem;
  }

  .solution a, .cto a {
    width: 80%;
    max-width: 375px;
  }

  .services-blocks .square ul {
    margin-top: 3em;
  }

  .container {
	  max-width: 90%;
  }
}

