
@charset "utf-8";



html {
  -webkit-font-smoothing: antialiased;
}

section + section {
margin-top: 0 !important;
}

.thispage_contents_wrap {
  width: 100%;
  margin: auto;
  padding: 0 0 120px;
  text-align: left;
}

.thispage_contents_wrap,
.thispage_contents_wrap li,
.thispage_contents_wrap dd {
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: left;
}

.thispage_contents_wrap p {
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: left;
	margin: 0;
  padding: 0;
}

.thispage_contents_wrap table,
.thispage_contents_wrap td,
.thispage_contents_wrap th {
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: left;
}

.thispage_contents_wrap table {
  border-top: 1px solid #e1d7b0;
}

.thispage_contents_wrap td,
.thispage_contents_wrap th {
  padding: 10px;
  border-bottom: 1px solid #e1d7b0;
}

.thispage_contents_wrap .red{
color: #ff3300;
}


.thispage_contents_wrap .small { font-size: 1rem !important; }
.thispage_contents_wrap .big {
  line-height: 1.6;
  zoom: 1.7;
}

.thispage_contents_wrap strong {font-weight: bold;}


.text_link {
	position: relative;
  display: inline-block;
  margin: 0;
  padding: 2px 0 0 20px;
}
.text_link.w {
	color: #ffffff;
}

.text_link::after {
	content: '';
	display: block;
	position: absolute;
	top: calc(50% - 3px);
	left: 2px;
	width: 7px;
	height: 7px;
	border-top:2px solid #5e5e5e;
	border-right:2px solid #5e5e5e;
	transform: rotate(45deg);
	transition: all 0.2s;
	-webkit-transition: all 0.2s;
}
.text_link.w::after {
	border-top:2px solid #ffffff;
	border-right:2px solid #ffffff;
}
.text_link:hover::after {
	left: 4px;
}


.clearfix::after {
	content: "";
	display: block;
	clear: both;
}
.clearfix {
	zoom: 1;
}

.tx_center {
  text-align: center;
}


/*テキストリンク*/

a.normal_button {
  display: inline-block;
  margin: 0;
  padding: 10px 40px;
  color: #ffffff;
  font-weight: bold;
  font-size: 2rem;
  background-color: #2ba738;
  transition: all 0.2s;
  -webkit-transition: all 0.2s;
}

a.normal_button:hover {
  background-color: #2bc0b6;
}


/*メインボタン*/
p.normal_button {
  margin: 50px 0 0 0;
  padding: 0;
  text-align: center;
}

p.normal_button a {
  display: inline-block;
  margin: 0;
  padding: 15px 40px;
  color: #000000;
  font-weight: bold;
  font-size: 170%;
  background-color: #dcbb00;
  border: 3px solid #ffffff;
  border-radius: 10px;
  box-shadow: 0 1px 10px 0 #32312f;
  transition: all 0.2s;
  -webkit-transition: all 0.2s;
}

p.normal_button a:hover {
  background-color: #eccd1b;
}

/*SP、PC切り替え*/

.sp{display: block;}



/*===========================================================================*/

/*
全体レイアウト要素
*/

/*===========================================================================*/

.section_block {
  position: relative;
  margin: 3em 0 0 0;
  padding-bottom: 50px;
}

.section_block .inner {
  position: relative;
  max-width: 1000px;
  width: calc(100% - 20px);
  margin: 0 auto;
}

.section_block img {
  max-width: 100%;
  height: auto;
}

.third {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
	grid-gap: 40px 20px;
}

.half {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
	grid-gap: 70px 50px;
}

.cel {
  position: relative;
}



/*===========================================================================*/

/*　KVエリア　*/

.kv {
  position: relative;
  margin: 0;
  padding: 0;
  background: url(../img/common/ja_bg_pattern.png), url(../img/kv/kv_under_mask.png);
  background-size: 100px, auto 60px;
  background-repeat: repeat, repeat-x;
  background-position: center center, center bottom;
  background-color: #000000;
  padding-top: 50px;
}

.kv .kv_explanation {
  display: none;
}

.kv img {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1400px;
}



/*===========================================================================*/
/*ローカルメニュー*/

.page_local_menu {
  margin: 50px auto 50px auto;
  padding: 0 10px 0 10px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  max-width: 1000px;
  width: 100%;
  text-align: center;
  grid-gap: 40px;
}

.page_local_menu li {
  margin: 0;
  padding: 0;
  position: relative;
  width: 100%;
  padding-top: 100%;
  border-radius: 50%;
  background-color: #d9dade;
}

.page_local_menu li:nth-of-type(1){
	background: url(../img/pagelink/pagelink_photoimg1.png) center center;
	background-size: cover;
}
.page_local_menu li:nth-of-type(2){
	background: url(../img/pagelink/pagelink_photoimg2.png) center center;
	background-size: cover;
}
.page_local_menu li:nth-of-type(3){
	background: url(../img/pagelink/pagelink_photoimg3.png) center center;
	background-size: cover;
}
.page_local_menu li:nth-of-type(4){
	background: url(../img/pagelink/pagelink_photoimg4.png) center center;
	background-size: cover;
}

.page_local_menu li a {
  position: absolute;
  bottom: 5px;
  left: 10%;
  width: 80%;
  margin: 0;
  padding: 5px 0;
  text-align: center;
  font-weight: bold;
  border: 1px solid #ff3300;
  background-color: #ffffff;
}

.page_local_menu li a[href="#omocha"] {
  border: 2px solid #007e05;
  color: #007e05;
}
.page_local_menu li a[href="#omocha"]::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -15px;
  left: calc(50% - 10px);
  width: 20px;
  height: 20px;
  background: url(../img/pagelink/pagelink_img1.png) center center no-repeat;
  background-size: 100%;
}

.page_local_menu li a[href="#winter"] {
  border: 2px solid #3791fd;
  color: #3791fd;
}
.page_local_menu li a[href="#winter"]::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -15px;
  left: calc(50% - 10px);
  width: 20px;
  height: 20px;
  background: url(../img/pagelink/pagelink_img2.png) center center no-repeat;
  background-size: 100%;
}

.page_local_menu li a[href="#snow"] {
  border: 2px solid #00a2b4;
  color: #00a2b4;
}
.page_local_menu li a[href="#snow"]::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -15px;
  left: calc(50% - 10px);
  width: 20px;
  height: 20px;
  background: url(../img/pagelink/pagelink_img3.png) center center no-repeat;
  background-size: 100%;
}

.page_local_menu li a[href="#onsen"] {
  border: 2px solid #bfb160;
  color: #bfb160;
}
.page_local_menu li a[href="#onsen"]::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -15px;
  left: calc(50% - 10px);
  width: 20px;
  height: 20px;
  background: url(../img/pagelink/pagelink_img4.png) center center no-repeat;
  background-size: 100%;
}


/*===========================================================================*/
/*コンテンツ　共通*/

.contents_area {
  position: relative;
}

.section_block {
  position: relative;
}

.center_section_block {
  margin: 0 auto 0 auto;
  padding: 0;
  max-width: 1200px;
  width: 100%;
  border: 1px solid #ff3300;
}

.contents_area .contents_kv img {
  display: block;
  margin: 0 auto;
  padding: 0;
  max-width: 2000px;
  width: 100%;
}

.notice {
	position: relative;
  margin: 0 auto 100px auto;
  padding: 0;
  max-width: 900px;
  width: 100%;
}

.notice:last-of-type {
  margin-bottom: 0;
}

/*写真1枚、またはクリック対象画像が3枚あるパターンの表示エリア*/

.notice .photo {
	position: relative;
  margin: 0;
  padding: 0 0 0 160px;
}

.notice h2 {
  margin: 0;
  padding: 0;
  font-weight: bold;
  font-size: 140%;
  transform: translate(0px, -20px);
}

.notice h2 i {
  font-style: normal;
  font-size: 70%;
}

.notice h2 span {
  padding: 15px 40px;
  display: inline-block;
  background-color: #ffffff;
}

.notice .text_explanation {
  width: 80%;
}

.notice .text_explanation p {
  color: #ffffff;
}

.dot_list {
  margin: 10px 0 10px 0;
  padding: 0;
	clear: both;
}

.dot_list.w {
  color: #ffffff;
}

.dot_list li {
  margin: 0;
  padding: 10px 5px;
  background: url(../img/common/dot_k50.png) center bottom repeat-x;
  background-size: 3px;
}
.dot_list.w li {
  margin: 0;
  padding: 10px 5px;
  background: url(../img/common/dot_w.png) center bottom repeat-x;
  background-size: 3px;
}

.dot_list li span {
  margin-right: 20px;
	font-weight: bold;
}

/*他の写真*/

.sub_images {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  width: 130px;
}

.sub_images li {
  margin: 0;
  padding: 0 0 10px 0;
}


/*===========================================================================*/
/*1　食を楽しむ*/

.dinner {
  background-color: #9f383d;
}

.dinner .header_area {
  position: relative;
  margin: 0;
  padding: 0;
  height: 300px;
  background: url(../img/common/bg_wave_w_pattern.png), url(../img/c1_dinner/header_img.jpg);
  background-size: auto 20px, cover;
  background-repeat: repeat-x, no-repeat;
  background-position: center top, center center;
}

.dinner .header_area .inner {
	position: relative;
  margin: 0 auto 0 auto;
  padding: 0;
  max-width: 1200px;
  width: 100%;
	height: 280px;
}

.dinner .header_area .inner h1 {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  overflow: hidden;
  margin: 0;
  padding-top: 500px;
  height: 0 !important;
  line-height: 250%;
  width: 220px;
  background: url(../img/c1_dinner/c_title.svg) center center no-repeat;
  background-size: 100%;
}

.dinner .header_area .inner h2 {
  position: absolute;
  bottom: 0;
  left: 250px;
  font-size: 140%;
	font-weight: bold;
	color: #ffffff;
}

.dinner .notice h2 span {
  background-color: #dcbb00;
}

.dinner .notice::before {
	content: '';
	display: block;
	position: absolute;
	top: 65%;
	left: 0px;
	height: 200px;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  background: url(../img/common/c1_bg_pattern.png) center center repeat-x;
  background-size: auto 100%;
}

.dinner .photo img {
  box-shadow: 0 1px 10px 0 #652629;
}


/*===========================================================================*/
/*2　あそぼっ！ランド*/

.omocha {
  background-color: #fff5dc;
	padding-bottom: 20px;
}

.omocha .header_area {
  position: relative;
  margin: 0;
  padding: 0;
  height: 300px;
  background: url(../img/common/bg_triangle_ele.png), url(../img/c2_omocha/header_img.jpg);
  background-size: auto 20px, cover;
  background-repeat: repeat-x, no-repeat;
  background-position: center top, center top;
}

.omocha .header_area .inner {
	position: relative;
  margin: 0 auto 0 auto;
  padding: 0;
  max-width: 1200px;
  width: 100%;
	height: 280px;
}

.omocha .header_area .inner h1 {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  overflow: hidden;
  margin: 0;
  padding-top: 500px;
  height: 0 !important;
  line-height: 250%;
  width: 220px;
  background: url(../img/c2_omocha/c_title.svg) center center no-repeat;
  background-size: 100%;
}

.omocha .header_area .inner h2 {
  position: absolute;
  bottom: 0;
  left: 250px;
  font-size: 140%;
	font-weight: bold;
	color: #ffffff;
}

.omocha .header_area .waku {
  margin: 0 10px 0 0;
  padding: 5px 10px;
  font-size: 70%;
  vertical-align: 3px;
  border: 1px solid #ffffff;
}

.omocha .section_block {
  margin: 0 auto 100px auto;
  padding: 0 10px;
  max-width: 1100px;
	width: 100%;
}

.omocha .section_block::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	height: 200px;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  background: url(../img/common/dot_cream_pattern.png);
  background-size: 15px;
}

.omocha .section_block.c1 h2 {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding-top: 170px;
	height: 0 !important;
	line-height: 250%;
	width: 100%;
	background: url(../img/c2_omocha/c_sub_title1.svg) center center no-repeat;
	background-size: auto 60px;
}

.omocha .section_block.c2 h2 {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding-top: 170px;
	height: 0 !important;
	line-height: 250%;
	width: 100%;
	background: url(../img/c2_omocha/c_sub_title2.svg) center center no-repeat;
	background-size: auto 60px;
}

.omocha .section_block.c3 h2 {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding-top: 170px;
	height: 0 !important;
	line-height: 250%;
	width: 100%;
	background: url(../img/c2_omocha/c_sub_title3.svg) center center no-repeat;
	background-size: auto 60px;
}

.omocha .section_block.c4 h2 {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding-top: 170px;
	height: 0 !important;
	line-height: 250%;
	width: 100%;
	background: url(../img/c2_omocha/c_sub_title4.svg) center center no-repeat;
	background-size: auto 60px;
}

.omocha .section_block img.p {
  box-shadow: 0 1px 10px 0 #e1d4b2;
}

.omocha .section_block h3 {
  position: relative;
  margin: 10px 0;
  padding: 5px 10px;
  font-size: 120%;
  font-weight: bold;
	border-left:4px solid #c8dfbc;
}

.omocha .section_block p.copy {
  clear: both;
}

.omocha p:first-of-type {
  width: 70%;
  float: left;
}

.omocha p.logo {
	box-sizing: border-box;
	padding: 10px;
  width: 28%;
  float: right;
	background-color:#ffffff;
	border-radius: 10px;
	text-align: center;
}

.omocha .table_spase {
  margin: 60px 0 0 0;
  padding: 20px;
  background-color: #ffffff;
}




/*===========================================================================*/
/*3　冬のコンテンツ*/

.winter {
	background: url(../img/common/winter_bg.png);
  background-size: 260px;
  background-color: #d1ecfc;
	padding-bottom: 20px;
}

.winter .header_area {
  position: relative;
  margin: 0;
  padding: 0;
  height: 300px;
  background: url(../img/common/bg_wave_y_pattern.png), url(../img/c3_winter/header_img.jpg);
  background-size: auto 20px, cover;
  background-repeat: repeat-x, no-repeat;
  background-position: center top, center top;
}

.winter .header_area .inner {
	position: relative;
  margin: 0 auto 0 auto;
  padding: 0;
  max-width: 1200px;
  width: 100%;
	height: 280px;
}

.winter .header_area .inner h1 {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  overflow: hidden;
  margin: 0;
  padding-top: 500px;
  height: 0 !important;
  line-height: 250%;
  width: 220px;
  background: url(../img/c3_winter/c_title.svg) center center no-repeat;
  background-size: 100%;
}

.winter .header_area .inner h2 {
  position: absolute;
  bottom: 0;
  left: 250px;
  font-size: 140%;
	font-weight: bold;
	color: #ffffff;
}

.winter .notice h2 span {
	color: #ffffff;
  background-color: #00b2d5;
}

.winter .notice .text_explanation p {
  color: #000000;
}

.winter .photo img {
  box-shadow: 0 1px 10px 0 #97aabd;
}



/*===========================================================================*/
/*5　雪遊び・スキー*/

.snow {
  background-color: #d7e3f9;
	padding-bottom: 20px;
}

.snow .header_area {
  position: relative;
  margin: 0;
  padding: 0;
  height: 300px;
  background: url(../img/c5_snow/header_img.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.snow .header_area .inner h2 {
  position: absolute;
  bottom: 10px;
  left: 250px;
  font-size: 140%;
	font-weight: bold;
	color: #ffffff;
}

.snow .header_area .inner h1 {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  overflow: hidden;
  margin: 0;
  padding-top: 500px;
  height: 0 !important;
  line-height: 250%;
  width: 220px;
  background: url(../img/c5_snow/c_title.svg) center center no-repeat;
  background-size: 100%;
}

.snow .notice h2 span {
	color: #ffffff;
  background-color: #3968be;
}

.snow .notice .text_explanation p {
  color: #000000;
}

.snow .photo img {
  box-shadow: 0 1px 10px 0 #7a93c0;
}

.snow .notice::before {
	content: '';
	display: block;
	position: absolute;
	top: 65%;
	left: 0px;
	height: 200px;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  background: url(../img/common/snow_bg.png) center center repeat-x;
  background-size: auto 100%;
}





/*===========================================================================*/
/*4　温泉施設*/

.onsen {
  background-color: #62573a;
	padding-bottom: 20px;
}

.onsen .header_area {
  position: relative;
  margin: 0;
  padding: 0;
  height: 300px;
  background: url(../img/common/bg_wave_snow_pattern.png), url(../img/c4_onsen/header_img.jpg);
  background-size: auto 20px, cover;
  background-repeat: repeat-x, no-repeat;
  background-position: center top, center center;
}

.onsen .header_area .inner {
	position: relative;
  margin: 0 auto 0 auto;
  padding: 0;
  max-width: 1200px;
  width: 100%;
	height: 280px;
}

.onsen .header_area .inner h1 {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  overflow: hidden;
  margin: 0;
  padding-top: 500px;
  height: 0 !important;
  line-height: 250%;
  width: 220px;
  background: url(../img/c4_onsen/c_title.svg) center center no-repeat;
  background-size: 100%;
}

.onsen .header_area .inner h2 {
  position: absolute;
  bottom: 0;
  left: 250px;
  font-size: 140%;
	font-weight: bold;
	color: #ffffff;
}

.onsen .notice h2 span {
  background-color: #ddd6ab;
}

.onsen .facility_info {
  margin: 50px auto 30px auto;
  max-width: 900px;
  width: 100%;
  font-size: 120%;
  line-height: 1.7;
  font-weight: bold;
}

.onsen .photo img {
  box-shadow: 0 1px 10px 0 #000000;
}

.onsen .facility_info p {
  margin-left: 160px;
  padding: 10px;
  text-align: center;
  background-color: #e3ddd1;
}

.onsen p.facility_memo {
  margin: 50px auto 30px auto;
  max-width: 900px;
  width: 100%;
  font-size: 120%;
  line-height: 1.7;
  font-weight: bold;
	color: #ffffff;
}






/*以上です*/
