@charset "UTF-8";

/*-----------------------------------------*/
/* reset
/*-----------------------------------------*/
html {
  font-size: 62.5%;
}

h1, h2, h3, p, dl, dt, dd {
    margin: 0;
    padding: 0;
}

ul,ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

img {vertical-align: top;}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

label {cursor: pointer;}

textarea, input, select {
    border: 1px solid #ccc;
    padding: 2px;
}

hr {
    height: 0;
    margin: 0;
    padding: 0;
    border: 0;
}

button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

/*-----------------------------------------*/
/* layout
/*-----------------------------------------*/
body{
 font-family: Verdana, Roboto, 'Droid Sans', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;
 font-size: 1.6rem;
 line-height: 1.6;
 color: #333;
 background:#7CBD24;
}

img{
	width: auto;
	max-width: 100%;
	height: auto;
}
#wrapper {
	padding: 0 0 64px;
}

.textIndent{
	padding-left: 1em;
	text-indent: -1em;
}

.attTxt{
	color: #E60012;
	font-weight: bold;
	font-size: 1.6rem;
}
.pcNone{display: none !important;}
.spNone{display: block !important;}
@media screen and (max-width:600px) {
	.pcNone{display: block !important;}
	.spNone{display: none !important;}
	#wrapper {
	padding: 10px 0 64px;
}
}

/*----------------------------*/
/*ボタン
/*----------------------------*/

.btn {
	position: relative;
	text-align: center;
	display: block;
	color: #fff;
	background-color: white;
	padding: 15px 40px;
	text-decoration: none;
	line-height: 1.0;
	vertical-align: middle;
	box-sizing: border-box;
	border-radius: 4px;
	-webkit-transition: none;
	transition: none;
	box-shadow: 0 3px 0 #d0c8c8;
	text-shadow: 0 1px 1px rgba(0, 0, 0, 0.4);
	margin: auto;
}

.btn input {
	cursor: pointer;
	color: #fff;
	line-height: 1.0;
	border: none;
	padding: 0;
	background: transparent;
}

.btn:hover {
	top: -4px;
	box-shadow: 0 7px 0 #d0c8c8;
}
.btn:active {
	top: 3px;
	box-shadow: none;
}

.btn:before {
	position: absolute;
	content: "";
	vertical-align: middle;
	right: 32px;
	top: 50%;
	margin-top: -8px;
	width: 16px;
	height: 16px;
	border-top: 4px solid #fff;
	border-right: 4px solid #fff;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);

}

/*ボタン赤色*/
.btn.btn_entry {
	background-color: #E60012;
	border-radius: 50px;
	font-weight: bold;
	font-size: 2.6rem;
	font-kerning: normal;
	letter-spacing: 0.1em;
	box-shadow: 0 3px 0 #9a000c;
	cursor: pointer;
}
.btn.btn_entry:hover {
	top: -4px;
	color: #E60012 !important;
	background-color: #FFF100;
	box-shadow: 0 7px 0 #b3a900;
}
.btn.btn_entry:hover input{color: #E60012;}
.btn.btn_entry:hover:before {
	color: #E60012;
	border-color: #E60012;
}
.btn.btn_entry:active {
	top: 4px;
	box-shadow: none;
}
.btn.btn_entry a:link {
	color: #fff;
	text-decoration: none;
}
.btn.btn_entry a:visited {
	color: #fff;
	text-decoration: none;
}
.btn.btn_entry a:hover {
	color: #fff;
	text-decoration: none;
}
.btn.btn_entry a:active {
	color: #fff;
	text-decoration: none;
}
.btn.btn_entry:before {right: 32px;}
.btn.btn_entry input {
	font-weight: bold;
	font-size: 2.6rem;
	font-kerning: normal;
	letter-spacing: 0.1em;
}
.btn.btn_entry input:hover {
	color: #E60012;
}

/*ボタングレー*/
.btn.btn_back {
	background-color: #9a9a9a;
	border-radius: 50px;
	font-weight: bold;
	font-size: 2.6rem;
	font-kerning: normal;
	letter-spacing: 0.1em;
}
.btn.btn_back:before {
	left: 32px;
	margin-top: -8px;
	-webkit-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
.btn.btn_back input {
	font-weight: bold;
	font-size: 2.6rem;
	font-kerning: normal;
	letter-spacing: 0.1em;
}

/*ボタン黄色*/
.btn.btn_yellow{
	background-color: #FFF100;
	border-radius: 50px;
	font-weight: bold;
	font-size: 2.6rem;
	font-kerning: normal;
	letter-spacing: 0.1em;
	box-shadow: 0 3px 0 #b3a900;
	cursor: pointer;
	color: #E60012;
}
.btn.btn_yellow:hover {box-shadow: 0 7px 0 #b3a900;}
.btn.btn_yellow:active {box-shadow: none;}
.btn.btn_yellow:before {
	color: #E60012;
	border-color: #E60012;
}

/*ボタン横並び2*/
.btnWrap.column2{
	text-align: center;
}

.btnWrap.column2{
	display: flex;
	display: -webkit-flex;
	width: 100%;
}
.btnWrap.column2 li{
	width: 50%;
	padding: 0 16px;
  float: left;
}

@media screen and (max-width:600px) {
	.btnWrap.column2 {
		display: block;
		padding-bottom: 16px;
	}
	.btnWrap.column2 li{
		width: 100%;
		margin: 16px 0 0;
	}
}
/*-----------------------------------------*/
/* header
/*-----------------------------------------*/
#headerWrap {
	background-repeat: no-repeat;
	background-size: cover;
}
#header{
	max-width: 980px;
	margin: 0 auto;
	padding-bottom: 10px;
}
#header h1{
 margin-bottom: 10px;
}
#header .Header-notes {
  text-align: center;
  font-weight: bold;
  border-radius: 100px;
  font-size: 2.4rem;
  color: #ffffff;
  width: 980px;
  max-width: 100%;
  margin: 0 auto 20px;
}

@media screen and (max-width:600px) {
	#header{
	padding: 0 10px 10px;
	box-sizing: border-box;
	}
	#header .Header-notes {
		margin: 0 auto;
		font-size: 1.5rem; padding: 0 12px;
	}
}


/*--------------------------------------------*/
/* box
/*--------------------------------------------*/
.contentsBox{
	max-width: 980px;
	margin: 0 auto;
	background: #fff;
	padding: 24px 20px 20px;
	border-radius: 20px;
}
.contentsBox.blue {
 background-color: #003894;
}
.boxWhite{
	width: 100%;
	background: #fff;
	padding: 20px 20px 40px;
	font-size: 1.4rem;
}

@media screen and (max-width:600px) {
	.contentsBox{
		padding: 12px;
		margin: 0 12px;
	}
	.boxWhite{
		padding: 12px;
	}
}

/*--------------------------------------------*/
/* leadTitle & leadTxt
/*--------------------------------------------*/
h2.leadTitle{
	font-size: 2.8rem;
	color: #fff;
	text-align: center;
	margin-bottom: 5px;
}
.leadTitle span.small{font-size: 2rem;}
.leadTxt{
 font-size: 2rem;
 font-weight: bold;
 text-align: center;
 color: #003894;
 background: #fff;
 border-radius: 25px;
 padding: 6px 16px;
 max-width: 940px;
 margin: 0 auto 24px;
}
.leadTxt span.small{font-size: 1.3rem;}
.leadBox{
	padding: 14px;
	background: #f3f1f1;
	margin-bottom: 16px;
}

.leadBox h3{
	font-size: 2.2rem;
	font-weight: bold;
}

.leadCircle{
 font-size: 2rem;
 padding-bottom: 2px;
 border-bottom: 2px solid #003894;
 position: relative;
 padding-left: 20px;
}

.leadCircle::before{
	position: absolute;
	display: block;
	content: "";
	width: 14px;
	height: 14px;
	background: #003894;
	border-radius: 25px;
	top: 10px;
	left: 0;
}

@media screen and (max-width:600px) {
	h2.leadTitle{font-size: 2rem;}
	h2.leadTitle .small {font-size: 1.2rem;}
	.leadTxt{font-size: 1.4rem; margin-bottom: 12px;}
	.leadBox{padding: 10px;}
	.leadBox h3{font-size: 1.8rem;}

	.leadCircle{font-size: 1.6rem;}
	.leadCircle::before{top: 6px;}
	}

/*--------------------------------------------*/
/* マーク関係
/*--------------------------------------------*/
.mark{position: relative;}
.mark::before{
	display: block;
	content: "";
	position: absolute;
}

.square{
	padding-left: 26px;
}
.square::before{
 width: 20px;
 height: 20px;
 border: 5px solid #E60012;
 top: 7px;
 left: 0;
}


@media screen and (max-width:600px) {
	.square::before{
		width: 16px;
		height: 16px;
		border: 4px solid #E60012;
		top:7px;
		left:0;
	}
}

/*----------------------------------------*/
/* index
/*----------------------------------------*/
.topPage .contentsBox{padding-bottom: 20px;}

/*応募期間*/
.entry{
	max-width:980px;
	margin:0 auto 40px;
	background-color:#FFF;
	padding:20px;
	border-radius: 20px;
}

.entry.last{
	padding: 40px 20px;
	margin: 0 auto;
}

.term:first-child {
	border-bottom: dotted 2px #333;
	padding-bottom: 20px;
}

.term img,
.deadline img{
	margin-right: 10px;
	vertical-align: middle;
	float: left;
}
.term span {
	padding-top: 15px;
	display: block;
	float: left;
}

.term img:first-child,
.deadline img:first-child{width: 120px;}
.deadline{margin:20px 0;}
.entryText{
	padding: 20px 0 0;
	font-size: 1.3rem;
}

.entry .btn.btn_entry{
	font-size: 5rem;
	box-shadow: 0 7px 0 #9a000c;
}

.entry .btn.btn_entry:hover{box-shadow: 0 11px 0 #b3a900;}
.entry .btn.btn_entry:active {box-shadow: none;}

.closeText {
	font-size: 2.6rem;
	font-weight: bold;
	margin-bottom: 20px;
	text-align: center;
}
@media screen and (max-width:600px) {
	.term img.termImg,.deadline img.termImg {width: 60px;}
	.entry,
	.entry.last{margin-right: 12px; margin-left: 12px;}
	.term img:first-child,
	.deadline img:first-child{margin-bottom: 10px;}
	.term span{display: block;text-align: right;padding: 10px 0;float: right;}
	.entry .btn.btn_entry{font-size: 3rem;}
	.closeText {
	font-size: 1.6rem;
	font-weight: bold;
	margin-bottom: 20px;
	text-align: center;
	}
	.term:first-child {
	padding-bottom: 0;
	}
}


/*キャンペーン概要*/
#campaign .boxWhite{
	padding: 0;
	margin: -2px;
}
.cpBox{
	display: table;
	width: 100%;
}
.cpBox > p,
.cpBox > div{
	display: table-cell;
	padding: 18px;
	border: 2px solid #003894;
	width: 50%;
	vertical-align: top;
}
.cpBox img{width: 100%;}
.separate .cpRight{padding: 0}
.separate .cpRight p{padding: 14px 18px;}
.separate .cpRight p:first-child{border-bottom: 2px solid #003894;}
.separate .cpRight p:last-child{border-top: 2px solid #003894;}

.cpTxt{
	max-width: 980px;
	margin: 10px auto 40px;
	font-size: 1.3rem;
	color: #fff;
}



@media screen and (max-width:600px) {
	.cpBox,
	.cpBox > p,
	.cpBox > div{display: block; width: 100%;}
	.cpTxt{margin: 0 12px 30px;}
 
	#campaign{padding-bottom:10px;}
	.campaignImages {
	width: 100%;
	margin: 0 auto 20px;
	}
	.campaignImg {
	width: 200px;
	margin: 0 auto 20px;
	float: none;
	}
	.campaignText {
	width: 100%;
	max-width: 100%;
	margin: 0 auto 20px;
	float: none;
	}
	.cpBox01 {
	width: 100%;
	border-bottom: 10px solid #A28244;
	}
	.cpBox02 {
	width: 100%;
	border-right: none;
	border-bottom: 10px solid #A28244;
	float: none;
	}
	.cpBox03 {
	width: 100%;
	float: none;
	}
	/*Wチャンス　キャンペーン*/
	#campaignW {
	width: auto;
	margin: 0 12px 20px;
	}

	/*バナー　アンケート*/
	#bnrEnquete {
	width: auto;
	margin: 0 12px 20px;
	}
}

/*協賛メーカー*/
#maker {margin-bottom: 40px;}
#maker .leadTitle{margin-bottom: 20px;}
#maker .boxWhite{padding-bottom: 20px;}
.makerBox{
	background: #f3f1f1;
	padding: 16px 8px;
	margin-top: 24px;
	text-align: center;
}
.makerBox li .btn{
  margin-top: 15px;
  font-size: 2rem;
}
@media screen and (max-width:600px) {
 .makerBox li .btn{
  font-size: 1.4rem;
  margin-top: 0;
}
}

/*応募要項-------------------------------*/
#guideline{margin-bottom: 64px;}
#guideline .leadTitle{margin-bottom: 20px;}
#guideline .boxWhite > div:not(:last-child){padding-bottom: 32px;}

@media screen and (max-width:600px) {
	#guideline{margin-bottom: 24px;}
	#maker {margin-bottom: 20px;}
}

/*応募要項 :ネット*/
#guideline .step{
	border: solid 3px #E60012;
	border-radius: 20px;
	margin-bottom:30px;
}
#guideline .stepTitle{
 padding: 10px 20px;
 border-bottom: dotted 3px #E60012;
 text-align: center;
 color: #E60012;
 font-size: 20px;
 font-weight: bold;
 margin: 0;
}

.stepBox{
	padding: 20px;
	font-size: 1.4rem;
	position: relative;
}

.stepBox::after{
	display: block;
	content: '';
	position: absolute;
	bottom: -38px;
	left: 50%;
	margin-left: -14px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14px 14px;
	border-color: #E60012 transparent transparent transparent;
}

.stepLead{
	padding: 10px 20px;
	color: #E60012;
	font-size: 1.8rem;
	font-weight: bold;
	border-radius: 25px;
	background: #f3f1f1;
	margin-bottom: 16px;
}

.receiptBox{display: table; padding-bottom: 20px;}
.receiptBox > div{display: table-cell; vertical-align: top;}
.receiptBox > div:last-child{width: 48%; padding-left: 20px;}
.receiptBox > div:last-child img{width: 100%;}

.step03 dd{padding-bottom: 20px;}
.step03 .stepBox::after{display: none;}

@media screen and (max-width:600px) {
	.receiptBox,
	.receiptBox > div{display: block;}
	.receiptBox > div:last-child{width: 100%; padding: 16px 0 0;}
	.stepBox{padding: 12px;}
}

/*応募要項 :郵送*/
#caseMail{
	font-size: 1.4rem;
}

#caseMail .mailNotes{
	font-size: 1.4rem;
	margin-top:20px;
	padding-left: 1em;
	text-indent: -1em;
}

#caseMail .camAdd {
	border: solid 3px #dadada;
	text-align: center;
	margin: 24px 0 0;
}

#caseMail dt{
	font-size: 2.0rem;
	margin:10px auto;
	padding-bottom:10px;
	border-bottom: dotted 2px #dadada;
	width:95%;
}

#caseMail dd{
	font-size: 1.6rem;
	margin:15px auto;
}

/*対象商品*/
#goods ul.goodsNotes{
	font-size: 1.3rem;
}
#goods .btnWrap{padding: 0 80px;}
#goods .btnWrap .btn{font-size: 2rem;}
@media screen and (max-width:600px) {
	#goods .btnWrap{padding: 0;}
}



/*注意事項*/
.attention ul{
	list-style: disc;
	padding-left: 20px;
}

.attention ul li:not(:first-child){
	padding-top: 8px;
}

/*推奨環境*/
.environment dl{padding-top: 12px;}
.environment dt{font-weight: bold;}

/*お問い合わせ*/
.inquiry dl{
	background: #f3f1f1;
	text-align: center;
	padding: 24px;
	color: #E60012;
}
.inquiry dt{
	font-weight: bold;
	font-size: 1.8rem;
}
.inquiry dd{font-size: 1.3rem;}
.inquiry dd.tel{
	font-weight: bold;
	font-size: 1.8rem;
}
.inquiry dd.tel img{
	width: 24px;
	margin: 0 3px;
	vertical-align: -2px;
}
.mb15 {
	margin-bottom: 15px;
}

/*----------------------------------------*/
/*利用規約　/　rule
/*----------------------------------------*/

.rule h2.leadTitle{margin-bottom: 20px;}
.rule .leadBox{margin-bottom: 0;}
.rulesBody{
	height: 560px;
	border: 3px solid #f3f1f1;
	padding: 20px;
	margin-bottom: 40px;
	overflow: auto;
	font-size: 1.4rem;
}

.rulesBody p + ol{padding-top: 12px;}
.rulesBody ol{
	list-style: decimal;
	padding-left: 20px;
}

.rulesBody ol > li:not(:first-child){margin-top: 8px;}

.rulesBody ol li dl dt{
	font-weight: bold;
	padding-top: 8px;
}
.rulesBody ul{
	list-style: disc;
	padding-left: 20px;
}

.rulesBody ul li{padding-top: 8px;}
.rulesBody p:last-child{padding: 24px 0 12px;}

@media screen and (max-width:600px) {
	.rule h2.leadTitle{margin-bottom: 12px;}
	.rulesBody{padding: 12px;}
}

/*----------------------------------------*/
/*キャンペーン対象賞品一覧 / item
/*----------------------------------------*/
.itemPage h2.leadTitle{margin-bottom: 20px;}
.itemPage .boxWhite{padding: 20px 10px 40px;}
.itemList{
	display: flex;
	display: -webkit-flex;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}
.itemList li{
	width: 33.333%;
	padding: 0 10px 32px ;
}
.itemPage .btnWrap{padding: 0 10px;}
@media screen and (max-width:600px) {
	.itemPage h2.leadTitle{margin-bottom: 12px;}
	.itemPage .boxWhite{padding: 12px;}
	.itemList li{width: 100%;	padding: 0 0 32px ;}
	.itemPage .btnWrap{padding: 0 0 8px;}

}


/*-----------------------------------------*/
/* キャンペーンクローズ
/*-----------------------------------------*/
.close .header p{
	font-size: 2.8rem;
	padding-top: 32px;
}

.close .entry .btn.btn_entry,.close .headerText .btn.btn_entry{
	font-size: 3rem;
	background: #9a9a9a;
	box-shadow: 0 3px 0 #d0c8c8;
}
.close .entry .btn.btn_entry:hover,.close .headerText .btn.btn_entry:hover{
	color: #fff !important;
	box-shadow: 0 7px 0 #d0c8c8;}
.close .entry .btn.btn_entry:hover:before,.close .headerText .btn.btn_entry:hover:before {
	color: #fff;
	border-color: #fff;
}
.close .entry .btn.btn_entry:active,.close .headerText .btn.btn_entry:active {box-shadow: none;}

@media screen and (max-width:600px) {
	.close .entry .btn.btn_entry {font-size: 2rem;}

}


/*-----------------------------------------*/
/* footer
/*-----------------------------------------*/

.footer{
 text-align: center;
 font-size: 1.2rem;
 color: #fff;
 padding: 16px;
 background-color: #003894;
}


/*-----------------------------------------*/
/* clearfix
/*-----------------------------------------*/
.clear{clear: both;}
.cl:after {
    content: "";
    display: block;
    clear: both;
}

/*一時メモ用マーカー*/
.marker {
  background: yellow;
  color: red;
}

.notice {
  text-align: right;
  margin: 0 15px 32px;
}

.itemList li {
  float: left;
}