@charset "UTF-8";
/* CSS Document */

html {
	font-size: 62.5%;
}

body {
	color: #353535;
	font-size: 1.6rem;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
	position: relative;
	cursor: none;
	overflow-x: hidden;
}

*, *::before, *::after {
	box-sizing: border-box;
}

a:link, a:visited, a:hover, a:active {
	color: #353535;
	text-decoration: none;
}
/*ここからPC*/
@media screen and (min-width: 980px) {
/*cursor*/
	.cursor,.follower {
		position: absolute;
		top: 0;
		left: 0;
		cursor: none;
		pointer-events: none;
	}
	
	.cursor {
		width: 8px;
		height: 8px;
		border-radius: 50%;
		background-color: #393939;
		z-index: 99999;
	}
	
	.follower {
		width: 40px;
		height: 40px;
		border-radius: 50%;
		background-color: #737373;
		opacity: .4;
		z-index: 9999;
	}
	
	.follower.is-active {
		width: 60px;
		height: 60px;
		border-radius: 50%;
		background-color: #FF4C00;
	}
/*/cursor*/
/*header*/
	header {
		width: 100%;
		height: auto;
		margin: auto;
		position: fixed;
		background-color: #fff;
		z-index: 999;
		box-shadow: 5px 5px 5px rgba(0,0,0,0.4);
	}

	.header_wrapper {
		width: auto;
		height: auto;
		margin: auto;
		display: flex;
		padding: 20px;
		transition: .4s;
	}
	
	.header_wrapper.transform {
		padding: 0 20px;
	}
	
	.header_img {
		width: 20%;
		height: 100px;
		margin: auto;
		left: 0;
		display: flex;
	}
	
	.header_img a {
		margin: auto;
	}
	
	.header_img img {
		width: 100%;
		height: auto;
	}
	
	.header_links {
		width: 80%;
		height: 100px;
		margin: auto;
		display: flex;
		right: 0;
	}
	
	.header_flex {
		padding-right: 30px;
		display: flex;
		left: 0;
		justify-content: flex-end;
	}
	
	.header_flex a {
		position: relative;
		display: inline-block;
	}
	
	.header_flex a::after {
		position: absolute;
		bottom: 20px;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background: #000000;
		transform: scale(0, 1);
		transform-origin: center top;
		transition: transform .3s;
	}
	
	.header_flex a:hover::after {
		transform: scale(1, 1);
	}
	
	.header_flex_items {
		font-size: 1.8rem;
		padding: 0 20px;
		line-height: 100px;
	}
	
	.header_container {
		width: 85%;
		left: 0;
	}
	
	.header_mailform {
		width: 15%;
		margin: auto;
		right: 0;
		text-align: center;
	}
	
	.header_mailform_btn:hover {
		transition: all .4s;
		opacity: .6;
	}
		
	.header_mailform_btn {
		width: 200px;
		margin: auto;
		background-color: #000000;
		color: #fff;
		line-height: 60px;
		border-radius: 30px;
	}
/*/header*/
/*main*/
	#products {
		width: 100%;
		height: auto;
		padding-top: 140px;
		position: relative;
	}
	
	.wrapper {
		width: 900px;
		margin: auto;
		padding: 100px 0;
	}
	
	.products_h1 {
		width: 600px;
		position: relative;
		margin: auto;
	}
	
	.products_h1 h1 {
		font-size: 4rem;
		text-align: center;
	}
	
	.products_h1 h1::after {
		width: 600px;
		height: 4px;
		position: absolute;
		left: 0;
		bottom: -20px;
		background-color: #FF4C00;
		content: "";
	}
	
	.products_img {
		width: 900px;
		margin: auto;
	}
	
	.products_img img {
		width: 100%;
	}
	
	.sp_h1 {
		display: none;
	}
/*/main*/
/*footer*/
/*contact*/
	.contact_wrapper {
		width: 500px;
		height: auto;
		margin: auto;
		padding: 100px 0;
	}
	
	.contact_container {
		width: 100%;
		height: auto;
		margin: auto;
		padding: 30px 50px;
		background-color: #fff;
	}
	
	.contact_txt {
		text-align: center;
	}
	
	.contact_txt h3 {
		font-size: 3.5rem;
	}
	
	.contact_txt p {
		line-height: 4rem;
	}
	
	.contact_call {
		width: 300px;
		display: flex;
		margin: auto;
	}
	
	.contact_call_icon {
		left: 0;
		padding-right: 10px;
	}
	
	.contact_call_num {
		right: 0;
		font-size: 3rem;
		color: #FF4C00;
	}
	
	.phonenumber_bold {
		padding-left: 10px;
		font-size: 5rem;
	}
	
	.contact_mail {
		width: 300px;
		height: 50px;
		margin: 10px auto 0;
		padding: 0 30px;
		border-radius: 50px;
		display: flex;
		color: #fff;
		background-color: #000000;
	}
	
	.contact_mail_txt {
		left: 0;
		margin: auto;
		font-size: 2.5rem;
	}
	
	.contact_mail_icon {
		right: 0;
		margin: auto;
	}
	
	.contact_item a:hover .contact_mail {
		opacity: .6;
		transition: .4s;
	}
/*/contact*/
/*footer_links*/
	.footer_links {
		background-color: #000000;
		color: #fff;
		padding-top: 50px;
		position: relative;
	}
	
	.footer_links h2 {
		font-size: 3rem;
		text-align: center;
	}
	
	.footer_links_flex {
		width: 800px;
		margin: 50px auto 150px;
		display: flex;
		padding-left: 80px;
	}
	
	.footer_links_flex_item {
		width: 200px;
		color: #5B5B5B;
		line-height: 4rem;
	}
	
	.footer_links_txtindent {
		text-indent: 2rem;
	}
	
	small {
		margin-left: 45%;
		color: #5B5B5B;
	}
/*/footer_links*/
/*/footer*/
/*parallax*/
	.parallax_bg {
		background-image: url("../img/parallax_bg.jpg");
		background-attachment: fixed;
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
	}
	
	.scrollbox {
		background-color: #fff;
	}
/*/parallax*/
/*passing*/
	.passing1 {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1s;
	}

	.passing1.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	
	.passing1 img {
		width: auto;
		height: auto;
	}
	.passing2 {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1.3s;
	}

	.passing2.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	
	.passing2 img {
		width: auto;
		height: auto;
	}
	.passing3 {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1.6s;
	}

	.passing3.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	
	.passing3 img {
		width: auto;
		height: auto;
	}
/*/passing*/
/*focus*/
	.focus {
		opacity: 0;
		transform: scale(0.8);
		transition : all 1s;
	}
	
	.focus.active {
		opacity: 1;
		transform: scale(1);
	}
/*/focus*/
/*common items*/
	.sp {
		display: none;
	}
/*/common items*/
}

/*ここからタブレット*/
@media screen and (min-width: 480px) and (max-width: 980px) {
/*header*/
	.header {
		width: 100%;
		height: 80px;
		margin: auto;
		position: fixed;
		background-color: #fff;
		z-index: 999;
	}
	
	.header_img {
		width: 100%;
		height: 80px;
		margin: auto;
		display: flex;
	}
		
	.header_img a {
		margin: auto;
	}

	.header_img img {
		width: auto;
		height: 50px;
		margin: auto;
	}

	.menu_trigger,
	.menu_trigger span {
		display: inline-block;
		transition: all .4s;
		z-index: 9999;
		right: 0;
	}
	
	.menu_trigger {
		position: fixed;
		width: 40px;
		height: 40px;
		right: 20px;
		top: 20px;
		margin: auto;
	}
	
	.menu_trigger span {
		position: absolute;
		width: 40px;
		height: 10px;
		background-color: #000000;
	}
	
	.menu_trigger span:nth-of-type(1) {
		top: 0px;
	}
	
	.menu_trigger span:nth-of-type(2) {
		top: 15px;
	}
	
	.menu_trigger span:nth-of-type(3) {
		bottom: 0px;
	}

	#menu_trigger.active {
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
	}
	
	#gnav {
		position: fixed;
		width: 100%;
		height: 100vh;
		padding-top: 50px;
		right: -100%;
		background-color: #fff;
		transition: all .6s;
		z-index: -1;
		overflow-y: auto;
	}

	.active#gnav {
		right: 0;
	}

	#gnav li {
		height: 6rem;
		margin: auto;
		font-size: 2rem;
		padding-left: 33%;
	}

	#gnav li a {
		line-height: 6rem;
		display: inline-block;
		font-weight: bold;
	}
	
	#gnav li a:hover {
		color: #E30003;
		transition: all .4s;
	}
	
	.gnav_mailform {
		position: fixed;
		right: 15px;
		top: 80px;
		z-index: -999;
	}
	
	.gnav_svg {
		width: 50px;
		animation: shakeAnime 1.5s linear infinite;
		transform-origin: center bottom;
		-webkit-transform: translate3d(0, 0, 0);
		-ms-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
	
	@keyframes shakeAnime {
		0% {
			transform: rotate(0deg);
		}
		25% {
			transform: rotate(8deg);
		}
		50% {
			transform: rotate(0deg);
		}
		75% {
			transform: rotate(-8deg);
		}
		100% {
			transform: rotate(0deg);
		}
	}
/*/header*/
/*main*/
	#products {
		width: 100%;
		height: auto;
		padding-top: 50px;
		position: relative;
	}
	
	.wrapper {
		width: 450px;
		margin: auto;
		padding: 100px 0;
	}
	
	.products_h1 {
		width: 300px;
		position: relative;
		margin: auto;
	}
	
	.products_h1 h1 {
		font-size: 2rem;
		text-align: center;
	}
	
	.products_h1 h1::after {
		width: 300px;
		height: 4px;
		position: absolute;
		left: 0;
		bottom: -20px;
		background-color: #FF4C00;
		content: "";
	}
	
	.products_img {
		width: 450px;
		margin: 50px auto 0;
	}
	
	.products_img img {
		width: 100%;
	}

	.sp_h1 {
		display: none;
	}
/*/main*/
/*footer*/
/*contact*/
	.contact_wrapper {
		width: 430px;
		height: auto;
		margin: auto;
		padding: 100px 0;
	}
	
	.contact_container {
		width: 100%;
		height: auto;
		margin: auto;
		padding: 30px 50px;
		background-color: #fff;
	}
	
	.contact_txt {
		text-align: center;
	}
	
	.contact_txt h3 {
		font-size: 3.5rem;
	}
	
	.contact_txt p {
		line-height: 4rem;
	}
	
	.contact_call {
		width: 300px;
		display: flex;
		margin: auto;
	}
	
	.contact_call_icon {
		left: 0;
		padding-right: 10px;
	}
	
	.contact_call_num {
		right: 0;
		font-size: 3rem;
		color: #FF4C00;
	}
	
	.phonenumber_bold {
		padding-left: 10px;
		font-size: 5rem;
	}
	
	.contact_mail {
		width: 300px;
		height: 50px;
		margin: 10px auto 0;
		padding: 0 30px;
		border-radius: 50px;
		display: flex;
		color: #fff;
		background-color: #000000;
	}
	
	.contact_mail_txt {
		left: 0;
		margin: auto;
		font-size: 2.5rem;
	}
	
	.contact_mail_icon {
		right: 0;
		margin: auto;
	}
	
	.contact_item a:hover .contact_mail {
		opacity: .6;
		transition: .4s;
	}
/*/contact*/
/*footer_links*/
	.footer_links {
		background-color: #000000;
		color: #fff;
		padding-top: 50px;
		position: relative;
	}
	
	.footer_links h2 {
		font-size: 3rem;
		text-align: center;
	}
	
	.footer_links_flex {
		width: 430px;
		margin: 50px auto 150px;
		padding-left: 190px;
	}
	
	.footer_links_flex_item {
		width: 200px;
		color: #5B5B5B;
		line-height: 4rem;
	}
	
	.footer_links_txtindent {
		text-indent: 2rem;
	}

	small {
		margin-left: 45%;
		color: #5B5B5B;
	}
/*/footer_links*/
/*/footer*/
/*parallax*/
	.parallax_bg {
		background-image: url("../img/parallax_bg.jpg");
		background-attachment: fixed;
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
	}
	
	.scrollbox {
		background-color: #fff;
	}
/*/parallax*/
/*passing*/
	.passing {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1s;
	}

	.passing.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	
	.passing img {
		width: 300px;
		height: auto;
	}
/*/passing*/
/*common items*/
	.pc {
		display: none;
	}
/*/common items*/
}

/*ここからスマホ*/
@media screen and (max-width: 480px) { 
/*header*/
	.header {
		width: 100%;
		height: 80px;
		margin: auto;
		position: fixed;
		background-color: #fff;
		z-index: 999;
	}
	
	.header_img {
		width: auto;
		height: 80px;
		margin: auto;
		display: flex;
	}
		
	.header_img a {
		margin: auto;
	}
	
	.header_img img {
		width: auto;
		height: 30px;
		margin: auto;
	}
	
	.menu_trigger,
	.menu_trigger span {
		display: inline-block;
		transition: all .4s;
		z-index: 9999;
		right: 0;
	}
	
	.menu_trigger {
		position: fixed;
		width: 40px;
		height: 40px;
		right: 20px;
		top: 20px;
		margin: auto;
	}
	
	.menu_trigger span {
		position: absolute;
		width: 40px;
		height: 10px;
		background-color: #000000;
	}
	
	.menu_trigger span:nth-of-type(1) {
		top: 0px;
	}
	
	.menu_trigger span:nth-of-type(2) {
		top: 15px;
	}
	
	.menu_trigger span:nth-of-type(3) {
		bottom: 0px;
	}

	#menu_trigger.active {
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
	}
	
	#gnav {
		position: fixed;
		width: 100%;
		height: 100vh;
		padding-top: 50px;
		right: -100%;
		background-color: #fff;
		transition: all .6s;
		z-index: -1;
		overflow-y: auto;
	}

	.active#gnav {
		right: 0;
	}

	#gnav li {
		height: 6rem;
		margin: auto;
		font-size: 2rem;
		padding-left: 33%;
	}

	#gnav li a {
		line-height: 6rem;
		display: inline-block;
		font-weight: bold;
	}
	
	#gnav li a:hover {
		color: #E30003;
		transition: all .4s;
	}
	
	.gnav_mailform {
		position: fixed;
		right: 15px;
		top: 80px;
		z-index: -999;
	}
	
	.gnav_svg {
		width: 50px;
		animation: shakeAnime 1.5s linear infinite;
		transform-origin: center bottom;
		-webkit-transform: translate3d(0, 0, 0);
		-ms-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
	
	@keyframes shakeAnime {
		0% {
			transform: rotate(0deg);
		}
		25% {
			transform: rotate(8deg);
		}
		50% {
			transform: rotate(0deg);
		}
		75% {
			transform: rotate(-8deg);
		}
		100% {
			transform: rotate(0deg);
		}
	}
/*/header*/
/*main*/
	#products {
		width: 100%;
		height: auto;
		padding-top: 30px;
		position: relative;
	}
	
	.wrapper {
		width: 300px;
		margin: auto;
		padding: 100px 0;
	}
	
	.products_h1 {
		width: 160px;
		position: relative;
		margin: auto;
	}
	
	.products_h1 h1 {
		font-size: 2rem;
		text-align: center;
		line-height: 2.5rem;
	}
	
	.products_h1 h1::after {
		width: 160px;
		height: 4px;
		position: absolute;
		left: 0;
		bottom: -20px;
		background-color: #FF4C00;
		content: "";
	}
	
	.products_img {
		width: 300px;
		margin: 30px auto 0;
	}
	
	.products_img img {
		width: 100%;
	}

/*/main*/
/*footer*/
/*contact*/
	.contact_wrapper {
		width: 310px;
		height: auto;
		margin: auto;
		padding: 100px 0;
	}
	
	.contact_container {
		width: 100%;
		height: auto;
		margin: auto;
		padding: 30px;
		background-color: #fff;
	}
	
	.contact_txt {
		text-align: center;
	}
	
	.contact_txt h3 {
		font-size: 3rem;
	}
	
	.contact_txt p {
		font-size: 1.3rem;
		line-height: 4rem;
	}
	
	.contact_call {
		width: 280px;
		display: flex;
		margin: auto;
	}
	
	.contact_call_icon {
		left: 0;
		padding-right: 10px;
	}
	
	.contact_call_num {
		margin: auto 0;
		right: 0;
		font-size: 2rem;
		color: #FF4C00;
	}
	
	.phonenumber_bold {
		padding-left: 10px;
		font-size: 4rem;
	}
	
	.contact_mail {
		width: 250px;
		height: 50px;
		margin: 10px auto 0;
		padding: 0 30px;
		border-radius: 50px;
		display: flex;
		color: #fff;
		background-color: #000000;
	}
	
	.contact_mail_txt {
		left: 0;
		margin: auto;
		font-size: 2rem;
	}
	
	.contact_mail_icon {
		right: 0;
		margin: auto;
	}
	
	.contact_item a:hover .contact_mail {
		opacity: .6;
		transition: .4s;
	}
/*/contact*/
/*footer_links*/
	.footer_links {
		background-color: #000000;
		color: #fff;
		padding-top: 50px;
		position: relative;
	}
	
	.footer_links h2 {
		font-size: 3rem;
		text-align: center;
	}
	
	.footer_links_flex {
		width: 300px;
		margin: 50px auto 150px;
		padding-left: 100px;
	}
	
	.footer_links_flex_item {
		width: 200px;
		color: #5B5B5B;
		line-height: 4rem;
	}
	
	.footer_links_txtindent {
		text-indent: 2rem;
	}

	small {
		margin-left: 35%;
		color: #5B5B5B;
	}
/*/footer_links*/
/*/footer*/
/*parallax*/
	.parallax_bg {
		background-image: url("../img/parallax_bg.jpg");
		background-attachment: fixed;
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
	}
	
	.scrollbox {
		background-color: #fff;
	}
/*/parallax*/
/*passing*/
	.passing {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1s;
	}

	.passing.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	
	.passing img {
		width: 300px;
		height: auto;
	}
/*/passing*/
/*common items*/
	.pc {
		display: none;
	}
/*/common items*/
}

