@charset "utf-8";

body{
	font-family: 'Noto Sans JP', sans-serif;
}

a img:hover{
	opacity: 0.7;
}

@media screen and (max-width: 798px) {
	img{width: 100%;}
}

@media screen and (min-width: 798px) {
	br.sp{
		display: none;
	}
}

/*main*/

main{
	background-image: url("../img/main_bg01.png"), url("../img/main_bg02.png"), url("../img/main_bg03.png"), url("../img/main_bg04.png");
	background-position: left  top, right top, left bottom, right bottom;
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
}

main h1{
	color: #061057;
	font-size: 34px;
	font-weight: bold;
	line-height: 1.2;
	margin-bottom: 57px;
}

main div.inner{
	max-width: 1108px;
	margin: 0 auto;
	padding: 74px 0 0;
	position: relative;
}

main div.inner ul{
	display: flex;
	margin-top: 48px;
	padding-bottom: 45px;
}

main div.inner ul li{
	margin-left: 14px;
}

main div.inner ul li:first-child{
	margin-left: 0;
}

section.btn_box{
	background: url("../img/main_btn_bg.gif") repeat;
	padding: 46px 0;
}

section.btn_box.btn_box02{
	/*padding: 46px 0 160px;新規キャンペーンあり*/
	padding: 46px 0;
}

section.btn_box ul{
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

@media screen and (min-width: 1200px) {

	main img.img01{
		position: absolute;
		top: 144px;
		right: -32px;
	}

	main img.img02{
		position: absolute;
		bottom: 0;
		right: 0;
	}
}
@media screen and (max-width: 1200px) {
	main h1{text-align: center; font-size: 25px;}
	main div.inner{
		width: calc( 100% - 50px);
	}
	main div.inner div{
		text-align: center;
	}
	main div.inner ul{
		justify-content: center;
	}
	
	main div.inner p{
		margin-top: 30px;
	}
	
	main div.inner p img{
		width:49%;
	}
	main div.inner p img.img01{
		max-width: 410px;
	}
	main div.inner p img.img02{
		max-width: 403px;
	}
	main{
		background-size: 40%;
	}
	section.btn_box ul{
		width: calc( 100% - 50px);
	}
	section.btn_box ul li:first-child{
		margin-right: 10px;
	}
	section.btn_box.btn_box02{
		/*padding: 46px 0 80px;新規キャンペーンあり*/
		padding: 46px 0;
	}
}

/*sec01*/

section#sec01{
	background: url("../img/sec01_bg.gif") repeat-x; 
	padding: 85px 0 220px;
	text-align: center;
}

section#sec01 h2{
	background: #051256;
	padding:5px 15px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 36px;
	display: block;
	max-width: 630px;
	border-radius: 20px;
	margin: 0 auto 20px;
}

section#sec01 .inner div{
	max-width: 945px;
	margin: 50px auto 0;
	display: flex;
	max-width: 960px;
	justify-content: space-between;
}

section#sec01 ul li{
	font-size: 30px;
	font-weight: bold;
	color: #051256;
	text-align: left;
	padding-top: 17px;
	padding-bottom: 17px;
	padding-left: 80px;
	background: url("../img/sec01_icon01.png") left center no-repeat; 
}

@media screen and (max-width: 945px) {
	section#sec01{padding: 85px 0 130px;}
	section#sec01 .inner{width: calc( 100% - 50px); margin: 0 auto;}
	section#sec01 .inner div{display: block;}
	section#sec01 ul{margin-bottom: 20px;}
	section#sec01 h2{font-size: 30px;}
	section#sec01 ul li{font-size: 22px; background-size: 31px; padding-left: 40px;}
}

/*sec02*/

section#sec02{
	background: url("../img/sec02_bg.jpg") repeat-y;
	background-size: contain;
}

section#sec02 .inner{
	padding: 120px 0 94px;
	position: relative;
	text-align: center;
}

section#sec02 .img01{
	position: absolute;
	top: -30px;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

section#sec02 div.box{
	background: #fff;
	border-radius: 15px;
	padding-left:160px;
	padding-top: 18px;
	padding-right: 18px;
	padding-bottom: 18px;
	max-width: 822px;
	margin: 0 auto;
	position: relative;
	display: flex;
	justify-content: space-between;
	text-align: left;
	margin-bottom: 35px;
}

section#sec02 div.box.mt40{
	margin: 40px auto 35px;
}

section#sec02 div.box img.point{
	position: absolute;
	top: -3px;
	left: 34px;
}

section#sec02 div.box h3{
	font-size: 43px;
	color: #001349;
	font-weight: bold;
	margin-top: 40px;
}

section#sec02 div.box h3.lh12{
	line-height: 1.2;
}

section#sec02 div.box h3 b{
	color: #008fc4;
}

section#sec02 div.box p{
	margin-top: 20px;
	font-weight: bold;
	line-height: 1.8;
	font-size: 18px;
}

section#sec02 div.box p span{
	background: #ffff00;
	display: inline-block;
}

section#sec02 div.box p b{
	font-size: 15px;
}

section#sec02 div.box h3 span{
	font-size: 20px;
	display: block;
}

@media screen and (max-width: 930px) {
	section#sec02 .inner{width: calc( 100% - 50px); margin: 0 auto; padding: 60px 0;}
	section#sec02 div.box h3{padding-left: 90px; line-height: 1.2; margin-top: 0; font-size: 28px;}
	section#sec02 div.box{display: block; padding-left:18px;}
	section#sec02 div.box img.point{width:85px; left: 20px;}
	section#sec02 div.box h3 span{margin-top: 5px; font-size: 13px; font-feature-settings: "palt";}
	section#sec02 div.box p span{display: inline;}
	section#sec02 div.box div.img_box{text-align: center;}
	section#sec02 div.box div.img_box img{max-width: 279px;}
	section#sec02 div.box.bx03 p{margin-top: 50px;}
	section#sec02 div.box.bx04 h3{margin-top: 5px;}
	section#sec02 div.box.bx04 p{margin-top: 30px;}
	section#sec02 .img01 {top: -10px;}
}

/*sec03*/

section#sec03{
	padding: 0 0 45px;
}

section#sec03 h3{
	background: #051256;
	padding: 45px 20px;
	color: #fff;
	font-size: 38px;
	text-align: center;
	font-weight: bold;
	position: relative;
	margin-bottom: 100px;
}

section#sec03 h3::after{
	content:  url("../img/sec03_img01.jpg");
 	vertical-align: middle;
	position: absolute;
	bottom: -72px;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

section#sec03 ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	text-align: center;
	max-width: 1000px;
	margin: 0 auto;
}

section#sec03 ul li{
	margin-bottom: 65px;
}

section#sec03 ul li span{
	display: block;
	font-size: 24px;
	font-weight: bold;
	margin-top: 5px;
	line-height: 1.3;
}

@media screen and (max-width: 877px) {
	section#sec03 ul{width: calc( 100% - 50px); margin: 0 auto; justify-content: space-around;}
	section#sec03 ul li{width: 43%; margin-bottom: 30px;}
	section#sec03 h3{font-size: 25px;}
	section#sec03 h3::after {bottom: -60px;}
	section#sec03 ul li span{font-size: 19px; margin-top: 11px;}
	
}

/*sec04*/

section#sec04{
	padding: 72px 0 57px;
	background: url("../img/sec04_bg.jpg") repeat;
	text-align: center;
	
}

section#sec04 div.inner{
	max-width: 1000px;
	margin: 73px auto 0;
}

section#sec04 div.inner ul {
	margin-top: 73px;
	display: flex;
	justify-content: space-between;
}

section#sec04 div.inner ul li{
	background: #fff;
	border-radius: 15px;
	padding: 40px 0;
	max-width: 294px;
	margin: 0 auto;
	position: relative;
}

section#sec04 div.inner ul li::after{
	content:  url("../img/sec04_icon.png");
 	vertical-align: middle;
	position: absolute;
	right: -40px;
    top: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}


section#sec04 div.inner ul li:last-child::after{
	display: none;
}

section#sec04 div.inner ul li p{
	text-align: left;
	padding: 0 25px;
	margin-top: 52px;
}

section#sec04 div.inner ul li:nth-child(2) p{
	margin-top: 20px;
}

section#sec04 div.inner ul li h4{
	font-size: 24px;
	font-weight: bold;
	margin-top: 33px;
	line-height: 1.3;
}

section#sec04 div.inner ul li p{
	font-size: 20px;
}

@media screen and (max-width: 999px) {
	section#sec04 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec04 div.inner ul{display: block; margin-top: 40px;}
	section#sec04 div.inner ul li{margin: 0 auto 40px;}
	section#sec04 div.inner ul li::after{
		content:  url("../img/sec04_icon02.png");
		left: 50%; top: 105%;
		transform: translate(-50%, -50%);
    	-webkit-transform: translate(-50%, -50%);
    	-ms-transform: translate(-50%, -50%);
		width: 37px;
		height: 19px;
	}
	section#sec04 div.inner ul li img{max-width: 183px;}
	section#sec04 div.inner ul li p{margin-top: 20px;}
}

/*sec05*/

section#sec05{
	padding: 0 0 85px;
	
}

section#sec05 .inner{
	max-width: 1000px;
	margin: 0 auto;
}

section#sec05 h3{
	font-size: 42px;
	background: #008fc4;
	padding: 50px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
}

section#sec05 .inner h4{
	color: #051256;
	font-size: 34px;
	text-align: center;
	font-weight: bold;
	margin-top: 80px;
	margin-bottom: 88px;
	line-height: 1.2;
}

section#sec05 .inner h4 span{
	color: #ff6d00;
	font-size: 43px;
	display: block;
}

section#sec05 .inner ul{
	display: flex;
	justify-content: space-between;
}

section#sec05 .inner ul li{
	max-width: 293px;
}

section#sec05 .inner ul li b{
	display: block;
	color: #051256;
	text-align: center;
	font-size: 24px;
	margin: 30px 0;
}

section#sec05 .inner ul li p{
	color: #051256;
	font-size: 24px;
}

section#sec05 .inner ul li p span{
	color: #ff6d00;
	font-weight: bold;
}

@media screen and (max-width: 920px) {
	section#sec05 {padding: 0 0 60px;}
	section#sec05 h3 {font-size: 30px;}
	section#sec05 .inner h4{font-size: 28px; margin-bottom: 50px; margin-top: 50px;}
	section#sec05 .inner h4 span{font-size: 35px;}
	section#sec05 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec05 .inner ul{display: block;}
	section#sec05 .inner ul li{max-width: 100%;text-align: center; margin-bottom: 20px;}
	section#sec05 .inner ul li img{max-width: 230px;}
	section#sec05 .inner ul li p{text-align: left; font-size: 20px;}
	section#sec05 .inner ul li b{margin: 5px 0;}
}

/*sec06*/

section#sec06{
	padding:0 0 85px;
	
}

section#sec06 .inner{
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
}

section#sec06 h3{
	font-size: 42px;
	background: #008fc4;
	padding: 50px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	margin-bottom: 150px;
}

section#sec06 td,section#sec06 th{
	border: solid 1px #000;
	padding: 15px 0;
	font-weight: bold;
	font-size: 19px;
}

section#sec06 th.emp {
  background-image: linear-gradient(to top left,
  transparent, transparent 49%,
     black 50%,
     black 50%,   /* 線の太さ */
    transparent 51%, transparent);
	border-top: none;
	border-left: none;
	background-color: #fff;
}

section#sec06 img.marunage{
	position: absolute;
	top: -86px;
	right: 0;
}

section#sec06 tr.ti {
	font-weight: bold;
	text-align: center;
	font-size: 22px;
	line-height: 1.2;
}

section#sec06 tr.ti th{
	width: 14%;
}

section#sec06 tr.ti td:nth-of-type(1){
	background: #ecf9ff;
	width: 12%;
}

section#sec06 tr.ti td:nth-of-type(2){
	background: #e9ffea;
	width: 14%;
}

section#sec06 tr.ti td:nth-of-type(3){
	background: #fef2e2;
	width: 14%;
}

section#sec06 tr.ti td:nth-of-type(4){
	background: #38a0e9;
	color: #fff;
	width: 17%;
}

section#sec06 tr.ti td:nth-of-type(5){
	background: #051256;
	color: #fff;
	width: 20%;
}

section#sec06 tr.ti td:nth-of-type(4) span{
	background: #f57802;
	color: #fff;
	padding: 2px;
	display: block;
	width: 100px;
	text-align: center;
	margin: 5px auto 0;
	font-size: 18px;
}

section#sec06 th{
	background: #e4e4e4;
}

section#sec06 th,section#sec06 td{
	text-align: center;
	line-height: 1.2;
}

section#sec06 .tb01 tr:nth-child(2) td{
	text-align: left;
	padding: 15px;
	font-size: 14px;
	font-weight: normal;
	line-height: 1.5;
}

section#sec06 th span{
	font-weight: normal;
	font-size: 15px;
}

section#sec06 .tb01 tr:nth-child(3) td,
section#sec06 .tb01 tr:nth-child(5) td{
	background:#ffffdd;
}

section#sec06 .tb01 tr:nth-child(6) td{
	background: #717171;
	color:#fff;
	padding: 10px 0;
}

section#sec06 tr td b{
	display: inline-block;
	width: 20px;
	height: 20px;
	background: #fff;
	border: solid 2px #000; 
	-moz-border-radius: 20px;
	-webkit-border-radius: 20px;
	-o-border-radius: 20px;
	-ms-border-radius: 20px; 
	border-radius: 20px;
	margin-top: 6px;
}

section#sec06 tr:nth-child(7) td,
section#sec06 tr:nth-child(8) td,
section#sec06 tr:nth-child(10) td,
section#sec06 tr:nth-child(11) td{
	font-size: 24px;
}

section#sec06 tr:nth-child(9) td,
section#sec06 tr:nth-child(11) td:nth-child(4),
section#sec06 tr:nth-child(11) td:nth-child(5),
section#sec06 tr:nth-child(11) td:nth-child(6){
	font-size: 19px;
}

section#sec06 .tb02{
	width: 100%;
	margin-top: 46px;
}

section#sec06 .tb02 tr:nth-child(1) th{
	background: #717171;
    color: #fff;
	padding: 10px;
	text-align: center;
}

section#sec06 .tb02 tr th{
	text-align: left;
	padding: 15px;
}

@media screen and (max-width: 820px) {
	section#sec06 h3 {font-size: 30px;}
	section#sec06 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec06 .tb01.pc{display: none;}
	section#sec06 img.marunage{display: none;}
	section#sec06 .tb01.sp{width: 100%;}
	
	section#sec06 .tb01.sp tr.ti td p span:nth-child(2){
		width: 100px;
	}
	section#sec06 .tb01.sp tr td,section#sec06 .tb01.sp tr th {
	  border-bottom: none;
		display: block;
		width: 100%; box-sizing:border-box;
	  }
	section#sec06 h3{margin-bottom: 50px;}
	section#sec06 tr.ti td:nth-of-type(4) span{width: 130px; margin: 0 auto;}
	section#sec06 .tb01.sp tr.ti td p{width: 240px;margin: 0 auto 5px;}
	section#sec06 .tb01.sp tr:nth-child(2) td{
		width: auto;
	}
	section#sec06 .tb01.sp tr.ti th:nth-of-type(1) {
		background: #ecf9ff;
	}
	section#sec06 .tb01.sp tr.ti td:nth-of-type(1),
	section#sec06 .tb01.sp tr.ti td:nth-of-type(2),
	section#sec06 .tb01.sp tr.ti td:nth-of-type(3),
	section#sec06 .tb01.sp tr.ti td:nth-of-type(4),
	section#sec06 .tb01.sp tr.ti td:nth-of-type(5){
		background: #fff;
		font-size: 18px;
		font-weight: normal;
		text-align: left;
		padding: 15px;
		color: #000;
	}
	section#sec06 .tb01.sp tr.ti th:nth-of-type(2) {
		background: #e9ffea;
	}
	section#sec06 .tb01.sp tr.ti th:nth-of-type(3) {
		background: #fef2e2;
	}
	section#sec06 .tb01.sp tr.ti th:nth-of-type(4) {
		background: #38a0e9;
		color: #fff;
	}
	section#sec06 .tb01.sp tr.ti th:nth-of-type(5) {
		background: #051256;
		color: #fff;
	}
	section#sec06 .tb01.sp tr.ti th p{
		background: #fff; 
		display: flex; 
		justify-content: center; 
		padding: 5px; 
		width: 210px;
		margin: 0 auto 5px;
	}
	section#sec06 .tb01.sp tr.ti th p span:first-child{
		background: linear-gradient(90deg, #47c5d1, #3aa5dd 30%, #2e82e5);
		background: -webkit-linear-gradient(0deg, #47c5d1, #3aa5dd 30%, #2e82e5);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
		padding: 3px;
		font-weight: bold;
	}
	section#sec06 .tb01.sp tr.ti th p span:nth-child(2){
		background: #f57802;padding: 3px;
	}
	section#sec06 .tb01.sp{border-bottom: solid 1px #000;}
	section#sec06 .tb03.sp{width: 100%; margin-top: 30px;}
	section#sec06 .tb03.sp td:nth-child(1),
	section#sec06 .tb04.sp td:nth-child(1){
		font-size: 16px;
	}
	section#sec06 .tb03.sp td:nth-child(1) span,
	section#sec06 .tb04.sp td:nth-child(1) span{
		background: #f57802;
    	padding: 3px;
		color: #fff;
		margin-left: 5px;
		font-size: 14px;
	}
	section#sec06 .tb04.sp{margin-top: 30px; width: 100%;}
	section#sec06 .tb04.sp tr:nth-child(1) th{
		background: #717171; color: #fff;
	}
	section#sec06 .tb04.sp tr:nth-child(1) th span{
		font-size: 14px;
		display: block;
	}
	section#sec06 .tb02 tr th,
	section#sec06 .tb02 tr td{
		font-size: 16px;
		padding: 15px;
	}
	section#sec06 .tb02{
		margin-top: 30px;
	}
}
	

@media screen and (min-width: 820px) {
	section#sec06 table.sp{display: none;}
	
}

/*sec06*/

section#sec07{
	padding:0 0 85px;
	background-color: #8cdaf1;
	background-image: url("../img/sec07_bg01.png"), url("../img/sec07_bg02.png"), url("../img/sec07_bg03.png"), url("../img/sec07_bg04.png");
	background-position: left  top, right top, left bottom, right bottom;
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	padding: 100px 0 80px;
	position: relative;
	text-align: center;
}

section#sec07 .img{
	position: absolute;
	top: -30px;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

section#sec07 .inner{
	max-width: 1096px;
	margin: 0 auto;
	position: relative;
}

@media screen and (max-width: 1096px) {
	section#sec07{padding: 60px 0 40px;}
	section#sec07 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec07 .img{width: 80%; top: -12px;}
}

/*sec08*/

section#sec08{
	padding:0 0 85px;
	
}

section#sec08 .inner{
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
}

section#sec08 h3{
	font-size: 42px;
	background: #008fc4;
	padding: 50px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	margin-bottom: 150px;
}

section#sec08 .inner dl{
	color: #001349;
	border-bottom: dotted #848484 2px;
	margin-bottom: 40px;
}

section#sec08 .inner dl dt{
	font-size: 30px;
	font-weight: bold;
	padding: 20px 0 20px 75px;
	background: url("../img/sec08_img01.jpg") no-repeat;
	line-height: 1;
}

section#sec08 .inner dl dd{
	font-size: 24px;
	padding: 10px 0 50px 75px;
	background: url("../img/sec08_img02.jpg") no-repeat;
}

@media screen and (max-width: 1000px) {
	section#sec08{padding: 0 0 40px;}
	section#sec08 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec08 h3{margin-bottom: 30px;}
	section#sec08 .inner dl dt{background-size: 45px; font-size: 22px;padding:  0px 0 5px 75px;}
	section#sec08 .inner dl dd{background-size: 45px; background-position: left top 10px; font-size: 18px;padding:  10px 0 35px 75px;}
	section#sec08 .inner dl:nth-child(2) dt{ padding: 13px 0 13px 75px;}
}

/*sec09*/

section#sec09 a.btn{
	background: -moz-linear-gradient(left, #47c5d1, #2d80e6);
  background: -webkit-linear-gradient(left, #47c5d1, #2d80e6);
  background: linear-gradient(to right, #47c5d1, #2d80e6);
	color: #fff;
	font-size: 30px;
	width: 350px;
	display: block;
	margin: 0 auto;
	text-align: center;
	padding: 20px;
	margin-top:20px;
}

section#sec09 a.btn:hover{
	opacity: 0.7;
}

section#sec09{
	text-align: center;
	padding:0 0 85px;
	background-color: #fff;
	background-image:
	 radial-gradient(#eee 1px, transparent 1px);
	background-size: 10px 10px;
}

section#sec09 .inner{
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
}

section#sec09 h3{
	font-size: 42px;
	background: #008fc4;
	padding: 50px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	margin-bottom: 60px;
}

section#sec09 p.txt{
	text-align: center;
	color: #C81E32;
	font-size: 20px;
	margin-bottom: 60px;
}

section#sec09 ul li{
	padding: 15px 0;
}

section#sec09 ul li p{
	width: 40%;
	padding: 10px 0;
	color: #001349;
	font-size: 18px;
}

@media screen and (max-width: 1000px) {
	section#sec09{padding: 0 0 60px;}
	section#sec09 div.inner{width: calc( 100% - 50px); margin: 0 auto; }
	section#sec09 ul li{padding: 5px 0;}
	section#sec09 p.txt{margin-bottom: 30px;}
	section#sec09 a.btn{width: 100%; max-width: 300px;}
}

footer{
	background: #001349;
	padding: 30px 0;
}

footer address{
	color: #fff;
	text-align: center;
}
