@charset "UTF-8";

/*--------------------------------
common
--------------------------------*/
* {
	margin: 0;
	padding: 0
}
*:focus {
	outline: none!important;
}
body {
	position: relative;
	font-family: 'Noto Sans JP', sans-serif;
}
a {
	color: #0000FF;
	transition: .5s;
}
a:hover {
	text-decoration: none;
	opacity: .8;
}
h1, h2, h3, h4, p, ul {
	margin: 0;
}
img {
	width: 100%;
	max-width: 100%;
}
.small {
	font-size: 14px;
}
.nowrap {
	white-space: nowrap;
}
.gray {
	color: #505050;
}

/*--------------------------------
header
--------------------------------*/
header .logo img {
	max-width: 180px;
}
header .kv {
	font-size: 20px;
	color: #fff;
	background-color: #004097;
	padding: 40px 0 80px 0;
}
header .kv a {
	color: #fff;
}
header .kv .img01 img {
	max-width: 372px;
}
header .kv .img02 img {
	max-width: 950px;
}

/*--------------------------------
body
--------------------------------*/
h2 {
	font-size: 50px;
	font-weight: 900;
}
h3 {
	font-size: 30px;
	font-weight: 900;
	color: #fff;
}
/*- fadeUp ----------*/
.fadein {
	opacity: 0;
	transform: translate3d(0, 100px, 0);
}
.fadein.active {
	opacity: 1;
	transform: translate3d(0, 0, 0);
	transition: 1s;
}
/*- appbtn ----------*/
.appbtn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 900;
	color: #004097!important;
	text-decoration: none;
	max-width: 380px;
	width: 100%;
	background: #f6e54f;
	padding: 23px 20px;
	z-index: 0;
}
.appbtn:before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	width: 24px;
	height: 14px;
	background: url("../images/icon-arrow-right.svg") no-repeat center / cover;
	margin: auto 0;
}
/*- section01 ----------*/
.section01 {
	position: relative;
	font-weight: bold;
	font-size: 22px;
	color: #fff;
	background-color: #0d5ad8;
	border-radius: 20rem 0 0 0;
	padding: 60px 0;
}
.section01:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: #004097;
	margin: auto;
	z-index: -1;
}
.section01 h2 {
	color: #fff;
}
/*- section02 ----------*/
.section02 {
	background: #004097 url("../images/section02_bg.jpg") no-repeat top / 100%;
	padding: 100px 0;
}
.section02 h2 {
	color: #fff;
}
.section02 .img01 img {
	max-width: 862px;
}
/*- section03 ----------*/
.section03 {
	background-color: #F1F5FB;
	padding: 100px 0;
}
.section03 h2 {
	color: #004097;
}
.section03 .img01 img {
	max-width: 786px;
}
/*- section04 ----------*/
.section04_01,
.section04_02 {
	padding: 100px 0;
}
.section04_01 {
	position: relative;
	color: #fff;
	background-color: #006bec;
	border-radius: 20rem 0 0 0;
	padding: 60px 0;
}
.section04_01:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: #F1F5FB;
	margin: auto;
	z-index: -1;
}
.section04_02 {
	position: relative;
	color: #fff;
	background-color: #25bba3;
	border-radius: 0 20rem 0 0;
	padding: 60px 0;
}
.section04_02:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: #006bec;
	margin: auto;
	z-index: -1;
}
.section04_01 .img01 img {
	max-width: 781px;
}
.section04_02 .img01 img {
	max-width: 863px;
}
/*- section05 ----------*/
.section05 {
	background-color: #004097;
	padding: 100px 0;
}
.section05 h2 {
	color: #fff;
}
.section05 .flow_slide {
	position: relative;
	overflow: hidden;
	opacity: 1;
	transform: translate(0, 0);
}
.section05 .swiper {
	overflow: visible;
}
.section05 .swiper .swiper-slide img {
	max-width: 480px;
}
.section05 .swiper .swiper-slide.swiper-slide-active img {
	filter: drop-shadow(15px 15px 15px rgba(0, 0, 0, .15));
}
.section05 .swiper-pagination-bullets {
  position: static;
  margin-top: 30px;
}
.section05 .swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	background-color: #d0d0d0;
	opacity: 1;
}
.section05 .swiper-pagination-bullet-active {
	width: 16px;
	height: 16px;
	background-color: #64d4b7;
	margin-bottom: -3px !important;
}
.section05 .row:last-child h2 {
	margin-top: 150px;
}
/*- faq ----------*/
.faq dt {
	background: #fff;
	border-radius: 10px;
	cursor: pointer;
	padding: 25px 78px;
}
.faq dt,
.faq dd {
	position: relative;
}
.faq dt:before,
.faq dd:before {
	content: "";
	position: absolute;
	display: block;
	width: 36px;
	height: 36px;
	background-repeat: no-repeat;
	background-size: cover;
}
.faq dt:before {
	top: 0;
	bottom: 0;
	margin: auto 0;
}
.faq dt:before,
.faq dd:before {
	left: 25px;
}
.faq dt:before {
	background-image: url("../images/icon-faq-q.svg");
}
.faq dd:before {
	top: 20px;
	background-image: url("../images/icon-faq-a.svg");
}
.faq dt:after {
	content: "";
	position: absolute;
	display: block;
	right: 20px;
	top: 0;
	bottom: 0;
	width: 25px;
	height: 25px;
	background: url("../images/icon-faq-plus.svg") no-repeat center / contain;
	margin: auto 0;
}
.faq dt.open:after {
	background: url("../images/icon-faq-minus.svg") no-repeat center / contain;
}
.faq dd {
	display: none;
	padding: 25px 78px;
}
/*- section06 ----------*/
.section06 {
	background-color: #f5f8f6;
	padding: 100px 0;
}
.section06 h2 {
	color: #004097;
}
/*- section07 ----------*/
.section07 {
	padding: 100px 0;
}
.section07 dt {
	font-size: 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid #323232;
	margin-bottom: 12px;
}
.section07 .img01 img {
	max-width: 71px;
}
.section07 .img02 img {
	max-width: 56px;
}
/*- section08 ----------*/
.section08 {
	background-color: #FAFAFA;
	padding: 100px 0;
}

/*--------------------------------
footer
--------------------------------*/
footer .footer_fast {
	font-size: 12px;
	color: #484848;
	border-bottom: 1px dotted #ccc;
	padding: 20px 0;
}
footer .logo img {
	max-width: 32px;
}

/*--------------------------------
pagetop
--------------------------------*/
#page_top {
	position: fixed;
	right: 0;
}
#page_top .appbtn {
	font-size: 18px;
	text-align: center;
	min-width: 177px;
	padding: 24px 30px 24px 12px;
}
#page_top .appbtn:before {
	right: 12px;
	width: 18px;
	height: 11px;
}

/*--------------------------------
media
--------------------------------*/
.sp {
	display: none;
}
@media (min-width: 992px) {
	.container {
		max-width: 1024px;
	}
	.section05 .swiper {
		max-width: 520px;
	}
}
@media (min-width: 576px) and (max-width: 991px) {
	.section05 .swiper {
		max-width: 440px;
	}
}
@media (max-width: 991px) {
	.section01,
	.section04_01 {
		border-radius: 50px 0 0 0;
	}
	.section01 .d-flex {
		flex-flow: column;
		gap: 40px;
	}
	.section04_02 {
		border-radius: 0 50px 0 0;
	}
	.section05 .swiper .swiper-slide img {
		max-width: 95%;
	}
}
@media (max-width: 575px) {
	.pc {
		display: none;
	}
	.sp {
		display: inline-block;
	}
	h2 {
		font-size: 34px;
	}
	header .kv {
		padding: 40px 0 ;
	}
	.section01 {
		font-size: 16px;
	}
	.section01 .circle {
		font-size: 32px;
		width: 350px;
    height: 350px;
	}
	.section01 .text {
		font-size: 22px;
	}
	.section02,
	.section03,
	.section04_01,
	.section04_02,
	.section05,
	.section06,
	.section07,
	.section08 {
		padding: 50px 0;
	}
	.section05 .row:last-child h2 {
    margin-top: 100px;
	}
	.section05 .flow_slide {
		padding: 0 4.67vw;
	}
	.section05 .flow_slide .swiper {
		width: 17.33em;
	}
	.section08 {
		padding-bottom: 120px;
	}
}
