.post_content h2 {
  font-size: 3.4rem;
  text-align: center;
  position: relative;
  border-bottom: none;
  padding: 0.7em 0;
}
@media only screen and (max-width: 991px) {
  .post_content h2 {
    font-size: 2.3rem;
  }
}
.post_content h2::after {
  content: "";
  position: absolute;
  left: calc(50% - 50px);
  bottom: 0;
  width: 100px;
  height: 4px;
  background: #60aa32;
}
@media only screen and (max-width: 991px) {
  .post_content h2::after {
    width: 50px;
    height: 2px;
    left: calc(50% - 25px);
  }
}
.post_content h3 {
  font-size: 3rem;
  border-style: solid;
  border-width: 0 0 2px 0;
  border-color: #60aa32;
  border-radius: 0;
  position: relative;
  padding: 0.4em 1em 0.4em 80px;
  margin-bottom: 1.6em;
}
@media only screen and (max-width: 991px) {
  .post_content h3 {
    font-size: 1.8rem;
    border-bottom-width: 1px;
    padding: 0.4em 1em 0.4em 50px;
  }
}
.post_content h3::before, .post_content h3::after {
  content: "";
  position: absolute;
  left: 0;
}
.post_content h3::before {
  width: 40px;
  height: calc(100% + 18px);
  background: #60aa32;
  top: 0;
}
@media only screen and (max-width: 991px) {
  .post_content h3::before {
    width: 30px;
    height: calc(100% + 9px);
  }
}
.post_content h3::after {
  content: "";
  width: 40px;
  height: 2px;
  background: white;
  bottom: -1px;
}
@media only screen and (max-width: 991px) {
  .post_content h3::after {
    height: 1px;
    width: 30px;
  }
}
.post_content h4 {
  font-size: 2rem;
  border-left: none;
  color: #5c5c5c;
  position: relative;
  padding: 0.6em 45px;
}
@media only screen and (max-width: 991px) {
  .post_content h4 {
    font-size: 1.6rem;
    padding: 0.6em 28px;
  }
}
.post_content h4::before, .post_content h4::after {
  content: "";
  position: absolute;
  left: 0;
  width: 30px;
  height: 5px;
}
@media only screen and (max-width: 991px) {
  .post_content h4::before, .post_content h4::after {
    width: 22px;
    height: 3px;
  }
}
.post_content h4::before {
  background: #60aa32;
  top: calc(50% - 3px);
}
@media only screen and (max-width: 991px) {
  .post_content h4::before {
    top: calc(50% - 2px);
  }
}
.post_content h4::after {
  background: #5c5c5c;
  top: calc(50% + 2px);
}
@media only screen and (max-width: 991px) {
  .post_content h4::after {
    top: calc(50% + 1px);
  }
}
.post_content h5 {
  font-size: 2.4rem;
  font-weight: 500;
  width: 100%;
  height: 2.3em;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  align-items: center;
  background: #f0f3fa;
  border-bottom: 1px solid #666666;
  padding: 0.5em;
}
@media only screen and (max-width: 991px) {
  .post_content h5 {
    font-size: 1.5rem;
    height: 2.8em;
  }
}
.post_content p {
  line-height: 2;
  font-weight: normal;
  margin-bottom: 1.5em;
}
@media only screen and (max-width: 991px) {
  .post_content p {
    font-size: 1.3rem;
  }
}
.post_content .q_button {
  background: #60aa32;
  border: none;
  min-width: 260px;
  font-size: 1.6rem;
  text-align: left;
  position: relative;
}
@media only screen and (max-width: 991px) {
  .post_content .q_button {
    min-width: 256px;
    font-size: 1rem;
  }
}
.post_content .q_button:hover {
  background: #666;
}
.post_content .q_button::before {
  content: "";
  width: 24px;
  height: 100%;
  background: url("../img/arrow_btn_link.png") center center no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  right: 9px;
}
@media only screen and (max-width: 991px) {
  .post_content .q_button::before {
    width: 15px;
  }
}
.post_content .q_button.sz_l {
  min-width: 384px;
  font-size: 1.6rem;
}
@media only screen and (max-width: 991px) {
  .post_content .q_button.sz_l {
    min-width: 292px;
    font-size: 1.4rem;
  }
}
.post_content .q_button.rounded {
  border-radius: 4px;
}

.page__header-image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  object-position: center;
  position: relative;
  left: 0;
  top: 0;
  transform: translate(0, 0);
}
.page__header-image h1.catch_copy {
  background: rgba(96, 170, 50, 0.85);
  font-size: 3.2rem;
  font-weight: bold;
  text-align: left;
}
@media only screen and (max-width: 991px) {
  .page__header-image h1.catch_copy {
    font-size: 1.7rem;
  }
}
@media only screen and (max-width:768px) {
  .page__header-image h1.catch_copy {
    height: 40px;
    line-height: 40px;
  }
}

@media only screen and (max-width:768px) {
  .page__header-image .inner {
    height: 180px;
  }
}

/*# sourceMappingURL=page.css.map */
