/* --------------------------　メインスライダー　-------------------------- */

figure {
	margin: 0 !important;
	padding: 0 !important;
}
.pcimg {
	display: block;
}
.spimg {
	display:none;
}

@media screen and (max-width: 1120px) {
.pcimg {
	display: none;
}
.spimg {
	display:block;
}

}

.top_main {
  background: linear-gradient(90deg, #583774 0%, #583774 50%, #e5787f 50%, #e5787f 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
	padding: 100px 0 150px 0;
}
.top_main_sp {
	display: none;
}
.mainbox {
	max-width: 1600px;
	margin: auto;
	display: flex;
}
.main_l {
	width: 20%;
}
.main_r {
	width: 20%;
}

.maintitle {
	width: 55%;
	margin-top: 60px;
}

.main_l img,
.main_r img{
	width: 100%;
	height: auto
}


@media screen and (max-width: 1120px) {
	

  .top_main {
	  display: none; 
  }
	
.top_main_sp {
  background: linear-gradient(90deg, #583774 0%, #583774 50%, #e5787f 50%, #e5787f 100%);
  width: auto;
	padding: 20px 10px 40px 10px;
	display: block;
}
  .top_main_title {
    width: 95%;
	 display: flex;
   justify-content: center;
  align-items: center;
	flex-direction: column;
	top: 0;
  }
	.top_main_title img {
    width: 100%;
  }
	
	
	
.mainbox {
	max-width: auto;
	margin: auto;
	display: flex;
}
.main_l {
	width: 50%;
}
.main_r {
	width: 50%;
}

.maintitle {
	width: 55%;
	margin-top: 60px;
}

.main_l img,
.main_r img{
	width: 100%;
	height: auto
}
	.top_main_sp .title {
		margin-bottom: 20px;
	}
	
	
	
}







/* --------------------------　コンテンツ　-------------------------- */


.content_wrap  {
	width: 1120px;
	margin: auto;
	position: relative;
	z-index: 1;
}
.content_block {
	margin-bottom: 60px;
}


.bg01-top {
	position: relative;
	margin-top: -65px;
	background: url("../../images/top/bg01-top.png");
	background-position: center;
	background-repeat:no-repeat;
	width: 100%;
	height: 65px;
	background-size: cover;
}
.section01 {
	padding: 20px 0;
}
.s01-01 {
	margin-bottom: 40px;
}
.s01-box {
	display: flex;
	justify-content: space-between;
	margin-bottom: 40px;
}
.s01-item {
	width: 31%;
}

.s01-item img {
	width: 100%;
	height: auto;
}
.section01 p {
	text-align: center;
	font-size: 3rem;
	line-height: 1.6;
	margin-bottom: 40px;
}



.sec02_midashi {
	background: #583376;
	padding: 40px 0;
	text-align: center;
}
.sec02_midashi_top {
	background: url("../../images/top/s02_mtop.png");
	background-reeat: repeat-x;
	height: 30px;
}
.sec02_midashi_bottom {
	background: url("../../images/top/s02_mbottom.png");
	background-repeat: repeat-x;
	height: 30px;
	margin-bottom: 60px;
}

.sec02_midashi div {
	max-width: 900px;
	margin: auto;
	text-align: center;
}
.sec02_midashi figure img {
	width: 100%;
	height: auto;
}
.sec02-m02 {
	max-width: 70%;
	margin: auto;
}
.sec02-m02 img {
	width: 100%;
	height: auto;
}



.section03 {
	background: #583774;
	padding: 0px 0 0px 0;
}
.s03-midashi {
	font-size: 3.6rem;
	color:#fff;
	text-align: center;
	line-height: 1.6;
	font-weight: 600;
	margin-bottom: 40px;
}
.s03-midashi .m {
	font-size: 4rem;
}
.s03-midashi .l {
	font-size: 5rem;
}
.s03-01 {
	max-width: 80%;
	margin: auto;
}
.s03-01 img {
	width: 100%;
	height: auto;
}


.section04 {
	padding: 80px 0 140px 0;
}

.s04-t01 {
	font-size: 3.4rem;
	text-align: center;
	line-height: 1.6;
}
.s04-t01 {
	font-size: 3.4rem;
	text-align: center;
	line-height: 1.6;
	position: relative;
}
.s04-t01:before {
  position: absolute;
  bottom: -40px;
  left: calc(50% - 210px);
  width: 420px;
  height: 8px;
  content: '';
  border-radius: 3px;
  background:url("../../images/top/sec04-border.png");
}
.s04-02 {
	max-width: 85%;
	margin: 100px auto 50px auto;
}



.section05 {
	background: #583774;
	padding: 0px 0 0px 0;
}
.section05 h2 {
	color: #fff;
	padding:40px 0;
	margin: 0;
	font-size: 5rem;
	font-weight: bold;
	line-height: 1.4;
}


.sankaku {
	width: 220px;
	margin: auto;
	position: relative;
}
.sankaku02 {
	position: absolute;
	width: 160px;
	top: -40%;
    left: 50%;
    transform: translate(-50%, -0%);
    -webkit-transform: translate(-50%, -0%);
    -ms-transform: translate(-50%, -0%);
}

.wbg {
	background: #fff;
	border-radius: 20px;
	padding: 40px 40px 20px 40px;
	position: relative;
}


.check01 li {
	padding-left: 60px;
	line-height: 1.6em;
	background: url("../../images/top/check.png") left 0px top 2px no-repeat;
	background-size: 40px auto;
	font-size: 2.4rem;
	margin-bottom: 25px;
}
.sec05-01 {
	max-width: 700px;
	margin: auto;
	margin-top: 40px;
}

.section06 {
	background: #fff;
	padding-bottom: 50px;
	
}
.nami01 {
	position: relative;
	top:-30px;
	background: url("../../images/top/nami01.png");
	background-repeat: repeat-x;
	width: 100%;
	height: 30px;
}

.sec06-01 {
	width: 70%;
	margin: 40px auto 50px auto;
}
.section06 p {
	font-size: 3.4rem;
	font-weight: 600;
	text-align: center;
	line-height: 1.6;
	margin-bottom: 30px;
}


.highlight {
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.5em; /* 線の太さ */
  text-decoration-color: rgba(255, 241, 0,1); /* 線の色 */
  text-underline-offset: -0.2em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}


 .dot-text  {
	padding-top: 10px;
	background-position: top left;
	background-repeat: repeat-x;
	background-size: 1em 0.5em;
	background-image: radial-gradient(circle at center, #62447d 20%, transparent 20%);

}

.nami02 {
	position: relative;
	top:0px;
	background: url("../../images/top/nami02.png");
	background-repeat: repeat-x;
	width: 100%;
	height: 30px;
}

.section07 {
	padding-bottom: 100px;

}
.section07 .content {
	position: relative;
}

.section07 h2 {
	padding-top: 80px;
}

.sec07-ill {
	position: relative;
	width: 1000px;
	margin: auto;
}
.sec07-ill img {
	position: absolute;
	width: 180px;
	height: auto;
	right:0;
	bottom:-100px;
}


.section08 {
	padding: 100px 0;

}

.sec08-01{
	width: 80%;
	margin: auto;
}
.sec08-01 img {
	width: 100%;
	height: auto;
}

.sec08-02 {
	max-width: 750px;
	margin: 60px auto 0px auto;
}
.sec08-02 img {
	width: 100%;
	height: auto;
}


.section09 {
	background: #e5787f;
	padding: 100px 0 0px 0;
}
.section09 h2 {
	width: 70%;
	margin: 0 auto;
	padding: 0;
}
.section09 h2 img {
	width: 100%;
	height: auto;
}

.sec09-03 {
	width: 70%;
	margin: 80px auto 0 auto;
}
.sec09-03 img {
	width: 100%;
	height: auto;
}

.section10 {
	padding: 100px 0 100px 0;
}

.section10 h2 {
	width: 100%;
	padding: 0;
	margin: 0 auto 60px auto;
}
.section10 h2 img {
	width: 100%;
	height: auto;
}

.kirabox {
	width: 660px;
	margin: auto;
	margin-bottom: 50px;
}

.kira li {
	padding-left: 60px;
	line-height: 1.6em;
	background: url("../../images/top/kira.png") left 0px top 6px no-repeat;
	background-size: 45px auto;
	font-size: 3rem;
	margin-bottom: 20px;
}
.sec10-02 {
	width: 80%;
	margin: 0px auto 0 auto;
}
.sec10-02 img {
	width: 100%;
	height: auto;
}


.section11 {
	padding-bottom: 100px;
}

.box {
	background: #fff;
	padding: 40px;
}


.box h3 {
	width: 40%;
	padding: 0;
	margin: 0 auto 30px auto;
}
.box h3 img {
	width: 100%;
	height: auto;
}

.balloon {
    position: relative;
    display: inline-block;
    background-color: #fff;
    border: solid 4px #e5787f;
    padding: 20px 20px 30px 20px;
    width: 100%;
    text-align: center;
	border-radius: 20px;
	box-sizing: border-box;
	font-size: 2.6rem;
	line-height: 1.6;
	margin-bottom: 50px;
}
.balloon:before,
.balloon:after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.balloon:before {
    border: solid 22px transparent;
    border-top: solid 28px #e5787f;
}
.balloon:after {
    border: solid 25px transparent;
    border-top: solid 32px #fff;
    margin-top: -10px;
}
.balloon p {
    margin: 0;
    padding: 0;
}


.sec11-02 {
	width: 20%;
	margin: 0px auto 80px auto;
}
.sec11-02 img {
	width: 100%;
	height: auto;
}

.section12 {
	padding: 100px 0;
}

.sec12-01 {
	width: 80%;
	margin: 0px auto 40px auto;
}
.sec12-01 img {
	width: 100%;
	height: auto;
}

.section12 p {
	font-weight: normal;
	font-size: 3.4rem;
	line-height: 2;
	margin: 50px 0;
}
.section12 p span {
	color:#39bc27;
	font-weight: bold;
}
.sec12-03 {
	width: 30%;
	margin: 100px auto 40px auto;
}
.sec12-03 img {
	width: 100%;
	height: auto;
}
.sec12-04 {
	width: 60%;
	margin: 60px auto 40px auto;
}
.sec12-04 img {
	width: 100%;
	height: auto;
}
p.endtext {
	margin-top: -30px;
	font-size: 4rem !important;
}

.lasttext {
    position: relative;
    padding: 20px 20px 30px 20px;
    margin-bottom: 0.2rem;
	text-align: center;
    border-top: 7px double #39bc27;
    border-bottom: 7px double #39bc27;
    color: #39bc27;
    font-weight: bold;
    font-size: 3rem;
	line-height: 1.5;
}


@media screen and (max-width: 786px) {
	
	
/* --------------------------　コンテンツ　-------------------------- */


.content_wrap  {
	width: auto;
	margin: auto;
	position: relative;
	z-index: 1;
}
.content_block {
	margin-bottom: 60px;
}


.bg01-top {
	position: relative;
	margin-top: -65px;
	background: url("../../images/top/bg01-top.png");
	background-position: center bottom;
	background-repeat:no-repeat;
	width: 100%;
	height: 65px;
	background-size: 100%;
}
.section01 {
	padding: 20px 0;
}
.s01-01 {
	margin-bottom: 20px;
}
.s01-01 img{
	width: 100%;
	height: auto;
}
.s01-box {
	display: flex;
	justify-content: space-between;
	flex-direction: column;
	margin-bottom: 40px;
	margin: 0 15%;
}
.s01-item {
	width: 100%;
	margin-bottom: 20px;
}

.s01-item img {
	width: 100%;
	height: auto;
}
.section01 p {
	text-align: center;
	font-size: 1.6rem;
	line-height: 1.6;
	margin-bottom: 0px;
}



.sec02_midashi {
	background: #583376;
	padding: 20px 20px;
	text-align: center;
	box-sizing: border-box;
}
.sec02_midashi_top {
	background: url("../../images/top/s02_mtop.png");
	background-repeat: repeat-x;
	height: 14px;
	background-size: contain;
	background-position: center bottom;
}
.sec02_midashi_bottom {
	background: url("../../images/top/s02_mbottom.png");
background-repeat: repeat-x;
	height: 14px;
	margin-bottom: 30px;
	background-size: contain;
	background-position: center top;
}

.sec02_midashi div {
	max-width: auto;
	margin: auto;
	text-align: center;
}
.sec02_midashi figure img {
	width: 100%;
	height: auto;
}
.sec02-m02 {
	max-width: 92%;
	margin: auto;
}
.sec02-m02 img {
	width: 100%;
	height: auto;
}



.section03 {
	background: #583774;
	padding: 0px 0 0px 0;
}
.s03-midashi {
	font-size: 1.8rem;
	color:#fff;
	text-align: center;
	line-height: 1.6;
	font-weight: 600;
	margin-bottom: 20px;
	margin-top: 30px;
}
.s03-midashi .m {
	font-size: 1.8rem;
}
.s03-midashi .l {
	font-size: 2.2rem;
}
.s03-01 {
	max-width: 90%;
	margin: auto;
}
.s03-01 img {
	width: 100%;
	height: auto;
}


.section04 {
	padding: 30px 0 70px 0;
}

.s04-t01 {
	font-size: 3.4rem;
	text-align: center;
	line-height: 1.6;
}
.s04-t01 {
	font-size: 1.5rem;
	text-align: center;
	line-height: 1.6;
	position: relative;
}
.s04-t01:before {
  position: absolute;
  bottom: -20px;
  left: calc(50% - 110px);
  width: 220px;
  height: 8px;
  content: '';
  border-radius: 3px;
  background:url("../../images/top/sec04-border.png");
	background-size: contain;
	background-repeat: no-repeat;
}
.s04-02 {
	max-width: 85%;
	margin: 40px auto 20px auto;
}



.section05 {
	background: #583774;
	padding: 0px 0 0px 0;
}
.section05 h2 {
	color: #fff;
	padding:30px 0;
	margin: 0;
	font-size: 2.3rem;
	font-weight: bold;
	line-height: 1.4;
}


.sankaku {
	width: 100px;
	margin: auto;
	position: relative;
	top:-2px;
}
.sankaku02 {
	position: absolute;
	width: 80px;
	top: -45%;
    left: 50%;
    transform: translate(-50%, -0%);
    -webkit-transform: translate(-50%, -0%);
    -ms-transform: translate(-50%, -0%);
}

.wbg {
	background: #fff;
	border-radius: 15px;
	padding: 20px 12px 10px 12px;
	position: relative;
	margin: 0 16px;
	box-sizing: border-box;
}


.check01 li {
	padding-left: 25px;
	line-height: 1.6em;
	background: url("../../images/top/check.png") left 0px top 0px no-repeat;
	background-size: 21px auto;
	font-size: 1.3rem;
	margin-bottom: 15px;
}
.sec05-01 {
	max-width: 90%;
	margin: auto;
	margin-top: 20px;
}

.section06 {
	background: #fff;
	padding-bottom: 20px;
	
}
.nami01 {
	position: relative;
	top:-30px;
	background: url("../../images/top/nami01.png");
	background-size: 300%;
	background-position: center bottom;
	background-repeat: repeat-x;
	width: 100%;
	height: 30px;
}

.sec06-01 {
	width: 90%;
	margin: 0px auto 30px auto;
}
.section06 p {
	font-size: 1.8rem;
	font-weight: 600;
	text-align: center;
	line-height: 1.6;
	margin-bottom: 10px;
}


.highlight {
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.5em; /* 線の太さ */
  text-decoration-color: rgba(255, 241, 0,1); /* 線の色 */
  text-underline-offset: -0.2em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}


 .dot-text  {
	padding-top: 10px;
	background-position: top left;
	background-repeat: repeat-x;
	background-size: 1em 0.5em;
	background-image: radial-gradient(circle at center, #62447d 20%, transparent 20%);

}

.nami02 {
	position: relative;
	top:0px;
	background: url("../../images/top/nami02.png");
	background-size: 300%;
	background-position: left top;
	background-repeat: repeat-x;
	width: 100%;
	height: 30px;
}

.section07 {
	padding-bottom: 50px;

}
.section07 .content {
	position: relative;
}

.section07 h2 {
	padding-top: 20px;
}

.sec07-ill {
	position: relative;
	width: auto;
	margin: auto;
}
.sec07-ill img {
	position: absolute;
	width: 80px;
	height: auto;
	right:0;
	bottom:-50px;
}


.section08 {
	padding: 40px 0;

}

.sec08-01{
	width: 90%;
	margin: auto;
}
.sec08-01 img {
	width: 100%;
	height: auto;
}

.sec08-02 {
	max-width: auto;
	margin: 30px auto 0px auto;
}
.sec08-02 img {
	width: 100%;
	height: auto;
}


.section09 {
	background: #e5787f;
	padding: 40px 0 0px 0;
}
.section09 h2 {
	width: 90%;
	margin: 0 auto;
	padding: 0;
}
.section09 h2 img {
	width: 100%;
	height: auto;
}

.sec09-03 {
	width: 80%;
	margin: 20px auto 0 auto;
}
.sec09-03 img {
	width: 100%;
	height: auto;
}

.section10 {
	padding: 30px 15px 30px 15px;
}

.section10 h2 {
	width: 100%;
	padding: 0;
	margin: 0 auto 20px auto;
}
.section10 h2 img {
	width: 100%;
	height: auto;
}

.kirabox {
	width: auto;
	margin: auto;
	margin-bottom: 0px;
}

.kira li {
	padding-left: 30px;
	line-height: 1.6em;
	background: url("../../images/top/kira.png") left 0px top 0px no-repeat;
	background-size: 25px auto;
	font-size: 1.4rem;
	margin-bottom: 10px;
}
	.nado {
		font-size: 1.2rem;
	}
.sec10-02 {
	width: 90%;
	margin: 0px auto 0 auto;
}
.sec10-02 img {
	width: 100%;
	height: auto;
}


.section11 {
	padding: 20px 15px 40px 15px;
}

.box {
	background: #fff;
	padding: 16px 16px 2px;
}


.box h3 {
	width: 50%;
	padding: 0;
	margin: 0 auto 15px auto;
}
.box h3 img {
	width: 100%;
	height: auto;
}

.balloon {
    position: relative;
    display: inline-block;
    background-color: #fff;
    border: solid 2px #e5787f;
    padding: 15px 15px 20px 15px;
    width: 100%;
    text-align: left;
	border-radius: 20px;
	box-sizing: border-box;
	font-size: 1.32rem;
	line-height: 1.6;
	margin-bottom: 25px;
}
.balloon:before,
.balloon:after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.balloon:before {
    border: solid 10px transparent;
    border-top: solid 16px #e5787f;
}
.balloon:after {
    border: solid 13px transparent;
    border-top: solid 20px #fff;
    margin-top: -8px;
}
.balloon p {
    margin: 0;
    padding: 0;
}


.sec11-02 {
	width: 30%;
	margin: 0px auto 40px auto;
}
.sec11-02 img {
	width: 100%;
	height: auto;
}

.section12 {
	padding: 30px 0;
}

.sec12-01 {
	width: 80%;
	margin: 0px auto 15px auto;
}
.sec12-01 img {
	width: 100%;
	height: auto;
}

.section12 p {
	font-weight: normal;
	font-size: 1.6rem;
	line-height: 2;
	margin: 20px 0 10px 0;
}
.section12 p span {
	color:#39bc27;
	font-weight: bold;
}
.sec12-03 {
	width: 30%;
	margin: 20px auto 0px auto;
}
.sec12-03 img {
	width: 100%;
	height: auto;
}
.sec12-04 {
	width: 65%;
	margin: 20px auto 40px auto;
}
.sec12-04 img {
	width: 100%;
	height: auto;
}
p.endtext {
	margin-top: -30px;
	font-size: 1.6rem !important;
}

.lasttext {
    position: relative;
    padding: 10px 0px 15px 0px;
    margin-bottom: 0.2rem;
	text-align: center;
    border-top: 3px double #39bc27;
    border-bottom: 3px double #39bc27;
    color: #39bc27;
    font-weight: bold;
    font-size: 1.2rem;
	line-height: 1.5;
	margin: 0 30px 30px 30px;
}
	
}
