
img {
  vertical-align: bottom;
}
.btn01 a {
  background-color: #152e89;
  box-shadow: .3rem .5rem 0 0 #282a5b;
  text-align: center;
  display: block;
  padding: 2rem;
  font-weight: bold;
  font-size: 2rem;
  color: #fff;
  border-radius: 5px;
  max-width: 700px;
  margin: 0 auto;
}
.btn02 a {
  background-color: #04c755;
  box-shadow: .3rem .5rem 0 0 #018638;
  text-align: center;
  display: block;
  padding: 1.5rem;
  font-weight: bold;
  font-size: 2rem;
  color: #fff;
  border-radius: 5px;
  max-width: 700px;
  margin: 0 auto;
  margin-top: 3rem;
}
.fix_btn {
  display: none;
  width: 100%;
  padding: 1.5rem 2rem;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 100;
  background-color: rgba(0, 0, 0, 0.5);
}
.bold {
  font-weight: bold;
  font-size: 1.6rem;
}
.bold_2 {
  font-weight: bold;
}
.text_red {
  color: #ea0000;
}
.ft_25 {
  font-size: 2.5rem;
}
.ft_30 {
  font-size: 3rem;
}
.ft_35 {
  font-size: 3.5rem;
}

.btncap {
    margin-top: 1.5rem;
}
.logo_wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 3rem;
  margin-top: 2rem;
  gap: 10px;
  align-items: baseline;
}

.logo_wrapper span {
  font-weight: bold;
  margin-top: 1rem;
  display: inline-block;
  border-radius: 50px;
}
.logo_wrapper li {
  width: 20%;
  text-align: center;
}
.logo_wrapper li img {
  max-height: 65px;
  max-width: 150px;
  vertical-align: bottom;
}
.logo_title {
  padding: 1rem;
  background-color: #eff1f3;
  margin: 1rem 0;
  border-radius: 50px;
  text-align: center;
}
.logo_title span {
  font-weight: bold;
  font-size: 1.6rem;
  display: inline-block;
  vertical-align: middle;
}
.logo_title img {
  width: 19%;
}
.detail_img {
  text-align: center;
  margin-top: 3rem;
}
/*flow_area*/
.flow_area {
  margin-bottom: 5rem;
}
.flow {
	margin-top: 4rem;
	padding: 0 2rem;
  margin-bottom: 4rem;
}
.flow li {
	display: flex;
	align-items: center;
	position: relative;
}
.flow li:nth-of-type(2), .flow li:nth-of-type(3){
	align-items: flex-start;
}
.flow li:first-child{
	align-items: flex-start;
}
.flow li + li {
	margin-top: 7rem;
}
.flow li>div {
	display: flex;
	align-items: center;
}
.flow li:nth-of-type(2)>div,
.flow li:nth-of-type(4)>div  {
align-items: flex-start;
}
.flow li::after {
content: "";
  display: block;
  border-left: dotted 2px #362c12;
  position: absolute;
  top: 6rem;
  left: 3.2rem;
  height: calc(100% - -55px);
  z-index: -100;
}
.flow li:nth-of-type(4)::after {
	content: none;
}
.flow li .icon_step {
	padding-right: 1.5rem;
  z-index: 200;
}
.flow li .detail_eria h3 {
	font-size: 2rem;
  padding-left: 2rem;
}
.flow li .detail_eria>.text {
	font-size: 1.6rem;
	margin-top: .5rem;
  margin-left: 2rem;
}
.icon_img {
  padding-left: 2rem;
  margin-top: 1rem;
}
.detail_eria .flex-wrapper {
  justify-content: left;
  padding: 0;
  margin-top: 1rem;
}
.flex_text {
  margin-left: 1rem;
  margin-top: 1rem;
  font-size: 1.3rem;
}
.detail_eria .btn {
  background-color: #152e89;
  padding: 1rem 2rem;
  border-radius: 10px;
  color: #fff;
  font-size: 1.6rem;
  margin: 0;
  border: none;
}
.detail_eria .sub_text {
  margin-top: 1rem;
  font-weight: bold;
}
/*END===flow_area*/

@media screen and (min-width:730px) and (max-width:1024px){
.logo_wrapper {
  gap: 25px;
}
.flow li::after {
  left: 3.5rem;
  top: 6.5rem;
  z-index: 100;
  height: calc(100% - -42px);
}
}
@media screen and (min-width:660px) and (max-width:730px){
.flow li::after {
  left: 4.5rem;
  top: 0rem;
  z-index: 100;
}
}
@media screen and (max-width:659px) {
.bold {
  font-weight: bold;
  font-size: 1.4rem;
}
.btn01 a {
  padding: 1.2rem;
  font-size: 1.5rem;
  border-radius: 10px;
  }
.btn02 a {
  padding: 1.2rem;
  font-size: 1.5rem;
  border-radius: 10px;
  margin-bottom: 4rem;
  }
.ft_25 {
font-size: 2rem;
}
.ft_30 {
  font-size: 1.8rem;
}
.ft_35 {
  font-size: 2rem;
}
.logo_wrapper {
  align-items: baseline;
  gap: 15px;
  margin-top: 2rem;
}
.logo_wrapper li {
  width: 40%;
  text-align: center;
}
.logo_wrapper li img {
    max-height: 70px;
    max-width: 90%;
  }
.logo_wrapper li:nth-of-type(n+3) {
    margin-top: 1.5rem;
  }
.logo_title img {
  max-height: 28px;
  width: auto;
  max-width: 100%;
  vertical-align: middle;
}
.logo_area {
  margin-bottom: 3rem;
}
.logo_area.logotop {
  margin-top: 2rem;
}
.logo_title {
  padding: 0.5rem;
}
.logo_title span {
  font-size: 1.3rem;
}
.detail_img {
  margin-top: 2rem;
}

/*flow_area*/
.flow_area {
  margin-bottom: 3rem;
}
.flow {
  margin-top: 3rem;
  padding: 0;
  margin-bottom: 3rem;
	}
	h2 {
		line-height: 0;
	}
	.flow li {
		align-items: flex-start;
	}
	.flow li + li {
  margin-top: 5rem;
}
	.flow li::after {
		top: 3.5rem;
    left: 2.2rem;
    height: calc(100% - -25px);
    z-index: 100;
	}
	.flow li .icon_step {
	  padding-right: 0.2rem;
		max-width: 70px;
		width: 15%;
	}
	.flow li>div {
		display: flex;
		flex-direction: column;
		width: 85%;
		text-align: left;
	}
	.flow li .detail_eria {
		width: 100%;
	}
	.flow li .detail_eria h3 {
	  font-size: 1.6rem;
		margin-top: .5rem;
    padding-left: 1rem;
	}
	.flow li .detail_eria > .text {
		font-size: 1.3rem;
		text-align: left;
    margin-left: 1rem;
	}
	.flow li:nth-of-type(2) .detail_eria > .text {
		text-align: center;
	}
.detail_eria .btn {
  width: 80%;
  font-size: 1.2rem;
  line-height: 1.2;
}
.icon_img {
  padding-left: 1rem;
}
.detail_eria .flex-wrapper {
  margin-top: 0;
}
.flex_text {
  margin-left: 0;
  margin-top: 0.5rem;
  font-size: 1.2rem;
}
/*END===flow_area*/
}