@charset "utf-8";
/* CSS Document */


/*_______________________________


　　　　CSS　(PC/TB/SP)
　
　＜＜ページコンテンツ用＞＞

_______________________________*/


/*       .mv
____________________*/

.mv{
	background-image:url("../img/home/mv_l.jpg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
	z-index: 0;
	line-height: 1;
	letter-spacing: 0.07em;
/*	aspect-ratio: 683 / 375;*/
}

.mv .up,
.mv .down{
	margin-left: 35%;
}

.mv .up{
	padding-top:126px;
	text-align: center;
}

.circle_b{
	padding:10px 24px;
	background-color:#73babf;
	border:1px solid #fff;
	border-radius: 25px;
	color:#fff;
	font-size:20px;
}

.mv h2{
	margin-top:30px;
	color:#fff;
	font-size: min(4.3vw, 54px);
	font-style:italic;
	letter-spacing: 0;
	line-height: 1;
	text-shadow: #555 1px 0 10px;
}

.mv h2 .small{
	display: inline-block;
	margin-top:26px;
	font-size:18px;
}

.mv .down{
	margin-top:40px;
	padding-bottom: 300px;
}

.mv .name{
	display: flex;
	justify-content: center;
	column-gap: 8px;
	align-items: center;
}

.circle_w{
	display: inline-block;
	padding:5px 15px;
	background:#fff;
	border-radius: 15px;
	color:#73babf;
	font-size:18px;
}

.mv hr{
	margin: 20px 0 14px;
	background-color: #fff;
    border: none;
    height: 1px;
}

.mv .mv_txt{
	font-size:20px;
	line-height: 2.4;
	letter-spacing: normal;
}



/*     technology
____________________*/

.technology .inner{
	position: relative;
	max-width:1400px;
}

.technology h2{
	text-align: center;
	margin-top:-115px;
	margin-bottom:70px;
	font-size:40px;
}

.technology h2 .small{
	font-size:24px;
}

.technology .tech_wrap{
	position: relative;
	max-width:1100px;
	width:100%;
	margin:180px auto 0;
}

.technology .tech_wrap:first-of-type{
	margin-top:0;
}

.technology .tech_wrap:nth-of-type(2):before{
	position: absolute;
	left:-42px; top:-123px;
	content:url(../img/home/flower01.png);
}
.technology .tech_wrap:nth-of-type(3):after{
	position: absolute;
	right:-90px; top:-123px;
	content:url(../img/home/flower02.png);
}
.technology .tech_wrap:nth-of-type(4):before{
	position: absolute;
	left:-65px; top:-111px;
	content:url(../img/home/flower03.png);
}
.technology .tech_wrap:nth-of-type(5):after{
	position: absolute;
	right:51px; top:-86px;
	content:url(../img/home/flower04.png);
}

.technology .tech_l,
.technology .tech_r{
	position: relative;
	width:73%;
	background:#fff;
	border-radius: 20px;
	box-shadow: #75685514 1px 0 20px;
}

.technology .tech_l{
	padding:50px 136px 50px 54px;
}

.technology .tech_r{
	float:right;
	padding:50px 54px 50px 136px;
}

.technology .tech_wrap .tech_l:before{
	position: absolute;
	top:-42px; left:-68px;
}

.technology .tech_wrap .tech_r:after{
	position: absolute;
	top:-42px; right:-68px;
}

.technology .tech_wrap:first-of-type .tech_l:before{
	content:url(../img/home/numb01.png);
}
.technology .tech_wrap:nth-of-type(2) .tech_r:after{
	content:url(../img/home/numb02.png);
}
.technology .tech_wrap:nth-of-type(3) .tech_l:before{
	content:url(../img/home/numb03.png);
}
.technology .tech_wrap:nth-of-type(4) .tech_r:after{
	content:url(../img/home/numb04.png);
}
.technology .tech_wrap:nth-of-type(5) .tech_l:before{
	content:url(../img/home/numb05.png);
}


.technology h3{
	margin-bottom:20px;
	font-size:30px;
	text-align: center;
}

.technology .efficacy{
	margin-bottom:24px;
    padding: 6px 10px;
	background: #73babf;
	border-radius: 20px;
	color:#fff;
	text-align: center;
	line-height: 1.9em;
}

.technology p{
	line-height: 2.4em;
}
.technology .blue_green{
	color: #73babf;
	margin-top: 24px;
	margin-bottom: 12px;
    font-size: 16px;
    text-align: center;
	display: inline-block;
}
.technology .point{
	list-style: disc;
	margin-left:1em;
}
.technology .point li{
    padding-left: 0.5em;
	letter-spacing: 0.2px;
}

.technology .tech_list{
	margin-top: 24px;
	padding:26px;
	background:#f4ecdf;
	border-radius: 10px;
}

.technology .tech_list h4{
	margin-bottom: 12px;
	font-size:18px;
	text-align: center;
}

.technology .tech_list .numb{
	margin-right: 2em;
	color:#cfa972;
	letter-spacing: -0.25em;
}

.technology .tech_l .tech_img{
	position: absolute;
	top:62px; right:-300px;
	z-index: 10;
}

.technology .tech_r .tech_img{
	position: absolute;
	top:62px; left:-300px;
    z-index: 10;
}



/*     ba
____________________*/

.ba{
	position: relative;	
	margin-top:200px;
	padding-bottom:80px;
    background: #c7e3e5;
	border-top-left-radius: 50%;
    border-top-right-radius: 50%;
    margin-left: -600px;
    margin-right: -600px;
    padding-left: 600px;
    padding-right: 600px;
}

.ba:before{
    position: absolute;
	top:-74px; left:50%;
	transform: translateX(-294px);
	content:url(../img/home/flower05.png);
}

.ba h2{
	margin-bottom: 70px;
	padding-top: 100px;
	text-align: center;
	font-size:40px;
	line-height: 1.7;
}
.ba h2 span{
	font-size:24px;
	line-height: 2;
}

.ba .slider li{
	padding:40px 40px 30px;
	background:#fff;
	border-radius: 20px;
}

.ba h3{
	margin-bottom:26px;
	font-size: min(2.2vw, 24px);
	text-align: center;
}

.ba .slider{
    max-width: 1068px;
    margin-left: auto;
    margin-right: auto;
	margin-bottom:60px;
}

.slick-list {
    overflow: visible;
}

.ba .slider .fig{
	display: flex;
	justify-content: space-between;
	column-gap: 18px;
	text-align: center;
}

.ba .slider .fig dd{
	padding-top:15px;
}

.slider .slick-slide {
  margin: 0 4px;
  position: relative;
  overflow: hidden;
}

.slider .slick-arrow {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: #cfa972;
  cursor: pointer;
  border: none;
  outline: none;
  font-size: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}
.slider .slick-arrow::before {
  content: '';
  display: block;
  width: 12px;
  height: 12px;
  border: 1px solid #fff;
  border-width: 2px 2px 0 0;
  position: absolute;
  top: 24px;
  transform: rotate(45deg);
}
.slider .slick-next {
  right: -40px;
}
.slider .slick-prev {
  left: -40px;
}
.slider .slick-next::before {
  left: 22px;
}
.slider .slick-prev::before {
  border-width: 0 0 2px 2px;
  right: 22px;
}


/* Information */
#access{
	background: #fff;
}
#access h2{
    margin-bottom: 70px;
    padding-top: 90px;
    text-align: center;
    font-size: 40px;
    line-height: 1.7;
}
#access .flex_info{
	display: flex;
	column-gap: 4%;
	align-items: center;
	padding-bottom:90px;
}
#access .text{
	flex-grow: 1;
}
#access .flex_info dl{
	display: flex;
	column-gap: 15px;
	padding:12px 0;
	border-top:1px dashed #cfa972;
}
#access .flex_info dl:first-child{
	border-top:none;
}
#access .flex_qr dl:first-child{
	border-top:1px dashed #cfa972;
}
#access .flex_qr dl:last-child{
	border-bottom:1px dashed #cfa972;
}
#access .flex_info dt{
	width:90px;
}
#access .flex_info dt span{
	display: block;
	color:#73babf;
	border:1px solid #73babf;
	border-radius: 20px;
	text-align: center;
}
#access .small{
	font-size:12px;
}
#access .flex_qr{
	display: flex;
	justify-content: space-between;
	align-items: center;
	column-gap: 20px;
}
#access .qr {
	display: flex;
	column-gap: 15px;
}



footer:before{
    position: absolute;
	top:-154px; right:50%;
	transform: translateX(330px);
	content:url(../img/home/flower06.png);
}


/* 　============================================


           メディアクエリ　切り替え


===============================================*/




/* 　＋＋＋＋＋＋＋　1400px 以下　用　＋＋＋＋＋＋＋　*/

@media screen and ( max-width:1400px) {
	.mv{
	background-image:url("../img/home/mv_m.jpg");
}

	
	
	
	
    /*　---　*/
}
/* ＋＋end＋＋　1400px 以下 用　ここまで　＋＋end＋＋　*/



/* 　＋＋＋＋＋＋＋　（1236px）以下　用　＋＋＋＋＋＋＋　*/

@media screen and ( max-width:1236px) {

	.technology .tech_wrap .tech_l:before {
	    left: -5%;
	}
		
	.technology .tech_wrap .tech_r:after {
	    right: -5%;
	}	
	

}
/* ＋＋end＋＋（1236px）以下 用　ここまで　＋＋end＋＋　*/





/* 　＋＋＋＋＋＋＋　TB 縦（1024px）以下　用　＋＋＋＋＋＋＋　*/

@media screen and ( max-width:1148px) {
	
	.slider .slick-prev {
   		left: 12px;
	}
	.slider .slick-next {
    	right: 12px;
	}
	#access .flex_info {
		align-items: start;	
	}
	#access .flex_qr{
		display: block;
	}
	#access .qr{
		display: block;
		padding-top:30px;
		text-align: center;
	}
	#access .qr img:last-child{
		margin-left:15px;
	}
	
    /*　---　*/
}
/* ＋＋end＋＋　TB 縦（1024px）以下 用　ここまで　＋＋end＋＋　*/




/* 　＋＋＋＋＋＋＋　SP（767px）以下　用　＋＋＋＋＋＋＋　*/

@media screen and ( max-width:767px) {

	
	/* mv */
	.mv {
		background-image:url("../img/home/mv_s.jpg");
		/*        background-position: 65% 50%;
	        	aspect-ratio: 4 / 6;*/
	}
	
	.mv .inner{
		display: flex;
		justify-content: right;
	}
	
	.circle_b {
	    font-size: 12px;
		padding: 6px 14px;
	}
	
	.mv h2 {
		font-size:30px;
		line-height: 1.26;
	}
	.mv h2 .small {
    	line-height: 1.8;
		font-size:14px;
	}
	
	.mv .up {
		margin-left:0;
	    padding: 90px 0 60px;
	}
	

	/* contents */
	
	.down {
		margin-top:14px;
	    text-align: center;
	}
	
	.circle_w {
	    font-size: 14px;
		border-radius: 22px;
	}
	.mv_txt{
		font-size: 15px;
		text-align: left;
	}
	.mv_txt p{	
        margin-top: 16px;
        margin-bottom: 16px;
        line-height: 1.4;
	}
	
	/* flower */
	
	.flower{
		margin:20px 0;
		text-align: center;
	}
	
	/* technology */
	.technology h2{
		margin-top:0;
		margin-bottom: 40px;
		font-size:30px;
	}
	.technology h2 .small{	
		font-size:18px;
	}

	.technology .tech_wrap {
	    margin-top: 40px;
	}
	
	.technology .tech_wrap:nth-of-type(2):before{
		content:"";
		width: 90px; height: 104px;
        left: -18px;
        top: -64px;
        background: url(../img/home/flower_sp02.png) no-repeat;
        background-size: cover;
        z-index: -10;
	}
	.technology .tech_wrap:nth-of-type(3):after{
		content:"";
		width: 116px; height: 100px;
        right: -18px;
        top: -94px;
        background: url(../img/home/flower_sp03.png) no-repeat;
        background-size: cover;
        z-index: -10;
	}
	.technology .tech_wrap:nth-of-type(4):before{
		content:"";
		width: 94px; height: 56px;
        left: 10px;
        top: -48px;
        background: url(../img/home/flower_sp04.png) no-repeat;
        background-size: cover;
        z-index: -10;
	}
	.technology .tech_wrap:nth-of-type(5):after{
		content:"";
		width: 29px; height: 29px;
        right: 35px;
        top: -24px;
        background: url(../img/home/flower_sp05.png) no-repeat;
        background-size: cover;
        z-index: -10;
	}
	
	.technology .tech_l, .technology .tech_r {
    	width: 100%;
	}
	
	.technology .tech_wrap:first-of-type .tech_l:before,
	.technology .tech_wrap:nth-of-type(2) .tech_r:after,
	.technology .tech_wrap:nth-of-type(3) .tech_l:before,
	.technology .tech_wrap:nth-of-type(4) .tech_r:after,
	.technology .tech_wrap:nth-of-type(5) .tech_l:before{
    	content: none;
	}
	
	
	.technology h3 {
		margin-bottom: 10px;
	    font-size: 22px;
	}
	
	.technology .tech_l,
	.technology .tech_r{
	    padding:20px;
	}	
	.technology .tech_l .tech_img,
	.technology .tech_r .tech_img{
    	position: unset;
	}
	
	.technology .numb_img{
		margin: 30px 0 10px;
		text-align: center;
	}
	
	.technology .efficacy {
	    margin-bottom: 12px;
	    padding: 6px 10px;
	    letter-spacing: 0.1em;
	    font-weight: normal;
	}
	
	.technology p {
    	line-height: 2em;
	}
	
	.technology .tech_list {
	    padding: 20px 15px;
	}
	
	.technology .tech_list h4 {
	    font-size: 15px;
		line-height: 1.6em;
	}
	.technology .tech_list li{
		text-indent: -2.5em;
    	padding-left: 3em;
	} 
	.technology .tech_list .numb {
	    margin-right: 1em;
	}
	
	
	/* ba */
	.ba {
	    margin-top: 73px;
		padding-bottom:40px;
	}
	
	.ba:before {
		content:"";
		width: 75px; height: 130px;
        top: -73px;
		transform: translateX(-143px);
        background: url(../img/home/flower_sp06.png) no-repeat;
        background-size: cover;
	}
	
	.ba h2 {
	    margin-bottom: 40px;
	    padding-top: 50px;
	    font-size: 30px;
	    line-height: 1.6;
	}
	
	.ba h2 span {
    	font-size: 18px;
	}
	
	.ba .slider {
		margin-bottom:32px;
	}
	.ba .slider li {
		 width: 300px;
	    padding: 20px 16px;
	}
	
	.ba h3 {
	    font-size: 17px;
	}
	

	/* Information */
	
    #access h2 {
        margin-bottom: 40px;
        padding-top: 50px;
        font-size: 30px;
        line-height: 1.6;
    }
	
	#access .flex_info{
		display: block;
	}
	#access .flex_info dl{
		display: block;
	}

	
	/* footer */
	footer:before {
		content:"";
		width: 27px; height: 33px;
        top: -20px;
		right: 56px;
		transform: none;
        background: url(../img/home/flower_sp07.png) no-repeat;
        background-size: cover;
	}
	
	
	/*　---　*/
}
/* ＋＋end＋＋　SP（767px）以下 用　ここまで　＋＋end＋＋　*/






