@charset "utf-8"; /* default PC */
#contents .reason-area {
  display: grid;
  gap: 80px;
}

#contents .photo img {
  border: 4px solid #c09520;
}

#contents .reason-box {
  display: grid;
  gap: 40px;
  grid-template-columns: 40% calc(60% - 40px);
}

#contents .reason-box .txt-box h2 {
  align-items: baseline;
  background-color: transparent;
  color: #333;
  clip-path: none;
  display: flex;
  flex-wrap: wrap;
  font-size: 30px;
  font-weight: 600;
  line-height: 1.4em;
  margin-bottom: 30px;
  margin-top: 0;
  letter-spacing: .1em;
  padding: 5px 0 5px 80px;
  position: relative;
}

#contents .reason-box .txt-box h2 .num {
  background-color: #314FA5;
  color: #fff;
  font-family: "Roboto", "Noto SansJP", sans-serif;
  font-size: 100%;
  font-weight: 500;
  line-height: 1em;
  left: 0;
  top: 2px;
  padding: 12px 7px 10px 9px;
  position: absolute;
}

@media screen and (max-width: 1140px) {
  #contents .reason-box .txt-box h2 {
    font-size: 23px;
    padding-left: 65px;
  }

  #contents .reason-area {
    gap: 50px;
  }

  #contents .reason-box .txt-box h2 .num {
    top: 1px;
  }
}

@media screen and (max-width: 767px) {
  #contents .reason-box {
    grid-template-columns: 100%;
  }

  #contents .reason-box .photo {
    text-align: center;
  }
}

@media screen and (max-width: 559px) {
  #contents .reason-box .txt-box h2 .num {
    padding: 10px 7px 9px 9px;
    top: 0;
  }

  #contents .reason-box .txt-box h2 {
    font-size: 21px;
    margin-bottom: 20px;
    padding-left: 58px;
  }

  #contents .reason-box {
    gap: 25px;
  }
}
