@charset "utf-8";
/*--------------------------------------
　MV
---------------------------------------*/
.mv_home {
	background: url("img/mv_bg.jpg") right center no-repeat,#88b1b7;
	background-size: contain;
	min-width: 1000px;
  margin: 50px 0 0;
}
.mv_home .mv_inner{
	width: 1000px;
	height: 650px;
	margin: 0 auto;
	position: relative;
	background: url("img/mv_white.svg") left 44px center no-repeat;
	background-size: contain;
  z-index: 0;
}
.mv_home .mv_inner:before {
	content: "";
	background: #fff;
	height: 100%;
	width: 100%;
	position: absolute;
	right: calc(100% - 45px);
  z-index: -1;
}

.mv_home .txt_01 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 384px;
  height: 100px;
  padding: 0.8rem 2rem 0 0;
  font-size: 2.4rem;
  text-align: center;
  transform-origin: center bottom;
  animation: yurayura 2s linear infinite;
  position: relative;
  z-index: 0;
  right: 22px;
}
.mv_home .txt_01::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  background: url("/wp/wp-content/uploads/mv_sb.png") left top no-repeat;
  background-size: contain;
  width: 384px;
  height: 100px;
  z-index: -1;
}

.mv_home .mv_ttl{
	padding-top: 6rem;
	font-size:40px;
}
.mv_home .mv_ttl .txt_02{
	font-size: 60px;
  line-height: 1.2;
}
.mv_home .mv_ttl .txt_03{
  line-height: 1.5;
}
.mv_home .mv_txt{
	width: 480px;
	line-height: 1.9;
	margin: 2rem 0 3rem;
}
.mv_home a {
	display: table;
	background: #02c0ac;
	border-radius: 100px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 22px;
	padding: 1.5rem 6rem;
	line-height: 1.4;
	margin-top: 4rem;
	position: relative;
}
.mv_home a span{
	font-weight: bold;
	font-size: 29px;
}
.mv_home a:after {
	content: "";
	background: url("img/arrow_under.png") no-repeat;
	background-size: cover;
	height: 39px;
	width: 23px;
	position: absolute;
	top:90%;
	left: 50%;
	transform: translate(-50%,0);
}

.mv_home .mv_illust {
	display: block;
	width: 540px;
	position: absolute;
	left: 56.8%;
	top: 210px;
}
.mv_home .mv_fukidashi {
	display: block;
	width: 597px;
	position: absolute;
	left: 55%;
	top: 150px;
}

@keyframes yurayura {
  0% , 100%{
      transform: translate(0,10px);
  }
  50%{
      transform: translate(0,-10px);
  }
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .mv_home {
    background: url("img/sp_mv.png") bottom no-repeat;
    background-size: 100% auto;
    min-width: 100%;
    margin: 0 0 0;
  }
  .mv_home .mv_inner{
    width:100%;
    height: auto;
    margin: 0 auto;
    position: relative;
    background: none;
    background-size: contain;
    padding: 0 1.4rem 21rem;
    box-sizing: border-box;
  }
  .mv_home .mv_inner:before {
    content: "";
    background: #fff;
    height: 100%;
    width: 100%;
    position: absolute;
    right: 100%;
  }


  .mv_home .txt_01 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: auto;
    margin: 0 0 2rem;
    padding: 0.8rem 0.5rem 0 0;
    font-size: 3.8vw;
    right: 0px;
  }
  .mv_home .txt_01::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 52%;
    transform: translate(-50%,-50%);
    background: url("/wp/wp-content/uploads/mv_sb.png") left top no-repeat;
    background-size: contain;
    width: 65%;
    height: 0;
    padding-top: calc(65%*100/384);
  }



  .mv_home .mv_ttl{
    padding-top: 2rem;
    font-size:24px;
    text-align: center;
  }
  .mv_home .mv_ttl .txt_02{
    font-size:36px;
    line-height: 1.2;
  }
  .mv_home .mv_txt{
    width: 100%;
    line-height: 1.6;
    margin:2rem 0;
  }
  .mv_btn {
    position: absolute;
    left: 50%;
    transform: translate(-50%,0);
    bottom: -3rem;
    width: 90%;
    z-index: 2;
  }
  .mv_home a {
    display: table;
    background: #02c0ac;
    border-radius: 100px;
    color: #fff;
    text-align: center;
    font-weight: bold;
    font-size: 1.6rem;
    padding: 1rem 0;
    line-height: 1.4;
    margin-top: 4rem;
    position: relative;
    width: 100%;


  }
  .mv_home a span{
    font-weight: bold;
    font-size: 2rem;
  }
  .mv_home a:after {
    content: "";
    background: url("img/arrow_under.png") no-repeat;
    background-size: cover;
    height: 22px;
    width: 13px;
    position: absolute;
    top:90%;
    left: 50%;
    transform: translate(-50%,0);
  }
  .mv_home .mv_illust {
    width: 70%;
    position: absolute;
    left: 49%;
    transform: translate(-50%,0);
    top:inherit;
    bottom: 0;
  }
  .mv_home .mv_fukidashi {
    display: block;
    width: 90%;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    top: inherit;
    bottom: 25%;
  }
  @keyframes yurayura {
    0% , 100%{
        transform: translate(0,5px);
    }
    50%{
        transform: translate(0,-5px);
    }
  }
}





/*--------------------------------------
　Main Index
---------------------------------------*/
.contents_top {
	width: 100%;
	min-width: 1000px;
	margin: auto;
	box-sizing: border-box;
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.sec {
	width: 100%;
	min-width: 1000px;
	margin: auto;
	box-sizing: border-box;
	position: relative;
	padding: 10rem 0;
}
.sec .inner {
	max-width: 1000px;
	margin: auto;
	box-sizing: border-box;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.contents_top {
		min-width: 100%;
	}
	.sec {
		min-width: 100%;
		padding: 6rem 0;
	}
	.sec .inner {
		max-width: 100%;
		padding: 0 1.4rem;
	}
}





/*--------------------------------------
　Title
---------------------------------------*/
.ttl_01 {
	position: relative;
	min-width: 1000px;
	text-align: center;
	background: linear-gradient(90deg, rgba(69,94,168,1) 0%, rgba(8,30,75,1) 100%);
	padding: 5rem 0 3rem;
}
.ttl_01 .txt {
	font-size: 3.4rem;
	text-align: center;
	color: #fff;
	line-height: 1.3;
}
.ttl_01 .txt span {
	font-size: 4rem;
	color: #fadb3b;
}
.ttl_01 .fukidashi {
	position: absolute;
	top: -6rem;
	left: 50%;
	transform: translate(-50%,0);
	left: 0;
	right: 0;
}
.ttl_01 .fukidashi span {
	background: #3ea2bd;
	font-size: 2.8rem;
	font-weight: bold;
	color: #fff;
	padding: 0.5rem 2rem;
	border-radius: 8px;
	position: relative;
}
.ttl_01 .fukidashi span:before {
  content: "";
  position: absolute;
  top: 98%;
  left: 50%;
  margin-left: -8px;
  border: 10px solid transparent;
  border-top: 15px solid #3ea2bd;
}


.ttl_02 .txt {
	font-size: 3.4rem;
	text-align: center;
	line-height: 1.3;
}
.ttl_02 .txt span {
	font-size: 4.4rem;
	color: #3cb2d2;
}
.ttl_02 .fukidashi {
	text-align: center;
}
.ttl_02 .fukidashi span {
	background: #081e4b;
	font-size: 2.8rem;
	font-weight: bold;
	color: #fff;
	padding: 0.5rem 2rem;
	border-radius: 8px;
	position: relative;
}
.ttl_02 .fukidashi span:before {
  content: "";
  position: absolute;
  top: 98%;
  left: 50%;
  margin-left: -8px;
  border: 10px solid transparent;
  border-top: 15px solid #081e4b;
}


.ttl_03 {
	text-align: center;
	font-size: 3.2rem;
}
.ttl_03 span{
	font-size: 4.4rem;
}
.ttl_03 a{
	position: relative;
	display: table;
	margin: 0 auto;
}
.ttl_03 a:after {
	display: block;
	position: absolute;
	content: "";
	right: -4rem;
	top: 50%;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #001c63;
  border-right: 2px solid #001c63;
  transform:translate(0,-50%)rotate(-45deg);
}
.mizuiro {
	color: #3cb2d2;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .ttl_01 {
    position: relative;
    min-width:100%;
    text-align: center;
    background: linear-gradient(90deg, rgba(69,94,168,1) 0%, rgba(8,30,75,1) 100%);
    padding: 2rem 0 1rem;
  }
  .ttl_01 .txt {
    font-size: 1.8rem;
    text-align: center;
    color: #fff;
    line-height: 1.3;
  }
  .ttl_01 .txt span {
    font-size: 2.8rem;
    color: #fadb3b;
  }
  .ttl_01 .fukidashi {
    position: absolute;
    top: -3.8rem;
    left: 50%;
    transform: translate(-50%,0);
    padding: 0;
    width: 100%;
    left: 0;
    right: 0;
  }
  .ttl_01 .fukidashi span {
    background: #3ea2bd;
    font-size: 1.6rem;
    font-weight: bold;
    color: #fff;
    padding: 0.5rem 2rem;
    border-radius: 2px;
    position: relative;
  }
  .ttl_01 .fukidashi span:before {
    content: "";
    position: absolute;
    top: 98%;
    left: 50%;
    margin-left: -4px;
    border: 6px solid transparent;
    border-top:8px solid #3ea2bd;
  }
  
  
  .ttl_02 .txt {
    font-size: 1.8rem;
    text-align: center;
    line-height: 1.3;
  }
  .ttl_02 .txt span {
    font-size: 2.8rem;
  }
  .ttl_02 .fukidashi {
    text-align: center;
  }
  .ttl_02 .fukidashi span {
    background: #081e4b;
    font-size: 1.6rem;
    font-weight: bold;
    color: #fff;
    padding: 0.5rem 2rem;
    border-radius: 2px;
    position: relative;
  }
  .ttl_02 .fukidashi span:before {
    content: "";
    position: absolute;
    top: 99%;
    left: 50%;
    margin-left: -4px;
    border: 6px solid transparent;
    border-top: 8px solid #081e4b;
  }


  .ttl_03 {
    text-align: center;
    font-size: 1.8rem;
  }
  .ttl_03 span{
    font-size: 2.8rem;
  }
  .ttl_03 a{
    position: relative;
    display: table;
    margin: 0 auto;
  }
  .ttl_03 a:after {
    display: block;
    position: absolute;
    content: "";
    right: -2rem;
    top: 50%;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #001c63;
    border-right: 2px solid #001c63;
    transform:translate(0,-50%)rotate(-45deg);
  }
}





/*--------------------------------------
　テキスト
---------------------------------------*/
.contents_top p {
	margin: 3rem 0 3rem;
	font-size: 1.4rem;
	line-height: 2;
}

.txt {
	margin: 1rem 0 3rem;
	font-size: 1.4rem;
	text-align: justify;
	line-height: 2;
}

.lead {
	margin: 3rem 0 0!important;
	font-size: 1.4rem;
	line-height: 2;
}
.bold {
	font-weight: bold;
}
.sub{
	font-size: 1.2rem;
}
/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.contents_top p {
		margin: 2rem 0 2rem;
		line-height: 1.8;
	}

	.txt {
		margin: 2rem 0 2rem;
		line-height: 1.8;
	}

	.lead {
		margin: 2rem 0 0!important;
		line-height: 1.8;
	}
}





/*--------------------------------------
　アコーディオン
---------------------------------------*/
.accordion-content {
  display: none;
}
.js-accordion-title {
  position: relative;
}
.js-accordion-title::after {
  border-right: solid 2px #030142;
  border-top: solid 2px #030142;
  content: "";
  display: block;
  height: 8px;
  position: absolute;
  right: 25px;
  top: 50%;
  transform:translate(0,-50%)rotate(135deg);
  transition: transform .3s ease-in-out, top .3s ease-in-out;
  width: 8px;
}
.js-accordion-title.open::after {
  top: 45%;
  transform: rotate(-45deg);
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .js-accordion-title::after {
    right: 15px;
    width: 6px;
    height: 6px;
  }
}





/*--------------------------------------
　目次
---------------------------------------*/
.mokuji {
	padding: 14rem 0 6rem;
}
.mokuji p {
	background: #d0eaeb;
	font-weight: bold;
	text-align: center;
	font-size: 2.8rem;
	position: relative;
	margin: 0!important;
	line-height: 2.5;
}
.mokuji p:before {
	content: "INDEX";
	color: #fff;
	font-size: 3.8rem;
	position: absolute;
	left: 3rem;
	top: 50%;
  transform: translate(0,-50%);
	line-height: 1;
}
.mokuji ul {
	background: #f4f4f4;
	padding: 4rem 10rem 3rem;
}
.mokuji ul li {
	font-size:2rem;
	font-weight: bold;
	position: relative;
	padding-bottom: 1.4rem;
	margin-bottom: 1.4rem;
	border-bottom: 3px dotted #cacaca;
	line-height: 1!important;
}
.mokuji ul li:after {
	display: block;
	position: absolute;
	content: "";
	right: 1rem;
	top: 0.8rem;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #001c63;
  border-right: 2px solid #001c63;
  transform: rotate(45deg);
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .mokuji {
    padding: 10rem 0 0;
  }
  .mokuji p {
    font-size: 1.8rem;
  }
  .mokuji p:before {
    content: "INDEX";
    color: #fff;
    font-size: 2.4rem;
    position: absolute;
    left: 1rem;
    line-height: 1;
  }
  .mokuji ul {
    background: #f4f4f4;
    padding: 2rem;
  }
  .mokuji ul li {
    font-size:1.6rem;
    font-weight: bold;
    position: relative;
    padding:0 1.4rem 1.4rem 0;
    margin-bottom: 1.4rem;
    border-bottom: 3px dotted #cacaca;
    line-height: 1.3!important;
  }
  .mokuji ul li:after {
    display: block;
    position: absolute;
    content: "";
    right: 1rem;
    top: 0.8rem;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #001c63;
    border-right: 2px solid #001c63;
    transform: rotate(45deg);
  }
}





/*--------------------------------------
　sec01
---------------------------------------*/
.sec01 {
	background: url("/wp/wp-content/uploads/sec01_bg.jpg") center bottom no-repeat;
	background-size: 100% auto;
	padding-bottom: 8rem;
}
.sec01 .sub {
	line-height: 1.4;
	text-align: center;
	margin-top: 2rem; 
}
.sec .txt_large {
	font-size: 3.2rem;
	font-weight: bold;
	text-align: center;
	display: table;
	position: relative;
	line-height: 1.4;
	margin: 4rem auto 4rem;
}
.sec .txt_large .txt_01{
	font-size: 4.8rem;
	font-weight: bold;
	color: #3ea2bd;
}
.sec .txt_large:before {
	content: "";
	background: url("img/dots_01.png") no-repeat;
	background-size: cover;
	width: 47px;
	height: 40px;
	position: absolute;
	top:0;
	left: -8rem;
}
.sec .txt_large:after {
	content: "";
	background: url("img/dots_02.png") no-repeat;
	background-size: cover;
	width: 47px;
	height: 40px;
	position: absolute;
	top:0;
	right: -8rem;
}
.sec .illust_box {
	display: flex;
	justify-content: space-between;
	position: relative;
	margin-top: 15rem;
}
.sec .illust_box:after {
	content: "";
	display: block;
	background: url("img/line_01.png") no-repeat;
	background-size: cover;
	width: 458px;
	height: 100px;
	position: absolute;
	top: -100px;
	left: 50%;
	transform: translate(-50%,0);
	z-index: -1;
}
.sec .illust_box > div {
	width: 48%;
	position: relative;
}
.sec .illust_box h3 {
	position: absolute;
	background: #3ea2bd;
	color: #fff;
	font-weight:bold;
	font-size: 2.6rem;
	padding: 1rem 2rem;
	top: -2rem;
	left: 50%;
}
.sec .illust_box .left h3 {
	transform: translate(-30%,0);
}
.sec .illust_box .right h3 {
	transform: translate(-80%,0);
}
.sec .illust_box h5 {
	position: absolute;
	background: #3ea2bd;
	color: #fff;
	font-weight:bold;
	font-size: 2.6rem;
	padding: 1rem 2rem;
	top: -2rem;
	left: 50%;
}
.sec .illust_box .left h5 {
	transform: translate(-30%,0);
}
.sec .illust_box .right h5 {
	transform: translate(-80%,0);
}
.sec .illust_box .fukidashi {
	width: 50%;
	position: absolute;
	left: 0;
	top: 60px;
	transform-origin: center bottom;
	/* animation: yurayura 2s linear infinite; */
}
.sec .illust_box .right .fukidashi {
	left: inherit;
	right: 0;
}
.sec02 .illust_box .fukidashi {
	width: 55%;
}
.sec06 .illust_box .fukidashi {
	width: 54%;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec01 {
    background: url("img/sp_sec01_bg.jpg") center bottom no-repeat;
    background-size: 100% auto;
    padding-bottom:3rem;
  }
  .sec .txt_large {
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    display: table;
    position: relative;
    line-height: 1.4;
    margin: 4rem auto;
  }
  .sec .txt_large .txt_01{
    font-size: 3rem;
  }
  .sec .txt_large:before {
    content: "";
    background: url("img/dots_01.png") no-repeat;
    background-size: cover;
    width:32px;
    height: 28px;
    position: absolute;
    top:0;
    left: -4rem;
  }
  .sec .txt_large:after {
    content: "";
    background: url("img/dots_02.png") no-repeat;
    background-size: cover;
    width:32px;
    height: 28px;
    position: absolute;
    top:0;
    right: -4rem;
  }
  .sec .illust_box {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin-top: 7rem;
  }
  .sec .illust_box:after {
    content: "";
    display: block;
    background: url("img/line_01.png") no-repeat;
    background-size: cover;
    width: 240px;
    height: 40px;
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translate(-50%,0);
    z-index: -1;
  }
  .sec .illust_box > div {
    width: 48%;
    position: relative;
  }
	.sec .illust_box h3 {
    position: absolute;
    background: #3ea2bd;
    color: #fff;
    font-weight:bold;
    font-size: 1.5rem;
    padding: 0.5rem 1rem;
    top: -2rem;
    left: inherit;
    width: 100%;
    text-align: center;
  }
  .sec .illust_box .left h3 {
    transform:none;
  }
  .sec .illust_box .right h3 {
    transform: none;
  }
  .sec .illust_box h5 {
    position: absolute;
    background: #3ea2bd;
    color: #fff;
    font-weight:bold;
    font-size: 1.5rem;
    padding: 0.5rem 1rem;
    top: -2rem;
    left: inherit;
    width: 100%;
    text-align: center;
  }
  .sec .illust_box .left h5 {
    transform:none;
  }
  .sec .illust_box .right h5 {
    transform: none;
  }
}





/*--------------------------------------
　sec02
---------------------------------------*/
.sec02 {
	background: url("/wp/wp-content/uploads/sec01_bg.jpg") center bottom no-repeat;
	background-size: 100% auto;
	padding-bottom: 10rem;
	margin-bottom: 7rem;
}
.sec02 .txt_01 {
	text-align: center;
	font-weight: bold;
	font-size: 2.2rem;
	line-height: 1.6;
	margin: 7rem 0 3rem;
}
.sec02 .txt_011 {
	text-align: center;
	font-weight: bold;
	font-size: 2.2rem;
	line-height: 1.6;
	margin: 3rem 0 12rem;
}
.sec02  ul {
	display: flex;
	justify-content: space-between;
}
.sec02  ul li{
	width: 23%;
	background: #f7f7f7;
	padding: 3rem;
	box-sizing: border-box;
}
.sec02  ul li h3{
	font-size: 1.7rem;
	text-align: center;
}
.sec02 .illust_box:after {
	content: "";
	display: block;
	background: url("img/sec02_arrow.png") no-repeat;
	background-size: cover;
	width: 100px;
	height: 40px;
	position: absolute;
	top: -120px;
	left: 45%;
	transform: translate(-50%,0);
	z-index: -1;
	animation: yurayura 2s linear infinite;
}
.sec02 .illust_box:before {
	content: "";
	display: block;
	background: url("img/sec02_03.png") no-repeat;
	background-size: cover;
	width: 255px;
	height: 209px;
	position: absolute;
	top: 10px;
	left: 50%;
	transform: translate(-50%,0);
	z-index: 2;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec02 {
    background: url("img/sp_sec01_bg.jpg") center bottom no-repeat;
    background-size: 100% auto;
    padding-bottom: 3rem;
    margin-bottom: 3rem;
  }
  .sec02 .txt_01 {
    text-align: center;
    font-weight: bold;
    font-size: 1.6rem;
    margin: 4rem 0 2rem;
  }
  .sec02 .txt_011 {
    text-align: center;
    font-weight: bold;
    font-size: 1.6rem;
    margin: 1rem 0 7rem;
  }
  .sec02  ul {
    display: block;
  }
  .sec02  ul li{
    width: 100%;
    padding: 2rem;
    box-sizing: border-box;
  }
    .sec02  ul li:not(:last-child){
      margin-bottom: 2rem;
  }
  .sec02  ul li h3{
    font-size: 1.6rem;
    text-align: center;
  }
  .sec02 .illust_box:after {
    content: "";
    display: block;
    background: url("img/sec02_arrow.png") no-repeat;
    background-size: cover;
    width: 60px;
    height: 24px;
    position: absolute;
    top: -60px;
    left: 42%;
    transform: translate(-50%,0);
    z-index: -1;
  }
  .sec02 .illust_box:before {
    content: "";
    display: block;
    background: url("img/sec02_03.png") no-repeat;
    background-size: cover;
    width: 100px;
    height: 82px;
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translate(-50%,0);
    z-index: 2;
  }
}





/*--------------------------------------
　sec03
---------------------------------------*/
.sec03 .img_01 {
	width: 55%;
	display: block;
	margin: 4rem auto;
}
/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec03 .img_01 {
    width: 100%;
    display: block;
    margin: 30px auto;
  }
}





/*--------------------------------------
　sec04
---------------------------------------*/
.sec04 {
	background: url("img/sec04_bg.jpg") center 0 no-repeat;
	background-size: 100% auto;
	padding: 6rem 0 3rem;
	color: #fff;
}
.sec04 .ttl_02 .txt {
	color: #fff;
}
.sec04 .ttl_02 .txt span {
	color: #fadb32;
}
.sec04 .txt_01 {
	text-align: center;
}
.sec04 .wrap_01 {
	display: flex;
	justify-content: space-between;
}
.sec04 .wrap_01 a {
	display: block;
	width: 32%;
	position: relative;
	background: #081e4b;
	color: #fff;
	padding: 3rem;
	box-sizing: border-box;
}

.sec04 .wrap_01 .img-box {
	display: block;
	width: 32%;
	position: relative;
	background: #081e4b;
	color: #fff;
	padding: 3rem 3rem 0;
	box-sizing: border-box;
}

.sec04 .wrap_01 a:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -25px;
  border: 20px solid transparent;
  border-top: 25px solid #081e4b;
}
.sec04 .wrap_01 h3 {
	font-size: 2.8rem;
	text-align: center;
}
.sec04 .wrap_01 a img {
	width: 98px;
	display: block;
	margin: 2rem auto 0;
}
.sec04 .wrap_01 .img-box img {
	width: 98px;
	display: block;
	margin: 2rem auto 0;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec04 {
    background: url("img/sp_sec04_bg.jpg") center 0 no-repeat;
    background-size: 100% auto;
    padding: 4rem 0 0;
    color: #fff;
  }
  .sec04 .txt_01 {
    text-align: left;
  }
  .sec04 .wrap_01 {
    display: block;
  }
  .sec04 .wrap_01 a {
    display: block;
    width: 100%;
    position: relative;
    background: #081e4b;
    color: #fff;
    padding: 2rem;
    box-sizing: border-box;
    margin-top:4rem;
  }

	.sec04 .wrap_01 .img-box {
    display: block;
    width: 100%;
    position: relative;
    background: #081e4b;
    color: #fff;
    padding: 2rem;
    box-sizing: border-box;
    margin-top:4rem;
  }


	
  .sec04 .wrap_01 a:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-top: 10px solid #081e4b;
  }

	.sec04 .wrap_01 .img-box:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-top: 10px solid #081e4b;
  }
  .sec04 .wrap_01 h3 {
    font-size: 1.8rem;
    text-align: center;
  }
  .sec04 .wrap_01 a img {
    width: 70px;
    display: block;
    margin: inherit;
    position: absolute;
    left: 2rem;
    top: -6rem;
  }

	.sec04 .wrap_01 .img-box img {
    width: 70px;
    display: block;
    margin: inherit;
    position: absolute;
    left: 2rem;
    top: -6rem;
  }
  .sec04 .wrap_01 a p {
    margin:1rem 0 0 0;
  }
	.sec04 .wrap_01 .img-box p {
    margin:1rem 0 0 0;
  }
}





/*--------------------------------------
　sec05
---------------------------------------*/
.sec05 p {
  margin: 0 0 0;
}

.sec05 .ttl_02 .txt {
  margin: 2rem 0 0;
}
.sec05 .ttl_02 .fukidashi {
  margin: 0 0 0;
}


/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec05 .ttl_02 .txt {
    margin: 1rem 0 0;
  }
}




/*--------------------------------------
　sec06
---------------------------------------*/
.sec06 {
	background: #edf3f9;
	padding-bottom: 8rem;
}
.sec06 .box_01 {
	background: #fff;
	margin-top: 10rem;
}
.sec06 .box_01 .upper .wrap_01{
	background: #fff;
	border-radius: 100px;
	position: relative;
	display: flex;
	width: 85%;
	margin: 0 auto;
	top: -4rem;
  border: 2px solid #081e4b;
}
.sec06 .box_01 .upper .wrap_01:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -12px;
  border: 12px solid transparent;
  border-top: 21px solid #fff;
  z-index: 2;
}
.sec06 .box_01 .upper .wrap_01:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 25px solid #081e4b;
  z-index: 1;
}


.sec06 .box_01 .upper .wrap_01 img {
	width: 146px;
	position:absolute;
	top: 50%;
	transform: translate(0,-50%);
	left: -30px;
}
.sec06 .box_01 .upper .wrap_01 .left {
	background: #081e4b;
	font-size: 2.4rem;
	font-weight: bold;
	color: #fff;
	line-height: 94px;
	padding: 0 4rem 0 14rem;
}
.sec06 .box_01 .upper .wrap_01 .right {
	display: flex;
	align-items: center;
	padding: 0 3rem;
}
.sec06 .box_01 .upper .wrap_01 .right .txt_01 {
	font-size: 3.6rem;
	font-weight: bold;
	background: #fadb32;
  padding: 0.8rem 1rem;
}
.sec06 .box_01 .upper .wrap_01 .right .txt_02 {
	font-weight: bold;
	padding-left: 1rem;
	line-height: 1.4;
}
.sec06 .box_01 .upper h3 {
	font-weight: bold;
	font-size: 4rem;
	text-align: center;
}
.sec06 .box_01 .upper .wrap_02 {
	padding: 6rem;
	display: flex;
	justify-content: space-between;
}
.sec06 .box_01 .upper .wrap_02 .left {
	width: 40%;
}
.sec06 .box_01 .upper .wrap_02 .left img {
	width: 295px;
}
.sec06 .box_01 .upper .wrap_02 .left .caption {
	margin: 1rem 0 2rem;
	line-height: 1.3;
	font-size: 1rem;
}
.sec06 .box_01 .upper .wrap_02 .left .price .txt_01{
	background: #c5e1ec;
	font-size: 2.2rem;
	text-align: center;
	font-weight: bold;
	margin: 0;
	
}
.sec06 .box_01 .upper .wrap_02 .left .price .price_inner{
	background: #f7f7f7;
	padding:2rem 3rem 3rem;
}
.sec06 .box_01 .upper .wrap_02 .left .price .price_inner .txt_02{
	font-size: 1.6rem;
	font-weight: bold;
	margin-bottom:1rem;
}
.sec06 .box_01 .upper .wrap_02 .left .price .price_inner .txt_02 span{
	font-size: 2.6rem;
	color: #3ea2bd;
	font-weight: bold;
}
.sec06 .box_01 .upper .wrap_02 .right {
	width: 50%;
}
.sec06 .box_01 .upper .wrap_02 .right .txt_01 {
	font-size: 2.2rem;
	border-top: 1px solid #030142;
	border-bottom: 1px solid #030142;
	text-align: center;
	line-height:3;
	margin-bottom: 2rem;
}
.sec06 .box_01 .on_off li {
	padding: 2rem 0;
}
.sec06 .box_01 .obi {
	background: #081e4b;
	text-align: center;
	font-size: 2.2rem;
	font-weight: bold;
	color: #fff;
	line-height: 2;
	margin-bottom: 2rem;
}
.sec06 .box_01 .wrap_03 {
	padding:0 6rem;
}
.sec06 .box_01 .wrap_03 ul {
	display: flex;
	justify-content: space-between;
	padding:2rem 0 6rem;;
}
.sec06 .box_01 .wrap_03 ul li {
	background: #f7f7f7;
	padding: 4rem 3rem;
	box-sizing: border-box;
	width: 32%;
}
.sec06 .box_01 .wrap_03 ul li .txt_01 {
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0;
	line-height:1.6;
}
.sec06 .box_01 .center {
	padding:6rem 6rem;
	background: url("img/sec06_bg.jpg") center no-repeat;
	background-size: cover;
	margin: 0 3rem;
	border-radius: 15px;
}
.sec06 .box_01 .illust_box {
	margin-top: 6rem;
}
.sec06 .box_01 .under .wrap_01{
	padding:6rem 6rem;
}
.sec06 .box_01 .under .wrap_01 ul{
	display: flex;
	flex-wrap: wrap;
}
.sec06 .box_01 .under .wrap_01 li{
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2;
	padding:0 2rem;
	position: relative;
}
.sec06 .box_01 .under .wrap_01 li::before {
  content: "";
  display: block;
	position: absolute;
  top: 14px;
  left: 0;
	background: #3cb2d2;
  width: 10px;
  height: 10px;
	box-sizing: border-box;
}
.sec06 .box_01 .under .wrap_02{
	padding:0 6rem 6rem;
}
.sec06 .box_01 .under .wrap_02 .seat_wrap{
	background: #edf3f9;
	width: 60%;
	padding: 3rem;
	box-sizing: border-box;
	margin: 0 auto;
}
.sec06 .box_01 .under .wrap_02 .seat_wrap a{
	display: block;
	position: relative;
	background: #00cdb8;
	font-weight: bold;
	font-size: 1.8rem;
	color: #fff;
	text-align: center;
	width: 100%;
	margin-top: 2rem;
	padding: 2rem 0;
}
.sec06 .box_01 .under .wrap_02 .seat_wrap a:after{
	display: block;
	position: absolute;
	content: "";
	background: url("img/mushimegane.png") no-repeat;
	background-size: cover;
	width:30px;
	height: 29px;
	right: 2rem;
	top: 14px;
}
.sec06 .box_01 .under .wrap_03 ul li{
	padding: 0;
	background: none;
	width: 28%;
}
.sec06 .box_01 .upper .wrap_03 .caption {
	margin: 1rem 0 2rem;
	line-height: 1.3;
	font-size: 1rem;
}
.sec06 .box_01 .under .wrap_03 ul li .caption {
	margin: 1rem 0 2rem;
	line-height: 1.3;
	font-size: 1rem;
}
.sec06 .box_01 .under .wrap_04{
	padding:0 6rem 6rem;
}
.sec06 .box_01 .under .wrap_04 ul {
	background: #f7f7f7;
	padding: 3rem 6rem;
	box-sizing: border-box;
}
.sec06 .box_01 .under .wrap_04 ul li {
	line-height: 2;
}


.sec06 .box_01#b .upper .wrap_02 .right .txt_01 {
	 margin-bottom: 4.4rem;
}
.sec06 .box_01#c .upper .wrap_02 .right .txt_01 {
	 margin-bottom: 4rem;
}


/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec06 {
    padding-bottom:4rem;
  }
  .sec06 .box_01 {
    background: #fff;
    margin-top: 5rem;
  }
  .sec06 .box_01 .upper .wrap_01{
    border-radius: 100px;
    position: relative;
    display: block;
    width: 90%;
    margin: 0 auto;
    top: -2rem;
    border: 1px solid #081e4b
  }
  .sec06 .box_01 .upper .wrap_01:before {
    margin-left: -9px;
    border: 9px solid transparent;
    border-top: 14px solid #fff;
  }
  .sec06 .box_01 .upper .wrap_01:after {
    margin-left: -10px;
    border: 10px solid transparent;
    border-top: 16px solid #081e4b;
  }
  
  .sec06 .box_01 .upper .wrap_01 img {
    width: 50px;
    position:absolute;
    top: 50%;
    transform: translate(0,-50%);
    left: 1rem;
  }
  .sec06 .box_01 .upper .wrap_01 .left {
    font-size: 1.4rem;
    line-height: 1;
    padding:0.5rem 1rem;
    position: absolute;
    top: -1rem;
    left: 50%;
    transform: translate(-50%,0);
  }
  .sec06 .box_01 .upper .wrap_01 .right {
    display: flex;
    align-items: center;
    padding: 2rem 2rem 2rem 7rem;
  }
  .sec06 .box_01 .upper .wrap_01 .right .txt_01 {
    font-size: 2rem;
    font-weight: bold;
    background: #fadb32;
    padding: 0.5rem 0.5rem;
  }
  .sec06 .box_01 .upper .wrap_01 .right .txt_02 {
    font-weight: bold;
    padding-left: 1rem;
    line-height: 1.4;
    font-size: 1.1rem;
  }
  .sec06 .box_01 .upper h3 {
    font-weight: bold;
    font-size: 2rem;
    text-align: center;
    margin-bottom: 2rem;
  }
  .sec06 .box_01 .upper .wrap_02 {
    padding: 0 2rem 4rem;
    display: block;
    justify-content: space-between;
  }
  .sec06 .box_01 .upper .wrap_02 .left {
    width: 100%;
  }
  .sec06 .box_01 .upper .wrap_02 .left img {
    width: 100%;
  }
  .sec06 .box_01 .upper .wrap_02 .left .caption {
    margin: 1rem 0 ;
    line-height: 1.3;
  }
  .sec06 .box_01 .upper .wrap_02 .left .price .txt_01{
    font-size:1.4rem;

  }
  .sec06 .box_01 .upper .wrap_02 .left .price .price_inner{
    background: #f7f7f7;
    padding:1rem 2rem 2rem;
  }
  .sec06 .box_01 .upper .wrap_02 .left .price .price_inner .txt_02{
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom:1rem;
  }
  .sec06 .box_01 .upper .wrap_02 .left .price .price_inner .txt_02 span{
    font-size: 2.2rem;
    color: #3ea2bd;
    font-weight: bold;
  }
  .sec06 .box_01 .upper .wrap_02 .right {
    width: 100%;
    padding: 4rem  0 0 0;
  }
  .sec06 .box_01 .upper .wrap_02 .right .txt_01 {
    font-size: 1.8rem;
    border-top: 1px solid #030142;
    border-bottom: 1px solid #030142;
    text-align: center;
    line-height:3;
    margin-bottom: 2rem;
  }
  .sec06 .box_01 .on_off li {
    padding: 2rem 0;
    font-size: 15px;
  }
  .sec06 .box_01 .obi {
    font-size:1.8rem;
    line-height:1.4;
    padding: 0.6rem 0;
    margin-bottom: 2rem;
  }
  .sec06 .box_01 .wrap_03 {
    padding:0 2rem;
  }
  .sec06 .box_01 .wrap_03 ul {
    display: block;
    justify-content: space-between;
    padding:0;
  }
  .sec06 .box_01 .wrap_03 ul li {
    padding: 2rem;
    width: 100%;
  }
  .sec06 .box_01 .wrap_03 ul li:not(:last-child){
      margin-bottom: 2rem;
  }
  .sec06 .box_01 .wrap_03 ul li .txt_01 {
    font-size: 1.8rem;
    font-weight: bold;
    margin: 0;
    line-height:1.6;
  }
  .sec06 .box_01 .center {
    padding:2rem;
    background: url("img/sec06_bg.jpg") center no-repeat;
    background-size: cover;
    margin: 2rem;
  }
  .sec06 .box_01 .illust_box {
    margin-top: 4rem;
  }
  .sec06 .box_01 .under .wrap_01{
    padding:2rem;
  }
  .sec06 .box_01 .under .wrap_01 ul{
    display: flex;
    flex-wrap: wrap;
  }
  .sec06 .box_01 .under .wrap_01 li{
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 2;
    padding:0 2rem 0 1.4rem;
    position: relative;
  }
  .sec06 .box_01 .under .wrap_01 li::before {
    content: "";
    display: block;
    position: absolute;
    top: 10px;
    left: 0;
    background: #3cb2d2;
    width: 8px;
    height: 8px;
    box-sizing: border-box;
  }
  .sec06 .box_01 .under .wrap_02{
    padding:2rem;
  }
  .sec06 .box_01 .under .wrap_02 .seat_wrap{
    width: 100%;
    padding: 2rem;
    box-sizing: border-box;
    margin: 0 auto;
  }
  .sec06 .box_01 .under .wrap_02 .seat_wrap a{
    font-size: 1.4rem;
    color: #fff;
    text-align: center;
    width: 100%;
    margin-top: 1rem;
    padding: 2rem 2rem 2rem 0;
    box-sizing: border-box;
  }
  .sec06 .box_01 .under .wrap_02 .seat_wrap a:after{
    display: block;
    position: absolute;
    content: "";
    background: url("img/mushimegane.png") no-repeat;
    background-size: cover;
    width:15px;
    height: 14px;
    right: 2rem;
    top: 20px;
  }
  .sec06 .box_01 .under .wrap_03 ul li{
    padding: 0;
    background: none;
    width: 100%;
  }
  .sec06 .box_01 .under .wrap_04{
    padding:2rem;
  }
  .sec06 .box_01 .under .wrap_04 ul {
    padding: 2rem;
  }
  .sec06 .box_01 .under .wrap_04 ul li {
    line-height: 2;
  }
	.sec06 .box_01#b .upper .wrap_02 .right .txt_01 {
	 margin-bottom: 2rem;
}
.sec06 .box_01#c .upper .wrap_02 .right .txt_01 {
	 margin-bottom: 2rem;
}
}





/*--------------------------------------
　sec07
---------------------------------------*/
.sec07 .ul_01 {
	display: flex;
	justify-content: space-between;
	margin-top: 5rem;
}
.sec07 .ul_01 > li{
	width: 32%;
	background: #f4f7fc;
	padding:0 3rem 3rem;
	box-sizing: border-box;
}
.sec07 .ul_01 > li:nth-child(odd){
	background: #f7f7f7;
}
.sec07 .ul_01 img {
	display: block;
	width: 45%;
	margin: 0 auto;
	position: relative;
	top: -4rem;
}
.sec07 .ul_01 .txt_01{
  margin: -3rem 0 0;
	font-size: 2.2rem;
	font-weight: bold;
	padding: 2rem 0;
	border-bottom: 1px solid #adbfd2;
	margin-bottom: 2rem;
	position: relative;
	display: block;
}
.sec07 .ul_01 .txt_01:after {
	display: block;
	position: absolute;
	content: "";
	right:1rem;
	top: 50%;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #001c63;
  border-right: 2px solid #001c63;
  transform:translate(0,-50%)rotate(-45deg);
}
.sec07 .ul_01 ul {
	background: #fff;
	padding: 2rem;
	line-height: 1.8;
}
.sec07 .ul_01 ul li:not(:last-child){
	margin-bottom: 1rem;
}
.sec07 .js-accordion-title {
	background: #d0eaeb;
	font-weight: bold;
	font-size: 1.8rem;
	width: 50%;
	text-align: center;
	line-height: 6rem;
	border-radius: 4px;
	margin:8rem auto 0;
}
.sec07 .accordion-content {
	padding-top: 8rem;
}

.sec07 .accordion-content .ul_01 {
	margin: 0 0 5rem;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec07 .ul_01 {
    display: block;
  }
  .sec07 .ul_01 > li{
    width: 100%;
    background: #f4f7fc;
    padding:2rem;
    box-sizing: border-box;
    position: relative;
  }
  .sec07 .ul_01 > li:nth-child(odd){
    background: #f7f7f7;
  }
  .sec07 .ul_01 > li:not(:last-child){
    margin-bottom: 2rem;
  }
  .sec07 .ul_01 img {
    display: block;
    width: 50px;
    margin: 0 auto;
    position: absolute;
    top: 2rem;
    left: 2rem;
  }
  .sec07 .ul_01 .txt_01{
    margin: 0 0 0;
    font-size: 1.8rem;
    font-weight: bold;
    padding: 2rem 0 2rem 6rem;
    border-bottom: 1px solid #adbfd2;
    margin-bottom: 2rem;
    position: relative;
    display: block;
  }
  .sec07 .ul_01 .txt_01:after {
    display: block;
    position: absolute;
    content: "";
    right:1rem;
    top: 50%;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #001c63;
    border-right: 2px solid #001c63;
    transform:translate(0,-50%)rotate(-45deg);
  }
  .sec07 .ul_01 ul {
    background: #fff;
    padding: 2rem;
    line-height: 1.8;
  }
  .sec07 .ul_01 ul li:not(:last-child){
    margin-bottom: 1rem;
  }
  .sec07 .js-accordion-title {
    background: #d0eaeb;
    font-weight: bold;
    font-size: 1.8rem;
    width:100%;
    text-align: center;
    line-height: 6rem;
    border-radius: 4px;
    margin:4rem auto 0;
  }
  .sec07 .accordion-content {
    padding-top: 4rem;
  }
}





/*--------------------------------------
　sec08
---------------------------------------*/
.sec08 .wrap_01 {
	display: flex;
	justify-content: space-between;
}
.sec08 .wrap_01 a {
	display: block;
	width: 48%;
	background:#407CB3;
	padding:6rem;
	box-sizing: border-box;
	color: #fff;
	margin-bottom: 4rem;
}
.sec08 .wrap_01 a:nth-child(2) {
	position: relative;
	top: 6rem;
}
.sec08 .wrap_01 a .txt_01 {
	position: relative;
	font-weight: bold;
	font-size: 2.2rem;
	text-align: center;
	margin-bottom: 3rem;
	color: #fff;
}
.sec08 .wrap_01 a .txt_01:after {
	display: block;
	position: absolute;
	content: "";
	right:1rem;
	top: 50%;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
  transform:translate(0,-50%)rotate(-45deg);
}

.sec.sec08 {
	padding: 10rem 0 6rem;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec08 .wrap_01 {
    display: block;
  }
  .sec08 .wrap_01 a {
    display: block;
    width: 100%;
    padding:2rem;
    box-sizing: border-box;

  }
  .sec08 .wrap_01 a:nth-child(2) {
    position: relative;
    top: 0;
    margin-top: 2rem;
  }
  .sec08 .wrap_01 a .txt_01 {
    position: relative;
    font-weight: bold;
    font-size: 1.8rem;
    text-align: center;
    margin-bottom: 2rem;
    color: #fff;
  }
  .sec08 .wrap_01 a .txt_01:after {
    display: block;
    position: absolute;
    content: "";
    right:1rem;
    top: 50%;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
    transform:translate(0,-50%)rotate(-45deg);
  }
	.sec.sec08 {
    padding: 6rem 0 2rem;
}
}





/*--------------------------------------
　sec09
---------------------------------------*/
.sec09 ul {
	background: #f7f7f7;
	padding: 6rem 0;
}
.sec09 ul li{
	width: 85%;
	display: flex;
	margin: 0 auto;
}
.sec09 ul li:nth-child(even){
	/* padding-left: 10%; */
}
.sec09 ul li .number{
	width: 15%;
	font-size: 4rem;
	text-align: center;
}
.sec09 ul li .number span{
	font-weight: bold;
	padding: 0 1rem;
	background:linear-gradient(transparent 60%, #b7eae3 60%);
}
.sec09 ul li .right{
	width: 80%;
}
.sec09 ul li .right .txt_01{
	font-weight: bold;
	font-size: 2.6rem;
	position: relative;
	display: block;
	margin: 2rem 0 0 0;
}
.sec09 ul li .right .txt_01:after {
	display: block;
	position: absolute;
	content: "";
	right:1rem;
	top: 50%;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #081e4b;
  border-right: 2px solid #081e4b;
  transform:translate(0,-50%)rotate(-45deg);
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .sec09 ul {
    padding: 4rem 0;
  }
  .sec09 ul li{
    width: 100%;
    display: flex;
    align-items: flex-start;
    display: block;
  }
  .sec09 ul li:nth-child(even){
    padding: 0;
    flex-direction: row-reverse;
  }
  .sec09 ul li .number{
    width: 35%;
    padding: 1.5rem 0rem 1.5rem 0;
    box-sizing: border-box;
    font-size: 3.5rem;
    text-align: center;
  }
  .sec09 ul li:nth-child(even) .number{
    padding: 1.5rem 0 1.5rem 0rem;
  }
  .sec09 ul li .number span{
    font-weight: bold;
    padding: 0 1rem;
    background:linear-gradient(transparent 60%, #b7eae3 60%);
  }
  .sec09 ul li .right{
    width: 100%;
    padding: 0 2rem 0 2rem;
    margin: 0 0 0 0rem;
    box-sizing: border-box;
  }
  .sec09 ul li:nth-child(even) .right{
    padding: 0 2rem 0 2rem;
    margin: 0 0rem 0 0;
  }

  .sec09 ul li .right .txt_01{
    font-weight: bold;
    font-size: 1.8rem;
    position: relative;
    display: block;
    margin: 1rem 0 0 0;
    line-height: 1.4;
    padding-right: 2rem;
  }
  .sec09 ul li .right .txt_01:after {
    display: block;
    position: absolute;
    content: "";
    right:1rem;
    top: 50%;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #081e4b;
    border-right: 2px solid #081e4b;
    transform:translate(0,-50%)rotate(-45deg);
  }
}






/*--------------------------------------
　modal
---------------------------------------*/
.modal {
	display: none;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
}
.modal__bg {
	background: rgba(0,0,0,0.8);
	height: 100vh;
	position: absolute;
	width: 100%;
  z-index: 1;
}
.modal__content {
	background: #fff;
	left: 50%;
	padding: 40px;
	position: absolute;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 60%;
	z-index: 1;
}

.modal .close {
	position: absolute;
	top: -40px;
	right: -40px;
	display: inline-block;
	margin: 0;
	padding: 0;
	cursor: pointer;
}
.modal .close:before,
.modal .close:after {
	content: "";
	position: absolute;
	top: 1rem;
	right: 2rem;
	display: inline-block;
	width: 2px;
	height: 30px;
	background: #fff;
	border: 0;
	margin: 0;
	padding: 0;
	cursor: pointer;
}
.modal .close:before {
	transform: rotate(45deg);
}
.modal .close:after {
	transform: rotate(-45deg);
}

#a .modal__content {
	/* width: 382px; */
	height: auto;
	padding: 20px;
}
#b .modal__content {
	width: 800px;
	height: auto;
	padding: 40px;
}
#c .modal__content {
	width: 800px;
	height: auto;
	padding: 40px;
}

.modal .close3:before,
.modal .close3:after {
	content: "";
	position: absolute;
	top: 1rem;
	right: 2rem;
	display: inline-block;
	width: 2px;
	height: 30px;
	background: #fff;
	border: 0;
	margin: 0;
	padding: 0;
	cursor: pointer;
}
.modal .close3:before {
	transform: rotate(45deg);
}
.modal .close3:after {
	transform: rotate(-45deg);
}

body.no_scroll{
   overflow: hidden;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
  .modal__content {
    padding: 10px;
    width: 85%;
  }

  .modal .close {
    top: -45px;
    right: -5px;
  }

	.sec07 .accordion-content .ul_01 {
    margin: 0 0 2rem;
}

	#a .modal__content {
	width: 85%;
	height: auto;
	padding: 10px;
}
#b .modal__content {
	width: 85%;
	height: auto;
	padding: 10px;
}
#c .modal__content {
	width: 85%;
	height: auto;
	padding: 10px;
}

	.modal .close3:before {
	transform: rotate(45deg);
	top: -3rem;
}
.modal .close3:after {
	transform: rotate(-45deg);
	top: -3rem;
}
}


.sec01 .ttl_01 .fukidashi {
	animation: yurayura 2s linear infinite;
}
.sec02 .ttl_02 .fukidashi {
	animation: yurayura 2s linear infinite;
}
.sec03 .ttl_02 .fukidashi {
	animation: yurayura 2s linear infinite;
}
.sec04 .ttl_02 .fukidashi {
	animation: yurayura 2s linear infinite;
}
.sec05 .ttl_02 .fukidashi {
	animation: yurayura 2s linear infinite;
}
.sec06 .ttl_01 .fukidashi {
	animation: yurayura 2s linear infinite;
}

@media screen and (max-width: 768px) {
.sec01 .ttl_01 .fukidashi {
	
}
.sec02 .ttl_02 .fukidashi {
	margin: 2rem 0 3rem;
}
.sec03 .ttl_02 .fukidashi {
	
}
.sec04 .ttl_02 .fukidashi {
	margin: 2rem 0 3rem;
}
.sec05 .ttl_02 .fukidashi {
	margin: 0 0 3rem;
}
.sec06 .ttl_01 .fukidashi {
	
}

.sec.sec05 .inner {
	padding: 3rem 1.4rem 0;
}
.sec.sec05 {
	padding: 4rem 0 6rem;
}
	
}



@keyframes yurayura {
  0% , 100%{
      transform: translate(0,10px);
  }
  50%{
      transform: translate(0,-10px);
  }
}