@charset "utf-8";


.SP{display:none !important;}
@media only screen and (max-width:1024px){
	.PC{display:none !important;}
	.SP{display:block !important;}
}



/* =======================================
	プルダウン
======================================= */

.pull{
	margin: 22px 0 0 0!important;
	right:10px;
}

.pull select{
	height : 25px;
	line-height: 0;
	vertical-align: middle;
	padding:0 5px 0 5px;
}

@media only screen and (max-width:1024px){
	.pull{margin: 10px 45px 0 0!important;	position: fixed!important;}
	.topHead .pull{margin: 10px 0 0 0!important;}
}






/* =======================================
	ヘッダ
======================================= */

#head{
	padding:0 10px 0 15px;
	box-sizing: border-box;
	background: #ffffff;
}

#head .headInner{
	max-width:1200px;
	margin:auto;

}

/* トップ用 */
#head.topHead .headInner{
	max-width:1280px;
}

	#head .headInner .headLeft{
		position: relative;
		float:left;
	}

		#head .headInner .headLeft a img{
    -moz-opacity: 1.0!important;
    opacity: 1.0!important;
	}


header{
	position: absolute;
}


	#head .headInner .headRight{
		float:right;
		font-size: 90%;
		margin:20px 0 0 0;
	}

	#head .headInner .headRight p{
		margin:0 17px 0 0;
	}

		.headRight li.tw a{
			background: url(../img/common/icon_tw.gif) no-repeat left center;
			padding:1px 0 0 27px;
			line-height: 100%;
		}

		 .headRight li.jp a{
			background: url(../img/common/icon_jp.gif) no-repeat left center;
			padding:1px 0 0 27px;
		}



	#head .headInner .headRight .bttop a{
		background:#eeeeee;
		padding:1px 10px 0px 10px;
		display: inline-block;
	}


	#head .headInner .headRight .bttop{
		margin:-2px 20px 0 0;
		float:left;
	}
	#head .headInner .headRight .lang{
		float:right;
	}

#head.topHead .headInner .headRight .bttop{display: none!important;}


@media only screen and (max-width:1024px){
	#head{
		z-index: 10;
		position: fixed;
	}

	#head.topHead{
		background: #ffffff;
		width: 100%;
	}


	#head .headInner{
		max-width:100%;
	}

	#head .headInner .headLeft{
		width: 150px;
	}

	#head .headInner .headRight{
		text-align: center;
		margin:10px 0 0 0;
	}

	.headRight span{
		display: none;
	}

	#head .headInner .headRight li{
		margin:0 0 0 5px;
	}
}



/* clear */
#head .headInner:after,
#head .headInner .headRight:after{
	display:block;content:"";clear:both;overflow:hidden;
}



/* =======================================
	グロナビ
======================================= */

		#nav{
			position: relative;
			font-size:105%;
			background:#00602a;
		}
			#nav .navInner{
				width:1260px;
				margin:auto;
			}
				#nav .navInner h1{
					float:left;
				}
				#nav .navInner ul{
					margin:0 0 0 8px;
					float:left;
				}
					#nav .navInner ul li{
						float:left;
					}
					#nav .navInner ul li a{
						height:40px;
						padding:7px 49px 0 49px;
						display:block;
						color:#ffffff;
						box-sizing: border-box;
						text-align: center;
					}

					#nav .navInner ul li a:hover,
					body#home #nav .navInner ul li.nav_home a,
					body#furano #nav .navInner ul li.nav_furano a,
					body#shizukuishi #nav .navInner ul li.nav_shizukuishi a,
					body#naeba #nav .navInner ul li.nav_naeba a,
					body#kagura #nav .navInner ul li.nav_kagura a,
					body#hakkaisan #nav .navInner ul li.nav_hakkaisan a,
					body#myoko #nav .navInner ul li.nav_myoko a,
					body#karuizawa #nav .navInner ul li.nav_karuizawa a,
					body#manzaonsen #nav .navInner ul li.nav_manzaonsen a{
						text-decoration: none;
						background:#229000;
						color: #ffffff!important;
					}

/* clear */
#nav .navInner:after{
	display:block;content:"";clear:both;overflow:hidden;
}





/* =======================================
	固定メニュー
======================================= */


ul.fmstyle{
  position: fixed;
	bottom:0;
	right:0;
	z-index:2;
  /*width:100%;*/
}

ul.fmstyle li.first{
    float:left;
    position: relative;
    width:300px;
		border: 3px solid #ffffff;
		border-right: none;
		border-bottom: none;
	}

	ul.fmstyle li.first p,
	ul.fmstyle li.first a{
		background: #00602a;
		color: #ffffff;
    padding:7px 0 3px 0;
		text-align: center;
		font-weight: bold;
		font-size: 110%;
		cursor: pointer!important;
		display: block;
	}

	ul.fmstyle li.first p.ticket span,
	ul.fmstyle li.first a.ticket span{
		background: url(../img/common/icon_btn_ticket.png) no-repeat left center;
		padding:0 0 0 38px;
	}
	ul.fmstyle li.first p.hotel span,
	ul.fmstyle li.first a.hotel span{
		background: url(../img/common/icon_btn_hotel.png) no-repeat left center;
		padding:3px 0 0 28px;
	}

		ul.fmstyle li.first p:hover,
		ul.fmstyle li.first a:hover{
			/*background: #cc1f1a;*/
			color: #ffffff!important;
		}


ul.fmstyle li ul.inner{
	display: none;
	position: absolute!important;
	bottom:38px;
	width:100%;
}

	ul.fmstyle li ul.inner li a{
		background: #e6efdf!important;
		font-size: 100%;
		font-weight: normal;
		color: #0b5100;
		text-align: left;
		padding:5px 5px 5px 15px!important;
		border-top:1px solid #ffffff;
		border-left:1px solid #ffffff;
    display: block;
	}

		ul.fmstyle li ul.inner li a:hover{
			background: #d1e5c3!important;
			color: #0b5100!important;
		}


@media only screen and (max-width:1024px){
	ul.fmstyle{
	  width:100%;
	}

	ul.fmstyle li.first{
	  width:50%;
		border-left: 1px solid #ffffff;
		border-right: 1px solid #ffffff;
		border-top: 2px solid #ffffff;
		font-size: 80%;
	}
	ul.fmstyle li.first a span,
	ul.fmstyle li.first p span{
		background: none!important;
		padding: 0!important;
	}

	ul.fmstyle.one li.first{
	  width:100%!important;
	}

	ul.fmstyle li ul.inner{
		bottom:34px;
	}

}



/* =======================================
	ページトップ
======================================= */
#pagetop{
  position: fixed;
  bottom: 15px;
  left: 15px;
	z-index:500;
}

/* =======================================
	topmain
======================================= */

#main .areaMenu{
	background: url(../img/map.png) no-repeat center top;
	width: 960px;
	height: 413px;
	margin: 50px auto 45px auto;
	position: relative;
}

	#main .areaMenu p{
		position: absolute;
	}

	#main .areaMenu p.areaFurano{
		left:195px;
		top:28px;
	}

	#main .areaMenu p.areaNaeba{
		left:65px;
		top:99px;
	}

	#main .areaMenu p.areaKagura{
		left:65px;
		top:154px;
	}

	#main .areaMenu p.areaMyoko{
		left:-33px;
		top:220px;
	}

	#main .areaMenu p.areaShizukuishi{
		right:37px;
		top:136px;
	}

	#main .areaMenu p.areaHakkaisan{
		right:82px;
		bottom:168px;
	}

	#main .areaMenu p.areaKaruizawa{
		right:125px;
		bottom:98px;
	}

	#main .areaMenu p.areaManzaonsen{
		right:125px;
		bottom:35px;
	}



#main .areaMenu_sp{
	width: 100%;
}

#main .areaMenu_sp a{
	display: block;
	border: solid 1px #aab7ca;
	padding:10px;
	font-size:120%;
	font-weight: bold;
	margin: 0 0 10px 0;
	color: #000000;
	background: url(../img/sp_arrow.png) no-repeat right center;
}
	#main .areaMenu_sp a span{
		font-size:80%;
		color: #006a1b;
	}











#main .topContents{
	padding:75px 0 75px 0;
	max-width:1280px;
	margin:auto;
}

#main .area{
	background: url(../img/sabg.jpg) no-repeat left top;
	background-size:100%!important;
}

/* video */
#main .video{
	background: url(../img/avbg.jpg) no-repeat left top;
	background-size:100%!important;
}
	#main .video .topVideo{
		width:855px;
		margin:80px auto 0 auto;
	}


#main .other{
	background: url(../img/ambg.jpg) no-repeat left top;
	background-size:100%!important;
}



/* orher */
		#main .other .topOther{
			display: table;
			margin:75px auto -80px auto;
		}
				#main .other .topOther h3{
					font-weight:bold;
					margin:10px 0 0 0;
					font-size: 150%;
				}
					#main .other .topOther h3 span{
						font-size: 80%;
						color: #000000;
					}

			#main .other .topOther .otherLeft{
				display: table-cell;
				text-align: center!important;
				padding:0 20px 0 0;
			}
				#main .other .topOther .otherLeft:last-child{
					padding-right:0;
				}

			#main .other .topOther .otherRight{
				display: table-cell;
				text-align: center;
			}


				#main .other .topOther h3.winter{
					color: #0064aa;
				}
				#main .other .topOther h3.autumn{
					color: #e44b00;
				}


/* special */

		#main .special .spInner{
			padding:60px 0 0 0;
			text-align: center;
		}


@media only screen and (max-width:1024px){
	#main .topContents{
		width:100%!important;
		margin:0 auto 0 auto;
		padding:35px 15px 35px 15px!important;
	}
		#main .video .topVideo{
			width:100%;
			margin:30px auto 0 auto;
		}

		#main .other .topOther{
			display: table;
			margin:30px 0 -40px 0;
		}

			#main .other .topOther .otherLeft{
				padding:0;
			}

		#main .other .topOther h3{
			margin:5px 0 0 0;
			font-size: 100%;
			line-height: 100%;
		}
		#main .other .topOther span{
			display: block;
		}

		#main .special .spInner{
			padding:30px 0 0 0;
			min-width: 100%;
		}
		#main .special .spInner.single{
			padding:0 0 0 0!important;
			min-width: 100%!important;

		}
			#main .special .spInner.single img{
				width:49%!important;
			}

			#main .special .spInner ul.topSpecial{
				width: 100%!important;
				float: none;
				padding-right:0;
			}

			#main .other .topOther .otherRight{
				padding:0 0 0 10px;
			}


}


/* clear */
#main .special .spInner:after{
	display:block;content:"";clear:both;overflow:hidden;
}



/* =======================================
	スライドショー
======================================= */

#container {
	height:617px;
	width: 100%;
	padding:0;
	margin:0;
  position: relative;
	z-index: 2!important;
	background: #ffffff;
}

body#top h1{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	width: 278px;
	height: 158px;
	z-index: 100!important;
}


@media only screen and (max-width:1024px){
	#container {
		height:380px;
		padding-top: 45px;
	}
	body#top #container {
		height:337px;
		padding:44px 0 0 0!important;
	}
	body#top h1{
		width: 220px!important;
		height:50px!important;
	}
}



@media only screen and (max-width:647px){
	#container {
		height:203px;
	}

	body#top #container {
		height:203px!important;
		padding:44px 0 0 0!important;
	}

	body#top h1{
		width: 120px!important;
		height:10px!important;
	}
}


/* =======================================
	タイトル
======================================= */

body#top button{display:none;}

.titleSet{
	width:100%;
	margin:-10px auto 0 auto;
	text-align: left;
}

	.titleSet h2{
		font-size: 210%;
		font-family:Helvetica!important;
		font-weight: bold;
		margin:0 0 20px 0;
	}



h2.cLine_top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  white-space: nowrap;
	font-size: 200%;
	font-weight: bold;
	color:#755e00;
}

h2.cLine_top.ac{
	color:#006a1b;
	margin:50px 0 50px 0;
}



h2.cLine_top:before,
h2.cLine_top:after {
  border-top: 1px solid #999999!important;
  content: "";
  display: inline; /* for IE */
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
  -ms-flex: 1;
  flex-grow: 1;
}

h2.cLine_top:before {
	margin-right: 0.5em;
}

h2.cLine_top:after {
	margin-left: 0.5em;
}

h2.cLine_top span {
	color:#000000;
	margin-left:7px;
}



@media only screen and (max-width:1024px){
	h2.cLine_top.ac{
		margin:30px 0 30px 0;
	}
}






/* =======================================
	アクティビティメニュー
======================================= */

/* 画像拡大キャプション表示 */
.ov_caption {
	position: relative;
	overflow:hidden;
	display:inline-block;
	vertical-align: bottom;
	/*line-height:0;*/
}
.ov_caption figure {
	vertical-align: bottom;
	display:inline-block;
	overflow: hidden;
	position: relative;
	text-align: center;
}
.ov_caption figcaption {
	position: absolute;margin: auto;top: 0;left: 0;right: 0;bottom: 0;
	color:#FFF;
	opacity: 0;
	transition:all 0.3s;
}
.ov_caption:hover figcaption {opacity: 1;}

.ov_caption figcaption ul{
	position: absolute;
	left:0;
	bottom:0;
}

.ov_caption figcaption ul li{
		float: left;
		width: 50%;
	}
.ov_caption figcaption ul li img{
		width: 100%!important;
	}



.ov_caption img.deImg{
	height: auto;
	transition:all 0.3s;
	/*width: 100%;*/
	/*vertical-align: bottom;*/
}

.ov_caption:hover img.deImg {
	transform:scale(1.1);
	-webkit-filter: blur(3px);
	filter: blur(3px);
}



.actSet{
	width: 1280px;
}

.actSet .act_inner{
	float: left;
	position: relative!important;
	width: 305px;
	margin:20px 20px 0 0;
}

.actSet .act_inner a img.nofade{
    -moz-opacity: 1;
    opacity: 1;
}

.actSet .act_inner:nth-child(4),
.actSet .act_inner:nth-child(8){
	margin-right:0;
}

	.actSet .act_inner h3{
		text-align: center;
		font-size: 110%;
		font-weight: bold;
		margin:8px 0 0 0;
		color: #0774a2;
	}
		.actSet .act_inner h3 span{
			color: #006b1b;
			margin:0 0 0 5px;
		}


/* ポップアップメニュー */



@media only screen and (max-width:1024px){
	.topContents{
		padding:7px 15px 15px 15px!important;
		box-sizing: border-box!important;
	}
	.titleSet{
		width:100%;
		margin:-15px auto 20px auto!important;
		line-height: 140%;
	}
	.titleSet h2,
	h2.cLine_top{
		font-size:140%;
	}
}

/* トップアコーディオン SPのみ */
.actSet_sp{
	border: solid 1px #aab7ca;
	background: #ffffff;
	margin-bottom: 10px;
}
	.actSet_sp .aco .acMenu{
		display: table;
	  background:url(../img/btn_open_sp.png) no-repeat right center;
	  cursor:pointer;
		width:100%;
	}
			.actSet_sp .aco .acMenu p{
				padding:1px;
				width:35%;
				display: table-cell!important;
			}

		.actSet_sp .aco .acMenu h3{
			font-size: 105%;
			width: 60%;
			font-weight: bold;
			line-height:110%;
			display: table-cell!important;
			vertical-align: middle!important;
			padding:0 0 0 10px;
			color: #0774a2;
		}
			.actSet_sp .aco .acMenu h3 span{
				color: #006b1b;
			}


	.actSet_sp .aco .acMenu.active{
	  background:url(../img/btn_close_sp.png) no-repeat right center!important;
	}
	.actSet_sp .aco .spec{
		border-top: 1px dotted #aab7ca;
		margin:0 0 0 0;
		padding:7px;
	  display:none;
	}

		.actSet_sp .aco .spec ul{
			display: table;
			width: 100%;
			margin-bottom:5px;
		}
			.actSet_sp .aco .spec ul:last-child{
				margin-bottom:0;
			}

		.actSet_sp .aco .spec ul li{
			text-align: center;
			display: table-cell;
			width: 33.3%;
		}
			.actSet_sp .aco .spec ul li a{
				display: block;
				border: solid 1px #5d7cb9;
				padding:0 10px 0 10px;
				margin-right:5px;
			}
			.actSet_sp .aco .spec ul li:last-child a{
				margin-right:0;
			}







/* clear */
.actSet:after,
.actSet_sp .aco .acMenu:after,
.ov_caption figcaption ul:after{
	display:block;content:"";clear:both;overflow:hidden;
}

/* =======================================
	footer
======================================= */

#sns{
	width:1200px;
	margin:0 auto 10px auto;
	text-align: right;
}
body#top #sns{
	width:1280px!important;
}


#sns .sns_go,
#sns .sns_tw,
#sns .sns_fb{
	display: inline-block;
	margin:0 0 0 15px!important;
}

#sns .sns_go{
	margin:0 0 0 0!important;
}


#footer {
  padding:0 0 65px 0!important;
	font-size:90%!important;
	min-width: 1280px;
}

body#top #footer {
	min-width: 1360px!important;
}

	#footer .footBg{
		background: #f3f5f6;
	}


		#footer .footBg .footInner{
			width:1200px;
			margin:0 auto 32px auto;
		}
		body#top #footer .footBg .footInner{
			width:1280px!important;
		}




	#footer .footBg .footInner ul.footNavi{
		padding:10px 0 10px 0;
		margin-left:-5px!important;
		float:left;
	}

	#footer .footBg .footInner ul.ftOther{
		float:right;
	}
		#footer .footBg .footInner ul.ftOther li{
			float:left;
			margin-left:10px;
		}
		#footer .footBg .footInner ul.ftOther li.other a{
			display:block;
			color:#000000;
			padding:3px 10px 0 10px;
			background:#e6ebed;
		}
			#footer .footBg .footInner ul.ftOther li.other a span{
				background: url(../img/common/arrowRight_2.png) no-repeat right center;
				padding:0 15px 0 0;
			}


		#footer .footBg .footInner ul.footNavi li{
			text-align:center;
			display:inline-block;
		  color:#1c1c1c;
			line-height:100%;
			padding:0 6px 0 6px;
			border-left:1px dotted #9d9d9d;
		}

		#footer .footBg .footInner ul.footNavi li:last-child{
			border-right:1px dotted #9d9d9d;
		}




		#footer .footBg .footInner ul.footNavi li.lastLine{
			border-right:1px dotted #9d9d9d!important;
		}

			#footer .footBg .footInner ul.footNavi li a{
				text-decoration:none;
				color:#1c1c1c;
			}



		#footer .foot_bottom{
			width:1200px;
			margin:auto;
		}

		body#top #footer .foot_bottom{
			width:1280px;
		}





			#footer .foot_bottom dl{
				float:left;
			}
				#footer .foot_bottom dl dt{
					float:left;
				}
				#footer .foot_bottom dl dd{
					margin:12px 0 0 20px;
					float:left;
				}
			#footer .foot_bottom p{
				margin:5px 0 0 0;
				float:right;
			}

		#footer p{
			font-family:Arial;
			color:#262626;
			font-size:110%!important;
		}


@media only screen and (max-width:1024px){
		#footer,
		body#top #footer{
			padding:0 0 70px 0!important;
			min-width: 100%!important;
		}

		#footer .footBg .footInner,
		body#top #footer .footBg .footInner{
			width:100%!important;
			padding:12px 0 10px 0;
		}
		#footer .foot_bottom,
		body#top #footer .foot_bottom{
			width:100%;
			text-align:center;
		}

		#footer .footBg .footInner ul.footNavi{
			padding:10px;
			float:none;
			width: 100%;
			text-align:center;
		}

		#footer .footBg .footInner ul.footNavi li{
			padding:0 6px 0 6px;
			margin-bottom:15px;
		}

		#footer .footBg .footInner ul.ftOther{
			float:none;
			width:268px;
			margin:-5px auto 10px auto;
		}

		#footer .foot_bottom dl{
			float:none;
		}
			#footer .foot_bottom dl dt{
				float:none;
			}
			#footer .foot_bottom dl dd{
				margin:10px 0 0 0;
				float:none;
			}
		#footer .foot_bottom p{
			float:none;
			margin:10px 0 0 0
		}

		#footer .foot_bottom img{
			width: 20%!important;
		}

	#sns,
	body#top #sns{
		width:100%!important;
		text-align: center;
		margin:0 0 18px 0;
	}
}

#main .covid{
	background:#ffd0cd!important;
		padding:25px;
	}
#main .covid p{
		width:1200px;
		text-align:left;
		margin:0 auto;
		
	}
body#top #main .covid p{
		width:1280px;
		text-align:left;
		margin:0 auto;
		
}
#main .covid p.title{
	font-size:120%;
	font-weight:bold;
	margin-bottom:10px;
}
#main .covid a{
	color:#000;
	text-decoration:underline;
}
	
	
	
	@media only screen and (max-width:1024px){
#main .covid p{
		width:auto;
		text-align:left;
		margin:0;
		
	}
body#top #main .covid p{
		width:auto;
		text-align:left;
		margin:0;
		
}
	}
	
	
	.t19{
		font-size:120%;
		margin-bottom:5px;
		margin-top:5px;
		color:#ee0000;
	}


.clear:after,
#footer .foot_bottom:after,
#footer .foot_bottom dl:after,
#footer .footBg .footInner:after,
#footer .footBg .footInner ul.ftOther:after{
	display:block;content:"";clear:both;overflow:hidden;
}

/******************************************************/
/* clear */
/******************************************************/

.clear:after{
	display:block;content:"";clear:both;overflow:hidden;
}
