/*----------------------------
	module/page_title
----------------------------*/
.page_header {
  width: 100%;
  margin-top: min(5.26vw, 10rem);
}
.page_header__title {
  font-size: min(2.57vw, 3.6rem);
  line-height: 1.45;
  font-weight: bold;
  text-align: center;
  color: #008cd6;
  padding-bottom: min(4.43vw, 6.2rem);
  position: relative;
}
.page_header__title span {
  color: #7b7b7b;
  font-size: min(1.07vw, 1.5rem);
  margin-top: 0.8em;
  padding-top: 0.7em;
  display: block;
  position: relative;
}
.page_header__title span::before {
  content: "";
  display: inline-block;
  height: 0.2rem;
  background-color: #fe9927;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.page_header__illust {
  position: absolute;
  bottom: 0;
  height: min(11.4vw, 16rem);
  left: 0;
}
.page_header__pic {
  position: relative;
  width: 100%;
  background-size: cover;
  background-position: center;
  height: min(28.12vw, 54rem);
  display: flex;
  justify-content: center;
  align-items: center;
  background-repeat: no-repeat;
}

/*--------------------------------
	SP用
----------------------------------- */
@media all and (max-width: 530px) {
  /*----------------------------
		parts/page_title
	----------------------------*/
  .page_header {
    width: 100%;
    margin-top: min(5.33vw, 2rem);
  }
  .page_header__title {
    font-size: min(6.93vw, 2.6rem);
    padding-bottom: 0;
  }
  .page_header__title span {
    font-size: min(2.6vw, 1rem);
    margin-top: 1.2em;
    padding-top: 1em;
  }
  .page_header__title span::before {
    width: 26em;
  }
  .page_header__pic {
    margin-top: min(10.67vw, 4rem);
    height: min(58.67vw, 22rem);
  }
  .page_header__illust {
    display: none;
  }
}
