@charset 'utf-8';

/*PC用CSS(ipad mini 7.9インチ対応)*/
@media only screen and (min-width: 768px) {
	.pc_none{
		display: none!important;
	}
}
/*SP用CSS(ipad mini 7.9インチ未対応)*/
@media only screen and (max-width: 767px) {
	.sp_none{
		display: none!important;
	}
}


/*リキッドの場合に使用*/
@media only screen and (min-width: 768px){
/*	768px-1280px 画面幅1280px閲覧で1px=0.1rem可変*/
	html{
			font-size: 0.782vw;
		}
}
@media only screen and (max-width: 767px){
/*	-767px 画面幅375px閲覧で1px=0.1rem可変*/
	html{
			font-size: 2.67vw;
		}
}
@media only screen and (max-width: 374px){
/*	-374px 画面幅374pxで1px=0.1rem固定*/
	html{
			font-size: 62.5%;
		}
}
/*@media (orientation: landscape) and (max-height: 450px) {
ここに横向きのデバイスに適用するスタイルを書く
	html{
			font-size: 62.5%;
		}
}*/

@media only screen and (min-width: 1280px){
/*	1280px- 画面幅1280pxで1px=0.1rem固定*/
	html{
		font-size: 62.5%;
	}
}

body{
	-webkit-text-size-adjust: 100%; /*ios横向き文字の拡大防止*/
	text-size-adjust: 100%; /*ios横向き文字の拡大防止*/
	font-family: "dnp-shuei-gothic-gin-std", sans-serif;
	font-weight: 400;
	font-style: normal;
	color: #000000;
}
html.active,
body.active{
	overflow: hidden;
}

.regular{
	font-family: "dnp-shuei-gothic-gin-std", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.bold{
	font-family: "dnp-shuei-gothic-gin-std", sans-serif;
	font-weight: 600;
	font-style: normal;
}
.a_mid{
	font-family: "neue-haas-grotesk-display", sans-serif;
	font-weight: 500;
	font-style: normal;
}
.a_bold{
	font-family: "neue-haas-grotesk-display", sans-serif;
	font-weight: 700;
	font-style: normal;
}
/*Googleフォントここまで*/
* {
	box-sizing: border-box;
}

.svg{
	position: relative;
}
.svg svg{
	width: 100%;
	min-width: initial;
	height: 100%;
	min-height: initial;
	display: block;
	position: absolute;
	top: 0;
	bottom: auto;
	left: 0;
	right: auto;
	margin: auto;
}
iframe{
	width: 100%;
	min-width: initial;
	height: 100%;
	min-height: initial;
	display: block;
	position: absolute;
	top: 0;
	bottom: auto;
	left: 0;
	right: auto;
	margin: auto;
}

/*body,
main,
footer{
	min-width: 1280px;
}*/
@media only screen and (max-width: 767px){
	body,
	main,
	footer{
		min-width: 320px;
	}
}

body{
	width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
	background-color: #fff98a;
	position: relative;
}
@media only screen and (max-width: 767px) {
	body{
		min-width: initial;
	}
}

main{
	width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
	position: relative;
}

main{
}
@media only screen and (max-width: 767px) {
	main{
	}
}

/*headerここから*/
header{
	width: 5.2rem;
	height: 4.4rem;
	display: block;
	position: fixed;
	top: 4.0rem;
	bottom: auto;
	left: 4.8rem;
	right: auto;
	z-index: 10;
}
@media only screen and (max-width: 767px){
	header{
		width: 3.6rem;
		height: 3.0rem;
		top: 3.2rem;
		left: 3.2rem;
	}
}
header .header01{
	width: 100%;
	height: 100%;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 767px){
	header .header01{
	}
}
header .header01 .slide-menu-btn{
	width: 100%;
	height: 100%;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	cursor: pointer;
	z-index: 1;
	transition: opacity .5s;
}
header:hover .header01 .slide-menu-btn{
	opacity: .8;
	transition: opacity .5s;
}
header .header01 .slide-menu-btn .line-bar{
	width: 100%;
	height: .8rem;
	background-color: #000000;
	position: relative;
	margin: 0;
	transition: all 0.6s ease;
	display: block;
}
@media only screen and (max-width: 767px){
	header .header01 .slide-menu-btn .line-bar{
		height: .5rem;
	}
}
header .header01 .slide-menu-btn .line-bar::before{
	content: '';
	width: 100%;
	height: .8rem;
	background-color: #000000;
	display: block;
	position: absolute;
	transition: all 0.6s ease;
	top: -1.8rem;
}
@media only screen and (max-width: 767px){
	header .header01 .slide-menu-btn .line-bar::before{
		height: .5rem;
		top: -1.3rem;
	}
}
header .header01 .slide-menu-btn .line-bar::after{
	content: '';
	width: 100%;
	height: .8rem;
	background-color: #000000;
	display: block;
	position: absolute;
	transition: all 0.6s ease;
	bottom: -1.8rem;
}
@media only screen and (max-width: 767px){
	header .header01 .slide-menu-btn .line-bar::after{
		height: .5rem;
		bottom: -1.3rem;
	}
}
header .header01 nav{
	width: auto;
	height: auto;
	display: block;
	visibility: hidden;
	opacity: 0;
	flex-shrink: 0;
	position: absolute;
	top: 0;
	bottom: auto;
	left: 0;
	right: auto;
	z-index: 0;
	transition: visibility .1s, opacity .5s;
}
@media only screen and (max-width: 767px){
	header .header01 nav{
		width: 100vw;
		height: 100vh;
		padding: 9.4rem 0;
		background-color: #ffff9d;
		display: flex;
		justify-content: center;
		align-items: flex-start;
		position: fixed;
		overflow-y: scroll;
	}
	header .header01 nav .slide-close-btn{
		width: 3.6rem;
		height: 3.6rem;
		margin: 0;
		display: flex;
		justify-content: center;
		align-items: center;
		position: fixed;
		top: 3.2rem;
		bottom: auto;
		left: auto;
		right: 3.2rem;
		cursor: pointer;
		z-index: 1;
	}
	header .header01 nav .slide-close-btn .line-bar{
		width: 100%;
		height: .5rem;
		background-color: #000000;
		position: relative;
		margin: 0;
		display: block;
		transform: rotate(135deg);
	}
	header .header01 nav .slide-close-btn .line-bar::before{
		content: '';
		width: 100%;
		height: .5rem;
		background-color: #000000;
		display: block;
		position: absolute;
		transform: rotate(90deg);
		top: 0;
	}
}
header .header01 nav.active{
	visibility: inherit;
	opacity: 1;
	transition: visibility .1s, opacity .5s;
}
header .header01 nav .nav_01{
	width: auto;
	height: auto;
	padding: 8.0rem 0 0;
	margin: 0;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
	flex-shrink: 0;
}
@media only screen and (max-width: 767px){
	header .header01 nav .nav_01{
		width: 30.0rem;
		padding: 10.0rem 2.9rem;
		background-color: #ffffff;
		border-radius: 9.0rem;
	}
}
header .header01 nav .nav_01 li{
	width: auto;
	height: auto;
	margin: 1.0rem 0 0;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-shrink: 0;
}
@media only screen and (max-width: 767px){
	header .header01 nav .nav_01 li{
		margin: 3.0rem 0 0;
	}
}
header .header01 nav .nav_01 li:nth-of-type(1){
	margin-top: 0;
}
header .header01 nav .nav_01 li a{
	width: auto;
	height: auto;
	font-size: 2.0rem;
	line-height: 1;
	position: relative;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
	flex-shrink: 0;
}
@media only screen and (max-width: 767px){
	header .header01 nav .nav_01 li a{
		font-size: 2.4rem;
	}
}
/*headerここまで*/

/*footerここから*/
footer{
	width: 100%;
	height: auto;
	margin: 0 auto;
	background-color: #ffe794;
	display: block;
}
footer .footer01{
	width: 108.0rem;
	height: auto;
	padding: 5.4rem 0;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	position: relative;
}
@media only screen and (max-width: 767px) {
	footer .footer01{
		width: 100%;
		padding: 2.5rem 0;
		justify-content: flex-start;
		align-items: center;
		flex-direction: column;
	}
}
footer .footer01 .footer01_01{
	width: auto;
	height: auto;
	margin: 0;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_01{
		margin: 0 0 1.3rem;
	}
}
footer .footer01 .footer01_01 .text01{
	width: auto;
	height: auto;
	padding: .2rem 0;
	margin: 0 0 3.8rem;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_01 .text01{
		margin: 0;
	}
}
footer .footer01 .footer01_01 .text01 span{
	width: auto;
	height: auto;
	margin: 0;
	font-size: 3.2rem;
	line-height: 1;
	display: block;
	flex-shrink: 0;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_01 .text01 span{
		font-size: 2.0rem;
		text-align: center;
	}
}
footer .footer01 .footer01_01 ul{
	width: auto;
	height: auto;
	margin: 0;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
footer .footer01 .footer01_01 ul li{
	width: auto;
	height: auto;
	margin: 0 0 0 1.3rem;
	display: block;
	flex-shrink: 0;
}
footer .footer01 .footer01_01 ul li:nth-of-type(1){
	margin-left: 0;
}
footer .footer01 .footer01_01 ul li a{
	width: auto;
	height: auto;
	margin: 0;
	font-size: 1.0rem;
	line-height: 1;
	display: block;
}
footer .footer01 .logo{
	width: 25.1rem;
	height: 9.3rem;
	display: block;
	position: absolute;
	top: 3.6rem;
	bottom: auto;
	left: 0;
	right: 0;
	margin: auto;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .logo{
		margin: 0 0 1.3rem;
		position: static;
	}
}
footer .footer01 .logo img{
	width: 100%;
	height: auto;
	margin: 0 auto;
	display: block;
}
footer .footer01 .footer01_02{
	width: auto;
	height: auto;
	margin: 0;
	display: flex;
	justify-content: flex-start;
	align-items: flex-end;
	flex-direction: column;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_02{
		align-items: center;
	}
}
footer .footer01 .footer01_02 ul{
	width: auto;
	height: auto;
	margin: 0 0 4.3rem;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_02 ul{
		margin: 0 0 2.7rem;
	}
}
footer .footer01 .footer01_02 ul li{
	width: 4.2rem;
	height: auto;
	margin: 0 0 0 2.0rem;
	display: block;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_02 ul li{
		width: 3.1rem;
		margin: 0 0 0 1.5rem;
	}
}
footer .footer01 .footer01_02 ul li:nth-of-type(1){
	margin-left: 0;
}
footer .footer01 .footer01_02 ul li:nth-of-type(2){
	width: 4.5rem;
}
@media only screen and (max-width: 767px) {
	footer .footer01 .footer01_02 ul li:nth-of-type(2){
		width: 3.3rem;
	}
}
footer .footer01 .footer01_02 ul li a{
	width: 100%;
	height: auto;
	margin: 0;
	display: block;
}
footer .footer01 .footer01_02 ul li a img{
	width: 100%;
	height: auto;
	margin: 0;
	display: block;
}
footer .footer01 .footer01_02 .text01{
	width: auto;
	height: auto;
	margin: 0;
	font-size: 1.0rem;
	line-height: 1;
	display: block;
	flex-shrink: 0;
}
/*footerここまで*/

/*includeここから*/

/*.eyecatch_incここから*/
.eyecatch_inc.top{
	width: 100%;
	min-width: 1280px;
	height: auto;
	position: relative;
	display: block;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.top{
		min-width: 320px;
	}
}
.eyecatch_inc.top .eyecatch_inc01{
	width: 980px;
	height: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 1;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.top .eyecatch_inc01{
		width: 90%;
		max-width: 320px;
	}
}
.eyecatch_inc.top .eyecatch_inc01 h2{
	font-size: 20px;
	line-height: 30px;
}
.eyecatch_inc.top .eyecatch_inc02{
	width: 100%;
	height: auto;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	position: relative;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-list{
	width: 100%;
	height: auto;
	display: block;
}
.eyecatch_inc.top .eyecatch_inc02 .eye_img{
	width: 100%;
	height: calc(100vh - 74px);
	min-height: 500px;
	margin: 0 auto;
	display: block;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top center;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.top .eyecatch_inc02 .eye_img{
		min-height: initial;
	}
}
.eyecatch_inc.top .eyecatch_inc02 .eye_img01{
	background-color: #abbcca;
}
.eyecatch_inc.top .eyecatch_inc02 .eye_img02{
	background-color:#104EA3;
}
.eyecatch_inc.top .eyecatch_inc02 .eye_img03{
	background-color: #abbcca;
}
.eyecatch_inc.top .eyecatch_inc02 .eye_img04{
	background-color:#104EA3;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.top .eyecatch_inc02 .eye_img01{
	}
	.eyecatch_inc.top .eyecatch_inc02 .eye_img02{
	}
	.eyecatch_inc.top .eyecatch_inc02 .eye_img03{
	}
	.eyecatch_inc.top .eyecatch_inc02 .eye_img04{
	}
}
.eyecatch_inc.top .eyecatch_inc02 .slick-prev,
.eyecatch_inc.top .eyecatch_inc02 .slick-next{
	width: 33px;
	height: 33px;
	top: 0;
	bottom: 0;
	z-index: 10;
	transition: all .5s;
}
@media only screen and (max-width: 767px){
	.eyecatch_inc.top .eyecatch_inc02 .slick-prev,
	.eyecatch_inc.top .eyecatch_inc02 .slick-next{
		width: 25px;
		height: 25px;
	}
}
.eyecatch_inc.top .eyecatch_inc02 .slick-prev:hover,
.eyecatch_inc.top .eyecatch_inc02 .slick-next:hover{
	opacity: .8;
	transition: all .5s;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-prev{
	left: 0;
	right: auto;
	margin: auto;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-next{
	left: auto;
	right: 0;
	margin: auto;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-prev::before{
	width: 33px;
	height: 33px;
	background-image: url(../img/slick/arrow01.png);
	background-repeat: no-repeat;
	background-size: 15px auto;
	background-position: center;
	opacity: 1;
}
@media only screen and (max-width: 767px){
	.eyecatch_inc.top .eyecatch_inc02 .slick-prev::before{
		width: 25px;
		height: 25px;
		background-size: 9px auto;
		/*background-color: #19496f;*/
	}
}
.eyecatch_inc.top .eyecatch_inc02 .slick-next::before{
	width: 33px;
	height: 33px;
	background-image: url(../img/slick/arrow02.png);
	background-repeat: no-repeat;
	background-size: 15px auto;
	background-position: center;
	opacity: 1;
}
@media only screen and (max-width: 767px){
	.eyecatch_inc.top .eyecatch_inc02 .slick-next::before{
		width: 25px;
		height: 25px;
		background-size: 9px auto;
		/*background-color: #19496f;*/
	}
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots{
	width: 200px;
	height: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	position: absolute;
	top: auto;
	bottom: 30px;
	left: 0;
	right: 0;
	z-index: 10;
	margin: auto;
}
@media only screen and (max-width: 767px){
	.eyecatch_inc.top .eyecatch_inc02 .slick-dots{
	}
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots li{
	width: 8px;
	height: 8px;
	margin: 4px 4px 0;
	display: block;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots li:nth-of-type(-n+12){
	margin-top: 0;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots li button{
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	display: block;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots li button::before{
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	border-radius: 50%;
	display: block;
	font-family: none;
	font-size: 0;
	line-height: 0;
	position: static;
	background: none;
	background-color: #abbcca;
}
.eyecatch_inc.top .eyecatch_inc02 .slick-dots .slick-active button::before{
	background-color: #19496f;
}
.eyecatch_inc.short{
	width: 100%;
	height: 422px;
	position: relative;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.short{
		height: 205px;
	}
}
.eyecatch_inc.short .eyecatch_inc01{
	width: 980px;
	height: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 1;
}
@media only screen and (max-width: 767px) {
	.eyecatch_inc.short .eyecatch_inc01{
		width: 90%;
		max-width: 320px;
	}
}
.eyecatch_inc.short .eyecatch_inc01 h2{
	font-size: 20px;
	line-height: 30px;
}
.eyecatch_inc.short .eyecatch_inc02{
	width: 100%;
	height: 100%;
	margin: 0 auto;
}
.eyecatch_inc.short .eyecatch_inc02 .eye_img{
	width: 100%;
	height: 100%;
	margin: 0 auto;
	display: block;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: bottom center;
}
.eyecatch_inc.short .eyecatch_inc02 .eye_img{
	background-color:#104EA3;
}
/*.eyecatch_incここまで*/

/*.paginationここから*/
.wp-pagenavi {
	width: 80%;
	height: auto;
	margin: 100px auto;
	font-size: 15px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
	.wp-pagenavi {
		max-width: 320px;
		margin: 80px auto;
	}
}
.wp-pagenavi span{
	width: 50px;
	height: 50px;
	font-size: 16px;
	line-height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 9px;
	text-align: center;
	border-radius: 6px;
	border: 1px solid #cccccc;
	/*font-family: 'Noto_Sans_JP',
	sans-serif;
	font-weight: 700;*/
}
@media only screen and (max-width: 767px) {
	.wp-pagenavi span{
		width: 35px;
		height: 35px;
		font-size: 11px;
		line-height: 35px;
		border-radius: 4px;
	}
}
.wp-pagenavi a{
	width: 50px;
	height: 50px;
	font-size: 16px;
	line-height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 9px;
	text-align: center;
	border-radius: 6px;
	border: 1px solid #cccccc;
	/*font-family: 'Noto_Sans_JP',
	sans-serif;
	font-weight: 700;*/
}
@media only screen and (max-width: 767px) {
	.wp-pagenavi a{
		width: 35px;
		height: 35px;
		font-size: 11px;
		line-height: 35px;
		border-radius: 4px;
	}
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink{
	border: 1px solid transparent;
}
.wp-pagenavi .extend{
	display: none;
}
.wp-pagenavi a:hover{
	color: #ffffff;
	border: 1px solid #000000;
	background-color: #000000;
	opacity: 1;
}
.wp-pagenavi .current{
	width: 50px;
	height: 50px;
	font-size: 16px;
	line-height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 9px;
	text-align: center;
	color: #ffffff;
	border: 1px solid #000000;
	background-color: #000000;
	border-radius: 6px;
	/*font-family: 'Noto_Sans_JP',
	sans-serif;
	font-weight: 700;*/
}
@media only screen and (max-width: 767px) {
	.wp-pagenavi .current{
		width: 35px;
		height: 35px;
		font-size: 11px;
		line-height: 35px;
		border-radius: 4px;
	}
}
/*.paginationここまで*/

/*includeここまで*/