@charset "UTF-8";
/*-------------------------------------------
 app-margin(アプリ表示時上部のマージンを消す)
-------------------------------------------*/
.app-margin {
	margin-top: -51px;
  }
  @media (min-width: 769px) {
	.app-margin {
	margin-top: -64px;
	}
  }
  
/*-------------------------------------------
 基本設定
-------------------------------------------*/
.cp-body img {display: block;}
.t-container{
	background: url("../img/bgall.gif") repeat;
	background-attachment: fixed;
}
.cp-body{
	background: url("../img/bgbottom_sp.png") no-repeat bottom center;
	background-size: contain;
}
.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{
	max-width: 960px;
	margin: 0 auto;
	padding: 0;
	background-color: #fff;
	box-shadow: 0px 0px 6px 0px rgba(118, 75, 30, 0.3);
}
.cp-main__lower{background: linear-gradient(transparent 99.8%, #9aa65d 0.2%);}
.read{
	margin-bottom:20px;
}
.entry-block{
	width:min(100%,860px);
	margin: auto;
}
.entry-block__btn-title img{
	width: 100%;
    max-width: 560px;
    margin: 0 auto 10px;
}

.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 1.5em;
    padding-bottom: 20px;
    border-bottom: 1px dashed #cecece;
}
.cp-main .cp-btn--large-green{
	box-shadow: 0px 3px 0 #195436;
}

.foot_img{
	background: url("../img/contents_foot_img.png") no-repeat bottom center/ contain;
	padding-bottom: min(23%, 150px);
}
.checkbox-area,.cp-entry__annotation,.nyukai-area{
	max-width: 600px;
	margin: auto;
}

@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;
}
}
.shelf-block{
	margin-top: 25px;
}
.shelf-jouken{
	width: 90%;
	margin: 10px auto;
	color: #764B1E;
	text-align: center;
	line-height: 1.5em;
	font-weight: normal;
	letter-spacing: 0.1rem;
}
.shelf-jouken .text-red{
	color: #EA6540;
	font-weight: bolder;
}
.shelf-jouken .bg_color{
	background: linear-gradient(transparent 50%, #F8F054 50%);
}
.wrapper-osusume{
	width:100%;
	max-width:960px;
	margin: 0 auto;
	padding: 0;
	background: url("../img/bg_advise_sp.png") no-repeat top center/contain;

}
.wrapper-osusume .search_title{
	width:96%;
}
.bikou-text{
	width:94%;
	margin:10px auto;
	color: #764B1E;
	font-size: 12px;
	line-height: 1.5em;
}
.category-btn{
	width:90%;
	margin: auto!important;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.category-btn li{
	width: calc(96%/2);
	margin: 2% auto 5px;
}
.category-btn li a{
	display: block;
	color:#fff;
	border: 1px #764B1E solid;
	box-shadow: 0px 3px 0 rgba(118, 75, 30, 0.7);
	background-color: #F56037;
	text-align: center;
	font-weight: bolder;
	border-radius: 30px;
	padding: 10px 0;
	letter-spacing: 0.1em;
}
.category-btn .green a{background-color: #9AA65D;}
.category-btn .yellow a{background-color: #FFBE2C;padding: 18px 0;}
.category-btn li span{font-weight:normal;font-size:12px;margin-top:5px;}
.wrapper-advise{
	margin-top: 30px;
}
.wrapper-advise img{
	width:100%;
}
.wrapper-advise .advise-onepoint{
	width:90%;
	max-width:600px;
	margin: 0 auto 20px;
}
.category-btn-app{
	width: 40%;
	margin: 18px auto 0!important;
	list-style: circle;
	color: #764B1E;
}
.category-btn-app li{
	margin: 5px auto;
}
@media (min-width: 769px) {
	.wrapper-shelf{
		margin-bottom:30px;
	}
.shelf-jouken{
	font-size: 20px;
    margin-top: 1em;
}
.shelf_01{
	margin-top: -30px;
}
.wrapper-osusume{
	background-image: url('../img/top-left.png'), url('../img/top-right.png'), url('../img/bottom-left.png'), url('../img/bottom-right.png');
    background-position: top left, top right, bottom left, bottom right;
	background-size: auto;
	padding: 0px 100px 30px;
	margin-top: 8%;
}
.wrapper-osusume .search_title{
	width:min(80%,490px);
	margin: auto;
}
.wrapper-osusume .search_read{
	width:min(75%,650px);
	margin: 1em auto;
}
.bikou-text{
	font-size: 16px;
	width:70%;
	font-weight: lighter;
	margin: 10px auto 20px;
}
.category-btn {
    width: 100%;
    display: flex;
    justify-content: space-around;
    flex-wrap: nowrap;
}
.category-btn li {
    width: calc(90% / 3);
    font-size: 20px;
    font-weight: bolder;
	line-height: 1.2em;
    border-radius: 40px;
}
.category-btn li span {
    font-size: 16px;
}
.category-btn li a{
	display: block;
	color:#fff;
	border: 1px #764B1E solid;
	box-shadow: 0px 3px 0 rgba(118, 75, 30, 0.7);
	background-color: #F56037;
	text-align: center;
	font-weight: bolder;
	border-radius: 30px;
	padding: 10px 0;
	letter-spacing: 0.1em;
}
.category-btn li a:hover{
	box-shadow: none !important;
	transform: translateY(3px);
	transition: all 0.5s; 
}
.wrapper-advise .advise-onepoint {
    margin: 9% auto;
}
.wrapper-advise img {
    width: min(88%,660px);
    margin: 0 auto 9%;
}
}

/*-------------------------------------------
　dマガジンとは
-------------------------------------------*/
/* 背景 */
.cp-main .about-dmag-block{
    background: url("../img/bg_about_magazine_sp.png") no-repeat top center/cover;
    position: relative;
	padding: 12% 0 6%;
}

.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{
	/* cp-btn__middle　流用 */
    position: absolute;
	bottom: 15%;
    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 .about-dmag-block{
		padding-top: 10%;
		margin-top: -30px;
	}
	.cp-main .aabout-dmag-block__btn.arrow:before{
		width: 10px;
		height: 10px;
		right: 20px;
	}
	/* 背景 */
	.cp-main .about-dmag-block{
    background: url("../img/bg_about_magazine.png") no-repeat top center/contain;
    position: relative;
	padding: 12% 0 6%;
	}
	.cp-main .about-dmag-block__inner{
		max-width:670px;
	}
}

/* hoverで透明にしたいものにだけ */
@media (min-width: 769px) {
	.cp-main .about-dmag-block__btn{
		opacity: 1;
		bottom: 17%;
	}

	.cp-main .about-dmag-block__btn:hover {
		opacity: .7;
	}
}
/*-------------------------------------------
利用規約
-------------------------------------------*/
/* 背景 */
.outline-block{
	background: #FFF;
    max-width: 960px;
    margin: 4% auto;
}

/*フォントサイズ・行間設定*/
.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: var(--col-magazine-green);
	padding: .5em;
	color: #FFF;
	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;
}

.outline-block__item-title{
    border: 2px solid var(--col-magazine-green);
	background: #FFF;
	text-align: center;
    color: var(--col-magazine-green);
    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 (max-width: 768px) {
	.outline-block{
		width: 92%;
	}
}

@media (min-width: 769px) {
	.outline-block__item-title {
		padding: .3em;
	}
	.outline-block{
		margin-top: 0;
		box-shadow: 0px 0px 6px 0px rgba(118, 75, 30, 0.3);
	}
	.outline-block__list {
    padding: 25px;
}
}

/*-- トップへボタン --*/
.cp-main .btn-top{
	right: 0px;
}

/*-- 背景設定 --*/
.bg-inner .bg-bottom{
	padding-bottom: 24%;
}
@media (min-width: 769px) {
.bg-inner .bg-bottom {
  position: relative; 
  z-index: 1;
  padding-bottom: 15%;
}
.bg-inner .parallax-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.bg-inner .parallax-bg .bg {
  background: no-repeat center center/cover;
  width: 100%;
  height: 100vh;
  position: sticky;
  top: 0; 
  z-index: -1; 
}
.bg-inner .parallax-bg .bg01 {
  background-image: url("../img/bgfixed.png");
  background-size: 100%;
  background-position: center bottom;
}
}

/*-- 棚調整 --*/
.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) {
.o-shelf {
    width: 96%;
    margin: 1% auto;
}
	.o-shelf.-narrow .carousel__prev{
		left: 0;
	}
	.o-shelf.-narrow .carousel__next{
		right: 0;
	}
}


/*-------------------------------------------
追従バナー
-------------------------------------------*/
.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;
}