@charset "UTF-8";
/* CSS Document */


/* ==================== base =====================*/

:root {
	--green: #009740;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

html {
	font-size: 62.5%;
}

body {
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
	font-size: 1.4rem;
	line-height: 1.8;
	color: #333;
	-webkit-text-size-adjust: 100%;
}

a {
	transition: .3s;
}

a:link {
	color:#333;
	text-decoration: none;
}
a:visited {
	color:#333;
	text-decoration: none;
}
a:hover,
a:focus {
	color: var(--green);
	text-decoration: none;
	}
a:active {
	color: var(--green);
}


.alpha a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}


.alpha_a a img {
	-webkit-transition: 0.2s ease-in-out;
	   -moz-transition: 0.2s ease-in-out;
	     -o-transition: 0.2s ease-in-out;
	        transition: 0.2s ease-in-out;
}
.alpha_a a:hover img {
	opacity: 0.6;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}


/*ページトップへ（矢印）*/
#ptop {
    position: fixed;
    bottom: 15px;
    right: 15px;
	z-index: 1;
}
#ptop a {
    text-align: center;
    display: block;
    border-radius: 5px;
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha(opacity=80)";
}


/*スマホでは非表示*/
.sp_displaynone {
    display: none;
}


/*==================== header ====================*/


.content{
	background-image: url(../images/backimage.jpg);
	background-repeat: repeat;
	background-size: 500px 500px;
}

header h1 img {
	width: 100%;
	height: auto;
}

/*==================== main ====================*/

.basetitle{
	margin: 0 auto;
	text-align: center;
	height: 11vw;
	max-height: 80px;
}


.basetitle img{
	height: 100%;
	width: auto;
}
.campaigntitle{
	height: 15vw;
	max-height: 90px;
}

.campaigntitle_con{
	width: 100%;
	
}
.presenttitle{
	text-align: center;
}
.presenttitle img{
	width: 90%;
	height: auto;
}

/* キャンペーンの装飾 */

.campaign{
	width: 100%;
	margin-top: 70px;
}

.campaign_con{
	width: 90%;
	max-width: 900px;
	margin: 0 auto;
}

.campaign .campaign_p{
	text-align: center;
	background-color: #fff;
	max-width: 800px;
	padding: 15px 10px;
	margin: 0 auto;
	margin-top: 30px;
}

.campaign .campaign_p span{
	font-weight: bold;
}

/* クラッカーの装飾 */


.deco{
	width: 100%;
	margin-top: -230px;
	margin-bottom: 30vh;
}

.deco_con{
	width: 98%;
	max-width: 980px;
	display: flex;
	flex-wrap: nowrap;
	margin: 0 auto;
	justify-content: space-between;
}
.deco img{
	min-height: 80px;
	height: 20vw;
	width: auto;
}


/* プレゼントの装飾 */
.present{
	width: 100%;
}
.present_con{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto;
}

.present_item{
	margin-top: 20px;
}


.present_list img{
	width: 100%;
	height: auto;
}

/* 応募方法の装飾 */
.apply{
	width: 100%;
	background-color: #006a1d;
	padding: 50px 0 10px;
	margin-top: 80px;
}

.apply_con{
	width: 90%;
	max-width: 800px;
	margin: 0 auto;
}

.apply_img{
	width: 85px;
	height: auto;
	margin-bottom: 10px;
}

.apply_img img{
	width: 100%;
	height: auto;
}

.apply_box{
	border-bottom: 1px solid #fff;
	width: 100%;
	margin: 0 auto;
}
.apply_wrap{
	margin: 0 auto;
	max-width: 800px;
	width: 90%;
	display: block;
	flex-wrap: nowrap;
	align-items: center;
	padding: 20px 0;
	
}

.apply_box:last-child{
	border-bottom: none;
}

.apply_box p{
	color: #fff;
	/* font-weight: bold; */
	max-width: 570px;
}

/* キャンペーン参加店の装飾 */
.dealer{
	width: 100%;
	margin-top: 70px;
	margin-bottom: 60px;
}
.dealer_con{
	width: 90%;
	max-width: 1100px;
	margin: 0 auto;
}
.dealer_con ul {
	margin-top: 30px;
	display: flex;
	flex-wrap: wrap;
}
.dealer_con ul li {
	width: 50%;
}
.dealer_con ul li a {
	width: 100%;
	height: 100%;
	display: block;
	font-weight: bold;
	padding: 15px 42px 15px 15px;
	background-color: #fff;
	border: solid 0.5px #ddd;
	background-image: url(../images/icon_link.png);
	background-size: 15px auto;
	background-repeat: no-repeat;
	background-position: right 15px center;
	font-size: 90%;
}

/*================= footer =================*/

.f_top{
	text-align: center;
	margin-bottom: 10px;
	color: #006a1d;
	font-weight: bold;
}
.f_top p,.f_bottom p{
	padding: 0 10px;
	font-size: 90%;
}
.f_bottom{
	text-align: center;
	padding: 10px 0;
	background-color: #006a1d;
	color: #fff;
	font-size: 90%;
}