/* CSS Document */
/*----- last up date 20201221 -----*/




/*---==============================---*/
/*---=======sp表示用css 　=======---*/
/*---==============================---*/


@media only screen and (max-width:840px){
	
	.pc,#wpadminbar{display:none !important;}
	.sp{display:block;}
	img.sp{display:inline;}
	
	
	img{width:100%; height:auto;}

	#contents,
	#header,
	#footer,
	.pagetop{
		transform:none;
		will-change:auto;
		
		}

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	text-decoration: none;
	font-size: 3vw;
}

body {
	width: 100%;
	min-width: 100%;
	padding: 0;
	margin: 0;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
}

/*---==============================---*/
/*---======  header 調整用 　======---*/
/*---==============================---*/

.bgc{
	height:150vh;
	width:100vw;
	background:rgba(000,000,000,0.8);
	position:fixed;
	left:0;
	top:-180vh;
	 z-index:6;
	-webkit-transition: .5s ease all;
	-moz-transition: .5s ease all;
	-o-transition: .5s ease all;
	transition: .5s ease all;
	transition-duration: 0.5s;
	}
		
.bgc.active{
	top:0vh;
	}
	
header {
	width: 100%;
	height: 23vw;
	position: fixed;
	z-index: 9999;
	top: 0;
	left: 0;
	display: flex;
	background-color: #fff;
	overflow: initial;
}

header::before {
	content: "";
	width: 100%;
	height: 18vw;
	background-color: rgba(255,255,255);
	display: block;
	position: absolute;
}

header .wrap.fe {
	width: 100%;
	margin: 0 auto;
	justify-content: flex-start;
	z-index: 999;
}

header #headtitle {
	width: 60vw;
	padding: 5vw 0 0 2vw;
}

header #headtitle h1 {
	position: absolute;
	left: 0;
	height: auto;
	width: 100%;
	margin: 0 2vw;
	top: 1vw;
}

header nav.nav {
	width: 85%;
	background-color: #dfeedc;
	position: absolute;
	top: 44vw;
	right: -85vw;
}

header .wrap.fe nav.subNav {
	width: 85%;
	position: absolute;
	top: 22vw;
	right: -85vw;
	background-color: #fff;
}

header .wrap.fe nav.subNav ul {
	width: 100%;
	justify-content: space-around;
}

header nav.nav ul {
	width: 100%;
	margin: 0 auto;
	position: absolute;
	background: #fff;
}

header .wrap.fe nav.subNav ul li {
	height: 10vw;
	line-height: 10vw;
	width: 49%;
	margin: 0 0 1vw;
}

header .wrap.fe nav.subNav ul li a {
	-webkit-transition: .3s ease all;
	-moz-transition: .3s ease all;
	-o-transition: .3s ease all;
	transition: .3s ease all;
	transition-duration: 0.3s;
	background-color: #dfeedc;
	text-align: left;
	border-radius: 0;
	height: 100%;
	transform: translate(0 , 0);
	display: block;
	padding: 0 0 0 3vw;
	font-size: 3vw;
}

header .wrap.fe nav.subNav ul li:nth-of-type(3){display:none;}

header nav.nav ul li {
	border-right: none;
	width: 100%;
	border-bottom: 1px dashed;
	line-height: 15vw;
	height: 15vw;
}

header nav.nav ul li a {
	margin-bottom: 0;
	width: 100%;
	font-size: 4vw;
	display: block;
	color: #3a3a3a;
	position: relative;
	height: 15vw;
	line-height: 15vw;
	text-align: left;
	padding: 0 5vw;
}

header > .wrap > div.cart {
	width: 12vw;
	height: 18vw;
	padding: 0;
	position: absolute;
	right: 17vw;
	top: 0;
}
header > .wrap > div.menu {
	width: 12vw;
	height: 18vw;
	padding: 3vw 0vw;
	position: absolute;
	right: 6px;
	top: 0;
}

header > .wrap > div.menu #menuButton {
	overflow: hidden;
	display: block;
	position: relative;
	z-index: 0;
	width: 100%;
	height: 11vw;
	cursor: pointer;
}

header > .wrap > div.menu #menuButton span,
header > .wrap > div.menu #menuButton::before,
header > .wrap > div.menu #menuButton::after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 3px;
	margin: auto;
	background: #054c0c;
	-webkit-transition: .1s ease-in-out;
	transition: all 1s;
}

header > .wrap > div.menu #menuButton span{
		overflow: hidden;
		z-index: 1;
		color: #fff;
	}

header > .wrap > div.menu #menuButton:before{
		z-index: 2;
		transform:rotate(0deg);
		top:7vw;
		content: "";
	}

header > .wrap > div.menu #menuButton:after{
		z-index: 2;
		transform:rotate(0deg);
		top:-7vw;
		content: "";
	}

header > .wrap > div.menu #menuButton span{
		transform:rotate(0deg) translateX(0px);
	}

header > .wrap > div.menu #menuButton:before,
header > .wrap > div.menu #menuButton:after{
		transition: transform 500ms;
	}

.open header > .wrap > div.menu #menuButton span{
		transform:translateX(-100px);
		top:0;
	}

.open header > .wrap > div.menu #menuButton:before{
		transform:rotate(495deg);
		top:0;
	}

.open header > .wrap > div.menu #menuButton:after{
		transform:rotate(405deg);
		top:0;
	}




/*---==============================---*/
/*---======  footer 調整用 　======---*/
/*---==============================---*/

footer {
	margin: 0px auto;
	padding-top: 0;
	padding-bottom: 0;
	width: 100%;
	text-align: center;
	font-size: 4vw;
}

footer .wrap {
	width: 100%;
	margin: 0 auto;
}

footer .wrap ul.fe {
	width: 100%;
	justify-content: flex-start;
}

footer .wrap ul.fe li {
	margin-bottom: 0;
	width: 50%;
	border-top: 1px solid #fff;
	border-right: none;
}

footer .wrap ul.fe li:nth-of-type(2n + 1) {border-right: 1px solid #fff;}

footer .wrap ul.fe li:nth-last-child(1),
footer .wrap ul.fe li:nth-last-child(2){border-bottom: 1px solid #fff;}

footer .wrap ul.fe li a {
	display: block;
	width: 100%;
	position: relative;
	padding: 0 0 0 4vw;
	height: 15vw;
	line-height: 15vw;
}

footer .wrap h2 {
	width: 100%;
	text-align: center;
	margin: 3vw auto;
	font-size: 3vw;
}

footer .wrap small {
	width: 100%;
	text-align: center;
	display: block;
	margin: 0;
	padding: 5vw 0 3vw;
}

/*---==============================---*/
/*---========  top 調整用 　=======---*/
/*---==============================---*/

.fs-body-top .fs-l-main .fs-l-pageMain {
	max-width: 100%;
	width: 100%;
	padding-top: 0;
}

#main-visual {
	width: 100%;
	margin: 0;
	padding: 5vw 0;
	background: #34923e;
}

#main-visual .mv-inbox {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.fs-body-top .fs-l-main .fs-l-pageMain section {
	width: 100%;
	margin: 0 auto 7vw;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.cvp {
	margin-top: 5vw;
	width: 100%;
	min-height: 55px;
	padding: 2vw;
	border-top: 2px solid #22551a;
	border-bottom: 2px solid #22551a;
	position: relative;
	line-height: 1.6;
	text-align: left;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.cvp h2 {
	font-size: 3vw;
	font-weight: 700;
	padding: 0 3vw 0;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.cvp h3 {
	font-size: 3vw;
	line-height: 1.5;
	font-weight: 100;
	margin: 0 3vw;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.bnrs ul {
	width: 96%;
	margin: 0 auto;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.bnrs ul.fe.w50.spw100 li {
	width: 100%;
	margin-top: 5vw;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.seminar h3 {
	width: 100%;
	height: 17vw;
	line-height: 1.3em;
	padding: 3vw 0 0 4vw;
	font-size: 4.5vw;
	font-weight: 700;
}

/*
.fs-body-top .fs-l-main .fs-l-pageMain section.seminar h3::before {
	content: "";
	width: 4vw;
	height: 4vw;
	background: url("https://ecjissenkai.itembox.design/item/img/index/main_title_seminar_before.png") no-repeat center center/100%;
	position: absolute;
	left: 2vw;
	top: 4.3vw;
}
*/

.fs-body-top .fs-l-main .fs-l-pageMain section.seminar h3 span {
	border-left: none;
	display: inline-block;
	line-height: 1.2;
	font-size: 3vw;
	margin-left: 0;
	padding-left: 0;
}
.fs-body-top .fs-l-main .fs-l-pageMain section.seminar ul {
	box-shadow: 0px 0px 5px 3px rgba(0, 0, 0, 0.2) inset;
	border: 1px solid #cccccc;
	width: 100%;
	padding: 2vw;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.seminar ul li {
	margin: 0 !important;
	padding: 2vw !important;
	line-height: 1.4em;
	border-bottom: 1px dotted #999999;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.seminar ul li p {
	font-size: 3vw;
	line-height: 1.5;
}

span.bn-cap {
	display: block;
	font-size: 3vw;
	line-height: 1.1;
	color: #5a5a5a;
	padding: 0;
}
/*
.fs-body-top .fs-l-main .fs-l-pageMain section.reason h3,
.fs-body-top .fs-l-main .fs-l-pageMain section.performance h3 {
	font-size: 4vw;
	font-weight: normal;
	position: relative;
	width: 100%;
	margin-bottom: 3vw;
	padding-bottom: 3vw;
	padding-left: 2vw;
}
*/

.fs-body-top .fs-l-main .fs-l-pageMain section.reason,
.fs-body-top .fs-l-main .fs-l-pageMain section.performance{text-align:center;}
/*
.fs-body-top .fs-l-main .fs-l-pageMain section.reason h4 {
	font-size: 5.5vw;
	color: #efe70d;
	text-align: left;
	height: 21vw;
	line-height: 28vw;
	background: no-repeat top left/170%;
	text-shadow: #024819 0 0 10px, #024819 0 0 10px, #024819 0 0 10px, #024819 0 0 10px, #024819 0 0 10px, #024819 0 0 10px, #024819 0 0 10px;
	font-weight: bolder;
	padding-left: 3vw;
	white-space: nowrap;
	overflow: hidden;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.reason figure {
	text-align: center;
	margin: 0vw 0 10vw;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.reason figure.fe img:nth-of-type(1){width:40vw}
.fs-body-top .fs-l-main .fs-l-pageMain section.reason figure.fe img:nth-of-type(2){width:50vw}
*/

.fs-body-top .fs-l-main .fs-l-pageMain section.performance ul.fe li:last-of-type {
	font-size: 30vw;
	color: #e11911;
	margin: 6vw auto 3vw;
	width: 100% !important;
	font-weight: bold;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.performance ul.fe li:last-of-type p{font-size:5vw;}

.fs-body-top .fs-l-main .fs-l-pageMain section.bnrs ul li img.inqBtn {
	width: 100%;
	margin: 0 auto;
	display: block;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.rank .fs-c-productListCarousel{
	width: 100vw;
	overflow: hidden;
}

.fs-body-top .fs-l-main .fs-l-pageMain section.rank h2 {
	font-size: 5vw;
	font-weight: normal;
	position: relative;
	width: 100%;
	margin-bottom: 3vw;
	padding-left: 2vw;
}


}