html {
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-overflow-scrolling: touch;
	font-size: 15px;
}
html, body {
	min-width: 1200px;
	width: 100%;
	padding: 0;
	margin: 0;
	height: 100%;
	font-family: 'Roboto', 'Noto Sans JP','ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
@media screen and (max-width:768px){
	html, body {
		min-width: 100%;
		width: 100%;
		padding: 0;
		margin: 0;
		height: 100%;
	}
}
/*---------------------------------------*/
#wrapper {
	opacity: 1;
}
#wrapper.load {
	opacity: 1;
}
/*-----------------------------------------
** section, .__inner
-----------------------------------------*/
section {
	width: 100%;
	position: relative;
}
.__inner {
	width: 1200px;
	margin: 0 auto;
	position: relative;
}
@media screen and (max-width:768px){
	.__inner {
		width: 90%;
		margin: 0 auto;
		position: relative;
	}
}



/*-----------------------------------------
** loading
-----------------------------------------*/
.__loadingWrap{
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,1.0);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
	overflow: hidden;
}
/*progressbar*/
.__progressbar {
	width: 0;
	height: 1px;
	background: rgba(255,47,75,1.0);
	position: fixed;
	bottom: 50%;
	right: 50%;
	transform: translate(50%,50%);
	transition: all 0.2s linear 0s;
	opacity: 1;
}
/*-----------------------------------------
** MORE button
-----------------------------------------*/
.__more-fff {
	display: block;
	font-family: 'Roboto', sans-serif;
	font-size: 0.93rem;
	font-weight: 700;
	width: 160px;
	margin: 0 auto;
	text-align: center;
	border: 1px solid #fff;
	background: rgba(255,255,255,0.0);
	color: #000;
	text-decoration: none;
	transition: 0.3s all;
}
.__more-fff:hover {
	display: block;
	font-family: 'Roboto', sans-serif;
	font-size: 0.93rem;
	font-weight: 700;
	width: 160px;
	margin: 0 auto;
	text-align: center;
	border: 1px solid #fff;
	background: rgba(255,255,255,0.0);
	color: #000;
	text-decoration: none;
	/*padding: 0.5em;*/
}
.__more-000 {
	display: block;
	font-family: 'Roboto', sans-serif;
	font-size: 0.93rem;
	font-weight: 700;
	width: 160px;
	margin: 0 auto;
	text-align: center;
	border: 1px solid #fff;
	/*background: rgba(0,0,0,0.0);*/
	color: #fff;
	text-decoration: none;
	/*padding: 0.5em;*/
	transition: 0.3s all;
}
.__more-000:hover {
	display: block;
	font-family: 'Roboto', sans-serif;
	font-size: 0.93rem;
	font-weight: 700;
	width: 160px;
	margin: 0 auto;
	text-align: center;
	border: 1px solid #fff;
	/*background: rgba(0,0,0,0.0);*/
	color: #fff;
	text-decoration: none;
	/*padding: 0.5em;*/
}

.__more-fff span {
	display: block;
	position: relative;
	padding: 0.5em;
	/*z-index: 2;*/
	background: rgba(255,255,255,0.3);
	transition: 0.3s all;
}
.__more-fff:hover span {
	background: rgba(255,255,255,0.0);
}
.__more-000 span {
	display: block;
	position: relative;
	padding: 0.5em;
	/*z-index: 2;*/
	background: rgba(0,0,0,0.5);
	transition: 0.3s all;
}
.__more-000:hover span {
	background: rgba(0,0,0,0.0);
}
a[class^='__more-'] span::after {
	content: '';
	width: 0;
	height: 100%;
	background: #00ffff;
	background: -moz-linear-gradient(left, #00ffff 1%, #ff00ff 100%);
	background: -webkit-linear-gradient(left, #00ffff 1%,#ff00ff 100%);
	background: linear-gradient(to right, #00ffff 1%,#ff00ff 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffff', endColorstr='#ff00ff',GradientType=1 );
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	transition: 0.3s all;
}
a[class^='__more-']:hover span::after {
	content: '';
	width: 100%;
	height: 100%;
	background: #00ffff;
	background: -moz-linear-gradient(left, #00ffff 1%, #ff00ff 100%);
	background: -webkit-linear-gradient(left, #00ffff 1%,#ff00ff 100%);
	background: linear-gradient(to right, #00ffff 1%,#ff00ff 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffff', endColorstr='#ff00ff',GradientType=1 );
	position: absolute;
	top: 0;
	left: 0;
}

/*-----------------------------------------
** PAGE TOP button
-----------------------------------------*/
#pageTop {
	width: 75px;
	height: 75px;
	color: #000;
	position: fixed;
	bottom: 25px;
	right: 25px;
	z-index: 10;
	cursor: pointer;
	opacity: 1;
	transition: 0.3s all;
}
#pageTop:hover {
	opacity: 0.7;
}
@media screen and (max-width:768px){
	#pageTop {
		width: 45px;
		height: 45px;
		color: #000;
		position: fixed;
		bottom: 15px;
		right: 15px;
		z-index: 10;
		cursor: pointer;
	}
}

/*-----------------------------------------
** btn effect
-----------------------------------------*/
/* rumble effect */

.__rumble:hover {
	animation: rumble 0.12s linear infinite;
}
@keyframes rumble {
	0% {
		transform: rotate(0deg) translate(0, 0);
	}
	12.5% {
		transform: rotate(0.4deg) translate(1px, -1px);
	}
	25% {
		transform: rotate(0.8deg) translate(0px, 1px);
	}
	37.5% {
		transform: rotate(0.4deg) translate(-1px, 0);
	}
	50% {
		transform: rotate(0deg) translate(0, 0);
	}
	62.5% {
		transform: rotate(-0.4deg) translate(1px, 0);
	}
	75% {
		transform: rotate(-0.8deg) translate(0, 1px);
	}
	87.5% {
		transform: rotate(-0.4deg) translate(-1px, -1px);
	}
	100% {
		transform: rotate(0deg) translate(0, 0);
	}
}

/* ripple efect */
.ripple__effect {
	/* 値の変更はエフェクト形体・サイズ・スピードに影響する */
	width: 150px;
	height: 150px;
	/* 必須 */
	position: absolute;
	border-radius: 100%;
	pointer-events: none;
	transform: scale(0);
	opacity: 0;
}

/* エフェクト要素の色を指定 */
.ripple__effect.is-orange {
	background: #FFB700;
}

.ripple__effect.is-blue {
	background: #4aa3df;
}

.ripple__effect.is-black {
	background: #999;
}

/* classが付与されたらアニメーションを実行 */
.ripple__effect.is-show {
	animation: ripple 0.75s ease-out;
}

@keyframes ripple {
	from {
		opacity: 1;
		background: rgba(255, 255, 25, , 1.0);
	}
	to {
		transform: scale(2);
		opacity: 0;
		background: rgba(255, 255, 25, , 1.0);
	}
}

@keyframes zoomUp {
	0% {
		transform: translateX(50%) scale(1.0);
	}
	50% {
		transform: translateX(50%) scale(1.1);
	}
	100% {
		transform: translateX(50%) scale(1.0);
	}
}

/* blur efect */
@keyframes blurAnimation {
	0% {
		filter: blur(20px);
	}
	100% {
		filter: blur(0);
	}
}
.__blurAnimation {
	animation: blurAnimation 1s linear 0s 1 normal forwards running;
}

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

