@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;
	}
}
.cp-main .orange-text{color: var(--col-c-orange);}
.cp-main .cont-padding{
	padding:0;
}
/*-------------------------------------------
 背景
-------------------------------------------*/
.bg-gradation{
	background:linear-gradient(180deg, #ebfef9, #f9ffd8);
}
.bg-dot:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100vh;
	background: url(../img/dot_bg.png);
  	background-size: cover;
	background-position: 50% 0% ;
	background-repeat: no-repeat;
}

@media screen and (min-width:769px) {
.bg-dot:before{
		background: url(../img/dot_bg.png);
		background-size: cover;
		background-position: center top ;
		background-repeat: no-repeat;
		background-attachment: fixed;
	}
}

/*-------------------------------------------
 リード
-------------------------------------------*/
.cp-main .lead-block{
	width: min(96% , 960px);
	margin: 12px auto;
	border:var(--col-boder) 3px solid;
	border-radius:15px;
	background-color: #FFF;
}
.cp-main .lead-block__inner{
	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: 80px;
	padding:25px 15px 10px;
}

.cp-main .lead-block__inner .lead-block__main{
	text-align: center;
	color:var(--col-c-dark-brown);
}
.cp-main .lead-block__inner .lead-block__main .pink-text{
	font-weight: bolder;
	color:var(--col-c-pink);
	font-size:18px;
}
@media (min-width:769px) {
	.cp-main .lead-block {
		margin: 30px auto;
	}
	.cp-main .lead-block__inner{
		background-size: 120px;
		padding:15px;
	}
	.cp-main .lead-block__inner .lead-block__main {
		font-size:24px;
	}
	.cp-main .lead-block__inner .lead-block__main .pink-text {
		font-size: 28px;
	}
}

/*-------------------------------------------
 基本設定
-------------------------------------------*/
.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:min(96%,960px);
	margin: auto;
	border:var(--col-boder) 3px solid;
	border-radius:15px;
	background-color: #FFF;
	padding-bottom: 20px;
}
.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:min(30%,160px);
	margin: 20px auto 0;
}
.cp-main .entry-block .entry-block_step .entry-block_step_text{
	text-align: center;
	color: var(--col-c-dark-brown);
	font-weight:bolder;
	margin:0 auto 10px;
}
.cp-main .entry-block .entry-block_step .step_decoration01::before,.cp-main .entry-block .entry-block_step .step_decoration01::after{
	content: url(../img/step01_illust_sp.png);
	vertical-align: top;
	margin:0 5px 0;
}
.cp-main .entry-block .entry-block_step .step_decoration02 .orange-text::before{
	content: url(../img/step02_illust-left_sp.png);
	vertical-align: top;
	margin:0 5px 0;
}
.cp-main .entry-block .entry-block_step .step_decoration02 .orange-text::after{
	content: url(../img/step02_illust-right_sp.png);
	vertical-align: top;
	margin:0 5px 0;
}
.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;
}
.cp-main .entry-block .entry-block_step .step_decoration03::before,.cp-main .entry-block .entry-block_step .step_decoration03::after{
	content: url(../img/step03_illust_sp.png);
	vertical-align: middle;
	margin:0 5px 0;
}
.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:18px auto;
	padding:20px 0;
}
.cp-main .entry-block02 > .nyukai-area{
	border-top: 3px solid var(--col-boder);
	padding-top: 20px;
	margin-top: 20px;
}
.cp-main .entry-block02 > .nyukai-area > .annotation{
	width:90%;
}
@media (min-width:769px) {
	.cp-main .entry-block02 {
		margin: 40px auto 0;
		padding:40px 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;
	}
	.cp-main .entry-block .entry-block_step .step_decoration01::before,.cp-main .entry-block .entry-block_step .step_decoration01::after{
		content: url(../img/step01_illust.png);
		vertical-align: top;
		margin:0 5px 0;
	}
	.cp-main .entry-block .entry-block_step .step_decoration02 .orange-text::before{
		content: url(../img/step02_illust-left.png);
		vertical-align: top;
		margin:0 5px 0;
	}
	.cp-main .entry-block .entry-block_step .step_decoration02 .orange-text::after{
		content: url(../img/step02_illust-right.png);
		vertical-align: top;
		margin:0 5px 0;
	}
	.cp-main .entry-block .entry-block_step .step_decoration03::before,.cp-main .entry-block .entry-block_step .step_decoration03::after{
		content: url(../img/step03_illust.png);
		vertical-align: middle;
		margin:0 5px 0;
	}
	.cp-main .cp-btn--large,.cp-main .cp-btn--large-green{
		height: 80px;
	}
	.entry-block .annotation{
	text-align: center;
}
}

/*-- 棚調整 --*/
.shelf-block{
	width:100%;
	background-color: #FFF;
	background-image:url(../img/tana_title_bg_sp.png),  url(../img/shelf_foot_bg.png);
	background-repeat: no-repeat, no-repeat;
	background-position:center top, center bottom;
	background-size:100%;
	padding-bottom: 10px;
}
.shelf-block .shelf-read_text{
	text-align: center;
	font-weight: bolder;
	color:var(--col-c-dark-brown);
	padding-bottom:10px;
}
.shelf-block .shelf-block-bg_foot{
	width:100%;
	max-width:1440px;
	margin: auto;
	background-image:url(../img/shelf_foot_bg02_sp.png), url(../img/shelf_foot_bg01_sp.png);
	background-repeat: no-repeat, no-repeat;
	background-position:bottom left,bottom right;
	background-size:100px,85px;
	padding-bottom: 70px;
}
.o-shelf {
    width: 96%;
    margin: 2% auto;
	overflow: hidden;
}
.o-shelf.-narrow .carousel__prev{
	left: 16px;
}
.o-shelf.-narrow .carousel__next {
	right: 16px;
}
@media (min-width: 769px) {
	.shelf-block{
		width:100%;
		background-color: #FFF;
		background-image:url(../img/tana_title_bg.png),  url(../img/shelf_foot_bg.png);
		background-repeat: no-repeat, no-repeat;
		background-position:center top, center bottom;
		background-size:100%;
	}
	.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;
	}
}

@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;
}
.foot_img{
	background-image: url('../img/point_02.png'), url('../img/point_01.png');
    background-position: bottom left, bottom right;
	background-size: auto;
}
}

/*-------------------------------------------
　dマガジンとは
-------------------------------------------*/
/* 背景 */
.cp-main .about-dmag-block{
    background: url(../img/about-magagine_haikei.jpg) left top / 80% auto repeat;
    position: relative;
	padding: 0;
}

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

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

.cp-main .about-dmag-block__btn{
    position: absolute;
	bottom: 18%;
    left: 50%;
    transform: translateX(-50%);
    background:var(--col-c-pink) ;
    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: 20%;
    left: 50%;
}
	/* 背景 */
	.cp-main .about-dmag-block{
    background: url("../img/about-magagine_haikei.jpg") repeat top center/40%;
    position: relative;
	padding: 0;
	}
	.cp-main .about-dmag-block__inner{
		max-width:670px;
	}
}

/*-------------------------------------------
 利用規約（outline-block）
-------------------------------------------*/
/* 背景 */
.cp-main .outline-block{
	background: #FFF;
	width:100%;
    margin: 4% auto 0;
}
/*フォントサイズ・行間設定*/
.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: #E4F77D;
	padding: .5em;
	color:var(--col-c-dark-brown);
	margin-bottom: .3em;
}
.outline-block__lead{
	font-weight: bold;
	line-height: 1.5;
	margin-bottom: 1em;
	padding-bottom: 1em;
	border-bottom: 1px solid var(--col-magazine-gray);
}
.outline-block__list{
	padding: 16px 10px;
}
.outline-block__item-title{
    border: 2px solid var(--col-c-dark-brown);
	background: #FFF;
	text-align: center;
    color: var(--col-c-dark-brown);
    font-size: clamp(16px , 2.6vw, 18px);
    padding: .5em .5em .3em .5em;
	font-weight: bold;;
    margin-bottom: .5em;
	line-height: 1.2;
}
.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) {
	.outline-block__item-title {
		padding: .3em;
	}
	.outline-block{
		margin-top: 0;
	}
	.outline-block__list {
    	padding: 25px 0;
        width: min(96%, 960px);
        margin: auto;
}
}
/*-- トップへボタン --*/
.cp-main .btn-top{
	width: 85px;
    height: 85px;
	right: 2%;
}
@media (min-width: 769px) {
	.cp-main .btn-top{
	width:100px;
	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;
}
/*-------------------------------------------
 app-margin(アプリ表示時上部のマージンを消す)
-------------------------------------------*/
.app-margin {
	margin-top: -51px;
  }
  @media (min-width: 769px) {
	.app-margin {
	margin-top: -64px;
	}
  }