p {
  font-family: var(--rt-font-dm);
}

h1,
h2,
h3 {
  font-family: var(--rt-font-ibm);
}

.co-teacher-hero {
  padding: 80px 32px;
  background-color: #132C55;
}
.co-teacher-hero .title {
  max-width: 599px;
  width: 100%;
}
.co-teacher-hero .title h1 {
  color: #fff;
  font-size: 48px;
  line-height: 58px;
  margin-bottom: 32px;
  font-weight: 700;
}
.co-teacher-hero .title p {
  color: #fff;
  font-size: 28px;
  font-weight: 400;
  line-height: 38px;
}
.co-teacher-hero img {
  width: 445px;
  height: 420px;
  object-fit: cover;
}
@media (max-width: 1100px) {
  .co-teacher-hero .d-flex {
    justify-content: center;
    row-gap: 30px;
  }
  .co-teacher-hero .title {
    max-width: 100%;
  }
}
@media (max-width: 768px) {
  .co-teacher-hero {
    padding: 80px 24px;
  }
}
@media (max-width: 480px) {
  .co-teacher-hero img {
    width: 330px;
    height: 310px;
  }
}

.overlap {
  background-color: #EEF5FF;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  padding: 64px;
  margin-top: -40px;
}
.overlap .d-flex {
  flex-wrap: nowrap;
}
.overlap .title {
  width: 318px;
}
.overlap .title h3 {
  font-size: 24px;
  line-height: 28px;
  font-weight: 700;
  color: #333;
  margin-bottom: 9px;
}
.overlap .title a {
  color: #498BF9;
  font-size: 18px;
  line-height: 24px;
  font-family: var(--rt-font-dm);
  font-weight: 700;
}
.overlap p {
  color: #333;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
  max-width: 692px;
  width: 100%;
}
@media (max-width: 768px) {
  .overlap {
    padding: 30px;
  }
  .overlap .d-flex {
    flex-wrap: wrap;
    row-gap: 30px;
    justify-content: center;
  }
}

.invited {
  margin-top: 66px;
}
.invited h2 {
  font-size: 36px;
  line-height: 44px;
  color: #333;
  font-weight: 700;
  text-align: center;
}
.invited .steps {
  margin-top: 48px;
  margin-bottom: 48px;
  gap: 15px;
}
.invited .steps .step {
  border: 1px solid #DFECFE;
  padding: 42px;
  border-radius: 30px;
  border-bottom-left-radius: 0px;
  flex-basis: calc(25% - 12px);
  flex-grow: 0;
  position: relative;
  min-height: 282px;
}
.invited .steps .step p {
  color: #333;
  font-size: 18px;
  line-height: 27px;
  font-weight: 400;
  position: relative;
  z-index: 2;
}
.invited .steps .step p strong,
.invited .steps .step p a {
  font-weight: 700;
  color: #498BF9;
  text-decoration: none;
}
.invited .steps .step .counter {
  position: absolute;
  bottom: -17px;
  left: -2px;
  font-size: 100px;
  line-height: 120px;
  font-family: var(--rt-font-ibm);
  color: #DFECFE;
  font-weight: 700;
  z-index: 0;
}
@media (max-width: 900px) {
  .invited .steps .step {
    flex-basis: calc(50% - 12px);
  }
}
@media (max-width: 600px) {
  .invited .steps .step {
    flex-basis: 100%;
    padding: 30px;
    min-height: 200px;
  }
}
.invited .global-btn {
  margin: 0 auto 48px;
  text-align: center;
}

.join {
  margin: 70px 0;
}
.join .title {
  max-width: 910px;
  width: 100%;
  text-align: center;
  margin: auto;
}
.join .title h2 {
  font-size: 36px;
  line-height: 44px;
  color: #333;
  font-weight: 700;
  text-align: center;
  margin-bottom: 24px;
}
.join .title p {
  color: #333;
  font-size: 22px;
  line-height: 28px;
  font-weight: 400;
}
.join .blocks {
  gap: 15px;
  margin-top: 48px;
}
.join .blocks .block {
  flex-basis: calc(50% - 7.5px);
  flex-grow: 0;
  border-radius: 30px;
  background-color: #EEF5FF;
  border-bottom: 8px solid #498BF9;
  padding: 42px;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.join .blocks .block img {
  width: 48px;
  height: 48px;
  object-fit: contain;
}
.join .blocks .block h3 {
  font-size: 24px;
  line-height: 34px;
  color: #333;
  font-weight: 700;
  margin-bottom: 0;
}
.join .blocks .block p {
  color: #646464;
  font-size: 18px;
  line-height: 27px;
  font-weight: 400;
}
@media (max-width: 768px) {
  .join .blocks .block {
    flex-basis: 100%;
    padding: 30px;
  }
}

.questions {
  background-color: #132C55;
  padding: 81px 32px 93px;
}
.questions .wrapper {
  flex-direction: column;
  text-align: center;
  align-items: center;
  gap: 24px;
  max-width: 700px;
  width: 100%;
  margin: auto;
}
.questions .wrapper img {
  width: 123px;
  height: 123px;
  object-fit: contain;
}
.questions .wrapper h2 {
  font-size: 36px;
  line-height: 43px;
  color: #fff;
  font-weight: 700;
  margin-bottom: 0;
}
.questions .wrapper p {
  color: #fff;
  font-weight: 400;
  font-size: 22px;
  line-height: 28px;
}
.questions .wrapper p a {
  color: rgb(207, 207, 81);
  font-weight: 700;
}
.questions .wrapper .link {
  margin-top: 22px;
}
.questions .wrapper .link a {
  color: #498BF9;
  padding: 15px 32px;
  border-radius: 32px;
  border: 2px solid #A4C5FC;
  font-size: 14px;
  font-weight: 700;
  line-height: 16px;
  transition: all 0.3s;
  display: inline-block;
}
.questions .wrapper .link a:hover {
  color: #A4C5FC;
  border: 2px solid #498BF9;
  transition: all 0.3s;
}