@charset "utf-8";

.mov_cont_wrap.cat03::before {
  top: auto;
  bottom: 0.80rem;
  height: 4.1rem;
}
@media screen and (max-width: 640px) {
  .mov_cont_wrap.cat03::before {
    height: 4.00rem;
  }
}

@media screen and (max-width: 640px) {
  .mov_cont_wrap {
    margin-top: 0.2rem;
  }
}

/*============================
MV
============================*/
.interview_wrap {
  padding-bottom: 1.00rem;
}
@media screen and (max-width: 640px) {
  .interview_wrap {
    padding-bottom: 0.30rem;
  }
}

.interview_wrap .mv {
  width: 100%;
  height: 65vh;
  min-height: 6rem;
  max-height: 6rem;
  position: relative;
  overflow-y: hidden;
  background-color: #F1F1F1;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv {
    min-height: 2.5rem;
    height: 38vh;
    position: relative;
  }
}

.interview_wrap .mv .ph {
  display: block;
  width: 100%;
  max-width: 11.00rem;
  position: absolute;
  bottom: -0.50rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 0;
  margin: auto;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv .ph {
    bottom: 0;
  }
}

.interview_wrap .mv .ph img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.interview_wrap .mv .txt_box {
  position: absolute;
  width: 100%;
  max-width: 12.00rem;
  top: 0.40rem;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv .txt_box {
    max-width: 100%;
    box-sizing: border-box;
    top: 0.30rem;
    left: auto;
    transform: none;
    text-align: center;
    z-index: 2;
  }
}

.interview_wrap .mv .txt_box .en {
  font-size: 0.20rem;
  font-family: 'Poppins', sans-serif;
  color: #fb903b;
  letter-spacing: 0.05em;
  font-weight: 600;
  display: inline-block;
  padding-bottom: 0.05rem;
  border-bottom: 0.02rem solid #fb903b;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv .txt_box .en {
    font-size: 0.12rem;
    padding-bottom: 0.02rem;
  }
}

.interview_wrap .mv .txt_box .ttl {
  font-size: 0.60rem;
  font-weight: 300;
  letter-spacing: 0.1em;
  margin-bottom: 0.30rem;
  padding-top: 0.30rem;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv .txt_box .ttl {
    font-size: 0.40rem;
    font-weight: 400;
    padding-top: 0.15rem;
    margin-bottom: 0.15rem;
  }
}

.interview_wrap .mv .txt_box .txt {
  font-size: 0.18rem;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 640px) {
  .interview_wrap .mv .txt_box .txt {
    font-size: 0.14rem;
    line-height: 1.6;
  }
}

.staff_list {
  padding-top: 1.00rem;
  padding-bottom: 0.40rem;
  max-width: 10.00rem;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 640px) {
  .staff_list {
    padding-top: 0.30rem;
    padding-bottom: 0.30rem;
  }
}

.staff_list::before {
  content: "";
  width: calc(100% + 0.40rem);
  height: calc(100% - 1.50rem);
  border-radius: 0.20rem;
  position: absolute;
  bottom: 0;
  left: -0.20rem;
  background-color: #feefd8;
  z-index: 0;
}
@media screen and (max-width: 640px) {
  .staff_list::before {
    width: 100%;
    height: 100%;
    left: 0;
    border-radius: 0;
  }
}

.staff_list .list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.40rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .staff_list .list {
    gap: 0.20rem;
  }
}

.staff_list .list .staff {
  width: 30%;
}
@media screen and (max-width: 640px) {
  .staff_list .list .staff {
    width: 100%;
    padding: 0 0.20rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0 0.20rem;
    box-sizing: border-box;
  }
}

.staff_list .list .staff .ph {
  width: 1.40rem;
  height: 1.40rem;
  overflow: hidden;
  border-radius: 50%;
  margin: auto;
  border: 0.03rem solid #FFF;
}
@media screen and (max-width: 640px) {
  .staff_list .list .staff .ph {
    width: 0.80rem;
    height: 0.80rem;
  }
}

.staff_list .list .staff .ph img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.staff_list .list .staff .txt_box {
  text-align: center;
  padding-top: 0.15rem;
  line-height: 1.6;
  font-size: 0.13rem;
}
@media screen and (max-width: 640px) {
  .staff_list .list .staff .txt_box {
    text-align: left;
    padding-top: 0;
    line-height: 1.4;
    font-size: 0.13rem;
    width: calc(100% - 0.80rem - 0.20rem);
  }
}

.staff_list .list .staff .txt_box .name {
  font-size: 0.16rem;
  font-weight: 600;
  padding-bottom: 0.10rem;
}

.staff_list .list .staff .txt_box .name span::after {
  content: "さん";
  font-size: 0.12rem;
  display: inline-block;
  padding-left: 0.04rem;
}


.interview_cont {
  width: 100%;
  max-width: 10.00rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.40rem 0;
  margin: auto;
  padding-top: 0.80rem;
}
@media screen and (max-width: 640px) {
  .interview_cont {
    max-width: 100%;
    padding: 0.40rem 0.20rem 0.10rem;
    box-sizing: border-box;
    gap: 0.30rem 0;
  }
}

.interview_cont .question {
  font-size: 0.18rem;
  font-weight: 700;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .interview_cont .question {
    font-size: 0.16rem;
    font-weight: 700;
    width: 100%;
    line-height: 1.75;
  }
}

.interview_cont .question::before {
  content: "";
  width: 0.40rem;
  height: 1px;
  background-color: #000;
  display: inline-block;
  margin-right: 0.20rem;
  vertical-align: middle;
}
@media screen and (max-width: 640px) {
  .interview_cont .question::before {
    width: 0.20rem;
    height: 1px;
    background-color: #000;
    display: inline-block;
    margin-right: 0.10rem;
    vertical-align: middle;
    position: relative;
    top: -0.02rem;
  }
}

.interview_cont .voice {
  display: flex;
  gap: 0 0.30rem;
}
@media screen and (max-width: 640px) {
  .interview_cont .voice {
    gap: 0.10rem 0.10rem;
  }
}

.interview_cont .voice .staff_box {
  width: 1.00rem;
  text-align: center;
}

.interview_cont .voice .staff_box .ph {
  width: 0.80rem;
  height: 0.80rem;
  border-radius: 50%;
  overflow: hidden;
  margin: auto;
}

.interview_cont .voice .staff_box .ph img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.interview_cont .voice .staff_box .name {
  font-size: 0.13rem;
  font-weight: 600;
  padding-top: 0.10rem;
}

.interview_cont .voice .staff_box .name span::after {
  content: "さん";
  font-size: 0.10rem;
  display: inline-block;
  padding-left: 0.04rem;
}

.interview_cont .voice .txt_box {
  width: calc(100% - 1.00rem);
  padding: 0.30rem;
  box-sizing: border-box;
  border-radius: 0.10rem;
  background-color: #F2F8E9;
  position: relative;
}
@media screen and (max-width: 640px) {
  .interview_cont .voice .txt_box {
    padding: 0.20rem;
  }
}

.interview_cont .voice .txt_box::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-right: 12px solid #F2F8E9;
  border-left: 0;
  position: absolute;
  top: 0.30rem;
  left: -0.10rem;
}

.interview_cont .voice .txt_box .txt {
  font-size: 0.14rem;
  line-height: 1.7;
}

.interview_cont .voice.-staff01 .txt_box {
  background-color: #F2F8E9;
}
.interview_cont .voice.-staff01 .txt_box::before {
  border-right-color: #F2F8E9;
}

.interview_cont .voice.-staff02 .txt_box {
  background-color: #DAF1F5;
}
.interview_cont .voice.-staff02 .txt_box::before {
  border-right-color: #DAF1F5;
}

.interview_cont .voice.-staff03 .txt_box {
  background-color: #faf3d7;
}
.interview_cont .voice.-staff03 .txt_box::before {
  border-right-color: #faf3d7;
}

.interview_wrap .bridge_ph {
  width: 100%;
  width: 12.00rem;
  height: 5.00rem;
  margin: 0.70rem auto 0;
  border-radius: 0.10rem;
  overflow: hidden;
}
@media screen and (max-width: 640px) {
  .interview_wrap .bridge_ph {
    width: 100%;
    height: 60vw;
    margin: 0.40rem auto 0;
    border-radius: 0;
  }
}

.interview_wrap .bridge_ph img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}