
/* footer
--------------------------- */
#footer{
	position: relative;
	padding-top: 6.34rem;
	padding-bottom: 7.54rem;
}
#footer::after{
	position: absolute;
	content: "";
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #000;
	z-index: -1;
}
.footer_page{
	margin-top: 5.5rem;
}
@media screen and (min-width: 768px){
	#footer{
		padding-top: 8.45rem;
	}
	.footer_page{
		margin-top: 7.33rem;
	}
}
@media screen and (min-width: 992px){
	#footer{
		padding-top: 10.56rem;
		padding-bottom: 9.42rem;
	}
	.footer_page{
		margin-top: 9.33rem;
	}
}
@media screen and (min-width: 1400px){
	#footer{
		padding-top: 12.69rem;
		padding-bottom: 11.33rem;
	}
	.footer_page{
		margin-top: 13.33rem;
	}
}
/* f_con */
.f_con{
	margin-bottom: 5.33rem;
}
.f_con_tit{
	font-size: 0.93rem;
	letter-spacing: 0.05em;
	color: #fff;
	line-height: 1.7;
	margin-bottom: 6.06rem;
}
.f_con_tit .f-eng{
	display: block;
	font-size: 3.33rem;
	font-weight: 300;
	letter-spacing: 0;
	line-height: 1;
	color: #b2b2b2;
	margin-bottom: 1.11rem;
	margin-left: -0.2rem;
}
.f_con_flex{
	margin-bottom: 0;
}
.f_con_flex li{
	position: relative;
	list-style: none;
	text-align: center;
	color: #fff;
	padding: 2rem 0 3rem;
}
.f_con_flex li::before, .f_con_flex li::after{
	position: absolute;
	content: "";
	background-color: rgba(255,255,255,0.5);
	top: 0;
	left: 0;
}
.f_con_flex li::after{
	width: 100%;
	height: 1px;
}
.f_con_flex li:last-child{
	padding-bottom: 0;
}
.f_con_flex li .no{
	color: #a6a6a6;
	font-size: 0.86rem;
	font-weight: 400;
	letter-spacing: -0.05em;
	line-height: 1;
	margin-bottom: 1.7rem;
}
.f_con_flex li .tit{
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	margin-bottom: 1.91rem;
}
.f_con_flex li .tit .f-eng{
	display: block;
	font-size: 1rem;
	font-weight: 400;
	margin-top: 0.05rem;
}
.f_con_flex li .vm{
	background-color: #000;
	border: 1px solid #fff;
	color: #fff;
}
.f_con_flex li .vm:hover{
	background-color: #fff;
	color: #000;
}
@media screen and (min-width: 768px){
	.f_con{
		margin-bottom: 7.1rem;
	}
	.f_con_tit{
		font-size: 1rem;
		margin-bottom: 4.08rem;
	}
	.f_con_tit .f-eng{
		font-size: 4.44rem;
		margin-bottom: 1.48rem;
	}
	.f_con_flex{
		display: flex;
	}
	.f_con_flex li{
		width: calc(100% /3);
		padding-top: 0;
	}
	.f_con_flex li::after{
		width: 1px;
		height: 100%;
	}
	.f_con_flex li:last-child::before{
		width: 1px;
		height: 100%;
		left: unset;
		right: 0;
	}
}
@media screen and (min-width: 768px) and (max-width: 991px){
	.f_con_flex li .tit{
		font-size: 1.3rem;
	}
	.f_con_flex li .vm{
		padding: 1.15rem 4rem;
	}
}
@media screen and (min-width: 992px){
	.f_con{
		margin-bottom: 8.87rem;
	}
	.f_con_tit{
		margin-bottom: 5.1rem;
	}
	.f_con_tit .f-eng{
		font-size: 5.55rem;
		margin-bottom: 1.85rem;
	}
}
@media screen and (min-width: 1200px){
	.f_con_tit{
		margin-bottom: 6.13rem;
	}
	.f_con_tit .f-eng{
		font-size: 6.66rem;
		margin-bottom: 2.23rem;
	}
	.f_con_flex li{
		padding-bottom: 4.66rem;
	}
	.f_con_flex li .no{
		margin-bottom: 3.4rem;
	}
	.f_con_flex li .tit{
		margin-bottom: 2.83rem;
	}
}
@media screen and (min-width: 1400px){
	.f_con{
		margin-bottom: 10.66rem;
	}
}

/* f_follow */
.f_follow{
	position: relative;
	padding: 2.7rem 0;
}
.f_follow::before, .f_follow::after{
	position: absolute;
	content: "";
	width: 94.11%;
	max-width: 1600px;
	height: 1px;
	left: 50%;
	transform: translateX(-50%);
	background-color: rgba(255,255,255,0.5);
}
.f_follow::before{
	top: 0;
}
.f_follow::after{
	bottom: 0;
}
.f_follow_inner{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.f_follow_inner .f-eng{
	font-size: 0.85rem;
	font-weight: 400;
	color: #a6a6a6;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-bottom: 0;
}
.f_sns{
	display: flex;
}
.f_sns a{
	width: auto;
	height: 20px;
	display: block;
	transition: .3s;
}
.f_sns a:not(:first-child){
	margin-left: 20px;
}
.f_sns a:hover{
	opacity: 0.7;
}
.f_sns a img{
	width: 100%;
	height: 100%;
	display: block;
}
@media screen and (min-width: 768px){
	.f_follow{
		padding: 3.1rem 0;
	}
	.f_follow_inner{
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
	.f_follow_inner .f-eng{
		font-size: 1.13rem;
	}
	.f_sns a:not(:first-child){
		margin-left: 25px;
	}
}
@media screen and (min-width: 992px){
	.f_follow{
		padding: 3.87rem 0;
	}
}
@media screen and (min-width: 1400px){
	.f_follow{
		padding: 4.66rem 0;
	}
	.f_sns a{
		height: 25px;
	}
	.f_sns a:not(:first-child){
		margin-left: 30px;
	}
}

/* f_company */
.f_company{
	color: #a6a6a6;
	margin-top: 3.9rem;
}
.f_company_left p{
	font-size: 0.86rem;
	letter-spacing: 0.05em;
	line-height: 2;
}
.f_company_left p + p{
	margin-bottom: 0;
}
.f_company_left p span{
	font-size: 0.73rem;
}
.f_company_right{
	display: flex;
	flex-direction: column;
	margin-top: 3rem;
}
.f_logo{
	width: 150px;
	display: inline-block;
	margin-bottom: 2.01rem;
}
.f_logo a{
	display: block;
}
.f_logo a img{
	width: 100%;
	height: 100%;
}
.f_policy{
	display: inline-block;
	font-size: 0.73rem;
	color: #fff;
	transition: .3s;
	margin-bottom: 0.53rem;
}
.f_policy:hover{
	color: #fff;
	opacity: 0.7;
	text-decoration: none;
}
.f_copy{
	font-size: 0.73rem;
	letter-spacing: 0.05em;
	font-weight: 400;
}
@media screen and (min-width: 768px){
	.f_company{
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
		margin-top: 5.2rem;
	}
	.f_company_right{
		align-items: flex-end;
		margin-top: 0;
	}
	.f_logo{
		width: 170px;
	}
}
@media screen and (min-width: 992px){
	.f_company{
		margin-top: 6.5rem;
	}
	.f_logo{
		width: 185px;
		margin-bottom: 2.51rem;
	}
}
@media screen and (min-width: 1200px){
	.f_logo{
		width: 200px;
		margin-bottom: 3.03rem;
	}
}
@media screen and (min-width: 1400px){
	.f_company{
		margin-top: 7.8rem;
	}
}




/* 767以下の表示設定
----------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 576px) {
ul.footer_menu {
	display: none;
}
}
@media screen and (max-width: 575px) {
	/*　フッター固定メニュー　*/
	ul.footer_menu {
		width: 100%;
		height: 50px;
		display: flex;
		margin: 0;
		padding: 0;
		position: fixed;
		bottom: 0;
		left:0;
		z-index: 999;
        transition: all .4s;
	}
	ul.footer_menu li {
		width: calc(100% / 3);
		margin: 0;
		list-style: none;
		position: relative;
	}
	ul.footer_menu li:not(:last-child)::after{
		position: absolute;
		content: "";
		width: 1px;
		height: 100%;
		background-color: rgba(255,255,255,0.4);
		top: 0;
		right: 0;
	}
	ul.footer_menu li a {
		border: none;
		text-align: center;
		text-decoration: none;
		width: 100%;
			height: 100%;
        font-size: 0.9375rem;
		letter-spacing: 0.08em;
		background-color: #f84519;
		color: #fff;
		display: flex;
		align-items: center;
		justify-content: center;
	}
}