@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/earlyaccess/notosansjp.css');
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@300;400&display=swap');
.fadein {
    opacity: 0;
    /* transform: translate(0, 30px); */
    transition: all 1500ms;
}
.fadein2 {
    opacity: 0;
    transform: translate(0, 0);
    transition: all 1500ms;
}
.fadein3 {
    opacity: 0;
    transform: translate(0, 15px);
    transition: all 3000ms;
}
.scrollin {
    opacity: 1;
    /* transform: translate(0, 0); */
}

/* PCスマホ共通------------------------------------------------------------------------ */
body.favorite #contents .inner #contents-main {
  font-family: 'Noto Sans JP',メイリオ, Meiryo, sans-serif;
}
body.favorite #contents .inner #contents-main article > h3{
    display: none;
}
#contents-main h3{
    border: none;
    padding: 0;
    font-weight: bold;
    font-size: 0;
    background: #fff;
    text-align: center;
    margin: auto;
}
#contents-main section.entry h3::before{
    content: '';
    display: block;
    background-image: url(cont-title05.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 50px;
    width: auto;
    aspect-ratio: 373 / 81;
    margin: auto;
    opacity: 100;
}

body.favorite #contents .inner {overflow: unset;}

/* タイトル部分 */

body.favorite #contents .inner #contents-main .html1 {
	position: relative;
}
body.favorite #contents .inner #contents-main .html1 > div{
	position: absolute;
	left:0;
	right: 0;
	margin: auto;
	z-index: 100;
}

/* アイテムリスト */
body.favorite #contents .inner #contents-main article .content1 {
}
body.favorite #contents .inner #contents-main article .content1 a {
}
body.favorite #contents .inner #contents-main article .content1 a:after {
}
body.favorite #contents .inner #contents-main article .content1 + section  {
	background:#fdd424;
	position: relative;
	z-index: 10;
	padding: 30px 0;
}
body.favorite #contents .inner #contents-main article .content1 + section::before,body.favorite #contents .inner section.entry::before  {
	content:"";
	background:url("bg-wave.png");
	background-size: contain;
	width: 100%;
	height: auto;
	aspect-ratio: 1023/38;
	display: block;
	position: absolute;
	top: -25px;
}
body.favorite #contents .inner #contents-main article .content1 + section > div  {
	background:#fff;
	margin:auto;
	border-radius:10px;
	position: relative;
}

body.favorite #contents .inner #contents-main .feature + .btn_vote {
    background-image: url(bg-touhyou.jpg);
    aspect-ratio: 51/35;
    background-position: center;
    background-size: cover;
    text-align: center;
    font-weight: bold;
}
body.favorite #contents .inner #contents-main .feature + .btn_vote::before {
    content: '';
    display: block;
    background-image: url(cont-title02.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
body.favorite #contents .inner #contents-main .feature + .btn_vote a {
    display: block;
    background-color: #e3007f;
    border: #fff solid 4px;
    text-align: center;
    line-height: 4rem;
    box-shadow: 5px 5px 0px 0px rgba(0, 0, 0, 0.25);
    width: 80%;
    margin: 8px auto 16px;
    font-weight: bold;
    font-size: 24px;
    color: #fff;
    border-radius: 10px;
    position: relative;
}
body.favorite #contents .inner #contents-main .feature + .btn_vote a:after {
    content: '';
    display: inline-block;
    height: 20px;
    width: 15px;
    clip-path: polygon(0% 0, 100% 50%, 0 100%);
    background: #fff;
    position: absolute;
    margin: auto;
    right: 20px;
    top: 0;
    bottom: 0;
}

/* アイテムリスト */
body.favorite #contents .inner #contents-main .NewsItemList {
    border: none;
    counter-reset: number 0;
}


body.favorite #contents .inner #contents-main .NewsItemList .item {
    border: none;
    position: relative;
    padding-bottom: 0;
    float: none;
    height: auto;
}

body.favorite #contents .inner #contents-main .NewsItemList .item:before{
    content: "NO.";
    position: absolute;
    z-index:20;
    top: 27px;
    left: 0px;
    font-weight: bold;
}
body.favorite #contents .inner #contents-main .NewsItemList .item:after{
    content: "12";
    position: absolute;
    z-index:20;
    font-weight: bold;
    border-top: 1px solid #333;
    width: 15%;
    text-align: center;
    padding-top: 2px;
}
body.favorite #contents .inner #contents-main .NewsItemList.cat2602002 .item:after{
    content: "12";
}

body.favorite #contents .inner #contents-main .NewsItemList .item .news_box {
    position: relative;
    counter-increment : number 1;
}
body.favorite #contents .inner #contents-main .NewsItemList .item .news_box:before {
    position: absolute;
    content: counter(number, decimal-leading-zero);
    background: #fff;
    border: 2px solid #000;
    z-index: 10;
    font-weight: 900;
    font-size: 25px;
    aspect-ratio: 1/1;
    border-radius: 50%;
}

body.favorite #contents .inner #contents-main .NewsItemList .item .image {
    position: relative;
    float: none;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    box-sizing: border-box;
    text-align: center;
    margin: 0;
    background: none;
}

body.favorite #contents .inner #contents-main .goods_like_btn.mini {
    margin: 10px 0 5px;
    position: absolute;
    bottom: 10px;
    top: auto;
    left: auto;
    right: -10px;
    z-index: 3;
    display: inline;
}
body.favorite #contents .inner #contents-main .goods_like_btn.mini p {
    display: grid;
    background: #fff;
    box-shadow: 2px 2px 0px 0px rgba(0, 0, 0, 0.25);
    padding: 5px;
    width: 55px;
    height: 55px;
    border-radius: 50px;
    border: #000 solid 2px;
    text-align: center;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}
body.favorite #contents .inner #contents-main .goods_like_btn.mini p i {
    color: #E24130;
    display: inline-block;
    font-size: 26px;
    margin: 0;
}
body.favorite #contents .inner #contents-main .NewsItemList .item .name {
    width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 9px 0 0px;
    color: #fff;
}
body.favorite #contents .inner #contents-main .NewsItemList .item .name a {
    font-size: 14px;
    line-height: 1.6rem;
    border: none;
    font-weight: bold;
    background: #e3007f;
    padding: 1px 5px 2px;
    color: #fff;
}

body.favorite #contents .inner #contents-main .goods_like_btn.mini p span {
    border:none;
    font-size: 1.2em;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2{
    padding: 0 15px;
    font-size: 16px;
    margin-bottom: 40px;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2 p.goodsname {
    font-weight: bold;
    font-size: 16px;
    border-bottom: dotted 2px #bbb;
    padding-bottom: 10px;
    margin-bottom: 11px;
    height: auto;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2 div{
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: bold;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2 div a {
    background: #000;
    color: #fff;
    border-radius: 20px;
    padding: 2px 15px;
    font-size: 13px;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2 > a {
	display: block;
	margin: auto;
	text-align: center;
	background: #e3007f;
	color: #fff;
	font-weight: bold;
	line-height: 3rem;
	border-radius: 5px;
	margin-top: 20px;
	box-shadow: 5px 5px 0px 0px rgba(0, 0, 0, 0.25);
	position:relative;
	width: 75%;
}
body.favorite #contents .inner #contents-main .NewsItemList .detail2 > a::before {
	content: '';
	display: inline-block;
	height: 17px;
	width: 12px;
	clip-path: polygon(0% 0, 100% 50%, 0 100%);
	background: #fff;
	position: absolute;
	margin: auto;
	right: 20px;
	top: 0;
	bottom: 0;
}
body.favorite #contents .inner #contents-main article .content1 + section > div h4{
    background: #E3007F;
    padding: 15px 0;
    font-size: 20px;
    font-weight: bold;
    color: #FFF;
    text-align: center;
    margin-bottom: 10px;
}
body.favorite #contents .inner #contents-main article .content1 + section > div h4.cat2602002{
    background: #46827C;
}
body.favorite #contents .inner #contents-main article .content1 + section > div h4 strong{
    font-size: 32px;
    padding: 0px 10px;
}


body.favorite #contents .inner #contents-main article .content1 + section > div h4 + p {
	text-align:center;
}



/*現在のランキング*/

body.favorite #contents .inner #contents-main section.current-rank {
    background:#ffb40d;
    position: relative;
    padding-bottom: 30px;
    padding: 40px 0;
    box-sizing: border-box;
    z-index: 10;
}
body.favorite #contents .inner #contents-main section.current-rank::before {
    content:"";
	background:url("bg-wave_2.png");
	background-size: contain;
	width: 100%;
	height: auto;
	aspect-ratio: 1023/38;
	display: block;
	position: absolute;
	top: -20px;
}

body.favorite #contents .inner #contents-main section.current-rank h3 {
    border: none;
    padding: 0;
    font-weight: bold;
    font-size: 0;
    background: transparent;
    text-align: center;
}
body.favorite #contents .inner #contents-main section.current-rank h3:before {
    content: '';
    display: block;
    background-image: url(cont-title03.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 50px;
    width: auto;
    aspect-ratio: 373 / 81;
    margin: auto;
    opacity: 100;
}
body.favorite #contents #favorite {
    border: none;
    position: relative;
    padding: 30px 0;
    background: #fff;
    margin: auto;
    border-radius: 10px;
    position: relative;
    width: 720px;
}
body.favorite #contents #favorite .item {
    float: none;
}
body.favorite #contents #favorite .item .name.subtitle {
    display:block;
    margin: 10px 0 2px;
    width: 195px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #fff;
}
body.favorite #contents #favorite .item .name.subtitle a {
    border-bottom: none;
    font-weight: bold;
    font-size: 13px;
    line-height: 1.6rem;
    border: none;
    background: #e3007f;
    padding: 1px 5px 2px;
    color: #fff;
}
body.favorite #contents #favorite .item .image {
    float: none;
    width: 70%;
    height: auto;
    aspect-ratio: 1 / 1;
    text-align: center;
    margin: auto;
    background: none;
    overflow: visible;
    box-sizing: border-box;
}
body.favorite #contents .inner #contents-main #favorite .goods_like_btn.mini {
    bottom: -25px;
    right: -20px;
}

body.favorite #contents .inner #contents-main #favorite .item .desc {
    width: 70%;
    margin: auto;
    padding: 0;
    display: block;
}
body.favorite #contents .inner #contents-main #favorite .item .desc h4.goods.title {
   font-size: 16px;
    text-align: justify;
}
body.favorite #contents .inner #contents-main #favorite .item .desc h4.goods.title a{
   margin-top: 0;
}
body.favorite #contents .inner #contents-main #favorite .item .desc div {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: bold;
    border-top: dotted 4px #333;
    padding-top: 10px;
    margin-top: 10px;
}
body.favorite #contents .inner #contents-main #favorite .item .desc div a {
   background: #000;
    color: #fff;
    border-radius: 20px;
    padding: 2px 15px;
    font-size: 13px;
}
body.favorite #contents .inner #contents-main #favorite .item {
    border: none;
}
body.favorite #contents .inner #contents-main #favorite .item::before {
    content: '';
    display: block;
    width: 80px;
    aspect-ratio: 126 / 112;
    margin: auto;
	top: 27px;
    left: 0px;
}
.favorite #contents .inner #contents-main .NewsItemList .item .news_box:before {
    top: -26px;
    left: -45px;
    padding: 17px 18px 43px 42px;
    
    box-sizing: border-box;
    
    max-width: 95px;
    max-height: 95px;
}
body.favorite #contents .inner #contents-main .NewsItemList .item:after {
    top: 55px;
    left: 0;
}
body.favorite #contents .inner #contents-main #favorite .item:first-of-type::before {
    background: url("fig-kanmuri01.png") no-repeat;
    background-size: contain;
}
body.favorite #contents .inner #contents-main #favorite .item:nth-of-type(2)::before {
    background: url("fig-kanmuri02.png") no-repeat;
    background-size: contain;
}
body.favorite #contents .inner #contents-main #favorite .item:nth-of-type(3)::before {
    background: url("fig-kanmuri03.png") no-repeat;
    background-size: contain;
}



body.favorite #contents .inner #contents-main section.current-rank + .btn_vote {
    display: block;
    background-color: #e3007f;
    border: #000 solid 4px;
    text-align: center;
    line-height: 4rem;
    box-shadow: 5px 6px 0px 0px #fff;
    width: 80%;
    margin: 20px auto;
    font-weight: bold;
    font-size: 24px;
    color: #fff;
    border-radius: 5px;
}


/*注意書き*/

body.favorite #contents .inner #contents-main .box_caution {
    background:#fff;
    box-sizing: border-box;
    padding: 20px 20px 40px;
}

body.favorite #contents .inner #contents-main .box_caution h5 {
    font-size: 0;
    background: url("cont-title04.png") no-repeat;
    background-size: contain;
    height: 50px;
    width: auto;
    aspect-ratio: 340 / 81;
    margin: 0 auto 20px;
}
body.favorite #contents .inner #contents-main p.warn {
    font-size: 12px;
    text-align: right;
    display: block;
}

body.favorite #contents .inner #contents-main .goods_like_btn.mini p i::after,body.favorite #contents .inner #contents-main .goods_like_btn.mini p span:before,body.favorite #contents .inner #contents-main .NewsItemList .item .morelink {
    display: none;
}

/*参加方法*/
section.entry {
    background:#fdd424;
    position: relative;
    z-index: 10;
    padding: 40px 0 60px;
    div {
        background:#fff;
        border-radius: 10px;
    }
}
body.favorite section.entry > div {
    margin:auto;
    text-align: center;
    h3{
        content: '';
        display: block;
        background-image: url(cont-title03.png);
        background-size: contain;
        background-repeat: no-repeat;
        width: auto;
        aspect-ratio: 373 / 81;
        margin: auto;
        opacity: 100;
    }
}



/* PCのみ */

body.favorite.pc #contents .inner {
    padding-left:0;
    padding-right:0;
    position: relative;
    overflow: unset;
    margin-top: -360px;
}


body.favorite.pc #contents .inner #contents-main {
    position: relative;
}
body.favorite.pc section.main-section{
    margin: auto;
    position: relative;
}


/* サイドボタン */
body.favorite.pc section.sidebtn {
	position: sticky;
	top:0;
	right: 0;
	z-index: 100;
	margin-bottom: 360px;
	div{
        position: absolute;
        right: 0;
        display: flex;
        flex-direction: column;
        row-gap: 3px;
        top: 60px;
        overflow: hidden;
        padding-bottom: 10px;
	}
    a {
        display: block;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        text-orientation: mixed;
        background: #46827c;
        border: 3px solid #fff;
        padding: 15px 20px 15px 10px;
        border-radius: 10px 0 0 10px;
        font-weight: bold;
        color: #fff;
        letter-spacing: 0.1rem;
        font-size: 16px;
        transform: translateX(13px);
		transition: 0.3s;
        box-shadow: -3px 3px 3px rgba(0, 0, 0, 0.25);
    }
    a.sidebtn02 {
        background: #e3007f;
    }
	a::after {
		content: '';
		display: inline-block;
		height: 10px;
		width: 15px;
		clip-path: polygon(0 0, 50% 100%, 100% 0);
		background: #fff;
		margin-top: 10px;
	}
	a:hover {
		transform: translateX(3px);
		transition: 0.3s;
	}
}


body.favorite.pc #contents .inner #contents-main .html1 > div{
	bottom: 132px;
	width: 720px;
}
body.favorite.pc #contents .inner #contents-main article .content1 + section > div  {
	width: 700px;
	padding: 40px 0 30px;
	top: -180px;
	margin-bottom: -150px;
}
body.favorite.pc #contents .inner #contents-main article .content1 + section > div h3 {
	width: 420px;
	margin-bottom: 15px;
}

body.favorite.pc #contents .inner #contents-main .feature + .btn_vote {
    font-size: 20px;
    line-height: 2.2rem;
    padding-top: 75px;
    box-sizing: border-box;
}
body.favorite.pc #contents .inner #contents-main .feature + .btn_vote::before{
    aspect-ratio: 506 / 127;
    width: 470px;
    margin: auto;
    padding-bottom: 20px;
}
body.favorite.pc #contents .inner #contents-main .feature + .btn_vote a {
    line-height: 5rem;
    width: 460px;
    margin: 20px auto 30px;
    position: relative;
}
/* PC アイテムリスト */
body.favorite.pc #contents .inner #contents-main .NewsItemList .item {
    float: none;
    height: auto;
    width: 430px;
    margin: auto;
}

body.favorite.pc #contents .inner #contents-main .NewsItemList .detail2 {
    padding: 0 30px;
    box-sizing: border-box;
    width: 400px;
    margin: 10px auto;
    margin-bottom: 45px;
}
body.favorite.pc #contents .inner #contents-main .NewsItemList .item .name {
}
body.favorite.pc #contents .inner #contents-main .NewsItemList .detail2 p.goodsname {
    text-align: justify;
    border-bottom: dotted 2px #999;
    padding-bottom: 12px;
    margin-bottom: 15px;
}
body.favorite.pc #contents .inner #contents-main .NewsItemList .item .goods_like_btn.mini p {
    padding: 8px;
    width: 45px;
    height: 45px;
}

body.favorite.pc  #contents .inner #contents-main .box_caution {
    padding: 20px 30px 50px;
    position: relative;
    z-index: 30;
}

body.favorite.pc #contents #favorite .item {
    width: 400px;
    height: auto;
    margin: auto;
    padding-top: 0;
}
body.favorite.pc #contents #favorite .item .image {
    width: 340px;
    height: auto;
    box-sizing: border-box;
}
body.favorite.pc #contents .inner #contents-main #favorite .item .desc {
    width: 340px;
}



body.favorite.pc .footer.shopsearch,body.favorite.pc .bnrArea, .pc .colGuide, .foot_group-sns {
    position: relative;
    z-index: 20;
}


/*参加方法*/
body.favorite.pc section.entry > div {
    width: 720px;
    padding: 20px;
    box-sizing: border-box;
    img {
        width: 80%;
        margin-top: 20px;
    }
    h3{
        height: 50px;
        width: auto;
    }
}

/* SPのみ */
body.favorite.sp #contents > .inner{
    padding:0;
}
/* SPアンカーボタン */
body.favorite.sp section.sidebtn {
	position: sticky;
	top: 50px;
	right: 0;
	z-index: 100;
	margin-bottom: 50px;
	div{
	position: absolute;
	display: flex;
	top: -50px;
	width: 100%;
	box-shadow: 0px 3px 3px rgba(0, 0, 0, 0.25);
	}
    a {
        display: block;
        background: #46827c;
        border: 3px solid #fff;
        padding: 10px;
		flex:1;
        border-radius: 0;
        font-weight: bold;
        color: #fff;
        letter-spacing: 0.1rem;
        font-size: 16px;
		text-align: center;
    }
    a.sidebtn02 {
        background: #e3007f;
        border-right: 0;
    }
	a::after {
		content: '';
		display: inline-block;
		height: 10px;
		width: 15px;
		clip-path: polygon(0 0, 50% 100%, 100% 0);
		background: #fff;
		margin-top: 10px;
	}
}

body.favorite.sp #contents .inner #contents-main .html1 > div{
	bottom: 5%;
	width: 95%;
}
body.favorite.sp #contents .inner #contents-main article .content1 + section > div  {
	width: calc(100% - 30px);
	padding: 30px 0;
	top: -65px;
	margin-bottom: -65px;
}
body.favorite.sp #contents .inner #contents-main article .content1 + section > div h3 {
	width: calc(100% - 40px);
	margin-bottom: 0px;
}
body.favorite.sp #contents .inner #contents-main .feature + .btn_vote {
    background-image: url(bg-touhyou_sp.jpg);
    aspect-ratio: 180/211;
    background-position: center;
    background-size: cover;
    text-align: center;
    font-weight: bold;
    padding-top: 40px;
    box-sizing: border-box;
}
body.favorite.sp #contents .inner #contents-main #favorite .item::before {
    content: '';
    display: block;
    width: 80px;
    aspect-ratio: 126 / 112;
    margin: auto;
	top: 27px;
    left: 0px;
}
body.favorite.sp #contents .inner #contents-main .NewsItemList .item .news_box:before {
    top: -27px;
    left: -10px;
    padding: 15px 12px 35px 38px;
    
    max-height: 85px;
    max-width: 85px;
}
body.favorite.sp #contents .inner #contents-main .NewsItemList .item:before{
    content: "NO.";
    position: absolute;
    z-index:20;
    top: 13px;
    left: 22px;
    font-weight: bold;
}
body.favorite.sp #contents .inner #contents-main .NewsItemList .item:after {
    top: 39px;
    left: 22px;
    max-width: 85px;
}
body.favorite.sp #contents .inner #contents-main .feature + .btn_vote::before{
    aspect-ratio: 506 / 127;
    width: calc(100% - 60px);
    margin: auto;
    padding-bottom: 10px;
}
body.favorite.sp #contents .inner #contents-main .goods_like_btn.mini p:has(.fas) {
  background: #FFF000;
}
body.favorite.sp #contents .inner #contents-main article .content1 + section::before, body.favorite.sp #contents .inner #contents-main section.current-rank::before,body.favorite.sp #contents .inner section.entry::before{
	top: -13px;
}
body.favorite.sp #contents #favorite {
	width: calc(100% - 40px);
}
body.sp #contents-main .NewsItemList .item {
    padding: 20px;
}

/*参加方法*/
body.favorite.sp {
    background:#fdd424;
    position: relative;
    z-index: 10;
    /*padding: 0px 0 60px;*/
    div {
        /*background:#fff;
        border-radius: 10px;*/
    }
}
body.favorite.sp section.entry > div {
    width: calc(100% - 40px);
    padding: 20px 40px;
    box-sizing: border-box;  
    img {
        width: 100%;
        margin-top: 20px;
    }
    h3{
        height: 50px;
        width: auto;
    }
    
}

body.favorite.sp footer .footer-navi .footer-navi_ul,
body.favorite.sp footer .footer-navi .btn_colclub{
    display: none;
}
body.favorite.sp .to-top {
    bottom: 10px;
}

.is-bounce {
	animation: 4s 0s bound ease-in;
}
@keyframes bound {
	19%,
	20%,
	27%,
	30% {
		-webkit-transform: translate(0);
		        transform: translate(0);
	}
	24% {
		-webkit-transform: translateY(-10px);
		        transform: translateY(-10px);
	}
	29% {
		-webkit-transform: translateY(-5px);
		        transform: translateY(-5px);
	}
}

