/*-------------------------------------------*/
/*共通*/
/*-------------------------------------------*/
main a, section a {
  text-decoration: none;
  color: #000;
  /*ベースの打消し*/
}

.work .flex, .satisfy .flex {
  gap: 20px;
}

.cue .flex {
  gap: 64px;
}

/*img {
  overflow: visible !important;
}:*/
.sp {
  display: none !important;
}

.pc {
  display: block !important;
}

@media screen and (max-width: 768px) {
  .sp {
    display: block !important;
  }

  .pc {
    display: none !important;
  }
}

/*-------------------------------------------*/
/*intro*/
/*-------------------------------------------*/

main section.intro {
  overflow-x: visible;
  margin-top: 126px;
}

.intro_wrap {
  position: relative;
}

.intro .heading {
  border-bottom: 1px dotted #e2e2e2;
  padding-bottom: 18px;
  margin-bottom: 22px;
}

.intro .heading_top {
  margin-bottom: 23px;
}

.intro .heading_bottom h2 {
  font-size: 4.1rem;
  line-height: 1.2;
  white-space: nowrap;
}


.intro .detail span {
  color: #fff;
  background-color: #36498f;
  padding: 3px 17px 2px 12px;
  display: inline-block;
  font-size: 1.5rem;
}

.intro .detail .join {
  font-size: 1.5rem;
  margin-top: 3px;
}

.intro .detail .name {
  font-size: 2.5rem;
}

.intro .image_block {
  position: relative;
  width: 30%;
}

.intro .flex {
  /* justify-content: space-between; */
  gap: 36px;
  margin-bottom: 200px;
}

.intro .text_block {
  margin-top: 50px;
}

.intro .image_block {
  position: relative;
  width: 47%;
}


.intro .image_wrap {
  position: relative;
  width: 100vw;
}

.intro .image_wrap img {
  width: 54.69%;
  object-fit: cover;
  object-position: top;
}

@media screen and (max-width: 768px) {
  .intro .flex {
    flex-direction: column;
  }

  .intro .image_wrap img {
    width: auto;
    object-fit: cover;
    object-position: top;
  }

  .intro .image_block {
    width: 100%;
  }

  .image_block.sp img {
    width: 100%;
  }

  .intro .heading_bottom h2 br {
    display: none;
  }

  .intro .heading_bottom h2 {
    font-size: 3.4rem;
    line-height: 1.2;
    white-space: normal;
    font-feature-settings: "palt";
  }
}

@media screen and (max-width: 480px) {
  main section.intro {
    margin-top: 50px;
  }

  .intro .heading_bottom h2 {
    font-size: 2.7rem;
  }

  .intro .detail span {
    background-color: #36498f;
    padding: 3px 17px 2px 12px;
    font-size: 1.2rem;
  }

  .intro .heading_top img {
    height: 15px;
  }

  .intro .detail .join {
    font-size: 1.4rem;
    margin-top: 6px;
  }

  .intro .detail .name {
    font-size: 2.0rem;
  }

  .intro .flex {
    margin-bottom: 80px;
  }

  .intro .heading_top {
    margin-bottom: 10px;
  }
}




/*-------------------------------------------*/
/*question_work*/
/*-------------------------------------------*/
section.work {
  margin-bottom: 140px;
}

.work .image_block {
  width: 100%;
}


.work .text_block {
  width: calc(100% - 50px);
  margin-top: 7px;
}

.work .text_block .question {
  font-weight: bold;
  color: #36498f;
  font-size: 2.0rem;
  border-bottom: 1px dotted #e1e1e1;
  margin-bottom: 40px;
  align-items: center;
  gap: 7px;
  padding-bottom: 7px;
}

.work .text_block .answer h3 span {
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 14px;
  display: block;
  line-height: 1.2;
}

.work .text_block .answer p {
  font-size: 1.6rem;
  font-weight: light;
  line-height: 1.7;
}

@media screen and (max-width: 1000px) {
  .work .text_block .answer h3 span br {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .work .flex {
    flex-direction: column-reverse;
  }

  .work .text_block .question {
    flex-direction: row;
  }

  .work .text_block {
    width: 100%;
    padding-right: 0px;
  }

  .work .text_block .answer h3 span {
    padding-left: 0px;
  }
}

@media screen and (max-width: 480px) {
  .work .text_block .question {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }

  .work .text_block .answer h3 span {
    font-size: 1.5rem;
  }

  .work .text_block .answer p {
    font-size: 1.3rem;
  }
}


/*-------------------------------------------*/
/*schdule*/
/*-------------------------------------------*/


.schedule {
  margin-bottom: 110px;
}

.bgc_white {
  background-color: #f8f8f8;
  padding-top: 100px;
  padding-bottom: 50px;
}

.schedule .heading {
  margin-bottom: 60px;
  display: flex;
  justify-content: center;
}

.schedule_content {
  padding-right: 30px;
  padding-left: 30px;
}

.schedule_box {
  background-color: #fff;
  border-radius: 10px;
  margin-bottom: 30px;
  box-shadow: 0px 5px 6px -6px rgba(0, 0, 0, 0.3);
}

.schedule_wrap.flex {
  padding: 36px;
}


.schedule_left.flex .detail span {
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 0px;
  margin-top: -6px;
  display: block;
}

.schedule_box:nth-child(2) .schedule_left.flex .detail span {
  margin-top: -8px
}

.schedule_box:nth-child(3) .schedule_left.flex .detail span {
  margin-top: -8px
}

.schedule_box:nth-child(4) .schedule_left.flex .detail span {
  margin-top: -7px
}

.schedule_box:nth-child(7) .schedule_left.flex .detail span, .schedule_box:nth-child(8) .schedule_left.flex .detail span {
  margin-top: -7px
}

.schedule_left.flex .detail p {
  font-size: 1.6rem;
  font-weight: light;
}

.schedule_right {
  flex-shrink: 0;
  margin-left: 22px;
}

.schedule_left.flex {
  gap: 20px;
}

.schedule_left.flex.morning {
  gap: 33px
}

.schedule_left .time {
  flex-shrink: 0;
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 20px;
}

.schedule_left .time::before {
  content: "";
  width: 14px;
  height: 14px;
  display: inline-block;
  background-color: #36498f;
  border-radius: 50%;
  margin-top: 5px;
  z-index: 10;
}

.schedule_left .time::after {
  content: "";
  width: 1px;
  height: calc(100% + 100px);
  border-left: 1px dotted #d3d3d3;
  position: absolute;
  top: 10%;
  left: 6.5px;
  z-index: 1;
}

.schedule_box:last-child .time::after {
  display: none;
}

@media screen and (max-width: 768px) {
  .schedule_wrap.flex {
    flex-direction: column;
    padding: 20px;
  }

  .schedule_right {
    flex-shrink: 0;
    margin-left: 0px;
    margin-top: 20px;
  }

  .schedule_left.flex .detail p br {
    display: none;
  }

  .schedule_left .time::before, .schedule_left .time::after {
    display: none;
  }

  .schedule_left.flex .detail span {
    margin-top: -8px;
  }
}

@media screen and (max-width: 480px) {
  .schedule_left.flex .detail p {
    font-size: 1.3rem;
  }

  .schedule_left.flex {
    flex-direction: column;
    gap: 0;
  }

  .schedule_content {
    padding-right: 0px;
    padding-left: 0px;
  }

  .schedule_left .time::before, .schedule_left .time::after {
    display: none;
  }

  .schedule_left.flex .detail span {
    font-size: 1.6rem;
    margin-top: 10px !important;
  }

  .schedule_box {
    margin-bottom: 15px;
  }

  .time img {
    height: 18px;
  }

  .schedule .heading img {
    height: 40px;
  }

  .bgc_white {
    padding-top: 60px;
    background-color: initial;
  }


  .schedule_left.flex.morning {
    gap: 0px;
  }

  .schedule {
    margin-bottom: 80px;
    background-color: #f8f8f8;
  }

}

/*-------------------------------------------*/
/*question_cue*/
/*-------------------------------------------*/
section.cue {
  margin-bottom: 130px;
}

.cue .image_block {
  width: 100%;
}


.cue .text_block {
  width: calc(100% - 50px);
  margin-top: 9px;
}

.cue .text_block .question {
  font-weight: bold;
  color: #36498f;
  font-size: 2.0rem;
  border-bottom: 1px dotted #e1e1e1;
  margin-bottom: 40px;
  align-items: center;
  gap: 7px;
  padding-bottom: 7px;
}

.cue .text_block .answer h3 span {
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 15px;
  display: block;
  line-height: 1.2;
}

.cue .text_block .answer p {
  font-size: 1.6rem;
  font-weight: light;
  line-height: 1.7;
}

@media screen and (max-width: 1000px) {
  .cue .text_block .answer h3 span br {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .cue .flex {
    flex-direction: column;
  }

  .cue .text_block .question {
    flex-direction: row;
  }

  .cue .text_block {
    width: 100%;
    padding-right: 0px;
  }

  .cue .text_block .answer p br {
    display: none;
  }
}

@media screen and (max-width: 480px) {
  .cue .text_block .question {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }

  .cue .text_block .answer h3 span {
    font-size: 1.5rem;
  }

  .cue .text_block .answer p {
    font-size: 1.3rem;
  }

  .cue .text_block .answer h3 span br {
    display: none;
  }

  section.cue {
    margin-bottom: 80px;
  }
}

/*-------------------------------------------*/
/*question_satisfy*/
/*-------------------------------------------*/
section.satisfy {
  margin-bottom: 158px;
}

.satisfy .image_block {
  width: 100%;
}


.satisfy .text_block {
  width: calc(100% - 50px);
  margin-top: 7px;
}

.satisfy .text_block .question {
  font-weight: bold;
  color: #36498f;
  font-size: 2.0rem;
  border-bottom: 1px dotted #e1e1e1;
  margin-bottom: 40px;
  align-items: center;
  gap: 7px;
  padding-bottom: 7px;
}

.satisfy .text_block .answer h3 span {
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 13px;
  display: block;
  line-height: 1.2;
}

.satisfy .text_block .answer p {
  font-size: 1.6rem;
  font-weight: light;
  line-height: 1.7;
}

@media screen and (max-width: 768px) {
  .satisfy .flex {
    flex-direction: column-reverse;
  }

  .satisfy .text_block .question {
    flex-direction: row;
  }

  .satisfy .text_block {
    width: 100%;
    padding-right: 0px;
  }

  .satisfy .text_block .answer h3 span br {
    /*display: none;*/
  }
}

@media screen and (max-width: 480px) {
  .satisfy .text_block .question {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }

  .satisfy .text_block .answer h3 span {
    font-size: 1.5rem;
  }

  .satisfy .text_block .answer p {
    font-size: 1.3rem;
  }

  .satisfy .text_block .answer h3 span br {
    display: none;
  }

  section.satisfy {
    margin-bottom: 80px;
  }

  .question span img {
    height: 24px;
  }
}


/*-------------------------------------------*/
/*message*/
/*-------------------------------------------*/

.message {
  margin-bottom: 190px;
}

.message .text_block {
  margin-bottom: 40px;
}

.message .text_block .massage_intro {
  margin-bottom: 19px;
}

.message .main_message .catch {
  margin-bottom: 20px;
}


.message .main_message .catch .catch_1 span, .message .main_message .catch .catch_2 span {
  background-color: #36498f;
  color: #fff;
  font-size: 2.9rem;
  font-weight: bold;
  padding: 5px 9px;
}

.message .main_message .catch .catch_2 span {
  padding-right: 19px;
}


.message .main_message .catch .catch_1 {
  margin-bottom: 15px;
}

.message .main_message .detail p {
  font-size: 1.6rem;
  line-height: 1.7;
  font-weight: light;
}

@media screen and (max-width: 768px) {
  .message .main_message .catch .catch_1 span, .message .main_message .catch .catch_2 span {
    font-feature-settings: "palt";
  }
}

@media screen and (max-width: 640px) {
  .message .main_message .catch .catch_1 span, .message .main_message .catch .catch_2 span {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 480px) {
  .message .main_message .detail p {
    font-size: 1.3rem;
  }

  .message .main_message .catch .catch_1 span, .message .main_message .catch .catch_2 span {
    font-size: 1.5rem;
    padding: 5px 5px;
    font-feature-settings: "palt";
  }

  .massage_intro span img {
    height: 14px;
  }

  .message .main_message .catch .catch_1 {
    margin-bottom: 8px;
  }
}



@media screen and (max-width: 340px) {
  .message .main_message .catch .catch_1 span, .message .main_message .catch .catch_2 span {
    font-size: 1.3rem;
  }
}