
@-ms-viewport
{
	width: auto;
	initial-scale: 1;
}
@viewport
{
	width: device-width;
}

html {
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-overflow-scrolling: touch;
}
html, button, input, select, textarea {
	font-family: 'Noto Sans Japanese', 'Nunito', sans-serif;
	letter-spacing: 1px;
}
html, body {
	min-width: 100%;
	width: 100%;
	font-size:16px;
	padding: 0;
	margin: 0;
	height: 100%;
}
body {
	font-family: 'Noto Sans Japanese', 'Nunito', sans-serif;
	background: rgba(255,255,255,1.0);
	color: rgba(0,0,0,1.0);
}
* {
	box-sizing: border-box;
}
*:before,
*:after {
	box-sizing: border-box;
}
a:active,
a:focus {
	text-decoration: none;
}
/*-----------------------------------------
** loading
-----------------------------------------*/
.__loadingWrap{
	width: 100%;
	height: 100%;
	background: rgb(161,214,219);
	background: -moz-linear-gradient(left, rgba(161,214,219,1) 0%, rgba(216,236,224,1) 58%, rgba(255,252,228,1) 100%);
	background: -webkit-linear-gradient(left, rgba(161,214,219,1) 0%,rgba(216,236,224,1) 58%,rgba(255,252,228,1) 100%);
	background: linear-gradient(to right, rgba(161,214,219,1) 0%,rgba(216,236,224,1) 58%,rgba(255,252,228,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a1d6db', endColorstr='#fffce4',GradientType=1 );
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
	overflow: hidden;
	/*display: none;*/
}
.__loadingWrap img {
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -50px;
	margin-left: -50px;
}

/*プログレスバー*/
.__progressbar {
	width: 0;
	height: 100%;
	background: url(../img/bg-loader-pen.png) right center repeat-y;
	background-size: cover;
	position: fixed;
	top: 0;
	left: 0;
	transition: all 0.2s linear 0s;
}

.loader {
	position: absolute;
	bottom: 50%;
	right: 50%;
	transform: translate(50%,50%);
}
.line-scale-pulse-out > div {
	background-color: #22aca1;
	width: 4px;
	height: 35px;
	border-radius: 2px;
	margin: 2px;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
	display: inline-block;
	-webkit-animation: line-scale-pulse-out 0.9s -0.6s infinite cubic-bezier(0.85, 0.25, 0.37, 0.85);
	animation: line-scale-pulse-out 0.9s -0.6s infinite cubic-bezier(0.85, 0.25, 0.37, 0.85); }
.line-scale-pulse-out > div:nth-child(2), .line-scale-pulse-out > div:nth-child(4) {
	-webkit-animation-delay: -0.4s !important;
	animation-delay: -0.4s !important; }
.line-scale-pulse-out > div:nth-child(1), .line-scale-pulse-out > div:nth-child(5) {
	-webkit-animation-delay: -0.2s !important;
	animation-delay: -0.2s !important; }

@-webkit-keyframes line-scale-pulse-out {
	0% {
		-webkit-transform: scaley(1);
		transform: scaley(1); }
	50% {
		-webkit-transform: scaley(0.4);
		transform: scaley(0.4); }
	100% {
		-webkit-transform: scaley(1);
		transform: scaley(1); } }

@keyframes line-scale-pulse-out {
	0% {
		-webkit-transform: scaley(1);
		transform: scaley(1); }
	50% {
		-webkit-transform: scaley(0.4);
		transform: scaley(0.4); }
	100% {
		-webkit-transform: scaley(1);
		transform: scaley(1); } }


#wrapper {
	opacity: 1;
}
#wrapper.load {
	opacity: 1;
	/*transition: opacity 5.0s;
	-moz-transition: opacity 5.0s;
	-webkit-transition: opacity 5.0s;
	-o-transition: opacity 5.0s;*/
}


/*-----------------------------------------
** section
-----------------------------------------*/
section {
	margin: 0;
	padding: 0;
}
/*@media screen and (max-width:980px) {
	section {
		margin: 0;
		padding: 0;
		min-width: 980px;
	}
}
@media screen and (min-width:641px) and (max-width:800px) {
	section {
		margin: 0;
		padding: 0;
		max-width: 100%;
		min-width: inherit;
	}
}
@media screen and (max-width:640px) {
	section {
		margin: 0;
		padding: 0;
		max-width: 100%;
		min-width: inherit;
	}
}*/

/*-----------------------------------------
** footer
-----------------------------------------*/
footer {
	margin: 0 0 0 0;
	padding: 40px 0;
	background: rgba(0,0,0,1.0);
}
footer p {
	color: rgba(255,255,255,1.0);
	font-size: 11px;
	margin: 1em 0;
}

footer.__fff {
	margin: 0 0 0 0;
	padding: 40px 0;
	background: rgba(255,255,255,1.0);
}
footer.__fff p {
	color: rgba(0,0,0,1.0);
	font-size: 11px;
	margin: 1em 0;
}

footer .col-md-7, footer .col-md-5 {
	width: 100%;
	text-align: center;
}
footer h1 {
	width: 100%;
	margin: 0;
}
footer h2, footer h2 img {
	margin:0 auto;
	width: 100%;
	height: auto;
}
footer ul {
	padding-left: 0;
	margin-left: 0;
}
footer ul li, footer h1 a {
	opacity: 1;
	-moz-transition: .5s;
	-webkit-transition: .5s;
	-o-transition: .5s;
	-ms-transition: .5s;
	transition: .5s;
}
footer ul li:hover, footer h1 a:hover {
	opacity: 0.7;
}
footer ul.snsnavi {
	width: 100%;
	height: auto;
	margin: 30px 0 0 0;
	text-align: center;
}
footer ul.snsnavi li {
    display: inline-block;
    margin: 0 0 10px;
    padding: 0 5px;
}
footer ul.bannernav {
	width: 100%;
	height: auto;
	margin: 30px 0 0 0;
	text-align: center;
}
footer ul.bannernav li {
	display: inline;
	margin: 0;
	padding:  0 5px;
}

footer ul.corpnavi {
	width: 100%;
	height: auto;
	margin: 30px 0 0 0;
	text-align: center;
}
footer ul.corpnavi li {
	display: inline;
	margin: 0;
	padding: 0 5px;
}

footer ul.corpnavi li a {
	font-size: 11px;
	color: rgba(255,255,255,1.0);
	font-family: "メイリオ", sans-serif;
}
footer ul.corpnavi li:before {
	content: ">";
	color: rgba(255,255,255,1.0);
	padding: 0 5px 0 0;
}
footer .footer-logo {
	width: 80px;
	height: auto;
	display: block;
	margin: 0 auto;
}
footer .footer-logo img {
	width: 100%;
	height: auto;
}

.sns {
	width: 50%;
	margin: 10px auto 0 auto;
	display: block;
	position: relative;
	z-index: 9;
}
.sns li {
	display: inline-block;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 10;
}
.sns li:last-child {
	top: 4px;
}
.sns li:first-child {
	top: 4px;
}
.sns li {
	width: auto;
	height: auto;
	overflow: hidden;
	margin: 0 0.5% 0 0;
	list-style: none;
	float: none;
	max-width: inherit;
	display: inline-block;
}



/* ==========================================================================
grnv
========================================================================== */





@media (min-width:992px) and (max-width:1200px){
	footer li{
		margin-right:10%;
	}
	footer ul {
		padding-left: 0;
		margin-left: 0;
	}
	
	footer li {
		margin-right: 10%;
	}
	.feature-content {
		width:55%;
	}
	.grnv ul li {
		width: 49%;
	}
	.grnv ul li:nth-child(even),
	.grnv ul li.about {
		width: 49%;
	}
}

@media (min-width:641px) and (max-width:991px){
	footer ul {
		padding-left: 0;
		margin-left: 0;
	}
	footer ul.snsnavi {
		width: 90%;
		height: auto;
		overflow: hidden;
		margin: 30px 5% 0 5%;
	}
	footer ul.snsnavi li {
		width: 25%;
		height:auto;
		float: left;
		margin: 0;
		padding:  0 5px 10px 5px;
	}
	footer ul.snsnavi li a img {
		width: 100%;
	}

	footer ul.bannernav {
		width: 90%;
		height: auto;
		overflow: hidden;
		margin: 30px 5% 0 5%;
	}
	footer ul.bannernav li {
		width: 25%;
		height:auto;
		float: left;
		margin: 0;
		padding:  0 5px 10px 5px;
	}
	footer ul.bannernav li a img {
		width: 100%;
	}
	footer ul.corpnavi {
		width: 90%;
		margin: 30px 5% 0 5%;
		overflow: hidden;
	}
	
	
}

@media (min-width:466px) and (max-width:640px){
	/* ==========================================================================
	footer
	========================================================================== */
	footer {
		padding: 10px 0px;
		background: rgba(0,0,0,1.0);
	}
	footer ul {
		padding-left: 0;
		margin-left: 0;
	}
	footer ul.snsnavi li {
		width: 50%;
		height:auto;
		float: left;
		margin: 0;
		padding:  0 5px 10px 5px;
	}

	footer ul.bannernav li {
		width: 50%;
		height:auto;
		float: left;
		margin: 0;
		padding:  0 5px 10px 5px;
	}

	footer ul.corpnavi {
		margin: 20px 5%;
	}
	footer ul.corpnavi li {
		width: 50%;
		display: block;
		text-align: left;
		float: left;
	}

	footer .footer-logo {
		padding-bottom: 40px;
	}

	.sns {
		width: 100%;
	}
	.sns li {
		/* display: block;*/
		margin: 15px auto;
	}
	.sns li:last-child {
		/* display: block;*/
		margin: 15px auto;
	}
	
	

}


@media screen and (max-width:465px){
	footer {
		padding: 10px 0px;
		background: rgba(0,0,0,1.0);
	}
	footer ul {
		padding-left: 0;
		margin-left: 0;
	}
	footer ul.corpnavi li {
		width: 100%;
	}

	.li_img{
		background:url(../img/button01.png) no-repeat;
		background-size:cover;
		margin-top:2px;
	}

	.li_img02{
		background:url(../img/button02.png) no-repeat;
		background-size:cover;
		margin-top:2px;
	}
	

}



/*---------------------------------
** white footer
---------------------------------*/
footer.__fff {
	margin: 0 0 0 0;
	padding: 40px 0;
	background: rgba(255,255,255,1.0);
}
footer.__fff p {
	color: rgba(0,0,0,1.0);
	font-size: 11px;
	margin: 1em 0;
}
footer.__fff ul.corpnavi li a {
	font-size: 11px;
	color: rgba(0,0,0,1.0);
	font-family: "メイリオ", sans-serif;
}
footer.__fff ul.corpnavi li:before {
	content: ">";
	color: rgba(0,0,0,1.0);
	padding: 0 5px 0 0;
}

@media (min-width:466px) and (max-width:640px){
	footer.__fff {
		padding: 10px 0px;
		background: rgba(255,255,255,1.0);
	}
}
@media screen and (max-width:465px){
	footer {
		padding: 10px 0px;
		background: rgba(255,255,255,1.0);
	}
}

