@charset "utf-8";
html,
[id^="top-"] h2 span,
#top-guest li a > span span,
main h1 span,
.base .box01 h2 span,
#roomsec01 ul span {
	font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "ＭＳ 明朝", "MS Mincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
#ptop,
[id^="top-"] h2,
#top-guest li a,
main h1,
.base .box01 h2,
#roomsec01 ul a,
#restaurantsec01 .ttl,
#partysec01 h4 {
	font-family: trajan-pro-3, "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "ＭＳ 明朝", "MS Mincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
html {
	font-size: 62.5%;
	color: #262626;
	background-color: #FFFFFF;
}
body {
	font-size: 2em;
}
a {
	color: #262626;
	text-decoration: none;
}
a:hover,
.slick-arrow:hover {
	opacity: 0.8;
}
img {
	max-width: 100%;
	height: auto;
}
@media all and (-ms-high-contrast:none) {
*::-ms-backdrop, table img {
	width: 100%;
}
}
/* class
============================== */
.sponly {
	display: none;
}
.clearfix::after {
	content:"";
	display:block;
	clear:both;
}
.right {
	text-align: right !important;
}
.center {
	text-align: center !important;
}
.col {
	display: flex;
	flex-wrap: wrap;
	margin-top: -50px !important;
}
.col + .col {
	margin-top: 0 !important;
}
.col.reverse {
	flex-direction: row-reverse;
}
.col > *,
.col.reverse > *:first-child {
	margin-left: 50px;
}
.col > * {
	flex: 1;
	margin-top: 50px !important;
}
.col > *:first-child,
.col.reverse > *:last-child {
	margin-left: 0;
}
.col-img {
	flex: 0 1 auto;
	max-width: 45%;
	text-align: center;
}
.gmap {
	position: relative;
	padding-top: 30px;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}
.gmap iframe,
.gmap object,
.gmap embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.btn {
	line-height: 1.4 !important;
	margin-top: 3em !important;
}
.btn a {
	display: block;
	width: 100%;
	max-width: 455px;
	font-size: 2.4rem;
	text-align: center;
	color: #FFFFFF;
	margin: 0 auto;
	padding: 1em;
	background: #996600;
}
.nav {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: center;
	padding: 0 !important;
}
#content > .nav {
	margin-top: 30px !important;
}
.nav li {
	margin-top: 1em;
	margin-left: 20px;
	margin-right: 20px;
}
.nav a {
	display: inline-block;
  font-size: 1.8rem;
	padding-bottom: 0.2em;
	border-bottom: 1px solid #262626;
}
/* ==================================================
layout
================================================== */
.wm,
header,
footer,
#content > .nav {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 20px;
}
header {
	max-width: 1366px;
}
#main-wrap {
	display: flex;
}
main {
	flex: 1;
	max-width: 100%;
}
#main-wrap > aside {
	width: 24.963vw;
}
#content-inner {
	max-width: 861px;
	margin-right: auto;
	padding: 70px 20px 0 70px;
}
/* ==================================================
header
================================================== */
header {
	display: flex;
	justify-content: space-between;
	padding-top: 20px;
	padding-bottom: 20px;
}
.drawer-hamburger {
	display: none;
}
#hnavi-wrap {
	width: 80%;
	max-width: 770px;
}
#hnavi {
	display: flex;
	justify-content: flex-end;
}
#hnavi li:nth-last-child(-n+2) a {
	display: block;
	width: 150px;
	font-size: 1.8rem;
	text-align: center;
	color: #FFFFFF;
	margin-left: 20px;
	padding: 0.8em;
	background: #996600;
}
#gnavi {
	display: flex;
	justify-content: space-between;
	text-align: center;
	margin-top: 25px;
}
#gnavi span {
	display: block;
	font-size: 1.2rem;
}
#gnavi a:hover,
#gnavi .on a {
	color: #BBBBBB;
}
/* ==================================================
footer
================================================== */
footer {
	text-align: center;
	padding-top: 50px;
	padding-bottom: 50px;
}
#fnavi {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	font-size: 1.8rem;
}
#fnavi a[href^="http"] {
	padding-left: 0.8em;
	background: url(../img/icon01.svg) left center / auto 0.6em no-repeat;
}
#flogo {
	margin-top: 2em;
}
#copyright {
	font-size: 1.2rem;
	margin-top: 1.5em;
}
/* ==================================================
aside
================================================== */
#main-wrap > aside {
	background: #262626;
	padding: 50px 30px;
}
#lnavi li:nth-child(n+2) {
	margin-top: 30px;
}
#lnavi a {
	display: block;
	line-height: 1.4;
  font-size: 1.8rem;
  color: #FFFFFF;
	padding-left: 18px;
	background: url(../img/arrow03r.svg) left center no-repeat;
}
#lnavi a:hover,
#lnavi .on a {
	color: #996600;
	background-image: url(../img/arrow03r02.svg);
}
#lnavi span {
	display: block;
  font-size: 1.7rem;
}
/* ==================================================
main
================================================== */
main {
	position: relative;
	line-height: 1.8;
}
body:not(#top) #content {
	padding-bottom: 160px;
	background: #F1ECE7;
}
main h1 {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	line-height: 1.4;
	font-size: 6.5rem;
	font-weight: normal;
	text-align: center;
	color: #FFFFFF;
}
main h1 span {
	font-size: 2.9rem;
}
#content-inner > *:first-child {
	margin-top: 0;
}
#ptop {
	position: -webkit-sticky;
	position: sticky;
	bottom: 0;
	margin-top: -120px;
	margin-left: auto;
	width: 120px;
	height: 120px;
}
#ptop a {
	display: block;
	height: 100%;
	line-height: 1;
	font-size: 1.6rem;
	text-align: center;
	color: #FFFFFF;
	padding-top: 55px;
	background: #262626 url(../img/arrow01t.svg) center 35px no-repeat;
}
#room-kv,
#restaurant-kv,
#party-kv,
#access-kv,
#event-kv {
	height: 21.961vw;
	padding-right: 0;
	padding-bottom: 0;
	background: url(../img/room-kv.jpg) center / cover no-repeat;
}
#room-kv::after,
#restaurant-kv::after,
#party-kv::after,
#access-kv::after,
#event-kv::after {
	content: normal;
}
#restaurant-kv {
	background-image: url(../img/restaurant-kv.jpg);
}
#party-kv {
	background-image: url(../img/party-kv.jpg);
}
#access-kv {
	background-image: url(../img/access-kv.jpg);
}
#event-kv {
	background-image: url(../img/event-kv.jpg);
}
/* base
============================== */
.base h1 {
	position: relative;
	height: 25.622vw;
	font-size: 4.6rem;
	padding-right: 50%;
	background: #996600;
}
.base h1:not([id]) {
	height: 21.961vw;
	padding-right: 0;
}
.base h1::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background: center / cover no-repeat;
}
.base #room01-kv::after {
	background-image: url(../img/room01-kv.jpg);
}
.base #room02-kv::after {
	background-image: url(../img/room02-kv.jpg);
}
.base #room03-kv::after {
	background-image: url(../img/room03-kv.jpg);
}
.base #room04-kv::after {
	background-image: url(../img/room04-kv.jpg);
}
.base #room05-kv::after {
	background-image: url(../img/room05-kv.jpg);
}
.base #room06-kv::after {
	background-image: url(../img/room06-kv.jpg);
}
.base #room07-kv::after {
	background-image: url(../img/room07-kv.jpg);
}
.base #room08-kv::after {
	background-image: url(../img/room08-kv.jpg);
}
.base #room09-kv::after {
	background-image: url(../img/room09-kv.jpg);
}
.base #room10-kv::after {
	background-image: url(../img/room10-kv.jpg);
}
.base #room11-kv::after {
	background-image: url(../img/room11-kv.jpg);
}
.base h1:not([id])::after {
	content: normal;
}
.base h1 span {
	font-size: 1.7rem;
}
.base h2,
.base h3,
.base h4,
.base h5,
.base h6 {
	line-height: 1.4;
	margin-top: 1.5em;
}
.base p,
.base ul,
.base ol {
	margin-top: 1em;
}
.base ul,
.base ol {
	padding-left: 40px;
}
.base ol {
	list-style: decimal;
}
.base ul > li {
	text-indent: -1em;
	margin-left: -1em;
	padding-left: 1em;
}
.base ul > li::before {
	content: "・";
}
.base ul ul,
.base ul ol,
.base ol ul,
.base ol ol,
.base li > *:not(li):first-child,
.base .col > * > *:first-child,
.base .box01 > *:first-child {
	margin-top: 0;
}
.base ul.col,
.base ol.col {
	padding-left: 0;
}
.base ul.col > li {
	text-indent: 0;
}
.base ul.col > li::before {
	content: normal;
}
.box01 {
	font-size: 1.6rem;
	background: #FFFFFF;
	margin-top: 50px;
	padding: 40px;
}
.box01 h2 {
	font-size: 2.4rem;
	font-weight: normal;
	margin-bottom: 1.6em;
	padding-bottom: 0.3em;
	border-bottom: 3px solid #996600;
}
.box01 h2 span {
	display: block;
	font-size: 1.8rem;
}
.box01 h3 {
	font-size: 1.8rem;
}
.list02 {
	padding-left: 0 !important;
}
.list ul,
.list02 > li {
	margin-left: 0 !important;
}
.list02 > li {
	text-indent: 0 !important;
	padding-left: 0 !important;
}
.list02 > li::before {
	content: normal !important;
}
.list {
	margin-top: 0 !important;
}
.list ul {
	flex: 0 1 auto;
	width: 33.33%;
	margin-top: 1em !important;
	padding-left: 1em;
}
.list02 li {
	margin-top: 2em;
}
.list02 p {
	line-height: 1.4;
	margin-top: 0;
}
.list02 p > span {
	font-size: 3.3rem;
}
.list02 p > span span {
	font-size: 2rem;
}
/* top
============================== */
.slick-prev,
.slick-next {
	width: 33px;
	height: 87px;
}
.slick-prev,
.slick-prev:hover,
.slick-prev:focus,
.slick-next,
.slick-next:hover,
.slick-next:focus {
	z-index: 1;
	background: url(../img/arrow02l.svg) center / 100% no-repeat;
}
.slick-next,
.slick-next:hover,
.slick-next:focus {
	background-image: url(../img/arrow02r.svg);
}
.slick-prev {
	left: 30px;
}
.slick-next {
	right: 30px;
}
.slick-prev:before,
.slick-next:before {
	content: normal;
}
.slick-dotted.slick-slider {
	margin-bottom: 120px;
}
.slick-dots {
	bottom: -60px;
}
.slick-dots li button:before {
	content: '●';
	font-size: 18px;
}
.slick-dots li {
	margin: 0 10px;
}
#kv img {
	width: 100%;
}
.emergency .title {
	flex: 0 1 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 200px;
	font-weight: bold;
	text-align: center;
	color: #FFFFFF;
	padding: 1em 1.5em;
	background: #996600;
}
.emergency .textCopy {
	margin-left: 0;
	padding: 1em 1.5em;
	border: 5px solid #996600;
	border-left-width: 0;
}
#top-read {
	text-align: center;
	margin-top: 120px;
	padding: 0 50px;
}
#top-read span {
	display: inline-block;
	position: relative;
	padding: 0 0.5em;
	background: #FFFFFF;
}
#top-read span::after {
	content: "";
	position: absolute;
	z-index: -1;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: calc(100% + 60px);
	height: 0;
	border-bottom: 1px solid;
}
[id^="top-"] {
	padding-top: 50px;
	padding-bottom: 80px;
}
[id^="top-"] h2,
[id^="top-"] h3,
#top-info,
#top-guest {
	line-height: 1.4;
}
[id^="top-"] h2,
[id^="top-"] h3 {
	font-weight: normal;
}
[id^="top-"] h2 {
	font-size: 4.3rem;
	text-align: center;
	margin-bottom: 0.8em;
}
[id^="top-"] h2 span {
	display: block;
	font-size: 2rem;
	font-weight: bold;
}
[id^="top-"] h3 {
	font-size: 3.2rem;
	margin-bottom: 0.8em;
}
#top-guest li {
	flex: 0 1 auto;
	width: calc(50% - 25px);
	height: 320px;
}
@media (max-width: 1040px) {
#top-guest li {
	height: 30vw;
}
}
#top-guest li:nth-child(2n+1) {
	margin-left: 0;
}
#top-guest li a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	font-size: 2.1rem;
	text-align: center;
	color: #FFFFFF;
	background: url(../img/top-guest-01.jpg) center / cover no-repeat;
}
#top-guest li:nth-child(2) a {
	background-image: url(../img/top-guest-02.jpg);
}
#top-guest li:nth-child(3) a {
	background-image: url(../img/top-guest-03.jpg);
}
#top-guest li:nth-child(4) a {
	background-image: url(../img/top-guest-04.jpg);
}
#top-guest li:nth-child(5) a {
	background-image: url(../img/top-guest-05.jpg);
}
#top-guest li a > span {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 60%;
	height: 124px;
	padding: 0.5em;
	background : rgba(0, 0, 0, 0.7);
}
#top-guest li a > span span {
	display: block;
	font-size: 1.6rem;
}
#top-info,
#top-access {
	background: #F1ECE7;
}
#top-info dl {
	display: flex;
	flex-wrap: wrap;
	padding: 1.5em 0;
	border: solid #000000;
	border-width: 1px 0;
}
#top-info dt:nth-of-type(n+2),
#top-info dd:nth-of-type(n+2) {
	margin-top: 1em;
}
#top-info dt {
	width: 9em;
}
#top-info dd {
	width: calc(100% - 9em);
}
#top-event .btn {
	margin-top: 2em !important;
}
#top-event .btn a {
	padding: 0.5em;
}
#top-access .gmap {
	padding-bottom: 425px;
	border: 1px solid #CCCCCC;
}
#top-access p:nth-of-type(2) {
	margin-top: 3em;
}
#top-access p:nth-of-type(3) {
	margin-top: 1em;
}
/* room
============================== */
#roomsec01 {
	text-align: center;
	margin-top: 70px;
}
#roomsec01 p {
	font-size: 3.2rem;
}
#roomsec01 ul {
	margin-top: 0 !important;
}
#roomsec01 ul li {
	flex: 0 1 auto;
	width: 30%;
	height: 308px;
	margin-left: 5%;
}
#roomsec01 ul li:nth-child(3n+1) {
	margin-left: 0;
}
#roomsec01 ul a {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	height: 100%;
	line-height: 1.4;
	font-size: 2.1rem;
	padding: 8% 0.5em 70%;
	background: #FFFFFF url(../img/room01.jpg) center bottom / 100% no-repeat;
}
#roomsec01 ul li:nth-child(2) a {
	background-image: url(../img/room02.jpg);
}
#roomsec01 ul li:nth-child(3) a {
	background-image: url(../img/room03.jpg);
}
#roomsec01 ul li:nth-child(4) a {
	background-image: url(../img/room04.jpg);
}
#roomsec01 ul li:nth-child(5) a {
	background-image: url(../img/room05.jpg);
}
#roomsec01 ul li:nth-child(6) a {
	background-image: url(../img/room06.jpg);
}
#roomsec01 ul li:nth-child(7) a {
	background-image: url(../img/room07.jpg);
}
#roomsec01 ul li:nth-child(8) a {
	background-image: url(../img/room08.jpg);
}
#roomsec01 ul li:nth-child(9) a {
	background-image: url(../img/room09.jpg);
}
#roomsec01 ul li:nth-child(10) a {
	background-image: url(../img/room10.jpg);
}
#roomsec01 ul li:nth-child(11) a {
	background-image: url(../img/room11.jpg);
}
#roomsec01 ul span {
	display: block;
	font-size: 1.6rem;
}
/* restaurant
============================== */
#restaurantsec01 {
	margin-top: 70px;
}
#restaurantsec01 > p {
	margin-bottom: 40px;
	text-align: center;
}
#restaurantsec01 div.col {
	align-items: flex-start;
}
#restaurantsec01 ul.col > li {
	flex: 0 1 auto;
	width: 47.17%;
	margin-left: 5.66%;
	margin-top: 0 !important;
}
#restaurantsec01 ul.col > li:nth-child(2n+1) {
	margin-left: 0;
}
#restaurantsec01 ul.col > li:nth-child(n+3) {
	margin-top: 30px !important;
}
#restaurantsec01 img {
	width: 100%;
}
#restaurantsec01 span.caption {
	text-align:right;
	font-size:14px;
	display:block;
}
#restaurantsec01 div.col > div {
	line-height: 2;
}
#restaurantsec01 .ttl,
#partysec01 .ttl {
	line-height: 1.4;
	font-size: 2.1rem;
	font-weight: normal;
	text-align: center;
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #262626;
}
#restaurantsec01 .ttl + P {
	line-height: 1.4;
}
#restaurantsec01 dl {
	display: flex;
	flex-wrap: wrap;
	font-size: 1.8rem;
}
#restaurantsec01 dt {
	width: calc(100% - 4em);
	text-indent: -1em;
	padding-left: 1em;
}
#restaurantsec01 dt::before {
	content: "・";
}
#restaurantsec01 dd {
	width: 4em;
	text-align: right;
}
#restaurantsec01 dl ~ p {
	font-size: 1.6rem;
	margin-top: 1em;
}
#restaurantsec02 {
	text-align: center;
	margin-top: 50px;
	padding: 50px 50px 24px;
	background: #FFF;
}
#restaurantsec02 li {
	flex: 0 1 auto;
	width: 29.7%;
	margin-left: 5.4%;
}
#restaurantsec02 li:nth-child(3n+1) {
	margin-left: 0;
}
#restaurantsec02 li span.caption {
	text-align:right;
	font-size:14px;
	display:block;
}
/* party
============================== */
[id^="partysec"],
[id^="accesssec"] {
	padding-top: 60px;
	padding-bottom: 60px;
}
[id^="partysec"] h2,
[id^="partysec"] h3,
[id^="accesssec"] h2,
[id^="accesssec"] h3,
[id^="eventsec"] h2 {
	line-height: 1.4;
	font-size: 3.2rem;
	font-weight: normal;
}
[id^="partysec"] h2,
[id^="accesssec"] h2,
[id^="eventsec"] h2 {
	text-align: center;
}
[id^="partysec"] h2 span::before,
[id^="accesssec"] h2 span::before {
	content: " / ";
}
#partysec01 .col,
#partysec02 .col {
	margin-top: 0 !important;
}
#partysec01 .ttl2 {
	font-size: 1.8rem;
	font-weight: bold;
}
#partysec01 dl + .ttl2,
#partysec01 dl + dl {
	margin-top: 0.5em;
}
#partysec01 > p {
	margin-top: 30px;
	text-align: center;
}
#partysec01 dl {
	display: flex;
	flex-wrap: wrap;
	font-size: 1.8rem;
}
#partysec01 dt {
	width: 5em;
	text-indent: -1em;
	padding-left: 1em;
}
#partysec01 dt.long {
	width: 8.5em;
}
#partysec01 dt::before {
	content: "・";
}
#partysec01 dd {
	width: calc(100% - 5em);
	text-indent: -0.5em;
	padding-left: 0.5em;
}
#partysec01 dt.long + dd {
	width: calc(100% - 8.5em);
}
#partysec01 dd::before {
	content: "/";
}
#partysec01 span.caption {
	text-align:right;
	font-size:14px;
	display:block;
}
#partysec02 {
	font-size: 1.8rem;
	background: #FFF;
}
#partysec02 h3 {
	text-align: center;
	margin-top: 2em;
	margin-bottom: 0.5em;
}
#partysec02 .col h3 {
	text-align: left;
	letter-spacing: -0.05em;
	margin-top: 0;
}
#partysec02 .col p {
	font-size: 2rem;
}
#partysec02 table {
	width: 100%;
	border-collapse: collapse;
}
#partysec02 th + th,
#partysec02 td + td {
	padding-left: 1em;
}
#partysec02 th {
	white-space: nowrap;
	border-bottom: 1px solid #262626;
}
#partysec02 td,
#partysec02 dt,
#partysec02 dd {
	padding-top: 0.8em;
}
#partysec02 td {
	text-align: center;
}
#partysec02 tr:nth-child(2) td,
#partysec02 dt:first-child,
#partysec02 dd:first-child {
	padding-top: 20px;
}
#partysec02 h3:nth-of-type(1) + .scroll td:nth-child(1) {
	white-space: nowrap;
}
#partysec02 h3:nth-of-type(1) + .scroll td:nth-child(2) {
	text-align: left;
}
#partysec02 h3 + .col {
	border-top: 1px solid #262626;
}
#partysec02 dl {
	display: flex;
	flex-wrap: wrap;
	margin-top: 0 !important;
}
#partysec02 dt {
	width: calc(100% - 5.5em);
}
#partysec02 dd {
	width: 5.5em;
	text-align: right;
}
#partysec02 .right {
	margin-top: 1em;
}
#partysec03,
#partysec04 {
	max-width: 1000px;
	margin-top: 60px;
	padding-top: 40px;
	background: #FFF;
}
#partysec03 h2,
#partysec04 h2 {
	margin-bottom: 1em;
}
#partysec04 {
	padding-left: 50px;
	padding-right: 50px;
}
#partysec04 p {
	font-size: 1.6rem;
}
/* access
============================== */
#accesssec01 h2 + p {
	font-weight: bold;
	text-align: center;
	margin-top: 40px;
}
#accesssec01 h3 {
	font-size: 1.8rem;
	text-align: center;
	color: #FFF;
	margin-top: 1em;
	padding: 0.5em 0;
	background: #262626;
}
#accesssec01 h3 + p {
	font-size: 1.8rem;
	margin-top: 1em;
	padding: 1em;
	background: #FFFFFF;
}
#accesssec01 .gmap {
	margin-top: 40px;
	padding-bottom: 300px;
}
#accesssec02 {
	background: #FFF;
}
#accesssec02 ul {
	margin-top: 0 !important;
}
#accesssec02 li {
	flex: 0 1 auto;
	width: 47%;
	margin-left: 6%;
}
#accesssec02 li:nth-child(2n+1) {
	margin-left: 0;
}
#accesssec02 li a {
	display: flex;
	justify-content: space-between;
}
#accesssec02 li a .img {
	width: 56.88%;
	display:none;
}
#accesssec02 li a div {
/*	margin-left: 20px;*/
	width: 100%;
}
#accesssec02 li a h3 {
	font-size: 2rem;
	margin-bottom: 0.5em;
}
#accesssec02 li a p {
	font-size: 1.4rem;
}
#accesssec03 li {
	margin-top:10px;
}
#accesssec03 li a {
	max-width: none;
}
/* event
============================== */
#eventsec01 {
	margin-top: 70px;
}
#eventsec01 h2 + * {
	margin-top: 50px;
}
/* privacy
============================== */
#privacysec01 {
	margin-top: 70px;
}

.box01 .btn a[href*='489ban'] {display:none;}