@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Roboto:ital,wght@0,500;0,700;1,500;1,700&display=swap');


body{
	width: 100%;
	display: block;
	margin:0 auto;
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.8;
	letter-spacing: 0.06em;
	position: relative;
}

.fix{
	width: 300px;
	position: fixed;
	z-index: 10;
	right: 20px;
	bottom: 40px;
	transition: 0.4s;
	display: block;
}

nav{
	position: fixed;
  overflow-y:scroll;
  height: 100vh;
    width: 100%;
    right: -100%;
    top: 0;
    margin-top: 0px;
    transition: .8s;
    padding-top: 20px;
    padding-bottom: 120px;
    z-index: 999;
    color: #fff;
    box-sizing: border-box;
}

.close{
	font-size: 20px;
	font-weight: bold;
	margin: 0;
	position: absolute;
	left: 0;
	top: 12px;
	z-index: 11;
	cursor: pointer;
}

.fix img{
	transition: 0.4s;
	width: 100%;
}

.fix.none{
	visibility: hidden;
	opacity: 0;
}

.fix img:hover{
	opacity: 0.7;
}

.en{
	font-family: 'Roboto', sans-serif;
}

.mainV{
	position: relative;
}

.mainVisual{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}

.mainV header h1{
	font-size: 65px;
	text-align: center;
	margin: 0;
	line-height: 1.5;
	position: relative;
	z-index: 2;
	padding-top: 3%;
}

.mainV header h1 span{
	display: block;
	font-size: 20px;
	color: #6EC3C8;
	font-style: italic;
}


.button-flex{
	width: 1000px;
	box-sizing: border-box;
	padding:0 20px;
	display: flex;
	margin:28% auto 190px;
	max-width: 100%;
}

.button-flex div.bf1{
	width:50%;
	box-sizing: border-box;
	padding-right: 20px;
}

.button-flex div.bf2{
	width:50%;
	box-sizing: border-box;
	padding-left: 20px;
}

.button-flex div a{
	text-align: center;
	position: relative;
	font-size: 25px;
	color: white;
	background: #6EC3C8;
	border-radius: 40px;
	display: block;
	width: 100%;
	text-decoration: none;
	padding:16px 0;
	font-weight: bold;
	box-sizing: border-box;
	border:2px solid #6EC3C8;
	letter-spacing: 0em;
	text-shadow: 2px 2px 2px #333;
	transition: 0.4s;
}

.button-flex div a:hover{
	opacity: 0.7;
}

.l-icon{
	position: absolute;
	top: 50%;
	right: 8px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);	
	width: 41px;
	height: 41px;
}

.section-1{
	position: relative;
	width: 100%;
}

.wrap{
	width: 1240px;
	display: block;
	box-sizing:border-box;
	padding:0 20px;
	max-width: 100%;
	margin: 0 auto;
}

.section-1 h2{
	font-size: 45px;
	position: relative;
	z-index: 3;
	padding-right: 20px;
	margin: 0;
	letter-spacing: 0;
}

.title-area{
	position:relative;
	display: flex;
	align-items: center;
	z-index: 3;
	justify-content: space-between;
}

.title-area:before{
	content: "";
	height: 2px;
	background: black;
	position: absolute;
	top: 50%;
	left: 0;
	width: 87%;	
	z-index: -1;
}

.section-1 .title-area:before{
	content: "";
	height: 2px;
	background: black;
	position: absolute;
	top: 50%;
	left: 28%;
	width: 60%;	
	z-index: -1;
}


.section-2 .title-area:before{
	content: "";
	height: 2px;
	background: black;
	position: absolute;
	top: 50%;
	left: 79%;
	width: 14%;	
	z-index: -1;
}


.title2{
	font-weight: bold;
	font-style: italic;
	font-size: 25px;
	margin: 0;
	padding-left: 20px;
	position: relative;
	z-index: 3;
}

.section-content{
	width: 100%;
	background: rgba(255,255,255,0.9);
	box-sizing: border-box;
	padding:90px 40px;
	border-radius: 40px;
	margin-top: 15px;
	box-shadow: 0px 0px 4px #CCC;
}

.content-flex{
	display: flex;
}

.cf-left{
	width: 50%;
	box-sizing: border-box;
}

.cf-right{
	width: 50%;
	box-sizing: border-box;
	padding-left: 50px;
	padding-top: 48px;
}

.item1{
	width:553px;
	max-width: 100%;
}

.cf-right p{
	font-size: 18px;
}

.cf-right p{
	margin-top: 0;
	margin-bottom: 42px;
}

.cf-right p.last{
	margin-bottom: 0;
}

.section-2 h2{
	font-size: 45px;
	position: relative;
	z-index: 3;
	padding-right: 20px;
	margin: 0;
	letter-spacing: 0;
}

.section-2{
	position: relative;
	width: 100%;
	margin-top:155px;
}

.item2{
	display: block;
	margin:0 auto;
	width: 412px;
}

.section-2 .cf-right{
	padding-top: 15px;
}

.s-icon{
	width: 25px;
	height: 25px;
	position: relative;
	margin-right: 5px;
	top: 4px;
}

.section-3 h2{
	font-size: 45px;
	position: relative;
	z-index: 3;
	padding-right: 20px;
	margin: 0;
	letter-spacing: 0;
}


.section-3 .title-area:before{
	content: "";
	height: 2px;
	background: black;
	position: absolute;
	top: 50%;
	left: 45%;
	width: 45%;	
	z-index: -1;
}

.section-3{
	position: relative;
	width: 100%;
	margin-top:155px;
}

.section-3 .cf-right{
	padding-left: 25px;
	padding-top: 0;
}

.section-3 .cf-left{
	padding-right: 25px;
	padding-top: 55px;
}

.cf-right .s-title{
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 25px;
	letter-spacing: 0.03em;
}

.cf-right .s-title span{
	color: #DD4545;
}

.flex-3{
	display: flex;
	justify-content: space-between;
}

.flex-3 div{
	width: 32.9%;
}

.flex-3 div img{
	width: 139px;
	display: block;
	margin:0 auto;
	max-width: 100%;
}

.flex-3 div p{
	border:1px solid #6EC3C8;
	text-align: center;
	font-size: 16px;
	font-weight: bold;
	box-sizing: border-box;
	letter-spacing: 0;
	border-radius: 15px;
	margin-bottom: 12px;
}

.section-3 .cf-left p{
	margin-top: 0;
	margin-bottom: 42px;
}

.section-4{
	margin-top: 330px;
	position: relative;
}

.title-bg{
	position: absolute;
	top: 0;
	left: 0;
	width: 58%;
	height: 163px;
	background: #FCDC4D;
	z-index: -1;
	border-top-right-radius: 80px;
	border-bottom-right-radius:80px;
  	box-shadow: 4px 4px 16px rgba(0, 0, 0, 0.2);	
}	

.yellow-title{
	margin-bottom: 140px;
	display: flex;
	justify-content: space-between;
	width: 57%;
	letter-spacing: 0;
	position: relative;
	margin-top: 0;
	padding-top: 22px;
}

.border{
	position: absolute;
	width: 100%;
	height: 3px;
	background: black;
	top: 60%;
	left: 0;
}

.t1{
	display: block;
	font-size: 48px;
	background:#FCDC4D;
	position: relative;
	z-index: 3;
	padding-right: 35px;
	top: 10px;
}

.t2{
	font-size: 61px;
	font-style: italic;
	background:#FCDC4D;
	position: relative;
	z-index: 3;
	padding-left: 35px;
}

.yellow-flex{
	display: flex;
}

.yf-left{
	width: 50%;
	box-sizing: border-box;
	padding-right: 25px;
}

.yf-right{
	width: 50%;
	box-sizing: border-box;
	padding-left: 25px;	
}

.yf-flex3{
	display: flex;
	justify-content: space-between;
}

.yf-flex3 div{
	width: 32.9%;
}

.strong{
	font-size: 23px;
	text-align: center;
	padding:0 20px;
	margin: 0 auto;
	width: 150px;
	max-width: 100%;
	box-sizing: border-box;
	position: relative;
}

.strong:before{
	content: '';
	background-image: url('img/left-object.png');
	background-size: cover;
	width: 15px;
	height: 22px;
	position: absolute;
	left: 0;
	top: 9px;
}

.strong:after{
	content: '';
	background-image: url('img/right-object.png');
	background-size: cover;
	width: 15px;
	height: 22px;
	position: absolute;
	right: 0;
	top: 9px;
}

.search{
	font-size: 15px;
	border:2px solid #6EC3C8;
	text-align: center;
	border-radius: 15px;
	margin:10px 0 0;
}

.search2{
	width: 16px;
	height: 16px;
	position: relative;
	top: 2px;
	left: 15px;
	margin-left: 5px;
}

.phone-img{
	display: block;
	width: 154px;
	max-width: 100%;
	margin:20px auto 0;
}

.yf-right p{
	font-size: 18px;
	margin:5px 0 42px;
}

.yf-right p span{
	font-weight: bold;
	color: #DD4545;
}

.section-5{
	margin-top: 135px;
	position: relative;
}

.able-flex{
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
	padding:70px 34px;
	border-radius: 10px;
	background: rgba(255,255,255,0.9);
	margin-top: 15px;
	box-shadow: 2px 2px 8px #CCC;	
}

.af1{
	width: 127px;
}

.af2{
	width: 190px;
	margin-top: 68px;
}

.af3{
	width: 127px;
}

.able-flex img{
	max-width: 100%;
}

.able-flex div p{
	font-size: 20px;
	text-align: center;
	margin: 0;
}

.yf-right .point{
	width: 144px;
	font-size: 21px;
	text-align: center;
	box-sizing: border-box;
	font-weight: bold;
	border:2px solid #6EC3C8;
	border-radius: 20px;
	margin-top: 70px;
	margin-bottom: 28px;
	background: white;
}

.yf-right .p-title{
	font-size: 35px;
	font-weight: bold;
	margin-top: 0;
	margin-bottom: 32px;
}

.yellow-flex2{
	display: flex;
	margin-top: 40px;
}

.yf-left2{
	width: 50%;
    box-sizing: border-box;
    padding-right: 25px;
}

.yf-right2{
	width: 50%;
    box-sizing: border-box;
    padding-left: 25px;	
}

.yf-left2 .point{
	width: 144px;
	font-size: 21px;
	text-align: center;
	box-sizing: border-box;
	font-weight: bold;
	border:2px solid #6EC3C8;
	border-radius: 20px;
	margin-top: 70px;
	margin-bottom: 28px;
	background: white;
}

.yf-left2 .p-title{
	font-size: 35px;
	font-weight: bold;
	margin-top: 0;
	margin-bottom: 32px;
}

.bo-area{
	width: 100%;
	box-sizing: border-box;
	padding:47px 34px;
	border-radius: 10px;
	background: rgba(255,255,255,0.9);
	box-shadow: 2px 2px 8px #CCC;		
}

.bo-area img{
	width: 368px;
	max-width: 100%;
	display: block;
	margin:0 auto;
}

.yellow-flex3{
	display: flex;
	margin-top: 40px;
}

.yf-left3{
	width: 50%;
    box-sizing: border-box;
    padding-right: 25px;
}

.yf-right3{
	width: 50%;
    box-sizing: border-box;
    padding-left: 25px;	
}

.bo-area2 img{
	width: 352px;
	max-width: 100%;
	display: block;
	margin:0 auto;
}

.yf-right3 .point{
	width: 144px;
	font-size: 21px;
	text-align: center;
	box-sizing: border-box;
	font-weight: bold;
	border:2px solid #6EC3C8;
	background: white;
	border-radius: 20px;
	margin-top: 70px;
	margin-bottom: 28px;
}

.yf-right3 .p-title{
	font-size: 35px;
	font-weight: bold;
	margin-top: 0;
	margin-bottom: 32px;
}

.section-6{
	margin-top: 200px;
	background: #6EC3C8;
	color: white;
	width: 100%;
	padding:100px 0;
	position: relative;
}

.section-6 h2{
	font-style: italic;
	text-align: center;
	margin: 0;
	position: absolute;
	font-size: 44px;
	top: -40px;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    color: black;
}

.online-flex{
	display: flex;
}

.of-left{
	width: 62%;
	box-sizing: border-box;
}

.of-right{
	width: 38%;
	box-sizing: border-box;	
}

.of-right img{
	width: 432px;
	margin-top: 15px;
}

.o-text1{
	font-size: 45px;
	font-weight: bold;
	line-height: 1.6;
	margin: 0;
	    text-shadow: 2px 2px 2px #333;
}

.o-text2{
	font-size: 22px;
	font-weight: bold;
	text-align: center;
	margin-top: 40px;
	margin-bottom: 17px;
	    text-shadow: 2px 2px 2px #333;
}

.zoom{
	display: block;
	background:#FCDC4D;
	color: black;
	text-align: center;
	font-size: 25px;
	font-weight: bold;
	text-decoration: none;
	padding:17px 0;
	border-radius: 40px;
}

.section-7{
	position: relative;
	margin-top: 100px;
	padding-bottom: 100px;
}

.section-7 h2{
	font-size: 45px;
    position: relative;
    z-index: 3;
    padding-right: 20px;
    margin: 0;
    letter-spacing: 0;
}

.section-7 .title-area:before{
	content: "";
	height: 2px;
	background: black;
	position: absolute;
	top: 50%;
	left: 18%;
	width: 76%;	
	z-index: -1;
}

.case-area{
	width: 100%;
	box-sizing: border-box;
	padding:80px 40px 40px;
	border-radius: 10px;
	margin-top: 50px;
	background: rgba(255,255,255,0.9);
	box-shadow: 2px 2px 8px #CCC;		
}

.case-flex{
	display: flex;
}

.yf-flex3 .search2{
	left: 0;
}

.pc-dot2{
	position: absolute;
	right: 60px;
	top: -110px;
	z-index: -1;
}

.cf-left-case{
	width: 56%;
	box-sizing: border-box;
}

.cf-right-case{
	width: 44%;
	box-sizing: border-box;
	padding-left: 36px;
}

.phone-case{
	width: 175px;
	max-width: 100%;
	display: block;
	margin:10px auto 0;
}

.case-t1{
	font-size: 32px;
	font-weight: bold;
	margin-top: 37px;
	margin-bottom: 45px;
}

.case-t1 span{
	color:#DD4545;
}

.table-1 img{
	margin-bottom:10px;
	width: 456px;
	max-width: 100%;
	margin-left: auto;
}

.table-2 img{
	width: 100%;
}

.arrow{
	display: block;
	margin:30px auto 55px;
	width: 87px;
}

.illust-area{
	position: relative;
	text-align: center;
}

.illust1{
	position: absolute;
	top: 0;
	left: -70px;
}

.illust2{
	position: absolute;
	top: 0;
	right: -70px;	
}

.il1{
	font-size: 24px;
	margin: 0;
}

.il2{
	font-weight: bold;
	font-size: 45px;
	margin: 0;
	line-height: 1.2;
}

.il2 span{
	font-size: 100px;
	color: #DD4545;
}

.il2 span .per{
	font-size: 70px;
}

.il3{
	font-size: 24px;
	margin:40px 0 20px;
}

.il4{
	border-top:4px solid black;
	border-bottom:4px solid black;
	font-size: 24px;
	padding:15px 0;
	margin-top: 20px;
}

.section-8{
	border-top:1px solid #FCDC4D;
	padding-top: 90px;
	background: white;
	position: relative;
	z-index: 2;
}

.section-8 h2{
	font-size: 45px;
    background: white;
    position: relative;
    z-index: 3;
    padding-right: 20px;
    margin: 0;
    letter-spacing: 0;
}

.table-area{
	display: block;
	margin-top: 55px;
	margin-bottom: 65px;
}

.row{
	display: flex;
}

/*.items-row{
	align-items: center;
}
*/
.row .col1{
	width:24%;
	border: none;
}

.row div{
	width: 15.2%;
	text-align: center;
	min-height: 55px;
	box-sizing: border-box;
	padding:11px 0;
	border-right:1px solid #ccc;
}

.row .row-t{
	min-height: auto;
	height: 55px;
	margin-top: 30px;
}

.row .yellow{
	background: #FCDC4D!important;


	padding-top: 15px;
	border-top-left-radius:20px;
	border-top-right-radius:20px;
}

.row .yellow p{
	font-size: 40px;
	margin: 0;
	color: black!important;	
	font-style: italic;
	box-sizing: border-box;
}

.row div p{
	font-size: 18px;
	font-weight: bold;
	margin: 0;
	line-height: 1.4;
	letter-spacing: 0;
}

.row div p .small{
	font-size: 14px;
	letter-spacing: -0.02em;
}

.row1 div{
	background:#595757;
}

.row1 div p{
	color:white;
}

.row1 div.col1{
	background: none;
}

.row .col1.col{

}

.row2 p{
	padding:25px 0;
}

.row2 .br3 p{
	padding: 0;
}

.items-row .col1{
	background: #F1F1F1;
	border-left:1px solid #ccc;
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	border-right:1px solid #FCDC4D;
}

.items-row div{
	border-bottom:1px solid #ccc;
}

.items-row div.y-col{
	border-bottom:1px solid #FCDC4D;
}

.row div.y-col{
	border-right:1px solid #FCDC4D;
}

.pc-dot{
	position: absolute;
	left: 20%;
	top: -250px;
	z-index: -1;
}

.row3 p{
	padding:12px 0;
}

.row3 p.br2{
	padding: 0;
}

.ir2 div p{
	font-size: 15px;
}

.ir2 .col1 p{
	font-size: 16px;
}

.ir2 div{
	padding:16px 0;
}

.table-info{
	font-size: 26px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 120px;
}

footer{
	border-top: 1px solid #FCDC4D;
	position: relative;
}

.f-text1{
	font-size: 34px;
	text-align: center;
	font-weight: bold;
	margin-top:120px;
	margin-bottom: 35px;
}

.bridge{
	display: block;
	margin:0 auto;
	position: relative;
	left: 10px;
}

.button-flex2{
	margin-top: 70px;
	margin-bottom: 65px;
}

.logo-link{
	display: block;
	margin:0 auto 60px;
	width: 287px;
}

.logo-link img{
	width: 100%;
}

.footer-link{
	background: #373737;
	padding:16px 0;
}

.footer-flex{
	display: flex;
}

.ff1{
	width: 50%;
}

.ff1 a{
	display: inline-block;
	font-size: 16px;
	color: white;
	text-decoration: none;
	margin-right: 25px;
}

.ff2{
	width: 50%;
}

.ff2 p{
	font-size: 15px;
	color: #aaa;
	margin: 0;
	text-align: right;
}


.footer-rel{
	position: relative;
	overflow: hidden;

}

.footer-rel:before{
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	background: #FBFBFB;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.bg1{
	position: absolute;
	bottom: -100px;
	right: 0;
	z-index: -1;
}

.bg2{
	position: absolute;
	top: -200px;
	left: 0;
	z-index: -1;
}

.dot1{
	position: absolute;
	right: 0px;
	bottom: 100px;
	z-index: -1;
}

.dot2{
	position: absolute;
	left: 11%;
	z-index: -1;
	bottom: 100px;
}

.s2-1{
	width: 440px;
	position: absolute;
	right: 15px;
	top: -55px;
	z-index: -1;
}

.s2-2{
	width: 473px;
	position: absolute;
	left: 0;
	top: -15px;
	z-index: -1;
}

.s2-3{
	width: 731px;
	position: absolute;
	right: 0;
	top: -450px;
	z-index: -1;
}

.s3-1{
	width: 589px;
	position: absolute;
	left: 0;
	top: -100px;
	z-index: -1;
}

.s3-2{
	width: 457px;
	position: absolute;
	right: 0;
	bottom: -200px;
	z-index: -1;
}

.s4-1{
	width:772px;
	bottom: -420px;
	right: 0;
	position: absolute;
	z-index: -1;
}

.s6-1{
	width:476px;
	top: 420px;
	left: 10%;
	position: absolute;
	z-index: -1;
}

.s6-2{
	width:838px;
	bottom: -60px;
	right: 5%;
	position: absolute;
	z-index: -1;
}

.section-7{
	overflow: hidden;
}

.si-1{
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: -1;
}

.si-2{
	position: absolute;
	bottom: -150px;
	left: 0;
	z-index: -1;
}

.si-dot{
	position: absolute;
	left: 0;
	bottom: 100px;
	z-index: -1;
}

.s4-dot{
	position: absolute;
	right: 3%;
	top: -230px;
	z-index: -1;
}

.zoom{
	transition: 0.4s;
}

.zoom:hover{
	opacity: 0.7;
}

.sp-div , .sp-img , .tb-text , .sp-mainV{
	display: none;
}

@media screen and (max-width: 1300px) {

	.mainV header h1 span{
		font-size: 18px;
	}

	.mainV header h1{
		font-size: 44px;
	}

	.search2{
		left: 0;
	}

	.dot1{
		width: 330px;
	}

	.dot2{
		width: 330px;
	}

	.bg2{
		width: 420px;
	}

	.bg1{
		width: 550px;
	}
	
}

@media screen and (max-width: 1240px){

	.tb-text{
		display: block;
		font-size: 18px;
		margin-top: 35px;
		margin-bottom: 0;
	}

	.tb-text img{
		width: 20px;
		margin-right: 15px;
		position: relative;
		top: 10px;
	}

	.scroll{
		overflow-x: scroll!important;
		margin-bottom: 50px;
	}

	.table-area{
		width: 1200px;
		white-space: nowrap;
		margin-bottom: 0;
	}

	.section-1 .title-area:before{
		width: 55%;
		left: 31%;
	}

	.section-2 .title-area:before{
		width: 10%;
		left: 84%;
	}

	.section-3 .title-area:before{
		width: 40%;
		left: 49%;
	}

	.yellow-title{
		width: 65%;
	}

	.title-bg{
		width: 68%;
	}

	.illust1{
		width: 160px;
		left: 0;
		z-index: 1;
	}

	.illust2{
		width: 160px;
		right: 0;
		z-index: 1;
	}

	.il1 , .il2 , .il3{
		position: relative;
		z-index: 2;
	}






} 

@media screen and (max-width: 1150px){

	.of-left{
		width: 55%;
	}

	.of-right{
		width: 45%;
	}

	.of-right img{
		max-width: 100%;
		display: block;
		margin-left: auto;
	}

	.o-text1{
		font-size: 40px;
	}

	.o-text1 br{
		display: none;
	}

	.o-text2{
		font-size: 18px;
	}




}


@media screen and (max-width: 1000px){

	.pc-dot , .pc-dot2{
		display: none;
	}

	.sp-right{
		position: fixed;
		right: 20px;
		top: 20px;
		width: 70px;
		height: 70px;
		background: white;
		z-index: 9999;
		border-radius: 50%;
	}

	nav{
		background: #6EC3C8;
	}

	.in {
    	transform: translateX(-100%);
	}

	nav .header-wrap{
		margin-top: 0;
	}

	.menu_button .menu_icon01{
		top: 22px;
		left: 16px;
	}

	.menu_button:hover{
		cursor:pointer;
	}

	.menu_button .menu_icon01 {
	  display: block;
	  float:left;
	  cursor: pointer;
	  transition: .7s;
	  position: relative;
	  top:24px;
	  left:18px;

	}


	.menu_button .menu_icon01 span {
	  display: block;
	  width: 35px;
	  height: 3px;
	  background: #6EC3C8;
	  margin-bottom: 7px;
	  transition: .7s;
	}

	.menu_button .menu_icon01 span.bar2{
		width: 35px;
	}

	.menu_button .menu_icon01 span.bar3{
		width: 35px;
	}

	.menu_button.open .menu_icon01 span.bar2{
		width: 35px;
	}

	.menu_button.open .menu_icon01 span.bar3{
		width: 35px;
	}	

	.menu_button.open .menu_icon01{
	  transform: rotate(-45deg);

	}
	.menu_button.open .menu_icon01 .bar1 {
	  transform: rotate(0deg) translateY(7px);
	}
	.menu_button.open .menu_icon01 .bar2 {
	  opacity: 0;
	}
	.menu_button.open .menu_icon01 .bar3 {
	 transform: rotate(-90deg) translateX(11px);

	}

	.menu_button.open .menu_icon01{
		left: 22px;
	}

	.menu_button .menu_icon02 {
	  display: block;
	  float: left;
	  cursor: pointer;
	  transition: all 0.2s ease-in;
	}
	.menu_button .menu_icon02 span {
	  display: block;
	  width: 30px;
	  height: 2px;
	  background: #707070;
	  margin-bottom: 4px;
	  transition: all 0.4s ease-out;
	}

	.nav-link{
		padding-top: 120px;
		padding-left: 0;
		text-align: center;
	}

	.nav-link li{
		list-style: none;
		margin:20px 0;		
	}

	.nav-link li a{
		text-decoration: none;
		color: white;
		font-weight: bold;
		font-size: 22px;

	}



	.menu_button.open .menu_icon02 .bar1 {
	  transform: translateY(10px) rotate(135deg);
	}
	.menu_button.open .menu_icon02 .bar2 {
	 opacity: 0;
	 transform:translateX(-100px);
	}
	.menu_button.open .menu_icon02 .bar3 {
	 transform:  translateY(-6px)
	 rotate(45deg);
	}

	.menu_button .menu_icon03 {
	  display: block;
	  float: left;
	  cursor: pointer;
	  transition: all 0.2s ease-in;
	}
	.menu_button .menu_icon03 span {
	  display: block;
	  width: 30px;
	  height: 2px;
	  background: #707070;
	  margin-bottom: 4px;
	  transition: all 0.4s ease-out;
	}
	.menu_button.open .menu_icon03 .bar1 {
	  transform: translateY(10px) rotate(45deg);
	}
	.menu_button.open .menu_icon03 .bar2 {
	 opacity: 0;
	 width:150px;
	 transform: translateX(-60px)
	}
	.menu_button.open .menu_icon03 .bar3 {
	 transform: translateY(-6px)
	 rotate(135deg);
	 }	

	.fix{
		width: 200px;
	}

	.close{
		top: 0;
	}

	.button-flex{
		display: block;
	}

	.button-flex div.bf1{
		width: 100%;
		padding-right: 0;
		margin:15px 0;
	}

	.button-flex div.bf2{
		width: 100%;
		padding-left: 0;
		margin:15px 0;
	}

	.button-flex{
		margin-bottom: 120px;
	}

	.section-1 h2{
		font-size: 32px;
	}

	.section-2 h2{
		font-size: 32px;
	}

	.section-3 h2{
		font-size: 32px;
	}

	.title2{
		font-size: 18px;
	}

	.section-content{
		padding:70px 20px;
	}

	.content-flex{
		display: block;
	}

	.cf-left{
		width: 100%;
	}

	.cf-left img{
		width: 100%;
	}

	.cf-right{
		width: 100%;
		padding-left: 0;
	}

	.cf-right p{
		font-size: 16px;
		margin-bottom: 30px;
	}

	.button-flex div a{
		padding:12px 0;
		font-size: 21px;
	}

	.pc-div{
		display: none;
	}

	.sp-div{
		display: block;
	}

	.cf-right .s-title{
		text-align: center;
	}

	.section-2 .cf-right{
		padding-top: 48px;
	}

	.section-3 .sp-div{
		padding-top: 48px;
	}

	.section-3 .sp-div p{
		font-size: 16px;
		margin:0 0 30px;
	}

	.section-3 .sp-div p.last{
		margin-bottom: 0;
	}

	.t1{
		font-size: 38px;
		top: 6px;
	}

	.t2{
		font-size: 44px;
	}

	.title-bg{
		height: 120px;
	}

	.yellow-flex{
		display: block;
	}

	.yf-left{
		padding: 0;
		width: 100%;
	}

	.yf-right{
		padding: 0;
		padding-top: 48px;
		padding-bottom: 48px;
		width: 100%;		
	}

	.yf-right p{
		font-size: 16px;
		margin:16px 0;
	}


	.yellow-title{
		margin-bottom: 90px;
	}

	.yf-right .point , .yf-left2 .point{
		margin-top: 0;
	}

	.yellow-flex2{
		display: block;
	}

	.yf-right2{
		padding: 0;
		width: 100%;
	}

	.yf-left2{
		width: 100%;
		padding: 0;
		padding-top: 48px;
		padding-bottom: 48px;
	}

	.yellow-flex3{
		display: block;
	}

	.yf-left3{
		padding: 0;
		width: 100%;
	}

	.yf-right3{
		width: 100%;
		padding-left: 0;
		padding-top: 48px;
	}

	.yf-right3 .point{
		margin-top: 0;
	}

	.yf-right .p-title{
		font-size: 28px;
		margin-bottom: 20px;
	}

	.yf-left2 .p-title{
		font-size: 28px;
		margin-bottom: 20px;
	}

	.yf-right3 .p-title{
		font-size: 28px;
		margin-bottom: 20px;
	}


	.s2-1{
		width: 320px;
	}

	.s2-2{
		width: 340px;
	}


	.s2-3{
		width: 470px;
	}

	.s3-1{
		width: 400px;
	}

	.s3-2{
		width: 330px;
	}

	.s4-dot{
		width: 300px;
	}

	.s4-1{
		width: 450px;
	}

	.sp-img{
		display: block;
	}

	.online-flex .of-left{
		width: 100%;
	}

	.sp-img{
		width:432px;
		max-width: 75%;
		margin:30px auto 0;
		position: relative;
		right: 20px;
	}

	.o-text1 br{
		display: block;
	}

	.o-text1{
		font-size: 34px;
		text-align: center;
	}

	.section-6{
		margin-top: 150px;
		padding:70px 0;
	}

	.zoom{
		padding:12px 0;
		font-size: 21px;
	}

	.section-7 h2{
		font-size: 32px;
	}

	.case-area{
		padding:70px 20px;
	}

	.case-flex{
		display: block;
	}

	.cf-left-case{
		width: 100%;
	}

	.cf-right-case{
		width: 100%;
	}

	.case-t1{
		font-size: 24px;
		margin-top: 0;
		text-align: center;
	}

	.cf-right-case{
		padding: 0;
		padding-top: 48px;
	}

	.table-1 img{
		width: 100%;
	}

	.illust1 , .illust2{
		display: none;
	}

	.illust-area .sp-div{
		width: 100%;
		margin-top: 35px;
	}

	.il-block{
		display: block;
		margin-top: 15px;
	}

	.il1{
		font-size: 20px;
	}

	.il2{
		font-size: 30px;
	}

	.il2 span{
		font-size: 70px;
	}

	.il2 span .per{
		font-size: 50px;
	}

	.il3{
		font-size: 20px;
	}

	.il4{
		font-size: 20px;
	}

	.si-dot{
		width: 320px;
	}

	.si-1{
		width: 180px;
	}

	.si-2{
		width: 180px;
	}

	.section-8 h2{
		font-size: 32px;
	}

	.table-info{
		font-size: 20px;
	}

	.f-text1{
		font-size:26px;
	}

	.button-flex2{
		margin:50px 0;
	}

	.arrow{
		width: 65px;
	}

	.mainV header h1 span{
		font-size: 16px;
	}

	.mainV header h1{
		font-size: 34px;
	}

	.section-3 .cf-right{
		padding: 0;
	}

	.section-4{
		margin-top: 220px;
	}



}



@media screen and (max-width: 800px){

	.pc-mainV{
		display: none;
	}

	.sp-mainV{
		display: block;
		position: relative;
	}

	.sp-header{
		position: absolute;
		width: 100%;
		padding:20px 20px 0;
		box-sizing: border-box;
	}

	.sp-left .en{
		font-size: 40px;
		font-weight: bold;
		font-style: italic;
		margin: 0;
	}

	.mainVisual2{
		width: 100%;
	}

	.button-flex{
		margin-top: 70px;
	}

	.section-1 h2{
		font-size: 24px;
	}

	.title2{
		font-size: 16px;
	}

	.section-2 h2{
		font-size: 24px;
	}

	.section-2 .title-area{
		display: block;
	}

	.section-2 .title2{
		text-align: right;
	}

	.section-2 .title-area:before{
		top: 79%;
		left: 62%;
		width: 30%;
	}

	.section-3 h2{
		font-size: 24px;
	}

	.section-3 .title-area:before{
		width: 28%;
		left: 56%;
	}

	.section-content{
		padding:60px 15px;
	}

	.flex-3 div p{
		font-size: 11px;
		padding:2px 0;
	}

	.title-bg{
		width: 90%;
		height: 100px;
	}

	.t1{
		font-size: 32px;
		top: 2px;
	}

	.t2{
		font-size: 34px;
	}

	.yellow-title{
		width: 80%;
	}

	.section-6 h2{
		font-size: 32px;
		top: -28px;
	}

	.o-text1{
		font-size: 28px;
	}

	.o-text2{
		font-size: 16px;
	}

	.section-7 h2{
		font-size: 24px;
	}

	.section-7 .title-area:before{
		width: 65%;
		left: 25%;
	}

	.case-area{
		padding:60px 20px;
	}

	.case-t1{
		font-size: 20px;
		margin-bottom: 30px;
	}

	.search{
		font-size: 11px;
		padding:2px 0;
	}

	.cf-left-case .search2{
		top: 4px;
	}

	.section-5{
		margin-top: 60px;
	}

	.button-flex div a{
		font-size: 18px;
		padding:10px 0 12px;
	}

	.l-icon{
		width: 32px;
		height: 32px;
	}

	.footer-flex{
		display: block;
	}

	.ff1{
		width: 100%;
		text-align: center;
	}

	.ff2{
		width: 100%;
	}

	.ff2 p{
		text-align: center;
		margin-top: 20px;
	}

	.ff1 a{
		margin:0 18px;
	}


}

.sp-fix , .sp-dot , .sp-dot2{
	display: none;
}

@media screen and (max-width: 585px){


	.sp-dot{
		display: block;
		width: 180px;
		position: absolute;
		left: 18%;
		top:-80px;
		z-index: -1;
	}

	.sp-dot2{
		display: block;
		width: 180px;
		position: absolute;
		right: 10%;
		top:-80px;
		z-index: -1;
	}


	.close{
		top: -8px;
	}

	.pc-fix{
		display: none;
	}

	.sp-fix{
		display: block;
	}

	.fix{
		width: 207px;
	}

	.sp-left .en{
		font-size: 30px;
	}

	.section-2 .title-area:before{
		top: 85%;
		left: 62%;
		width: 30%;
	}

	.title-bg {
		width: 97%;
		height: 88px;
	}

	.yellow-title{
		width: 90%;
	}

	.t1{
		font-size: 24px;
	}

	.t2{
		font-size: 25px;
	}

	.section-1 .title-area:before{
		width: 40%;
		left: 38%;
	}

	.bridge{
		left: 0;
		max-width: 100%;
	}

	.footer-rel{
		padding:0 20px;
		box-sizing: border-box;
	}

	.table-area{
		width: 900px;
	}

	.row .yellow p{
		font-size: 24px;
	}

	.row div p{
		font-size: 13px;
	}

	.row div p .small{
		font-size: 10px;
	}

	.ir2 .col1 p{
		font-size: 13px;
	}

	.row .yellow{
		padding-top: 31px;
	}

	.row1 div{
		padding:19px 0;
	}

	.v-small{
		font-size: 10px!important;
		padding-top: 3px;
	}

	.s2-3{
		width: 290px;
	}

	.bg2{
		width: 250px;
		top: -180px;
	}

	.bg1{
		width: 230px;
		bottom: -20px;
	}

	.dot1{
		width: 240px;
	}

	.s6-1{
		width: 220px;
		left: 3%;
	}

	.s6-2{
		width: 250px;
		right: 2%;
	}

	.s3-1 , .s3-2{
		width: 220px;
	}

	.section-8 .title-area:before{
		width: 40%;
		left: 40%;
	}


}

@media screen and (max-width: 480px){



	.section-1 h2{
		font-size: 20px;
	}

	.section-1 .title-area:before{
		width: 24%;
		left:47%;
	}

	.section-2 .title-area:before{
		left: 58%;
	}

	.section-3 h2{
		font-size: 20px;
		padding: 0;
	}

	.title2{
		font-size: 15px;
		padding: 0;
	}

	.section-3 .title-area:before{
		width: 10%;
		left: 69%;
	}

	.wrap{
		padding:0 13px;
	}

	.flex-3 div p{
		font-size: 10px;
	}


	.section-3 .sp-div p{
		font-size: 15px;
	}

	.cf-right .s-title{
		font-size: 18px;
	}

	.s-icon{
		width: 18px;
		height: 18px;
	}

	.strong{
		font-size: 14px;
		width: 100px;
	}

	.strong:before{
		width: 12px;
		height: 18px;
		top: 4px;
	}

	.strong:after{
		width: 12px;
		height: 18px;
		top: 4px;		
	}

	.search{
		font-size: 10px;
	}

	.yf-right p{
		font-size: 15px;
	}

	.able-flex{
		padding:50px 20px;
	}

	.able-flex div p{
		font-size: 16px;
	}

	.af1{
		width: 30%;
	}

	.af2{
		width: 40%;
	}

	.af3{
		width: 30%;
	}

	.yf-right .point , .yf-left2 .point , .yf-right3 .point{
		width: 120px;
		font-size: 18px;
	}

	.yf-right .p-title , .yf-left2 .p-title , .yf-right3 .p-title{
		font-size: 23px;
	}

	.sp-div p , .yf-right3 p{
		font-size: 15px;
	}

	.o-text1{
		font-size: 20px;
	}

	.section-6{
		padding:60px 0;
	}

	.sp-img{
		right: 10px;
	}

	.o-text2{
		font-size: 15px;
	}

	.zoom{
		font-size: 18px;
		padding:10px 0;
	}

	.section-7 .title-area:before{
		width: 54%;
		left: 31%;
	}

	.section-7 h2{
		font-size: 20px;
	}

	.section-6 h2{
		font-size: 24px;
		top: -20px;
	}

	.case-area{
		padding:40px 15px;
	}

	.case-t1{
		font-size: 18px;
		margin-bottom: 20px;
	}

	.search2{
		width: 10px;
		height: 10px;
		top: 2px;
		margin-left: 3px;
	}

	.arrow{
		width: 50px;
		margin:30px auto 50px;
	}

	.il1{
		font-size: 18px;
	}

	.il2 span{
		font-size: 60px;
	}

	.il2{
		font-size: 24px;
	}

	.il2 span .per{
		font-size: 48px;
	}

	.il3{
		font-size: 18px;
	}

	.il4{
		font-size: 16px;
	}

	.si-1{
		width: 90px;
	}

	.si-2{
		width: 140px;
	}

	.section-8 h2{
		font-size: 20px;
	}

	.section-8 .title-area:before{
		width: 70%;
	}

	.table-info{
		font-size: 18px;
		margin-bottom: 80px;
	}

	.f-text1{
		font-size: 20px;
		margin-top: 80px;
	}

	.bridge{
		max-width: 80%;
		left: 10px;
	}

	.button-flex2{
		padding: 0;
	}

	.logo-link{
		margin-bottom: 45px;
	}

	.t1{
		font-size: 20px;
		padding-right: 25px;
	}

	.yellow-title{
		width: 93%;
	}

	.t2{
		font-size: 20px;
		padding-left: 25px;
	}

	.border{
		top: 69%;
	}

	.section-5{
		margin-top: 40px;
	}

	.section-4{
		margin-top: 100px;
	}

	.cf-right p{
		font-size: 15px;
	}

	.section-2{
		margin-top: 100px;
	}

	.o-text2{
		font-size: 13px;
	}

	.title-bg{
		height: 80px;
	}

	.case-area{
		margin-top: 30px;
	}

	.tb-text{
		font-size: 16px;
	}

	.tb-text img{
		width: 16px;
		margin-right: 12px;
	}

	.s2-1{
		width: 140px;
	}

	.s2-2{
		width: 200px;
	}

	.sp-left .en{
		font-size: 26px;
	}

	.fix{
		right: 13px;
		bottom: 30px;
	}

	.button-flex2{
		margin-top: 35px;
	}

	.sp-right{
		right: 13px;
		top: 15px;
		width: 60px;
		height: 60px;
	}

	.menu_button .menu_icon01 span{
		width: 30px;
		margin-bottom: 5px;
	}

	.menu_button .menu_icon01 span.bar2{
		width: 30px;
	}

	.menu_button .menu_icon01 span.bar3{
		width: 30px;
	}

	.menu_button .menu_icon01{
		top: 20px;
		left: 15px;
	}

	.menu_button.open .menu_icon01 span.bar3{
		width: 30px;
	}

	.menu_button.open .menu_icon01 span.bar2{
		width: 30px;
	}

	.menu_button.open .menu_icon01 .bar3{
		transform: rotate(-90deg) translateX(8px);
	}

	.menu_button.open .menu_icon01{
		left: 18px;
	}

	.nav-link{
		padding-top: 45px;
	}

	.nav-link li a{
		font-size: 20px;
	}

	.section-8 .title-area:before{
		width: 30%;
	}

	.row .yellow{
		min-height: auto;
		height: 75px;
		padding-top: 25px;
		margin-top: 9px;
	}


}


