@charset "utf-8";

/*===============================================================

slider

=================================================================*/
.swiper-container {
	width:100%;
	position:relative;
}

.swiper-slide {
	position:relative;
}

.swiper-slide img {
	width:100%;
}

.swiper-slide .btn_style1 {
	width:100%;
	position:absolute;
	bottom:2%;
	left:0;
}

.swiper-slide.slide3 .btn_style1 {
	bottom: 7%;
}

.swiper-slide.slide1 .btn_style1 {
	width:auto;
	right:29%;
	left:auto;
}

@media screen and (max-width:1280px){
	.swiper-slide.slide1 .btn_style1 {
		right:27%;
	}
}

@media screen and (max-width:1100px){
	.swiper-slide.slide1 .btn_style1 {
		right:25%;
	}
}

@media screen and (max-width:900px){
	.swiper-slide.slide1 .btn_style1 {
		right:5%;
	}
}

@media screen and (max-width:660px){
	.swiper-slide.slide1 .btn_style1 {
		right:5%;
		bottom:10%;
	}
}

@media screen and (max-width:500px){
	.swiper-slide.slide1 .btn_style1 {
		right:5%;
		bottom:3%;
	}
}

.swiper-slide .btn_style1 a {
	padding:1rem 4rem;
}

.swiper-pagination-fraction, .swiper-pagination-custom, .swiper-container-horizontal > .swiper-pagination-bullets {
	bottom:auto;
}

.swiper-pagination {
	width:100%;
	position:absolute;
	top:1rem;
	left:0;
	bottom:auto;
	right:0;
	z-index:3;
}
.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
	margin:0 5px;
}

.swiper-button-prev, .swiper-button-next {
	width:41px;
	height:78px;
}

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
	background:url(../img/slide_next.png) center no-repeat;
	background-size:cover;
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
	background:url(../img/slide_prev.png) center no-repeat;
	background-size:cover;
}

.swiper-pagination-bullet {
	width:12px;
	height:12px;
	cursor:pointer;
	background:#fff;
	opacity:1;
}
.swiper-pagination-bullet-active {
	background:#FF4E00;
}

.swiper-container .sp { display:none; }

@media screen and (max-width:900px){
	.swiper-slide.slide3 .btn_style1 {
		bottom: 5%;
	}
}

@media screen and (max-width:660px){
	.swiper-container .sp { display:block; }
	.swiper-container .pc { display:none; }
	.swiper-slide.slide3 .btn_style1 {
		bottom: 10%;
	}
	.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
		background:url(../img/slide_next_sp.png) center no-repeat;
		background-size:cover;
	}
	
	.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
		background:url(../img/slide_prev_sp.png) center no-repeat;
		background-size:cover;
	}
}

@media screen and (max-width:480px){
	.swiper-slide.slide3 .btn_style1 {
		bottom: 7%;
	}
	.swiper-button-prev, .swiper-button-next {
		width:21px;
		height:39px;
	}
}

/*===============================================================

section1

=================================================================*/
#section1 {
	padding-top: 6.7857%;
	background:url(../img/section1_bg_top.png) top left no-repeat;
	background-size:100% auto;
}

#section1 .ft_bg {
	padding-bottom: 9.5238%;
	background:url(../img/section1_bg_btm.png) bottom left no-repeat;
	background-size:100% auto;
	position:relative;
}

#section1 .img {
	width:100%;
	text-align:right;
	position:relative;
	z-index:0;
}

#section1 .img img {
	width:auto;
	max-width:60%;
	height:auto;
}

#section1 .img:after {
	display:block;
	content:'';
	width:197px;
	height:242px;
	background:url(../../common/img/chara_kaiketsuT.png) center no-repeat;
	background-size:cover;
	position:absolute;
	bottom:0;
	right:calc( 60% - 200px );
}

#section1 .text {
	width:94%;
	max-width:1520px;
	position:absolute;
	top:0;
	left: 0;
	right: 0;
	bottom:0;
	margin: auto;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-direction:column;
	-moz-flex-direction:column;
	-ms-flex-direction:column;
	flex-direction:column;
	-webkit-align-items:flex-start;
	-moz-align-items:flex-start;
	-ms-align-items:flex-start;
	align-items:flex-start;
	padding-top:5%;
	z-index:3;
}

#section1 .text h2 {
	background:#004DA0;
	position:relative;
	color:#fff;
	font-size:2.2rem;
	font-weight:bold;
	padding:0.5em 10rem 0.5em 0;
	margin-bottom:4rem;
}

#section1 .text h2:before {
	width:100vw;
	height:100%;
	display:block;
	content:'';
	background:#004DA0;
	position:absolute;
	top:0;
	right:100%;
}

#section1 .text h2:after {
	display:block;
	width:214px;
	height:119px;
	content:'';
	background:url(../../common/img/chara_heroine.png) no-repeat;
	background-size:cover;
	position:absolute;
	left:calc( 100% - 10rem );
	bottom:0;
}

#section1 .text .chara_heroine {
	display:none;
}

#section1 .text .marker span {
	display:inline-block;
	font-size:2.6rem;
	font-weight:bold;
	background: linear-gradient(#fff 60%, #FFFCBA 60%);
	color:#4E4E4E;
}

#section1 .text .main {
	width:35%;
	margin-top:2rem;
	background:#fff;
}

#section1 .text .marker_mini span {
	display:table;
	border-bottom:4px solid #FFF972;
	margin-top:2rem;
	background:#fff;
	font-weight:bold;
	color:#4E4E4E;
}

@media screen and (max-width:1280px){
	#section1 .img:after {
		width:145px;
		height:179px;
		right:calc( 60% - 150px );
	}
		
}

@media screen and (max-width:1160px){
	#section1 .text {
		padding-top:2%;
	}
}

@media screen and (max-width:1100px){
	#section1 .text h2 {
		font-size:1.8rem;
		margin-bottom:2rem;
	}
	
	#section1 .text .marker {
		font-size:2.2rem;
	}
	
	#section1 .text .main,
	#section1 .text .marker_mini {
		font-size:1.4rem;
	}
	
	#section1 .text h2:after {
		width:153px;
		height:85px;
	}
	
}

@media screen and (max-width:960px){
	#section1 {
		padding-top:10%;
	}
	#section1 .text {
		width:100%;
		display:block;
		position:static;
	}
	#section1 .text h2 {
		width:100%;
		text-align:center;
		padding:0.5em 0;
	}
	#section1 .text h2:before,
	#section1 .text h2:after {
		display:none;
	}
	#section1 .text .chara_heroine {
		width:60%;
		margin:0 auto;
		display:block;
		text-align:center;
		margin-top:2rem;
	}
	#section1 .text .main {
		width:90%;
		margin: 0 auto;
		padding:2rem 0;
		line-height:1.8;
	}
	#section1 .text .marker span {
		display:table;
		font-size:2.8rem;
		width:10em;
		text-align:center;
		margin:0 auto;
	}
	
	#section1 .text .marker_mini {
		width:90%;
		margin:0 auto;
	}
	#section1 .img {
		margin-top:2rem;
	}
	#section1 .img img {
		max-width:100%;
	}
	#section1 .img:after {
		top:-3rem;
		right:2rem;
	}
}

@media screen and (max-width:600px){
	#section1 {
		padding-top:15%;
	}
	#section1 .text .marker_mini {
		padding-right:40%;
	}
	#section1 .text .marker_mini span {
		display:inline;
		border:none;
		background: linear-gradient(transparent 80%, #FFF972 80%);
		line-height:1.8;
	}
	#section1 .img:after {
		top:-9rem;
	}
}

@media screen and (max-width:500px){
	#section1 {
		padding-top:20%;
	}
	#section1 .text .marker span {
		font-size:2.4rem;
	}
}

@media screen and (max-width:480px){
	#section1 .img:after {
		width:113px;
		height:139px;
		top:-11rem;
		right:1rem;
	}
}


/*===============================================================

section2

=================================================================*/
#section2 {
	margin-top:10%;
	background:url(../img/section2_bg_center.png) left 80% no-repeat;
	background-size:100% auto;
}

#section2 .ft_bg {
	padding-bottom:7%;
	background:url(../img/section2_bg_btm.png) right bottom no-repeat;
	background-size:100% auto;
}

#section2 .wrap {
	width:94%;
	max-width:1520px;
	margin:0 auto;
}

#section2 .wrap h2 {
	display:table;
	background:#004DA0;
	position:relative;
	color:#fff;
	font-size:2.2rem;
	font-weight:bold;
	padding:0.5em 10rem 0.5em 0;
	margin-bottom:4rem;
}

#section2 .wrap h2:before {
	width:100vw;
	height:100%;
	display:block;
	content:'';
	background:#004DA0;
	position:absolute;
	top:0;
	right:100%;
}

#section2 .wrap h2:after {
	display:block;
	width:92px;
	height:182px;
	content:'';
	background:url(../../common/img/chara_secret.png) no-repeat;
	background-size:cover;
	position:absolute;
	right:-5rem;
	bottom:0;
}

#section2 .box {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-justify-content:space-between;
	-moz-justify-content:space-between;
	-ms-justify-content:space-between;
	justify-content:space-between;
}

#section2 .box dl {
	width:calc( 94% / 4 );
}

#section2 .box dl dt {
	height:5em;
	text-align:center;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-direction:column;
	-moz-flex-direction:column;
	-ms-flex-direction:column;
	flex-direction:column;
	-webkit-align-items:center;
	-moz-align-items:center;
	-ms-align-items:center;
	align-items:center;
	-webkit-justify-content:center;
	-moz-justify-content:center;
	-ms-justify-content:center;
	justify-content:center;
}

#section2 .box dl dt,
#section2 .box dl dt * {
	color:#fff;
	line-height:1.4;
	font-weight:bold;
}

#section2 .box dl dt .small {
	font-size:1.2rem;
}

#section2 .box dl dd {
	text-align:center;
}

#section2 .box dl {
	padding:0 1rem 1rem 1rem;
}

#section2 .box1 {
	background:#004DA0;
}

#section2 .box2 {
	background:#7E98B7;
}

#section2 .box3 {
	background:#61B2ED;
}

#section2 .box4 {
	background:#3D82B4;
}

#section2 .btn_style1 {
	margin-top:5rem;
}

@media screen and (max-width:960px){
	#section2 .wrap {
		width:100%;
	}
	#section2 .wrap h2 {
		width:100%;
		text-align:center;
		padding:0.5em 0;
	}
	#section2 .wrap h2:after {
		top:50%;
		left:2rem;
		margin-top:-120px;
	}
}

@media screen and (max-width:900px){
	#section2 .box {
		display:block;
	}
	
	#section2 .box dl {
		width:100%;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: flex;
		-webkit-flex-wrap:wrap;
		-moz-flex-wrap:wrap;
		-ms-flex-wrap:wrap;
		flex-wrap:wrap;
		-webkit-justify-content:space-between;
		-moz-justify-content:space-between;
		-ms-justify-content:space-between;
		justify-content:space-between;
		-webkit-align-items:center;
		-moz-align-items:center;
		-ms-align-items:center;
		align-items:center;
		padding:2rem;
		margin-top:2rem;
	}
	
	#section2 .box dl dt {
		display:block;
		width:50%;
		text-align:left;
		height:auto;
		font-size:2rem;
	}
	
	#section2 .box dl dt .small {
		display:block;
	}
	#section2 .box dd {
		width:50%;
		text-align:center;
	}
}

@media screen and (max-width:600px){
	#section2 {
		margin-top:15%;
	}
	#section2 .box dl dt {
		font-size:1.6rem;
	}
}

@media screen and (max-width:480px){
	#section2 {
		margin-top:20%;
	}
	#section2 .wrap h2 {
		font-size:1.8rem;
		text-align:right;
		padding-right:1em;
	}
	#section2 .wrap h2:after {
		width:53px;
		height:105px;
		margin-top:-50px;
		left:1rem;
	}
	#section2 .box dl dt {
		font-size:1.4rem;
		width:55%;
	}
	#section2 .box dl dt .small {
		font-size:1.2rem;
	}
	#section2 .box dl {
		padding:1rem;
	}
	#section2 .box dd {
		width:45%;
	}
	#section2 .btn_style1 {
		margin-top:3rem;
		padding:0 3%;
	}
}


/*===============================================================

section3

=================================================================*/
#section3 {
	margin-bottom:5%;
	background:url(../img/section3_bg.png) bottom left no-repeat;
	background-size:100% auto;
}
#section3 .wrap {
	width:94%;
	max-width:1520px;
	margin:0 auto;
	margin-top:5%;
}

#section3 .wrap h2 {
	display:table;
	background:#004DA0;
	position:relative;
	color:#fff;
	font-size:2.2rem;
	font-weight:bold;
	padding:0.5em 7rem 0.5em 0;
	margin-bottom:4rem;
}

#section3 .wrap h2:before {
	width:100vw;
	height:100%;
	display:block;
	content:'';
	background:#004DA0;
	position:absolute;
	top:0;
	right:100%;
}

#section3 .wrap h2:after {
	display:block;
	width:134px;
	height:117px;
	content:'';
	background:url(../../common/img/chara_korichi.png) no-repeat;
	background-size:cover;
	position:absolute;
	right:-7rem;
	bottom:-1rem;
}

#section3 .wrap h2 br {
	display:none;
}

#section3 .point_wrap {
	width:90%;
	max-width:1180px;
	margin:0 auto;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-justify-content:space-between;
	-moz-justify-content:space-between;
	-ms-justify-content:space-between;
	justify-content:space-between;
}

#section3 .point_wrap > * {
	width:30%;
	max-width:280px;
	text-align:center;
}

#section3 .point_wrap > * > * + * {
	margin-top:1.5rem;
}

#section3 .point_wrap > * > p {
	text-align:left;
}

#section3 .point_wrap h3 {
	font-weight:bold;
}

#section3 .text {
	width:90%;
	max-width:850px;
	margin:0 auto;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-justify-content:space-between;
	-moz-justify-content:space-between;
	-ms-justify-content:space-between;
	justify-content:space-between;
	-webkit-align-items:flex-end;
	-moz-align-items:flex-end;
	-ms-align-items:flex-end;
	align-items:flex-end;
	border-bottom:5px solid #FFF972;
	padding:1.5rem;
}

#section3 .text .chara {
	width:136px;
	margin-left:2rem;
}

#section3 .text p {
	width:calc( 100% - 136px );
}

#section3 .text .marker {
	font-size:2.6rem;
	font-weight:bold;
	color:#4E4E4E;
}

#section3 .btn_style1 {
	margin-top:5rem;
}

@media screen and (max-width:960px){
	#section3 .wrap {
		width:100%;
	}
	#section3 .wrap h2 {
		width:100%;
		text-align:center;
		padding:0.5em 0;
	}
	#section3 .wrap h2:after {
		right:1rem;
	}
	#section3 .point_wrap .img {
		padding:0 2rem;
	}
}

@media screen and (max-width:800px){
	#section3 .wrap h2:after {
		width:91px;
		height:80px;
	}
	#section3 .text .marker {
		font-size:2rem;
	}
}

@media screen and (max-width:680px){
	#section3 .wrap {
		margin-top:10%;
	}
	#section3 .wrap h2 br {
		display:block;
	}
	#section3 .wrap h2:after {
		top:50%;
		margin-top:-40px;
	}
	#section3 .point_wrap {
		display:block;
	}
	#section3 .point_wrap > div {
		width:100%;
		max-width:100%;
		min-height:100px;
		padding-left:120px;
		position:relative;
		text-align:left;
	}
	
	#section3 .point_wrap .box{
		margin-top:2rem;
	}
	
	#section3 .point_wrap .img {
		width:100px;
		position:absolute;
		top:0;
		left:0;
		padding:0;
	}
	
	#section3 .text {
		border-bottom:none;
	}
	#section3 .text p br {
	display:none;
}
	#section3 .text p .marker {
		display:inline !important;
		background: linear-gradient(transparent 80%, #FFF972 80%);
		line-height:1.8;
	}
	#section3 .btn_style1 {
		margin-top:3rem;
	}
}

@media screen and (max-width:500px){
	#section3 .text .marker {
		font-size:1.8rem;
	}
}

@media screen and (max-width:480px){
	#section3 .wrap {
		margin-top:15%;
	}
	#section3 .wrap h2 {
		font-size:1.8rem;
		text-align:left;
		padding-left:1em;
	}
	#section3 .point_wrap .img {
		width:80px;
	}
	#section3 .point_wrap > div {
		padding-left:100px;
	}
	#section3 .text {
		width:94%;
	}
	#section3 .text .chara {
		width:100px;
		margin-left:1rem;
	}
	
	#section3 .text .marker {
		font-size:1.6rem;
	}
	
	#section3 .text p {
		width:calc( 100% - 100px );
	}
	
}


/*===============================================================

section4

=================================================================*/
#section4 {
	padding-top:13%;
	background:url(../img/section2_bg_center.png) left 80% no-repeat;
	background-size:100% auto;
}

#section4 .ft_bg {
	padding-bottom:7%;
	background:url(../img/section2_bg_btm.png) right bottom no-repeat;
	background-size:100% auto;
}

#section4 .wrap {
	width:94%;
	max-width:1520px;
	margin:0 auto;
}

#section4 .wrap h2 {
	display:table;
	background:#004DA0;
	position:relative;
	color:#fff;
	font-size:2.2rem;
	font-weight:bold;
	padding:0.5em 7rem 0.5em 0;
	margin-bottom:4rem;
}

#section4 .wrap h2 br {
	display:none;
}

#section4 .wrap h2:before {
	width:100vw;
	height:100%;
	display:block;
	content:'';
	background:#004DA0;
	position:absolute;
	top:0;
	right:100%;
}

#section4 .wrap h2:after {
	display:block;
	width:110px;
	height:148px;
	content:'';
	background:url(../../common/img/chara_kaiketsuT_typeC.png) no-repeat;
	background-size:cover;
	position:absolute;
	right:-5rem;
	bottom:0;
}

#section4 .box {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-justify-content:space-between;
	-moz-justify-content:space-between;
	-ms-justify-content:space-between;
	justify-content:space-between;
}

#section4 .box > div {
	width:calc( 94% / 4 );
	padding:0 1rem 1rem 1rem;
}

#section4 .box .tit {
	height:5em;
	text-align:center;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-direction:column;
	-moz-flex-direction:column;
	-ms-flex-direction:column;
	flex-direction:column;
	-webkit-align-items:center;
	-moz-align-items:center;
	-ms-align-items:center;
	align-items:center;
	-webkit-justify-content:center;
	-moz-justify-content:center;
	-ms-justify-content:center;
	justify-content:center;
}

#section4 .box .tit,
#section4 .box .tit * {
	color:#fff;
	line-height:1.4;
	font-weight:bold;
	font-size:1.8rem;
}

#section4 .box .tit .small {
	font-size:1.2rem;
	margin-bottom:0.5rem;
}

#section4 .box1 {
	background:#004DA0;
}

#section4 .box2 {
	background:#7E98B7;
}

#section4 .box3 {
	background:#61B2ED;
}

#section4 .box4 {
	background:#3D82B4;
}

#section4 .box .icon {
	width:150px;
	height:150px;
	border-radius:99px;
	background:#fff;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-justify-content:center;
	-moz-justify-content:center;
	-ms-justify-content:center;
	justify-content:center;
	-webkit-align-items:center;
	-moz-align-items:center;
	-ms-align-items:center;
	align-items:center;
	margin:0 auto;
}

#section4 .btn_style1 {
	margin-top:2rem;
}

#section4 .btn_style1 a {
	width:100%;
	padding: 1.5rem 3rem;
	font-size:1.4rem;
}

@media screen and (max-width:1030px){
	#section4 .box {
		width:94%;
		max-width:600px;
		margin:0 auto;
	}
	#section4 .box > div {
		width:calc( 94% / 2 );
		margin-bottom:3rem;
	}
}

@media screen and (max-width:960px){
	#section4 .wrap {
		width:100%;
	}
	#section4 .wrap h2 {
		width:100%;
		text-align:center;
		padding:0.5em 0;
	}
	#section4 .wrap h2:after {
		top:50%;
		left:2rem;
		margin-top:-120px;
	}
}

@media screen and (max-width:540px){
	#section4 {
		margin-top:20%;
	}
	#section4 .wrap h2 br {
		display:block;
	}
	#section4 .box {
		max-width:100%;
	}
	#section4 .box > div {
		width:100%;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: flex;
		-webkit-flex-wrap:wrap;
		-moz-flex-wrap:wrap;
		-ms-flex-wrap:wrap;
		flex-wrap:wrap;
		-webkit-align-items:center;
	-moz-align-items:center;
	-ms-align-items:center;
	align-items:center;
		padding:1rem;
	}
	#section4 .box .tit {
		display:block;
		width:calc( 100% - 80px );
		height:auto;
		text-align:left;
	}
	#section4 .box .icon img {
		max-width:100%;
		max-height:70%;
	}
	#section4 .box .tit .small {
		display:block;
	}
	#section4 .box .icon {
		width:80px;
		height:80px;
	}
	#section4 .btn_style1 {
		width:100%;
	}
}

@media screen and (max-width:480px){
	#section4 .wrap h2 {
		font-size:1.8rem;
		text-align:center;
		padding-right:0;
	}
	
	#section4 .box .tit {
		width:calc( 100% - 50px );
		height:auto;
		text-align:left;
	}
	#section4 .box .icon {
		width:50px;
		height:50px;
	}
	
	
	
	#section4 .wrap h2:after {
		width:75px;
		height:100px;
		margin-top:-50px;
		left:1rem;
	}
}