@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;
}

#ffnpcs h2 {
	width: 265px;
	margin: 0 auto;
}
#mamm h2 {
	width: 131px;
	margin: 0 auto;
}
#food h2 {
	width: 184px;
	margin: 0 auto;
}
#education h2 {
	width: 155px;
	margin: 0 auto;
}
#company h2,
#contact h2 {
	font-family: 'Noto Sans', sans-serif;
	font-size: 24px;
	text-align: center;
	position: relative;
	margin-bottom: 48px;
}
#company h2:before,
#contact h2:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -16px;
  display: inline-block;
  width: 40px;
  height: 2px;
  transform: translateX(-50%);
  background-color: #FFF;
}

main {
	width: 100%;
	overflow: hidden;
	padding: 86px 0 50px;
}
.wrapper {
	color: #FFF;
	margin: 0 auto;
}

main p.catch {
	margin-top: 30px;
	padding: 0 15px;
}
main img.top {
	margin-top: 30px;
}
main .sec-box01 h3 {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 24px;
	text-align: center;
	position: relative;
	margin-bottom: 48px;
}
main .sec-box01 h3:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -16px;
  display: inline-block;
  width: 40px;
  height: 2px;
  transform: translateX(-50%);
  background-color: #FFF;
}

main .sec-box01 {
	margin-top: 30px;
	overflow: hidden;
}
main .sec-box01 p {
	padding: 0 15px 20px;
}
main .sec-box01 figure {
	box-sizing: border-box;
	width: 33.33%;
	float: left;
	margin-top: 0;
	padding: 5px;
}
main .sec-box01 figure img {
	width: 100%;
	height: auto;
}

main .sec-box02 {
	margin-top: 40px;
	overflow: hidden;
	padding: 0 15px;
}
main .sec-box02 h3 {
	font-size: 15px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
}
main .sec-box02 p {
	text-align: center;
	margin-top: 20px;
}

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

#contact dl {
	width: 100%;
	margin: 30px auto 0;
}
#contact dl dt {
	color: #FFF;
	margin: 0 0 10px;
}
#contact dl dt span {
	color: #ff2ed5;
}
#contact dl dd {
	padding: 0 0 16px 0;
	margin-bottom: 16px;
	border-bottom: 1px dotted #727171;
}
#contact input.smpl {
	box-sizing: border-box;
	width: 100%;
	padding: 4px;
	font-size: 16px;
	background: #FFF;
	border: 1px solid #CCC;
}
#contact textarea.smpl {
	box-sizing: border-box;
	width: 100%;
	height: 100px;
	padding: 4px;
	font-size: 16px;
	background: #FFF;
	border: 1px solid #CCC;
}
#contact input.btn {
	box-sizing: border-box;
	width: 100%;
	padding: 4px;
	font-size: 16px;
	background: #8a8a8a;
	color: #FFF;
	border: 1px solid #CCC;
	cursor: pointer;
}
#contact input.btn:focus {
	outline: none;
}
#contact .privacy {
	margin: 50px 0 0;
}
#contact .privacy h3 {
	text-align: center;
	font-size: 16px;
	margin-bottom: 10px;
	color: #FFF;
}
#contact .privacy p {
	font-size: 13px;
	text-align: left;
}

#food .rnb {
	width: calc(207px * 0.8);
	margin: 40px auto 0;
}

}

/*--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;
}

main {
	width: calc(100% - 340px);
	float: right;
	overflow: hidden;
	padding: 50px 0;
}
.wrapper {
	width: 80%;
	min-width: 800px;
	color: #FFF;
	margin: 0 auto;
}

#ffnpcs h2 {
	width: 400px;
	margin: 0 auto;
}
#mamm h2 {
	width: 196px;
	margin: 0 auto;
}
#food h2 {
	width: 276px;
	margin: 0 auto;
}
#education h2 {
	width: 232px;
	margin: 0 auto;
}
#company h2,
#contact h2 {
	font-family: 'Noto Sans', sans-serif;
	font-size: 32px;
	text-align: center;
	position: relative;
	margin-bottom: 40px;
}
#company h2:before,
#contact h2:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -16px;
  display: inline-block;
  width: 48px;
  height: 2px;
  transform: translateX(-50%);
  background-color: #FFF;
}

main p.catch {
	text-align: center;
	margin-top: 40px;
}
main img.top {
	margin-top: 40px;
}
main .sec-box01 h3 {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 28px;
	text-align: center;
	position: relative;
	margin-bottom: 48px;
}
main .sec-box01 h3:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -16px;
  display: inline-block;
  width: 40px;
  height: 2px;
  transform: translateX(-50%);
  background-color: #FFF;
}

main .sec-box01 {
	margin-top: 60px;
	overflow: hidden;
}
main .sec-box01 p {
	padding: 0 15px;
}
main .sec-box01 figure {
	box-sizing: border-box;
	width: 33.33%;
	float: left;
	margin-top: 30px;
	padding: 0 15px;
}
main .sec-box01 figure img {
	width: 100%;
	height: auto;
}

main .sec-box02 {
	margin-top: 60px;
	overflow: hidden;
}
main .sec-box02 h3 {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 30px;
}
main .sec-box02 p {
	text-align: center;
	margin-top: 30px;
}

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

#contact dl {
	width: 800px;
	margin: 30px auto 0;
}
#contact dl dt {
	float: left;
	color: #FFF;
}
#contact dl dt span {
	color: #ff2ed5;
}
#contact dl dd {
	padding: 0 0 16px 200px;
	margin-bottom: 16px;
	border-bottom: 1px dotted #727171;
}
#contact input.smpl {
	width: 500px;
	padding: 4px;
	font-size: 16px;
	background: #FFF;
	border: 1px solid #CCC;
}
#contact textarea.smpl {
	width: 500px;
	height: 100px;
	padding: 4px;
	font-size: 16px;
	background: #FFF;
	border: 1px solid #CCC;
}
#contact input.btn {
	width: 508px;
	padding: 4px;
	font-size: 16px;
	background: #8a8a8a;
	color: #FFF;
	border: 1px solid #CCC;
	cursor: pointer;
}
#contact input.btn:focus {
	outline: none;
}
#contact .privacy {
	text-align: center;
	margin: 50px 0 0;
}
#contact .privacy h3 {
	font-size: 16px;
	margin-bottom: 10px;
	color: #FFF;
}
#contact .privacy p {
	font-size: 13px;
}

#food .rnb {
	width: 207px;
	margin: 80px auto 0;
}

}

/*--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;
}


#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;
}

#ffnpcs {
	background: #8a8b71;
}
#mamm {
	background: #003969;
}
#food {
	background: #8d7b2e;
}
#education {
	background: #5f401a;
}
#company,
#contact {
	background: #3e3a39;
}

main .sns {
	width: 184px;
	margin: 50px auto 0;
}
main .sns ul {
	list-style: none;
}
main .sns ul li {
	float: left;
	width: 36px;
	margin: 0 5px;
}

main .sec-box02 p a {
	color: #f9ff43;
	text-decoration: none;
}

#education p.link {
	font-size: 20px;
	text-align: center;
}
#education p.link a {
	color: #FFF;
	text-decoration: underline;
	transition: all 0.6s;
}
#education p.link a:hover {
	color: #f9ff43;
}








