@charset "UTF-8";
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Old+Mincho&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cinzel:wght@400..900&display=swap");
*, ::before, ::after { box-sizing: border-box; border-style: solid; border-width: 0; min-width: 0; }

/* Document */
/* ============================================ */
/** 1. Correct the line height in all browsers. 2. Prevent adjustments of font size after orientation changes in iOS. 3. Remove gray overlay on links for iOS. */
html { line-height: 1.15; /* 1 */ -webkit-text-size-adjust: 100%; /* 2 */ -webkit-tap-highlight-color: transparent; /* 3*/ }

/* Sections */
/* ============================================ */
/** Remove the margin in all browsers. */
body { margin: 0; }

/** Render the `main` element consistently in IE. */
main { display: block; }

/* Vertical rhythm */
/* ============================================ */
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0; }

/* Headings */
/* ============================================ */
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ul, ol { margin: 0; padding: 0; list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt { font-weight: bold; }

dd { margin-left: 0; }

/* Grouping content */
/* ============================================ */
/** 1. Add the correct box sizing in Firefox. 2. Show the overflow in Edge and IE. */
hr { box-sizing: content-box; /* 1 */ height: 0; /* 1 */ overflow: visible; /* 2 */ border-top-width: 1px; margin: 0; clear: both; color: inherit; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
pre { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

address { font-style: inherit; }

/* Text-level semantics */
/* ============================================ */
/** Remove the gray background on active links in IE 10. */
a { background-color: transparent; text-decoration: none; color: inherit; }

/** 1. Remove the bottom border in Chrome 57- 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. */
abbr[title] { text-decoration: underline dotted; /* 2 */ }

/** Add the correct font weight in Chrome, Edge, and Safari. */
b, strong { font-weight: bolder; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
code, kbd, samp { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

/** Add the correct font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` elements from affecting the line height in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sub { bottom: -0.25em; }

sup { top: -0.5em; }

/* Replaced content */
/* ============================================ */
/** Prevent vertical alignment issues. */
svg, img, embed, object, iframe { vertical-align: bottom; }

/* Forms */
/* ============================================ */
/** Reset form fields to make them styleable. 1. Make form elements stylable across systems iOS especially. 2. Inherit text-transform from parent. */
button, input, optgroup, select, textarea { -webkit-appearance: none; /* 1 */ appearance: none; vertical-align: middle; color: inherit; font: inherit; background: transparent; padding: 0; margin: 0; border-radius: 0; text-align: inherit; text-transform: inherit; /* 2 */ }

/** Correct cursors for clickable elements. */
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer; }

button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default; }

/** Improve outlines for Firefox and unify style with input elements & buttons. */
:-moz-focusring { outline: auto; }

select:disabled { opacity: inherit; }

/** Remove padding */
option { padding: 0; }

/** Reset to invisible */
fieldset { margin: 0; padding: 0; min-width: 0; }

legend { padding: 0; }

/** Add the correct vertical alignment in Chrome, Firefox, and Opera. */
progress { vertical-align: baseline; }

/** Remove the default vertical scrollbar in IE 10+. */
textarea { overflow: auto; }

/** Correct the cursor style of increment and decrement buttons in Chrome. */
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }

/** Correct the outline style in Safari. */
[type="search"] { outline-offset: -2px; /* 1 */ }

/** Remove the inner padding in Chrome and Safari on macOS. */
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** 1. Correct the inability to style clickable types in iOS and Safari. 2. Fix font inheritance. */
::-webkit-file-upload-button { -webkit-appearance: button; /* 1 */ font: inherit; /* 2 */ }

/** Fix appearance for Firefox */
[type="number"] { -moz-appearance: textfield; }

/** Clickable labels */
label[for] { cursor: pointer; }

/* Interactive */
/* ============================================ */
/* Add the correct display in Edge, IE 10+, and Firefox. */
details { display: block; }

/* Add the correct display in all browsers. */
summary { display: list-item; }

/* Remove outline for editable content. */
[contenteditable]:focus { outline: auto; }

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table { border-color: inherit; /* 1 */ border-collapse: collapse; }

caption { text-align: left; }

td, th { vertical-align: top; padding: 0; }

th { text-align: left; font-weight: bold; }

/******************************************************

base

******************************************************/
html { font-size: 10px; }

body { background: #fff; color: #000; }

a { color: #000; text-decoration: none; transition: .2s linear; }
a[href*="tel:"] { pointer-events: none; }

.aw { display: inline-block; }

.note { font-size: 12px; line-height: 1.6; }

.sp { display: none !important; }

#allWrapper { overflow: hidden; }

#footerNavArea { font-size: 12px; color: #333; }
#footerNavArea a { color: #b49c39; text-decoration: underline; transition: none; }
#footerNavArea * { box-sizing: content-box; }

#footerArea * { box-sizing: content-box; }

@media screen and (max-width: 1121px) { html { font-size: 9px; } }
@media screen and (max-width: 768px) { html { font-size: 8px; }
  a[href*="tel:"] { pointer-events: initial; }
  .sp { display: block !important; }
  .pc { display: none !important; }
  #allWrapper { padding-bottom: 53px; } }
@media screen and (max-width: 480px) { html { font-size: 7px; } }
/******************************************************

header

******************************************************/
.header { font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; position: fixed; z-index: 10; width: 100%; top: 0; transition: background-color .2s linear; background-color: rgba(0, 0, 0, 0.4); }

.header-inner { display: flex; align-items: center; padding: 15px 30px; position: relative; }
.header-inner .siteid { font-feature-settings: "palt"; letter-spacing: 0.02em; font-size: 11px; margin-left: 20px; line-height: 1.2; color: #fff; }
.header-inner .sitename { order: -1; width: 310px; }
.header-inner .sitename a { display: block; }
.header-inner .sitename .img { width: 100%; height: auto; }
.header-inner .guide-nav { margin-left: auto; }
.header-inner .guide-nav ul { display: grid; grid-template-columns: repeat(4, auto); }
.header-inner .guide-nav li { display: flex; font-size: 14px; line-height: 1; margin-left: 25px; font-feature-settings: "palt"; letter-spacing: 0.02em; }
.header-inner .guide-nav li:first-of-type { margin-left: 0; }
.header-inner .guide-nav li a { display: flex; align-items: center; justify-content: center; padding: 0 0 0 16px; position: relative; color: #fff; }
.header-inner .guide-nav li a:hover { opacity: .6; }
.header-inner .guide-nav li.entry a, .header-inner .guide-nav li.reserve a { box-shadow: 0 0 6px #000; padding: 10px 30px; }
.header-inner .guide-nav li.entry a:hover, .header-inner .guide-nav li.reserve a:hover { opacity: 1; filter: brightness(110%); }
.header-inner .guide-nav li.entry a::before, .header-inner .guide-nav li.reserve a::before { display: none; }
.header-inner .guide-nav li.entry a { background: radial-gradient(circle, #fff, #AEADA9); color: #3E3A39; }
.header-inner .guide-nav li.reserve a { background: radial-gradient(circle, #e8e5db, #e0dccf, #aba07b); color: #3E3A39; }
.header-inner .guide-nav li.reserve a::before, .header-inner .guide-nav li.reserve a::after { content: ""; display: inline-block; width: 1.5em; }
.header-inner .guide-nav li.login { margin-left: 10px; }
.header-inner .guide-nav li.login a { background: radial-gradient(circle, #fff, #CEC6AF); color: #3E3A39; padding: 10px 20px; text-align: center; }
.header-inner .guide-nav li.login a:hover { opacity: 1; filter: brightness(110%); }
.header-inner .guide-nav li.login a::before { display: none; }

.sp-nav { font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; display: none; position: fixed; left: 0; bottom: 0; width: 100%; background-color: #bbb; z-index: 13; }
.sp-nav ul { display: grid; grid-template-columns: repeat(5, 1fr); height: 100%; }
.sp-nav ul li { font-size: 9px; line-height: 1; display: flex; }
.sp-nav ul li a { width: 100%; display: flex; flex-direction: column; text-align: center; justify-content: center; padding: 5px 0; }
.sp-nav ul li a { color: #fff; }
.sp-nav ul li .icon .img { width: 20px; height: auto; }
.sp-nav ul li .text { margin-top: 5px; width: 100%; }
.sp-nav ul li.tel { background-color: #33332D; }
.sp-nav ul li.entry a, .sp-nav ul li.reserve a { color: #3E3A39; }
.sp-nav ul li.entry { background: radial-gradient(circle, #fff, #AEADA9); color: #3E3A39; }
.sp-nav ul li.reserve { background: radial-gradient(circle, #e8e5db, #e0dccf, #aba07b); color: #3E3A39; }
.sp-nav ul li.reserve img { filter: brightness(0) saturate(100%); }
.sp-nav ul li.map, .sp-nav ul li.outline { background: #33332D; color: #fff; }

#sp-menu { display: none; position: absolute; top: 0; right: 0; width: 40px; height: 40px; z-index: 99999; padding: 5px; }
#sp-menu .nav-switch { position: relative; width: 100%; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: center; justify-content: center; -webkit-box-align: center; align-items: center; }
#sp-menu .nav-switch * { min-height: 0%; }
#sp-menu .nav-switch .icon, #sp-menu .nav-switch::before, #sp-menu .nav-switch::after { background-color: #fff; content: ""; display: block; width: 24px; height: 2px; transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1); position: absolute; top: 10px; left: calc(50% - 12px); }
#sp-menu .nav-switch::before { transform: translateY(6px); }
#sp-menu .nav-switch::after { transform: translateY(-6px); }
#sp-menu .nav-switch .text { font-family: "Cinzel", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; letter-spacing: .1em; padding-top: 25px; width: 100%; color: #fff; display: block; text-align: center; }

body.menu-opened #sp-menu .nav-switch .icon { transform: scaleX(0); }
body.menu-opened #sp-menu .nav-switch::before { transform: rotate(135deg) scaleX(1.2) translate(0, 0); }
body.menu-opened #sp-menu .nav-switch::after { transform: rotate(-135deg) scaleX(1.2) translate(0, 0); }

@media screen and (max-width: 1121px) { .header-inner .siteid { position: absolute; left: 30px; top: 8px; margin-left: 0; }
  .header-inner .siteid br { display: none; }
  .header-inner .sitename { margin-top: 5px; }
  .header-inner .guide-nav ul { grid-template-columns: repeat(3, auto); grid-template-rows: repeat(2, 1fr); grid-auto-flow: column; }
  .header-inner .guide-nav li { font-size: 14px; margin-left: 0; }
  .header-inner .guide-nav li.entry, .header-inner .guide-nav li.reserve { grid-row: span 2; } }
@media screen and (max-width: 768px) { .header { position: static; background-color: #060a23; padding-bottom: 0; }
  .header.add-bg { background-color: #060a23; }
  .header-inner { padding: 15px; }
  .header-inner .sitename { margin-top: 0; text-align: center; width: 240px; }
  .header-inner .siteid, .header-inner .guide-nav { display: none; }
  .sp-nav { display: block; }
  #sp-menu { display: block; } }
/******************************************************

global nav

******************************************************/
.global-nav { width: 100%; padding: 20px 0; }
.global-nav ul { display: grid; grid-template-columns: repeat(8, 1fr); max-width: 1200px; margin: 0 auto; }
.global-nav li { position: relative; }
.global-nav li .new, .global-nav li .update { position: absolute; top: -15px; right: 0; display: inline-block; font-family: "Cinzel", serif; font-size: 10px; line-height: 1; }
.global-nav li .new { color: #9E905B; }
.global-nav li .update { color: #fff; background-color: #d00000; padding: 2px 3px; }
.global-nav li a, .global-nav li .close { display: block; width: 100%; height: 100%; color: #fff; position: relative; }
.global-nav li a .en, .global-nav li .close .en { display: block; text-align: center; font-family: "Cinzel", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; letter-spacing: .1em; font-size: 16px; line-height: 1; }
.global-nav li a { transition: opacity .2s linear; }
.global-nav li a:hover { opacity: .6; }
.global-nav li a.current::after { display: block; content: ''; width: 100%; height: 2px; background-color: #9E905B; position: absolute; left: 50%; translate: -50% 0; bottom: -10px; }
.global-nav li .close { opacity: .4; }
.global-nav li.zeh .en, .global-nav li.premiumplan .en { font-size: 13px; }
.global-nav li.map, .global-nav li.outline { display: none; }

@media screen and (max-width: 1121px) { .global-nav li { font-size: 14px; } }
@media screen and (max-width: 768px) { .global-nav { position: fixed; right: 0; top: 50%; z-index: 99999; width: 100%; height: auto; translate: 100% -50%; transition: translate 500ms; will-change: translate; contain: paint; }
  .global-nav ul { width: 100%; height: auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; }
  .global-nav li { font-size: 14px; width: 100%; height: auto; /*&.top {
	grid-column: span 2;
}*/ }
  .global-nav li .new, .global-nav li .update { top: 0; }
  .global-nav li a, .global-nav li .close { font-family: "Cinzel", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; letter-spacing: .1em; height: auto; line-height: inherit; padding: 20px; }
  .global-nav li::before { display: none; }
  .global-nav li a.current { color: #9E905B; text-shadow: none; }
  .global-nav li a.current::after { bottom: 0; } }
body.menu-opened .global-nav { translate: 0 -50%; }

/******************************************************

container

******************************************************/
#container { font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; width: 100%; padding: 0; margin-top: 0; position: relative; }
#container .block { width: 100%; padding: 10rem 0 0 0; }
#container .block:first-of-type { padding-top: 30px; }
#container.nomv { padding-top: 120px; }

.breadcrumb { display: -webkit-box; display: flex; flex-wrap: wrap; align-content: center; width: 100%; z-index: 2; height: 30px; position: absolute; top: 120px; font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; }
.breadcrumb * { min-height: 0%; }
.breadcrumb.b .bread-list ol li { color: #171411; }
.breadcrumb.b .bread-list ol li a { color: #171411; }

.bread-list { display: block; width: 90%; max-width: 1360px; margin: 0 auto; }
.bread-list ol { display: flex; flex-wrap: wrap; }
.bread-list ol li { color: #fff; display: flex; align-items: center; font-size: 12px; }
.bread-list ol li:not(:last-child)::after { content: '\03e'; margin: 0 6px; }
.bread-list ol li a { color: #fff; }

.page-caption { width: 90%; max-width: 1000px; margin-inline: auto; margin: 0 auto; padding: 10rem 0; }
.page-caption .note { font-size: 12.5px; font-weight: normal; line-height: 1.6; position: relative; padding-left: 15px; }
.page-caption .note::before { content: "\203b"; font-size: 12px; position: absolute; top: 1px; left: 0; }
.page-caption .note1 { padding-left: 24px; }
.page-caption .note1::before { content: "\203b 1"; }
.page-caption .note2 { padding-left: 24px; }
.page-caption .note2::before { content: "\203b 2"; }
.page-caption .note3 { padding-left: 24px; }
.page-caption .note3::before { content: "\203b 3"; }

@media screen and (max-width: 768px) { #container { padding-bottom: 0 !important; }
  #container .block:first-of-type { padding-top: 0; }
  #container.nomv { padding-top: 0; }
  #container { padding-top: 0; }
  #container::before { content: ''; cursor: pointer; position: fixed; left: 0; bottom: 53px; z-index: 9999; width: 100%; height: calc(100% - 53px); visibility: hidden; opacity: 0; transition: 300ms; background: #000; }
  .breadcrumb { display: none; }
  body.menu-opened #container::before { visibility: visible; opacity: .8; } }
/******************************************************

footer

******************************************************/
.footer { font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; padding-bottom: 174px; }
.footer .bg03 { padding: 40px 0; }
.footer .guide-nav { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
.footer .guide-nav .g-txt { text-align: center; color: #fff; font-size: 1.4rem; line-height: 1.6; }
.footer .guide-nav ul { margin-top: 2rem; }
.footer .guide-nav li { width: 100%; display: flex; font-size: 2.8rem; font-feature-settings: "palt"; letter-spacing: 0.05em; line-height: 1.2; }
.footer .guide-nav li + li { margin-top: 1.2rem; }
.footer .guide-nav li.entry a { background: radial-gradient(circle, #fff, #AEADA9); color: #3E3A39; }
.footer .guide-nav li.reserve a { background: radial-gradient(circle, #f7f6f3, #e0dccf, #a3976f); color: #3E3A39; }
.footer .guide-nav li a { color: #fff; display: flex; flex-direction: column; justify-content: center; text-align: center; padding: 2rem 3rem; width: 100%; position: relative; }
.footer .guide-nav li a:hover { filter: brightness(110%); }
.footer .footer-nav { width: 98%; max-width: 1670px; margin-right: auto; margin-left: auto; padding: 80px 0 0 0; }
.footer .footer-nav ul { display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: stretch; align-items: stretch; }
.footer .footer-nav ul * { min-height: 0%; }
.footer .footer-nav li { width: 10%; line-height: 1; font-size: 13px; border-right: 1px solid #bbb; }
.footer .footer-nav li:first-child { border-left: solid 1px #bbb; }
.footer .footer-nav li a, .footer .footer-nav li .close { display: block; width: 100%; text-align: center; text-decoration: none; padding: 5px 0; position: relative; color: #fff; }
.footer .footer-nav li a .en, .footer .footer-nav li .close .en { font-family: "Cinzel", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; letter-spacing: .1em; }
.footer .footer-nav li a .ja, .footer .footer-nav li .close .ja { font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; }
.footer .footer-nav li a:hover { opacity: .6; }
.footer .footer-nav li a.current { color: #9E905B; }
.footer .footer-nav li a.current::after { content: ""; display: block; width: 80%; height: 2px; background: #9E905B; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
.footer .footer-nav li .close { opacity: .4; }
.footer .tel { width: 90%; font-size: 14px; font-weight: normal; line-height: 1; margin-top: 4rem; margin-inline: auto; }
.footer .tel a { display: block; text-align: center; gap: 15px; }
.footer .tel .title { display: block; font-size: 16px; letter-spacing: 0.05em; width: 100%; text-align: center; }
.footer .tel .number { display: inline-block; margin: 2rem 15px 0 auto; width: calc(481 / 1920 * 100%); }
.footer .tel .number .img { width: 100%; height: auto; }
.footer .tel .opening { display: inline-block; margin: 2rem auto 0 0; font-size: 14px; letter-spacing: 0.05em; text-align: left; line-height: 1.8; }
.footer .company { width: 90%; margin-top: 4rem; margin-inline: auto; display: flex; justify-content: center; gap: 50px; }
.footer .company li .in-charge { font-size: 12px; display: block; text-align: left; }
.footer .company li.daiwa .in-charge { display: block; text-align: center; margin-bottom: 2px; }
.footer .company li.keio .in-charge { margin-bottom: 10px; }
.footer .company li.sumitomo .in-charge { margin-left: 45px; margin-bottom: 10px; }

@media screen and (max-width: 768px) { .footer { padding-bottom: 20px; }
  .footer .bg03 { padding: 0; }
  .footer .guide-nav { padding: 40px 0; }
  .footer .guide-nav .g-txt { font-size: 12px; }
  .footer .guide-nav ul { grid-template-columns: 1fr; gap: 15px; }
  .footer .footer-nav { width: 100%; padding: 0; padding: 1px 0; background-color: #ccc; }
  .footer .footer-nav ul { width: 100%; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; }
  .footer .footer-nav li { width: 100%; font-size: 12px; padding: 0; border-right: 0; }
  .footer .footer-nav li a, .footer .footer-nav li .close { width: 100%; display: block; padding: 15px 0; text-align: center; background: #fff; color: #222; }
  .footer .footer-nav li .close { color: #000; opacity: .4; }
  .footer .footer-nav li a.current { background-color: #060a23; color: #fff; }
  .footer .footer-nav li a.current::after { display: none; }
  .footer .tel a .title { line-height: 1.6; }
  .footer .tel a .number { width: 100%; margin: 2rem auto 0 auto; }
  .footer .tel a .number img { width: 100%; max-width: 330px; }
  .footer .tel a .opening { margin: 2rem auto 0 auto; text-align: center; }
  .footer .company { flex-direction: column; gap: 10px; margin-top: 20px; }
  .footer .company li { margin-inline: auto; } }
/******************************************************

other

******************************************************/
#container .img-box { position: relative; }
#container .img-box .img { width: 100%; height: auto; max-width: 10000px; }
#container .img-box .cap { font-size: 12px; line-height: 1.2; position: absolute; right: 10px; bottom: 10px; text-align: right; }
#container .img-box .w { color: #fff; text-shadow: 0 0 3px #000,0 0 6px #000; }
#container .img-box .l { right: auto; left: 10px; text-align: left; }
#container .img-box .out { bottom: -10px; right: 0; }
#container .img-box .note { position: relative; margin-top: 5px; text-align: right; }

.bg01 { background: #3A3A34; }

.bg02 { background: #33332D; }

.bg03 { background: #282822; }

.bg04 { background: #52524D; }

.mv { width: 100%; display: block; }
.mv .mv-ttl { display: block; width: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: #fff; text-shadow: 0 0 10px #000, 0 0 10px #000,0 0 5px #000; text-align: center; }
.mv .mv-ttl .en { font-size: 16px; display: block; letter-spacing: .2em; line-height: 1; }
.mv .mv-ttl .ja { display: block; letter-spacing: .1em; margin-top: 20px; font-size: 24px; line-height: 1.6; }
@media screen and (max-width: 768px) { .mv .mv-ttl .en { font-size: 14px; }
  .mv .mv-ttl .ja { margin-top: 10px; font: 20px; } }

.inner { width: 98%; max-width: 1670px; margin-right: auto; margin-left: auto; }

.inner2 { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }

.en { font-family: "Cinzel", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; letter-spacing: .1em; letter-spacing: .1em; }

.midashi { font-size: 2.2rem; line-height: 1.6; }
.midashi + .lead { margin-top: 6rem; }
@media screen and (max-width: 768px) { .midashi { font-size: 20px; } }

.lead { font-size: 15px; line-height: 1.8; }
@media screen and (max-width: 768px) { .lead { font-size: 13px; } }

.page-links { width: 100%; background: #52524D; margin: 0; padding: 0; }
.page-links ul { width: 98%; max-width: 1670px; margin-right: auto; margin-left: auto; display: -webkit-box; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; -webkit-box-align: stretch; align-items: stretch; width: 100%; }
.page-links ul * { min-height: 0%; }
.page-links ul li { width: 50%; position: relative; }
.page-links ul li a { display: block; font-family: "Zen Old Mincho",'游明朝', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝','Noto Serif JP',  serif; font-weight: 400; font-style: normal; font-size: 14px; line-height: 1; color: #fff; padding: 30px 0; position: relative; transition: .3s; }
.page-links ul li a:hover { background: #30302E; color: #9E905B; }
.page-links ul li a::after { content: ""; display: block; width: 12px; height: 12px; position: absolute; top: 50%; border-top: solid 1px #fff; border-right: solid 1px #fff; }
.page-links ul li a .nav-txt { font-size: 12px; opacity: .3; display: inline-block; padding: 0 10px; }
.page-links ul li a .nav-txt2 { display: inline-block; }
.page-links ul li.prev::before { content: ""; position: absolute; top: 50%; right: 0; display: block; width: 1px; height: 20px; background: #fff; transform: translateY(-50%); }
.page-links ul li.prev a { padding-left: 5%; }
.page-links ul li.prev a::after { left: 2%; transform: translateY(-50%) rotate(-135deg); }
.page-links ul li.next { text-align: right; }
.page-links ul li.next a { padding-right: 5%; }
.page-links ul li.next a::after { right: 2%; transform: translateY(-50%) rotate(45deg); }
@media screen and (max-width: 768px) { .page-links ul li a .nav-txt { display: none; }
  .page-links ul li a .nav-txt2 { font-size: 12px; }
  .page-links ul li a::after { width: 10px; height: 10px; }
  .page-links ul li.prev a { padding: 15px 0 15px 10%; }
  .page-links ul li.next a { padding: 15px 10% 15px 0; } }

.bg-box { position: relative; z-index: 2; }
.bg-box::after { content: ""; display: block; width: 33%; height: 100%; position: absolute; top: 0; bottom: 0; left: 0; z-index: -1; }
.bg-box.l::after { left: auto; right: 0; }
.bg-box .box-inner { position: relative; z-index: 2; width: 100%; }

.bgarea { width: 100%; position: relative; }
.bgarea .img-box { width: 100%; z-index: 3; }
.bgarea .area-inner { position: relative; width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; margin-top: -15%; }
.bgarea .area-inner .area-content { display: inline-block; }
.bgarea .area-inner.r { text-align: right; }
.bgarea .txtarea { display: inline-block; text-align: left; color: #fff; position: relative; z-index: 3; padding-bottom: 10rem; }
.bgarea .txtarea .txt-head .img-box { display: none; }
.bgarea .bg-img { display: block; }
@media screen and (max-width: 1121px) { .bgarea .img-box .cap { display: inline-block; }
  .bgarea .area-inner { width: 65%; margin-top: -30%; margin-left: 5%; margin-right: auto; }
  .bgarea .area-inner.r { margin-right: 5%; margin-left: auto; }
  .bgarea .txtarea { display: block; width: 100%; /*.txt-head{
	font-size: 20px;
	.en{
		font-size: 14px;
	}
}
.lead{
	font-size: 15px;
}*/ } }
@media screen and (max-width: 768px) { .bgarea .bg-img { display: none; }
  .bgarea .area-inner { width: 100%; margin-top: 0; margin-left: 0; margin-right: 0; }
  .bgarea .area-inner.r { margin-right: 0; margin-left: 0; text-align: right; }
  .bgarea .area-inner.r .txtarea { text-align: right; }
  .bgarea .area-inner.r .txtarea .txt-head .txt { margin-left: auto; margin-right: 5%; text-align: left; }
  .bgarea .area-inner.r .txtarea .txt-head .img { left: 0; right: auto; }
  .bgarea .area-inner.r .txtarea .lead { margin-right: 5%; margin-left: auto; text-align: left; }
  .bgarea .area-inner.r .txtarea .btn-area { margin-right: 5%; margin-left: auto; }
  .bgarea .area-inner .area-content { display: block; width: 100%; }
  .bgarea .txtarea .txt-head { position: relative; }
  .bgarea .txtarea .txt-head .txt { display: inline-block; padding: 5rem 0; margin-left: 5%; }
  .bgarea .txtarea .txt-head .img-box { display: block; overflow: hidden; height: 350px; }
  .bgarea .txtarea .txt-head .img-box .img { display: block; height: 350px !important; width: auto !important; max-width: 10000px !important; position: absolute; z-index: 1; top: 0; right: 0; }
  .bgarea .txtarea .txt-head .img-box .cap { z-index: 9; }
  .bgarea .txtarea .lead { display: inline-block; margin-left: 5%; margin-right: auto; }
  .bgarea .txtarea .btn-area { margin-left: 5%; } }
@media screen and (max-width: 480px) { .bgarea .txtarea .txt-head .img-box { height: 280px !important; }
  .bgarea .txtarea .txt-head .img-box .img { height: 280px !important; } }

.txt-head { font-size: 2.2rem; line-height: 1.8; letter-spacing: .05em; }
.txt-head .en { display: inline-block; }
.txt-head .en.line { position: relative; color: #9E905B; }
.txt-head .en.line::after { content: ""; display: block; width: 100000px; height: 1px; background: #9E905B; position: absolute; right: 0; left: auto; bottom: 0; z-index: 2; }
.txt-head .en.line + .ja { padding-top: 6rem; color: #fff; }
.txt-head + .lead { margin-top: 6rem; font-size: 1.4rem; line-height: 2; }
@media screen and (max-width: 1121px) { .txt-head { font-size: 20px; }
  .txt-head .en { font-size: 14px; }
  .txt-head + .lead { font-size: 15px; } }

.r .txt-head .en.line::after { left: 0; right: auto; }

.conv { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; }
.conv .conv-txt { text-align: center; color: #fff; font-size: 14px; line-height: 1.6; }
.conv ul { margin-top: 2rem; }
.conv li { width: 100%; display: flex; font-size: 2.8rem; font-feature-settings: "palt"; letter-spacing: 0.05em; line-height: 1.2; }
.conv li + li { margin-top: 1.2rem; }
.conv li.entry a { background: radial-gradient(circle, #fff, #AEADA9); color: #3E3A39; }
.conv li.reserve a { background: radial-gradient(circle, #f7f6f3, #e0dccf, #a3976f); color: #3E3A39; }
.conv li a { color: #fff; display: flex; flex-direction: column; justify-content: center; text-align: center; padding: 2rem 3rem; width: 100%; position: relative; box-shadow: 0 0 6px #000; }
.conv li a:hover { filter: brightness(110%); }
