@charset "UTF-8";

/*- campaign -*/
.campaign_contents .main {
	background-color: #fffbe8;
	width: 1000px;
	padding: 0 0 20px 0;
}

#footer .footer {
    margin-bottom: -20px;
}

.caution{
	font-size: 80%;
	width: 90%;
	margin: 0 auto;
}
.mt10{
	margin-top: 10px;
}
.mt15{
	margin-top: 15px;
}
.mt20{
	margin-top: 20px;
}
.mt30{
	margin-top: 30px;
}
.mb20{
	margin-bottom: 20px;
}
.mb30{
	margin-bottom: 30px;
}
ul.lb{
	width: 1000px;
}
ul.lb>li{
	position: relative;
	display: inline-block;
	width: 400px;
	text-align: center;
	vertical-align: top;
	margin: 40px 40px 50px 50px;
}
ul.lb li img.toppict{
	border: 1px solid #b78f72;
}
p.name{
	font-size: 20px;
	margin: 0 0 8px 0;
}
ol.set{
	counter-reset: my-counter;
	margin: 0 0 18px 30px;
}
ol.set li{
	text-align: left;
	font-size: 16px;
	line-height: 1;
	padding-left: 25px;
	margin-bottom: 8px;
	position: relative;
}
ol.set li span{
	font-size: 12px;
}
ol.set li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	background-color: #ef6a34;
	border: 1px solid;
	border-radius: 50%;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 20px;
	width: 20px;
	color: #fff;
	font-size: 75%;
	line-height: 1;
	position: absolute;
	top: -4px;
	left: 0;
}
ol.present{
	position: relative;
	background-color: #fffbe8;
	padding: 18px 10px 15px 50px;
	margin: 10px 0 15px 35px;
	width: 330px;
	counter-reset: my-counter;
}
ol.present::after{
	position: absolute;
	top: -8px;
	left: -8px;
	content: '';
	width: 88px;
	height: 74px;
	background-image: url(../img/campaign/202103home/ribbon_present.png);
	background-repeat: no-repeat;
	background-size: contain;
	vertical-align: middle;
}
ol.present li{
	text-align: left;
	font-size: 16px;
	line-height: 1.5;
	padding-left: 25px;
	position: relative;
}
ol.present li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	background-color: #fff;
	border: 1px solid;
	border-radius: 50%;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 18px;
	width: 18px;
	color: #ef6a34;
	font-size: 70%;
	line-height: 1;
	position: absolute;
	top: 1px;
	left: 0;
}
ol.present li.one{
	line-height: 2.5;
}
ol.present li.one:before {
	top: 8px;
	left: 0;
}
ul.lb li .discount{
    font-size: 200%;
    color: #d90f1c;
    line-height: 1;
    font-weight: 600;
    margin-bottom: 10px;
}
ul.lb li .discount b{
	font-size: 150%;
}
ul.lb li .price{
	line-height: 1.2;
	font-size: 18px;
	font-weight: 500;
}
ul.lb li .price b{
	font-weight: 600;
	font-size: 160%;
}
ul.lb li .price span{
	font-weight: 600;
	color: #d90f1c;
}
ul.lb li .price span b{
	font-size: 160%;
}
ul.lb li .price small{
	font-size: 80%;
}
ul.lb li .bt{
	width: 230px;
	height: 36px;
	line-height: 36px;
	margin: 15px auto 0;
	padding: 0;
	font-size: 100%;
	background-color: #000;
	color: #fff;
	box-sizing: border-box;
	border-radius: 0;
}


h4.glaybg{
	background-color: #e8e8e8;
	color: #333;
	font-style: italic;
	font-size: 200%;
	font-weight: 500;
	padding: 5px 0;
	margin: 0 1%;
}
h4.glaybg .red{
	font-size: 1.3em;
	color: #d13434;
	font-weight: 600;
}
.glaybox{
	border: #e8e8e8 solid 5px;
	border-top: none;
	padding: 5px 5% 0px;
	margin: 0 1% 40px;
}
.glaybox a{
	display: block;
}
.glaybox p{
	margin: 30px auto 10px;
	font-size: 1.5em;
}
#machine .coupon{
	margin-bottom: 60px;
}
#machine .coupon:last-child{
	margin-bottom: 20px;
}

h4.glay{
	padding: 0;
	margin: 0 1% 0;
	font-size: 0;
}
.glaybox.tworows{
	padding: 5px 1% 0px;
	margin: 0 1% 40px;
}
.glaybox.tworows .bt-coupon{
	padding: 0 5%;
}
.glaybox.tworows .cp-item a{
	display: inline-block;
	vertical-align: top;
	width: 46%;
	margin: 0 1% 20px;
}
.glaybox.cellphel{
	padding: 5px 1% 0px;
	margin: 0 1% 40px;
}
.glaybox.cellphel .coupon{
	width: 92%;
}
.glaybox.cellphel .mt20{
	margin: 20px auto 5px;
	width: 92%;
}
.glaybox.cellphel .cp-item a{
	display: inline-block;
	vertical-align: top;
	width: 46%;
	margin: 0 1% 20px;
}

/*- SALE -*/
.campaign_contents.ss{
	width: 920px;
	margin: 0 auto;
	text-align: center;
}
.campaign_contents.ss h2{
    margin-bottom: 20px;
    padding: 0!important;
}
.campaign_contents.ss section{
	padding: 30px 0 0 0;
}
.campaign_contents.ss .notice{
	font-size: 14px;
}
.campaign_contents .mb40{
	margin-bottom: 40px!important;
}
.campaign_contents .mb20{
	margin-bottom: 20px!important;
}
.campaign_contents.ss .main {
	background-color: #fff;
	width: 100%;
	padding: 00;
	margin: 0;
}
.campaign_contents.ss ul.ssmenu{
	width: 100%;
}
.campaign_contents.ss ul.ssmenu li{
	width: 24.5%;
	display: inline-block;
	text-align: center;
}
.campaign_contents.ss ul.ssmenu li img{
	width: 214px;
}
.campaign_contents.ss ul.lineup li{
	display: inline-block;
	vertical-align: top;
	width: 30%;
	padding: 0 1% 1%;
}
.campaign_contents.ss ul.lineup li img{
	border: 1px solid #e5daaf;
}
.campaign_contents.ss #HAPPYBAG ul.lineup li, .campaign_contents.ss #KYOUSAN ul.lineup li, .campaign_contents.ss #CELLPHELBOX ul.lineup li{
	width: 45%;
	padding: 0 2% 2%;
}
.campaign_contents.ss p{
	line-height: 1.2;
}
.campaign_contents.ss p span.tax{
	font-size: 10px;
}
.campaign_contents.ss p span.name{
	font-size: 22px;
}
.campaign_contents.ss p span.price{
	font-size: 26px;
	color: #d13434;
	font-weight: 600;
}
.campaign_contents.ss .link{
	width: 100%;
	margin: 30px auto;
	font-size: 20px;
}
.campaign_contents.ss #START a img, .campaign_contents.ss #LAST a img, .campaign_contents.ss #ITEM6 .bn{
    width: 700px;
}
.campaign_contents.ss #LAST .aboutcp{
    width: 810px;
    margin: auto;
    border: 1px solid #297380;
    background-color: #eef8fa;
    padding: 20px 20px 15px;
}
.campaign_contents.ss #LAST .aboutcp img{
    display: inline-block;
    width: 45%;
    border: 5px solid #fff;
}
.campaign_contents.ss #LAST .aboutcp p.text{
    display: inline-block;
    vertical-align: top;
    width: 50%;
    padding: 0 0 0 20px;
    font-size: 20px;
    line-height: 28px;
    font-family: Georgia, 'Times New Roman', Times, serif;
}
.campaign_contents.ss #LAST .aboutcp p.text .blue{
    color: #297380;
    font-weight: bold;
}
.campaign_contents.ss #LAST .aboutcp p.text .name{
	font-family: "Montserrat","游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
    font-size: 24px;
}
.campaign_contents.ss #LAST .aboutcp p.text .small{
	font-family: "Montserrat","游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
    font-size: 14px;
}
.campaign_contents.ss #LAST ul{
    width: 100%;
    padding: 30px 0 0;
}
.campaign_contents.ss #LAST ul li{
    display: inline-block;
    width: 29%;
    padding: 0 1%;
}
.campaign_contents.ss .itemarrow{
    font-size: 26px;
    text-align: center;
    line-height: 170%;
}
.campaign_contents.ss #CELLPHELBOX .link img{
	width: 80%;
	margin: 0px auto;
}
.campaign_contents.ss #WRAPPING .link{
	width: 100%;
	margin: 0px auto;
}

/*- 2020-21スペシャルアーバンWEEK -*/
.campaign_contents.spweek .main {
	background-color: #fff;
}
.campaign_contents.spweek .main .submain {
	width: 90%;
}
.campaign_contents.spweek .couponbox{
	width: 980px;
	background-color: #fcf7e3;
	padding: 10px 0 0;
	margin: auto;
}
.campaign_contents.spweek .couponbox li{
	display: inline-block;
	margin: 0 9px 0 10px;
}

/*-  linefriend  -*/
#linefriend {
	text-align: center;
}
#linefriend img{
	display: block;
	margin:0 auto;
}
#linefriend a{
	opacity: 1;
}
#linefriend .btline img{
	margin-top: 5px;
	width: 687px;
}
#linefriend dl dd{
	display: inline-block;
	width: 45%;
	margin: 50px 2% 10px;
}
#linefriend #friend{
	margin-bottom: 50px;
}



/*- 21-22福袋 -*/
.campaign_contents.happybag{
	margin-top: 0!important;
}
.campaign_contents.happybag .main {
    background-color: #fff;
}
.menubag{
	width: 100%;
}
.menubag li{
	display: inline-block;
	width: 24.5%;
}
#contents .hbarea{
	text-align: center;
	padding: 50px 0 0;
}
#contents .salon.hbarea{
	padding: 0;
}
#contents h2{
	padding: 0;
	margin: 0;
}
#contents .main h2{
    padding: 20px 0 30px;
}
.hb li{
	display: inline-block;
	vertical-align: top;
	width: 49%;
	margin-bottom: 70px;
}
#SALON .hb li{
	display: block;
	width: 100%;
}
.happybag a:hover {
    opacity: 1!important;
    text-decoration: none;
}
button{
    width: 330px;
    line-height: 2.3em;
    background-color: #c91832;
    color: #fff;
    font-size: 1.5em;
    border-radius:5px;
    border: 1px solid #c91832;
}

/*- 感謝祭 -*/
.campaign_contents.thanks{
	width: 765px;
	margin: 0 auto;
	text-align: center;
}
.campaign_contents.ss section{
	padding: 0;
}
.campaign_contents.ss #CAM02 .coupon {
    margin: 0 50px 20px;
}
.campaign_contents.ss .coupon {
    margin-bottom: 30px;
}
.campaign_contents.thanks .listlink{
	margin-bottom: 50px;
}
.campaign_contents.thanks .listlink a{
	text-decoration: underline;
	font-size: 1.6em;
}
.campaign_contents.ss .anchor{
	width: 765px;
	margin: 0 auto 50px;
}
.campaign_contents.ss .anchor dd{
	width: 31%;
	display: inline-block;
	margin-right: 2%;
	vertical-align: top;
}
.campaign_contents.ss .anchor dd:last-child{
	margin-right: 0;
}


@media screen and (max-width: 760px){

	.mt10{
		margin-top: 7px;
	}
	.mt15{
		margin-top: 10px;
	}
	.mt20{
		margin-top: 14px;
	}
	.mt30{
		margin-top: 20px;
	}
	.mb20{
		margin-bottom: 14px;
	}
	.mb30{
		margin-bottom: 20px;
	}
	.caution{
		margin: 0 auto 20px;
	}
	.campaign_contents .main {
		width: 100%;
		padding: 0 0 15px 0;
		margin-bottom: 0px;
	}
	.campaign_contents .main p.center{
		width: 80%;
		margin: auto;
	}
	ul.lb{
		width: 100%;
	}
	ul.lb>li{
		display: block;
		width: 86%;
		margin: 0px auto 40px;
	}
	ul.lb>li::after{
		top: -10vw;
		left: -13%;
		width: 80%;
		height: 80%;
	}
	p.name{
		font-size: 4.8vw;
		margin: 0 -10% 8px -12%;
	}
	ol.set{
		margin: 0 0 18px 0px;
	}
	ol.set li{
		font-size: 4vw;
		padding-left: 22px;
		margin-bottom: 4px;
	}
	ol.set li span{
		font-size: 3vw;
	}
	ol.set li:before {
		height: 18px;
		width: 18px;
		font-size: 75%;
		line-height: 1;
		top: -3px;
		left: 0;
	}
	ol.present{
		padding: 15px 5px 12px 50px;
		margin: 15px 0 15px 0px;
		width: 100%;
	}
	ol.present::after{
		top: -7px;
		left: -5px;
		width: 88px;
		height: 74px;
	}
	ol.present li{
		text-align: left;
		font-size: 4.5vw;
		line-height: 1.5;
		padding-left: 25px;
		position: relative;
	}
	ol.present li:before {
		height: 16px;
		width: 16px;
		font-size: 70%;
		line-height: 1;
		top: 2px;
		left: 0;
	}
	ul.lb li .price{
		line-height: 1.3;
		font-size: 4vw;
	}
	ul.lb li .bt{
		width: 70%;
		height: 34px;
		line-height: 34px;
		margin: 10px auto;
		padding: 0;
		font-size: 120%;
		background-color: #000;
		color: #fff;
	  }

	.campaign_contents.ss{
		width: 100%;
		margin: 0 auto;
		text-align: inherit;
	}
	.campaign_contents.ss section{
		padding: 30px 0 0 0;
		text-align: center;
	}
	.campaign_contents.ss .notice{
		font-size: 3vw;
		text-align: center;
	}
	.campaign_contents .mb40{
		margin-bottom: 20px!important;
	}
	.campaign_contents .mb20{
		margin-bottom: 10px!important;
	}
	.campaign_contents.ss .main {
		width: 100%;
		padding: 0;
	}
	.campaign_contents.ss ul.ssmenu{
		width: 98%;
		margin: 0 auto;
		text-align: center;
	}
	.campaign_contents.ss ul.ssmenu li{
		width: 23%;
		display: inline-block;
	}
	.campaign_contents.ss p span.tax{
		font-size: 2vw;
	}
	.campaign_contents.ss p span.price{
		font-size: 3.6vw;
	}
	.campaign_contents.ss p span.name{
		font-size: 4vw;
	}
	.campaign_contents.ss .link{
		width: 84%;
		margin: 15px auto;
		font-size: 4vw;
	}
	.campaign_contents.ss #WRAPPING .link{
		width: 84%;
		margin: 0px auto;
	}
    .campaign_contents.ss #START a img, .campaign_contents.ss #LAST a img, .campaign_contents.ss #ITEM6 .bn{
        width: 84%;
    }
	.campaign_contents.ss #VARIETY p img, .campaign_contents.ss #P44 p img{
		width: 84%;
	}

	.campaign_contents.spweek .main .submain {
		width: 100%;
	}
	.campaign_contents.spweek .couponbox{
		width: 100%;
		background-color: #fcf7e3;
		padding: 10px 0 5px 1%;
		margin: auto;
	}
	.campaign_contents.spweek .couponbox li{
		display: inline-block;
		margin: 0 0 0 1%;
		width: 31%;
	}
	.campaign_contents.spweek .main p.center {
    width: 95%;
    margin: auto;
	}
	.campaign_contents.spweek p.notice{
		font-size: 80%;
	}
	.campaign_contents.spweek img.arrow{
		width: 7px;
	}
	
	/*-  linefriend  -*/
	#linefriend .lineac{
		text-align: center;
	}
	#linefriend .btline img{
		margin-top: 5px;
		width: 90%;
	}
	#linefriend dl dd{
		display: inline-block;
		width: 45%;
		margin: 40px 2% 10px;
	}
	#linefriend #friend{
		margin-bottom: 30px;
	}

	/*- 20-21福袋 -*/
	.menubag{
		width: 100%;
	}
	.menubag li{
		display: inline-block;
		width: 48%;
	}
	#contents .hbarea{
		text-align: center;
		padding: 25px 0 0;
	}
    #contents .main h2 {
        padding: 5px 0 10px;
    }
	.hb li{
		display: block;
		width: 100%;
		margin-bottom: 40px;
	}
    form table{
        width: 90%;
        margin: 0 auto;
    }
    form table td:nth-child(2){
        width: 70%;
    }
    button{
        width: 100%;
    }

	/*- 感謝祭 -*/
	.campaign_contents.ss .coupon {
		margin-bottom: 20px;
	}
	.campaign_contents.ss #CAM02 .coupon {
		margin: 0 3% 10px;
	}
	.campaign_contents.ss section {
		padding: 0;
		text-align: center;
	}
	.campaign_contents.thanks .listlink{
		margin-bottom: 30px;
	}
	.campaign_contents.thanks .listlink a{
		text-decoration: underline;
		font-size: 1.4em;
	}
	.campaign_contents.ss .anchor{
		width: 97%;
		margin: 0 0 30px 2%;
	}

}