@charset "UTF-8";
/*-------------------------------------------
 基本設定
-------------------------------------------*/
.cp-main{
	--col-c-orange: #FF7970;
	--col-c-pink: #FD567A;
	--col-c-dark-brown: #AD5C6D;
	--col-c-black: #222222;
	--col-c-red: #CC0033;
	--col-boder:#E4F77D
}

/* テキスト行間 */
.cp-main p{
  line-height: 1.7;
}

.cp-main li,
.cp-main dt,
.cp-main dd   {
  line-height: 1.5;
}

.cp-main .text-pink{
	color: var(--col-c-pink);
}
@media screen and (min-width:769px) {
	.sp-only{
		display: none;
	}
	.margin-left{
		margin-left: 2em;
	}
}
.cp-main .orange-text{color: var(--col-c-orange);}
.cp-main .cont-padding{
	padding:0;
}
/*-------------------------------------------
 背景
-------------------------------------------*/
.bg-gradation{
	background:#FFFFF3;
}
.bg-dot:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100vh;
	background: url(../img/bg_all.png);
  	background-size: cover;
	background-position: 50% 0% ;
	background-repeat: no-repeat;
}

@media screen and (min-width:769px) {
.bg-dot:before{
		background: url(../img/bg_all.png);
		background-size: cover;
		background-position: center top ;
		background-repeat: no-repeat;
		background-attachment: fixed;
	}
}
/*-------------------------------------------
 mv_block
-------------------------------------------*/
.cp-main .mv-block{
	background-image: url('../img/circle_bg_sp.png'),url('../img/bg_mv.jpg');
	background-position: bottom center,top center;
	background-size: 78%,cover;
	background-repeat: no-repeat,repeat-x;
	padding:0 0 10px;
}
.cp-main .mv-block__detail{
	background: url(../img/bg_stripe.png);
	background-size: 7%;
	background-repeat: repeat;
	background-position: center top;
	padding:1% 0;
}
.cp-main .mv-block__detail .mv-block__detail_list{
	width:96%;
	margin:auto;
	display: block;
}
.cp-main .mv-block__detail .mv-block__detail_list_item{
	width:100%;
	margin: 10px auto;
}
.cp-main .mv-block__detail .mv-block__detail_list_item_text{
	background-color: #fff;
	border-radius:50px;
	height: auto;
    padding: 19px 10px 10px;
    text-align: center;
    vertical-align: middle;
    line-height: 1.3em;
	font-weight: bold;
	font-size:13px;
}
.cp-main .mv-block__detail .mv-block__detail_list_item_title{
	display: block;
	width:auto;
	height:22px;
	margin:0 auto -2%;
}
.cp-main .frill{
	background: url(../img/stripe_frill.png),#fff;
	background-size: 7%;
	background-repeat: repeat-x;
	background-position: bottom center;
	padding-bottom:15px;
}
.cp-main .cp__detail_text{    
	width: 96%;
    max-width: 960px;
    padding: 0px 15px;
    background-color: #fff;
    border: #EA3255 2px solid;
    margin: 0 auto;
    border-radius: 14px;
    text-align: center;
    font-weight: bold;
    font-size: 12px;
}
.cp-main .cp__detail_text a{
	color:#04ADFE ;
}
.cp-main .cp__detail_text ul li{
	padding:5px 0;
}
.cp-main .cp__detail_text ul li:first-child{
	border-bottom: #000 dotted 1px;
}
.cp-main .bg-white{
	width:100%;
	background-color: #fff;
	padding:10px 0;
}
@media screen and (min-width:769px) {
.cp-main .mv-block{
	background-image: url('../img/circle_bg_pc.png'),url('../img/bg_mv.jpg');
	background-position: bottom center,top center;
	background-size: auto,cover;
	background-repeat: no-repeat,repeat-x;
} 

.cp-main .mv-block__detail{
	background: url(../img/bg_stripe.png);
	background-size: auto;
	background-repeat: repeat;
	background-position: center top;
	padding:1% 0;
}
.cp-main .mv-block__detail .mv-block__detail_list{
	max-width:960px;
	margin:auto;
	display: flex;
	justify-content: space-around;
}
.cp-main .mv-block__detail .mv-block__detail_list_item{
	width:calc((100% - 40px)/2);
}
.cp-main .mv-block__detail .mv-block__detail_list_item_text{
	background-color: #fff;
	border-radius:50px;
	height: 70px;
    padding: 19px 20px 0;
    text-align: center;
    vertical-align: middle;
    line-height: 1.3em;
	font-weight: bold;
	font-size:16px;
}
.cp-main .mv-block__detail .mv-block__detail_list_item_title{
	display: block;
	width:auto;
	height:30px;
	margin:0 auto -3%;
}
.cp-main .frill{
	background: url(../img/stripe_frill.png);
	background-size: auto;
	background-repeat: repeat-x;
	background-position: bottom center;
	padding-bottom:22px;
}
.cp-main .cp__detail_text{
	padding:5px 15px;
	margin:20px auto 30px;
	border-radius:20px;
	font-size:16px;
}
.cp-main .cp__detail_text a{
	color:#04ADFE ;
}
.cp-main .cp__detail_text ul li{
	padding:10px 0;
}
.cp-main .cp__detail_text ul li:first-child{
	border-bottom: #000 dotted 1px;
}
.cp-main .bg-white{
	background: none;
	padding: 0;
}
}

/*-------------------------------------------
 リード
-------------------------------------------*/
.cp-main .lead-block_bg__wrapper{
	background-color: #fff;
	background-image:url(../img/stripe_frill_bottom.png);
	background-repeat:repeat-x;
	background-position:bottom center;
	background-size: 7%;
	padding-bottom: 8%;
}
.cp-main .lead-block{
	width: 100%;
	margin: 0 auto;
	background-color: #FFF;
	background-image:url(../img/flag_left.png), url(../img/flag_right.png);
	background-repeat: no-repeat, no-repeat;
	background-position:top left,top right;
	background-size: 30%;
}
.cp-main .lead-block__inner{
	padding:5px 15px 10px;
}
.cp-main .lead-block__inner .lead-block__inner_titleimg{
	max-width: 230px;
    width: 40%;
    margin: 0 auto 15px;
}
.cp-main .lead-block__inner .hyou_app{
	margin: 10px auto;
}
.cp-main .lead-block__inner .nyuukai_btn{
	width: 100%;
    height: auto;
    margin: 10px auto;
    position: relative;
    background-image: url(../img/hyou_sp.png);
    background-size: 100%;
    background-position: center top;
    background-repeat: no-repeat;
    padding: 50% 0 5%;	
}
	.cp-main .lead-block__inner .lead-block__inner_nyuukai_btn{
	position: absolute;
    width: 35%;
    top: 69%;
    left: 40%;
	}
	.cp-main .lead-block__inner .lead-block__inner_nyuukai_btn:hover{
		opacity: 0.8;
	}
	.cp-main .lead-block__inner .kirari01{
	width: 13%;
    height: auto;
    position: absolute;
    top: 10%;
    left: 0;
	}
	.cp-main .lead-block__inner .kirari02{
	width: 13%;
    height: auto;
    position: absolute;
    top: 10%;
    right: 0;
	}

.cp-main .lead-block__inner .check_760pt{
	position: relative;
}
.cp-main .lead-block__inner .kirari01,.cp-main .yokoku_block__text .kirari01 {
    animation-name: kirari01;
    animation-delay: 0s;
    animation-duration: 1s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
}
@keyframes kirari01 {
  0%{ transform:rotateY(0);}
  100%{ transform:rotateY(360deg); }
}

.cp-main .lead-block__inner .kirari02 ,.cp-main .yokoku_block__text .kirari02{
    animation-name: kirari02;
    animation-delay: 0s;
    animation-duration: 1s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
}
@keyframes kirari02 {
  0%{ transform:rotateY(0);}
  100%{ transform:rotateY(360deg); }
}

@media (min-width:769px) {
	.cp-main .lead-block{
		margin: 30px auto;
		border:#000 3px solid;
		border-radius:20px;
		background-color: #FFF;
		background-image:url(../img/flag_left.png), url(../img/flag_right.png);
		background-repeat: no-repeat, no-repeat;
		background-position:top left,top right;
		background-size: auto;
		width: 96%;
        max-width: 960px;
	}
	.cp-main .lead-block__inner{
		background-size: 120px;
		padding:24px 10px 50px;
		max-width:730px;
	}
	.cp-main .lead-block__inner .lead-block__inner_titleimg{
		margin: 0 auto 30px;		
	}
	.cp-main .lead-block__inner .lead-block__inner_nyukai01{
		max-width:715px;
		margin: auto;
	}
	.cp-main .lead-block__inner .lead-block__inner_nyukai02{
		max-width:500px;
		margin: auto;
	}
	.cp-main .lead-block__inner .nyuukai_btn{
		max-width: 696px;
		height:350px;
		margin: 30px auto;
		position: relative;
		background-image: url(../img/hyou.png);
		background-size: cover;
		background-position: center;
		background-repeat: no-repeat;
		padding: 0;
			
	}
	.cp-main .lead-block__inner .lead-block__inner_nyuukai_btn{
		position: absolute;
		width:231px;
		top:263px;
		left:273px;
	}
	.cp-main .lead-block__inner .lead-block__inner_nyuukai_btn:hover{
		opacity: 0.8;
	}
	.cp-main .lead-block__inner .kirari01{
		width:117px;
		height:106px;
		position: absolute;
		top:30px;
		left:0;
	}
	.cp-main .lead-block__inner .kirari02{
		width:114px;
		height:103px;
		position: absolute;
		top:30px;
		right:0;
	}
	.cp-main .lead-block_bg__wrapper{
		background-color: transparent;
		background-image:url(../img/bg_left.png),url(../img/bg_right.png),url(../img/stripe_frill_bottom.png);
		background-repeat:no-repeat,no-repeat,repeat-x;
		background-position:left center,right center,bottom center;
		background-size: 15%,21%,auto;
		padding-bottom: 80px;
	}
	.cp-main .lead-block__inner .check_760pt {
    position: relative;
    width: 96%;
    margin: auto;
	}
}
/*-------------------------------------------
 基本設定
-------------------------------------------*/
.cp-body img {display: block;}
.cp-main{
	--size-rl-padding: 8px;
	--size-rl-padding-plus: calc( var(--size-rl-padding) + 2);
	--gap-base: min(5%, 58px);
	--gap-base-tb: min(8%, 48px);
}
.cp-main__inner{
	margin: 0 auto;
	padding: 0;
}
.read{
	margin-bottom:20px;
}

/*--エントリー--*/
.cp-main .entry-block{
	width:100%;
	margin: auto;
	background-color: #FFF;
	background-image: url(../img/bg_entry_shelf.png);
	background-repeat: repeat;
	background-size: 100%;
	padding-bottom: 0px;
	padding-top: 1px;
}
.cp-main .entry-block .entry-block__btn-title{
	background: url(../img/step-title_bg.png) center top / cover repeat-x;
	padding:5px 0;
	margin-bottom:20px;
	border-radius: 10px 10px 0 0;
}
.cp-main .entry-block__btn-title img{
	width: 80%;
    max-width: 500px;
    margin: 0 auto;
}
.cp-main .entry-block .entry-block_step .step-icon{
	width: 96%;
    margin: 20px auto 10px;
}
.cp-main .entry-block .entry-block_step .entry-block_step_text{
	text-align: center;
	color: #222;
	font-weight:bolder;
	margin:0 auto 10px;
	line-height:1.3em;
}
.cp-main .entry-block .entry-block_step .step_decoration03{
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
.cp-main .entry-block > .step03 > .step_decoration03 > .entry-block_step_text{
	display: contents;
}
.checkbox-area__btn-set,.checkbox-area__checkbox-set,.cp-entry__annotation,.nyukai-area__btn-set{
	width: 90%;
	margin: auto;
}
.cp-main .cp-entry__annotation{
	margin: 0.2em auto 0;
	max-width:540px;
}
.cp-main .cp-btn--large-green{
	box-shadow: 0px 3px 0 #195436;
}
.entry-block .annotation{
	width:90%;
	max-width:540px;
	font-size:12px;
	margin:10px auto;
}
.checkbox-area,.cp-entry__annotation,.nyukai-area{
	max-width: 600px;
	margin: auto;
}
.cp-main .caution_box .caution{
	text-align: center;
	margin: 1em auto;
}
.cp-main .caution_box .caution::before{
	content: url(../img/caution_icon_sp.png);
	vertical-align: top;
	margin-right:5px;
}
.cp-main .separatorline{
		max-width:600px;
		margin: auto;
	}
/*--エントリー02--*/
.cp-main .entry-block02{
	margin:0 auto;
	padding:30px 0 15px;
}
.cp-main .step-icon02{
	width: 65%;
    max-width: 300px;
    margin: 0 auto 10px;
}
.cp-main .entry-block02 > .nyukai-area{
	padding-top: 20px;
	margin-top: 20px;
}
.cp-main .entry-block02 > .nyukai-area > .annotation{
	width:90%;
}
.cp-main .shelf_title{
	margin-top: -20px;
}
@media (min-width:769px) {
	.cp-main .entry-block{
		width:100%;
		margin: auto;
		background-color: #FFF;
		background-image: url(../img/bg_entry_shelf.png);
		background-repeat: repeat;
		background-size: auto;
		padding-bottom: 0px;
		padding-top: 1px;
	}
	.cp-main .entry-block .entry-block_step .step-icon{
	width: 600px;
    margin: 50px auto 20px;
	}
	.cp-main .entry-block02 {
		margin: 0 auto;
		padding:50px 0;
	}
	.cp-main .entry-block .entry-block_step .step_decoration03{
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.cp-main .entry-block > .step03 > .step_decoration03 > .entry-block_step_text{
		display: contents;
	}
	.cp-main .entry-block .entry-block_step .entry-block_step_text{
		font-size: 24px;
		letter-spacing: -1px;
		line-height: 1.5em;
	}
	.cp-main .cp-btn--large,.cp-main .cp-btn--large-green{
		height: 80px;
	}
	.entry-block .annotation{
	text-align: center;
	}
	.cp-main .shelf_title{
		margin-top: -20px;
	}
	.cp-main .step-icon02{
	max-width:300px;
	margin:20px auto 10px;
	}
}

/*-- 棚調整 --*/
.shelf-block{
	width:100%;
	background-color: #FFF;
	background-image: url(../img/bg_entry_shelf.png);
	background-repeat: repeat;
	background-size: 100%;
	padding-bottom: 0;
}
.shelf-block .shelf-read_text{
	text-align: center;
	font-weight: bolder;
	color:var(--col-c-dark-brown);
	padding-bottom:10px;
}
.o-shelf {
    width: 96%;
    margin: 1% auto;
	overflow: hidden;
}
.o-shelf.-narrow .carousel__prev{
	left: 16px;
}
.o-shelf.-narrow .carousel__next {
	right: 16px;
}
	.o-shelf.-narrow {
    position: relative;
    width: 100%;
	margin-bottom: 0;
    z-index: 0;
    padding-bottom: 20px;
	}
@media (min-width: 769px) {
	.shelf-block{
		width:100%;	background-color: #FFF;
		background-image: url(../img/bg_entry_shelf.png);
		background-repeat: repeat;
		background-size: auto;
		padding-bottom: 50px;
		margin-top: -1%;
	}
	.shelf-block .shelf_read{
		max-width:1440px;
		padding:20px 0 0;
		margin: auto;
	}
	.shelf-block .shelf-read_text{
		margin:-5% auto 30px;
		font-size:130%;
	}
	.shelf-block .wrapper-shelf{
		max-width:960px;
		margin: auto;
	}
	.shelf-block .shelf-block-bg_foot{
	background-image:url(../img/shelf_foot_bg02.png), url(../img/shelf_foot_bg01.png);
	background-repeat: no-repeat, no-repeat;
	background-position:bottom left,bottom right;
	background-size:11%;
	padding-bottom: min(160px, 15%);
}
	.o-shelf {
		width: 96%;
		margin: 1% auto;
	}
	.o-shelf.-narrow .carousel__prev{
		left: 0;
	}
	.o-shelf.-narrow .carousel__next{
		right: 0;
	}
	.o-shelf.-narrow {
    position: relative;
    width: 100%;
	margin-bottom: 20px;
    z-index: 0;
    padding-bottom: 0;
	}
}

@media (min-width: 769px) {
.cp-body{
	background-image: none;
	padding: 0;
}
.cp-main__lower{background: none;}
.entry-block__btn-title img{
    margin: 0 auto 20px;
}
.entry-margin{
	margin-top: -30px;
}
}

/*-------------------------------------------
　dマガジンとは
-------------------------------------------*/
/* 背景 */
.cp-main .about-dmag-block{
    position: relative;
	padding: 0;
}

.cp-main .about-dmag-block__inner{
	position: relative;
	margin:20px auto;
	padding:min(3%, 50px);
}

.cp-main .aabout-dmag-block__img{
	display: block;
	margin: auto;
}

.cp-main .about-dmag-block__btn{
    position: absolute;
	bottom: 16%;
    left: 50%;
    transform: translateX(-50%);
    background:#CC0033;
    font-size: clamp(14px, 2.8vw, 24px);
    padding: 0.7em;
    width: min(60%, 440px);
}

.cp-main .about-dmag-block__btn.arrow:before{
	width: 8px;
	height: 8px;
}

@media (min-width: 769px) {

	.cp-main .aabout-dmag-block__btn.arrow:before{
		width: 10px;
		height: 10px;
		right: 20px;
	}
	.cp-main .about-dmag-block__btn{
    position: absolute;
	bottom: 18%;
    left: 50%;
}
	/* 背景 */
	.cp-main .about-dmag-block{
    position: relative;
	padding: 0;
	}
	.cp-main .about-dmag-block__inner{
		max-width:670px;
		margin:0 auto;
	}
}
/*-------------------------------------------
第二弾予告
-------------------------------------------*/
.cp-main .yokoku_block .yokoku_block__bg_stripe{
	background: url(../img/bg_stripe.png);
    background-size: 7%;
    background-repeat: repeat;
    background-position: center top;
    padding:3% 0 1%;
}
.cp-main .yokoku_block .yokoku_block__bg_frill{
	background: url(../img/stripe_frill.png);
    background-size: 7%;
    background-repeat: repeat-x;
    background-position: center bottom;
	padding-bottom: 18px;
}
.cp-main .yokoku_block .yokoku_block__bnr_link{
	width: 94%;
	max-width:750px;
	margin:4% auto 8%;
	display: block;
}
	.cp-main .yokoku_block__text{
		width: 96%;
		max-width:715px;
		margin: auto;
		position: relative;
	}
	.cp-main .yokoku_block__text_sub{
		text-align: center;
		font-size: 14px;
		line-height:1.5em;
		font-weight: bold;
	}
	.cp-main .yokoku_block__text_img{
		width:250px;
		margin:5px auto 0;
	}
	.cp-main .yokoku_block__text .kirari01{
		width: 16%;
		height: auto;
		position: absolute;
		top: 30%;
		left: 0;
	}
	.cp-main .yokoku_block__text .kirari02{
		width: 16%;
		height: auto;
		position: absolute;
		top: 30%;
		right: 0%;
	}
@media (min-width:480px) {
	.cp-main .yokoku_block__text{
		width: 75%;
	}
	.cp-main .yokoku_block__text .kirari01{
		width: 15%;
		height: auto;
		position: absolute;
		top: 25%;
		left: 0;
	}
	.cp-main .yokoku_block__text .kirari02{
		width: 15%;
		height: auto;
		position: absolute;
		top: 25%;
		right: 0%;
	}
	}
@media (min-width: 769px) {
	.cp-main .yokoku_block .yokoku_block__bg_stripe{
		background: url(../img/bg_stripe.png);
		background-size: auto;
		background-repeat: repeat;
		background-position: center top;
		padding: 1% 0;
	}
	.cp-main .yokoku_block .yokoku_block__bg_frill{
		background: url(../img/stripe_frill.png);
		background-size: auto;
		background-repeat: repeat-x;
		background-position: center bottom;
		padding-bottom: 20px;
	}
	.cp-main .yokoku_block .yokoku_block__bnr_link{
		width: 96%;
		max-width:750px;
		margin:2% auto 5%;
		display: block;
	}
	.cp-main .yokoku_block__text{
		width:96%;
		max-width:715px;
		margin: auto;
		position: relative;
	}
	.cp-main .yokoku_block__text_sub{
		text-align: center;
		font-size: 24px;
		line-height:1.5em;
		font-weight: bold;
	}
	.cp-main .yokoku_block__text_img{
		width:100%;
		max-width:550px;
		margin: auto;
	}
	.cp-main .yokoku_block__text .kirari01{
		width:82px;
		height:74px;
		position: absolute;
		top:5px;
		left:0;
	}
	.cp-main .yokoku_block__text .kirari02{
		width: 80px;
        height: 72px;
        position: absolute;
        top: 5px;
        right: 0;
	}
}

/*-------------------------------------------
 利用規約（outline-block）
-------------------------------------------*/
/* 背景 */
.cp-main .outline-block{
	background: #FFF;
    width: 94%;
    max-width: 960px;
    margin: 4% auto 10%;
    border-radius: 20px;
    padding: 20px 10px;
}
/*フォントサイズ・行間設定*/
.outline-block p,
.outline-block dd,
.outline-block li,
.outline-block li{
	line-height: 1.5;
	font-size: 14px;
}
/* 余白調整定１ */
.outline-block ul{
	margin-top: .3em;
}
/* 余白調整定2 */
.outline-block li,
.outline-block li{
	margin-bottom: .3em;
}
.outline-block li:last-child,
.outline-block li:last-child{
	margin-bottom: 0;
}
.outline-block__title{
    text-align: center;
    font-size: clamp(18px, 4vw, 26px);
    background: #00915D;
    padding: .5em;
    color: #fff;
    margin-bottom: .3em;
	border-radius: 5px;
}
.outline-block__lead{
	line-height: 1.5;
	margin:1em auto;
	width:96%;
}
.outline-block__list{
	padding: 0;
}
.outline-block__item-title{
    border: 2px solid #00915D;
	background: #FFF;
	text-align: center;
    color: #00915D;
    font-size: clamp(16px , 2.6vw, 18px);
	font-weight: bold;
    margin-bottom: .5em;
	border-radius:5px;
}
.outline-block__item-title + .outline-block__item-disc {
    margin-bottom: 2em;

}
.outline-block__item-title  + .outline-block__item-disc:last-child {
  margin-bottom: 0;
}
.outline-block__list .kome{
  list-style: none;
}
.outline-block__list .kome li {
  position: relative;
	padding-left: min(1.2em, 20px);
}
.outline-block__list .kome li::before {
  content: '\0203B';
  position: absolute;
  left: 0;
}
.outline-block__list .number {
  list-style: none;
  counter-reset: number;
}
.outline-block__list .number li {
  position: relative;
  padding-left: min(2.5em, 35px);
}
.outline-block__list .number li::before {
  counter-increment: number;
  content: '（' counter(number) '）';
  position: absolute;
  left: 0;
}
.outline-block__list .list-style_on{
	list-style:disc;
}
.outline-block__list .disc li{
margin-left: 1.2em;
}

@media (min-width: 769px) {
	.cp-main .outline-block{
		margin: 4% auto;
		padding:20px;
	}
	.outline-block__item-title {
		padding: .3em;
	}
	.outline-block{
		margin-top: 0;
	}
	.outline-block__list {
    	padding:10px 0 20px;
        width: 100%;
        margin: auto;
	}
	.outline-block__title{
		border-radius: 0px;
	}
}
/*-- トップへボタン --*/
.cp-main .btn-top{
	width: 68px;
    height: 106px;
	right: 2%;
}
@media (min-width: 769px) {
	.cp-main .btn-top{
	width:68px;
	right: 5%;
}
}
/*-------------------------------------------
hover
-------------------------------------------*/
/* hoverで透明にしたいものにだけ */
@media (min-width: 769px) {
	.cp-main .about-dmag-block__btn{
		opacity: 1;
	}
	.cp-main .about-dmag-block__btn:hover {
		opacity: .7;
	}
	.float-area__banner:hover{
		opacity: .7;
	}
}

/*-------------------------------------------
追従バナー
-------------------------------------------*/
.float-area__inner {
    position: fixed;
    z-index: 100;
    bottom: 0;
    right: 0;
}
.float-area__banner-block {
    width: 100vw;
    padding: 20px 0 12px;
    background: rgba(255, 255, 255, 0.7);
}
.float-area__banner {
    display: flex;
    justify-content: center;
    align-items: center;
    width: clamp(250px, 67vw, 500px);
    height: 57px;
    font-size: clamp(16px, 4.3vw, 24px);
    font-weight: bold;
    color: #fff;
    background: linear-gradient(#df202a, #c61c26);
    border-radius: 25px;
    margin: 0 auto;
    position: relative;
    padding: 12px;
    border: 2px solid transparent;
    box-shadow: 0 2px 4px -2px rgb(33 37 56 / 25%);
    border-color: rgb(80, 80, 80, 0.1);
}
.float-area__banner-arrow:before {
    position: absolute;
    content: "";
    right: 10px;
    width: 10px;
    height: 10px;
    border-top: 2px solid var(--col-white);
    border-right: 2px solid var(--col-white);
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
}
.yellow {
    color: #ffff00;
}
@media (min-width: 769px) {
	.float-area__banner {
        border-radius: 50px;
    }    
	.float-area__banner-arrow:before {
        right: 15px;
	}
}
.o-footer {
padding-bottom: 100px;
}
.cp-main .text-red{
	color: #EA3255;
}
/*-------------------------------------------
 app-margin(アプリ表示時上部のマージンを消す)
-------------------------------------------*/
.app-margin {
	margin-top: -51px;
  }
  @media (min-width: 769px) {
	.app-margin {
	margin-top: -64px;
	}
  }