@charset "utf-8";
@font-face {
	font-family: 'jost';
	src: url(../fonts/Jost-SemiBold.ttf);
}
.jost {
	font-family: 'jost';
}
.flex {
	display: flex;
	align-items: center;
	justify-content: space-around;
}
.bg {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}
.container {
	width: 1200px;
	margin: 0 auto;
}
header#header {
	width: 100%;
	justify-content: space-between;
	position: fixed;
	top: 0;
	left: 0;
	background-color: #fff;
	z-index: 5000;
}
#header .logo {
	width: 330px;
	transform: translateY(-200%);
	transition: 0.4s all;
}
#header .pages {
	width: 330px;
	transform: translateY(0%);
	transition: 0.4s all;
}
#header .logo figure {
	text-align: center;
}
#header .logo figure img {
	width: 85%;
}
.header_wrap {
	width: 70%;
}
.header_wrap nav {
	justify-content: flex-end;
}
.header_wrap nav ul {
	width: calc(100% - 180px);
	justify-content: flex-start;
}
.header_wrap nav ul li {
	/*width: calc( calc(100% - 180px) / 7);*/
	width: 100%;
	margin-right: calc(100% - 93%);
}
.header_wrap nav ul li:last-child {
	margin-right: 70px;
}
.header_wrap nav ul li a {
	color: #4D4D4D;
	font-size: 20px;
	letter-spacing: 0.1rem;
	transition: 0.3s all;
}
.header_wrap nav ul li a:hover {
	color: #EC8785;
}
.header_wrap a.header_contact {
	background-color: #EC8785;
	width: 180px;
	text-align: center;
	padding: 19px 0;
}
.header_wrap a.header_contact p {
	line-height: 1;
	padding-top: 20px;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
}
#header .hide{
  transform: translateY(0%);
}
/*        共通ボタン        */
a.commonBtn {
	width: 300px;
	margin: 0 auto;
	display: block;
	text-align: center;
	border: 1px solid #707070;
	position: relative;
	padding: 19px 0;
	line-height: 1;
	font-weight: bold;
	font-size: 22px;
	box-sizing: border-box;
	z-index: 20;
	background-color: #fff;
	color: #4D4D4D;
	box-shadow: 4px 4px 0px #4D4D4D;
	transition: 0.3s all;
}
a.commonBtn:hover {
	background-color: #EC8785;
	color: #fff;
}
/*        section共通        */
h2.sec_ttl {
	font-size: 64px;
	text-align: center;
	color: #4D4D4D;
	letter-spacing: 0.2em;
	padding-bottom: 120px;
}
h2.sec_ttl small {
	display: block;
	font-size: 16px;
	text-align: center;
	color: #4D4D4D;
	letter-spacing: 0.05em;
	padding-top: 10px;
}
#campaign h2.sec_ttl {
	padding-bottom: 70px;
}
.sec {
	padding: 96px 0 0 0;
}
.camp_contents {
	width: 100%;
	background-color: #ddd;
	height: 400px;
	margin-bottom: 50px;
}
h2.sec_ttl_sm {
	font-size: 26px;
	color: #EC8785;
}
h2.sec_ttl_sm span {
	display: block;
	font-size: 40px;
	color: #4D4D4D;
	letter-spacing: 0.1em;
	line-height: 1.8;
	padding-top: 16px;
	font-family:"Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "Hiragino Kaku Gothic ProN", Verdana, Meiryo, sans-serif;
}
/*        CONTACT        */
#contact {
	background-color: #EC8785;
	padding-bottom: 110px;
}
#contact h2 {
	color: #fff;
	font-size: 53px;
	padding-bottom: 110px;
}
#contact h2 small {
	color: #fff;
}
#contact ul {
	align-items: flex-start;
}
#contact ul li {
	color: #fff;
	width: 34.166%;
	text-align: center;
	position: relative;
}
#contact ul li::after {
	content: "";
	width: 1px;
	height: 85px;
	background-color: #fff;
	display: block;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
#contact ul li:last-child::after {
	display: none;
}
#contact ul li p {
	font-size: 22px;
	line-height: 1.5;
	font-weight: bold;
	position: relative;
	margin-bottom: 28px;
}
#contact ul li p::after {
	content: "";
	background-image: url(./images/arrow_down.svg);
	background-size: 15px 9px;
	width: 15px;
	height: 9px;
	background-repeat: no-repeat;
	position: absolute;
	bottom: -20px;
	right: 0;
	left: 0;
	margin: auto;
}
#contact ul li a.contact_tel {
	color: #fff;
	display: block;
	text-align: center;
	font-size: 34px;
	letter-spacing: 0.1em;
}
#contact ul li small {
	font-size: 16px;
}
#contact ul li a.commonBtn {
	width: 250px;
}

/*        BLOG        */
#blog {
	margin-top: 80px;
}
.blog_wrap {
	background-color: #F8F8F8;
	padding-top: 180px;
	margin-top: -205px;
	padding-bottom: 130px;
}
.blog_wrap .container > ul {
	width: 100%;
	justify-content: space-between;
	align-items: flex-start;
}
.blog_wrap .container > ul > li {
	width: 30%;
	position: relative;
}
.blog_wrap .container > ul li span.thumb {
	width: 100%;
	height: 270px;
	display: block;
}
.blog_wrap .container > ul >li div ul li a {
	display: inline-block;
	color: #4D4D4D;
	font-size: 14px;
	padding: 3px 15px;
	line-height: 1;
	text-align: center;
	border: 1px solid #4D4D4D;
}
.blog_wrap .container > ul > li > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.blog_wrap .container > ul li div {
	justify-content: space-between;
	padding-top: 30px;
}
.blog_wrap .container > ul li div time {
	color: #EC8785;
	letter-spacing: 0.1em;
}
.blog_wrap .container > ul li ul {
	width: 50%;
}
.blog_wrap .container > ul li h2 {
	font-size: 18px;
	color: #4D4D4D;
	padding-top: 30px;
}
a.blogBtn {
	margin-top: -31px;
	letter-spacing: 0.2em;
}

/*     footer     */
#footer {
	padding-top: 110px;
	padding-bottom: 40px;
}
footer .container {
	justify-content: space-between;
	align-items: flex-start;
}
.ft_info {
	width: 480px;
	margin-left: 30px;
}
.ft_info figure {
	margin-bottom: 30px;
}
.ft_info p {
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.1em;
}
.ft_nav {
	width: 650px;
	align-items: center;
}
.ft_nav nav {
	margin-bottom: 80px;
}
.ft_nav ul li a {
	color: #4D4D4D;
	font-size: 18px;
	line-height: 1;
	display: block;
	letter-spacing: 0.1em;
	transition: 0.3s all;
}
.ft_nav ul li a:hover {
	color: #EC8785;
}
.ft_nav ul li a svg path {
	fill: #4D4D4D;
	transition: 0.3s all;
}
.ft_nav ul li a:hover svg path {
	fill: #EC8785;
}
.ft_nav ul.ft_link {
	float: right;
	width: 550px;
	clear: both;
}
#footer small {
	text-align: center;
	display: block;
	letter-spacing: 0.1em;
	color: #4D4D4D;
	padding-top: 66px;
}
.page_mainVisual {
	background-image: url(../images/menu/mv_bg.png);
	padding: 98px 0;
	margin-top: 120px;
	margin-bottom: 150px;
}
.page_mainVisual h1 {
	text-align: center;
	color: #fff;
	font-size: 64px;
	letter-spacing: 0.15em;
	line-height: 1;
	text-transform: uppercase;
}

/*        flex number        */
/*.num_01 {
	order: 1;
}
.num_02 {
	order: 2;
}*/
br.sp {
	display: none;
}
img.img_sp {
	display: none;
}
a.scroll_btn {
	position: fixed;
	right: 5%;
	bottom: 5%;
	z-index: 200;
}
a.btn_contact_sp {
	display: none;
}
@media screen and (max-width: 767px) {
	.container {
		width: 86.666666%;
	}
	.header_wrap {
		width: 100%;
		height: 100vh;
		background-color: #fff;
		transform: translateX(100%);
		opacity: 0;
		transition: 0.8s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 0.8s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 0.8s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 0.8s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav {
		width: 100%;
		flex-wrap: wrap;
		height: 100vh;
		align-content: space-between;
	}
	.header_wrap nav ul {
		flex-wrap: wrap;
		width: 100%;
		padding-top: 35%;
	}
	.header_wrap nav ul li a {
		letter-spacing: 0.15em;
	}
	.header_wrap nav ul li {
		width: 100%;
		margin-right: 0;
		text-align: center;
		margin-bottom: 40px;
		transform: translateX(20px);
		opacity: 0;
	}
	.header_wrap nav ul li:nth-child(1) {
		transition: 1s 0.3s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.3s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.3s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.3s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(2) {
		transition: 1s 0.32s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.32s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.32s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.32s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(3) {
		transition: 1s 0.34s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.34s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.34s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.34s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(4) {
		transition: 1s 0.36s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.36s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.36s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.36s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(5) {
		transition: 1s 0.38s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.38s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.38s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.38s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(6) {
		transition: 1s 0.4s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.4s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.4s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.4s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:nth-child(7) {
		transition: 1s 0.42s cubic-bezier(.19, 1, .22, 1);
		-webkit-transition: 1s 0.42s cubic-bezier(.19, 1, .22, 1);
		-moz-transition: 1s 0.42s cubic-bezier(.19, 1, .22, 1);
		-o-transition: 1s 0.42s cubic-bezier(.19, 1, .22, 1);
	}
	.header_wrap nav ul li:last-child {
		margin-right: 0;
	}
	.header_wrap a.header_contact {
		width: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	header#header {
		flex-wrap: wrap;
		height: 70px;
	}
	.header_wrap a.header_contact p {
		padding-top: 0;
	}
	#header .logo {
		position: absolute;
		z-index: 5000;
	}
	#toggle {
		display: block;
		position: fixed;
		z-index: 1000;
		top: 20px;
		right: 20px;
		width: 30px;
		height: 30px;
	}
	#toggle span {
		display: inline-block;
		width: 30px;
		background-color: #4D4D4D;
		height: 2px;
		transition: all 0.4s ease-out;
		-webkit-transition: all 0.4s ease-out;
		-moz-transition: all 0.4s ease-out;
		-o-transition: all 0.4s ease-out;
	}
	#toggle span:nth-of-type(1) {
		position: absolute;
		top: 0;
		right: 0;
		transform: translateY(0px) rotate(0deg);
	}
	#toggle span:nth-of-type(2) {
		position: absolute;
		top: 10px;
		right: 0;
		opacity: 1;
		transform: translateX(0);
	}
	#toggle span:nth-of-type(3) {
		position: absolute;
		top: 20px;
		right: 0;
		transform: translateY(0px) rotate(0deg);
	}
	.open #toggle span:nth-of-type(1) {
		transform: translateY(10px) rotate(-45deg);
	}
	.open #toggle span:nth-of-type(2) {
		opacity: 0;
		transform: translateX(10px);
	}
	.open #toggle span:nth-of-type(3) {
		transform: translateY(-10px) rotate(45deg) ;
	}
	.open .header_wrap {
		transform: translateX(0%);
		opacity: 1;
	}
	.open .header_wrap nav ul li {
		transform: translateX(0px);
		opacity: 1;
	}
	#header .logo figure {
		text-align: left;
	}
	#header .logo figure img {
		width: 170px;
		padding-left: 6.66667%;
	}
	.header_wrap a.header_contact p {
		padding-left: 20px;
	}
	h2.sec_ttl {
		font-size: 40px;
		padding-bottom: 45px;
	}
	h2.sec_ttl small {
		font-size: 14px;
		line-height: 1.8;
	}
	br.sp {
		display: block;
	}
	#campaign {
		margin-top: 22px;
	}
	a.commonBtn {
		width: 100%;
		font-size: 18px;
	}
	.page_mainVisual h1 {
		font-size: 30px;
	}
	.page_mainVisual {
		padding: 35px 0;
		margin-top: 70px;
		margin-bottom: 48px;
	}
	img.img_sp {
		display: block;
	}
	img.img_pc {
		display: none;
	}
		#contact h2 {
		font-size: 36px;
	}
	#contact ul {
		flex-wrap: wrap;
	}
	#contact ul li {
		width: 100%;
		margin-bottom: 90px;
	}
	#contact ul li::after {
		width: 85px;
		height: 1px;
		left: 0;
		bottom: auto;
		top: -47px;
	}
	#contact {
		padding-bottom: 0;
	}
	#footer {
		padding-top: 50px;
	}
	footer .container {
		flex-wrap: wrap;
	}
	.ft_nav nav {
		display: none;
	}
	.ft_info {
		width: 100%;
		margin-left: 0;
	}
	.ft_info p {
		font-size: 12px;
		text-align: center;
		letter-spacing: 0;
	}
	.ft_info figure {
		text-align: center;
	}
	.ft_info figure img {
		width: 180px;
	}
	.ft_nav ul.ft_link {
		width: 100%;
		flex-wrap: wrap;
		justify-content: space-between;
		margin-top: 45px;
	}
	.ft_nav ul.ft_link li figure {
		text-align: center;
	}
	.ft_nav ul.ft_link li figure img {
		width: 135px;
	}
	.ft_nav ul.ft_link li:nth-child(1) {
		width: 100%;
		margin-bottom: 30px;
	}
	a.scroll_btn {
		display: none;
	}
	a.btn_contact_sp {
		display: block;
		position: absolute;
		bottom: -35px;
		z-index: 500;
		width: 90%;
		margin: auto;
		left: 0;
		right: 0;
	}
	a.btn_contact_sp img {
		width: 100%;
	}

}


@media only screen and (min-width: 767px) and (max-width: 1280px) {
（ここにタブレット用スタイルを記述）
}

