@charset "utf-8";

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

   common

--------------------------------------------------------------------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400&display=swap');



/*reset-------------------------------------------------*/
body,div,h1,h2,h3,h4,h5,h6,p,dl,dt,dd {
  margin: 0;
  padding: 0;
}

* {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  border: none;
  vertical-align: top;
}

header,section,article,aside,footer,nav {
 display: block;
}

/*-------------------------------------------------reset*/


/*common-------------------------------------------------*/
body {
  margin: 0;
  padding: 0;
  color: #333;
  font-size: 15px;
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Lora', 'Noto Serif JP', 'Noto Serif SC', 'Noto Serif KR', 'Noto Serif TC', "ＭＳ Ｐ明朝", "MS PMincho", serif, 'Font Awesome 5 Free';
  line-height: 1.6;
	letter-spacing:1.3px;
}

#en, #vi {
	font-family: 'Roboto', sans-serif;
}

a {
  text-decoration: none;
  cursor: pointer;
  display: block;
	color:inherit;
}

a:hover,
a:visited,
a:active {
	color:inherit;
}

ul,li,ol {
  margin: 0px;
  padding: 0px;
  list-style: none;
}

address {
  font-style: normal;
}

.clear:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clear {
  display: inline-table;
  overflow: hidden;
	clear:both;
}

/* mac \*/
* html .clear {
  height: 1%;
}

.clear {
  display: block;
}


/*-------------------------------------------------common*/


/*--------------------------------------------------------------------------------------------
  header
--------------------------------------------------------------------------------------------*/
header {
	height:100px;
	position:relative;
	color:#084C64;
	position:fixed;
	top:0;
	width:100%;
	background:#FFF;
	z-index:9997;
}

header a:hover {
	opacity:0.8;
}

header .logo {
	position:absolute;
	left:20px;
	top:10px;
}

header .menu-top,
header .menu-bottom {
	position:absolute;
	right:0;
	margin:14px 20px;
	line-height:30px;
}

header .ss {
	float:right;
	width:440px;
}

header form .nice-select {
	margin:0 40px;
}

.nice-select {
/*  position: absolute!important;*/
  -webkit-tap-highlight-color: transparent;
  background-color: #fff;
  border: solid 1px #084C64;
  box-sizing: border-box;
  clear: both;
  cursor: pointer;
  display: block;
  float: left;
  font-family: inherit;
  font-size: 14px;
  font-weight: normal;
  height: 24px;
  line-height: 22px;
  outline: none;
  padding-left: 15px;
  padding-right: 30px;
  position: relative;
  text-align: left !important;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  white-space: nowrap;
  width: auto;
}
.nice-select:hover {
	border-color:rgba(8, 76, 100, 0.8);
}
.nice-select:after {
	border-bottom: 2px solid rgba(8, 76, 100, 0.5);
	border-right: 2px solid rgba(8, 76, 100, 0.5);
	content: '';
	display: block;
	height: 5px;
	margin-top: -4px;
	pointer-events: none;
	position: absolute;
	right: 12px;
	top: 50%;
	-webkit-transform-origin: 66% 66%;
			-ms-transform-origin: 66% 66%;
					transform-origin: 66% 66%;
	-webkit-transform: rotate(45deg);
			-ms-transform: rotate(45deg);
					transform: rotate(45deg);
	-webkit-transition: all 0.15s ease-in-out;
	transition: all 0.15s ease-in-out;
	width: 5px;
}
.nice-select.open:after {
	-webkit-transform: rotate(-135deg);
			-ms-transform: rotate(-135deg);
					transform: rotate(-135deg);
}
.nice-select.open .list {
	opacity: 1;
	pointer-events: auto;
	-webkit-transform: scale(1) translateY(0);
			-ms-transform: scale(1) translateY(0);
					transform: scale(1) translateY(0);
}
.nice-select .list {
	background-color: #fff;
	box-shadow: 0 0 0 1px rgba(68, 88, 112, 0.11);
	box-sizing: border-box;
	margin-top: 4px;
	opacity: 0;
	overflow: hidden;
	padding: 0;
	pointer-events: none;
	position: absolute;
	top: 100%;
	left: 0;
	-webkit-transform-origin: 50% 0;
			-ms-transform-origin: 50% 0;
					transform-origin: 50% 0;
	-webkit-transform: scale(0.75) translateY(-21px);
			-ms-transform: scale(0.75) translateY(-21px);
					transform: scale(0.75) translateY(-21px);
	-webkit-transition: all 0.2s cubic-bezier(0.5, 0, 0, 1.25), opacity 0.15s ease-out;
	transition: all 0.2s cubic-bezier(0.5, 0, 0, 1.25), opacity 0.15s ease-out;
	z-index: 9;
}
.nice-select .list:hover .option:not(:hover) {
	background-color: transparent !important;
}
.nice-select .option {
	cursor: pointer;
	font-weight: 400;
	line-height: 24px;
	list-style: none;
	min-height: 24px;
	outline: none;
	padding-left: 15px;
	padding-right: 29px;
	text-align: left;
	-webkit-transition: all 0.2s;
	transition: all 0.2s;
}
.nice-select .option:hover, .nice-select .option.focus, .nice-select .option.selected.focus {
	background-color:rgba(8, 76, 100, 0.1);
}
.nice-select .option.selected {
	font-weight: bold;
}

header .social li {
	float:left;
	margin:0 5px;
}

header .social i {
	font-size:22px;
}

header .bacc {
	float:right;
}

header .bacc li {
	float:left;
	margin:0 14px;
}

header .bacc li:first-child a {
	color:#FFF;
	background:#A70C0C;
	padding:4px 10px;
	line-height:normal;
}

header nav.menu-bottom {
	bottom:0;
}

header .menu-bottom li {
	float:left;
	margin:0 14px;
}


/*--------------------------------------------------------------------------------------------
  content
--------------------------------------------------------------------------------------------*/
a::after,
#contact span::before {
	font-family: 'Font Awesome 5 Free';
}

.bookingbtn {
	position:fixed;
	right:20px;
	bottom:20px;
	color:#FFF;
	background:#A70C0C;
	border-radius:100%;
	padding:33px 5px;
	min-width:90px;
	text-align:center;
	border:solid 1px #A70C0C;
	box-shadow:0 3px 10px rgba(0,0,0,0.4);
	transition:0.2s;
}

.bookingbtn:hover {
	color:#A70C0C;
	background:#FFF;
	box-shadow:0 5px 15px rgba(0,0,0,0.4);
}

iframe.bframe {
	display:none;
	position:fixed;
	top:50%;
	left:50%;
	transform:translate(-50%,-50%);
	border:none;
	transition:0.5s;
	z-index:9999;
	width:500px;
	height:420px;
	background:rgba(163, 126, 56, 0.5);
	border:solid 5px rgba(163, 126, 56, 0.5);
}

iframe.bframe.open {
	display:block;
	animation:booking 0.6s;
}

@keyframes booking {
	0% {opacity:0}
	100% {opacity:1}
}

#bframe-bg {
	display:none;
	background:url(images/overlay.png) repeat 0 0;
	opacity:0.9;
	position:fixed;
	width:100%;
	height:100%;
	top:0;
	left:0;
	overflow:hidden;
	z-index:9998;
}

#bframe-bg::after {
	content:'\f00d';
	font-family: 'Font Awesome 5 Free';
	font-weight:600;
	font-size:50px;
	color:#FFF;
	position:absolute;
	top:30px;
	right:60px;
	cursor:pointer;
}

#room,#restaurant,#event,#wellness {
	overflow:hidden;
}

.content {
	width:1080px;
	margin:0 auto;
}

.mainimg {
	position:relative;
	margin-top:100px;
}

.mainimg img {
	width:100%;
}

h2 {
	font-size:30px;
	font-weight:normal;
}

section.menu .menu-content {
	color:#FFF;
	position:relative;
}

section.menu .menu-content img {
	width:100%;
}

section.menu .menu-content div:not(.content) {
	position:absolute;
	background:rgba(0,0,0,0.5);
}

section.menu div a,
#facility .facility a.detail,
#gallery .content .area p {
	height:50px;
	line-height:50px;
	border:solid 1px #FFF;
	padding-left:1em;
	font-size:16px;
}

section.menu div a::after,
#facility .facility a.detail::after {
	content:'\f105';
	font-weight:600;
	margin-right:1em;
	float:right;
}

section.menu .menu-content a.detail {
	width:200px;
}

section.menu .menu-content a.detail:hover {
	background:rgba(255,255,255,0.3);
}

/*second*/
.mainimg h1 {
	position:absolute;
	top:0;
	background:rgba(8,76,100,0.5);
	width:100%;
	line-height:80px;
	color:#FFF;
	font-size:30px;
	font-weight:normal;
}

.mainimg h1 span.content {
	display:block;
}

.descrip {
	width:100%;
	height:100px;
	background:rgba(163,126,56,0.3);
	text-align:center;
	color:#084C64;
	position:relative;
	overflow:hidden;
}

.descrip p {
	width:1080px;
	position:absolute;
	top:50%;
	left:50%;
	transform:translate(-50%,-50%);
	-webkit-transform:translate(-50%,-50%);
}

section.menu .menu-content .wrap1080 {
	position:absolute;
	width:1080px;
	top:0;
	left:50%;
	transform:translateX(-50%);
	-webkit-transform:translateX(-50%);
}

section.menu .menu-content .wrap1080 div {
	top:100px;
	width:540px;
	padding:50px 30px;
}

section.menu .menu-content:nth-child(2n) .wrap1080 div {
	right:0;
}

section.menu .menu-content .wrap1080 p {
	margin:30px 0;
}

section.menu .menu-content .wrap1080 p br:first-of-type {
	font-size:20px;
}

section.content .photo {
	margin:100px 0;
	overflow:hidden;
}

section.content .slider {
	width:850px;
	float:left;
}

section.content .slider-nav {
	width:200px;
	float:right;
	margin:10px 0;
}

section.content .slider-nav .slick-slide {
	outline:none;
}

section.content .slider-nav .slick-current img {
	opacity:0.6;
}

section.content .slider-nav .slick-prev,
section.content .slider-nav .slick-next {
	left:50%;
	transform:translateX(-50%);
	-webkit-transform:translateX(-50%);
	width:20px;
	height:8px;
	border-left:solid 10px transparent;
	border-right:solid 10px transparent;
}

section.content .slider-nav .slick-prev {
	top:-10px;
	border-bottom:solid 8px #064C64;
}

section.content .slider-nav .slick-next {
	top:auto;
	bottom:-10px;
	border-top:solid 8px #064C64;
}

section.content .slider-nav .slick-prev::before,
section.content .slider-nav .slick-next::before {
	content:'';
}

section.content .info {
	overflow:hidden;
	margin-bottom:100px;
}

section.content .info dl {
	width:50%;
	float:left;
}

section.content .info dt {
	font-size:20px;
	color:#064C64;
	margin-bottom: 30px;
}

section.content .info dd ul div {
	float:left;
	width:45%;
}

section.content .info dd li {
	margin:5px 0;
}

section.other {
	padding:15px 0;
	position:relative;
	z-index:0;
	min-height:192px;
	display:flex;
	align-items:center;
}

section.other::after {
	content:'';
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	background:rgba(8,76,100,0.5);
	z-index:-1;
}

section.other ul {
	width:1080px;
	margin:0 auto;
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
}

section.other li {
	margin:15px;
}

section.other a {
	width:300px;
	height:50px;
	line-height:50px;
	border:solid 1px #FFF;
	padding-left:1em;
	font-size:16px;
	background:rgba(8,76,100,0.50);
	color:#FFF;
}

#en section.other a.long,
#vi section.other a.long,
#ko section.other a.long {
	width:380px;
}

#zh section.other a.long {
	width:340px;
}

section.other a:hover {
	background:#084c64;
}

section.other a::after {
	content:'\f105';
	font-weight:600;
	margin-right:1em;
	float:right;
}

h3 {
	font-size:20px;
	font-weight:normal;
	color:#084C64;
	margin-bottom:30px;
}



/*--------------------------------------------------------------------------------------------
  footer
--------------------------------------------------------------------------------------------*/
footer {
	color:#084C64;
	clear:both;
}

footer a:hover {
	opacity:0.8;
}

footer .content {
	padding:30px 0;
	overflow:hidden;
}

footer .footer-top {
	background:rgba(163,126,56,0.3);
}

footer .logo {
	display:inline-block;
	margin-bottom:10px;
}

footer .logo img {
	height:50px;
}

footer .address p {
	margin-top:10px;
}

footer .address p i {
	font-size:22px;
	width:23px;
	text-align:center;
	margin:0 10px;
	vertical-align:middle;
}

footer ul {
	float:right;
}

footer ul div {
	width:170px;
	float:left;
}

footer ul div:first-child {
	margin-right:30px;
}

#vi footer ul div:last-child {
	width:200px;
}

footer ul li {
	margin:5px 0;
}

footer .footer-bottom .content {
	padding:10px 0;
}

footer .footer-bottom a {
	float:left;
}

footer .footer-bottom p {
	float:right;
	line-height:40px;
}

/*--------------------------------------------------------------------------------------------
  booking
--------------------------------------------------------------------------------------------*/
#booking {
	width:456px;
	margin:0 auto;
	padding:30px 0;
	color:#FFF;
	font-size:14px;
	transition:0.5s;
}

#booking h2 {
	text-align:center;
	font-size:30px;
	margin-bottom:30px;
}

#booking div.field {
	clear:both;
	margin:20px 0;
	height:24px;
}

#booking div.field p {
	float:left;
}

#booking select {
	padding:1px 10px 5px;
	outline:none;
	cursor:pointer;
	font-family:inherit;
	font-size:inherit;
	border:none;
}

#booking input[type="text"] {
	font-family:inherit;
	font-size:inherit;
	letter-spacing:inherit;
	padding:0 5px;
	outline:none;
	border:none;
}

#booking input[type="button"] {
	width:100px;
	display:block;
	line-height:40px;
	text-align:center;
	margin:30px auto 0;
	background:#FFF;
	font-size:16px;
	/* font-family:"ヒラギノ明朝 Std W2", "Hiragino Mincho Std", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
	color:#a37e38;
	border:none;
	cursor:pointer;
	outline:none;
	border-radius:0;
	-webkit-appearance:none;
}

#booking input[type="button"]:hover {
	background:#a37e38;
	color:#FFF;
}

#en #booking input[type="button"] {
	width:155px;
}
/*-----index iframe-----*/
#index iframe {
	position:absolute;
	background:rgba(0,0,0,0.5);
	left:20px;
	left:20px;
	bottom:20px;
	width:400px;
	height:290px;
	border:none;
	display: none;
}

#vi #index iframe {
	width:476px;
}

@media all and (width: 400px) { /*index*/
	#booking {
		width:400px;
		height:290px;
		margin:0;
		padding:10px;
	}
	
	#booking h2 {
		font-size:30px;
		margin-bottom:0;
	}
	
	#booking div.field {
		margin:10px 0;
		height:24px;
	}
	
	#booking div.field.dates p {
		float:left;
	}
	
	#booking input[type="button"] {
		margin:0 auto;
	}
}
@media all and (width: 476px) { /*index*/
	#vi #booking {
		width:476px;
		padding:10px;
	}
	
	#vi #booking h2 {
		margin-bottom:0;
	}
	
	#vi #booking div.field {
		margin:10px 0;
	}
	#vi #booking input[type="button"] {
		margin:0 auto;
	}
}
@media all and (max-width: 399px) {
	#booking,
	#vi #booking {
		width:90%;
		font-size:13px;
	}
	
	#booking div.field {
		height:auto;
	}
	
	#booking div.field.dates p {
		float:none;
		margin-bottom:5px;
	}

}
.hotellinks-container{
	width: 80%;
    margin: 150px auto;
	padding-left: 16px;
	padding-right: 16px;
    overflow: hidden;
}

@media all and (max-width: 1025px) {
	.hotellinks-container{
		width: 85%;
	}
}
@media all and (max-width: 500px) {
	.hotellinks-container{
		margin: 100px auto;
		width: 100%;
	}
}