@charset "UTF-8";
* {
     margin: 0;
     padding: 0;
}
img, a img {
     border: none;
     vertical-align: bottom;
}
a:focus,
area:focus {
     outline:none;
}
.pic {
	width: 100%;
	height: auto;
}
.trans-up {transform: translate(0,60px); opacity: 0;}
.trans-up.on {transform: translate(0,0); opacity: 1; transition: all 1s;}

/*--SP-----------------------------------*/

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

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	font-weight: 300;
	letter-spacing: 0.05em;
	color: #595656;
	background: #000;
}

.no-sp {
	display: none;
}
#gnav-pc {
	display: none;
}

#top h1 {
	position: absolute;
	top: 86px;
	left: calc(50% - (180px /2));
	width: 180px;
	opacity: 0;
	display: none;
}
#top h1.on {
	opacity: 1;
	transition: all 1s;
}
#top .text{
	text-align: center;
}
#top .text .catch-01,
#top .text .catch-02 {
	font-family: 'Noto Sans', sans-serif;
	letter-spacing: 0.05em;
	font-weight: bold;
	font-size: 22px;
	color: #FFF;
	transform: translate(0,60px); opacity: 0;
}
#top .text .catch-01.on,
#top .text .catch-02.on {
	transform: translate(0,0); opacity: 1;
	transition: all 1s;
}
#top .text p.icon {
	width: 32px;
	margin: 20px auto 0;
	opacity: 0;
}
#top .text p.icon.on {
	opacity: 1;
	transition: all 1s;
}

main {
	width: 100%;
	overflow: hidden;
}
footer {
	width: 100%;
	overflow: hidden;
	color: #FFF;
	padding: 50px 0 20px;
	text-align: center;
}

#home #sec01 {
	background: #3e3a39;
	padding: 50px 15px;
	overflow: hidden;
	color: #FFF;
}
#home #sec01 h2 {
	width: 180px;
	margin: 0 auto;
}
#home #sec01 p {
	margin-top: 30px;
	letter-spacing: 0.08em;
	line-height: 180%;
}

#home .cont {
	width: 100%;
	overflow: hidden;
	position: relative;
	border-bottom: 20px solid #3e3a39;
}
#home .cont .bg {
	height: 300px;
	width: 100%;
	overflow: hidden;
	background-position: center bottom;
	background-size: cover;
}
#home .cont .inner {
	box-sizing: border-box;
	width: 100%;
	color: #FFF;
	padding: 15px;
	overflow: hidden;
	background-position: right bottom;
	background-size: cover;
}
#home .cont .inner.trans-up {
	opacity: 1;
	transform: translate(0,0);
}
#home .cont.ffnpcs .inner h3 {
	width: calc(286px * 0.8);
}
#home .cont.mamm .inner h3 {
	width: calc(140px * 0.8);
}
#home .cont.food .inner h3 {
	width: calc(197px * 0.8);
}
#home .cont.education .inner h3 {
	width: calc(170px * 0.8);
}
#home .cont .inner p {
	margin-top: 10px;
	font-size: 13px;
}
#home .cont .inner .arow {
	position: absolute;
	top: calc(50% - (34px / 2));
	right: 15px;
	display: none;
}

}

/*--PC-----------------------------------*/

@media screen and (min-width: 737px) {

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 15px;
	font-weight: 100;
	letter-spacing: 0.05em;
	color: #595656;
	background: #000;
}

.no-pc {
	display: none;
}
header#sp {
	display: none;
}

#top h1 {
	position: absolute;
	top: 60px;
	left: 60px;
	width: 332px;
	opacity: 0;
}
#top h1.on {
	opacity: 1;
	transition: all 1s;
}
#top .text{
	text-align: center;
}
#top .text .catch-01,
#top .text .catch-02 {
	font-family: 'Noto Sans', sans-serif;
	letter-spacing: 0.05em;
	font-weight: bold;
	font-size: 38px;
	color: #FFF;
	transform: translate(0,60px); opacity: 0;
}
#top .text .catch-01.on,
#top .text .catch-02.on {
	transform: translate(0,0); opacity: 1;
	transition: all 1s;
}
#top .text p.icon {
	width: 63px;
	margin: 20px auto 0;
	opacity: 0;
}
#top .text p.icon.on {
	opacity: 1;
	transition: all 1s;
}

main {
	width: calc(100% - 340px);
	float: right;
	overflow: hidden;
}
footer {
	width: calc(100% - 340px);
	float: right;
	overflow: hidden;
	color: #FFF;
	padding: 50px 0 20px;
	text-align: center;
}

#home #sec01 {
	background: #3e3a39;
	padding: 50px 0;
	overflow: hidden;
	text-align: center;
	color: #FFF;
}
#home #sec01 h2 {
	width: 273px;
	margin: 0 auto;
}
#home #sec01 p {
	margin-top: 30px;
	letter-spacing: 0.08em;
	line-height: 180%;
}

#home .cont {
	height: 480px;
	width: 100%;
	overflow: hidden;
	position: relative;
	border-bottom: 20px solid #3e3a39;
}
#home .cont .bg {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	overflow: hidden;
	background-position: right bottom;
	background-size: cover;
}
#home .cont .inner {
	width: 600px;
	color: #FFF;
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 20px 30px;
	overflow: hidden;
	background-position: right bottom;
	background-size: cover;
}
#home .cont.ffnpcs .inner h3 {
	width: 286px;
}
#home .cont.mamm .inner h3 {
	width: 140px;
}
#home .cont.food .inner h3 {
	width: 197px;
}
#home .cont.education .inner h3 {
	width: 170px;
}
#home .cont .inner p {
	margin-top: 20px;
}
#home .cont .inner .arow {
	position: absolute;
	top: calc(50% - (34px / 2));
	right: 20px;
}

}

/*--COMMON-----------------------------------*/

header#sp {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	overflow: hidden;
	z-index: 999;
}
header#sp h1 {
	width: 206px;
	height: auto;
}
header#sp #sp-logo-box{
	overflow: hidden;
	padding: 12px 15px;
	background: rgba(0,0,0,1);
}
header#sp .trigger-box {
	float: right;
	padding: 6px 0 0 0;
	overflow: hidden;
	height: 18px;
}
header#sp .menu-trigger,
header#sp .menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
header#sp .menu-trigger {
	position: relative;
	width: 25px;
	height: 18px;
	cursor: pointer;
}
header#sp .menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #FFF;
	border-radius: 2px;
}
header#sp .menu-trigger span:nth-of-type(1) {
	top: 0;
}
header#sp .menu-trigger span:nth-of-type(2) {
	top: 8px;
}
header#sp .menu-trigger span:nth-of-type(3) {
	bottom: 0;
}
header#sp .menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(8px) rotate(-315deg);
	transform: translateY(8px) rotate(-315deg);
}
header#sp .menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
header#sp .menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-8px) rotate(315deg);
	transform: translateY(-8px) rotate(315deg);
}

#sp-gnavi {
	overflow: hidden;
	color: #FFF;
	padding: 0 0 20px 30px;
	transform: translateX(100%);
	opacity: 0;
	transition: all 1s;
	background: rgba(0,0,0,1);
	position: fixed;
	top: 54px;
	left: 0;
	z-index: 999;
	width: 100%;
	height: 100%;
	box-sizing: border-box;
}
#sp-gnavi.on {
	padding: 0 0 20px 20px;
	transform: translateX(0);
	opacity: 1;
	transition: all 1s;
}
#sp-gnavi ul.main {
	list-style: none;
	margin-top: 15px;
	position: relative;
}
#sp-gnavi ul.sub {
	list-style: none;
	margin-top: 40px;
	position: relative;
}
#sp-gnavi ul.main::after,
#sp-gnavi ul.sub::after {
	content: '';
  position: absolute;
  left: 0;
  bottom: -20px;
  display: inline-block;
  width: 20px;
  height: 1px;
  background-color: #999;
}
#sp-gnavi ul.main li,
#sp-gnavi ul.sub li {
	position: relative;
	margin-bottom: 12px;
}
#sp-gnavi ul.main li a,
#sp-gnavi ul.sub li a {
	color: #FFF;
	text-decoration: none;
	transform: translateX(0);
	transition: all 0.3s;
	display: block;
}
#sp-gnavi ul.main {
	font-size: 14px;
}
#sp-gnavi ul.sub {
	font-size: 13px;
}

#sp-gnavi .sns {
	margin-top: 36px;
	color: #FFF;
}
#sp-gnavi .sns ul {
	list-style: none;
	margin: 8px 0 10px;
}
#sp-gnavi .sns ul li {
	float: left;
	margin-right: 10px;
	width: 24px;
}
#sp-gnavi .sns p {
	clear: left;
	padding-top: 10px;
}

#top {
	width: 100%;
	height: 100vh;
	overflow: hidden;
	background-position:center center;
	background-size: cover;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

#top p.arow {
	position: absolute;
	width: 40px;
	bottom: 20px;
	left: calc(50% - (40px / 2))
}

#content {
	width: 100%;
	overflow: hidden;
}

#gnav-pc {
	width: 330px;
	float: left;
	overflow: hidden;
	padding: 40px 30px 0;
	box-sizing: border-box;
}
.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 998;
}
#gnav-pc p.logo img {
	width: 228px;
}
#gnav-pc ul.main,
#gnav-pc ul.sub {
	list-style: none;
	margin-top: 50px;
	position: relative;
}
#gnav-pc ul.main::after,
#gnav-pc ul.sub::after {
	content: '';
  position: absolute;
  left: 0;
  bottom: -25px;
  display: inline-block;
  width: 20px;
  height: 1px;
  background-color: #999;
}
#gnav-pc ul.main li,
#gnav-pc ul.sub li {
	position: relative;
	margin-bottom: 15px;
}
#gnav-pc ul.main li a,
#gnav-pc ul.sub li a {
	color: #FFF;
	text-decoration: none;
	transform: translateX(0);
	transition: all 0.3s;
	display: block;
}
#gnav-pc ul.main li a:hover,
#gnav-pc ul.sub li a:hover {
	color: #f9ff43;
	transition: all 0.3s;
	transform: translateX(8px);
}
#gnav-pc ul.main {
	font-size: 15px;
}
#gnav-pc ul.sub {
	font-size: 14px;
}

#gnav-pc .sns {
	margin-top: 50px;
	color: #FFF;
}
#gnav-pc .sns ul {
	list-style: none;
	margin: 8px 0 10px;
}
#gnav-pc .sns ul li {
	float: left;
	margin-right: 10px;
	width: 24px;
}
#gnav-pc .sns ul li a img {
}
#gnav-pc .sns ul li a:hover img {
}
#gnav-pc .sns p {
	clear: left;
	padding-top: 10px;
}

#home .cont.ffnpcs .bg {
	background-image: url(img/home/ffnpcs-bg.jpg);
}
#home .cont.mamm .bg {
	background-image: url(img/home/mamm-bg.jpg);
}
#home .cont.food .bg {
	background-image: url(img/home/food-bg.jpg);
}
#home .cont.education .bg {
	background-image: url(img/home/education-bg.jpg);
}

#home .cont.ffnpcs .inner {
	background-image: url(img/home/ffnpcs-bg-c.png);
}
#home .cont.mamm .inner {
	background-image: url(img/home/mamm-bg-c.png);
}
#home .cont.food .inner {
	background-image: url(img/home/food-bg-c.png);
}
#home .cont.education .inner {
	background-image: url(img/home/education-bg-c.png);
}

#home .cont .inner a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
#home .cont .inner:hover {
	opacity: 0.6;
	transition: all 0.6s;
}



















