@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Josefin+Sans:wght@400;500;600;700&display=swap');




/* FONT size
---------------------------------------------------------------------
[ px ]	[ % ]
10px 	72  %		19px 	136 %
11px 	79  %		20px 	143 %
12px 	86 %		21px 	150 %
13px 	93 %		22px 	158 %
14px 	100 %		23px 	165 %
15px 	108 %		24px 	172 %
16px 	115 %		25px 	179 %
17px 	122 %		26px 	186 %
18px 	129 %
---------------------------------------------------------------------*/




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 共通項目 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
*{margin:0;padding:0;text-decoration:none}fieldset{border:0}body{line-height:1.8;font-size:88%}body,dd,dl,dt,form,h1,h2,h3,h4,h5,h6,input,li,ol,p,select,ul{margin:0;padding:0}img{border:0;vertical-align:top}a{text-decoration:none}em{font-style:normal}ul li{list-style-type:none;list-style-image:none}address{font-style:normal}
*{box-sizing: border-box}


body {
	font-family: 'Josefin Sans', 'arial', 'MS Sans Serif', sans-serif;
	font-weight: 500;
	color: #231815;
	padding: 0;
	margin: 0;
	letter-spacing: .1rem;
	word-spacing: .1rem;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
/*	text-align: justify;*/
	text-justify: inter-ideograph;
	-ms-text-justify: inter-ideograph;
}

body.noscroll{
  overflow: hidden;
}

/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ボタン */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */


/* PCナビゲーション
--------------------- */
#nav ul.menu li.menu_level01 a.mnlv_a01{
	position: relative;
	overflow: hidden;
/*	text-transform: uppercase;*/
	z-index: 0;
	transition: 0.3s ease-in-out;
}
#nav ul.menu li.menu_level01:hover a.mnlv_a01{
	color:#000;
}	


	.btn-1 {
		position: relative;
		display: block;
		overflow: hidden;
		width: 240px;
		padding: 20px 20px 20px 0;
		margin: 0;
		font-size:1rem;
		text-align: center;
/*		text-transform: uppercase;*/
		border: 1px solid #000;	
		background-color:#fff;
		color: #000;
		cursor: pointer;
		z-index: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-1:hover {
		color: #fff;
		border: 1px solid #212121;
	}
		.btn-1:before {
			content: "";
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color:#212121;
			transform: translateX(-100%);
			z-index: -1;
			transition: 0.3s ease-in-out;
		}
		.btn-1:hover:before {
			transform: translateX(0);
		}
		.btn-1:after{
			content: url("../img/common/arrow_b0.svg");
			position: absolute;
			top: 50%;
			right: 20px;
			margin-top: -16px;
			transition: all .4s;
		}
		.btn-1:hover:after{
			content: url("../img/common/arrow_f0.svg");
			right: 16px;
		}


	.btn-2 {
		position: relative;
		display: block;
		overflow: hidden;
		width: 220px;
		padding: 20px 20px 20px 0;
		margin: 0 20px 0 0;
		text-align: center;
/*		text-transform: uppercase;*/
		border: 1px solid #fff;	
		background-color:transparent;
		color: #fff;
		cursor: pointer;
		z-index: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-2:hover {
		color: #fff;
		border: 1px solid #212121;
	}
		.btn-2:before {
			content: "";
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color:#212121;
			transform: translateX(-100%);
			z-index: -1;
			transition: 0.3s ease-in-out;
		}
		.btn-2:hover:before {
			transform: translateX(0);
		}
		.btn-2:after{
			content: url("../img/common/arrow_f0.svg");
			position: absolute;
			top: 50%;
			right: 20px;
			margin-top: -16px;
			transition: all .4s;
		}
		.btn-2:hover:after{
			content: url("../img/common/arrow_f0.svg");
			right: 16px;
		}



	.btn-3 {
		position: relative;
		display: block;
		overflow: hidden;
		width: 220px;
		margin: 40px auto 0;
		text-align: center;
/*		text-transform: uppercase;*/
		background-color:#212121;
		border:1px solid #212121;
		color: #fff;
		cursor: pointer;
		z-index: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-3 input{
		width: 220px;
		padding: 20px 0;
		background-color: transparent;
		border:none;
		color:#fff;
		font-size:.9rem;
		line-height: 1.4rem;
		letter-spacing: .1rem;
		cursor: pointer;
	}
	.download_btn .btn-3{
		padding: 20px 0;
		font-size:.9rem;
		line-height: 1.4rem;
		letter-spacing: .1rem;
	}
	.btn-3 input:hover{
		color:#212121;
	}
	.download_btn .btn-3:hover{
		color:#212121;
	}
		.btn-3:before {
			content: "";
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color:#fff;
			transform: translateX(-100%);
			z-index: -1;
			transition: 0.3s ease-in-out;
		}
		.btn-3:hover:before {
			transform: translateX(0);
		}
	.btn-4 {
		position: relative;
		display: block;
		overflow: hidden;
		width: 220px;
		padding: 20px 0;
		margin: 40px 30px 0 0;
		text-align: center;
/*		text-transform: uppercase;*/
		background-color:#fff;
		border:1px solid #212121;
		font-size:.9rem;
		line-height: 1.4rem;
		letter-spacing: .1rem;
		color: #212121;
		cursor: pointer;
		z-index: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-4:hover{
		color:#fff;
	}
		.btn-4:before {
			content: "";
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color:#212121;
			transform: translateX(-100%);
			z-index: -1;
			transition: 0.3s ease-in-out;
		}
		.btn-4:hover:before {
			transform: translateX(0);
		}

	.contact_submitbtn{
		display: table;
		margin: 0 auto;
	}
	.contact_submitbtn .btn-3 {
		margin: 40px 0 0;
	}





	.return_btn{
		margin: 80px auto 0;
	}
		.return_btn .btn-1{
			width: 220px;
			margin:0 auto;
			padding: 16px 0px 16px 0;
		}
		.return_btn .btn-1:after{
			content:'';
		}

	.form_submitbtn{
		margin: 40px auto 0;
	}




/*フェードインアニメ*/
/*左から右にフェードイン*/
.left-to-right {
  opacity: 0;
  transform: translateX(-20px);
  transition: all 2s;
}
.left-to-right.scrollin {
  opacity: 1;
  transform: translate(0);
}

/*下から上にフェードイン*/
.down-to-top {
  opacity: 0;
  transform: translateY(20px);
  transition: all 2s;
}
.down-to-top.scrollin {
  opacity: 1;
  transform: translateY(0);
}


/* 欧文フォント */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.en {
	font-family: 'Josefin Sans', 'arial', 'MS Sans Serif', sans-serif;
	font-weight: 400;
}




/* pc,sp,tablet切り替え */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.pc{
	display: block;
}
.sp{
	display: none;
}
.pcc{
	display: block;
}
.spp{
	display: none;
}
.tablet{
	display: none;
}


/* flex */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.flex {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: flex-start; 
	align-items:center;
}
.flex-center {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: center; 
	align-items:center;
}
.flex-start {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: flex-start;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
	position:relative;
	z-index: 10;
}

.header_inner{
	width: 100%;
	height: 80px;
	position:absolute;
	top:0;
	left: 0;
}
	/* ロゴ
	--------------------- */
	.header_inner .header_logo a{
		width: 144px;
		height: auto;
		margin-left: 30px;
		transition: 0.3s ease-in-out;
	}
	.header_inner .header_logo a:hover{
		opacity: .6;
	}
		.header_inner .header_logo a img{
			width: 144px;
			height: 22px;
		}

	/* SNSアイコン
	--------------------- */
	.header_inner .sns_icon{
		margin: 0 0 0 auto;
	}
		.header_inner .sns_icon a{
			display: block;
			position: relative;
			width: 30px;
			height: 30px;
			border-radius: 30px;
			background-color: #212121;
			transition: 0.2s ease-in-out;
		}
		.header_inner .sns_icon a:hover{
			background-color: #fff;
		}
		.header_inner .sns_icon a:first-child{
			margin-right: 10px;
		}
			.header_inner .sns_icon a:before{
				content:"";
				position:absolute;
				top:0;
				left:0;
				right:0;
				bottom:0;
				margin: auto;
			}
			.header_inner .sns_icon a:first-child:before{	
				background: url("../img/common/facebookf_icon.svg") no-repeat center;
				background-size: contain;
				height: 12px;
				width: 6px;			
			}
			.header_inner .sns_icon a:first-child:hover:before{
				background-image: url(../img/common/facebookb_icon.svg);
			}
			.header_inner .sns_icon a:nth-child(2):before{
				background: url("../img/common/instaf_icon.svg") no-repeat center;	
				background-size: contain;
				height: 13px;
				width: 14px;					
			}
			.header_inner .sns_icon a:nth-child(2):hover:before{
				background-image: url("../img/common/instab_icon.svg");			
			}

	/* コンタクトボタン
	--------------------- */
	.header_inner ul.contact_btn{
		margin: 0 0 0 20px;
	}
		.header_inner ul.contact_btn li{
			width: 212px;
			border-right: 1px solid #707070;
		}
		.header_inner ul.contact_btn li:nth-child(3){
			width: 86px;
			border-right: none;
		}

			.header_inner ul.contact_btn li a{
				width: 100%;
				height: 80px;
				padding-left: 36px;
				background-color: #212121;
				display: flex;
				justify-content: center;
				align-items:center; 
				font-size:0.8rem;
				line-height: 1.2rem;
				letter-spacing: 0.14rem;
				transition: 0.3s ease-in-out;
			}
			.header_inner ul.contact_btn li a:hover{
				background-color: #fff;
			}

			p .btnb_ani{
				position:relative;				
				overflow: hidden;
				color:#fff;
				transition: 0.2s ease-in-out;
				z-index: 0;
			}
			p .btnb_ani:hover{
				color:#000;
			}

			.header_inner ul.contact_btn li:nth-child(3) a{
				padding-left: 0px;
			}
				.header_inner ul.contact_btn li:nth-child(3) a span:nth-child(2){
					font-weight: bold;
	/*				border-bottom: 1px solid #fff;*/
					box-sizing: border-box;
					padding-bottom: 8px;
					transition: all .3s;
				}
				.header_inner ul.contact_btn li:nth-child(3) a:hover span:nth-child(2){
	/*				border-bottom: none;*/
					padding-bottom: 0px;
					font-weight: 500;
				}
				.header_inner ul.contact_btn li:nth-child(3) a span:nth-child(1){
					transition: all .3s;
				}
				.header_inner ul.contact_btn li:nth-child(3) a:hover span:nth-child(1){
					font-weight: bold;
	/*				border-bottom: 1px solid #212121;*/
					box-sizing: border-box;
					padding-bottom: 8px;
				}
			.header_inner ul.contact_btn li a:after{
				content:url("../img/common/mailf_icon.svg");
				width: 25px;
				height: 18px;
				position:absolute;
				top:50%;
				left:26px;
				margin-top: -8px;
				transition:all 0.2s;
			}
			.header_inner ul.contact_btn li a:hover:after{
				content:url("../img/common/mailb_icon.svg");
			}
			.header_inner ul.contact_btn li:nth-child(3) a:after{
				content:'';
			}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ページタイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.pagetitle_sec{
	width: 100%;
	height: 424px;
	color:#fff;
	padding-top: 80px;
	text-align: center;
}
.pagetitle_grp h1{
	font-size:3.6rem;
	line-height: 3.6rem;
	letter-spacing: .5rem;
    text-transform: uppercase;
}
.pagetitle_grp p{
	font-size:1.0rem;
}

#news .pagetitle_sec{
	background: url("../img/news/news_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
	
}
#contact .pagetitle_sec,
#cantact_confirm .pagetitle_sec{
	background: url("../img/contact/contact_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#catalog .pagetitle_sec,
#catalog_confirm .pagetitle_sec{
	background: url("../img/catalog/catalog_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#corp_contact .pagetitle_sec,
#corp_contact_confirm .pagetitle_sec{
	background: url("../img/contact/forcorp_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#blog .pagetitle_sec{
	background: url("../img/labblog/labblog_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#mystory .pagetitle_sec{
	background: url("../img/mystory/mystory_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#academy .pagetitle_sec,
#curriculum .pagetitle_sec{
	background: url("../img/academy/academy_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#product .pagetitle_sec{
	background: url("../img/product/product_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#about .pagetitle_sec{
	background: url("../img/about/about_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#kodawari .pagetitle_sec{
	background: url("../img/about/kodawari/kodawari_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#company .pagetitle_sec{
	background: url("../img/about/company/company_pagetitleb.jpg") no-repeat center;
	background-size: cover;
}
#perfume .pagetitle_sec{
	background: url("../img/about/perfume/perfume_pagetitleb.jpg") no-repeat center;
	background-size: cover;
}
#shop .pagetitle_sec{
	background: url("../img/about/shop/shop_pagetitleb.jpg") no-repeat center;
	background-size: cover;
}
#labshop .pagetitle_sec{
	background: url("../img/about/shop/labshop_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#cotoiro .pagetitle_sec{
	background: url("../img/about/shop/cotoiro_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
	}
#shop201lab .pagetitle_sec{
	background: url("../img/about/shop/pagetitlebg201.jpg") no-repeat center;
	background-size: cover;
}
#recruit .pagetitle_sec{
	background: url("../img/recruit/recruit_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#utility .pagetitle_sec{
	background: url("../img/utility/utility_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}
#error404 .pagetitle_sec{
	background: url("../img/error404/error404_pagetitlebg.jpg") no-repeat center;
	background-size: cover;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ナビゲーション */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
nav.pc {
}
	nav.pc ul.menu li.menu_level01{
		height: auto;
		border-right: 1px solid #707070;
		background-color: #212121;
		position:relative;
		transition:all .3s ease 0s;
	}
	nav.glnav01 ul.menu li.menu_level01{
		width: 20%;
	}
/*
	nav ul.menu li.menu_level01:nth-child(1){
		display: none;
	}
	nav ul.menu li.menu_level01:nth-child(6){
		border-right:none;
	}
	nav ul.menu li.menu_level01:nth-child(7){
		display: none;
	}
*/
	nav.pc ul.menu li.menu_level01:last-child{
		border-right:none;
	}
	nav.pc ul.menu li.menu_level01:hover{
		background-color: #ddd;
	}
	nav.pc ul.menu li.menu_level01:nth-child(6){
		border-right: none;
	}
		nav.pc ul.menu li.menu_level01 a.mnlv_a01{
			width: 100%;
			display: flex;
			align-items: center;
			justify-content: center;
			color:#fff;
			text-align: center;
		}
		nav.glnav01 ul.menu li.menu_level01 a.mnlv_a01{
			height: 96px;
			font-size:1.2rem;
			line-height: 1.2rem;
			letter-spacing: 0.12rem;
		}
		nav.glnav01 ul.menu li.menu_level01:hover a.mnlv_a01{
			color:#000;
		}	
		nav.glnav01 ul.menu li.menu_level01 a.mnlv_a01 span{
			font-size:0.6rem;
			letter-spacing: 0.1rem;
			color:#959695;
		}

		li.menu_level01 ul.menu_level02 {
			visibility: hidden;
			opacity: 0;	
			z-index: 2;
			position: absolute;
			top: 96px;
			width: 100%;
			height: auto;
			background:rgba(241,241,241,1.00);
			text-align: center;			
			-webkit-transition: all .3s ease;
			transition: all .2s ease;
		}
		li.menu_level01:hover ul.menu_level02 {
			visibility: visible;
			opacity: 1;
		}
			li.menu_level01 ul.menu_level02 li{
				position:relative;
				width: 100%;
				color:#000;
				border-bottom: 1px solid rgba(68,68,68,.2);
				font-size:.8rem;
				line-height: 1.1rem;
				letter-spacing: .08rem;
			}
			li.menu_level01 ul.menu_level02 li:last-child{
				border-bottom: none;
			}
			li.menu_level01 ul.menu_level02 li:after{
				content:'';
				background: url("../img/top/news_arrowright.svg") no-repeat center;
				background-size: contain;
				display: block;
				width: 6px;
				height: 10px;
				position:absolute;
				top:50%;
				right:10px;
				transform: translateY(-50%);
				z-index: 3;
				transition: all .2s;
			}
			li.menu_level01 ul.menu_level02 li:hover:after{
				right:7px;			
			}
				li.menu_level01 ul.menu_level02 li a{
					display:block;
					color:#000;
					padding: 20px 0;					
				}


@keyframes show{
    from{
        opacity: 0;
    }
    to{
        opacity: 1;
    }
}
#global-nav{
	display: none;
}
#global-nav.m_fixed{
	width: 100%;
	display: block;
	position: fixed;	
	top: 0;	
	left: 0;
	z-index: 2;
	animation: show .6s linear 0s;
	opacity:1;
}
#global-nav.m02_fixed{
	opacity:1!important;
	margin-top: 0!important;
}
	#global-nav.m_fixed ul.menu li.menu_level01{
		width: 14.2857%;
	}
	#global-nav.m_fixed ul.menu li.menu_level01:nth-child(6){
		border-right: 1px solid #707070;
	}
		#global-nav.m_fixed ul.menu li.menu_level01 a.mnlv_a01 .logo{
			max-width: 120px;
			width: 68%;
			height: auto;
		}
		#global-nav.m_fixed ul.menu li.menu_level01 a.mnlv_a01 .logo img{
			width: 100%;
			height: auto;
		}

		#global-nav.m_fixed ul.menu li.menu_level01 a.mnlv_a01{
			height: 60px;
			font-size:1rem;
			line-height: 1rem;
			letter-spacing: 0.1rem;
		}
		#global-nav.m_fixed ul.menu li.menu_level01:hover a.mnlv_a01{
			color:#000;
		}
		#global-nav.m_fixed ul.menu li.menu_level01 a.mnlv_a01 span{
			display:none;
		}
		#global-nav.m_fixed ul.menu li.menu_level01 a.mnlv_a01 br.tablet{
			display:block!important;
		}

		#global-nav.m_fixed ul.menu li.menu_level01 ul.menu_level02 {
			top: 60px;
			width: 100%;
			height: auto;
			background:rgba(241,241,241,1.00);
			text-align: center;			
			-webkit-transition: all .3s ease;
			transition: all .2s ease;
		}
		#global-nav.m_fixed ul.menu li.menu_level01:hover ul.menu_level02 {
			visibility: visible;
			opacity: 1;
		}
			#global-nav.m_fixed ul.menu li.menu_level01 ul.menu_level02 li{
				position:relative;
				width: 100%;
				color:#000;
				border-bottom: 1px solid rgba(68,68,68,.2);
				font-size:.7rem;
				line-height: 1.1rem;
				letter-spacing: .08rem;
			}
			#global-nav.m_fixed ul.menu li.menu_level01 ul.menu_level02 li:last-child{
				border-bottom: none;
			}
			#global-nav.m_fixed ul.menu li.menu_level01 ul.menu_level02 li a{
				padding: 14px 0;
			}


/* ハンバーガーメニュー
	--------------------- */
.humburger_cntnr{
	position: fixed;
	top:0;
	right:0;
	z-index: 20;
}
.burger-btn{
	display: block;      
	width:70px;      
	height:70px;      
	position: relative;      
	z-index: 3;
	border:none;   
	background-color: #212121;
}    
	.bar{      
	  width: 30px;      
	  height: 1px;        
	  display: block;      
	  position: absolute;      
	  left: 50%;      
	  transform: translateX(-50%);      
	  background-color: #fff;   
	}    
	.bar_top{   
	  top: 26px;
	}
	.bar_mid{    
	  top: 50%;
	  transform: translate(-50%,-50%);
	}
	.bar_bottom{
	  bottom: 26px;
	}
		.burger-btn.close .bar_top{      
		  transform: translate(-50%,10px) rotate(45deg);      
		  transition: transform .3s;    
		}    
		.burger-btn.close .bar_mid{      
		  opacity: 0;       
		  transition: opacity .3s;    
		}    
		.burger-btn.close .bar_bottom{      
		transform: translate(-50%,-8px) rotate(-45deg);      
		transition: transform .3s;    
		}

.nav-wrapper{      
	display: none;      
	width: 100vw;      
	height: 100vh;      
	position: fixed;      
	top: 0;      
	left: 0;       
	z-index: 2; 
}     
	.header-nav{        
		width: 100%;        
		height: 100%;        
		background-color:#212121;    
		z-index: 2; 
		text-align: center;
		padding: 110px 0;
		color:#fff;
		overflow-y:scroll;
	}     
		.nav_logo{
			display: block;
			width: 160px;
			height: auto;
			margin: 0 auto 50px;
		}
			.nav_logo img{
				width: 100%;
				height: auto;
			}
		.header-nav .nav-list{   
			letter-spacing: .09rem;
		}      
			.header-nav .nav-item{ 
				display: block;
				position: relative;
				font-size:1.2rem;
				line-height: 1.8rem;
				color:#fff;
				cursor: pointer;
			}
			.header-nav .nav-item:hover{ 
				opacity: .6;
				transition: all .4s;
			}
			.header-nav dl .nav-item:nth-child(2n+1){
				margin-top: 34px;
			}
			.header-nav dl .nav-item:first-child{
				margin-top: 0px;
			}
			.header-nav .nav-item span{        
				font-size:0.8rem;
				line-height: 0.8rem;
				color:#959695;
			}
				.header-nav .nav-item::before,
				.header-nav .nav-item::after {
					content: '';
					display: block;
					width: 20px;
					height: 1px;
					border-radius: 5px;
					background: #fff;
					position: absolute;
					right: 30px;
					top: 50%;
					transform: translateY(-50%);
				}
				.header-nav .nav-item::after {
					background: #fff;
					transform: translateY(-50%) rotate(90deg);
					transition: 0.5s;
				}
				.header-nav .nav-item.navitem-a::before,
				.header-nav .nav-item.navitem-a::after {
					display: none;
				}
				.header-nav .nav-item.active::after{
					transform: rotate(0)!important;
				}

			.header-nav dd ul li{  
				display: block;
				width: 60%;
				height: auto;
				font-size:.8rem;
				line-height: 1.2rem;
				border: 1px solid #fff;					
				margin: 0 auto 12px;
				overflow: hidden;	
			}
			.header-nav dd ul li:first-child{  
				margin: 20px auto 12px;
			}
/*
			.header-nav dd ul li:last-child{  
				margin: 0 auto 0px;
			}
*/
				.header-nav dd ul li a{
					display: block!important;
					position: relative;
					width: 100%;
					height: auto;
					padding: 18px 0;					
					color:#fff;
					z-index: 0;
					transition: all 0.2s;
				}
				.header-nav dd ul li a:hover{
					color:#212121;
				}
				.header-nav dd ul li a:before {
					content: "";
					position: absolute;
					top: 0;
					right: 0;
					bottom: 0;
					left: 0;
					background-color:rgba(255,255,255,1);
					transform: translateX(-100%);
					z-index: -1;
					transition: 0.2s ease-in-out;
				}
				.header-nav dd ul li a:hover:before {
					transform: translateX(0);
				}

		.header-nav .contact_btn{   
			margin: 60px auto 20px!important;
			text-align: left!important;
		} 
		.header-nav .contact_btn li{   
			margin: 0 auto!important;
			width: 280px!important;
			border: 1px solid #fff!important;			
		}
		.header-nav .contact_btn li:nth-child(2){   
			margin: 20px auto!important;		
		} 	
		.header-nav .contact_btn li a {
			height: 80px!important;
			font-size: 1rem!important;
			line-height: 1.4rem!important;
			padding: 0 38px 0 36px!important;
			position: relative;
		}
		.header-nav .contact_btn li p{
			position:relative;
			overflow: hidden;
		}
			.header-nav .contact_btn li p:after {
				content: url("../img/common/arrow_f0.svg");
				display: block;
				width: 20px;
				height: 6px;
				position: absolute;
				top: 40%;
				right: 16px;
				margin-top: -8px;
				transition: all 0.2s;
			}
			.header-nav .contact_btn li p:hover:after {
				content: url("../img/common/arrow_b0.svg");
				display: block;
				width: 20px;
				height: 6px;
				position: absolute;
				top: 40%;
				right: 16px;
				margin-top: -8px;
				transition: all 0.2s;
			}
			.header-nav .contact_btn li p:before {
				content: "";
				position: absolute;
				top: 0;
				right: 0;
				bottom: 0;
				left: 0;
				background-color:rgba(255,255,255,1);
				transform: translateX(-100%);
				z-index: 0;
				transition: 0.2s ease-in-out;
			}
			.header-nav .contact_btn li p:hover:before {
				transform: translateX(0);
			}

		.header-nav .sns_icon {
			margin: 40px auto 0;
		}
			.header-nav .sns_icon a {
				width: 40px;
				height: 40px;
				background-color: #333333;
			}
			.header-nav .sns_icon a:first-child {
				margin-right: 20px;
			}
				.header-nav .sns_icon a:first-child:before {
					height: 16px;
					width: 8px;
				}
				.header-nav .sns_icon a:nth-child(2):before {
					height: 20px;
					width: 22px;
				}
		.header-nav .fatag_contents{
			margin-top: 60px;
		}
				.header-nav .fatag_contents a{
					display: block;
					color:#fff;
					font-size:1.0rem;
					line-height: 1.0rem;
					margin-bottom: 30px;
				}
				.header-nav .fatag_contents a:hover{
					opacity: .6;
					transition: all .4s;
				}
				.header-nav .fatag_contents a:last-child{
					margin-bottom: 0px;
				}



/* ++++++++++++++++++++++++++++++++++++++++++++++ 
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#main {
}
	
.container{
	max-width: 1200px;
	width: 90%;
	margin: 0 auto;
}

.sec_title h2{
	font-size:3.0rem;
	line-height: 3.0rem;
}
.sec_title p{
	margin-top: 0px;
	color:#737473;
}
	
	ul.blog li a .pht{
		overflow:hidden;
		
	}
	ul.blog li a .pht img{
		-webkit-transform: scale(1);
		  transform: scale(1);
		  -webkit-transition: .3s ease-in-out;
		  transition: .3s ease-in-out;
	}
	ul.blog li a:hover .pht img{
		-webkit-transform: scale(1.08);
		transform: scale(1.08);
	}


		ul.blog li .text{
			margin-top: 16px;
			letter-spacing: .12rem;
			color:#000;
		}
			ul.blog li .text .days{
				display: inline-block;
				font-size:.8rem;
				line-height: .8rem;
				font-weight: 400;
				padding: 2px 0;
			}
			ul.blog li .text span.cat{
				font-size:.6rem;
				line-height: .9rem;
				letter-spacing: .08rem;
				font-weight: 400;
				background-color: #DEE1DA;
				padding: 5px 6px;
				margin-left: 10px;
			}
			ul.blog li .text .tit{
				font-size:.9rem;
				letter-spacing: .1rem;
				text-align: left;
/*
				overflow: hidden;
				text-overflow: ellipsis;
				white-space: nowrap;
*/
				transition: 0.3s ease-in-out;
				margin-top: 5px;
			}
			ul.blog li .text .txt{
				margin-top: 2px;
				font-size:.8rem;
				line-height: 1.2rem;
				letter-spacing: .08rem;
				font-weight: 400;
				 display: -webkit-box;
				-webkit-box-orient: vertical;
				-webkit-line-clamp: 2;
				overflow: hidden;
				transition: 0.3s ease-in-out;
			}
			ul.blog li .text .more{
				margin: 6px 24px 0 0;
				text-align: right;
				font-size:.8rem;
				line-height: .8rem;
			}
				ul.blog li .text .more p.en{
					position: relative;
					display: inline-block;
				}
				ul.blog li .text .more p.en:after{
					content:'';
					background: url("../img/common/arrowb_sharp.svg") no-repeat center;
					background-size: contain;
					width: 18px;
					height: 6px;
					position:absolute;
					top:50%;
					right:-22px;
					margin-top: -3px;
					transition: all .4s;
				}
				ul.blog li a:hover .text .more p.en:after{
					right:-26px;
				}

/* wp-pagenavi
---------------- */
.pagenavi{
	display: table;
	margin: 0 auto;
}
.wp-pagenavi {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	text-align: center;
	padding-top: 60px;
	font-family: 'Poppins', sans-serif;
	font-size: 115%;
	font-weight: 400;
}
.wp-pagenavi a, .wp-pagenavi span {
	width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
	color: #000;
	background: #fff;
	border: 1px solid #212121;	
	margin: 0 5px;
	transition: 0.3s;
	-webkit-transition: 0.3s;
}
.wp-pagenavi a:hover{
	color:#FFF; 
	background: #999; 
}
.wp-pagenavi span.current{
	color: #fff;
	background: #000;
}

/*
.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink{
	border:none;
}
*/



/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#pagetitle {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* パンくず */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#breadcrumb {
	width: 100%;
	background-color: #434343;
}
	#breadcrumb ul{
		padding: 24px 0px 19px 0;
	}
	#breadcrumb ul li{
		position: relative;
		padding: 0px 36px 0px 0;
	}
	#breadcrumb ul li:after{
		content:'-';
		position: absolute;
		top:50%;
		transform: translateY(-60%);
		right:16px;
		margin: auto;
		color:#fff;
		font-size: 1rem;
		line-height: 1rem;
	}
	#breadcrumb ul li:last-child:after{
		display: none;
	}
		#breadcrumb ul li a{
			color:#fff;
			font-size:.8rem;
			line-height:  .8rem;
			letter-spacing: .3rem;
			transition:all .3s;
		}
		#breadcrumb ul li{
			color:#fff;
		}
		#breadcrumb ul li:first-child a{
			color:#AFAFAF;
		}
		#breadcrumb ul li a:hover{
			opacity:.7;
		}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	padding: 60px 0;
	background-color: #212121;
	color:#fff;
}
	#footer .flogo img{
		width: 142px;
		height: 22px;
	}
	#footer .faddress{
		font-size:.8rem;
		margin-left: 24px;
		margin-top: -5px;
	}
#footer .faddress a{
        color: #fff;
    text-decoration: underline;
	}
@media screen and (min-width: 1020px) {
    #footer .faddress a{
        cursor: text;
        pointer-events: none;
        text-decoration: none;
	}
}
	.footer_right{
		margin: 0 0 0 auto;
		text-align: right;
	}
		.footer_right .fatag_contents a{
			color:#fff;
			margin-right: 20px;
			transition: all .4s;
		}
		.footer_right .fatag_contents a:hover{
			opacity:.6;
		}
		.footer_right .fatag_contents a:last-child{
			margin-right: 0px;
		}
			.footer_right .copyright{
				color:#969696;
				font-size:.7rem;
				line-height: .7rem;
				margin-top: 22px;
			}




/* 1200px */
@media screen and (max-width: 1200px) {
/* pc,sp,tablet切り替え */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.tablet{
	display: block;
}





/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ナビゲーション */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#nav {
}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#main {
}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ボタン */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.btn {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#pagetitle {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* パンくず */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#breadcrumb {
}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
}






}

	







/* max 880px */
@media screen and (max-width: 880px) {
	
	
/* pc,sp.tablet切り替え */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.pc{
	display: none;
}
.sp{
	display: block;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
}
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */

.header_inner{
	height: 70px;
	padding-right: 70px;
}
	/* ロゴ
	--------------------- */
	.header_logo{
		display: flex;
		align-items:center;
	}
	.header_inner .header_logo a{
		display: block;
		width: auto;
		margin-left: calc(100vw / 20);
		padding-top: 10px;
	}
		.header_inner .header_logo a img{
			width: 110px;
			height: auto;
		}
/* コンタクトボタン
--------------------- */
.header_inner ul.contact_btn{
	margin: 0 0 0 auto;
}
		.header_inner ul.contact_btn li a{
			height: 70px;
			background-color: transparent;
			font-size:.9rem;
			line-height: 1.0rem;
			text-align: center;
			padding: 0 36px 0 45px!important;
		}

		p .btnb_ani{
			position:relative;				
			overflow: hidden;
			color:#fff;
			transition: 0.2s ease-in-out;
			z-index: 0;
		}
		p .btnb_ani:hover{
			color:#000;
		}
		p .btnb_ani:before {
			display: none;
		}


/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ナビゲーション */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#nav {
}
	
#global-nav.m_fixed{
	display: none;
}



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#main {
}
	
.sec_title{
	text-align: center;
}
.fullwa .sec_title{
	text-align: left;
}
.sec_title h2 {
	font-size: 3rem;
	line-height: 3.4rem;
}
	.sec_title p{
		font-size:1rem;
	}
	
	ul.blog li .text .tit{
		font-size:.8rem;
	}


	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ボタン */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.btn {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#pagetitle {
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* パンくず */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#breadcrumb {
}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	padding: 60px 0;
	background-color: #212121;
	color:#fff;
}
	#footer .flogo{
		width: 100%;
		margin: 0 auto;
	}
	#footer .flogo img{
		display: block;
		width: 100%;
		margin: 0 auto;
	}
	#footer .faddress{
		width: 100%;
		text-align: center;
		font-size:.8rem;
		margin:20px auto 30px;
	}
	.footer_right{
		margin: 0 auto 0;
		text-align: center;
	}
		.footer_right .fatag_contents a{
			display: block;
			margin: 0 auto 5px;
		}
		.footer_right .fatag_contents a:last-child{
			margin: 0px auto;
		}
			.footer_right .copyright{
				text-align: center;
				margin-top: 30px;
			}




}





/* 767px */
@media screen and (max-width: 767px) {
.pcc{
	display: none;
}
.spp{
	display: block;
}
	
	.sec_title{
		text-align: center;
	}
	.sec_title h2 {
		font-size: 1.9rem;
		line-height: 2.3rem;
	}
		.sec_title p{
			font-size:.9rem;
		}
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ボタン */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */	
	
	.return_btn{
		margin: 40px auto 0;
	}	
	
	.btn-4 {
		margin: 20px 0px 0 0;
	}
	.contact_submitbtn .btn-3 {
		margin: 40px 0 0;
		order:-1;
	}


	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ページタイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.pagetitle_sec{
	height: 270px;
	padding-top: 50px;
}
.pagetitle_grp h1{
	font-size:2.2rem;
	line-height: 2.8rem;
	letter-spacing: .3rem
}
.pagetitle_grp p{
	font-size:.8rem;
}

#news .pagetitle_sec{
	background: url("../img/news/news_pagetitlebg_sp.jpg") no-repeat center;
	background-size: cover;
	text-align: center;
}	
#catalog .pagetitle_sec,
#catalog_confirm .pagetitle_sec{
	background: url("../img/catalog/catalog_pagetitlebg_sp.jpg") no-repeat center;
	background-size: cover;
}
#blog .pagetitle_sec{
	background: url("../img/labblog/labblog_pagetitlebg_sp.jpg") no-repeat center;
	background-size: cover;
}
#mystory .pagetitle_sec{
	background: url("../img/mystory/mystory_pagetitlebg_sp.jpg") no-repeat center;
	background-size: cover;
}
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* パンくず */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#breadcrumb ul li a{
	letter-spacing: .3rem;
}



	
	
	
}