@charset "utf-8";
/* CSS Document */
.section_top {
  width: auto;
  position: relative;
  z-index: -1;
}
h1 {
  color: #ffffff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  font-size: 4.5vw;
  font-family: "Aboreto", serif;
  letter-spacing: 2vw;
  white-space: nowrap;
}
.sh_on_top {
  display: none;
}
.sh_non_top {
  margin-top: -80px;
}
h2 {
  font-size: 23px;
  font-family: "Noto Serif JP", serif;
  letter-spacing: 3px;
  font-weight: 800;
  width: auto;
  margin: 80px 0 30px 0px;
}
.main_message {
  font-size: 18px;
  font-family: "Noto Serif JP", serif;
  line-height: 45px;
  letter-spacing: 3px;
  margin-bottom: 30px;
  font-weight: 600;
}
@media (max-width: 790px) {
  .header_top_image_wrap {
    height: 300px;
  }
  h2 {
    font-size: 20px;
    letter-spacing: 3px;
    margin-top: 50px;
  }
  .main_message {
    font-size: 14px;
    line-height: 30px;
  }
}
@media (max-width: 768px) {
  .sh_non_top {
    margin-top: 0;
  }
}
@media (max-width: 500px) {
  h1 {
    font-size: 6vw;
    letter-spacing: 3vw;
  }
  .header_top_image_wrap {
    height: 300px;
  }
  .header_container {
    display: none;
  }
  h2 {
    font-size: 18px;
    letter-spacing: 3px;
    margin-top: 40px;
  }
  .sh_non_top {
    display: none;
  }
  .sh_on_top {
    display: block;
    margin-top: 0px;
  }
  .main_message {
    font-size: 14px;
    line-height: 30px;
  }
}