:root {
  --white: white;
  --black: black;
}

a {
  text-decoration: none;
}

.section_header {
  position: relative;
  overflow: hidden;
}

.container2 {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 5rem 3rem;
  display: flex;
  position: relative;
}

.section_body {
  position: relative;
}

.hero_wrap {
  aspect-ratio: auto;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  inset: 0%;
  overflow: visible;
}

.hero_image {
  width: 100%;
  position: relative;
  inset: 0%;
}

.layout_wrap {
  overflow: clip;
}

.hero_content_wrap {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  padding-left: 3rem;
  display: flex;
  position: relative;
}

.heading {
  color: #fff;
  max-width: 30ch;
  font-size: 3rem;
  font-weight: 400;
}

.hero_heading_layout {
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.layout_split {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  justify-content: space-between;
  width: 100%;
  display: flex;
  position: relative;
}

.split_col_wrap {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  width: 50%;
  display: flex;
}

.item_bg {
  background-color: #f5f5f5;
  border-radius: 6px;
  justify-content: space-between;
  padding: 1rem 1rem 1rem 1.5rem;
  display: flex;
}

.heading_category {
  color: #0081b2;
  font-size: 24px;
}

.item_layout_text {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 70%;
  display: flex;
}

.item_layout_text.is-grado {
  width: 60%;
}

.img_item {
  width: 30%;
}

.button_wrap {
  background-color: #fff;
  border: 1px solid #2278c9;
  border-radius: 6px;
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  padding: .75rem 1rem;
  display: flex;
  box-shadow: 0 0 4px #0006;
}

.button_lable {
  color: #2278c9;
  font-size: 16px;
  text-decoration: none;
}

.item_header {
  color: #21205c;
  font-size: 20px;
  font-weight: 700;
}

.item_grade {
  font-size: 18px;
}

.intro_text_wrap {
  border-bottom: 1px solid #bababa;
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
}

.intro_text {
  font-size: 20px;
  line-height: 26px;
}

.item_cover_img {
    /*width: 135px;*/
    width: 100%;
  }

.hero_img {
  width: 430px;
}

@media screen and (max-width: 991px) {
  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .hero_wrap {
    justify-content: center;
    align-items: center;
    width: 100%;
  }

  .hero_content_wrap {
    min-height: 20rem;
  }

  .layout_split {
    flex-flow: column;
  }

  .split_col_wrap {
    width: 100%;
  }

  .img_item {
    justify-content: flex-end;
    align-items: center;
    display: flex;
  }

  .item_cover_img {
    height: 11rem;
  }

  .hero_img {
    width: 25vw;
  }
}

@media screen and (max-width: 767px) {
  .container {
    margin-left: 1rem;
    margin-right: 1rem;
  }

  .heading {
    font-size: 2rem;
    line-height: 36px;
  }

  .img_wrap {
    max-height: 16rem;
  }

  .hero_img {
    width: 20vw;
  }
}

@media screen and (max-width: 479px) {
  .container {
    margin-left: auto;
    margin-right: auto;
    padding-top: 2rem;
  }

  .hero_wrap {
    height: 14rem;
  }

  .hero_image {
    max-width: 100%;
    overflow: visible;
  }

  .hero_content_wrap {
    min-height: 14rem;
    padding-left: 1rem;
  }

  .item_bg {
    padding: 1rem .5rem 1rem 1rem;
  }

  .item_bg.is-grado {
    padding-left: .75rem;
  }

  .item_layout_text {
    grid-column-gap: .75rem;
    grid-row-gap: .75rem;
  }

  .button_wrap {
    border-radius: 4px;
    padding: .25rem .75rem;
  }

  .button_lable {
    font-size: 14px;
  }

  .item_header {
    font-size: 18px;
  }

  .item_grade {
    font-size: 16px;
  }

  .item_cover_img {
    height: auto;
  }

  .intro_text_wrap {
    padding-top: .5rem;
    padding-bottom: 1rem;
  }

  .intro_text {
    font-size: 16px;
    line-height: 20px;
  }

  .hero_img {
    width: 20vw;
  }
}
