.container {
  margin: 0 auto;
  /* width: 80%; */
  width: 85%;
}

.mv {
  padding: 0 0 100px;
  position: relative;
}

.mv_inner {
  /* border-radius: 300px 300px 50px 50px; */
  overflow: hidden;
  /* height: 450px; */
}

.mv_inner.post01 img {
  /* aspect-ratio: 1187 / 800;
  margin: -43px 0 0; */
}

.heading {
  padding: 0 0 110px;
  position: relative;
}

.heading::before {
  border-left: 1px solid #b6b6b6;
  content: "";
  position: absolute;
  top: -64px;
  right: 0;
  left: 0;
  height: 45px;
  margin: auto;
  width: 1px;
}

.heading::after {
  border-left: 1px solid #b6b6b6;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 87px;
  margin: auto;
  width: 1px;
}

.heading_title {
  color: #000;
  font-size: 24px;
  line-height: 38px;
  margin: 0 0 20px;
  text-align: center;
}

.heading_text {
  color: #3c3c3c;
  font-size: 17px;
  line-height: 38px;
  text-align: center;
}

.post {
  padding: 0 0 100px;
}

.post_inner {
  padding: 70px 0 120px;
}

.post_contents {
  background-color: #fff;
  border: 1px solid #b6b6b6;
  border-radius: 200px 200px 166px 166px;
  box-shadow: 0 10px 20px #efefef;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 100px 20px 20px;
  position: relative;
}

.post_contents::before {
  background-image: url("../img/page/post_contents_head.jpg");
  background-size: 100%;
  content: "";
  position: absolute;
  top: -5px;
  right: 0;
  left: 0;
  margin: auto;
  height: 73px;
  width: 135px;
}

.post_contents::after {
  background-image: url("../img/page/post05/bottom_embellishments.png");
  background-size: 100%;
  content: "";
  position: absolute;
  right: 0;
  bottom: 20px;
  left: 0;
  margin: auto;
  height: 50px;
  width: 909px;
}

.post_item {
  position: relative;
  margin: 0 auto 100px;
  width: 86%;
}

.post_item.adjust_mb {
  margin: 0 auto 200px;
}

.post_item.col_right {
  margin: 0 auto 70px;
}

.post_item.post_item_dots {
  margin: 0 0 140px;
}

.post_item.pc_mb40 {
  margin: 0 auto 40px;
}

.post_item_dots::after {
  background-image: url("../img/page/post05/post_item_dots.png");
  background-size: 100%;
  content: "";
  position: absolute;
  right: 0;
  bottom: -44px;
  left: -116px;
  margin: auto;
  height: 3px;
  width: 1066px;
}

.post_item > .half {
  width: 45%;
}

.post_item > .right {
  margin: 0 0 0 auto;
}

.post_item > p:last-of-type {
  margin: 0;
  padding: 0;
}

.post_item > p.right:last-of-type {
  margin: 0 0 0 auto;
  padding: 0;
}

.post_item_title {
  color: #000;
  font-size: 24px;
  line-height: 38px;
  padding: 0 0 40px;
}

.post_item_head {
  color: #3c3c3c;
  font-size: 17px;
  font-weight: bold;
  line-height: 35px;
  padding: 0 0 40px;
  text-align: justify;
}

.post_item_text {
  color: #3c3c3c;
  font-size: 17px;
  line-height: 35px;
  padding: 0 0 40px;
  text-align: justify;
}

.post_item_text .orange {
  color: #d2591f;
  font-weight: bold;
}

.post_item_text .green {
  color: #3a8c61;
  font-weight: bold;
}

.post_item_text.adjust_mt {
  margin: 140px 0 0;
}

.post_item_img {
  margin: 0 auto 60px;
  width: 80%;
}

.post_careerList {
  position: absolute !important;
  top: 80px;
  right: -20px;
  width: 400px;
}

.post_img {
  position: absolute !important;
  top: 20px;
  right: -155px;
  width: 567px;
}

.post_profile {
  position: absolute !important;
  top: 80px;
  right: -152px;
  width: 600px;
}

.post_profile.left {
  position: absolute;
  top: 0;
  left: -132px;
  width: 600px;
}

.post_profile.right {
  position: absolute !important;
  top: 0;
  right: -142px;
  width: 584px;
}

.post_profile.post_profile01 {
  position: absolute !important;
  top: 40px;
  right: 20px;
  width: 357px;
}

.post_profile_texts {
  background-color: #faf500;
  margin: -60px auto 0;
  border-radius: 100px;
  padding: 40px 50px 40px 60px;
  width: 410px;
  position: relative;
}

.post_profile.left .post_profile_texts {
  margin: -60px auto 0;
  padding: 40px 50px 40px 60px;
  width: 456px;
}

.post_profile.right .post_profile_texts {
  background-color: #faf500;
  margin: -30px 0 0 30px;
  border-radius: 100px;
  padding: 40px 50px 40px 60px;
  width: 470px;
  position: relative;
}

.post_profile.post_profile01 .post_profile_texts {
  background-color: #faf500;
  margin: -60px auto 0;
  border-radius: 120px;
  padding: 40px 50px 40px 60px;
  position: relative;
  width: 357px;
}

.post_profile_head {
  font-size: 17px;
  line-height: 24px;
  margin: 0 0 6px;
}

.post_profile_name {
  font-size: 24px;
  line-height: 38px;
  margin: 0 0 10px;
}

.post_profile_text {
  font-size: 15px;
  line-height: 28px;
}

.post_bar {
  position: relative;
}

.post_bar.w100 {
  width: 100%;
}

.post_bar::before {
  background-image: url("../img/page/post05/post_item_dots.png");
  background-size: 100%;
  content: "";
  position: absolute;
  right: 0;
  top: -60px;
  left: -12px;
  margin: auto;
  height: 3px;
  width: 1066px;
}

.post_lists {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin: 40px auto 140px;
  width: 84%;
}

.post_lists > div:nth-of-type(1) {
  width: 45.4%;
}

.post_lists > div:nth-of-type(2) {
  width: 44.6%;
}

.circle04,
.circle05 {
  position: relative;
}

.circle04::after {
  background-image: url("../img/page/bg_circle04.png");
  background-size: 100%;
  content: "";
  position: absolute;
  top: -100px;
  right: -50px;
  animation: sway 14s linear infinite;
  opacity: 0.5;
  height: 400px;
  width: 400px;
  z-index: -1;
}

.circle05::after {
  background-image: url("../img/page/bg_circle05.png");
  background-size: 100%;
  content: "";
  position: absolute;
  top: 1200px;
  right: -200px;
  animation: sway 20s linear infinite;
  opacity: 0.5;
  height: 400px;
  width: 400px;
  z-index: -1;
}

.circle06::after {
  background-image: url("../img/page/bg_circle06.png");
  background-size: 100%;
  content: "";
  position: absolute;
  bottom: 1300px;
  right: -300px;
  animation: sway 20s linear infinite;
  opacity: 0.5;
  height: 461px;
  width: 514px;
  z-index: -1;
}

@keyframes sway {
  0% {
    transform: translate(-100px, 0);
  }

  25% {
    transform: translate(0, 100px);
  }

  50% {
    transform: translate(100px, 0);
  }

  75% {
    transform: translate(0, 100px);
  }

  100% {
    transform: translate(-100px, 0);
  }
}

.post_qa {
  background-color: #fffbdc;
  border-radius: 0 0 166px 166px;
  position: relative;
}

.post_qa_head {
  position: absolute;
  top: -130px;
  right: 0;
  left: 0;
  margin: 0 auto 50px;
  width: 32.5%;
}

.post_qa_contents {
  padding: 140px 0 50px;
  margin: 0 auto;
  width: 84%;
}

.post_qa_item {
  margin: 0 0 40px;
}

.post_qa_item_head {
  color: #843e0c;
  font-size: 21px;
  line-height: 1.6em;
  margin: 0 0 30px;
  padding: 0 0 0 50px;
  position: relative;
}

.post_qa_item_head::before {
  background-image: url("../img/page/post05/post_qa_icon.png");
  background-size: 100%;
  background-position: center;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  height: 43.5px;
  width: 43.5px;
}

.post_qa_item_text {
  color: #3c3c3c;
  font-size: 17px;
  line-height: 35px;
  padding: 0 0 20px;
  text-align: justify;
}

.post_qa_item_text.bold {
  font-weight: bold;
}

.post_qa_item_text .orange {
  color: #d2591f;
  font-weight: bold;
}

.post_qa_item_caption {
  color: #7c7c7c;
  font-size: 12px;
  line-height: 1.8em;
  padding: 0 0 20px;
  text-align: justify;
}

@media screen and (max-width: 1366px) {
  .mv {
    padding: 0 0 7.321vw;
  }

  .heading {
    padding: 0 0 8.053vw;
  }

  .heading::before {
    top: -4.685vw;
    height: 3.294vw;
    width: 0.073vw;
  }

  .heading::after {
    height: 6.369vw;
    width: 0.073vw;
  }

  .heading_title {
    font-size: 1.757vw;
    line-height: 2.782vw;
    margin: 0 0 1.464vw;
  }

  .heading_text {
    font-size: 1.245vw;
    line-height: 2.782vw;
  }

  .post {
    padding: 0 0 7.321vw;
  }

  .post_inner {
    padding: 5.124vw 0 8.785vw;
  }

  .post_contents {
    border-radius: 14.641288vw 14.641288vw 12.152269vw 12.152269vw;
    box-shadow: 0 .732vw 1.464vw #efefef;
    padding: 7.321vw 1.464vw 1.464vw;
  }

  .post_contents::before {
    top: -0.366vw;
    height: 5.344vw;
    width: 9.883vw;
  }

  .post_contents::after {
    bottom: 1.464vw;
    height: 3.66vw;
    width: 66.545vw;
  }

  .post_item {
    margin: 0 auto 7.321vw;
  }

  .post_item.col_right {
    margin: 0 auto 5.124451vw;
  }

  .post_item.post_item_dots {
    margin: 0 0 10.249vw;
  }

  .post_item.pc_mb40 {
    margin: 0 auto 2.928vw;
  }

  .post_item_dots::after {
    bottom: -3.221vw;
    left: -8.492vw;
    height: 0.22vw;
    width: 78.038vw;
  }

  .post_item_title {
    font-size: 1.757vw;
    line-height: 2.782vw;
    padding: 0 0 2.928vw;
  }

  .post_item_head {
    font-size: 1.245vw;
    line-height: 2.562vw;
    padding: 0 0 2.928vw;
  }

  .post_item_text {
    font-size: 1.245vw;
    line-height: 2.562vw;
    padding: 0 0 2.928vw;
  }

  .post_item_text.adjust_mt {
    margin: 10.248902vw 0 0;
  }

  .post_item_img {
    margin: 0 auto 4.392387vw;
  }

  .post_careerList {
    top: 5.857vw;
    right: -1.464vw;
    width: 29.283vw;
  }

  .post_img {
    top: 1.464vw;
    right: -11.347vw;
    width: 41.508vw;
  }

  .post_profile {
    top: 5.857vw;
    right: -11.127vw;
    width: 43.924vw;
  }

  .post_profile.left {
    top: 0;
    left: -9.663vw;
    width: 43.924vw;
  }

  .post_profile.right {
    right: -10.395315vw;
    width: 42.752562vw;
  }

  .post_profile.post_profile01 {
    top: 2.928258vw;
    right: 1.464129vw;
    width: 26.1347vw;
  }

  .post_profile_texts {
    margin: -4.392vw auto 0;
    border-radius: 7.321vw;
    padding: 2.928vw 3.66vw 2.928vw 4.392vw;
    width: 30.015vw;
  }

  .post_profile.left .post_profile_texts {
    margin: -4.392vw auto 0;
    padding: 2.928vw 3.66vw 2.928vw 4.392vw;
    width: 33.382vw;
  }

  .post_profile.right .post_profile_texts {
    margin: -2.196193vw 0 0 2.196193vw;
    border-radius: 7.320644vw;
    padding: 2.928258vw 3.660322vw 2.928258vw 4.392387vw;
    width: 34.407028vw;
  }

  .post_profile.post_profile01 .post_profile_texts {
    margin: -4.392387vw auto 0;
    border-radius: 8.784773vw;
    padding: 2.928258vw 3.660322vw 2.928258vw 4.392387vw;
    width: 26.1347vw;
  }

  .post_profile_head {
    font-size: 1.245vw;
    line-height: 1.757vw;
    margin: 0 0 0.439vw;
  }

  .post_profile_name {
    font-size: 1.757vw;
    line-height: 2.782vw;
    margin: 0 0 0.732vw;
  }

  .post_profile_text {
    font-size: 1.098vw;
    line-height: 2.05vw;
  }

  .post_bar::before {
    top: -4.392vw;
    left: -0.878vw;
    height: 0.22vw;
    width: 78.038vw;
  }

  .post_lists {
    margin: 2.928258vw auto 10.249vw;
  }

  .circle04::after {
    top: -7.321vw;
    right: -3.66vw;
    height: 29.283vw;
    width: 29.283vw;
  }

  .circle05::after {
    top: 87.848vw;
    left: -14.641vw;
    height: 29.283vw;
    width: 29.283vw;
  }

  .circle06::after {
    bottom: 95.168vw;
    right: -21.962vw;
    height: 33.748vw;
    width: 37.628vw;
  }

  .post_qa {
    border-radius: 0 0 12.152269vw 12.152269vw;
  }
  
  .post_qa_head {
    top: -9.516837vw;
    margin: 0 auto 3.660322vw;
  }
  
  .post_qa_contents {
    padding: 10.248902vw 0 3.660322vw;
  }
  
  .post_qa_item {
    margin: 0 0 2.928258vw;
  }
  
  .post_qa_item_head {
    font-size: 1.537335vw;
    margin: 0 0 2.196193vw;
    padding: 0 0 0 3.660322vw;
  }
  
  .post_qa_item_head::before {
    height: 3.18448vw;
    width: 3.18448vw;
  }
  
  .post_qa_item_text {
    font-size: 1.24451vw;
    line-height: 2.562225vw;
    padding: 0 0 1.464129vw;
  }
  
  .post_qa_item_caption {
    font-size: 0.878477vw;
    padding: 0 0 1.464129vw;
  }
}

@media screen and (max-width: 768px) {
  .container {
    max-width: 100%;
    width: 90%;
  }

  .mv {
    padding: 0 0 23.321vw;
  }

  .heading {
    padding: 0 0 40.053vw;
  }

  .heading::before {
    top: -16.685vw;
    height: 12vw;
    width: 0.533vw;
  }

  .heading::after {
    bottom: 12vw;
    height: 23.2vw;
    width: 0.533vw;
  }

  .heading_title {
    font-size: 6.4vw;
    line-height: 10.133vw;
    margin: 0 0 8vw;
  }

  .heading_text {
    font-size: 4.533vw;
    line-height: 9.867vw;
    text-align: center;
  }

  .post_inner {
    padding: 0 0 24.785vw;
  }

  .post_contents {
    border: 0.267vw solid #b6b6b6;
    padding: 26.667vw 1.6vw 0;
  }

  .post_contents::before {
    top: -1.6vw;
    height: 19.2vw;
    width: 35.467vw;
  }

  .post_contents::after {
    background-image: url("../img/page/post05/bottom_embellishments_sp.png");
    bottom: 1.6vw;
    height: 15.467vw;
    width: 87.467vw;
  }

  .post_item.sp_adjust {
    margin: 0 auto;
  }

  .post_item.sp_mt {
    margin: 100vw 0 10vw;
    width: 88%;
  }

  .post_item {
    margin: 0 auto 180vw;
    width: 88%;
  }

  .post_item.sp_flex_column {
    display: flex;
    flex-direction: column;
    margin: 0 auto 186vw;
  }

  .post_item > .half {
    order: 2;
    width: 100%;
  }

  .post_item.col_right {
    padding: 0;
    margin: 0 0 164vw;
  }

  .post_item.post_item_dots {
    margin: 0 0 24vw;
  }

  .post_item.pc_mb40 {
    margin: 0 auto 154vw;
  }

  .post_profile_img {
    width: 120%;
  }

  .post_item_title {
    font-size: 6.4vw;
    line-height: 10.133vw;
    padding: 0 0 5.333vw;
    text-align: center;
  }

  .post_item_head {
    font-size: 4.533vw;
    line-height: 9.333vw;
    padding: 0 0 5.333vw;
  }

  .post_item_text {
    font-size: 4.533vw;
    line-height: 9.333vw;
    padding: 0 0 10vw;
  }

  .post_item_dots::after {
    background-image: url("../img/page/post_item_dots_sp.png");
    bottom: -12.221vw;
    left: 0;
    right: 0;
    height: 0.8vw;
    width: 23.467vw;
  }

  .post_profile {
    top: unset;
    bottom: -166vw;
    right: -35.733vw;
    width: 114.667vw;
  }

  .post_profile_texts {
    margin: -6.321vw 0 0 auto;
    border-radius: 26.667vw;
    padding: 8vw 0 8vw 16vw;
    width: 100%;
  }

  .post_profile.left {
    top: unset;
    bottom: -162vw;
    left: -50.733vw;
    width: 130.667vw;
  }

  .post_profile.right {
    top: unset;
    bottom: -162vw;
    right: -50.733vw;
    width: 130.667vw;
  }

  .post_profile.post_profile01 {
    top: 233.928258vw;
    right: 0;
    left: 0;
    margin: auto;
    width: 100%;
  }

  .post_profile_img {
    width: 100%;
  }

  .post_profile.left .post_profile_img {
    margin: 0;
    width: 100%;
  }

  .post_profile.post_profile01 .post_profile_texts {
    margin: -16vw auto 0;
    border-radius: 26.667vw;
    padding: 10.666667vw 10.133333vw;
    width: 100%;
  }

  .post_profile.left .post_profile_texts {
    margin: -9.321vw 0 0 auto;
    border-radius: 26.667vw;
    padding: 8vw 14vw 8vw 51vw;
    width: 100%;
  }

  .post_profile.right .post_profile_texts {
    margin: -9.321vw 0 0 auto;
    border-radius: 26.667vw;
    padding: 8vw 51vw 8vw 14vw;
    width: 100%;
  }

  .post_profile_head {
    font-size: 3.733vw;
    line-height: 8.267vw;
  }

  .post_profile_name {
    font-size: 5.333vw;
    line-height: 5.333vw;
    margin: 0 0 3.733vw;
  }

  .post_profile_text {
    font-size: 3.2vw;
    line-height: 6.133vw;
  }

  .post_lists {
    flex-direction: column;
    margin: 0 auto 35.249vw;
    width: 96%;
  }

  .post_lists > div:not(:last-of-type) {
    margin: 0 auto 20vw;
  }

  .post_lists > div:nth-of-type(1) {
    width: 100%;
  }
  
  .post_lists > div:nth-of-type(2) {
    width: 100%;
  }

  .post_img {
    top: -100vw;
    right: unset;
    left: -16%;
    width: 100vw;
  }

  .post_img .post_profile_img {
    width: 100%;
  }

  .post_item_img {
    margin: 0 auto 18.392387vw;
    width: 100%;
  }

  .post_careerList {
    order: 1;
    padding: 0 0 12vw;
    position: unset !important;
    width: 100%;
  }

  .post_bar {
    margin: 0 auto 30vw;
    width: 100%;
  }

  .post_bar::before {
    background-image: url("../img/page/post_item_dots_sp.png");
    top: -16vw;
    left: 0;
    right: 0;
    height: 0.8vw;
    width: 23.467vw;
  }

  .post_bar.w100 {
    margin: 0 auto;
    padding: 26vw 0 0;
  }

  .circle04::after,
  .circle05::after,
  .circle06::after {
    content: unset;
  }

  .post_qa {
    border-radius: 0 0 15.641288vw 15.641288vw;
    padding: 0 0 18vw;
    margin: 0 0 1.6vw;
  }

  .post_qa_contents {
    padding: 40vw 0 3.660322vw;
    margin: 6vw auto 0;
    width: 86%;
  }

  .post_qa_head {
    top: -28.516837vw;
    margin: 0 auto;
    width: 92%;
  }

  .post_qa_item {
    margin: 0 0 30px;
  }

  .post_qa_item_head {
    font-size: 21px;
    margin: 0 0 20px;
    padding: 80px 0 0;
  }

  .post_qa_item_head::before {
    top: 0;
    right: 0;
    bottom: unset;
    left: 0;
    height: 60px;
    width: 60px;
  }

  .post_qa_item_text {
    font-size: 17px;
    line-height: 2em;
    padding: 0 0 1em;
  }

  .post_qa_item_caption {
    font-size: 12px;
    line-height: 2em;
    padding: 0 0 1em;
  }
}
