@charset "utf-8";
/* ===================================================================
//CSS information

// file name  :  common.css
// style info :  スタイル指定
=================================================================== */
.noSMP {
	display:block !important;
}
.visibleSMP {
	display:none !important;
}
.sp .noSMP {
	display:none !important;
}
.sp .visibleSMP {
	display:block !important;
}

.noMobile {
	display:inline-block !important;
}
.visibleMobile {
	display:none !important;
}
.mobile .noMobile {
	display:none !important;
}
.mobile .visibleMobile {
	display:inline-block !important;
}

.min1000 {
	display:inline-block !important;
}
.max1000 {
	display:none !important;
}
.max767 {
	display:none !important;
}
.max360 {
	display:none !important;
}


/**********
// container
**********/

#container {
	position: relative;
}


/**********
// ttl
**********/
#ttl {
	padding:80px 0 0;
}
#ttl h2 {
	position:relative;
	height:0;
	margin:0 0 43px;
	font-size:48px;
	color:#ccc;
	text-align:center;
	line-height:1.1;
	overflow:hidden;
	transition:1s all ease-in-out .2s;
}
	.loadComplete #ttl h2 {
		height:43px;
		margin:0 0 0;
		transform:translateY(-43px);
		opacity:1;
	}
#ttl h2::after {
	content:"";
	position:absolute;
	bottom:0;
	left:50%;
	width:0;
	height:1px;
	background:#ddd;
	transform:translate(-50%);
	transition:1s all ease-in-out .4s;
}
	.loadComplete #ttl h2::after  {
		width:100%;
	}


/**********
// kvSec
**********/
#kvSec {
	position: relative;
}
#kvSec figure::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background: #201b3a;
	transition: 1.5s all .5s cubic-bezier(0.455, 0.03, 0.515, 0.955);
	z-index: 1;
}
#topPage #kvSec figure::before {
	content: none;
}
.loadComplete #kvSec figure::before {
	bottom: 100%;
}
#kvSec figure { overflow: hidden;}
#kvSec figure img { transform: scale(1.1,1.1); transition: 2s all 1s cubic-bezier(0.455, 0.03, 0.515, 0.955);}
.loadComplete #kvSec figure img { transform: scale(1,1);}



/**********
// heading
**********/
h2.h-nomal {
	margin-bottom:20px;
	font-size:2.8em;
	text-align:center;
	line-height:1.5;
	color: #0F0E47;
    font-weight: 500 !important;
}
h3.h-nomal {
	margin-bottom:20px;
	font-size:2.4em;
	text-align:center;
	line-height:1.5;
	color: #0F0E47;
    font-weight: 500 !important;
}

@media only screen and (max-width: 1024px) {
}

@media only screen and (max-width: 767px) {
	h2.h-nomal {
		font-size:2.2em;
		margin-bottom:15px;
	}
	h3.h-nomal {
		font-size:1.8em;
	}
}
@media only screen and (max-width: 360px) {
	h2.h-nomal {
		font-size:1.8em;
	}
	h3.h-nomal {
		font-size:1.6em;
	}
}


/**********
// font-size pc base
**********/
.f60 {font-size:6.0em}
.f48 {font-size:4.8em}
.f40 {font-size:4.0em}
.f36 {font-size:3.6em}
.f30 {font-size:3.0em}
.f24 {font-size:2.4em}
.f20 {font-size:2.0em}
.f18 {font-size:1.8em}
.f16 {font-size:1.6em}
.f14 {font-size:1.4em}
.f12 {font-size:1.2em}
.f075 {font-size:.75em}
.f05 {font-size:.5em}



/**********
// Material icons
**********/
.material-icons {
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: 24px; 
  display: inline-block;
  width: 1em;
  height: 1em;
  line-height: 1;
  text-transform: none;

  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'liga';
}

.material-icons.md-18 { font-size: 18px; }
.material-icons.md-24 { font-size: 24px; }
.material-icons.md-36 { font-size: 36px; }
.material-icons.md-48 { font-size: 48px; }

.material-icons.md-dark { color: rgba(0, 0, 0, 0.54); }
.material-icons.md-dark.md-inactive { color: rgba(0, 0, 0, 0.26); }

.material-icons.md-light { color: rgba(255, 255, 255, 1); }
.material-icons.md-light.md-inactive { color: rgba(255, 255, 255, 0.3); }



/**********
// button
**********/
.button {
	position: relative;
	z-index: 2;
}
.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-transition: all .3s;
	transition: all .3s;
}

.button::after {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-webkit-transform: scale(.5);
	transform: scale(.5);
}

@media only screen and (min-width: 769px) {
	.button:hover {
		color: #fff;
	}
	.button:hover::after {
		background: #201b3a;
		-webkit-transform: scale(1);
		transform: scale(1);
	}
}





/**********
//icon
**********/
.icon-arrow,
.icon-arrow2,
.icon-arrow3 {
	position:relative;
}
.icon-arrow::before,
.icon-arrow::after,
.icon-arrow2::before,
.icon-arrow2::after,
.icon-arrow3::before,
.icon-arrow3::after{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}

.icon-arrow::before{
	left: 6px;
	box-sizing: border-box;
	width: 4px;
	height: 4px;
	border: 3px solid transparent;
	border-left: 5px solid #333;
}
.icon-arrow2::before{
	left: -10px;
	box-sizing: border-box;
	width: 4px;
	height: 4px;
	border: 3px solid transparent;
	border-left: 5px solid #333;
}
.icon-arrow3::before{
	left: -20px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}



/**********
// swipeIcon
**********/
.swipeIcon { display: none;}

	@media only screen and (max-width: 767px) {
		.slideWrap {
			position: relative;
			height: 320px;
			overflow-x: auto;
			overflow-y: hidden;
		}
		.slideWrap > img,
		.slideWrap > figure > img{
			max-width: none;
			width: 600px !important;
		}

		/**********
		//swipeIcon
		**********/
		.swipeIcon {
			display: block;
			position:absolute;
			top:50%;
			left:50%;
			z-index:1;
			width:110px;
			animation: horizontal 1s ease-in-out infinite alternate;
		}
		@keyframes horizontal {
			0% { transform:translate(-30%,-50%); }
		  100% { transform:translate(-70%,-50%);}
		}
	}



/**********
// accordion_icon
**********/
.accordion_icon,
.accordion_icon span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.accordion_icon {
	position: relative;
	width: 25px;
	height: auto;
	float: right;
    margin-right: -25px;
}
.accordion_icon span {
	position: absolute;
    left: 6px;
    width: 50%;
	height: 2px;
    background-color:#fff;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-ms-border-radius: 4px;
	-moz-border-radius: 4px;
	-o-border-radius: 4px;
}
.button:hover .accordion_icon span {
    background-color: #fff;
}
.accordion_icon span:nth-of-type(1) {
    top: 5px;
	transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
}
.accordion_icon span:nth-of-type(2) {
    top: 5px;
	transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
	-moz-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
}
/*＋、－切り替え*/
.accordion_icon.active span:nth-of-type(1) {
	display:none;
}
.accordion_icon.active span:nth-of-type(2) {
	top: 5px;
	transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
}


/**********
// inview
**********/
/* fadeIn */
.inview-fadeIn {
	opacity: 0;
	transform: translate(0,50px); 
	-webkit-transform: translate(0,50px); 
	transition: 1s all cubic-bezier(0.455, 0.03, 0.515, 0.955);;
}
.start-fadeIn {
	opacity: 1.0;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}
.inview-fadeIn.delay1 { transition: 1s all .4s ease; }
.inview-fadeIn.delay2 { transition: 1s all .8s ease; }
.inview-fadeIn.delay3 { transition: 1s all 1.2s ease; }
.inview-fadeIn.delay4 { transition: 1s all 1.6s ease; }

@media only screen and (max-width: 1024px) {
	.inview-fadeIn.delay1 { transition: 1s all ease; }
	.inview-fadeIn.delay2 { transition: 1s all ease; }
	.inview-fadeIn.delay3 { transition: 1s all ease; }
	.inview-fadeIn.delay4 { transition: 1s all ease; }
}

/* zoomIn */
.inview-zoomIn {
	overflow: hidden;
	opacity: 0;
	transform: scale(.9, .9);
	-webkit-transform: scale(.9, .9);
	transition: 1s all cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.start-zoomIn {
	opacity: 1.0;
	transform: scale(1, 1);
	-webkit-transform: scale(1, 1);
}

/* slideIn */
.inview-slideIn {
	position: relative;
}
.inview-slideIn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background: #fff;
	transition: .8s all cubic-bezier(0.455, 0.03, 0.515, 0.955);
	z-index: 1;
}
.start-slideIn::before {
	left: 100%;
}
.inview-slideIn.gray::before { background: #eee; }
.inview-slideIn.gray2::before { background: #e4e4e4; }

/**********
//fig
**********/
figure {
	position: relative;
}
figure figcaption {
	position: absolute;
	bottom: 0;
	right: 0;
	background: rgba(0,0,0,0.5);
	padding: 4px 6px;
	color: #fff;
	font-family: Helvetica, Arial, YuGothic, '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, sans-serif;
}
figure figcaption.noBg {
	position: absolute;
	bottom: 0;
	right: 0;
	background: none;
	padding: 4px 6px;
	color: #333;
	font-family: Helvetica, Arial, YuGothic, '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, sans-serif;
}

/**********
//captionArea
**********/
#captionArea {
	padding: 20px 5%;
	background: #fff;
}
#captionArea li {
	font-size: 1.1em;
	font-family: Helvetica, Arial, YuGothic, '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, sans-serif;
	color: #666;
	margin-bottom: 5px;
	line-height:1.5;
}


/**********
//boxLine
**********/
.boxLine,.boxLine_cur {position: relative; display:block; width:100%;}
.lineSet {position:absolute; -webkit-transition:all 0.3s; transition:all 0.3s; background:#827249;}
.lineT{width: 0; height:3px; top:0; left:0;}
.lineB{width: 0; height:3px; bottom:0; right:0;}
.lineR{height:0; width :3px; right:0; top:0;}
.lineL{height:0; width :3px; left:0; bottom:0;}

@media only screen and (min-width: 769px) {
.boxLine:hover .lineT,.boxLine:hover .lineB{width: 100%;}
.boxLine:hover .lineR,.boxLine:hover .lineL{height:100%;}

}
.boxLine_cur .lineT,.boxLine_cur .lineB{width: 100%;}
.boxLine_cur .lineR,.boxLine_cur .lineL{height:100%;}










@media only screen and (max-width: 1024px) {
	.min1000 {
		display:none !important;
	}
	.max1000 {
		display:inline-block !important;
	}

}
@media only screen and (max-width: 767px) {
	.max767 {
		display:inline-block !important;
	}
	.btnCheck {
		margin-top: 10px;
	}
	.button:hover .accordion_icon span {
		background-color: #333;
	}
}
@media only screen and (max-width: 360px) {
	.max360 {
		display:inline-block !important;
	}
}

@media only screen and (min-width: 1001px) {
	/**********
	//h1 seo
	**********/
	h1#seoText {
		position:absolute;
		bottom:0;
		left:0;
		right:0;
		clear: both;
		font-size:1.2em;
		font-weight:500;
		color:#fff;
		background: #000;
		text-align: center;
		padding: 10px;
		opacity: 1;
	}
	#topPage h1#seoText {
		bottom:0;
	}

	body:not(#topPage) h1 {
			opacity: 1;
	}
}
@media only screen and (max-width: 1024px) {
	#seoText { display:none;}
}



