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

html {
	font-size: 62.5%;
}

body {
	color: #353535;
	font-size: 1.2rem;
	font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

*, *::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: 1024px) { /*ウィンドウ幅が767px以上の場合に適用*/
	/*ここからheader*/
	.header_img img {
		position: fixed;
		width: 50px;
		height: 50px;
		display: block;
		top: 30px;
		right: 110px;
		z-index: 1000;
	}

	/*ここまでheader*/
	/*ここからハンバーガーメニュー*/

	.black-bg {
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		height: 100vh;
		z-index: 100;
		background-color: rgb(0,0,0);
		opacity: 0;
		visibility: hidden;
		transition: all .6s;
		cursor: pointer;
	}

	.active.black-bg {
		visibility: visible;
		opacity: .7;
	}

	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		z-index: 1000;
		right: 0;
	}

	.menu-trigger {
		position: fixed;
		width: 40px;
		height: 42px;
		right: 60px;
		margin: 30px auto;
	}
	.menu-trigger span {
		position: absolute;
		width: 40px;
		height: 2px;
		background-color: #ff0000;
		border-radius: 2px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 10px;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 20px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 10px;
	}

	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-45deg);
		transform: translateY(10px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-10px) rotate(45deg);
		transform: translateY(-10px) rotate(45deg);
	}

	.menu {
		position: fixed;
		width: 30%;
		height:100vh;
		padding-top: 80px;
		right: -30%;
		background-color: #fff;
		transition: all .6s;
		z-index: 900;
		overflow-y: auto;
	}

	.active.menu {
		right: 0;
	}

	.menu li {
		height: 6rem;
		margin: auto;
		font-size: 2rem;
		padding-left: 40px;
	}

	.menu li a {
		line-height: 6rem;
		display: block;
	}

	.menu_hover {
		display: none;
	}

	a:hover .menu_hover {
		font-size: 2.5rem;
		color: #ff0000;
		display: inline;
	}

	a:hover .menu_normal {
		display: none;
	}

	.menu_item_second {
		text-indent: 3rem;
	}

	/*ここまでハンバーガーメニュー*/
/*ここからdescription*/
	#description {
		width: 100%;
		height: auto;
		margin: 0 auto 50px;
	}
	
	.description_txt {
		width: 40%;
		margin: 80px 20% 0;
		position: absolute;
		z-index: 1;
	}
	
	.description_txt p {
		padding: 50px 20px;
		background-color: #fff;
		font-size: 2rem;
		font-weight: bold;
		line-height: 2.5rem;
	}
	
	.description_img img {
		width: 50%;
		height: auto;
		float: right;
	}

/*ここまでdescription*/
	/*ここからform*/

	form#mail_form * {
		margin: 0;
		padding: 0;
		outline: 0;
	}

	form#mail_form {
		width: 960px;
		margin: 50px auto;
		padding: 10px 0;
		background: #ffffff;
		font-size: 1.8rem;
		line-height: 1.8;
	}

	form#mail_form dl {
		width: 90%;
		margin: 0 auto;
		overflow: hidden;
	}

	form#mail_form dl dt {
		clear: both;
		width: 30%;
		float: left;
		padding: 15px 0;
		text-align: left;
		overflow: hidden;
	}

	form#mail_form dl dd {
		width: 65%;
		float: right;
		padding: 15px 0 15px 5%;
	}

	form#mail_form dl dt:first-child,
	form#mail_form dl dt:first-child + dd {
		border: none;
	}

	form#mail_form dl dt .indention {
		display: block;
		font-size: 85%;
		color: #9B9B9B;
	}

	/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

	form#mail_form dl dt span.required,
	form#mail_form dl dt span.optional {
		display: inline-block;
		float: left;
		color: #ffffff;
		padding: 4px 10px;
	}

	form#mail_form dl dd span.error_blank,
	form#mail_form dl dd span.error_format,
	form#mail_form dl dd span.error_match {
		display: block;
		color: #ff0000;
		margin-top: 3px;
	}


	span.loading {
		width: 50px;
		height: 50px;
		border-radius: 50%;
		border-top: 5px solid rgba( 255, 255, 255, 0.2 );
		border-right: 5px solid rgba( 255, 255, 255, 0.2 );
		border-bottom: 5px solid rgba( 255, 255, 255, 0.2 );
		border-left: 5px solid #ffffff;
		-webkit-transform: translateZ( 0 );
		-ms-transform: translateZ( 0 );
		transform: translateZ( 0 );
		-webkit-animation: load-circle 1.0s linear infinite;
		animation: load-circle 1.0s linear infinite;
		position: absolute;
		top: 50%;
		left: 50%;
		margin-top: -30px;
		margin-left: -30px;
	}

	@-webkit-keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}

	@keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}


	/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


	form#mail_form input[type="text"],
	form#mail_form input[type="email"],
	form#mail_form input[type="tel"] {
		max-width: 90%;
		padding: 7px 2%;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
		margin-top: 7px;
	}

	form#mail_form input[type="text"]:focus,
	form#mail_form input[type="email"]:focus,
	form#mail_form input[type="tel"]:focus,
	form#mail_form textarea:focus {
		border: 1px solid #ff0000;
		background: #fff;
		outline: 0;
	}

	form#mail_form ul li input[type="radio"],
	form#mail_form ul li input[type="checkbox"] {
		margin-right: 10px;
		margin-top: 10px;
	}

	form#mail_form ul li:first-child input[type="radio"],
	form#mail_form ul li:first-child input[type="checkbox"] {
		margin-top: 0px;
	}

	form#mail_form select {
		font-size: 100%;
		font-family: inherit;
		margin-top: 10px;
	}

	form#mail_form textarea {
		display: block;
		width: 90%;
		max-width: 90%;
		height: 200px;
		padding: 7px 2%;
		resize: vertical;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
	}


	form#mail_form ul {
		list-style-type: none;
	}

	form#mail_form ul li label:hover {
		cursor: pointer;
	}


	form#mail_form input#company {
		width: 60%;
	}

	form#mail_form input#name_1,
	form#mail_form input#name_2,
	form#mail_form input#read_1,
	form#mail_form input#read_2,
	form#mail_form input#postal,
	form#mail_form input#phone,
	form#mail_form input#schedule {
		width: 30%;
	}

	form#mail_form input#mail_address,
	form#mail_form input#mail_address_confirm {
		width: 80%;
	}

	form#mail_form input#postal + a {
		display: inline-block;
		padding: 5px 15px;
		border: 1px solid #ff0000;
		background: #5bc0de;
		font-size: 100%;
		color: #ffffff;
		text-decoration: none;
	}

	form#mail_form input#postal + a:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		opacity: .5;
	}

	form#mail_form input#address {
		width: 90%;
	}


	form#mail_form p#form_submit {
		width: 90%;
		margin: 50px auto;
		padding: 15px 0;
	}

	form#mail_form input[type="button"] {
		padding: 7px 20px;
		border: 1px solid #9B9B9B;
		background: #fff;
		font-size: 100%;
		color: #353535;
		font-family: inherit;
		-webkit-appearance: none;
	}

	form#mail_form input[type="button"]:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		color: #fff;
		transition: .4s;
	}

	form#mail_form input#form_submit_button {
		margin-left: 35%;
	}

/*ここからfooter*/

	footer {
		height: 350px;
		background-color: #C9E8F8;
	}

	.footer_flex {
		display: flex;
		padding: 50px 50px 100px;
	}

	.footer_address {
		width: 40%;
		font-size: 1.5rem;
		left: 0;
	}

	.footer_address_flex {
		display: flex;
	}

	.footer_address_logo {
		margin-left: 20px;
		margin-right: 20px;
		left: 0;
	}

	.footer_address_logo img {
		width: 4rem;
		height: auto;
	}

	.footer_address_main {
		right: 0;
	}

	.footer_name {
		font-size: 1.8rem;
		margin-bottom: 10px;
	}

	.footer_sitemap {
		width: 60%;
		font-size: 1.5rem;
		line-height: 3rem;
		right: 0;
	}

	.footer_sitemap_second {
		text-indent: 2rem;
	}

	.footer_sitemap_ul {
		width: 100%;
		display: flex;
	}

	.footer_sitemap_left {
		width: 50%;
		left: 0;
	}

	.footer_sitemap_right {
		width: 50%;
		right: 0;
	}

	small {
		display: block;
		text-align: center;
	}

	/*ここまでfooter*/
	/*ここからその他共通タグ*/
	h1 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 7.5rem;
		padding: 0 5%;
		color: #ACB6E5;
		background: -webkit-linear-gradient(0deg, #43c6ac, #191654);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
	}

	h2 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 6rem;
	}

	h3 {
		font-family: 'Source Sans Pro', YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 4.5rem;
	}
	
	.section_h2 {
		margin-left: 10%;
	}
	
	.red {
		color: #ff0000;
	}
	
	.underline {
		text-decoration: underline;
	}
	
	.wrapper_p {
		width: 70%;
		margin: 30px auto;
		font-size: 1.8rem;
		line-height: 2rem;
	}
	
	/*ここからviewmorebtn*/
	.viewmore_btn {
		width: 500px;
		height: 100px;
		margin: 30px auto;
	}
	
	.viewmore_btn_item {
		display: inline-block;
		width: 100%;
		height: 100%;
		text-align: center;
		background-color: #353535;
		border: 2px solid #353535;
		font-size: 3rem;
		color: #353535;
		text-decoration: none;
		font-weight: bold;
		padding: 10px 24px;
		margin: auto;
		position: relative;
	}

	.viewmore_btn_item span {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		position: relative;
		line-height: 7rem;
		z-index: 1;
		left: 0;
	}
	
	.viewmore_btn_item span::after {
		width: 2.5rem;
		height: 2.5rem;
		position: absolute;
		top: 10;
		bottom: 0;
		left: 280px;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #353535;
		border-right: 2px solid #353535;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item:hover span::after {
		width: 2.5rem;
		height: 2.5rem;
		position: absolute;
		top: 10;
		bottom: 0;
		left: 280px;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item::before,
	.viewmore_btn_item::after {
		content: "";
		display: block;
		background-color: #FFF;
		width: 50%;
		height: 100%;
		position: absolute;
		top: 0;
		transition: .2s;
	}
	
	.viewmore_btn_item::before {
		left: 0;
	}
	
	.viewmore_btn_item::after {
		right: 0;
	}

	.viewmore_btn_item:hover:before,
	.viewmore_btn_item:hover:after {
		width: 0;
		background-color: #FFF;
	}

	.viewmore_btn_item:hover {
		color: #FFF;
	}
	
	/*ここまでviewmorebtn*/
	/*ここからfadein*/

	.fadein_top {
		animation-name: fadein;
		animation-duration: 2s;
	}

	@keyframes fadein {
		from {
			opacity: 0;
			transform: translateX(80px);
		}
		to {
			opacity: 1;
			transform: translateX(0);
		}
	}

	.fadein {
		opacity : 0;
		transform : translate(0, 100px);
		transition : all 1s;
	}

	.fadein.active{
		opacity : 1;
		transform : translate(0, 0);
	}

	.fadein_second {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1s;
	}

	.fadein_second.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	/*ここまでfadein*/
}

/*ここからタブレット*/
@media screen and (min-width: 480px) and (max-width: 1024px) { 
	/*ここからheader*/
	.header_img img {
		position: fixed;
		width: 50px;
		height: 50px;
		display: block;
		top: 30px;
		right: 150px;
		z-index: 1000;
	}

	/*ここまでheader*/
	/*ここからハンバーガーメニュー*/

	.black-bg {
		position: fixed;
		left: 0;
		top: 0;
		width: 100vw;
		height: 100vh;
		z-index: 100;
		background-color: rgb(0,0,0);
		opacity: 0;
		visibility: hidden;
		transition: all .6s;
		cursor: pointer;
	}

	.active.black-bg {
		visibility: visible;
		opacity: .7;
	}

	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		z-index: 1000;
		right: 0;
	}

	.menu-trigger {
		position: fixed;
		width: 40px;
		height: 42px;
		right: 60px;
		margin: 30px auto;
	}
	.menu-trigger span {
		position: absolute;
		width: 40px;
		height: 2px;
		background-color: #ff0000;
		border-radius: 2px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 10px;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 20px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 10px;
	}

	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-45deg);
		transform: translateY(10px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-10px) rotate(45deg);
		transform: translateY(-10px) rotate(45deg);
	}

	.menu {
		position: fixed;
		width: 60%;
		height:100vh;
		padding-top: 80px;
		right: -60%;
		background-color: #fff;
		transition: all .6s;
		z-index: 900;
		overflow-y: auto;
	}

	.active.menu {
		right: 0;
	}

	.menu li {
		height: 6rem;
		margin: auto;
		font-size: 2rem;
		padding-left: 40px;
	}

	.menu li a {
		line-height: 6rem;
		display: block;
	}

	.menu_hover {
		display: none;
	}

	a:hover .menu_hover {
		font-size: 2.5rem;
		color: #ff0000;
		display: inline;
	}

	a:hover .menu_normal {
		display: none;
	}

	.menu_item_second {
		text-indent: 3rem;
	}

	/*ここまでハンバーガーメニュー*/
/*ここからdescription*/
	#description {
		width: 100%;
		height: auto;
		margin: 0 auto 50px;
	}
	
	.description_txt {
		width: 80%;
		margin: 350px 5% 0;
		position: absolute;
		z-index: 1;
		right: 0;
	}
	
	.description_txt p {
		padding: 30px;
		background-color: #fff;
		font-size: 2rem;
		font-weight: bold;
		line-height: 2.5rem;
	}
	
	.description_img {
		margin-top: 30px;
	}
	
	.description_img img {
		width: 100%;
		height: auto;
	}

/*ここまでdescription*/
	/*ここからform*/
	form#mail_form * {
		margin: 0;
		padding: 0;
		outline: 0;
	}

	form#mail_form {
		width: 95%;
		margin: 50px auto;
		padding: 10px 0;
		background: #ffffff;
		font-size: 1.8rem;
		line-height: 1.8;
	}

	form#mail_form dl {
		width: 90%;
		margin: 0 auto;
		overflow: visible;
	}

	form#mail_form dl dt {
		width: auto;
		float: none;
		text-align: left;
		padding: 15px 0 5px;
		font-weight: bold;
	}

	form#mail_form dl dd {
		width: auto;
		float: none;
		border-top: none;
		padding: 0px 0 20px 0px;
	}

	form#mail_form dl dt:first-child,
	form#mail_form dl dt:first-child + dd {
		border: none;
	}

	form#mail_form dl dt .indention {
		display: block;
		font-size: 85%;
		color: #9B9B9B;
	}

	/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

	form#mail_form dl dt span.required,
	form#mail_form dl dt span.optional {
		display: inline-block;
		float: left;
		color: #ffffff;
		padding: 4px 10px;
	}

	form#mail_form dl dd span.error_blank,
	form#mail_form dl dd span.error_format,
	form#mail_form dl dd span.error_match {
		display: block;
		color: #ff0000;
		margin-top: 3px;
	}


	span.loading {
		width: 50px;
		height: 50px;
		border-radius: 50%;
		border-top: 5px solid rgba( 255, 255, 255, 0.2 );
		border-right: 5px solid rgba( 255, 255, 255, 0.2 );
		border-bottom: 5px solid rgba( 255, 255, 255, 0.2 );
		border-left: 5px solid #ffffff;
		-webkit-transform: translateZ( 0 );
		-ms-transform: translateZ( 0 );
		transform: translateZ( 0 );
		-webkit-animation: load-circle 1.0s linear infinite;
		animation: load-circle 1.0s linear infinite;
		position: absolute;
		top: 50%;
		left: 50%;
		margin-top: -30px;
		margin-left: -30px;
	}

	@-webkit-keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}

	@keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}


	/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


	form#mail_form input[type="text"],
	form#mail_form input[type="email"],
	form#mail_form input[type="tel"] {
		max-width: 90%;
		padding: 7px 2%;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
		margin-top: 7px;
	}

	form#mail_form input[type="text"]:focus,
	form#mail_form input[type="email"]:focus,
	form#mail_form input[type="tel"]:focus,
	form#mail_form textarea:focus {
		border: 1px solid #ff0000;
		background: #fff;
		outline: 0;
	}

	form#mail_form ul li input[type="radio"],
	form#mail_form ul li input[type="checkbox"] {
		margin-right: 10px;
		margin-top: 10px;
	}

	form#mail_form ul li:first-child input[type="radio"],
	form#mail_form ul li:first-child input[type="checkbox"] {
		margin-top: 0px;
	}

	form#mail_form select {
		font-size: 100%;
		font-family: inherit;
		margin-top: 10px;
	}

	form#mail_form textarea {
		display: block;
		width: 90%;
		max-width: 90%;
		height: 200px;
		padding: 7px 2%;
		resize: vertical;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
	}


	form#mail_form ul {
		list-style-type: none;
	}

	form#mail_form ul li label:hover {
		cursor: pointer;
	}


	form#mail_form input#company {
		width: 60%;
	}

	form#mail_form input#name_1,
	form#mail_form input#name_2,
	form#mail_form input#read_1,
	form#mail_form input#read_2,
	form#mail_form input#postal,
	form#mail_form input#phone,
	form#mail_form input#schedule {
		width: 30%;
	}

	form#mail_form input#mail_address,
	form#mail_form input#mail_address_confirm {
		width: 80%;
	}

	form#mail_form input#postal + a {
		display: inline-block;
		padding: 5px 15px;
		border: 1px solid #ff0000;
		background: #5bc0de;
		font-size: 100%;
		color: #ffffff;
		text-decoration: none;
	}

	form#mail_form input#postal + a:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		opacity: .5;
	}

	form#mail_form input#address {
		width: 90%;
	}


	form#mail_form p#form_submit {
		width: 90%;
		margin: 50px auto;
		padding: 15px 0;
	}

	form#mail_form input[type="button"] {
		padding: 7px 20px;
		border: 1px solid #9B9B9B;
		background: #fff;
		font-size: 100%;
		color: #353535;
		font-family: inherit;
		-webkit-appearance: none;
	}

	form#mail_form input[type="button"]:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		color: #fff;
		transition: .4s;
	}

	form#mail_form input#form_submit_button {
		margin-left: 35%;
	}

/*ここからfooter*/

	footer {
		height: 350px;
		background-color: #C9E8F8;
	}

	.footer_flex {
		display: flex;
		padding: 50px 20px 100px;
	}

	.footer_address {
		width: 50%;
		font-size: 1.3rem;
		left: 0;
	}

	.footer_address_flex {
		display: flex;
	}

	.footer_address_logo {
		margin-right: 20px;
		left: 0;
	}

	.footer_address_logo img {
		width: 3rem;
		height: auto;
	}

	.footer_address_main {
		right: 0;
	}

	.footer_name {
		font-size: 1.5rem;
		margin-bottom: 10px;
	}

	.footer_sitemap {
		width: 50%;
		font-size: 1.3rem;
		line-height: 3rem;
		right: 0;
	}

	.footer_sitemap_second {
		text-indent: 2rem;
	}

	.footer_sitemap_ul {
		width: 100%;
		display: flex;
	}

	.footer_sitemap_left {
		width: 50%;
		left: 0;
	}

	.footer_sitemap_right {
		width: 50%;
		right: 0;
	}

	small {
		display: block;
		text-align: center;
	}

	/*ここまでfooter*/
	/*ここからその他共通タグ*/
	h1 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 6rem;
		padding: 0 5%;
		color: #ACB6E5;
		background: -webkit-linear-gradient(0deg, #43c6ac, #191654);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
	}

	h2 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 4.5rem;
	}

	h3 {
		font-family: 'Source Sans Pro', YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 3.5rem;
	}

	.section_h2 {
		margin-left: 10%;
	}
	
	.red {
		color: #ff0000;
	}
	
	.underline {
		text-decoration: underline;
	}
	
	.wrapper_p {
		width: 70%;
		margin: 30px auto;
		font-size: 1.8rem;
		line-height: 2rem;
	}

	/*ここからviewmorebtn*/
	.viewmore_btn {
		width: 500px;
		height: 100px;
		margin: 30px auto;
	}
	
	.viewmore_btn_item {
		display: inline-block;
		width: 100%;
		height: 100%;
		text-align: center;
		background-color: #353535;
		border: 2px solid #353535;
		font-size: 3rem;
		color: #353535;
		text-decoration: none;
		font-weight: bold;
		padding: 10px 24px;
		margin: auto;
		position: relative;
	}

	.viewmore_btn_item span {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		position: relative;
		line-height: 7rem;
		z-index: 1;
		left: 0;
	}
	
	.viewmore_btn_item span::after {
		width: 2.5rem;
		height: 2.5rem;
		position: absolute;
		top: 10;
		bottom: 0;
		left: 280px;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #353535;
		border-right: 2px solid #353535;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item:hover span::after {
		width: 2.5rem;
		height: 2.5rem;
		position: absolute;
		top: 10;
		bottom: 0;
		left: 280px;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item::before,
	.viewmore_btn_item::after {
		content: "";
		display: block;
		background-color: #FFF;
		width: 50%;
		height: 100%;
		position: absolute;
		top: 0;
		transition: .2s;
	}
	
	.viewmore_btn_item::before {
		left: 0;
	}
	
	.viewmore_btn_item::after {
		right: 0;
	}

	.viewmore_btn_item:hover:before,
	.viewmore_btn_item:hover:after {
		width: 0;
		background-color: #FFF;
	}

	.viewmore_btn_item:hover {
		color: #FFF;
	}
	
	/*ここまでviewmorebtn*/
	/*ここからfadein*/

	.fadein_top {
		animation-name: fadein;
		animation-duration: 2s;
	}

	@keyframes fadein {
		from {
			opacity: 0;
			transform: translateX(10px);
		}
		to {
			opacity: 1;
			transform: translateX(0);
		}
	}

	.fadein {
		opacity : 0;
		transform : translate(0, 100px);
		transition : all 1s;
	}

	.fadein.active{
		opacity : 1;
		transform : translate(0, 0);
	}

	.fadein_second {
		opacity : 0;
		transform : translate(10px, 0);
		transition : all 1s;
	}

	.fadein_second.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	/*ここまでfadein*/
}
/*ここからスマホ*/
@media screen and (max-width: 480px) { 
	/*ここからheader*/
	.header_img img {
		position: fixed;
		width: 40px;
		height: 40px;
		display: block;
		top: 30px;
		right: 90px;
		z-index: 1000;
	}

	/*ここまでheader*/
	/*ここからハンバーガーメニュー*/

	.black-bg {
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		height: 100vh;
		z-index: 100;
		background-color: rgb(0,0,0);
		opacity: 0;
		visibility: hidden;
		transition: all .6s;
		cursor: pointer;
	}

	.active.black-bg {
		visibility: visible;
		opacity: .7;
	}

	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		z-index: 1000;
		right: 0;
	}

	.menu-trigger {
		position: fixed;
		width: 40px;
		height: 42px;
		right: 30px;
		margin: 30px auto;
	}
	.menu-trigger span {
		position: absolute;
		width: 40px;
		height: 2px;
		background-color: #ff0000;
		border-radius: 2px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 10px;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 20px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 10px;
	}

	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-45deg);
		transform: translateY(10px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-10px) rotate(45deg);
		transform: translateY(-10px) rotate(45deg);
	}

	.menu {
		position: fixed;
		width: 100%;
		height:100%;
		padding-top: 80px;
		right: -100%;
		background-color: #fff;
		transition: all .6s;
		z-index: 900;
		overflow-y: auto;
		opacity: .8;
	}

	.active.menu {
		right: 0;
	}

	.menu li {
		height: 5.5rem;
		margin: auto;
		font-size: 1.6rem;
		padding-left: 20px;
	}

	.menu li a {
		line-height: 5.5rem;
		display: block;
	}

	.menu_hover {
		display: none;
	}

	a:hover .menu_hover {
		font-size: 2rem;
		color: #ff0000;
		display: inline;
	}

	a:hover .menu_normal {
		display: none;
	}

	.menu_item_second {
		text-indent: 3rem;
	}

	/*ここまでハンバーガーメニュー*/
/*ここからdescription*/
	#description {
		width: 100%;
		height: auto;
		margin: 0 auto 50px;
	}
	
	.description_txt {
		width: 80%;
		margin: 200px 5% 0;
		position: absolute;
		z-index: 1;
		right: 0;
	}
	
	.description_txt p {
		padding: 20px;
		background-color: #fff;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 2.2rem;
	}
	
	.description_img {
		margin-top: 30px;
	}
	
	.description_img img {
		width: 100%;
		height: auto;
	}

/*ここまでdescription*/
	/*ここからform*/
	form#mail_form * {
		margin: 0;
		padding: 0;
		outline: 0;
	}

	form#mail_form {
		width: 95%;
		margin: 50px auto;
		padding: 10px 0;
		background: #ffffff;
		font-size: 1.8rem;
		line-height: 1.8;
	}

	form#mail_form dl {
		width: 90%;
		margin: 0 auto;
		overflow: visible;
	}

	form#mail_form dl dt {
		width: auto;
		float: none;
		text-align: left;
		padding: 15px 0 5px;
		font-weight: bold;
	}

	form#mail_form dl dd {
		width: auto;
		float: none;
		border-top: none;
		padding: 0px 0 20px 0px;
	}

	form#mail_form dl dt:first-child,
	form#mail_form dl dt:first-child + dd {
		border: none;
	}

	form#mail_form dl dt .indention {
		display: block;
		font-size: 85%;
		color: #9B9B9B;
	}

	/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

	form#mail_form dl dt span.required,
	form#mail_form dl dt span.optional {
		display: inline-block;
		float: left;
		color: #ffffff;
		padding: 4px 10px;
	}

	form#mail_form dl dd span.error_blank,
	form#mail_form dl dd span.error_format,
	form#mail_form dl dd span.error_match {
		display: block;
		color: #ff0000;
		margin-top: 3px;
	}


	span.loading {
		width: 50px;
		height: 50px;
		border-radius: 50%;
		border-top: 5px solid rgba( 255, 255, 255, 0.2 );
		border-right: 5px solid rgba( 255, 255, 255, 0.2 );
		border-bottom: 5px solid rgba( 255, 255, 255, 0.2 );
		border-left: 5px solid #ffffff;
		-webkit-transform: translateZ( 0 );
		-ms-transform: translateZ( 0 );
		transform: translateZ( 0 );
		-webkit-animation: load-circle 1.0s linear infinite;
		animation: load-circle 1.0s linear infinite;
		position: absolute;
		top: 50%;
		left: 50%;
		margin-top: -30px;
		margin-left: -30px;
	}

	@-webkit-keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}

	@keyframes load-circle {
		0% {
			-webkit-transform: rotate( 0deg );
			transform: rotate( 0deg );
		}
		100% {
			-webkit-transform: rotate( 360deg );
			transform: rotate( 360deg );
		}
	}


	/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


	form#mail_form input[type="text"],
	form#mail_form input[type="email"],
	form#mail_form input[type="tel"] {
		max-width: 90%;
		padding: 7px 2%;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
		margin-top: 7px;
	}

	form#mail_form input[type="text"]:focus,
	form#mail_form input[type="email"]:focus,
	form#mail_form input[type="tel"]:focus,
	form#mail_form textarea:focus {
		border: 1px solid #ff0000;
		background: #fff;
		outline: 0;
	}

	form#mail_form ul li input[type="radio"],
	form#mail_form ul li input[type="checkbox"] {
		margin-right: 10px;
		margin-top: 10px;
	}

	form#mail_form ul li:first-child input[type="radio"],
	form#mail_form ul li:first-child input[type="checkbox"] {
		margin-top: 0px;
	}

	form#mail_form select {
		font-size: 100%;
		font-family: inherit;
		margin-top: 10px;
	}

	form#mail_form textarea {
		display: block;
		width: 90%;
		max-width: 90%;
		height: 200px;
		padding: 7px 2%;
		resize: vertical;
		border: 1px solid #9B9B9B;
		background: #fff;
		-webkit-appearance: none;
		font-size: 100%;
		font-family: inherit;
	}


	form#mail_form ul {
		list-style-type: none;
	}

	form#mail_form ul li label:hover {
		cursor: pointer;
	}


	form#mail_form input#company {
		width: 60%;
	}

	form#mail_form input#name_1,
	form#mail_form input#name_2,
	form#mail_form input#read_1,
	form#mail_form input#read_2,
	form#mail_form input#postal,
	form#mail_form input#phone,
	form#mail_form input#schedule {
		width: 30%;
	}

	form#mail_form input#mail_address,
	form#mail_form input#mail_address_confirm {
		width: 80%;
	}

	form#mail_form input#postal + a {
		display: inline-block;
		padding: 5px 15px;
		border: 1px solid #ff0000;
		background: #5bc0de;
		font-size: 100%;
		color: #ffffff;
		text-decoration: none;
	}

	form#mail_form input#postal + a:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		opacity: .5;
	}

	form#mail_form input#address {
		width: 90%;
	}


	form#mail_form p#form_submit {
		width: 90%;
		margin: 50px auto;
		padding: 15px 0;
	}

	form#mail_form input[type="button"] {
		padding: 7px 20px;
		border: 1px solid #9B9B9B;
		background: #fff;
		font-size: 100%;
		color: #353535;
		font-family: inherit;
		-webkit-appearance: none;
	}

	form#mail_form input[type="button"]:hover {
		cursor: pointer;
		background: #ff0000;
		border: 1px solid #ff0000;
		color: #fff;
		transition: .4s;
	}

	form#mail_form input#form_submit_button {
		margin-left: 35%;
	}


/*ここからfooter*/

	footer {
		height: 230px;
		background-color: #C9E8F8;
	}

	.footer_flex {
		display: flex;
		padding: 50px 10px 80px;
	}

	.footer_address {
		width: 100%;
		font-size: 1.3rem;
	}
	
	.footer_address_flex {
		display: flex;
	}

	.footer_address_logo {
		margin-right: 10px;
		left: 0;
	}

	.footer_address_logo img {
		width: 3rem;
		height: auto;
	}

	.footer_address_main {
		right: 0;
	}

	.footer_name {
		font-size: 1.3rem;
		margin-bottom: 10px;
	}

	small {
		display: block;
		text-align: center;
		font-size: 1rem;
	}

	/*ここまでfooter*/
	/*ここからその他共通タグ*/
	h1 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 4rem;
		padding: 0 5%;
		color: #ACB6E5;
		background: -webkit-linear-gradient(0deg, #43c6ac, #191654);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;

	}

	h2 {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 3.5rem;
	}

	h3 {
		font-family: 'Source Sans Pro', YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		font-size: 2.5rem;
	}
	
	.section_h2 {
		margin-left: 10%;
	}

	.red {
		color: #ff0000;
	}
	
	.pc {
		display: none;
	}
	
	.underline {
		text-decoration: underline;
	}
	
	.wrapper_p {
		width: 80%;
		margin: 30px auto;
		font-size: 1.5rem;
		line-height: 1.8rem;
	}
	
	/*ここからviewmorebtn*/
	.viewmore_btn {
		width: 100%;
		height: 70px;
		margin: 30px auto;
	}
	
	.viewmore_btn_item {
		display: inline-block;
		width: 100%;
		height: 100%;
		text-align: center;
		background-color: #353535;
		border: 2px solid #353535;
		font-size: 1.8rem;
		color: #353535;
		text-decoration: none;
		font-weight: bold;
		margin: auto;
		position: relative;
	}

	.viewmore_btn_item span {
		font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
		position: relative;
		line-height: 7rem;
		z-index: 1;
		left: 0;
	}
	
	.viewmore_btn_item span::after {
		width: 1.5rem;
		height: 1.5rem;
		position: absolute;
		top: 1px;
		bottom: 0;
		left: 140%;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #353535;
		border-right: 2px solid #353535;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item:hover span::after {
		width: 1.5rem;
		height: 1.5rem;
		position: absolute;
		top: 1px;
		bottom: 0;
		left: 140%;
		content: "";
		vertical-align: middle;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	
	.viewmore_btn_item::before,
	.viewmore_btn_item::after {
		content: "";
		display: block;
		background-color: #FFF;
		width: 50%;
		height: 100%;
		position: absolute;
		top: 0;
		transition: .2s;
	}
	
	.viewmore_btn_item::before {
		left: 0;
	}
	
	.viewmore_btn_item::after {
		right: 0;
	}

	.viewmore_btn_item:hover:before,
	.viewmore_btn_item:hover:after {
		width: 0;
		background-color: #FFF;
	}

	.viewmore_btn_item:hover {
		color: #FFF;
	}
	
	/*ここまでviewmorebtn*/
	/*ここからfadein*/

	.fadein_top {
		animation-name: fadein;
		animation-duration: 2s;
	}

	@keyframes fadein {
		from {
			opacity: 0;
			transform: translateX(80px);
		}
		to {
			opacity: 1;
			transform: translateX(0);
		}
	}

	.fadein {
		opacity : 0;
		transform : translate(0, 100px);
		transition : all 1s;
	}

	.fadein.active{
		opacity : 1;
		transform : translate(0, 0);
	}

	.fadein_second {
		opacity : 0;
		transform : translate(100px, 0);
		transition : all 1s;
	}

	.fadein_second.active{
		opacity : 1;
		transform : translate(0, 0);
	}
	/*ここまでfadein*/
}