@charset "UTF-8";

*{
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
html{
	font-size: 62.5%;
}
body{
	font-family: 游ゴシック, YuGothic, メイリオ, Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN",  sans-serif;
	font-size: 1.6rem;
	color: #333;
	position: relative;
	letter-spacing: .05em;
	line-height: 1;
	font-weight: 500;
}
main{
	display: block;
	padding: 14.5rem 5rem 15rem;
}
img{
	border:none;
	-webkit-backface-visibility: hidden;
}
ul,ol{
	list-style: none;
}
li{
	list-style-type: none;
}

a{
	text-decoration: none;
	color: #333;
	transition: .3s all ease;
}
a:hover{
	opacity: .7;
	filter: alpha(opacity=70);
}

.sp{
	display: none !important;
}

.pic img,
.pic picture,
.pic source,
.pic a{
	display: block;
	width: 100%;
}
.pic img{
	height: 100%;
	object-fit: cover;
	font-family: "object-fit: cover;";
}
table{
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
}
.bold{
	font-weight: 600;
}
.txt-green{
	color: #009d52;
}
.parag{
	line-height: 2;
}
.narrow{
	padding-left: 5rem;
	padding-right: 5rem;
	margin: 0 auto;
}
/* +++++++++++++++++++++++header++++++++++++++++++++++ */
#header{
	position: fixed;
	left: 0;
	top: 0;
	width: 25rem;
	height: 100vh;
	background: #fff;
	padding: 5rem 5rem 0;
	overflow-y: auto;
}
#copyrights{
	font-size: 1rem;
	letter-spacing: .1em;
	line-height: 1.8;
	position: fixed;
	left: 5rem;
	bottom: 5rem;
}
nav{
	padding-top: 2.5rem;
	padding-bottom: 14rem;
}
nav li{
	border-bottom: 2px dotted #cccccc;
}
nav li a{
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 2rem 0;
	line-height: 1.625;
	font-weight: 600;
}
nav li a span{
	font-size: 1.1rem;
}


/* +++++++++++++++++++++++contents++++++++++++++++++++++ */
#contents{
	width: calc(100% - 25rem);
	margin-left: 25rem;
}


/* +++++++++++++++++++++++footer++++++++++++++++++++++ */
#footer{
	background: #f6f6f6;
	padding: 6.5rem 5rem 5rem;
	position: relative;
}
#footer .logo{
	width: 30rem;
	margin-bottom: 4rem;
	display: block;
}
.group-company{
	display: flex;
	margin-bottom: 11.5rem;
}
.group-company dl{
	width: 41rem;
	font-size: 1.3rem;
}
.group-company dl:nth-of-type(1){
	margin-right: 5rem;
}
.group-company dt{
	border-bottom: 1px dotted #ccc;
	padding-bottom: 1.2rem;
	margin-bottom: 1.5rem;
}
#footer .sitemap{
	display: flex;
	justify-content: space-between;
	font-size: 1.2rem;
}
#footer .sitemap ul{
	display: flex;
}
#footer .sitemap ul li:not(:last-of-type):after{
	content: " ｜ ";
	display: inline;
}
#page-top{
	width: 5rem;
	display: block;
	position: absolute;
	right: 5rem;
	top: -1rem;
}

/* ++++++++++++++++++++++++key-visual++++++++++++++++++++++++ */
#key-visual{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center top;
	height: calc((100vw - 25rem) * 0.46218) ;
}
#page-ttl{
	color: #fff;
	letter-spacing: .1em;
	font-size: 4.8rem;
	text-align: center;
}
#page-ttl span{
	font-size: 50%;
	display: block;
	margin-bottom: 1em;
}
/* ++++++++++++++++++++++++各見出しのスタイル++++++++++++++++++++++++ */
.sec-ttl01{
	font-size: 3.6rem;
	font-weight: 500;
	padding: .7rem 0 .7rem 5rem;
}
.sec-ttl01 span{
	font-size: 1.2rem;
	padding-bottom: 1.5rem;
	display: block;
}
.sec-ttl01.blue{
	border-left: .4rem solid #65aadd;
}
.sec-ttl01.yellow{
	border-left: .4rem solid #ffe114;
}
.sec-ttl01.red{
	border-left: .4rem solid #e94620;
}
.sec-ttl01.navy{
	border-left: .4rem solid #083582;
}
.sec-ttl01.green{
	border-left: .4rem solid #009966;
}
.sec-ttl01.orange{
	border-left: .4rem solid #ff9900;
}
.sec-ttl01.parple{
	border-left: .4rem solid #920783;
}

.sec-ttl01.blue span{
	color: #65aadd;
}
.sec-ttl01.yellow span{
	color: #ffe114;
}
.sec-ttl01.red span{
	color: #e94620;
}
.sec-ttl01.navy span{
	color: #083582;
}
.sec-ttl01.green span{
	color: #009966;
}
.sec-ttl01.orange span{
	color: #ff9900;
}
.sec-ttl01.parple span{
	color: #920783;
}
.sec-ttl02{
	font-size: 3rem;
	letter-spacing: .1em;
	margin-bottom: 3rem;
	line-height: 2;
}
.vertical-txt{
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	font-size: 3.6rem;
}



/* ++++++++++++++++++++++++セクション内共通++++++++++++++++++++++++ */


/* **********************IE用のスタイル************************* */
@media all and (-ms-high-contrast: none){


}



@media screen and (max-width: 1100px){
	#header{
		width: 20rem;
		padding: 5rem 4rem 0;
	}
	#copyrights{
		left: 4rem;
		bottom: 4rem;
	}
	#contents{
		width: calc(100% - 20rem);
		margin-left: 20rem;
	}

	#footer{
		padding: 6.5rem 4rem 4rem;
	}
	#footer .sitemap{
		font-size: 1.1rem;
		flex-wrap: wrap;
	}
	#footer .sitemap ul{
		line-height: 2.25;
	}
}



@media screen and (max-width:768px){
	body{
		width: 100vw;
		font-size: 1.4rem;
	}
	.pc{
		display:none !important;
	}
	.sp{
		display:block !important;
	}
	main{
		padding: 6rem 2.5rem;
	}
	.narrow{
		padding-left: 0;
		padding-right: 0;
	}
/* +++++++++++++++++++++++header++++++++++++++++++++++ */
	#header{
		width: 100%;
		padding: 4rem 2.5rem;
		overflow-y: scroll;
		z-index: 999;
		transition: .2s all ease;
		left: -100vw;
	}
	#header.opened{
		left: 0;
	}
	#header .logo{
		width: 10rem;
		margin: 0 auto;
	}
	#copyrights{
		position: relative;
		left: auto;
		bottom: auto;
		margin-top: 3rem;
	}
	nav{
		padding-top: 2rem;
		padding-bottom: 0;
	}
	nav li a{
		padding: 2rem 0;
	}
	.menu-btn{
		width: 4rem;
		height: 4rem;
		background: #ffe114;
		cursor: pointer;
		position: fixed;
		right: 1.5rem;
		top: 1.5rem;
		border-radius: 100%;
	}
	.menu-btn span{
		display: block;
		width: 2rem;
		height: .2rem;
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		background: #000;
		transition: .2s all ease;
	}
	.menu-btn span:nth-of-type(1){
		transform: translateY(-.4rem);
	}
	.menu-btn span:nth-of-type(2){
		transform: translateY(.4rem);
	}
	.menu-btn.opened span:nth-of-type(1){
		transform: translateY(0) rotate(30deg);
	}
	.menu-btn.opened span:nth-of-type(2){
		transform: translateY(0) rotate(-30deg);
	}
	.logo-btn{
		position: fixed;
		left: 1.5rem;
		top: 1.5rem;
		width: 7.4rem;
		z-index: 99;
	}
/* +++++++++++++++++++++++contents++++++++++++++++++++++ */
	#contents{
		width: 100%;
		margin-left: 0;
	}


/* +++++++++++++++++++++++footer++++++++++++++++++++++ */
	#footer{
		padding: 4rem 2.5rem 2.5rem;
	}
	#footer .logo{
		width: 25rem;
		margin: 0 auto 4rem;
	}
	.group-company{
		flex-direction: column;
		margin-bottom: 2rem;
	}
	.group-company dl{
		width: 100%;
		font-size: 1.3rem;
		margin-bottom: 3rem;
	}
	.group-company dt{
		padding-bottom: 1rem;
		margin-bottom: 1rem;
	}
	.group-company dd{
		line-height: 1.5;
	}
	.group-company dl:nth-of-type(1){
		margin-right: 0;
	}
	#page-top{
		width: 4rem;
		right: 2.5rem;
		top: -1rem;
	}
	#footer .sitemap{
		flex-direction: column;
		align-items: center;
		font-size: 1.1rem;
		letter-spacing: 0;
		text-align: center;
	}
	#footer .sitemap ul{
		line-height: 1;
		flex-wrap: wrap;
		width: 100%;
	}
	#footer .sitemap ul li{
		width: 50%;
		padding: 1em .5em;
	}
	#footer .sitemap ul li:not(:last-of-type):after{
		display: none;
	}

/* ++++++++++++++++++++++++key-visual++++++++++++++++++++++++ */
	#key-visual{
		height: 60vw;
	}
	#page-ttl{
		font-size: 2rem;
	}

/* ++++++++++++++++++++++++++ section title ++++++++++++++++++++++++ */
	.sec-ttl02{
		font-size: 2rem;
		margin-bottom: 2rem;
		line-height: 1.75;
	}
	.sec-ttl01{
		font-size: 2.2rem;
		padding: .7rem 0 .7rem 1.5rem;
		border-width: .3rem !important;
	}
	.sec-ttl01 span{
		font-size: 1.2rem;
		padding-bottom: 1.5rem;
		display: block;
	}
}

