@charset "utf-8";
body{
overflow: hidden;
font-family: ryo-gothic-plusn, sans-serif;
}
.inner {
  width: 1245px;
  margin: 0 auto;
  font-feature-settings: "palt";
  letter-spacing: 2px;
	padding: 0 40px;
}

.flex {
  display: flex;
  justify-content: center;
}

.pc_only {
  display: block !important;
}

.sp_only {
  display: none !important;
}
.min{
	font-family: source-han-serif-japanese, serif;
}
.go{
	font-family: ryo-gothic-plusn, sans-serif;
}
.col{
color: #252525!important;
}
.red {
  color: #da0024!important;
}
.wh {
  color: #FFF!important;
}
.yel{
  color: #ffdf00!important;
}
.bl{
  color: #001f76!important;
}
.grn {
  color: #00aa40!important;
}
.org{
  color: #f98101!important;
}

.bl-l{
  color: #00a0e1!important;
}
.bk{
  color: #000!important;
}
.nv{
  color: #002967!important;
}
.bg-bl{
background: #001f76;
}
.bg-lbl{
background: #ecf4fc;
}
.bg-lbl2{
background: #dfe9f3;
}
.bg-yel{
background: #fdff69;
}
.bg-dgry{
	background: #646464;
}
.bg-gry{
	background: #f4f6f7;
}
.bg-lgry{
	background: #646464;
}
.bg-grnl{
	background: #eeffef;
}
.bg-grn{
	background: #00a417;
}
.bd-bl2{
	border-bottom: 2px solid #00317a;
}
.bg-wh{
	background: #fff;
}

.btn01 {
  color: #04003f;
  margin-bottom: 20px;
	animation-name: dokidoki;
    /* アニメーション名の指定 */
    animation-delay: 0s;
    /* アニメーションの開始時間指定 */
    animation-duration: 2s;
    /* アニメーション動作時間の指定 */
    animation-timing-function: ease-in-out;
    /* アニメーションの動き（徐々に早く徐々に遅く）*/
    animation-iteration-count: infinite;
    /* アニメーションをループさせる */
    display: block;
	overflow: hidden;
	text-align: center;
	font-size: 50px;
	padding: 10px 0;
	font-weight: 800;
}
.btn01 img{
  width: 100%;
}
.btn01 a {
 display: block;
}
.btn01 a::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -200px;
  left: 0;
  width: 60px;
  height: 100%;
  background-color: #fff;
  animation: shiny-btn1 3s ease-in-out infinite;
}
.btn01 a::after {
  font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f101";
    padding-left: 5px;
	position: absolute;
	right:30px;
}
.btn01.btn-col1{
background: linear-gradient(0deg, rgba(250,129,0,1) 50%, rgba(250,148,38,1) 50%);
	margin-bottom: 40px;
}
.btn01.btn-col2{
	 animation-duration: 2.5s;
	background: linear-gradient(0deg, rgba(250,183,38,1) 50%, rgba(250,208,38,1) 50%);
}
.btn01.btn-col2 a{
	color: #212121;
}
.btn01.btn-col2 a::before {
  animation: shiny-btn1 3.5s ease-in-out infinite;
}
.line-yel {
    background: linear-gradient(transparent 60%, #fcf300 0%);
	
}
.line-red {
    background: linear-gradient(transparent 96%, #fe2c55 0%);
	padding-bottom: 5px;
	
}



header{
background: rgb(255,255,255);
background: linear-gradient(145deg, rgba(255,255,255,1) 0%, rgba(223,233,243,1) 100%);
margin-bottom: 60px;
}
header h1{
  color: #001f76;
font-size:40px;
padding: 20px 0;
font-feature-settings: "palt";
  letter-spacing: 2px;
}
header h1 span{
  display: block;
color: #FFF;
font-size: 44px;
font-weight:500;
letter-spacing: 2px;
}
header h2{
font-size: 36px;
	color: #fff;
	background: #46b1d3;
}
header h2 span{
font-size: 60px;
}


main section{
	padding-bottom: 100px;
}
main h3{
	font-size: 43px;
	font-style: italic;
	font-weight: bold;
	text-align: center;
	color: #fff;
	padding:20px 0;
}
main p{
	font-size: 22px;
	margin-top: 40px;
	padding-left: 20px;
	font-weight: normal;
}
main p span{
	font-weight: 700;
}
main h4{
	margin-top: 40px;
	font-size: 36px;
	font-style: italic;
	border-left: 8px solid #001f76;
	padding-left: 20px;
	background: #fff;
	font-weight:600;
}
main .seen-li{
	margin-top: 40px;
}
main .seen-li li{
	background:#fff url("../img/bg-seen-ph01.jpg") no-repeat top right; 
	min-height: 370px;
	border: solid 1px #002395;
	font-size: 22px;
	padding-top: 30px;
	padding-left: 20px;
	color: #001f76;
	margin-bottom: 30px;
}
main .seen-li li:nth-child(2){
	background:#fff url("../img/bg-seen-ph02.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li:nth-child(3){
	background:#fff url("../img/bg-seen-ph03.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li:nth-child(4){
	background:#fff url("../img/bg-seen-ph04.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li:nth-child(5){
	background:#fff url("../img/bg-seen-ph05.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li:nth-child(6){
	background:#fff url("../img/bg-seen-ph06.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li:nth-child(7){
	background:#fff url("../img/bg-seen-ph07.jpg") no-repeat top right; 
	min-height: 320px;
}
main .seen-li li .icon{
	background: #002395;
	display: inline-block;
	border-radius: 100px;
	color: #fff;
	font-size: 24px;
	padding: 0 20px;
	margin-bottom: 10px;
}
main .seen-li li .txt{
	display: block;
	max-width: 70%;
	line-height: 2;
	padding-left: 20px;
}
main .point{
	padding-top: 100px;
}
main .point li:nth-child(1){
	margin-right: -50px;
	position: relative;
	z-index: 9;
}
main .point li:nth-child(2){
	background: #f6fbfe;
	border: solid 1px #46b1d3;
	border-radius: 100px;
	box-shadow: 4px 6px 0px -2px #46b1d3;
	white-space: inherit;
overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 60px;
	font-size: 22px;
}
main .ttl-i::after{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f4ad";
color: #FFF;
	padding-left: 10px;
}

main .voice{
	margin-top: 60px;
}
main .voice dl{
	background: #e7e7e7;
	box-shadow: 4px 6px 0px 2px #d2d2d2; 
	padding: 20px 40px;
	align-items: center;
	margin-top: 40px;
}
main .voice dl dt{
	margin-right: 40px;
}
main .voice dl dt span{
	font-size: 16px;
	margin-top: 5px;
	display: block;
	text-align: center;
}
main .voice dl dd{
	font-size: 20px;
	
}
main .voice dl .vo-ttl{
	font-size: 26px;
	margin-bottom: 20px;
	border-bottom: solid 2px #252525;
	display: block;
	padding: 0 10px 5px;
}
main .sec-con{
	padding-top: 100px;
}
main .sec-con h3{
	font-style: normal;
}
main .sec-con p.txt{
	margin-top: 0;
	margin-bottom: 60px;
}
main .sec-con .box{
	background: #FFF;
	box-shadow: 4px 6px 0px 2px #d0e4ec; 
	padding:40px;
	margin-bottom: 40px;
}
main .sec-con .box h5{
	font-size: 30px;
	color: #00a0e1;
	border-top: solid 2px #00a0e1; 
	border-bottom: solid 2px #00a0e1; 
	padding: 10px 0;
	text-align: center;
	font-weight: 700;
	font-style: italic;
	margin-bottom: 20px;
}
main .sec-con .box .co-ttl{
	background:#00a0e1;
	color: #fff;
	font-size: 26px;
	padding:0 20px;
	display: inline-block;
	margin-top: 20px;
	border-radius: 100px;
}
.bg-arrow {
    position: relative;
    margin: 0 0 160px;
    padding: 40px 10px;
}
.bg-arrow .inner {
    position: relative;
    z-index: 2;
    min-height: 500px;
}
.bg-arrow:after {
    content: "";
    position: absolute;
    display: block;
    left: 0;
    border-style: solid;
}
.bg-arrow:after {
    bottom: 0;
    margin-bottom: -5vw;
    border-color: #ecf4fc transparent transparent;
    border-width: 5vw 50vw 0;
}

main .bene .sec-bloc{
	border: solid 1px #fcb316;
	box-shadow: 4px 6px 0px 2px #fcb316; 
	position: relative;
	padding: 80px 40px;
}
main .bene .sec-bloc .bene-ttl{
	position: absolute;
    top: -55px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
main .bene .bene-subttl{
	margin-bottom: 80px;
	font-size: 30px;
    font-weight: 600;
}
main .bene li{
	position: relative;
	background: #fcf8d9;
	font-size: 30px;
	padding: 20px 20px 20px 80px;
	margin-left: 50px;
	margin-bottom: 40px;
}
main .bene li:last-child{
	margin-bottom: 0;
}
main .bene li::before{
	content: "";
	background:url("../img/bene-i01.png") no-repeat top left; 
	width: 105px;
	height: 105px;
	display: inline-block;
	position: absolute;
    top: 50%;
    left:  -50px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
main .bene li:nth-child(1)::before{
	background:url("../img/bene-i01.png") no-repeat top left; 
}
main .bene li:nth-child(2)::before{
	background:url("../img/bene-i02.png") no-repeat top left; 
}
main .bene li:nth-child(3)::before{
	background:url("../img/bene-i03.png") no-repeat top left; 
}
main .bene li:nth-child(4)::before{
	background:url("../img/bene-i04.png") no-repeat top left; 
}
main .bene li:nth-child(5)::before{
	background:url("../img/bene-i05.png") no-repeat top left; 
}
main .bene li:nth-child(6)::before{
	background:url("../img/bene-i06.png") no-repeat top left; 
}
main .bene li:nth-child(7)::before{
	background:url("../img/bene-i07.png") no-repeat top left; 
}
main .bene2{
	margin-top: 100px;
}
main .bene2 .sec-bloc{
	border: solid 1px #fc7d16;
	box-shadow: 4px 6px 0px 2px #fc7d16; 
}
main .bene2 li{
	background: #fcedd9;
}
main .bene2 li::before{
	width: 125px;
	height: 125px;
	top: 40%;
}
main .bene2 li:nth-child(1)::before{
	background:url("../img/bene-i01-1.png") no-repeat top left; 
}
main .bene2 li:nth-child(2)::before{
	background:url("../img/bene-i01-2.png") no-repeat top left; 
}
main .arrow-b {
    transform: translate(-30%, -30%);
    font-size: 6rem;
    animation: updown 2s infinite ease-in-out;
    margin-top: 5px;
}
main .arrow-b::before{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f13a";
  font-size: 80px;
}
@keyframes updown {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -30px);
  }
  100% {
    transform: translate(0, 0);
  }
}
main .cta {
	background: #f8fafc;
}
main .cta h2 {
    font-size: 36px;
    color: #fff;
    background: #46b1d3;
}
main .cta h2 span {
    font-size: 60px;
}

main .cta .time{
	text-align: center;
	margin-top: 30px;
}
main .cta .time span{
	background: #dfe9f3;
	border-radius: 100px;
	padding: 0 30px;
	display: inline-block;
	text-align: center;
	font-size:34px;
	font-weight: 700;
}
main .cta .price{
font-size:34px;
	font-weight: 700;
	padding: 30px 0 ;	
}
main .cta .price2{
font-size:60px;
	font-weight: 700;
	margin-top: 20px;
	margin-bottom: 40px;
}
main .cta .price2 strong{
font-size:60px;
	font-weight: 700;
	padding-right: 10px;
}
main .cta .btn li{
	position: relative;
	font-size:28px;
	font-weight: 700;
	width: 60%;
	margin: 0 auto;
	text-align: center;
}
main .cta .btn li:first-child{
	margin-bottom: 20px;
}
main .cta .btn li a{
	color: #252525;
	padding: 10px 0;
	display: block;
	border-radius: 100px;
	margin: 10px auto;

}
main .cta .btn li:nth-child(1) a{
	background: #ffca2a;
	box-shadow: 2px 4px 0px 0px #b9a400; 
}

main .cta .btn li:nth-child(2) a{
	background: #ff9f57;
	box-shadow: 2px 4px 0px 0px #af6400; 
}
main .cta .btn li:nth-child(1) a{
	display: block;
	overflow: hidden;
	animation-name: dokidoki;
    /* アニメーション名の指定 */
    animation-delay: 0s;
    /* アニメーションの開始時間指定 */
    animation-duration: 2s;
    /* アニメーション動作時間の指定 */
    animation-timing-function: ease-in-out;
    /* アニメーションの動き（徐々に早く徐々に遅く）*/
    animation-iteration-count: infinite;
    /* アニメーションをループさせる */
}
main .cta .btn li:nth-child(2) a{
	display: block;
	overflow: hidden;
	animation-name: dokidoki;
    /* アニメーション名の指定 */
    animation-delay: 0s;
    /* アニメーションの開始時間指定 */
    animation-duration: 3s;
    /* アニメーション動作時間の指定 */
    animation-timing-function: ease-in-out;
    /* アニメーションの動き（徐々に早く徐々に遅く）*/
    animation-iteration-count: infinite;
    /* アニメーションをループさせる */
}
main .cta .btn a::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -100px;
  left: 0;
  width: 60px;
  height: 100%;
  background-color: #fff;
  animation: shiny-btn1 3s ease-in-out infinite;
	border-radius: 100px;
}

main .cta .btn li a::after{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f054";
	padding-right: 10px;
	position: absolute;
	right:20px;
	top:10px;
}


main .cta .btn li a:hover{
	opacity: 1;
    margin-left:5px;
    margin-top:5px;
    box-shadow:none;
}
main .cta .btn li:nth-child(1) a:hover{
    background:#ffca2a;
}
@-webkit-keyframes shiny-btn1{
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

@keyframes dokidoki {
  0% {
    transform: scale(1);
  }
  40% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  60% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
  }
}
main .cta .price2 small{
font-size:24px;
	font-weight: 700;
}
main .cta .note{
	background: #fff;
	border: solid 1px #46b1d3;
	padding: 30px;
	width: 80%;
	margin: 60px auto 0;
}
main .cta .no-ttl{
color:#001f76;
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 10px;
}
main .cta .no-li li{
	list-style: disc;
	margin-left: 1em;
}

main .cta .no-ttl::before,
main .cta .no-ttl::after{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f111";
	font-size: 10px;
	vertical-align: middle;
}

main #intro{
	background: #dfe9f3;
	padding: 60px 0;
}
main #intro .bg-wh{
	padding:0 0 60px;
}
main #intro h3{
	border-bottom: solid 4px #001f76;
	margin-bottom: 40px;
}
main #intro .flex{
	padding:  0 20px;
	padding-bottom: 60px;
	border-bottom: dashed 1px #001f76;
	width: 93%;
    margin: 0 auto 60px;
}
main #intro .ttl{
	margin-top: 40px;
    font-size: 36px;
    font-style: italic;
    border-left: 8px solid #001f76;
    padding-left: 20px;
	font-weight: 700;
}
main #intro p {
    font-size: 18px;
}
main #intro .ttl small{
	font-size: 22px;
	padding-left: 10px;
}
main #intro .come{
	padding:  0 40px;
}
main #intro .ttl2{
	margin-left: 20px;
}
main #intro .come .come-txt{
font-family: dnp-shuei-4go-std, sans-serif;
font-weight: 500;
font-style: normal;
background-image:
    linear-gradient(
      90deg,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,0) 50%,
      #ffff 50%,
      #ffff 50%
    ),
    linear-gradient(
      180deg,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,0) 97%,
      #e4e4e4 97%,
      #e4e4e4 100%
    );
  background-size:
    8px 100%,
    100% 2em;
  line-height:2;
}

/* メモ　クリップ　Ａ */
main #intro .come{
 position: relative;
 margin: 2em auto;
 padding: 15px 35px 50px 25px;
 width: 80%; /* ボックス幅 */
 background-color: #fff; /* ボックス背景色 */
 color: #555555; /* 文章色 */
 border: 1px solid #ccc; /* 枠線 */
 box-shadow: 1px 1px 1px #acacac; /* 影の色 */
}
main #intro .come::before {
 position: absolute;
 content: '';
 top: -15px;
 right: 10px;
 height: 55px;
 width: 15px;
 border: 3px solid #555555; /*クリップ色 */
 background-color: none;
 border-radius: 12px;
 box-shadow: 1px 1px 2px #999;
 transform: rotate(10deg);
 z-index: 1;
}
main #intro .come::after {
 position: absolute;
 content: '';
 top: 0px;
 width: 10px; 
 right: 20px;
 border: solid 5px #fff; /*背景色と同じ色にする*/
 z-index: 2;
}

main .check-1,
main .check-2{
	font-style: italic;
}
main .check-1::before{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f058";
color: #00aa40;
	padding-right: 10px;
}

main .check-2::before{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f14a";
color: #f42c64;
	padding-right: 10px;
}
main .arrow{
    transform: translate(-30%, -30%);
    font-size: 6rem;
    animation: updown 2s infinite ease-in-out;
    margin-top: 5px;
}
main .arrow::before{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f058";
  font-size: 100px;
}
@keyframes updown {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -30px);
  }
  100% {
    transform: translate(0, 0);
  }
}

.box .read_text{
	margin-top: 20px;
	margin-bottom: 20px;
}
.box .more-btn{
	margin-bottom: 40px;
	text-align: center;
}
.box a.v-btn {
	margin: 0 auto;
    display: inline-block;
    padding:10px 0;
    color: #252525;
    text-align: center;
    text-decoration: none;
    background: #e7e7e7;
	width: 100%;
}
.box a.v-btn::after{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f107";
color: #252525;
	padding-left: 10px;
}
.box a.v-btn_close {
	margin: 0 auto;
    display: block;
    padding: 4px 0 7px;
    color: #00a0e1;
    padding:10px 0;
	background: #d0e4ec;
    text-align: center;
    text-decoration: none;
}
.box a.v-btn_close::after{
	font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f106";
color: #00a0e1;
	padding-left: 10px;
}
.box a.v-btn_close span{
    color: #0085bc;
}
.box .read_text{
	
}
.txt .open{
	position: relative;
}
main section#faq {
    padding-bottom: 0;
}
/*accordion*/
#accordion{
	margin-top: 100px;
}
.accordionBlock {
  position: relative;
  width: 100%;
  border-top: none;
  outline: 0;
  cursor: pointer;
}

.accordionBlock .accordionTtl {
  display: flex;
  position: relative;
  padding: 10px 75px 10px 30px;
  font-size: 22px;
  font-weight: 700;
  background: #e3e3e3;
	border-bottom: solid 1px #c6c6c6;
  cursor: pointer;
	line-height:1.5;
	align-items: center;
}
.answer  .accordionTtl-sub,
.accordionTtl .accordionTtl-sub{
	font-size: 30px;
	margin-right: 10px;
	color: #001f76;
}
.answer  .accordionTtl-sub{
	color: #00a0e1;
	font-weight: 800;
}
/*.accordionBlock .accordionTtl:hover,
.accordionBlock .accordionTtl:active,
.accordionBlock .content-entry.open .accordionTtl {
	background: #0f2f56;
}*/
.answer{
	display: flex;
    align-items: center;
}
.answer .accordionTtl-sub,
.answer p{

}
.answer p{
	margin-top: 0;
	padding-left: 0;
}

.answer .txt-in{
	display: block;
	text-indent: 6em;
}
.answer small{
	text-align: right;
	display: block;
	font-size: 16px;
	margin-right: 40px;
}
.accordionTtl{
  position: relative;
}
.accordionTtl::before {
  content: "";
  position: absolute;
  top: 35%;
  right: 25px;
  display: block;
    width: 15px;
    height: 15px;
    border-top: solid 3px #001f76;
    border-right: solid 3px #001f76;
  /*横線に*/
  -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
  transition: all .2s ease-in-out;
}
/*.accordionTtl::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 25px;
  縦線
  width: 40px;
  height: 6px;
  background: #0063d3;
  transition: all .2s ease-in-out;
}*/
.accordionTtl.open::before{
top: 50%;
}
.accordionTtl.open::before {
 transform: rotate(-45deg);
}
.accordionTtl.open:after {
   opacity: 0;
}

.accordionCont{
  display: none;
padding: 10px 15px 10px 30px;
	line-height: 2;
	background: #f0f0f0;
	font-size: 20px;
	border-bottom: solid 1px #c6c6c6;
}

/* CSS for CodePen */
.accordionBlock {
  margin: 0 auto ;
}


footer {
  position: relative;
  background: #001f76;
  padding:20px 0;
}

footer .flex {
  justify-content: end;
	flex-wrap: wrap;
}

footer li a:link {
  color: #fff;
	display: inline-block;
	font-size: 12px;
	line-height: 1.5;
}

footer li {
  margin-right: 20px;
}
footer li:first-child {
  border-right: solid 1px #fff;
padding-right: 20px;
}



/*リンクの形状*/

#page-top a {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #00317a;
  border-radius: 100px;
  width: 60px;
  height: 60px;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  font-size: 4rem;
  transition: all 0.3s;
  z-index: 9999;
}

#page-top a::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f106";
}


/*リンクを右下に固定*/

#page-top {
  position: fixed;
  right: 10px;
  z-index: 2;
  bottom: 20px;
  /*はじめは非表示*/
  opacity: 0;
  transform: translateY(100px);
}

/*　上に上がる動き　*/

#page-top.UpMove {
  animation: UpAnime 0.5s forwards;
}


.btn-cp {
  position: fixed;
  left: 0px;
  bottom: 40%;
  z-index: 999;
  width: 150px;
font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;	

}

.btn-cp a {
  background-image: radial-gradient(circle, rgba(58, 99, 255, 1), rgba(42, 179, 252, 1) 90%);
  display: block;
  color: #fff;
  width: 20%;
  /* margin-right: -6%; */
  padding: 30px 30px 30px 20px;
  border-radius: 0 30px 30px 0;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 2px;
}

.btn-cp:hover {
  left: -10px;
  transition: all 0.5s ease;
}

.btn-cp a::after {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f06b";
  padding-top: 3px;
}



@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/*　下に下がる動き　*/

#page-top.DownMove {
  animation: DownAnime 0.5s forwards;
}


@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 1;
    transform: translateY(100px);
  }
}



@media screen and (max-width: 1200px) {
  .inner {
    width: 98%;
    margin: 0 auto;

  }
}

@media screen and (max-width: 1100px) {
  .pc_only {
    display: none !important;
  }
  .sp_only {
    display: block !important;
  }
  body {
    position: relative;
  }
  img {
    max-width: 100%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    vertical-align: top;
    width: auto;
  }
  .inner {
    width: 95%;
    margin: 0 auto;
	padding: 0; 
  }
.mv-txt {
    margin-top: 0;
    margin-left: auto;
}
.mv-txt img{
   width: 100%;
}	
 
}

@media screen and (max-width: 678px) {
	.flex {
    flex-wrap: wrap;
}
	.inner{
		padding: 0;
	}
	header{
		margin-bottom:20px;
	}
	header h1{
	font-size: 18px;
	padding: 10px 0;
	}
	header h2{
	font-size: 18px;
	}
	header h2 span {
    font-size: 22px;
}
	header .mv-txt{
	margin-top:0;
    margin-left: 0;	
	}
	main h3{
	font-size: 18px;
	padding:10px 0;
	}
	main h4{
	margin-top: 20px;
    font-size: 18px;
	border-left: 4px solid #001f76;
    padding-left:10px;
	}
	main p {
    font-size: 16px;
    margin-top: 20px;
    padding-left: 0;
    font-weight: normal;
}
	main section {
    padding-bottom: 30px;
}
	
	main .seen-li li{
    font-size: 16px;
		padding:20px 20px 10px;
background-color:rgba(255,255,255,0.8);
background-blend-mode:lighten;
min-height: auto;
}
	main .seen-li li .icon{
    font-size: 16px;
	}
	main .seen-li li:nth-child(2){
	background-color:rgba(255,255,255,0.8);
	min-height: auto;
	}
	main .seen-li li:nth-child(3){
	background-color:rgba(255,255,255,0.8);	
	min-height: auto;
	}
	main .seen-li li:nth-child(4){
	background-color:rgba(255,255,255,0.8);	
	min-height: auto;
	}
	main .seen-li li:nth-child(5){
	background-color:rgba(255,255,255,0.8);	
	min-height: auto;
	}
	main .seen-li li:nth-child(6){
	background-color:rgba(255,255,255,0.8);	
	min-height: auto;
	}
	main .seen-li li:nth-child(7){
	background-color:rgba(255,255,255,0.8);	
	min-height: auto;
	}
	main .seen-li li .txt{
	max-width: 100%;
	padding-left:0;
	text-shadow:0 0 3px #fff;
	line-height: 1.8;
	}
	main .point img{
		display: none;
	}
	main .point {
    padding-top: 40px;
}
	main .point li:nth-child(2){
	border-radius:10px;	
		padding: 10px ;
		font-size: 16px;
		white-space: revert;
    overflow: auto;
    display: block;
	}
	main .voice dl{
	padding: 20px;
	box-shadow: 4px 4px 0px 2px #d2d2d2;
	}
	main .voice dl dt{
		text-align: center;
		margin:0 auto 20px;
		width: 60%;
	}
	main .voice dl dt span{
	font-size: 14px;	
	}
	main .voice dl .vo-ttl{
	font-size: 18px;
	border-bottom:solid 1px #252525;
	padding: 0 0 5px;
		margin-bottom: 10px;
	}
	main .voice dl dd{
	font-size: 16px;	
	}
	main .sec-con {
    padding-top: 0;
}
	main .sec-con p.txt{
	margin-bottom:20px;	
	}
	main .sec-con .box{
		padding: 20px;
	}
	main .sec-con .box h5{
	font-size: 18px;
	margin-bottom:0;
	}
	main .sec-con .box .co-ttl{
	margin-top: 20px;	
	font-size: 16px;
	}
	.box .more-btn{
	margin-bottom:0;
	}
	.bg-arrow{
	margin: 0 0 60px;	
	}
	main .bene .bene-subttl{
	font-size: 18px;	
	}
	main .bene .sec-bloc .bene-ttl{
	width:100%;
	}
	main .bene .sec-bloc{
	padding: 40px 20px;	
	}
	main .bene li{
	font-size: 16px;
	display: flex;
	margin-left:0;
	padding:30px 10px 10px;
}
	main .bene li::before{
	background-size: 80% !important;	
	width: 20%;
    left: 0;
    right: 0;
	top:30px;
    margin: auto;
	background-position: center top !important;
	}
main .bene2 {
    margin-top: 40px;
}
	main .bene2 li::before{
	width: 23%;	
	}
	#accordion {
    margin-top: 40px;
}
	.accordionBlock .accordionTtl{
	font-size: 16px;
	padding: 10px 55px 10px 15px;
	}
	
	.accordionCont{
	font-size: 18px;
	padding: 10px 10px 10px 15px;
	}
	.accordionTtl.open::before {
    top: 40%;
}
	main .cta h2{
	font-size: 18px;
	}
	main .cta h2 span {
    font-size: 22px;
}
	main .cta .mv-txt {
    margin-top: 0;
    margin-bottom: 30px;
}
	main .cta .time span{
	font-size: 18px;
	padding: 0 10px
	}
	main .cta .price {
    font-size: 18px;
    padding: 15px 0;
}
	main .arrow-b::before{
	font-size: 40px;	
	}
	main .cta .price2{
	font-size: 40px;
    margin-top: 0px;
    margin-bottom: 20px;
	}
	main .cta .price2 strong{
	font-size: 30px;
	display: block;
	padding-right: 0;
	}
	main .cta .btn li{
		width: 100%;
		font-size: 18px;
	}
	main .cta .note{
	padding: 10px 20px;
    width: 80%;
    margin: 30px auto 0;	
	}
	main .cta .no-ttl{
		font-size: 16px;
		margin-bottom: 5px;
	}
	main .cta .no-li li{
		font-size: 14px;
	}
	main #intro h3{
	border-bottom:solid 2px #001f76;	
	    margin-bottom: 0;
	}
	main #intro .flex{
		padding: 0 0 20px;
		margin: 0 auto 40px;
	}
	main #intro .ph{
		width: 60%;
		margin: 0 auto;
	}
	main #intro .ttl{
		margin-top: 15px;
		font-size: 20px;
    border-left: 4px solid #001f76;
    padding-left: 10px;
	}
	main #intro .ttl small {
    font-size: 16px;
    padding-left: 10px;
}
	main #intro p {
    font-size: 14px;
}
	main #intro .bg-wh {
    padding: 0 0 10px;
}
	footer li a:link{
	    font-size: 10px;	
	}
	footer li:first-child{
	padding-right:10px;	
	}
	footer li {
    margin-right: 10px;
}
}
@media screen and (max-width: 430px) {
}

@-webkit-keyframes shiny-btn1{
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

@keyframes dokidoki {
  0% {
    transform: scale(1);
  }
  40% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  60% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
  }
}



