@media screen and (max-width: 767px) {
  section .container .contents .hgroup .contents_copy:before, section .container .contents .hgroup .contents_copy:after {
    display: none;
  }
}

.history_flow {
  margin-top: 84px;
  display: flex;
  flex-direction: column;
  gap: 60px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .history_flow {
    gap: 30px;
  }
}
.history_flow:after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: 20px;
  height: 100%;
  background: #3F6147;
}
.history_flow .history {
  padding: 60px 60px 66px;
  background: #FFF;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .history_flow .history {
    padding: 40px 15px 44px;
  }
}
.history_flow .history .this_year {
  width: 149px;
  height: 46px;
  background: #4F8A5D;
  color: #FFF;
  font-size: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -23px;
  left: 50%;
  translate: -50% 0;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 767px) {
  .history_flow .history .this_year {
    height: 29px;
    width: 76px;
    font-size: 16px;
    top: -13px;
  }
}
.history_flow .history .h_title {
  font-size: clamp(18px, 1.42857vw, 20px);
  line-height: 1.5;
  padding-left: 35px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .history_flow .history .h_title {
    padding-left: 20px;
  }
}
.history_flow .history .h_title:before {
  content: "";
  position: absolute;
  display: block;
  top: 15px;
  left: 0;
  width: 20px;
  height: 2px;
  background: #222;
}
@media screen and (max-width: 767px) {
  .history_flow .history .h_title:before {
    width: 10px;
    top: 12px;
  }
}
.history_flow .history .h_title + .list_wrap,
.history_flow .history .h_title + .text {
  margin-top: 38px;
}
@media screen and (max-width: 767px) {
  .history_flow .history .h_title + .list_wrap,
  .history_flow .history .h_title + .text {
    margin-top: 28px;
  }
}
.history_flow .history .h_title + .h_title {
  margin-top: 28px;
}
.history_flow .history .img_area {
  display: flex;
  gap: 20px;
  margin-top: 38px;
}
.history_flow .history .img_area:has(:nth-of-type(2)) {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (max-width: 767px) {
  .history_flow .history .img_area:has(:nth-of-type(2)) {
    grid-template-columns: repeat(2, 1fr);
  }
}
.history_flow .history .img_area:has(.img01) {
  display: grid;
  grid-template-columns: 143px 292px;
}
@media screen and (max-width: 767px) {
  .history_flow .history .img_area:has(.img01) {
    grid-template-columns: 74px 150px;
  }
}
.history_flow .history .img_area .img {
  width: 100%;
}
.history_flow .history .img_area .img .img_cap {
  font-size: 13px;
  text-align: center;
  margin-top: 12px;
  line-height: 1.75;
}
.history_flow .history .img_area + .h_title {
  margin-top: 28px;
}
.history_flow .history .has_img {
  display: grid;
  grid-template-columns: 1fr 224px;
  gap: 40px;
  margin-top: 38px;
}
@media screen and (max-width: 767px) {
  .history_flow .history .has_img {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: center;
    gap: 30px;
  }
}
.history_flow .history .has_img .img_area {
  display: flex;
  max-width: 224px;
  margin-top: 0;
}
.history_flow .history .has_img + .h_title {
  margin-top: 28px;
}

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