@charset "UTF-8";
/*
	Setting CSS
-----------------------------------------------------------------------------------------------*/
@media print, screen and (min-width:897px){
	/* iPad背景切れ対策 */
	body{
		min-width: 1200px;
	}
	/* tel pcのみ無効 */
	a[href^="tel:"]{
		pointer-events: none;
	}
}
button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}
/* 表示切替 */
.switch{
	visibility: hidden;
}
.sp{
	display: none;
}
/*
	common
-----------------------------------------------------------------------------------------------*/
:root{
	/* color */
	--blue: #00557d;
	--blue-rgb: 0, 85, 125;
	--green: #029e66;
	/* font-weight */
	--light: 100;
	--regular: 400;
	--medium: 500;
	--bold: 700;
	--black: 900;
	/* width */
	--maw: 1050px;
}
#wrapper > *{
	font-family: 'Noto Sans JP', 'Yu Gothic', YuGothic, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
	font-size: 1.6rem;
	font-weight: var(--regular);
}
#wrapper a{
	text-decoration:none;
	transition: all 0.3s;
}
#wrapper a:hover{
	text-decoration:none;
}
a.txtLink{
	text-decoration: underline!important;
}
a.txtLink:hover{
	text-decoration: none!important;
}
/* box
============================== */
.ctsArea{
	max-width: var(--maw);
	margin: 0 auto;
	padding: 70px 30px;
	position: relative;
}
/* flex
============================== */
[class$="__flex"]{
	display: flex;
}
/* target="_blank"
============================== */
a[target="_blank"] span{
	background: url(../img/link_icon02svg) no-repeat right center;
	background-size: 13px;
	display: inline-block;
	padding-right: 16px;
}
/* button-arrow
============================== */
.button__container{
	margin-top: 35px;
	text-align: center;
}
a.button-arrow{
	align-items: center;
	color: #FFF;
	background: var(--blue);
	display: inline-flex;
	font-size: 2.0rem;
	font-weight: var(--medium);
	height: 70px;
	margin: 12px 0 0 0;
	min-width: 345px;
	padding: 0 25px;
	position: relative;
}
.button-arrow::before,
.button-arrow::after{
	background: #FFF;
	content: '';
	height: 1px;
	position: absolute;
	right: 30px;
	transition: right .3s;
}
.button-arrow::before{
	top: 53%;
	width: 40px;
}
.button-arrow::after{
	transform: rotate(45deg);
	width: 7px;
}
/* hover */
.button-arrow:hover::before,
.button-arrow:hover::after{
	right: 25px;
}
/* button-radius
============================== */
.radius{
	border-radius: 10px;
	color: #0053a4;
	height: 80px;
	justify-content: center;
	position: absolute;
	width: 460px;
}
/*
	kv
-----------------------------------------------------------------------------------------------*/
#kv{
	position: relative;
}
.kv__flex{
	flex-direction: row-reverse;
	flex-wrap: nowrap;
}
.slick__list{
	height: 370px;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
	max-width: 58%;
	z-index: -1;
}
.slick__item{
	display: inline-block;
}
.slick-slide img{
	min-width: 760px;
	width: 100%;
}
.kv__container{
	align-items: center;
	background: #ddf1ff url(../img/kv_bg01.png) no-repeat center center/ cover;
	clip-path: polygon(0 0, 80% 0, 100% 100%, 0% 100%);
	display: flex;
	height: 370px;
	justify-content: center;
	padding-right: 120px;
	max-width: 55%;
	z-index: 1;
}
.kv__body{
	margin-bottom: 10px;
	z-index: 3;
}
.kv__head--copy{
	display: block;
	font-size: 2.7rem;
	font-weight: var(--bold);
	line-height: 1.5;
}
.kv__title{
	display: block;
	font-size: 1.7rem;
	font-size: clamp(1.7rem, 1.5vw, 2.5rem);
	font-weight: var(--bold);
	margin: 10px 0 0;
}
.kv__title--txt{
	display: block;
	line-height: 1;
	margin: 0 0 12px;
	max-width: 550px;
	min-width: 420px;
	width: 33vw;
}
.kv__img{
	bottom: -10px;
	left: 50%;
	position: absolute;
	transform: translate(-50%, 0);
	max-width: 210px;
	z-index: 3;
}
/* level2 kv
============================== */
.level2 .kv__img{
	bottom: -42px;
	left: auto;
	right: 0;
	transform: none;
	width: 210px;
}
/* nav
============================== */
#header{
	height: 80px;
	position: relative;
	z-index: 1;
}
/* menuArea */
.header__list{
	background: #ecfbff;
	display: flex;
	justify-content: center;
}
.header__item:last-child:before{
	content: none;
}
.header__item--button{
	align-items: center;
	border-right: 1px solid #bad1dc;
	color: #000;
	cursor: pointer;
	display: flex;
	font-size: 1.9rem;
	font-weight: var(--bold);
	height: 80px;
	justify-content: center;
	padding: 0 25px;
}
.header__item:last-child .header__item--button{
	border-right: none;
}
.header__item--button:hover{
	background: #c2e7ff;
	transition: .3s;
}
.nav__txt{
	display: block;
	padding-right: 25px;
	position: relative;
}
.nav__txt::before{
	background: #0053a4;
	border-radius: 9px;
	content: '';
	height: 18px;
	position: absolute;
	right: 0;
	top: 4px;
	width: 18px;
}
.nav__txt::after{
	border-right: 2px solid #ecfbff;
	border-top: 2px solid #ecfbff;
	content: '';
	height: 6px;
	position: absolute;
	right: 7px;
	top: 50%;
	transform: translate(0, -50%) rotate(45deg);
	width: 6px;
}
@media print, screen and (min-width:897px){
	.header__list{
		display: flex;
	}
	.header__item--button{
		display: flex;
		justify-content: center;
		align-items: center;
		height: 80px;/* headerの高さ */
		min-width: 330px;
		transition: all 0.3s;
	}
	span.header__item--button:hover{
		cursor: pointer;
	}
	/* メガメニュー pcのみ */
	.jsMenuIn{
		background: #e3f1f4;
		display: none;
		width: 500px;
		padding: 10px;
		position: absolute;
		transform: translate(-50%, 0);
		top: 80px;
		left: 50%;
	}
	.jsMenuIn::before{
		background: #e3f1f4;
		content: '';
		height: 20px;
		left: 50%;
		position: absolute;
		top: 0;
		transform: rotate(45deg) translate(-50%, 0);
		width: 20px;
	}
	.listIn{
		display: flex;
		justify-content:center;
		flex-wrap: wrap;
		margin: 0 auto -15px auto;
	}
	.listIn__item{
		margin: 0 12px 15px 0;
	}
	.listIn__item:nth-of-type(3n),
	.listIn__item:last-of-type{
		margin-right: 0;
	}
	.listIn__item--button{
		background: #fff;
		color: #000;
		display: flex;
		align-items: center;
		height: 35px;
		font-size: 1.4rem;
		font-weight: 700;
		padding: 0 30px 0 20px;
		position: relative;
		width: 150px;
	}
	.listIn__item--button::before{
		border-right: 1px solid #000;
		border-top: 1px solid #000;
		content: '';
		height: 5px;
		position: absolute;
		right: 15px;
		transform: rotate(45deg);
		width: 5px;
	}
	.listIn__item--button:hover{
		opacity: .7;
	}
}
#footerlink{
	background: #5876aa;
	text-align: center;
}
#footerWrapper{
	position: relative;
}
#footerlink .header__item--button{
	background: #fff;
}
#footerlink .header__item--button:hover{
	background: #c2e7ff;
	transition: .3s;
}
#footerlink .nav__txt::after{
	top: 47%;
}
#header + *{
	position: relative;
}
#header + *::before,
#header + *::after{
	background: url(../img/bg_pattern01.png) no-repeat center center / cover;
	content: '';
	height: 380px;
	position: absolute;
	width: 650px;
	z-index: -1;
}
#header + *::before{
	right: 0;
	top: 0;
	transform: rotate(180deg);
}
#header + *::after{
	bottom: 0;
	left: 0;
}
@media screen and (max-width:897px){
	img{
		width:100%;
	}
	/* p{
		line-height: 150%;
		font-size: 1.6rem;
	} */
	.pc{
		display:none;
	}
	.sp{
		display:block;
	}
	br.sp{
		display:inline-block;
	}
	/*
		common
	-----------------------------------------------------------------------------------------------*/
	:root{
		--maw: 100%;
	}
	/* box
	============================== */
	.ctsArea{
		padding: 70px 15px;
	}
	/* flex
	============================== */
	[class$="__flex"]{
		display: flex;
	}
	/* target="_blank"
	============================== */
	a[target="_blank"] span{
		background: url(../img/link_icon02svg) no-repeat right center;
		background-size: 13px;
		display: inline-block;
		padding-right: 16px;
	}
	/* button-arrow
	============================== */
	a.button-arrow{
		font-size: 1.7rem;
		margin: 0;
		min-width: 100%;
		padding: 0 20px;
	}
	.button-arrow::before,
	.button-arrow::after{
		right: 30px;
	}
	.button-arrow::before{
		top: 53%;
		width: 40px;
	}
	.button-arrow::after{
		width: 7px;
	}
	/* hover */
	.button-arrow:hover::before,
	.button-arrow:hover::after{
		right: 25px;
	}
	/*
		kv
	-----------------------------------------------------------------------------------------------*/
	#kv::before{
		height: 150px;
		width: 250px;
	}
	.kv__flex{
		flex-direction: row-reverse;
		flex-wrap: nowrap;
	}
	.slick__list{
		height: auto;
		position: relative;
		right: auto;
		top: auto;
		max-width: 108%;
	}
	.slick__item{
		display: inline-block;
	}
	.slick-slide img{
		min-width: 100%;
		width: 100%;
	}
	.kv__wrapper{
		position: static;
	}
	.kv__container{
		clip-path: none;
		display: block;
		height: auto;
		max-width: 100%;
		padding: 20px 15px 25px;
		text-align: center;
	}
	.kv__body{
		margin-bottom: 0;
	}
	.kv__head--copy{
		font-size: 2.2rem;
		line-height: 1.3;
	}
	.kv__title{
		font-size: 1.6rem;
		margin: 8px 0 0;
	}
	.kv__title--txt{
		margin: 2px auto 0;
		max-width: 500px;
		min-width: auto;
		padding-left: 8px;
		width: 100%;
	}
	.kv__img{
		bottom: -10px;
		left: 0;
		max-width: 300px;
		transform: translate(0);
		width: 40%;
	}
	/* level2 kv
	============================== */
	.level2 .kv__img{
		bottom: 0;
		left: 0;
		right: auto;
		transform: none;
		width: 170px;
	}
	/* nav
	============================== */
	#header{
		width: 100%;
		height: auto;
		z-index: 0;
	}
	/* menuArea */
	.header__container{
		display: none;
		width: 100%;
	}
	/* listMenu */
	.header__list{
		border-top: 1px solid #bad1dc;
		display: block;
	}
	.header__item--button{
		border-bottom: 1px solid #bad1dc;
		border-right: none;
		font-size: 1.5rem;
		height: 50px;
		justify-content: space-between;
		line-height: 140%;
		padding: 15px;
		position: relative;
	}
	.header__item[class ^= "toggle"] > span::before,/* + */
	.header__item[class ^= "toggle"] > span::after{
		content: " ";
		display: block;
		width: 10px;
		height: 2px;
		transition: all 0.3s;
	}
	.jsMenuIn{
		display: block!important;
	}
	.jsMenuIn::before{
		content: none;
	}
	/* listIn */
	.listIn__item{
		border-bottom: 1px solid rgba(105,86,69,0.2);
		margin: 0 15px;
	}
	.listIn__item--button{
		color: #000;
		display: block;
		font-size: 1.3rem;
		padding: 12px 15px;
		position: relative;
	}
	.listIn__item--button::before{
		border-right: 1px solid #000;
		border-top: 1px solid #000;
		content: '';
		height: 5px;
		position: absolute;
		right: 15px;
		top: 18px;
		transform: rotate(45deg);
		width: 5px;
	}
	/* btnHbg */
	.btnHbg{
		align-items: center;
		display: flex;
		width: 100%;
		height: 50px;
		background-color: #d3f5fe;
		font-weight: var(--bold);
		padding: 0 15px;
		position: relative;
		transition: all 0.3s;
		z-index: 9000;
	}
	.btnHbg::before,
	.btnHbg::after{
		background: #000;
		content: '';
		height: 1px;
		position: absolute;
		right: 20px;
		width: 18px;
	}
	.btnHbg::after{
		transform: rotate(90deg);
		transition: transform .3s;
	}
	.jsActive.btnHbg::after{
		transform: rotate(180deg);
		transition: transform .3s;
	}
	/* btnHbg jsActive */
	body.jsActive{
		overflow: hidden;
	}
	.nav__txt{
		width: 100%;
	}
	.nav__txt::after{
		top: 60%;
	}
	#footerlink #footerWrapper{
		margin: 0 auto;
		max-width: 500px;
		text-align: left;
	}
	#footerlink .ctsArea {
		padding: 30px 15px;
	}
	#footerlink .nav__txt::after{
		top: 60%;
	}
	#footerlink .btnHbg{
		background: #fff;
	}
	#footerlink .jsMenuIn {
		background: #fff;
		left: auto;
		transform: none;
		width: 100%;
	}
	#header + *::before,
	#header + *::after{
		width: 100%;
	}
}