@charset "utf-8";


/*----------------------------------------------
	Overall settings
-----------------------------------------------*/

body{ min-width: 1100px; color: #1D2A89; text-align: center;}
body.ovh{ position: fixed; left: 0; top: 0; width: 100%; height: 100vh;}
a{ color: #1D2A89; text-decoration:none; -webkit-transition: all .2s; transition: all .2s;}
a:hover{ opacity: .7; text-decoration:none;}
.underline{ text-decoration: underline;}
/* font */
.noto-sans{ font-family: "Noto Sans JP", sans-serif;}
.zen-kaku-gothic{ font-family: "Zen Kaku Gothic New", sans-serif;}
.montserrat{ font-family: "Montserrat", sans-serif;}
/* bg */
.bg-white{ background: #fff;}
/* color */
.white{ color: #fff;}
.red{ color: #c00;}

/*------------------------------ responsive ------------------------------*/
@media screen and (max-width: 768px) {
	body{ min-width: inherit;}
	a:hover{ opacity: 1;}
}
@media screen and (max-width: 768px) {
	html{ font-size: 50%;}
}



/*----------------------------------------------
	header
-----------------------------------------------*/

header{
	background: url("../img/header-bg.jpg") center top / 100% 100% no-repeat;
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
}
header .slide{
	width: 52%;
	position: relative;
	z-index: 2;
}
header .slide img{ border-radius: 0 0 0 32vw;}
header .leftcol{
	width: 48%;
	position: relative;
	padding-top: 165px;
}
header .leftcol .top-ttl{
	font-size: 35px;
	line-height: 1.2;
	text-align: center;
	position: relative;
	z-index: 2;
	padding: 0 3%;
	margin-bottom: 20px;
}
header .leftcol .top-ttl .subt{
	display: flex;
	justify-content: center;
}
header .leftcol .top-ttl .subt em{
	color: #fff;
	font-size: 29px;
	background: url("../img/ttl-bg.png") center / 102px auto no-repeat;
	width: 114px;
	height: 102px;
	display: block;
	padding-top: 20px;
	margin-right: 15px;
}
header .leftcol .top-ttl .subt span{
	font-weight: 500;
	text-align: left;
	display: block;
	padding-top: 10px;
}
header .leftcol .top-ttl strong{
	font-size: 63px;
	font-weight: bold;
}
header .leftcol p.montserrat{
	color: #fff;
	position: absolute;
	z-index: 1;
	top: 288px;
	left: -20px;
	font-size: 145px;
	line-height: .8;
	font-weight: 600;
	text-align: left;
	opacity: .3;
}
header .leftcol dl.top-news{
	position: absolute;
	bottom: 20px;
	left: 2%;
	display: flex;
	align-items: flex-start;
}
header .leftcol dl.top-news dt{
	color: #fff;
	font-size: 15px;
	line-height: 1.2;
	font-weight: 500;
	border-radius: 20px;
	padding: 1px 15px;
	background: #1D2A89;
	width: 92px;
	margin-right: 15px;
}
header .leftcol dl.top-news dd{
	font-size: 14px;
	line-height: 1.2;
}

@media screen and (max-width: 1450px) {
	header .slide{ width: calc( 100% - 680px);}
	header .leftcol{ width: 680px;}
}
@media screen and (max-width: 1150px) {
	header .leftcol .top-ttl strong{ font-size: 60px;}
	header .slide img{ border-radius: 0 0 0 360px;}
	header .leftcol dl.top-news{ position: static; margin-left: 3%;}
}
@media screen and (max-width: 768px) {
	header{
		background: url("../img/header-bg-sp.jpg") center top / 100% 100% no-repeat;
		display: block;
	}
	header .slide{
		width: 100%;
	}
	header .slide img{ border-radius: 0 0 0 55vw;}
	header .leftcol{
		width: 100%;
		padding-top: 5px;
	}
	header .leftcol .top-ttl{
		font-size: 6.033vw;
		padding: 0 3%;
		margin-bottom: 8vw;
	}
	header .leftcol .top-ttl .subt em{
		font-size: 5.6vw;
		background: url("../img/ttl-bg.png") center / 20vw auto no-repeat;
		width: 20vw;
		height: 20vw;
		padding-top: 4vw;
		margin-right: 2vw;
	}
	header .leftcol .top-ttl .subt span{ padding-top: 3vw;}
	header .leftcol .top-ttl strong{ font-size: 8.8vw;}
	header .leftcol p.montserrat{
		top: inherit;
		left: 0;
		bottom: 13vw;
		font-size: 19vw;
	}
	header .leftcol dl.top-news{
		position: static;
		padding-bottom: 2vw;
	}
	header .leftcol dl.top-news dt{
		font-size: 4vw;
		padding: .2vw 3vw;
		width: 24vw;
		margin-right: 3vw;
	}
	header .leftcol dl.top-news dd{ font-size: 3.733vw;}
}



.wrap{ clear: both; box-sizing: content-box; max-width: 1000px; margin-left: auto; margin-right: auto; padding-left: 5%; padding-right: 5%;}
.w1044{max-width: 1044px;}
.btn{
	font-size: 14px;
	line-height: 1.4;
	padding: 8px 25px;
	min-width: 130px;
	border-radius: 99px;
	font-weight: 500;
	display: inline-block;
	background: url("../img/ic-link.svg") right 10px center no-repeat #B4EBD6;
}
.btn.bg-aqua{ background: url("../img/ic-link.svg") right 10px center no-repeat #D0F1FF;}
@media screen and (max-width: 1150px) {
	.btn{
		min-width: 100px;
		background: url("../img/ic-link.svg") right 8px center no-repeat #B4EBD6;
	}
	.btn.bg-aqua{ background: url("../img/ic-link.svg") right 8px center no-repeat #D0F1FF;}
}



/*----------------------------------------------
	top
-----------------------------------------------*/

.top1{
	padding: 65px 0 45px;
	background: url("../img/top1-bg.jpg") center top / 1006px auto no-repeat;
}
.top1 .wrap{
	display: flex;
	justify-content: space-between;
}
.top1 .wrap figure{
	width: 48.85%;
	padding-top: 10px;
}
.top1 .wrap figure img{ border-radius: 200px 200px 0 200px;}
.top1 .wrap div{
	text-align: left;
	width: 47%;
}
.top1 .wrap div h2{
	font-size: 25px;
	margin-bottom: 10px;
}
.top-guide{
	font-size: 13px;
	text-align: left;
	padding: 110px 0 1px;
	background: url("../img/floor-guide-bg.jpg") center / 100% 100% no-repeat;
}
.top-guide .guide1{
	display: flex;
	justify-content: space-between;
	margin-bottom: 40px;
}
.top-guide .guide1 h2{
	font-size: 20px;
	font-weight: normal;
	width: 28%;
	padding-top: 110px;
}
.top-guide .guide1 h2 img{ margin-bottom: 15px;}
.top-guide .guide1 div{
	width: 63%;
	position: relative;
}
.top-guide .guide1 div figure{ margin-right: -40px;}
.top-guide .guide1 div p.t-right{
	position: absolute;
	right: 0;
	bottom: -10px;
}
.top-guide .guide2{
	display: flex;
	justify-content: space-between;
}
.top-guide .guide2 .cont{
	line-height: 1.8;
	width: 32%;
	background: rgba(255,255,255,.56);
	border: 1px solid #fff;
	border-radius: 10px;
	box-shadow: -2px 10px 20px rgba(0,0,0, 0.11);
	padding: 15px;
	margin-bottom: 20px;
}
.top-guide .guide2 .cont .department{
	display: flex;
	align-items: center;
	padding-bottom: 10px;
	border-bottom: 1px solid #898BA3;
	margin-bottom: 25px;
}
.top-guide .guide2 .cont .department figure{
	width: 47px;
	margin-right: 10px;
}
.top-guide .guide2 .cont .department p{
	font-weight: 500;
	line-height: 1.4;
}
.top-guide .guide2 .cont .department dl{ flex: 1;}
.top-guide .guide2 .cont .department dl dd{
	font-size: 16px;
	font-weight: bold;
}
.top-guide .guide2 .cont .name{
	display: flex;
	align-items: center;
	min-height: 85px;
	margin-bottom: 20px;
}
.top-guide .guide2 .cont .name figure{
	width: 70px;
	margin-right: 25px;
}
.top-guide .guide2 .cont .name div{
	flex: 1;
	line-height: 1.4;
}
.top-guide .guide2 .cont .name div strong{
	font-size: 16px;
	font-weight: bold;
	display: block;
}
.top-guide .guide2 .cont .tel{
	font-size: 19px;
	font-weight: bold;
	margin-bottom: 20px;
}
.top-guide .guide2 .cont .btn-cont{
	display: flex;
	justify-content: center;
}
.top-guide .guide2 .cont .btn-cont a{ margin: 0 10px;}
.top-guide .guide3{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 40px;
}
.top-guide .guide3 .cont{
	line-height: 1.8;
	width: 49%;
	background: rgba(255,255,255,.56);
	display: flex;
	align-items: center;
	border: 1px solid #fff;
	border-radius: 10px;
	box-shadow: -2px 10px 20px rgba(0,0,0, 0.11);

	padding: 15px;
	margin-bottom: 20px;
}
.top-guide .guide3 .cont figure{ margin-right: 25px;}
.top-guide .guide3 .cont dl dd{
	font-size: 16px;
	font-weight: bold;
}
.top-guide .guide4{
	margin-bottom: 10px;
}
.top-guide .guide4 div{
	display: flex;
	justify-content: space-between;
	margin-bottom: 10px;
}
.top-guide .guide4 div figure{ width: 32.8125%;}
.top-access{ margin-bottom: 40px;}
.top-access .wrap{
	text-align: left;
	display: flex;
	justify-content: space-between;
}
.top-access .wrap h2{
	font-size: 20px;
	font-weight: normal;
}
.top-access .wrap h2 img{ margin-bottom: 15px;}


/*------------------------------ responsive ------------------------------*/
@media screen and (max-width: 540px) {
	.top1{
		padding: 5vw 0 5vw;
		background: url("../img/top1-bg-sp.jpg") center top 25vw / 150% auto no-repeat;
	}
	.top1 .wrap{
		padding-right: 3%;
		padding-left: 3%;
		display: block;
	}
	.top1 .wrap figure{
		width: 100%;
		padding-top: 0;
		margin-bottom: 2vw;
	}
	.top1 .wrap figure img{ border-radius: 50vw 50vw 0 50vw;}
	.top1 .wrap div{
		width: 100%;
	}
	.top1 .wrap div h2{
		font-size: 6vw;
		margin-bottom: 3vw;
	}
	.top1 .wrap div p{ padding: 0 5%;}
	.top-guide{
		font-size: 3.466vw;
		padding: 30vw 0 1vw;
		background: url("../img/floor-guide-bg-sp2.jpg") center top / 100% auto no-repeat,
					url("../img/floor-guide-bg-sp.jpg") center / 100% 100% no-repeat;
	}
	.top-guide .guide1{
		display: block;
		margin-bottom: 18vw;
	}
	.top-guide .guide1 h2{
		font-size: 5.6vw;
		width: 100%;
		padding-top: 0;
		margin-bottom: 10vw;
	}
	.top-guide .guide1 h2 img{
		width: 48vw;
		margin-bottom: 2vw;
	}
	.top-guide .guide1 div{ width: 100%;}
	.top-guide .guide1 div figure{ margin: 0 3vw 3vw;}
	.top-guide .guide1 div p.t-right{ position: static;}
	.top-guide .guide2{
		display: block;
	}
	.top-guide .guide2 .cont{
		width: 100%;
		padding: 3vw;
		margin-bottom: 5.33vw;
	}
	.top-guide .guide2 .cont .department{
		padding-bottom: 2vw;
		margin-bottom: 5vw;
	}
	.top-guide .guide2 .cont .department figure{
		width: 12.8vw;
		margin-right: 2vw;
	}
	.top-guide .guide2 .cont .department dl dd{ font-size: 4.266vw;}
	.top-guide .guide2 .cont .name{
		min-height: inherit;
		margin-bottom: 5vw;
	}
	.top-guide .guide2 .cont .name figure{
		width: 18.66vw;
		margin-right: 5vw;
	}
	.top-guide .guide2 .cont .name div strong{ font-size: 4.266vw;}
	.top-guide .guide2 .cont .tel{
		font-size: 5.066vw;
		margin-bottom: 5vw;
	}
	.top-guide .guide2 .cont .btn-cont a{ margin: 0 3vw;}
	.top-guide .guide3{
		display: block;
		margin-bottom: 13vw;
	}
	.top-guide .guide3 .cont{
		line-height: 1.4;
		width: 100%;
		padding: 5vw;
		margin-bottom: 5vw;
	}
	.top-guide .guide3 .cont figure{ margin-right: 5vw;}
	.top-guide .guide3 .cont dl dt{ margin-bottom: 2vw;}
	.top-guide .guide3 .cont dl dd{ font-size: 4.266vw;}
	.top-guide .guide4{
		background: #fff;
		padding-bottom: 2vw;
		margin-bottom: 0;
	}
	.top-guide .guide4 div{ margin-bottom: 2vw;}
	.top-guide .guide4 div figure{ margin-bottom: 2vw;}
	.top-access{ margin-bottom: 10vw;}
	.top-access .wrap{
		padding-right: 3%;
		padding-left: 3%;
		display: block;
	}
	.top-access .wrap h2{
		font-size: 5.33vw;
		padding: 0 3%;
		margin-bottom: 8vw;
	}
	.top-access .wrap h2 img{
		width: 52vw;
		margin-bottom: 2vw;
	}
	.top-access .wrap div p{
		font-size: 3.733vw;
		padding: 0 3%;
	}
}



/*----------------------------------------------
	footer
-----------------------------------------------*/

footer{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 15px 3%;
}
footer .footer-logo{
	font-size: 15px;
	font-weight: 500;
	display: flex;
	align-items: center;
}
footer .footer-logo figure{ margin-right: 15px;}
footer .footer-logo figure img{ width: 40px;}
footer #copy{
	color: #C3C3C3;
	font-size: 12px;
}

/*------------------------------ responsive ------------------------------*/
@media screen and (max-width: 540px) {
	footer{
		display: block;
		padding: 3%;
	}
	footer .footer-logo{ font-size: 4vw; justify-content: center;}
	footer .footer-logo figure{ margin-right: 3vw;}
	footer #copy{ font-size: 3.2vw;}
}



























