@charset "utf-8";
.contWrapper {
    text-align: right;
}
.bn_camp{
	text-align: center;
 margin: 0 0 60px 0;
}
.bn_camp img{
	width: 50%;
 height: auto;
 border: 3px solid #92CC00;
}
.contentTitle{
	display: flex;
	justify-content: start;
	align-items: center;
	height: 66px;
	color: #fff;
	background: #3fa5f1;
	font-size: 3rem;
	font-weight: bold;
	line-height: 2;
	padding-left: 15px;
	margin-bottom: 30px;
}
.iconBox{
	display: block;
	width: 26px;
	height: 26px;
	margin-right: 10px;
}
.iconBox img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.contentText{
	text-align: center;
	font-size: 2rem;
	margin-bottom: 30px;
}
.itemList{
	width: 100%;
}
.item{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: flex-end;
	width: 100%;
	margin-bottom: 30px;
 padding: 0 10px;}
.item:nth-of-type(even){
	margin-bottom: 35px;
	flex-direction: row-reverse;
}
.item .itemImage{
	height: 315px;
	width: calc(100% - 535px - 20px);
	max-width: 470px;
}
.item01 .itemImage{
	border: solid 5px #008c55;
}
.item02 .itemImage{
	border: solid 5px #08618d;
}
.item03 .itemImage{
	border: solid 5px #843E23;
}
.itemImage img{
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.itemText{
	width: 535px;
}
.item h3{
	display: inline-block;
	position: relative;
	font-size: 2.6rem;
	line-height: 1;
	margin-bottom: 7px;
}
.item01 h3{
	color: #008c55;
}
.item02 h3{
	color: #08618d;
}
.item03 h3{
	color: #843E23;
}
.item h3::after{
	position: absolute;
	top: 50%;
	right: -40px;
	transform: translateY(-50%);
	content: "";
	height: 1px;
	width: 30px;
}
.item01 h3::after{
	background: #008c55;
}
.item02 h3::after{
	background: #0038b2;
}
.item03 h3::after{
	background: #843E23;
}
.itemLead{
	line-height: 1.87;
	margin-bottom: 16px;
}
.item01 .itemLead{
	color: #005d00;
}
.item02 .itemLead{
	color: #005da6;
}
.item03 .itemLead{
	color: #843E23;
}
.itemDesc{
	border-radius: 6px;
	font-size: 2rem;
	width: 100%;
	height: 230px;
}
.item01 .itemDesc{
	background: #f2ffea;
	border: solid 1px #28a100;
}
.item02 .itemDesc{
	background: #ebfbff;
	border: solid 1px #007fb5;
}
.item03 .itemDesc{
	background: #FCEFD9;
	border: solid 1px #AE7000;
}
.itemDesc p{
	margin: 20px 14px 34px;
}
.button-exp{
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff !important;
	font-size: 2.6rem;
	line-height: 1.15;
	width: 316px;
	height: 56px;
}
.item01 .button-exp{
	background: #008c55;
	border-radius: 6px 2px 5px 2px;
	margin: 0 0 0 auto;
}
.item02 .button-exp{
	background: #08618d;
	border-radius: 2px 6px 2px 5px;
	margin: 0 auto 0 0;
}
.item03 .button-exp{
	background: #843E23;
	border-radius: 2px 6px 2px 5px;
	margin: 0 auto 0 0;
}
.activeList{
 margin: 60px 0;
}
.expTitle{
	color: #008c55;
	font-size: 2.6rem;
	text-align: center;
	line-height: 1.15;
	margin-bottom: 10px;
}
.expTitle.item02,.expLead.item02{
	color: #08618d;
}
.expTitle.item03,.expLead.item03{
	color: #843E23;
}

.expLead{
	color: #005d00;
	font-size: 1.6rem;
	text-align: center;
	line-height: 1.87;
	margin-bottom: 15px;
}
.expList{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
.expItem{
	/*width: 26vw;*/
	max-width: 300px;
	min-width: 310px;
	margin: 0 4px 60px;
}
.expImage{
	width: 100%;
	height: 17vw;
	max-height: 230px;
	min-height: 210px;
}
.expImage img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.expDesc{
	width: 100%;
}
.expName{
	font-size: 2.0rem;
	line-height: 1.25;
	margin: 5px 0;
}
.expTel, .expPeriod{
	display: flex;
	justify-content: start;
	align-items: center;
	margin-bottom: 7px;
}
.expTel .tel, .expPeriod .period{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 42px;
	height: 24px;
	background: #49a700;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.66;
	margin-right: 6px;
}
.expTel a, .expPeriod span{
	font-size: 1.4rem;
	line-height: 1.42;
}
.expPeriod .period{
	background: #00a783;
}
.expDesc table{
	width: 100%;
	text-align: center;
	font-size: 1.4rem;
	line-height: 1.85;
}
.expDesc th{
	font-weight: normal;
	background: #f0ffff;
}
.expDesc table, .expDesc th, .expDesc td{
	border-collapse: collapse;
	border: 1px solid #757575;
}
.expDesc th, .expDesc td{
	width: calc(100% / 3);
}
/* [PC]メインコンテンツ　ここまで */

/* [PC]キャンペーンリンク　ここから */
.contentWrapper02{
	max-width: 1080px;
	min-width: 315px;
	height: 42.9vw;
	max-height: 550px;
	min-height: 404px;
	padding: 20px;
}
.campaignBox{
	position: relative;
	width: 100%;
	height: 100%;
}
.campaignBox.bg1{
	background: url(../img/campaign/campaign_bg1_pc.png) right/cover no-repeat;
}
.campaignBox.bg2{
	background: url(../img/campaign/campaign_bg2_pc.png) right/cover no-repeat;
}
.campaignBox.bg3{
	background: url(../img/campaign/campaign_bg3_pc.png) right/cover no-repeat;
}
.campaignBox.bg5{
	background: url(../img/campaign/campaign_bg5_pc.png) right/cover no-repeat;
}
.campaignLink{
	display: block;
	position: absolute;
	top: 50%;
	left: 5%;
	transform: translate(0, -50%);
	-webkit-transform: translate(0, -50%);
	width: 43vw;
	max-width: 400px;
	height: auto;
	padding: 10px;
}
.campaignLink.reverse{
 left: inherit;
	right: 0;
}
.campaignImage{
	display: block;
	width: 100%;
	height: 100%;
}
.campaignImage img{
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.campaignDesc{
	position: absolute;
	top: 50%;
	right: 2vw;
	transform: translateY(-50%);
	width: 30vw;
	max-width: 497px;
	min-width: 400px;
	height: auto;
	font-size: 2rem;
}
.campaignDesc.reverse{
	right: inherit;
 left: 1vw;
}
.campaignSpan{
	display: flex;
	justify-content: center;
	align-items: center;
	height: 53px;
	background: rgba(255, 255, 255, 0.9);
	border-radius: 30px;
	text-align: center;
	margin-bottom: 15px;
}
.campaignText{
	background: rgba(255, 255, 255, 0.9);
	line-height: 1.75;
	padding: 30px 20px;
}
.campaignText a{
	text-decoration: underline;
	color: #006CD6;
}
/* [PC]キャンペーンリンク　ここまで */

/* [PC]エリア検索ボタン　ここから */
.contentWrapper03 .text{
	color: #3fa5f1;
	text-align: center;
	font-size: 1.8rem;
	margin-bottom: 15px;
}

/* [PC]スポットリスト　ここから */
.spotList{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
.spot{
	max-width: 300px;
	margin-bottom: 20px;
	margin-left: 4px;
	margin-right: 4px;
}
.imageWrapper{
	width: 100%;
	height: auto;
	position: relative;
	cursor: pointer;
}
.imageWrapper:hover{
	opacity: 0.7;
	transition: 0.3s;
}
.spotImage{
	width: 100%;
	height: 100%;
}
.spotImage img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.imageWrapper .area{
	position: absolute;
	left: 3px;
	bottom: 6px;
}
.seasonWrapper{
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
	align-items: center;
	width: 100%;
	height: 34px;
	background: #993844;
	margin: 5px 0 11px;
	padding: 0px 3px 0px 15px;
}
.seasonTitle{
	color: #fff;
	padding-right: 15px;
}
.seasonMonth{
	display: flex;
	justify-content: center;
	align-items: center;
	color: #993844;
	background: #fff;
	width: 80%;
	height: 28px;
}

.contentWrapper h2.spotlistTitle{
	display: flex;
	justify-content: start;
	align-items: center;
	height: 66px;
	background: #f7f7f7;
	border-top: 1px solid #3fa5f1;
	border-bottom: 1px solid #3fa5f1;
	padding-left: 15px;

	color: #383838;
	font-size: 2.0rem;
	font-weight: normal;
	line-height: 1.25;
	margin-bottom: 7px;
}

.spotText{
	color: #000;
	font-size: 1.4rem;
	text-align: left;
	line-height: 1.42;
}
.contWrapper{
	text-align: right;
	width: 100%;
}
a.cont{
	display: inline-block;
	color: #916f00;
	font-size: 1.4rem;
	line-height: 1.42;
	text-decoration: underline #916f00;
	-webkit-text-decoration: underline #916f00;
	cursor: pointer;
}
a.cont:visited, a.cont:hover{
	text-decoration: none;
	-webkit-text-decoration: none;
}
/* [PC]スポットリスト　ここまで */

.contentWrapper04, .contentWrapper05{
	padding: 45px 30px 30px;
}
.contentWrapper05{
	margin-bottom: 68px;
}
.eventTitle{
	position: relative;
	text-align: left;
	font-size: 3rem;
	line-height: 2;
	padding-left: calc(80px + 30px);
	margin-bottom: 46px;
}
.eventTitle .num{
	padding-top: 15px;
	position: absolute;
	width: 80px;
	height: 80px;
	left: 0px;
	top: -10px;
	color: #fff;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
	background-color: #3fa5f1;
	border-radius: 50%;
}
.eventTitle .num.num2{
	background-color: #1E67B6;
}
.eventTitle .num.num3{
	background-color: #1B8783;
}
.eventTitle .num span{
	display: inline-block;
	font-size: 4rem;
	line-height: 1;
	vertical-align: 3px;
}
.eventDesc{
	display: flex;
	justify-content: center;
}
.eventImage{
	width: 33vw;
	max-width: 422px;
	min-width: 310px;
	height: 33vw;
	max-height: 422px;
	min-height: 310px;
	margin-right: 5vw;
}
.contentWrapper05 .eventImage{
	width: 32.9vw;
	height: 24.4vw;
}
.eventImage img{
	width: 100%;
	height: auto;
	object-fit: unset;
}
.eventText{
	width: 40vw;
	max-width: 510px;
	min-width: 310px;
	font-size: 2rem;
	line-height: 1.75;
}
.eventText p{
	margin-bottom: 38px;
}
.eventAlert{
	color: #ff0000;
}
.textBr{
	display: none;
}

/* [PC]モーダル　ここから */
.modalBack {
  position: fixed;
  width: 100vw;
  height: 100vh;  
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
	background: rgba(0, 0, 0, 0.34);
  overflow-y: scroll; 
	opacity: 1;
	visibility: visible;
	transition: 0.5s all ease;
}
.modalBack.disable {
	opacity: 0;
	visibility: hidden;
}
.modal{
	position: relative;
	height: auto;
	width: 66vw;
	max-width: 1000px;
	background: #fff;
	padding: 55px 67px;
	border-radius: 30px;
	margin: 15% auto 0;
}
.modalWrapper{
	height: 100%;
}
.modalClose{
	position: absolute;
	top: -30px;
	right: -22px;
}
.modalClose img{
	width: 68px;
}
body.modal-open {
	overflow: hidden;
	height: 100%;
}
.modalTitle{
	color: #383838;
	font-size: 3rem;
	text-align: center;
	margin-bottom: 20px;
}
.modalText{
	font-size: 2rem;
	margin: 0 auto 30px;
}
.modalSeasonBox{
	background: #993844;
	width: 176px;
	height: 63px;
}
.modalSeason{
	display: block;
	width: 170px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	color: #fff;
}
.modalMonth{
	display: block;
	width: 170px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	background: #fff;
	color: #993844;
	margin-left: 3px;
}
/* [PC]モーダル　ここまで */

/* モーダルスライダー　ここから */
.slider-for{
	width: 100%;
	max-width: 766px;
	min-width: 305px;
	height: 40vw;
	max-height: 509px;
	min-height: 202px;
	margin: 0 auto 15px;
}
.slider-for .slick-list{
	padding-right: 0 !important;
}
.slider-nav .slick-list{
	padding-right: 0 !important;
}
.mainImage{
	width: 100%;
	max-width: 766px;
	min-width: 305px;
	height: 40vw;
	max-height: 509px;
	min-height: 202px;
}
.mainImage img{
	width: 100%;
	max-width: 766px;
	min-width: 305px;
	height: 40vw;
	max-height: 509px;
	min-height: 202px;
	object-fit: cover;
}
.slider-nav{
	display: flex;
	justify-content: center;
	margin-bottom: 50px;
}
.thumImage{
	width: 7vw;
	max-width: 90px;
	min-width: 45px;
	height: 4vw;
	max-height: 60px;
	min-height: 30px;
	cursor: pointer;
}
.thumImage:first-of-type{
	margin-right: 10px;
}
.thumImage img{
	width: 7vw;
	max-width: 90px;
	min-width: 45px;
	height: 4vw;
	max-height: 60px;
	min-height: 30px;
	object-fit: cover;
}
/* モーダルスライダー　ここまで */
.shop_calendar{
 display: table;
 width: 94%;
 height: auto;
 margin: 10px auto 100px auto;
}
.shop_calendar caption{
 font-size: 2.4rem;
}
.shop_calendar caption span{
 font-size: 2.0rem;
}
.shop_calendar th,.shop_calendar td{
 padding: 10px;
 vertical-align: top;
}
.shop_calendar td{
 border: 1px solid #DADADA;
 padding: 10px;
}
.shop_calendar .day{
 display: block;
}
.shop_calendar .shop_calendar_trhd{
 border: 1px solid #959595;
}
.shop_calendar .shop_calendar_thhd{
 border: 1px solid #959595;
 width: 14.285%;
 box-sizing: border-box;
 background: #F6F4E4;
}
.shop_calendar .shop_calendar_thhd.sat{
 background: #E4EDF6;
}
.shop_calendar .shop_calendar_thhd.sun{
 background: #F6E4E9;
}

@media all and (min-width: 897px) {
}
@media all and (max-width: 896px) {
.bn_camp img{
	width: 80%;
 height: auto;
 border: 3px solid #92CC00;
}
.eventImage{
	width: 100%;
	max-width: 422px;
	min-width: 310px;
	height:auto;
	max-height:inherit;
	min-height:inherit;
	margin-right: 5vw;
}
.contentWrapper05 .eventImage{
	width: 100%;
	height: auto;
}

	.contentWrapper{
		padding: 2px 2px 40px;
		margin-bottom: 10px;
	}
/* [SP]メインコンテンツ　ここから */
	.contentTitle{
		height: 33px;
		font-size: 1.5rem;
		padding-left: 10px;
		margin-bottom: 15px;
	}
	.iconBox{
		width: 13px;
		height: 13px;
		margin-right: 5px;
	}
	.contentWrapper01 h2{
		height: 33px;
		font-size: 1.5rem;
		padding-left: 10px;
		margin-bottom: 15px;
	}
	.contentText{
		font-size: 1.2rem;
		margin-bottom: 15px;
	}
	.itemList{
		max-width: 650px;
		margin: 0 auto;
	}
	.item{
		margin-bottom: 64px;
	}
	.item:last-of-type{
		margin-bottom: 40px;
		flex-direction: initial;
	}
	.item .itemImage{
	width: 310px;
	height: 208px;
	}
	.itemText{
		width: 310px;
	}
	.item h3{
		font-size: 1.5rem;
		margin-top: 15px;
		margin-bottom: 4px;
	}
	.itemLead{
		font-size: 1.2rem;
		line-height: 1.24;
		margin-bottom: 10px;
	}
	.itemDesc{
		border-radius: 4px;
		font-size: 1.2rem;
		width: 100%;
		height: 133px;
	}
	.itemDesc p{
		margin: 20px 10px 11px;
	}
	.button-exp{
		font-size: 1.3rem;
		width: 158px;
		height: 28px;
	}
	.item01 .button-exp, .item02 .button-exp{
		border-radius: 4px 2px 3px 2px;
		margin: 0 0 0 auto;
	}
	.expList{
		max-width: 650px;
		margin: 0 auto;
	}
	.expItem{
		margin: 0 0 30px;
	}
	.expTitle{
	font-size: 1.5rem;
	}
	.expLead{
		font-size: 1.2rem;
		line-height: 1.25;
	}
	.expName{
		font-size: 2.2rem;
	}
	.expTel .tel, .expPeriod .period{
		width: 38px;
		height: 22px;
		font-size: 1.1rem;
	}
	.expTel a, .expPeriod span{
		font-size: 1.3rem;
	}
	.expDesc table{
		font-size: 1.3rem;
	}
/* [SP]メインコンテンツ　ここまで */

/* [SP]キャンペーンリンク　ここから */
	.contentWrapper02{
		height: 126vw;
		padding: 2px;
	}
	.campaignBox{
		background: url(../img/campaign/campaign_bg_sp.png) top/cover no-repeat;
	}
	
	.campaignBox.bg1{
		background: url(../img/campaign/campaign_bg1_sp.png) right/cover no-repeat;
	}
	.campaignBox.bg2{
		background: url(../img/campaign/campaign_bg2_sp.png) right/cover no-repeat;
	}
	.campaignBox.bg3{
		background: url(../img/campaign/campaign_bg3_sp.png) right/cover no-repeat;
	}
	.campaignBox.bg5{
		background: url(../img/campaign/campaign_bg5_sp.png) right/cover no-repeat;
	}

	.campaignLink{
		top: 0;
		left: 50%;
		transform: translate(-50% ,0);
		-webkit-transform: translate(-50% ,0);
		width: 100%;
		max-width: 497px;
		height: 404px;
		padding: 5px;
	}
	.campaignImage img{
		object-position: top;
	}
	.campaignDesc{
		top: initial;
		bottom: 3%;
		right: 50%;
		transform: translateX(50%);
		min-width: 305px;
		font-size: 1.2rem;
	}
.campaignDesc.reverse{
 left: inherit;
	right: 50%;
}
.campaignLink.reverse{
 left: 50%;
 right: inherit;
}
	.campaignSpan{
		display: none;
	}
	.campaignText{
		width: 100%;
		line-height: 1.41;
		padding: 8px 10px;
	}
/* [SP]キャンペーンリンク　ここまで */

	.contentWrapper03{
		padding: 15px 2px 0;
		margin-bottom: 5px;
	}

/* [SP]エリア検索ボタン　ここから */
	.text{
		font-size: 1.4rem;
		margin-bottom: 8px;
	}
	.areaList{
		margin: 0 auto 15px;
  flex-wrap: wrap;
	}
	.area{
		width: 64px;
		height: 30px;
		font-size: 0.8rem;
		margin-right: 3px;
  margin-bottom: 10px;
	}
	.area:last-of-type{
		margin-right: 0;
	}
	.area span{
		font-size: 1.2rem;
		vertical-align: -1px;
	}
	.area-hokuto{
		box-shadow: 0 2px 0 #9B3844 !important;
	}
	.area-okushiri{
		box-shadow: 0 2px 0 #412959 !important;
	}
	.area-aonae{
		box-shadow: 0 2px 0 #3c7029 !important;
	}
	.area-hokusei{
		box-shadow: 0 2px 0 #b37f4a !important;
	}
/* [SP]エリア検索ボタン　ここまで */

/* [SP]スポットリスト　ここから */
	.imageWrapper .area{
		left: 2px;
		bottom: 3px;
	}
	.seasonWrapper{
		width: 170px;
		height: 31px;
		padding: 0 2px 0 15px;
		font-size: 1.4rem;
	}
	.seasonMonth{
		width: 110px;
	}
	.spot{
  width: 170px;
		margin-bottom: 40px;
		margin-left: 0;
		margin-right: 0;
	}
	.spotlistTitle{
		font-size: 1.6rem;
		padding-left: 2px;
		margin-bottom: 8px;
	}
	.spotText{
		font-size: 1.2rem;
		padding: 2px;
	}
	.cont{
		font-size: 1.2rem;
		padding-right: 2px;
	}
/* [SP]スポットリスト　ここまで */

	.contentWrapper04, .contentWrapper05{
		padding-top: 32px;
	}
.eventDesc{
	flex-wrap: wrap;
}
	.eventTitle{
		font-size: 1.5rem;
		padding-left: calc(40px + 50px);
		margin-bottom: 18px;
	}
	.eventTitle .num{
		padding-top: 8px;
		width: 40px;
		height: 40px;
		left: 40px;
		top: -5px;
		font-size: 1rem;
	}
	.eventTitle .num span{
		font-size: 2rem;
	}
	.eventImage{
		margin-right: 6px;
		margin-left: 6px;
	}
	.eventText{
		font-size: 1.2rem;
	}
	.eventText p{
		margin:8px 0 15px;
	}
	.textBr{
		display: block;
	}

	/* [SP]モーダル　ここから */
.modal{
	width: calc(100vw - 10px );
	padding: 20px 2px;
	border-radius: 13px;
}
.modalClose{
	top: -15px;
	right: 5px;
}
.modalClose img{
	width: 27px;
}
.modalTitle{
	font-size: 1.5rem;
	margin-bottom: 8px;
}
.modalText{
	font-size: 1.2rem;
	margin: 0 auto 10px;
}
.modalSeasonBox{
	width: 88px;
	height: 36px;
	font-size: 0.8rem;
}
.modalSeason{
	width: 83px;
	height: 14px;
	line-height: 14px;
	padding-top: 3px;
}
.modalMonth{
	width: 83px;
	height: 14px;
	line-height: 14px;
	margin: 5px 2px 0 2px;
}
/* [SP]モーダル　ここまで */
}