@charset "utf-8";
/*
Theme Name: 湯の山ロッジテーマ
Theme URI: http://madecom.co.jp
Description: madecomtheme
Version: 1.0
Author: madecom
Author URI: http://madecom.co.jp
*/


/* 以下ブログテーマのスタイル */


a {
	outline: none;
	-webkit-transition-duration: 0.25s;
	transition-duration: 0.25s;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
	display: block;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-size: 17px;
	margin: 0;
	padding: 0;
	line-height: 170%;
	font-family: "Noto Sans JP", "メイリオ", Meiryo, "Open Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Verdana, Helvetica, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ＭＳ Ｐゴシック", "MS PGothic", Arial, sans-serif;
	position: relative;
	font-weight: 400;
	background: #FFF;
	color: #333333;
}


h1 {
	font-weight: 700;
}

h1 img {
	max-width: 100%;
}

h2 {
	font-size: 28px;
	margin: 0 0 30px 0;
	font-weight: 700;
	line-height: 1.6;
	padding: 0 0 0 0;
}

h3 {
	font-size: 25px;
	margin: 15px 0 10px 0;
	font-weight: 700;
	line-height: 1.6;
}

h3 span.small {
	font-size: 70%;
	display: block;
	letter-spacing: 0.1em;
}

h4 {
	font-size: 18px;
	font-weight: 700;
	margin: 10px 0 15px 0;
}

a,
a:visited {
	color: #515cae;
	text-decoration: underline;
}

a:hover,
a:active {
	color: #0066cf;
	text-decoration: none;
}

ul {
	padding: 0;
	margin: 0;
}

ol {
	counter-reset: num;
	list-style-type: none !important;
	padding: 0;
	margin: 0 0 20px 0;
}

ol li {
	position: relative;
	padding-left: 30px;
	line-height: 1.5em;
	padding: 0.3em 0.5em 0.3em 30px;
}

ol li:before {
	position: absolute;
	counter-increment: num;
	content: counter(num);
	display: inline-block;
	background: #333;
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	left: 0;
	width: 22px;
	height: 22px;
	line-height: 22px;
	text-align: center;
	top: 7px;
}

li {
	list-style-type: none;
	padding: 0;
	margin: 0;
}

p {
	padding: 10px 0;
}

hr {
	border: none;
	margin: 10px 0;
	clear: both;
}

input {
	margin: 3px;
	padding: 2px;
}

.aligncenter input {
	padding: 5px 20px;
}

table {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 5px 0;
	padding: 0;
	border-collapse: collapse;
}

th, td {
	padding: 8px 10px;
	text-align: left;
}

.alignright {
	float: right;
	margin: 0 0 15px 30px;
}

.alignleft {
	float: left;
	margin: 0 30px 15px 0;
}

.aligncenter {
	text-align: center;
	display: block;
	margin: 15px auto;
}

.mb0 {
	margin-bottom: 0px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb120 {
	margin-bottom: 120px !important;
}

.mr20 {
	margin-right: 20px;
}

.mr40 {
	margin-right: 40px;
}

.pd0 {
	padding: 0px !important;
}

.pd20 {
	padding: 0 20px;
}

.pd30 {
	padding: 30px 0;
}

.pd60 {
	padding: 60px 0;
}

.pd90 {
	padding: 90px 0 !important;
}
.pl20{
	padding:0 0 10px 16px;
}

.clear {
	clear: both;
}

/* For modern browsers */
.clearfix:before,
.clearfix:after {
	content: "";
	display: block;
	overflow: hidden;
}

.clearfix:after {
	clear: both;
}

.bg-gray {
	background-color: #f7f7f7;
}

/* For IE 6/7 (trigger hasLayout) */
.clearfix {
	zoom: 1;
}

.flexwrap, .flex {
	display: flex;
	flex-wrap: wrap;
}

.flex-b, .flex-2{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
 .flex-4, .flex-3{
	gap: 16px;
	display: flex;
	flex-wrap: wrap;
 }
 .flex-2{
	gap: 16px;
 }
.flex-c{
	justify-content: center;
}
.flex-2-c{
	width: 48%;
	margin-bottom: 20px;
}
.flex-2 li{
flex: 0 0 calc((100% - 16px) / 2);
}

.flex-3 li {
flex: 0 0 calc((100% - 32px) / 3);
	margin-bottom: 30px;
}

.flex-4 li {
flex: 0 0 calc((100% - 48px) / 4);
}

.flex-5 li {
	width: 20%;
}

.flex20 {
	width: 18%;
}

.flex30 {
	width: 28%;
}

.flex40 {
	width: 38%;
}

.flex50 {
	width: 50%;
}

.flex60 {
	width: 58%;
}

.flex70 {
	width: 67%;
}

.flex80 {
	width: 78%;
}

.flex-2-c li {
	width: 100%;
}

.alc {
	align-items: center;
}

.jcc {
	justify-content: center;
}

.reverse {
	flex-direction: row-reverse;
}

.bold {
	font-weight: bold;
}

.small {
	font-size: 85%;
	line-height: 1.5;
}

.small70 {
	font-size: 70%;
}

.big {
	font-size: 140%;
	line-height: 1.8;
	font-weight: 700;
}

.big2 {
	font-size: 120%;
	line-height: 1.8;
	font-weight: 700;
}

.red {
	color: #c20a00;
}

.blue {
	color: #006eb9;
}

.yellow {
	color: #cea700;
}

.underline {
	border-bottom: 2px solid #6687ae;
}

.gray {
	color: #9b9b9b;
}

.txr {
	text-align: right;
}

.txc {
	text-align: center;
}

.txc .centertxt {
	text-align: left;
	display: inline-block;
}

.lsl {
	letter-spacing: 0.15em;
}

.lhl {
	line-height: 2.4;
}

a.pdficon[href $='.pdf'] {
	padding: 4px 0 5px 25px;
	margin: 5px 5px 5px 0;
	line-height: 190%;
	background: transparent url(images/pdf.png) no-repeat left center;
}

.min {
	font-family: "Noto Serif JP", serif;
	font-weight:700;
	font-style: normal;
}

h2.adfont {
	font-size: 300%;
}

.contents {
	position: relative;
}

.wrap800 {
	max-width: 800px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

.wrap980 {
	max-width: 980px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

.wrap1100 {
	width: 80%;
	max-width: 1100px;
	box-sizing: border-box;
	padding: 0;
	margin: 0 auto;
}


.wrap1200 {
	width: 80%;
	max-width: 1200px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

@media screen and (max-width: 1300px) {
	.wrap1100 {
		width: 96%;
	}
}

@media screen and (max-width: 767px) {

	.wrap1200 {
		width: 92%;
	}

	.wrap800, .wrap980 {
		padding: 0;
	}

	h2.gfont_en {
		margin-bottom: 20px;
		font-size: 200%;
		font-weight: 800;
		letter-spacing: 0.02em;
	}

	.flex-b,.seibun .flex-3,.mealbtn,.courselist,.topnewswrap{
		flex-direction: column;
	}

	.flex-2-c, .flex-3 li, .flex30, .flex40, .flex50, .flex60, .flex70, .flex80, .links li {
		width: 100%;
	}
	.imgbox{
		gap: 8px;
	}
	.imgbox li{
	flex: 0 0 calc((100% - 8px) / 2);
}

	.mb40, .mb30 {
		margin-bottom: 10px !important;
	}

	.mb60, .mb90, .mb120 {
		margin-bottom: 30px !important;
	}

	.mr20, .mr40 {
		margin-right: 0;
	}

	.pd30 {
		padding: 14px 0;
	}

	.pd60, .pd90 {
		padding: 30px 0 !important;
	}

	.lhl {
		line-height: 2;
	}
}


/*ページネーション*/
.post-navigation {
	overflow: hidden;
	padding: 12px 5px;
	display: flex;
	margin-top: 60px;
	justify-content: space-between;

}

.prev, .all, .next {
	width: 33%;
}

.prev a, .all a, .next a {
	display: inline-block;
	padding: 2px 14px;
	font-size: 90%;
	border: 1px solid #666;
	color: #666;
	text-decoration: none;
	font-weight: 500;
}

.prev a:hover, .all a:hover, .next a:hover {
	border: 1px solid #2256b8;
	color: #2256b8;
	background-color: #ebe4e4;
}

#header {
	width: 100%;
	padding: 0;
	transition: .4s;
	z-index: 999;
	position: absolute;
	left: 0;
	top: 0;
	background-color: rgba(255,255,255,0.8);
}

@media screen and (min-width: 768px) {

	.pc_lhl {
		line-height: 2.4;
	}

	.pc_lsl {
		letter-spacing: 0.15em;
	}

	.pc_img_s {
		max-width: 75%;
	}
}

.logo {
	width: 220px;
	padding: 0;
	margin-left: 10px;

}

.logo h1 {
	margin-right: 8px;
}




/*ドロップダウンメニュ*/

nav#navigation ul {
	display: flex;
	flex-direction: row;
	justify-content: flex-end;
	font-weight: 700;
	letter-spacing: 0.06em;
}

nav#navigation ul li {
	list-style: none;
	position: relative;
}

nav#navigation ul li:last-child {
	border-right: 0;
}

nav#navigation ul li a {
	display: block;
	padding:26px 14px;
	text-align: center;
	line-height: 1.2;
	color: #333;
	font-size: 95%;
	text-decoration: none;
	position: relative;
	transition: .4s;
	font-weight: 400;
}

nav#navigation ul li a:hover {
	color: #9c9c9c;
}
nav#navigation ul li.headbtn a{
	background-color: #00421E;
	color: #FFF;
	position: relative;
	padding:26px 20px 26px 40px;
}
nav#navigation ul li.headbtn a:hover{
	background-color: #096934;
}

nav#navigation ul li.headbtn a::after,.topnews-l a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	left: 20px;
	width: 8px;
	height: 8px;
	border-top: 2px solid #FFF;
	border-right: 2px solid #FFF;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

nav#navigation ul li ul {
	width:300%;
	position: absolute;
	top: 70px;
	left: -100%;
	visibility: hidden;
	opacity: 0;
	-webkit-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-moz-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-ms-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-o-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	z-index: 9999;
	display: flex;
	flex-direction: column;
}

nav#navigation ul li:hover ul {
	visibility: visible;
	opacity: 1;
}

nav#navigation ul li ul a {
	font-size: 100%;
	display: block;
	line-height: 1.4;
	background-color: #3a4354;
	text-shadow: none;
	padding: 10px 14px;
	color: #FFF;
}

nav#navigation ul li ul a:hover {
	background-color: #5c6e8f;
	color: #FFF;
}

nav#navigation ul li ul li {
	margin: -5px 0 0;
	border-left: none;
	border-bottom: 1px solid #51658a;
	float: none;
	width: 100%;
	-webkit-transition: margin 0.1s ease-in;
	-moz-transition: margin 0.1s ease-in;
	-ms-transition: margin 0.1s ease-in;
	-o-transition: margin 0.1s ease-in;
	transition: margin 0.1s ease-in;
}

nav#navigation ul li:hover ul li {
	margin-top: 0;
}

nav#navigation ul li:hover ul li ul {
	visibility: hidden;
	opacity: 0;
}

nav#navigation ul li:hover ul li:hover ul {
	visibility: visible;
	opacity: 1;
}

.img-s {
	width: 200px;
	height: auto;
}
@media screen and (min-width: 1401px) {

	#header .wrap1200 {
		padding: 0 0 0 8px;
		max-width: 1400px;
	}
}
@media screen and (max-width: 1400px) {

	#header .wrap1200 {
		padding: 0 0 0 8px;
		width: 100%;
	}
}
@media screen and (max-width: 1020px) {
.head-r{
		display: none !important;
	}}

@media screen and (max-width: 768px) {

	.pc_only {
		display: none !important;
	}

	.logo {
		width:190px;
		margin: 5px 0 5px 0;
	}


	.sp_txl {
		text-align: left;
	}

	.sp_txc {
		text-align: center;
	}

	.sp_pd {
		padding: 0 14px;
	}
	.sp_mb14{
		margin-bottom: 14px;
	}

	.sp_img_s {
		width: 60%;
	}

	.sp_img_s80 {
		width: 80%;
	}

	.sp_flex {
		display: flex;
	}

	.sp_txt {
		font-size: 90%;
		line-height: 1.6;
	}

	.sp_reverse {
		flex-direction: column-reverse;
	}

	.sp_small {
		font-size: 80%;
		line-height: 1.6;
	}

	.big {
		font-size: 110%;
	}

	.big2 {
		font-size: 110%;
		line-height: 1.3;
	}

	.big2 p {
		line-height: 1.7;
	}


	#header .wrap1200 {
		padding: 0 0 0 8px;
		width: 100%;
	}

}
@media screen and (min-width: 1021px){
	.sp_menu{
		display:none;
	}
} 
@media screen and (max-width: 1020px) {

		.sp_menulogo {
		width:190px;
		margin: 5px 0 5px 0;
		padding-left: 5px;
		margin-top: 10px;
	}


	/*メニュー*/

	.openbtn {
		position: fixed;
		right: 5px;
		top: 5px;
		background: #3f6941;
		cursor: pointer;
		width: 50px;
		height: 50px;
		border-radius: 5px;
		z-index: 99999;
	}

	.openbtn .openbtn-area {
		transition: all .6s;
		/*アニメーションの設定*/
		width: 50px;
		height: 50px;
	}

	.openbtn span {
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 14px;
		height: 3px;
		border-radius: 2px;
		background: #fff;
		width: 45%;
	}

	.openbtn span:nth-of-type(1) {
		top: 15px;
	}

	.openbtn span:nth-of-type(2) {
		top: 23px;
	}

	.openbtn span:nth-of-type(3) {
		top: 31px;
	}

	.openbtn.active .openbtn-area {
		transform: rotate(360deg);
	}

	.openbtn.active span:nth-of-type(1) {
		top: 18px;
		left: 18px;
		transform: translateY(6px) rotate(-45deg);
		width: 30%;
	}

	.openbtn.active span:nth-of-type(2) {
		opacity: 0;
	}

	.openbtn.active span:nth-of-type(3) {
		top: 30px;
		left: 18px;
		transform: translateY(-6px) rotate(45deg);
		width: 30%;
	}
	.sp_menu {
		display: block;
		background-color: #3f6941;
		box-sizing: border-box;
		position: fixed;
		top: 0;
		right: -100%;
		width: 100%;
		height: 100vh;
		padding: 0 0 0;
		overflow-y: auto;
		color: #fff;
		z-index: 9999;
		transition: .3s ease-in-out;
		/*滑らかに表示*/
		opacity: 0;
	}

	.sp_menu.active {
		/*display: block;*/
		right: 0;
		opacity: 1;
	}

	.main_link {
		border-top: 1px solid #3f6941;
	}

	.main_link ul {
		display: none;
	}
	.menu-s{
		width: 50%;
	}
	    .sp_menu .main_link ul li.menu-l{
		width: 100%;
	}

	.sp_menu .lastl {
		background: none;
		padding-bottom: 20px;
	}

	.sp_menu .lastl img {
		margin-right: 10px;
		vertical-align: middle;
	}

	.sp_menu .main_link a {
		display: block;
		text-decoration: none;
		padding: 10px 10px 14px;
		color: #333;
		font-weight: bold;
		background-color: #fafafa;
		border-bottom: 1px solid #9e9e9e;
	}

	.sp_menu .main_link ul {
		display: flex;
		flex-wrap: wrap;
	}

	.sp_menu .main_link ul li {
		width: 50%;
	}

	.sp_menu .main_link ul a {
		display: block;
		text-decoration: none;
		padding: 10px 10px 14px;
		color: #333;
		font-weight: bold;
		background-color: #e2eaec;
		border-bottom: 1px solid #9e9e9e;
	}

	.sp_menu a.parent {
		background: #fafafa url(images/arrow-sita.svg) center right 10px no-repeat;
		background-size: 20px 20px;
	}

	.sp_menu a.active {
		background: #fafafa url(images/arrow-ue.svg) center right 10px no-repeat;
		background-size: 20px 20px;
	}

	.sp_menu nav {
		padding: 10px 0;
	}
}
@media screen and (min-width: 768px) {

	.sp_only,
	.sp_br {
		display: none !important;
	}

	.pc_txc {
		text-align: center;
	}

	.pc_txr {
		text-align: right;
	}

	.pc_alc {
		align-items: center;
	}

	.pc_reverse {
		flex-direction: row-reverse;
	}

}

/*----------トップページ------------------------*/

.mainimg{
	background: url(images/main.jpg) right center no-repeat;
	background-size: cover;
	padding: 150px 0;
	height: 100vh;
	min-height: 550px;
	position: relative;
}

.catch{
	width: 200px;
	height: 550px;
	position: absolute;
	right: 10%;
	top: 150px;
}

#topnews{
	background-color: #00421E;
	color: #FFF;
	
}
.topnews-l{
	width: 140px;
}
.topnews-l a{
	position: relative;
	padding-left: 40px;
	color: #FFF;
	text-decoration: none;
}
#topnews ul{
	padding: 0 20px;
	flex: 1;
}

#topnews ul a{
	color: #ffffff;
	display: block;
	padding: 10px 0;
	text-decoration: none;
}
#topnews ul a:hover{
	text-decoration: underline;
}
.newslist li a{
	display: block;
	padding: 10px 10px;
	text-decoration: none;
	color: #333;
	border-bottom: 1px dashed #dcdcdc;
}
.newslist li a:hover{
	background-color: #d7e0db;
}
.newsdate{
	display: inline-block;
	margin-right: 10px;
}
.top_coupon{
	width: 340px;
}
.top_furo{
	padding-top: 120px;
	background:url(images/nagare.png) 50px 40px no-repeat,linear-gradient(180deg, #DEE2D9 0%, #DEE2D9 80%, #fff 80%, #fff 100%); 
}
.top_heya{
	padding-top: 120px;
	background:linear-gradient(180deg, #FFECE1 0%, #FFECE1 80%, #fff 80%, #fff 100%); 
}

.top_syokuji{
	padding-top: 120px;
	background:url(images/yama.png) 10% 40% no-repeat,linear-gradient(180deg, #FFF4E0 0%, #FFF4E0 80%, #fff 80%, #fff 100%); 
}
.top_cont{
	flex: 1;
}
.top_furo h2,.top_heya h2,.top_syokuji h2{
	width: 150px;
	padding-right: 60px;
}
.top_furo h3,.top_heya h3,.top_syokuji h3{
	margin-bottom: 0;
}

.top_heya h2{
	position: relative;
}
.top_heya h2::after{
	content: "";
	background: url("images/sakura.png") 0 0 no-repeat;
	background-size: 260px 254px;
	width: 260px;
	height: 254px;
	position: absolute;
	bottom:10%;
	right:-20px;
}

.topss a{
	position: relative;
	padding-right: 30px;
	color: #333;
	text-decoration: none;

}
.topss a:hover{
		color: #36681f;
}
.topss a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	right: 8px;
	width: 8px;
	height: 8px;
	border-top: 2px solid #333;
	border-right: 2px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
		transition: .4s;
}
.topss a:hover::after{
		border-top: 2px solid #36681f;
	border-right: 2px solid #36681f;
		right: 0px;
}

#topkankou .topss a{
	color: #FFF;
}

#topkankou .topss a::after{
	border-top: 2px solid #FFF;
	border-right: 2px solid #FFF;
}

#topplan{
	background-color: #F2ECE8;
}
.topplan_ttl{
	padding-top: 20px;
	background: url(images/topplan_ttl_bg.png) center 0 no-repeat;
}
.topplan_ttl2{
	padding-top: 20px;
	margin: 40px 0;
	background: url(images/topplan_ttl_bg2.png) center 0 no-repeat;
}
.topplan_ttl h2,.topplan_ttl2 h2{
	width: 240px;
margin: 0 auto;}

.blackbg{
	background-color: #333;
	color: #FFF;
	display: inline-block;
	padding: 4px 14px;
	line-height: 100%;
}
.top_golf_t,#topkankou h2{
	font-size: 220%;
}
#topkankou{
	background: url(images/top_kankou_bg.jpg) 0 bottom no-repeat;
	background-size: cover;
	color: #FFF;
}



.arrowbtn a{
	font-weight: 400;
	font-size: 110%;
	display: inline-block;
	position: relative;
	padding: 14px 60px 14px 50px;
	text-decoration: none;
	color: #333;
	z-index: 2;
	background-color: rgba(255,255,255,0.9);
	border: 1px solid #dcdcdc;
}

.arrowbtn a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	left: 20px;
	width: 8px;
	height: 8px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.arrowbtn a:hover{
	background-color: rgba(255,255,255,0.5);
}

.yoyakubtn a{
	font-weight: 400;
	font-size: 120%;
	display: inline-block;
	position: relative;
	padding: 24px 60px 24px 60px;
	text-decoration: none;
	color: #333;
	border-radius: 10px;
	z-index: 2;
background-image: linear-gradient(to top, #e6b980 0%, #eacda3 100%);
	border: 1px solid #dcdcdc;
}

.yoyakubtn a:hover{
background-image: linear-gradient(to top, #d6ad77 0%, #dbc099 100%);
}
.hover-zoom {
	display: inline-block;
	overflow: hidden;
	transition: transform 0.3s ease;
	border: 2px solid rgba(255,255,255,0.4);
	transition: border-color 0.3s ease;
}

.hover-zoom:hover {
	border-color: rgba(255,255,255,0.6);
}

.hover-zoom img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.5s ease, filter 0.5s ease;
}

.hover-zoom:hover img {
	transform: scale(1.08);
	filter: brightness(0.8);
}


@media (max-width: 767px) {
	.mainimg{
	background: url(images/main_sp.jpg) center top no-repeat;
	background-size: cover;
	padding: 60px 0;
}

	.catch{
	width:25%;
}
.top_furo h2,.top_heya h2,.top_syokuji h2{
	width: 80px;
	padding-right: 18px;
}
.top_furo,.top_heya,.top_syokuji{
	padding: 40px 0;
	margin-bottom: 0 !important;
}

.top_furo{
	background:#DEE2D9 url(images/nagare.png) 0 bottom no-repeat; 
	background-size: 220px auto;
}
.top_heya{
	background:#FFECE1 url(images/sakura.png) 0 bottom no-repeat; 
	background-size: 160px auto;
}
.top_heya h2::after{
	display:none;
}

.top_syokuji{
	background:#FFF4E0 url(images/yama.png) 0 bottom no-repeat; 
		background-size: 160px auto;
}

.top-about h2{
	font-size: 100%;
	margin-bottom: 0;
}
.top-about .mb60{
	margin-bottom: 0 !important;
}
.top_golf_t,#topkankou h2{
	font-size: 120%;
	margin-bottom: 8px;
}
 .topplan_ttl h2,.topplan_ttl2 h2{
	width: 160px;
	margin: 10px auto;}

.topplan_ttl2{
		padding-top: 0;
		background: url(images/topplan_ttl_bg2.png) center 0 no-repeat;
		background-size:100% auto;}
.topnews-l h2{
	width: 110px;
margin: 0;}

.topnews-l{
	width: 100%;
	display: flex;
	justify-content: space-between;
}
	#topnews ul{
		padding: 0;
		width: 100%;
	}

	.arrowbtn a{
	font-weight: 400;
	font-size: 90%;
	line-height: 1.5;
	padding: 14px 20px 14px 44px;
	text-align: left;
}

}


/*--------------------お問い合わせフォーム-----------------------------*/

input[type="submit"] {
	appearance: none;
	-webkit-appearance: none;
}

.form {
	margin: 0 auto 30px;
}

.form table th, #wpcf7cpcnf table th {
	text-align: left;
	padding: 6px 10px;
	min-width: 20%;
}

.form table td, #wpcf7cpcnf table td {
	padding: 6px 20px;
	text-align: left;
}
#wpcf7cpcnf table td,#wpcf7cpcnf table th{
	border-bottom: 1px solid #cacaca;
}

.form td p, .form th p, .form p ,#wpcf7cpcnf p{
	padding: 0;
}

.form .input-l input,
.form .input-l textarea {
	width: 100%;
}

input#zip {
	width: 150px;
}

.form input.wpcf7-submit, .form input.wpcf7-confirm, .wpcf7cp-btns .wpcf7-form-control {
	padding: 12px 40px;
	background-color: #ff9900;
	color: #FFF;
	border-radius: 5px;
	border: none;
	font-size: 110%;
	font-weight: bold;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: .4s;
}
.wpcf7cp-btns{
	text-align: center;
}
.wpcf7cp-btns .wpcf7-form-control:hover {
	cursor: pointer;
	background-color: #db7500;
}

input[type="submit"]:hover {
	background-color: #db7500;
	cursor: pointer;
}

.formReq {
	background-color: #da452a;
	color: #FFF;
	font-size: 70%;
	font-weight: bold;
	padding: 3px 5px 5px 5px;
	line-height: 100%;
	display: inline-block;
	border-radius: 5px;
	margin-left: 5px;
	margin-right: 5px;
}

#wpcf7cpcnf {
	border: none !important;
	background-color: rgb(245, 241, 241) !important;
}

.form input.wpcf7-back {
	background-color: #dcdcdc;
	color: #000;
	padding: 12px 46px;
	display: inline-block;
	margin-left: 5px;
}

.privacyp {
	padding: 20px 10px;
}

span.wpcf7-list-item {
	margin: 0 !important;
}

form input,
form textarea {
	box-sizing: border-box;
	padding: 8px 10px;
}

.form .wpcf7-submit:disabled {
	background-color: #dcdcdc !important;
	color: #999 !important;
	padding: 12px 40px;
}

.form input[type="checkbox"],
.form input[type="radio"],
input#consentCheckbox {
	accent-color: #e40000;
	transform: scale(1.5);
}

.form .wpcf7-list-item label {
	padding: 2px 8px;
}

.form .wpcf7-list-item label:has(input:checked) {
	background-color: #feffd8;
}
div.wpcf7 .wpcf7-spinner {
    display: none !important;
}

.wpcf7cp-form-hide{
	display: none;
}
div#wpcf7cpcnf{
	position:  relative !important;
}

@media screen and (min-width: 768px) {

	.form {
		padding: 0 20px;
	}
}

.wpcf7-checkbox label {
	margin-right: 10px;
}

@media screen and (max-width: 767px) {

	.form table, #wpcf7cpcnf table,
	.form table tbody, #wpcf7cpcnf table tbody,
	.form table tr, #wpcf7cpcnf table tr,
	.form table th, #wpcf7cpcnf table th,
	.form table td, #wpcf7cpcnf table td,
	.form textarea, #wpcf7cpcnf textarea {

		display: block;
		box-sizing: border-box;
		width: 100%;
	}

	.form textarea, form input, form textarea {
		max-width: 100% !important;
	}

	.sp-l input {
		width: 100%;
	}

	.sp-vertical .mwform-checkbox-field {
		display: block;
		margin-left: 0 !important;
	}

	.wpcf7-submit, .form input.wpcf7-confirm {
		font-size: 17px;
		padding: 3px 25px;
		background: #e9e9e9;
		color: #363B3F;
		border-radius: 4px;
		-webkit-border-radius: 4px;
		-moz-border-radius: 4px;
		border-top: none;
		border-right: none;
		border-left: none;
		border-bottom: solid 4px #dcdcdc;
	}

	.wpcf7-submit:hover, .form input.wpcf7-confirm:hover {
		background-color: #dcdcdc;
		color: #dc143c;
	}
}
/*---------フッター--------------------------*/

a.contactbtn {
	background:rgba(255,255,255,0.1);
	text-decoration: none;
	color: #ffffff;
	border: 1px solid rgba(255,255,255,0.5);
	font-weight: 700;
	padding: 14px 10px 14px 10px;
	font-size: 120%;
	display: block;
	text-align: center;
	box-shadow: rgba(0, 0, 0, 0.15) 1.4px 1.4px 2.2px;
}

a.btnmail{
	text-align: left;
	font-size: 110%;
	display: flex;
	align-items: center;
	justify-content: center; 
	gap: 10px; 
}
a.btnmail::before {
	content: "";
	width: 24px;
	height: 24px;
	background: url(images/mail.svg) no-repeat center;
	background-size: contain;
}

a.contactbtn:hover {
	background:rgba(255,255,255,0.2) ;
	border: 1px solid rgba(255,255,255,0.8);
}


.footer {
	margin: 0 auto 0;
	padding: 80px 30px 80px;
	font-weight: 500;
	font-size: 90%;
	color: #fff;
	background-color: #00421E;
}

.footer h3 {
	max-width: 300px;
	width: 300px;
	margin: 0 auto;
}

.footer a, .footinfo-c a {
	text-decoration: none;
	color: #FFF;
}
.footbtn{
	gap: 8px;
	display: flex;
	flex-wrap: wrap;
 }
.footbtn li {
flex: 0 0 calc((100% - 16px) / 3);
	margin-bottom: 30px;
}

.foottel {
	font-size: 150%;
	font-weight: 700;
}

.footer p.copy {
	font-size: 12px;
	padding: 0;
	color: #fff;
	clear: both;
}

.footer p.copy a, .footer p.copy a:visited {
	color: #fff;
}
 .footmenu a{
	display: inline-block;
	padding: 4px 16px;
	line-height: 100%;
	border-right:1px solid rgba(255,255,255,0.5) ;
 }
  .footmenu a:hover{
	color: #cedbcf;
  }
  .footmenu li:last-child a{
	border-right: none;
  }

  .footbtn a.footyoyaku{
	color: #333;
	background-image: linear-gradient(135deg, #fdfcfb 0%, #e2d1c3 100%);
}
  .footbtn a.footyoyaku:hover{
	background-image: linear-gradient(135deg, #ebe3dc 0%, #d4c0af 100%);
}
.floatingban {
    position: fixed;
    z-index: 9997;
    top: 30%;
	right: 0;
	display: flex;
	flex-direction: column;
}
.floatingban a{
	display: inline-block;
	margin: 0;
}
.floatingban img{
	margin-bottom: 8px;
}


@media (min-width: 768px) and (max-width: 1300px) {
	footer .wrap1200 {
		width: 95%;
	}
}

@media screen and (max-width: 767px) {

	.footer {
		padding: 14px 8px 50px;
	}

	.footer h3 {
		max-width: 240px;
	}

	.footlogo {
		justify-content: space-between;
	}
	.footbtn{
		flex-direction: column;
	}
.footbtn li{
	width: 96%;
	margin: 0 auto 8px auto;
}
	footer p {
		padding-top: 0px;
		font-size: 85%;
	}

	.footer p.copy {
		font-size: 10px;
		margin: 0 0 10px 0;
		line-height: 1.3;
		padding-bottom: 0;
	}

	.footer .mb20 {
		margin-bottom: 8px !important;
	}

	#top-img li {
		height: 300px;
	}
.floatingban {
    position: fixed;
    z-index: 9998;
    top:auto;
	bottom: 0;
	right: 0;
	display: flex;
	padding: 6px 8px 0 8px;
	flex-direction:row;
}
.floatingban a{
	margin: 0 5px 0 0;
}
.floatingban img{
	margin: 0;
	width: 110px;
	height:auto;
}
img.floatsns{
	border-radius: 50vh;
		width: 36px;
		margin-right: 8px;
}
}

/*---------------------------*/

.wp-pagenavi {
	text-align: center;
}

.wp-pagenavi a, .wp-pagenavi span {
	padding: 3px 10px !important;
	margin: 2px 5px !important;
}

.wp-pagenavi {
	margin-bottom: 30px;
}

#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
}

#page-top a img {
	width: 60px;
	display: block;
}


.contactbox {
	position: relative;
}

.g_map {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 8px;
	padding-left: 8px;
	padding-right: 8px;
	height: 0;
	overflow: hidden;
}

.g_map iframe,
.g_map object,
.g_map embed,
.g_map video {
	position: absolute;
	top: 0;
	left: 8px;
	width: calc(100% - 16px);
	height: 100%;
}

/*--------------------下層ページ---------------------*/
.contents-page {
	position: relative;
}

.pagettl {
	letter-spacing: 0.1em;
	padding: 200px 0 100px;
	margin: 0 0 80px 0;
	position: relative;
	color: #ffffff;
	text-align: center;
	font-size: 110%;
	background: url(images/ttl-base.jpg) center center no-repeat;
	background-size: cover;
  text-shadow: 0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333;
}

.sttl {
	line-height: 1.4;
	font-size: 150%;
	padding: 24px 24px 24px 24px;
	border-top:2px solid #333;
	border-bottom: 2px solid #333;
	margin-bottom: 30px;
	position: relative;
	color: #333;
	font-family: "Noto Serif JP", serif;
}


.page-id-10 .pagettl{
	margin-bottom: 0;
}

.page-id-4 .pagettl{
	background: url(images/ttl-furo.jpg) center center no-repeat;
	background-size: cover;
}
.page-id-30 .pagettl{
	background: url(images/ttl-restrant.jpg) top center no-repeat;
	background-size: cover;
}
.page-id-22 .pagettl{
	background: url(images/ttl-kankou.jpg) top center no-repeat;
	background-size: cover;
}

.sttl2 {
	font-size: 120%;
	border-left: 1px solid #00421E;
	padding-left: 10px;
	color: #00421E;
	font-family: "Noto Serif JP", serif;
	font-weight:700;
	font-style: normal;
	margin-bottom: 14px;
}


.sttl3 {
	font-size: 110%;
	font-family: "Noto Serif JP", serif;
background-image: linear-gradient(135deg, #e2d1c3 0%, #fdfcfb 100%);
	padding: 14px 18px 14px 18px;
	line-height: 1.3;
	margin-bottom: 10px;
}

.table01 {
	margin: 10px 0 30px 0;
	font-size: 90%;
	line-height: 1.6;
	border-top: 1px solid #d4d4df;
}

.table02 {
	margin: 10px 0 30px 0;
	font-size: 90%;
	line-height: 1.6;
	border-top: 1px solid #d4d4df;
}
.page-id-10 .table02 td,.page-id-10 .table02 th{
	text-align: center;
}
.table03 {
	margin: 0;
	width: auto;
}

.table01 th, .table01 td, .table02 th, .table02 td, .table03 td {
	border: 1px solid #d4d4df;
	padding: 14px 16px;
	background-color: #f5f1f1;
}

.table01 th, .table02 th {
	white-space: nowrap;
	background-color: #456744;
	color: #FFF;
}
.table03 th {
	white-space: nowrap;
		padding: 14px 16px;
			border: 1px solid #919c93;
	background-color: #ccd8d1;
	color: #333;
}

.table03 td{
	border: 1px solid #919c93;
}

.table-menu td{
	padding: 14px 16px;
		font-family: "Noto Serif JP", serif;
border-bottom: 1px solid #b8beba;
}


.table-menu th{
padding: 14px 16px;
	font-family: "Noto Serif JP", serif;
	border-bottom: 1px solid #b8beba;
}

.nowrap {
	white-space: nowrap;
}


.list01 li {
	list-style-type: none;
	margin-bottom: 2px;
	padding-left: 21px;
	position: relative;
}

.list01 li:before{ 
  display:inline-block; 
  vertical-align: middle;
  content:'';
  width:0.8em;
  height: 0.8em;
  background: #146d27;
  border-radius: 50%;
  margin-right: 8px;
  position: absolute;
  left: 0;
  top: 8px;
}
.simplebox2{
	border: 1px solid #333;
	padding: 14px 20px;
	border-radius: 10px;
}

.simplebox2 .table03 th,.simplebox2 .table03 td{
	padding: 6px 10px;
}

@media screen and (max-width: 1200px) {
	.pagettl {
		padding: 120px 0 30px 0;
		margin: 0 0 10px;
  text-shadow: 0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333;
	}

	.pagettl h1 {
		font-size: 110%;
		padding: 10px;
	}

.sttl{
		font-size: 110%;
		padding: 12px 0;
}

}

@media screen and (max-width: 767px) {


	.table01,.table03,
	.table01 tbody,.table03 tbody,
	.table01 tr,.table03 tr,
	.table01 th,.table03 th,
	.table01 td,.table03 td  {
		display: block;
		box-sizing: border-box;
		width: 100%;
	}

	.table01 th, .table01 td,.table02 th{
		padding: 8px 5px;
		font-size: 90%;
	}

	.table01 th {
		border-bottom: none;
		padding: 5px;
	}


	.table02 td {
		line-height: 1.6;
		font-size: 90%;
		padding: 5px;
	}

	.table03 th{
		white-space: wrap;
	}
.table-scroll{
	overflow: auto;
  }
  
.table-scroll table {
	width: 100%;
	white-space: nowrap;
  }
  .table-scroll table td,.table-scroll table th{
	padding: 6px 10px;
	font-size: 90%;
  }
    .table-scroll::-webkit-scrollbar{
	height: 5px;
   }
  
   .table-scroll::-webkit-scrollbar-track{
	background: #F1F1F1;
   }
  
   .table-scroll::-webkit-scrollbar-thumb {
	background: #BCBCBC;
   }
.table-menu th,.table-menu td{
padding: 7px 12px;
}


	h2, h3 {
		font-size: 120%;
	}

	.simplebox {
		padding: 10px 14px;
		margin-bottom: 10px;
		background-color: #f5f5f5;
	}

	.list01 li {
		line-height: 1.5;
	}

	.simplebox2 {
		padding: 10px 16px;
	}
}

.fade-in {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 1.5s, transform 1s;
}

.fade-in.active {
	opacity: 1;
	transform: translateY(0px);
}

/* 2つ目の要素に200msのdelayをかける */
.fade2 {
	-moz-transition-delay: 200ms;
	-webkit-transition-delay: 200ms;
	-o-transition-delay: 200ms;
	-ms-transition-delay: 200ms;
	transition-delay: 200ms;
}

/* 3つ目の要素に400msのdelayをかける */
.fade3 {
	-moz-transition-delay: 400ms;
	-webkit-transition-delay: 400ms;
	-o-transition-delay: 400ms;
	-ms-transition-delay: 400ms;
	transition-delay: 400ms;
}

@media screen and (max-width: 767px) {
	.sptate {
		flex-direction: row;
	}

	.sptate .flex-2-c {
		width: 48%;
	}

	.footinfo {
		padding: 0 14px;
		flex-direction: column;
	}

	.footinfo-c-r {
		border: none;
	}

	.footinfo-c {
		padding: 0 1em;
	}

.sp2retsu li{
	flex: 0 0 calc((100% - 16px) / 2);
}

}


.mealbtn li{
	background-color: #333;
}
.mealbtn a{
	display: block;
	padding: 40px 8px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	  text-shadow: 0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333,
               0 0 10px #333;
			   border: 6px solid rgba(255,255,255,0.4);
			   	  filter: brightness(0.9); 
}
.mealbtn a:hover{
	border: 6px solid rgba(255,255,255,0.8);
}
.mealbtn_now a{
	  filter: brightness(1.30); 
}
#mb01 a{
	background: url(images/mb01.jpg) center center no-repeat;
	background-size: cover;

}
#mb02 a{
		background: url(images/mb02.jpg) center center no-repeat;
			background-size: cover;
}
#mb03 a{
		background: url(images/mb03.jpg) center center no-repeat;
					background-size: cover;
}


.gaibu{
	display: inline-block;
	margin-top: 10px;
	position: relative;
}

 .gaibu::after{
	content: "";
	background-image: url("images/gaibu.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	height: 1.2rem;
	width: 1.2rem;
	margin: 0 0 4px 4px;
	vertical-align: middle;
}

.waribiki{
	display: inline-block;
	color: #FFF;
	font-size: 110%;
	padding: 2px 14px;
	border-radius: 50vh;
	margin-bottom: 0;
	background-image: linear-gradient(-60deg, #ff5858 0%, #f09819 100%);
}

/*MTSSimplebookingform*/

.calendar-title{
	 background-color: #36681f;
	color: #FFF;
text-align: center;}

.booking-form-people-number-row,.yoyakujikan{
	display: none !important;
}

.monthly-calendar td{
	border:1px solid #dcdcdc;
	padding:0 0 6px 0 !important;
	vertical-align: top;
}

.monthly-calendar th{
	border:1px solid #dcdcdc;
}

.schedule-note{
	font-size: 85%;
	color:#ff6347;
}
.calendar-caption{
	background-color: #EEE;
	font-weight: 700;
}

.day-number{
	font-weight: bold;
	background-color: #f8f8ed;
}

.holiday .day-number,.sun .day-number{
	background-color: #f4c5ad;
}
.sat .day-number{
	background-color: #dce7f2;}

@media screen and (max-width: 767px) {
	.content-form legend{
		background-color: #146d27;
		color: #FFF;
		display: block;
		width: 100%;
	}
	.content-form tr,
	.content-form th, .content-form td{
		display: block;
		width: 100% !important;
		border-right:none !important ;
		text-align: left !important;
	}
	.content-form fieldset{
		border: none !important;
		padding: 0 !important;
	}
	.content-form button{
		font-size: 120%;
	}
	.mealbtn{
		gap: 8px;
	}
	.mealbtn a{
	padding: 30px 8px;}
	.mealbtn li{
		margin-bottom: 0px;
	}
}