@charset "utf-8";
@font-face {
	font-family: "YuGothicM";
	font-weight: 500;
	src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular"), local("游ゴシック");
}
@font-face {
	font-family: "YuGothicM";
	font-weight: bold;
	src: local("YuGothic-Bold"), local("Yu Gothic Bold");
}

/* CSS Document */
* {
	margin: 0;
	padding: 0;
}
body {
	position: relative;
	font-family: "YuGothicM", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	font-size: 10px !important;
	background: #f4f4f4;
}
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
  display: block;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: bold;
}
p, li, dt, dd, th, td, span, a, label {
	line-height: 100%;
}
p *, li *, dt *, dd *, th *, td * {
	font-size: 100%;
}
img {
	border: none;
	vertical-align: bottom;
}
.upper {
	text-transform: uppercase;
}
.nw {
	display: inline-block;
	white-space: nowrap;
}
.cf {
	height: 1%;
}
.cf:after {
	display: block;
	clear: both;
	visibility: hidden;
	height: 0;
	content: ".";
}
/* 画像置換 */
.rp {
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
.sectionTitle {
	width: 100%;
	border-bottom: 1px dotted #ccc;
	color: #535353;
	font-weight: normal;
}
.sectionTitle:before {
	color: #fd7478;
	content: "●";
}
/* -------------------------*/
/* Common Style
/* -------------------------*/
.contents {
	margin: 0 auto;
	background: #fff;
}
/* -------------------------*/
/* .header
/* -------------------------*/
.header {
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	overflow: hidden;
	background-color: rgba(0, 0, 0, 0.7);
}
.header .logo {
	float: left;
}
.header .logo a {
	display: block;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
.header .nav {
	overflow: hidden;
	list-style: none;
}
.header .nav li a {
	color: #fff;
	text-decoration: none;
}
.header .nav .sns:before {
	content: none;
}
.header .nav .sns a {
	display: block;
	height: 100%;
	overflow: hidden;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
/* -------------------------*/
/* .slide
/* -------------------------*/
.slide {
	width: 100%;
}
/* -------------------------*/
/* .about
/* -------------------------*/
.about .mainTitle {
	text-align: center;
}
.about .list {
	margin: 0 auto;
	overflow: hidden;
	list-style: none;
}
.about .list dt,
.about .list dd,
.about .theme .title,
.about .theme .detail1,
.about .theme .detail2 {
	background-repeat: no-repeat;
	background-position: 0 0;
}
/* -------------------------*/
/* .result
/* -------------------------*/
.result h2,
.result h2 + p {
	overflow: hidden;
	margin: 0 auto;
	text-indent: 100%;
	white-space: nowrap;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
.result-block {
	text-align: center;
}
.result h3 {
	color: #fd7478;
	border-bottom: 1px dotted #535353;
	text-align: left;
	box-sizing: border-box;
}
.result h3:before {
	display: inline-block;
	content: "●";
}
.result .photo {
	display: block;
	text-align: center;
}
.result .photo img {
	display: block;
	margin: 0 auto;
	cursor: pointer;
}
.result .user {
	
	color: #535353;
	font-weight: 600;
	text-align: center;
}
.result .user span {
	display: inline-block;
}
.result .user:before {
	display: inline-block;
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: 100% auto;
	content: "";
}
.result .user.non-ico.left:before {
	content: none;
}
.result h4 {
	display: block;
	width: 100%;
	color: #535353;
	border-bottom: 1px dotted #535353;
	text-align: left;
	box-sizing: border-box;
}
.showPhoto {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	z-index: 998;
	width: 100%;
	height: 100%;
}
.showPhoto span {
	display: inline-block;
	position: relative;
	z-index: 999;
}
.showPhoto span:before {
	position: absolute;
	z-index: 999;
	border-radius: 50%;
	color: #fff;
	text-align: center;
	line-height: 100%;
	background-color: rgba(0,0,0,0.5);
	background-image: url("../img/showphot_close_btn.png");
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: 50% auto;
	cursor: pointer;
	content: "";
}
/* -------------------------*/
/* .present
/* -------------------------*/
.present .specialGift .unitTitle {
	margin: 0 auto;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
.present .specialGift .block {
	box-sizing: border-box;
}
.present .specialGift .categoryTitle {
	color: #fd7478;
	text-align: center;
}
.present .specialGift .categoryTitle:after {
	display: block;
	border-top: 1px dotted #ccc;
	background-repeat: no-repeat;
	background-size: 100% auto;
	content: "";
}
.present .specialGift .areaTitle {
	color: #535353;
	font-weight: normal;
}
.present .specialGift .areaTitle:before {
	content: "【";
}
.present .specialGift .areaTitle:after {
	content: "】";
}
.present .specialGift .provider {
	border-bottom: 1px dotted #ccc;
}
.present .specialGift .provider a {
	color: #fd7478;
}
.present .specialGift .provider a:before {
	content: "・";
}
.present .specialGift .provider a:hover {
	color: #f06;
}
#overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 997;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.7);
}
.present .specialGift .area .detail {
	display: none;
	position: fixed;
	z-index: 1000;
	height: auto;
	border: 1px solid #ccc;
	background-color: #fff;
	box-sizing: border-box;
}
.present .specialGift .area .detail dt {
	border-bottom: 1px dotted #ccc;
	color: #fd7478;
}
.present .specialGift .area .detail dd {
	word-wrap: break-word;
	line-height: 140%;
}
.present .specialGift .area .detail .closeBtn {
	display: block;
	position: absolute;
	z-index: 999;
	border-radius: 50%;
	color: #fff;
	text-align: center;
	background-color: rgba(0,0,0,0.5);
	cursor: pointer;
}
.present .prize .unitTitle {
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
.present .prize .prizeLead {
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
}
.present .prize .prizeList {
	margin: 0 auto;
	border-collapse: collapse;
	border-bottom: 1px solid #ccc;
}
.present .prize .prizeList > thead > tr > th {
	border: 1px solid #ccc;
	border-bottom: 0;
	color: #fd7478;
	font-weight: normal;
	text-align: center;
	background-color: #f3f3f3;
}
.present .prize .block {
	width: 100%;
	border-collapse: collapse;
}
.present .prize .block td {
	color: #535353;
	font-size: 120%;
}
/* -------------------------*/
/* .join
/* -------------------------*/
.join {
	overflow: hidden;
}
.join .block {
	overflow: hidden;
	border: 1px solid #ccc;
	box-sizing: border-box;
	background: #f3f3f3;
}
.join .block .blockTitle {
	font-size: 160%;
	font-weight: normal;
}
.join .block .blockTitle b {
	color: #fd7478;
	font-weight: normal;
}
.join .snsFollow {
	list-style: none;
}
.join .snsFollow > li a {
	display: block;
	height: 100%;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% auto;
}
.join .snsFollow .nonAccount ul {
	list-style: none;
}
.join .block .notes {
	list-style: none;
}
.join .block .notes li {
	color: #fd7478;
}
.join .block .notes li:first-child {
	margin-bottom: 15px;
}
.join .block .notes .red {
	color: #f00;
}
.join .block .notes .bold {
	font-weight: bold;
}
.join .map {
	clear: both;
}
/* -------------------------*/
/* contract
/* -------------------------*/
.contract .block {
	overflow-y: scroll;
	padding: 10px;
	border:1px solid #ccc;
	color: #535353;
	box-sizing: border-box;
}
.contract .block ul {
	list-style: none;
}
.contract .block li {
	padding-left: 1em;
	text-indent: -1em;
	text-align: left;
}
.contract .block li:before {
	content: "・";
}
/* -------------------------*/
/* SNS posts
/* -------------------------*/
.snsPosts {
	display: none;
}
.snsPosts .title {
	position: relative;
	background: #fff;
	background-position: 50% 50%;
	background-repeat: no-repeat;
}
.snsPosts .inner {
	width: 100%;
	padding: 10px 0;
	overflow-y: auto;
	border: 1px solid #ccc;
	border-radius: 6px;
	text-align: center;
	box-sizing: border-box;
}
/* -------------------------*/
/* .returnTop
/* -------------------------*/
.returnTop {
	display: none;
	position: fixed;
	z-index: 997;
}
.returnTop a {
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden;
	border-radius: 50%;
	text-indent: 100%;
	white-space: nowrap;
	background: #000 url(../img/btn_return_top.png) no-repeat 50% 40%;
	background-size: 100% auto;
	opacity: 0.3;
}
.returnTop a:hover {
	opacity: 0.6;
}
/* -------------------------*/
/* .footer
/* -------------------------*/
.footer {
	display: block;
	border-top: 1px dotted #ccc;
}
.footer p {
	color: #535353;
	font-size: 120%;
	text-align: center;
}
/******************************/
/* Mobile Layout: ～ 767px
/******************************/
	@media screen and (max-width: 767px) {
		body {
			min-width: 320px;
		}
		.pcNone {
			display: block;
		}
		.spNone {
			display: none;
		}
		.contents {
			padding: 7.8125% 0 0;
		}
		/* -------------------------*/
		/* .header
		/* -------------------------*/
		.header {
			min-width: 320px;
			background-color: rgba(0,0,0,0.8);
		}
		.header .logo {
			width: 12.5%;
			height: auto;
			margin: 1.5625% 0 1.5625% 3.125%;
		}
		.header .logo a {
			padding-top: 100%;
			background-image: url(../img/pc_header_logo.png);
		}
		.header .menuBtn {
			display: block;
			float: right;
			width: 12.5%;
			height: auto;
			margin: 1.5625% 3.125% 1.5625% 0;
		}
		.header .menuBtn span {
			display: block;
			width: 100%;
			height: 0;
			overflow: hidden;
			padding-top: 100%;
			text-indent: 100%;
			white-space: nowrap;
			background: url(../img/sp_menu_btn.png) no-repeat 50% 50%;
			background-size: 100% auto;
		}
		.header .nav {
			display: none;
			clear: both;
			margin-top: 10px;
			border-top: 1px solid #aaa;
		}
		.header .nav li {
			width: 100%;
			font-size: 4.375vw;
			border-bottom: 1px solid #aaa;
		}
		.header .nav li a {
			display: block;
			line-height: 180%;
			padding: 3.125%;
			text-align: center;
		}
		.header .nav .sns {
			overflow: hidden;
			padding-top: 0;
		}
		.header .nav .sns a {
			
		}
		.header .nav .sns a:before {
			display: inline-block;
			width: 6.25vw;
			height: 6.25vw;
			margin-right: 3.3334vw;
			vertical-align: -1.7vw;
			background-repeat: no-repeat;
			background-position: 50% 0;
			background-size: 100% auto;
			content: "";
		}
		.header .nav .sns.fb a:before {
			background-image: url(../img/sp_nav_fb_icon.png);
		}
		.header .nav .sns.tw a:before {
			background-image: url(../img/sp_nav_tw_icon.png);
		}
		.header .nav .sns.ig a:before {
			background-image: url(../img/sp_nav_ig_icon.png);
		}
		.header .nav .close {
			display: block;
		}
		.showPhoto span {
			padding: 5%;
		}
		.showPhoto span:before {
			top: 3.125vw;
			right: 3.125vw;
			padding: 3.125vw;
			font-size: 200%;
		}
		.showPhoto span img {
			width: 100%;
			height: auto;
		}
		/* -------------------------*/
		/* .slide
		/* -------------------------*/
		.slide {
			width: 100%;
			height: auto;
			margin-bottom: 9.375%;
		}
		.slide img {
			width: 100%;
			height: auto;
		}
		.bx-wrapper {
			margin-top: 15.625%;
		}
		/* -------------------------*/
		/* .about
		/* -------------------------*/
		.about {
			padding: 0 3.125%;
		}
		.about .mainTitle img {
			width: 100%;
			height: auto;
			margin-bottom: 7.8125%;
		}
		.about .list {
			height: 0;
			margin: 0 1.6667% 7.8125%;
			padding-top: 64.3334%;
			background: url(../img/sp_about_list.png) no-repeat 50% 0;
			background-size: 100% auto;
		}
		.about .theme {
			height: 0;
			margin: 0 1.6667% 15.625%;
			padding-top: 44.6667%;
			background: url(../img/sp_about_theme.png) no-repeat 50% 0;
			background-size: 100% auto;
		}
		/* -------------------------*/
		/* .result
		/* -------------------------*/
		.result {
			margin-bottom: 15.625%;
			padding: 0 4.6875% ;
		}
		.result h2 {
			height: 0;
			margin-bottom: 5.17242%;
			padding-top: 12.06897%;
			background-image: url(../img/sp_result_ttl.gif);
		}
		.result h2 + p {
			height: 0;
			margin-bottom: 13.79311%;
			padding-top: 24.137932%;
			background-image: url(../img/sp_result_desc.gif);
		}
		.result h3 {
			font-size: 200%;
			margin-bottom: 8.62069%;
		}
		.result h3:before {
			margin-right: 1%;
		}
		.result h3 span {
			margin: 2% 0;
			padding-top: 2%;
			font-size: 80%;
			font-weight: normal;
		}
		.result .photo {
			width: 100%;
			margin-bottom: 3.44828%;
			padding: 0 6.89656%;
			box-sizing: border-box;
		}
		.result .photo.large {
			padding: 0;
		}
		.result .photo img {
			width: 100%;
			height: auto;
		}
		.result-block,
		.result-block-col > div {
			margin-bottom: 8.62069%;
		}
		.result .user {
			color: #535353;
			font-size: 160%;
			font-weight: normal;
		}
		.result .user:before {
			width: 6.25vw;
			height: 6.25vw;
			margin-right: 1%;
			vertical-align: -1vw
		}
		.result .user.tw:before {
			background-image: url("../img/result_icon_tw.png");
		}
		.result .user.fb:before {
			background-image: url("../img/result_icon_fb.png");
		}
		.result .user.ig:before {
			background-image: url("../img/result_icon_ig.png");
		}
		.result h4 {
			padding: 5.17242% 0 0 0.86207%;
			margin-bottom: 1.72414%;
			font-size: 140%;
		}
		.result-block-col-child {
			display: -webkit-flex;
			display: -ms-flexbox;
			display: flex;
			-webkit-flex-wrap: wrap;
			-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		}
		.result-block-col-child > div {
			width: 50%;
			margin-bottom: 3.44828%;
		}
		.result-block-col-child .user {
			font-size: 120%;
		}
		.result-block-col-child .user:before {
			width: 3.75vw;
			height: 3.75vw;
			vertical-align: -1vw;
		}

		/* -------------------------*/
		/* .present
		/* -------------------------*/
		.present {
			margin-bottom: 7.8125vw;
			padding: 0 3.1257%;
		}
		.present .specialGift .unitTitle {
			width: 20%;
			height: 0;
			margin-bottom: 7.14286%;
			padding-top: 20%;
			background-image: url(../img/sp_present_spgift_title.png);
		}
		.present .specialGift .block {
			height: auto !important;
			margin-bottom: 6.6667%;
			padding: 3.3334%;
			background-color: #eee;
		}
		.present .specialGift .categoryTitle {
			margin-bottom: 3.5715%;
			font-size: 140%;
		}
		.present .specialGift .categoryTitle:after {
			margin-top: 3.5715%;
			padding-bottom: 54.7143%;
			background-position: 50% 100%;
		}
		.present .specialGift .food .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img01.jpg);
		}
		.present .specialGift .entranceFee .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img02.jpg);
		}
		.present .specialGift .coupon .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img03.jpg);
		}
		.present .specialGift .areaTitle {
			margin-bottom: 3.5715%;
			font-size: 120%;
		}
		.present .specialGift .provider {
			margin-bottom: 1.7858%;
			padding-bottom: 1.7858%;
			font-size: 120%;
		}
		.present .specialGift .item {
			margin-bottom: 5.3572%;
			color: #535353;
			font-size: 120%;
			line-height: 140%;
		}
		.present .specialGift .area .detail {
			top: 35%;
			left: 3.125%;
			width: 93.75%;
			margin-top: -25%;
			padding: 3.3334%;
		}
		.present .specialGift .area .detail dt {
			margin-bottom: 1.7858%;
			padding-bottom: 1.7858%;
			font-size: 140%;
		}
		.present .specialGift .area .detail dd {
			margin-bottom: 5.3572%;
			font-size: 140%;
		}
		.present .specialGift .area .detail .closeBtn {
			top: -3%;
			right: -3%;
			width: 12.5vw;
			height: 12.5vw;
			padding-top: 4vw;
			font-size: 4.375vw;
			font-weight: bold;
			line-height: 100%;
			box-sizing: border-box;
		}
		.present .prize .unitTitle {
			width: 20%;
			height: 0;
			margin: 0 auto 7.14286%;
			padding-top: 20%;
			background-image: url(../img/sp_present_prize_title.png);
		}
		.present .prize .prizeLead {
			height: 0;
			margin-bottom: 7.14286%;
			padding-top: 9.3334%;
			background-image: url(../img/sp_present_prize_lead.gif);
		}
		.present .prize .prizeList {
			width: 100%;
			border: none;
		}
		.present .prize .prizeList > thead > tr > th {
			display: none;
		}
		.present .prize .block {
			margin-bottom: 5%;
			border-bottom: 1px solid #ccc;
		}
		.present .prize .block tr {
			display: block;
			margin-bottom: 3%;
			padding-bottom: 3%;
			border-bottom: 1px dotted #efefef;
		}
		.present .prize .block tr:last-child {
			padding-bottom: 0;
			border-bottom: 0;
		}
		.present .prize .block td {
			display: block;
			width: auto;
			font-size: 120%;
			text-align: left;
			line-height: 140%;
		}
		.present .prize .city {
			margin-bottom: 3%;
		}
		.present .prize .city:before {
			content: "【";
		}
		.present .prize .city:after {
			content: "】";
		}
		.present .prize .org:before {
			color: #fd7478;
			content: "組織名：";
		}
		.present .prize .item:before {
			color: #fd7478;
			content: "賞　品：";
		}
		.present .prize .num:before {
			color: #fd7478;
			content: "人　数：";
		}
		/* -------------------------*/
		/* .join
		/* -------------------------*/
		.join {
			margin-bottom: 7.8125vw;
			padding: 0 3.1257%;
		}
		.join .sectionTitle {
			font-size: 4.375vw;
			margin-bottom: 6.25%;
			padding-bottom: 1.5625%;
		}
		.join .block {
			width: auto;
			padding: 3%;
			margin-bottom: 7.8125%;
		}
		.join .block:last-child {
			margin-bottom: 0;
		}
		.join .block .blockTitle {
			width: 100%;
			overflow: hidden;
			margin-bottom: 7.1428%;
		}
		.join .block .blockTitle .icon {
			display: block;
			float: left;
			width: 10.94vw;
			height: auto;
			padding: 3.285vw 0;
			border-radius: 5px;
			color: #fff;
			font-size: 4.375vw;
			text-align: center;
			line-height: 100%;
			background-color: #fd7478;
		}
		.join .block .blockTitle .text {
			display: block;
			float: left;
			width: 70vw;
			padding-left: 3.125%;
			color: #535353;
			font-size: 4.375vw;
			line-height: 140%;
			text-align: left;
			box-sizing: border-box;
		}
		.join .block .text.spPt {
			padding-top: 3.7%;
			box-sizing: border-box;
		}
		.join .snsFollow > li {
			margin-top: 5.3572%;
			height: auto;
			background-repeat: no-repeat;
			background-position: 0 0;
			background-size: 100% auto;
		}
		.join .snsFollow > li > a {
			display: block;
			height: 0;
			padding-top: 14.2858%;
			background-size: 100% auto;
		}
		.join .snsFollow .fb a {
			background-image: url(../img/sp_jon_flow1_fb_follow.png);
		}
		.join .snsFollow .tw a {
			background-image: url(../img/sp_jon_flow1_tw_follow.png);
		}
		.join .snsFollow .ig a {
			background-image: url(../img/sp_jon_flow1_ig_follow.png);
		}
		.join .snsFollow .nonAccount {
			margin-bottom: 6.25vw;
			font-size: 3.75vw;
		}
		.join .snsFollow .nonAccount p {
			margin-bottom: 3.125vw;
		}
		.join .snsFollow .nonAccount li {
			display: block;
			margin-bottom: 4.6875vw;
		}
		.join .snsCapture {
			width: 100%;
			height: auto;
		}
		.join .block .notes {
			padding-top: 6.25%;
		}
		.join .block .notes li {
			padding-left: 1em;
			font-size: 3.75vw;
			line-height: 160%;
			text-indent: -1em;
		}
		.join .map img {
			width: 100%;
			height: auto;
		}
		/* -------------------------*/
		/* .inquiry
		/* -------------------------*/
		.inquiry {
			margin-bottom: 7.8125vw;
			padding: 0 3.125vw;
		}
		.inquiry .sectionTitle {
			font-size: 4.375vw;
			margin-bottom: 6.25%;
			padding-bottom: 1.5625%;
		}
		.inquiry p {
			font-size: 3.75vw;
		}
		/* -------------------------*/
		/* .contract
		/* -------------------------*/
		.contract {
			margin-bottom: 7.8125vw;
			padding: 0 3.125vw;
		}
		.contract .sectionTitle {
			font-size: 4.375vw;
			margin-bottom: 6.25%;
			padding-bottom: 1.5625%;
		}
		.contract .block li {
			margin-bottom: 2.5vw;
			font-size: 3.75vw;
			line-height: 140%;
		}
		/* -------------------------*/
		/* SNS posts
		/* -------------------------*/
		.snsPosts {
			margin-bottom: 7.8125vw;
			padding: 0 3.125vw;
		}
		.snsPosts .title {
			height: 14.8125vw;
			margin-bottom: 3.125vw;
			background-size: 100% auto;
		}
		.snsPosts .title.fb {
			background-image: url(../img/pc_snsposts_fb_logo.gif);
		}
		.snsPosts .title.tw {
			background-image: url(../img/pc_snsposts_tw_logo.gif);
		}
		.snsPosts .title.ig {
			background-image: url(../img/pc_snsposts_ig_logo.gif);
		}
		.snsPosts .inner {
			width: 100%;
			height: 78.125vw;
			margin-bottom: 6.25vw;
			padding: 3.125vw;
			overflow-y: auto;
			text-align: center;
		}
		/* -------------------------*/
		/* .returnTop
		/* -------------------------*/
		.returnTop {
			right: 2%;
			width: 12.5vw;
			height: 12.6vw;
		}
			.returnTop a:hover {
				opacity: 0.3;
			}
		/* -------------------------*/
		/* .footer
		/* -------------------------*/
		.footer p {
			margin-bottom: 3.125vw;
			padding-top: 4.6875%;
			line-height: 140%;
		}
	}
/******************************/
/* PC Layout： 768px～
/******************************/
	@media screen and (min-width:768px) {
		body {
			min-width: 1024px;
		}
		.pcNone {
			display: none;
		}
		.spNone {
			display: block;
		}
		.contents {
			width: 1024px;
			padding: 50px 0 0;
		}
		.sectionTitle {
			margin-bottom: 20px;
			padding-bottom: 5px;
			font-size: 180%;
		}
		.sectionTitle:before {
			margin-right: 3px;
		}
		.twoColumn {
			overflow: hidden;
		}
		.twoColumn section {
			width: 482px;
		}
		.twoColumn section:first-child {
			float: left;
			margin-left: 20px;
		}
		.twoColumn section:last-child {
			float: right;
			margin-bottom: 25px;
		}
		/* -------------------------*/
		/* .header
		/* -------------------------*/
		.header {
			height: 60px;
		}
		.header .inner {
			max-width: 1024px;
			margin: 0 auto;
		}
		.header .logo {
			margin: 5px 0 0 10px;
		}
		.header .logo a {
			width: 50px;
			height: 50px;
			background-image: url(../img/pc_header_logo.png);
		}
		.header .menuBtn {
			display: none;
		}
		.header .nav {
			display: block !important;
			float: right;
			margin: 22px 10px 0 0;
		}
		.header .nav li {
			float: left;
			margin-left: 25px;
			padding-top: 2px;
			font-size: 140%;
		}
		.header .nav li:first-child {
			margin-left: 0;
		}
		.header .nav li:before {
			color: #aaa;
			content: "｜";
			margin-right: 25px;
		}
		.header .nav li:first-child:before {
			content: none;
		}
		.header .nav li a:hover {
			text-decoration: underline;
		}
		.header .nav .sns {
			width: 20px;
			height: 18px;
			margin-left: 15px;
			padding-top: 0;
			text-indent: 100%;
			white-space: nowrap;
		}
		.header .nav .sns.fb {
			margin-left: 30px;
		}
		.header .nav .sns.fb a {
			background-image: url(../img/pc_nav_fb_icon.png);
		}
		.header .nav .sns.tw a {
			background-image: url(../img/pc_nav_tw_icon.png);
		}
		.header .nav .sns.ig a {
			background-image: url(../img/pc_nav_ig_icon.png);
		}
		.header .nav .sns a:hover {
			opacity: 0.8;
		}
		.header .nav .close {
			display: none;
		}
		/* -------------------------*/
		/* .slide
		/* -------------------------*/
		.slide p {
			width: auto !important;
		}
		/* -------------------------*/
		/* .about
		/* -------------------------*/
		.about .mainTitle {
			margin-bottom: 30px;
		}
		.about .list {
			width: 760px;
			margin-bottom: 30px;
		}
		.about .list dt {
			clear: both;
			float: left;
			width: 125px;
			margin: 0 20px 20px 0;
		}
		.about .list dd {
			float: left;
			max-width: 615px;
			margin-bottom: 20px;
		}
		.about .list .date {
			height: 40px;
		}
		.about .list dt.date {
			background-image: url(../img/pc_about_list_title01.gif);
		}
		.about .list dd.date {
			width: 620px;
			background-image: url(../img/pc_about_list_text01.gif);
		}
		.about .list .area {
			height: 30px;
		}
		.about .list dt.area {
			background-image: url(../img/pc_about_list_title02.gif);
		}
		.about .list dd.area {
			width: 620px;
			background-image: url(../img/pc_about_list_text02.gif);
		}
		.about .list .sns {
			height: 30px;
		}
		.about .list .sns {
			height: 30px;
		}
		.about .list dt.sns {
			background-image: url(../img/pc_about_list_title03.gif);
		}
		.about .list dd.sns {
			width: 620px;
			background-image: url(../img/pc_about_list_text03.gif);
		}
		.about .list .gift {
			height: 44px;
		}
		.about .list dt.gift {
			background-image: url(../img/pc_about_list_title04.gif);
		}
		.about .list dd.gift {
			width: 620px;
			background-image: url(../img/pc_about_list_text04.gif);
		}
		.about .theme {
			width: 800px;
			margin: 0 auto 80px;
		}
		.about .theme .title {
			height: 19px;
			margin-bottom: 15px;
			background-image: url(../img/pc_about_theme_title.gif);
			background-position: 30px 0;
		}
		.about .theme .detail1 {
			height: 24px;
			margin-bottom: 15px;
			background-position: 30px 0;
			background-image: url(../img/pc_about_theme_detail1.gif);
		}
		.about .theme .detail2 {
			height: 73px;
			border-top: 1px dotted #535353;
			background-position: 50% 15px;
			background-image: url(../img/pc_about_theme_detail2.gif);
		}
		/* -------------------------*/
		/* .result
		/* -------------------------*/
		.result {
			margin-bottom: 100px;
			padding: 0 10px;
		}
		.result h2 {
			width: 543px;
			height: 47px;
			margin-bottom: 40px;
			background-image: url(../img/pc_result_ttl.gif);
		}
		.result h2 + p {
			width: 591px;
			height: 88px;
			margin-bottom: 55px;
			background-image: url(../img/pc_result_desc.gif);
		}
		.result-block h3:before {
			margin-right: 5px;
		}
		.result-block {
			width: 100%;
			margin-bottom: 50px;
		}
		.result-block-col {
			display: -webkit-flex;
			display: -ms-flexbox;
			display: flex;
			-webkit-flex-wrap: wrap;
			-ms-flex-wrap: wrap;
			flex-wrap: wrap;
			width: 100%;
			margin-bottom: 50px;
		}
		.result-block-col > div {
			width: 492px;
		}
		.result-block-col > div:nth-child(2) {
			margin-left: 20px;
		}
		.result h3 {
			margin: 0 0 10px;
			padding: 0 0 8px 5px;
			font-size: 180%;
		}
		.result .photo {
			margin-bottom: 10px;
		}
		.result .photo img {
			opacity: 1;
			-webkit-transition-duration: 0.5s;
			transition-duration: 0.5s;
		}
		.result .photo img:hover {
			opacity: 0.7;
		}
		.result .user {
			font-size: 160%;
		}
		.result .user span {
			margin-left: 3px;
			font-weight: normal;
		}
		.result .user:before {
			width: 30px;
			height: 30px;
			margin-right: 5px;
			vertical-align: -10px;
		}
		.result .user.tw:before {
			background-image: url("../img/result_icon_tw.png");
		}
		.result .user.fb:before {
			background-image: url("../img/result_icon_fb.png");
		}
		.result .user.ig:before {
			background-image: url("../img/result_icon_ig.png");
		}
		.result .user.non-ico:before {
			background: none;
		}
		.result .user.non-ico.left {
			text-align: left;
		}
		.result h4 {
			padding: 30px 0 0 5px;
			margin-bottom: 10px;
			font-size: 160%;
		}
		.result-block-col-child {
			display: -webkit-flex;
			display: -ms-flexbox;
			display: flex;
			-webkit-flex-wrap: wrap;
			-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		}
		.result-block-col-child > div {
			width: 241px;
			margin-bottom: 10px;
		}
		.result-block-col-child > div:nth-child(3),
		.result-block-col-child > div:nth-child(5) {
			margin-left: 10px;
		}
		.result-block-col-child .user {
			font-size: 140%;
		}
		.result-block-col-child .user:before {
			width: 24px;
			height: 24px;
			vertical-align: -7px;
		}
		.showPhoto span:before {
			top: -15px;
			right: -15px;
			padding: 15px;
			font-size: 200%;
		}
		/* -------------------------*/
		/* .present
		/* -------------------------*/
		.present {
			margin-bottom: 50px;
		}
		.present .specialGift {
			overflow: hidden;
			margin-bottom: 50px;
			padding: 0 20px;
		}
		.present .specialGift .unitTitle {
			width: 74px;
			height: 76px;
			margin-bottom: 30px;
			background-image: url(../img/pc_present_spgift_title.gif);
		}
		.present .specialGift .block {
			float: left;
			width: 314px;
			margin-left: 21px;
			padding: 10px;
			background-color: #eee;
		}
		.present .specialGift .unitTitle + .block {
			margin-left: 0;
		}
		.present .specialGift .categoryTitle {
			margin-bottom: 10px;
			font-size: 140%;
		}
		.present .specialGift .categoryTitle:after {
			width: 295px;
			height: 150px;
			margin: 10px auto;
			padding-top: 10px;
			background-position: 50% 10px;
		}
		.present .specialGift .food .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img01.jpg);
		}
		.present .specialGift .entranceFee .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img02.jpg);
		}
		.present .specialGift .coupon .categoryTitle:after {
			background-image: url(../img/pc_present_spgift_img03.jpg);
		}
		.present .specialGift .areaTitle {
			margin-bottom: 8px;
			font-size: 120%;
		}
		.present .specialGift .provider {
			margin-bottom: 5px;
			padding-bottom: 5px;
			font-size: 120%;
		}
		.present .specialGift .item {
			margin-bottom: 10px;
			color: #535353;
			font-size: 120%;
			line-height: 140%;
		}
		.present .specialGift .area .detail {
			top: 50%;
			left: 50%;
			margin: -15% 0 0 -200px;
			width: 400px;
			padding: 20px;
		}
		.present .specialGift .area .detail dt {
			margin-bottom: 5px;
			padding-bottom: 5px;
			font-size: 140%;
		}
		.present .specialGift .area .detail dd {
			margin-bottom: 20px;
			font-size: 140%;
		}
		.present .specialGift .area .detail .tel a {
			color: #535353;
			text-decoration: none;
			cursor: auto;
		}
		.present .specialGift .area .detail .closeBtn {
			top: -15px;
			right: -15px;
			width: 30px;
			height: 22px;
			padding-top: 8px;
			font-size: 140%;
			font-weight: bold;
		}
		.present .prize .unitTitle {
			width: 74px;
			height: 74px;
			margin: 0 auto 20px;
			background-image: url(../img/pc_present_prize_title.gif);
		}
		.present .prize .prizeLead {
			width: 469px;
			height: 44px;
			margin: 0 auto 20px;
			background-image: url(../img/pc_present_prize_lead.gif);
		}
		.present .prize .prizeList {
			width: 700px;
		}
		.present .prize .prizeList > thead > tr > th {
			padding: 10px;
			font-size: 140%;
		}
		.present .prize .block td {
			padding: 10px;
			border: 1px solid #ccc;
			border-bottom: 0;
			font-size: 120%;
			line-height: 140%;
		}
		.present .prize .city {
			width: 15%;
			text-align: center;
		}
		.present .prize .org {
			width: 30%;
		}
		.present .prize .item {
			width: 30%;
		}
		.present .prize .num {
			width: 15%;
			text-align: center;
		}
		/* -------------------------*/
		/* .join
		/* -------------------------*/
		.join {
			margin-bottom: 50px;
			padding: 0 20px;
		}
		.join .block {
			float: left;
			width: 482px;
			padding: 20px;
		}
		.join .block .towColmun > div {
			float: left;
		}
		.join .sectionTitle + .block {
			float: none;
			width: 984px;
			margin-bottom: 20px;
		}
		.join .sectionTitle + .block + .block + .block {
			margin-left: 20px;
		}
		.join .block .blockTitle {
			display: table;
			margin-bottom: 20px;
			font-size: 160%;
			line-height: 100%;
		}
		.join .block .blockTitle span {
			display: table-cell;
		}
		.join .block .blockTitle span:first-child {
			width: 35px;
			height: 35px;
			border-radius: 5px;
			color: #fff;
			text-align: center;
			vertical-align: middle;
			background-color: #fd7478;
		}
		.join .block .blockTitle span:last-child {
			width: auto;
			padding-left: 10px;
			color: #535353;
			text-align: left;
			vertical-align: middle;
			line-height: 120%;
		}
		.join .block .towColmun div:first-child {
			width: 250px;
			margin-right: 110px;
		}
		.join .snsFollow {
			margin-bottom: 20px;
			list-style: none;
		}
		.join .snsFollow > li {
			width: 250px;
			height: 60px;
			margin-top: 20px;
			background-repeat: no-repeat;
			background-position: 0 0;
			background-size: 100% auto;
		}
		.join .snsFollow > li a {
			display: block;
			height: 100%;
		}
		.join .snsFollow > li a:hover {
			opacity: 0.7;
		}
		.join .snsFollow .fb a {
			background-image: url(../img/pc_jon_flow1_fb_follow.gif);
		}
		.join .snsFollow .tw a {
			background-image: url(../img/pc_jon_flow1_tw_follow.gif);
		}
		.join .snsFollow .ig a {
			background-image: url(../img/pc_jon_flow1_ig_follow.gif);
		}
		.join .snsFollow > li:first-child {
			margin-top: 0;
		}
		.join .snsFollow .nonAccount {
			font-size: 120%;
		}
		.join .snsFollow .nonAccount p {
			margin-bottom: 10px;
		}
		.join .snsFollow .nonAccount li {
			display: inline-block;
			margin-bottom: 10px;
		}
		.join .block .notes {
			clear: both;
			padding-top: 20px;
		}
		.join .block .notes li {
			padding-left: 1em;
			font-size: 120%;
			line-height: 160%;
			text-indent: -1em;
		}
		.join .map {
			padding-top: 50px;
		}
		/* -------------------------*/
		/* .inquiry
		/* -------------------------*/
		.inquiry {
			margin: 0 0 50px 20px;
		}
		.inquiry p {
			color: #535353;
			font-size: 140%;
		}
		/* -------------------------*/
		/* contract
		/* -------------------------*/
		.contract {
			margin-bottom: 50px;
		}
		.contract .block {
			height: 130px;
		}
		.contract .block li {
			margin-bottom: 8px;
			font-size: 120%;
			line-height: 140%;
		}
		/* -------------------------*/
		/* SNS posts
		/* -------------------------*/
		.snsPosts {
			margin: 0 auto;
			padding: 0 20px;
			overflow: hidden;
		}
		.snsPosts .block {
			float: left;
			width: 318px;
			margin-left: 15px;
		}
		.snsPosts .block:first-child {
			margin-left: 0;
		}
		.snsPosts .title {
			height: 50px;
			margin-bottom: 10px;
		}
		.snsPosts .title.fb {
			background-image: url(../img/pc_snsposts_fb_logo.gif);
		}
		.snsPosts .title.tw {
			background-image: url(../img/pc_snsposts_tw_logo.gif);
		}
		.snsPosts .title.ig {
			background-image: url(../img/pc_snsposts_ig_logo.gif);
		}
		.snsPosts .inner {
			width: 100%;
			height: 350px;
			overflow-y: auto;
			text-align: center;
		}
		/* -------------------------*/
		/* .returnTop
		/* -------------------------*/
		.returnTop {
			right: 2%;
			width: 45px;
			height: 45px;
		}
		/* -------------------------*/
		/* .footer
		/* -------------------------*/
		.footer p {
			margin-bottom: 15px;
			padding-top: 15px;
		}
	}