/*------------------------
  contents main
------------------------*/
.contents_wrap {
  width: 100%;
  margin: 0 auto;
}

.contents_item {
  width: 100%;
}
.contents_item:not(:last-child) {
  margin-bottom: 7.5rem;
}
@media screen and (max-width: 767px) {
  .contents_item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .contents_item:not(:last-child) {
    margin-bottom: 4.375rem;
  }
}
.contents_item .contents_item_image {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 80%;
  display: block;
  border: 0.0625rem solid #1e1e1e;
  padding: 0.5rem;
  margin-bottom: 1.25rem;
  -webkit-box-shadow: inset 0px 0px 0px 0.4375rem #fff4e9, inset 0px 0px 0px 0.625rem #1e1e1e;
          box-shadow: inset 0px 0px 0px 0.4375rem #fff4e9, inset 0px 0px 0px 0.625rem #1e1e1e;
}
@media screen and (max-width: 767px) {
  .contents_item .contents_item_image {
    padding: 0.25rem;
    -webkit-box-shadow: inset 0px 0px 0px 0.1875rem #fff4e9, inset 0px 0px 0px 0.625rem #1e1e1e;
            box-shadow: inset 0px 0px 0px 0.1875rem #fff4e9, inset 0px 0px 0px 0.625rem #1e1e1e;
  }
}
@media screen and (max-width: 576px) {
  .contents_item .contents_item_image {
    width: 100%;
  }
}
.contents_item .contents_item_text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.contents_item .contents_item_text .contents_text_inner {
  position: relative;
}
.contents_item .contents_item_text .contents_text_inner h3 {
  border-top: 0.0625rem solid #1e1e1e;
  border-bottom: 0.0625rem solid #1e1e1e;
  padding: 1.5rem 0;
  font-weight: 700;
  font-size: 1.625rem;
  letter-spacing: 0.0625rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contents_item .contents_item_text .contents_text_inner h3 {
    font-size: 1.5rem;
    padding: 1.25rem 0;
  }
}
@media screen and (max-width: 576px) {
  .contents_item .contents_item_text .contents_text_inner h3 {
    font-size: 1.125rem;
    padding: 0.75rem 0;
  }
}
.contents_item .contents_item_text .contents_text_inner p.text {
  position: relative;
  z-index: 2;
  padding: 1.5rem 0;
  border-bottom: 0.0625rem solid #1e1e1e;
}
@media screen and (max-width: 767px) {
  .contents_item .contents_item_text .contents_text_inner p.text {
    padding: 1.25rem 0;
  }
}
@media screen and (max-width: 576px) {
  .contents_item .contents_item_text .contents_text_inner p.text {
    padding: 0.75rem 0;
  }
}