@charset "UTF-8";

.contentpage .m_img_area{
	background-image: url(../images/first/m_img@2x.jpg);}


/* vision
---------------------------------------------------------*/
#vision .box1{
	position: relative;
	background: url("../images/first/img01@2x.jpg")no-repeat right center;
	background-size: cover;
	padding-top: min(120px,6vw);
	padding-bottom:min(200px,15vw);
}
#vision .box1::before{
	position: absolute;
	display: block;
	content: "";
	background: linear-gradient(to right,  rgba(122,156,29,1) 0%,rgba(122,156,29,0) 100%); 
	background-size: 100% auto;
	width: 80%;
	height: 100%;
	top:0;
	left: 0;
}
#vision .box1 .w1340{
	position: relative;
	z-index: 2;
}
#vision .box1 .titlebox{
	margin-bottom: min(80px,4vw);
}
#vision .box1 .titlebox .ft_zen{
	margin-top: min(.6em,1vw);
}
#vision .box1 .txtbox{
	width: 55%;
	max-width: 470px;
	padding-left: min(60px,3.5vw);
}
#vision .box1 .txtbox .zen46{
	margin-bottom: min(.6em,1.5vw);
}

#vision .box2{
	position: relative;
	padding-top: min(75px,4vw);
}
#vision .box2 .img_l{
	position: absolute;
	top: min(-100px,-0.5vw);
	left: 0;
	width:45%;
}
#vision .box2 .txt_r{
	width: 51%;
	max-width: 635px;
	margin-left: auto;
}
#vision .box2 .txt_r .zen18{
	margin-bottom: .3em;
}
#vision .box2 .txt_r .zen27{
	margin-bottom: .8em;
}
#vision .box2 .txt_r .txt{
	padding-right: min(50px,3vw);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#vision .box1{
	padding-bottom: 10vw;
}
#vision .box1 .txtbox{
	padding-left: 0;
}
#vision .box1::before{
	width: 100%;
}
#vision .box2 .img_l{
	width: 40%;
	top:-4vw;
	left: -4%;
}
#vision .box2 .txt_r{
	width: 61%;
	margin-right: -1%;
}
#vision .box2 .txt_r .zen18{
	margin-bottom: .1em;
	letter-spacing: normal;
}
#vision .box2 .txt_r .zen27{
	margin-bottom: .3em;
	margin-left: -0.5em;
	letter-spacing: normal;
}
#vision .box2 .txt_r .txt{
	padding-right: 0;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) {
#vision .box1{
	background-image: url("../images/first/img01_sp@2x.jpg");
	background-position: left center;
	padding-top: 8vw;
	padding-bottom: 13vw;
}
#vision .box1::before{
	width:110%;
	background: linear-gradient(to right,  rgba(122,156,29,1) 0%,rgba(122,156,29,0) 100%); 
}
#vision .box1 .titlebox{
	margin-bottom: 5vw;
}
#vision .box1 .titlebox .zen20{
	font-size:90%;
}
#vision .box1 .titlebox .ft_zen{
	margin-top: 1.5vw;
}
#vision .box1 .txtbox{
	width: 100%;
	max-width: 100%;
	padding-left: 0;
}
#vision .box1 .txtbox .zen46{
	margin-bottom: .4em;
}
#vision .box1 .txtbox dd{
	font-size: 88%;
}
	
#vision .box2{
	padding-top: 0;
}
#vision .box2 .img_l{
	position: static;
	width:75%;
	margin: -8vw auto 5%;
	text-align: center;
}
#vision .box2 .txt_r{
	width:100%;
	max-width:100%;
}
#vision .box2 .txt_r .zen18{
	margin-bottom: .2em;
}
#vision .box2 .txt_r .zen27{
	margin-bottom: .3em;
}
#vision .box2 .txt_r .txt{
	padding-right: 0;
}
}



/* yoyaku
---------------------------------------------------------*/
.fir_index{
	text-align: center;
	margin-bottom: min(70px,5vw);
}
.fir_index .ft_ro{
	color: #aeb1ac;
	margin-top: min(1em,1.2vw);
}

#yoyaku .flex_box{
	flex-flow: row-reverse;
}
#yoyaku .flex_box .img_r{
	width: 37%;
}
#yoyaku .flex_box .txt_l{
	width: 59%;
}
#yoyaku .flex_box .txt_l .txt1{
	border-bottom: 1px solid #bbbeba;
	padding-bottom: min(40px,3vw);
	margin-bottom: min(40px,3vw);
}
#yoyaku .flex_box .txt_l .txt1 .zen25{
	margin-bottom: .9em;
}
#yoyaku .flex_box .txt_l .txt2 .zen18{
	margin-bottom: .9em;
}
#yoyaku .flex_box .txt_l .txt2 li{
	position: relative;
	padding-left: 1em;
	box-sizing: border-box;
}
#yoyaku .flex_box .txt_l .txt2 li::before{
	position: absolute;
	display: block;
	content: "";
	background: #91ad2c;
	background-size: 100% auto;
	width: 3px;
	height: 1em;
	top:.5em;
	left: 0;
}

#yoyaku .yoyaku{
	background: #f3f4ef;
	border-radius: 10px;
	padding: 0 4%;
	padding-top: min(55px,4vw);
	padding-bottom: min(55px,4vw);
	box-sizing: border-box;
	text-align: center;
}
#yoyaku .yoyaku .yoyaku_tel p,
#yoyaku .yoyaku .yoyaku_tel div{
	display: inline-block;
	vertical-align: middle;
}
#yoyaku .yoyaku .yoyaku_tel p{
	margin-right: 1em;
}
#yoyaku .yoyaku .yoyaku_tel div{
	width: 20em;
}
#yoyaku .yoyaku .yoyaku_list{
	background: #fff;
	border-radius: 50px;
	max-width: 930px;
	margin: 0 auto;
	margin-top: min(30px,2.5vw);
	padding: 1em 1em;
	box-sizing: border-box;
}
#yoyaku .yoyaku .yoyaku_list li{
	line-height: 1.5em;
	display: inline-block;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#yoyaku .flex_box{
	display: block;
	overflow: hidden;
}
#yoyaku .flex_box .img_r{
	float: right;
	margin-left: 4%;
	margin-bottom: 1em;
}
#yoyaku .flex_box .txt_l{
	width: 100%;
}
#yoyaku .flex_box .txt_l .txt1{
	width: 57%;
}
#yoyaku .flex_box .txt_l .txt1 .zen25{
	margin-bottom: .5em;
}
#yoyaku .flex_box .txt_l .txt2 .zen18{
	margin-bottom: .5em;
}
#yoyaku .flex_box .txt_l .txt2 li{
	letter-spacing: normal;
	padding-left: .8em;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
.fir_index{
	margin-bottom: 8vw;
}
.fir_index .ft_ro{
	margin-top: 2vw;
}

#yoyaku .flex_box{
	display: block;
}
#yoyaku .flex_box .img_r{
	width: 75%;
	margin: 0 auto 4%;
}
#yoyaku .flex_box .txt_l{
	width: 100%;
}
#yoyaku .flex_box .txt_l .txt1{
	padding-bottom:5vw;
	margin-bottom: 5vw;
}
#yoyaku .flex_box .txt_l .txt1 .zen25{
	margin-bottom: .3em;
}
#yoyaku .flex_box .txt_l .txt2 .zen18{
	margin-bottom: .3em;
}
#yoyaku .flex_box .txt_l .txt2 li{
	padding-left: .8em;
}
#yoyaku .flex_box .txt_l .txt2 li::before{
	top:.4em;
}

#yoyaku .yoyaku{
	padding: 5% 4%;
}
#yoyaku .yoyaku .yoyaku_tel p,
#yoyaku .yoyaku .yoyaku_tel div{
	display: inline-block;
}
#yoyaku .yoyaku .yoyaku_tel p{
	margin-right: 0;
	margin-bottom: 2vw;
}
#yoyaku .yoyaku .yoyaku_list{
	margin-top: 5vw;
	padding:4% 5%;
	border-radius:10px;
}
}




/* flow
---------------------------------------------------------*/
#flow .bg{
	background: #9a9d97;
	margin-bottom: 10px;
}
#flow .fir_index .ft_ro{
	color: #d2d4d1;
}
#flow .flow_list .arrow{
	margin-top: min(40px,3.5vw);
	margin-bottom: min(40px,3.5vw);
	width: 3.5rem;
	text-align: center;
}
#flow .flow_list .index{
	display: flex;
    justify-content: space-between;
    align-items: center;
}
#flow .flow_list .index .flex_l{
	width: 3.5rem;
	text-align: center;
}
#flow .flow_list .index .flex_r{
	width: calc(100% - 7em);
}
#flow .flow_list .txtbox{
	position: relative;
	background: #fff;
	margin-top: min(40px,2vw);
	width: calc(100% - 7em);
	margin-left: auto;
	padding: 0 4%;
	padding-top: min(60px,3vw);
	padding-bottom: min(60px,3vw);
	box-sizing: border-box;
}
#flow .flow_list .txtbox::before{
	position: absolute;
	display: block;
	content: "";
	background: #fff;
	background-size: 100% auto;
	width: 1px;
	height: 100%;
	top:0;
	left: -5.2em;
}
#flow .flow_list > li:last-child .txtbox::before{
	display: none;
}
#flow .flow_list .txtbox > ul > li{
	border-bottom: 1px solid #ccc;
	padding-bottom:min(60px,3vw);
	margin-bottom:min(60px,3vw);
}
#flow .flow_list .txtbox > ul > li:last-child{
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}
#flow .flow_list .txtbox > ul > li > .flex_box{
	max-width: 948px;
	margin-left: auto;
	margin-right: auto;
}
#flow .flow_list .txtbox > ul > li > div.inbox{
	max-width: 910px;
	margin-left: auto;
	margin-right: auto;
}
#flow .flow_list .txtbox .flex_box{
	flex-flow: row-reverse;
}
#flow .flow_list .txtbox .img_r{
	width:35%;
}
#flow .flow_list .txtbox .txt_l{
	width:61%;
}
#flow .flow_list .txtbox h6{
	position: relative;
	padding-left: 1.5em;
	box-sizing: border-box;
}
#flow .flow_list .txtbox h6 i{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	font-size:65%;
	color: #b7d219;
}
#flow .flow_list .txtbox .col2{
	display: flex;
    justify-content: space-between;
	flex-wrap: wrap;
}
#flow .flow_list .txtbox .col2 > li{
	width: 48%;
	max-width: 415px;
	display: flex;
    justify-content: space-between;
	margin-top: min(60px,3vw);
}
#flow .flow_list .txtbox .col2 > li:nth-child(-n+2){
	margin-top: 0;
}
#flow .flow_list .txtbox .col2 > li .img{
	width: 35%;
}
#flow .flow_list .txtbox .col2 > li .txt{
	width: 59%;
	max-width: 250px;
}
#flow .flow_list .txtbox .col2 > li .txt dt{
	margin-bottom: .3em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#flow .flow_list .arrow{
	width: 3rem;
}
#flow .flow_list .index .flex_l{
	width: 3rem;
}
#flow .flow_list .index .flex_r{
	width: calc(100% - 5em);
}
#flow .flow_list .txtbox{
	width: calc(100% - 5em);
}
#flow .flow_list .txtbox h6{
	margin-bottom: 1em;
}
#flow .flow_list .txtbox .col2 > li .txt dt{
	margin-bottom: .05em;
}
#flow .flow_list .txtbox .col2 > li .txt dd{
	line-height: 1.7em;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#flow .flow_list .arrow{
	margin-top: 3vw;
	margin-bottom: 4vw;
	width: 2.5rem;
}
#flow .flow_list .index{
	align-items: start;
}
#flow .flow_list .index .flex_l{
	width: 2.5rem;
}
#flow .flow_list .index .flex_r{
	width: calc(100% - 3.5em);
}
#flow .flow_list .txtbox{
	margin-top: 5vw;
	width: calc(100% - 3.5em);
	padding:5% 5% 7%;
}
#flow .flow_list .txtbox::before{
	left: -2.4em;
}
#flow .flow_list .txtbox > ul > li{
	padding-bottom: 8%;
	margin-bottom: 8%;
}
#flow .flow_list .txtbox > ul > li > .flex_box{
	display: block;
}
#flow .flow_list .txtbox .flex_box{
	display: block;
}
#flow .flow_list .txtbox .img_r{
	width: 100%;
	margin-bottom: 4%;
}
#flow .flow_list .txtbox .txt_l{
	width:100%;
}
#flow .flow_list .txtbox .col2{
	display: block;
}
#flow .flow_list .txtbox .col2 > li{
	width: 100%;
	max-width: 100%;
	margin-top: 0;
	margin-bottom: 2em;
}
#flow .flow_list .txtbox .col2 > li:last-child{
	margin-bottom: 0;
}
#flow .flow_list .txtbox .col2 > li .img{
	width: 35%;
}
#flow .flow_list .txtbox .col2 > li .txt dt{
	margin-top: -0.5em;
	margin-bottom: .05em;
}
#flow .flow_list .txtbox .col2 > li .txt dd{
	font-size:90%;
	line-height: 1.6em;
	letter-spacing: normal;
}
}