@charset "UTF-8";
/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: auto;
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  /* iOS 8+ */ }

body {
  overflow-x: hidden; }

*,
::before,
::after {
  padding: 0;
  /* Reset `padding` and `margin` of all elements */
  margin: 0;
  background-repeat: no-repeat;
  /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit; }

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit; }

*:not(.slick-list):not(.slick-slider):not(.slick-track):not(.slick-slide) {
  max-width: 100%; }

/* # =================================================================
   # General elements
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0; }

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */
  height: 1px;
  margin: 0;
  background-color: #000;
  border: none; }

ul, ol {
  list-style: none; }

li {
  display: block; }

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block; }

summary {
  display: list-item;
  /* Add the correct display in all browsers */ }

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */ }

[hidden],
template {
  display: none;
  /* Add the correct display in IE */ }

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */ }

a {
  background-color: transparent;
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */ }

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */ }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */ }

b,
strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */ }

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */ }

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000; }

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0; }

/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
  cursor: pointer; }

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default; }

[type="number"] {
  width: auto;
  /* Firefox 36+ */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Safari 8+ */ }

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  /* Safari 8 */ }

textarea {
  overflow: auto;
  /* Internet Explorer 11+ */
  resize: vertical;
  /* Specify textarea resizability */ }

button,
input,
optgroup,
select,
textarea {
  font: inherit;
  /* Specify font inheritance of form elements */ }

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule. */ }

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */ }

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: 0;
  padding: 0; }

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText; }

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS */ }

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */ }

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
  color: inherit; }

br {
  margin: 0;
  border: 0;
  padding: 0;
  font-size: 0;
  line-height: 0; }

/* Style select like a standard input */
select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */ }

select::-ms-value {
  color: currentColor;
  /* Internet Explorer 11+ */ }

legend {
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */ }

table {
  border-collapse: collapse; }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit;
  /* Change font properties to `inherit` in Chrome and Safari */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */ }

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
  -webkit-backface-visibility: hidden; }

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline; }

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */ }

audio,
canvas,
progress,
video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */ }

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~="screen"] {
    display: inherit; }

  [hidden~="screen"]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important; } }
/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress; }

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer; }

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default; }

:link {
  color: #000; }

:visited {
  color: #000; }

/* # =================================================================
   # Selection
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

::selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

.android * {
  font-family: "Sawarabi Mincho", sans-serif; }

html {
  position: relative;
  font-size: 62.5%;
  background-color: #000;
  overflow-x: hidden;
  overflow-y: auto; }
  html.hidden {
    overflow: hidden !important; }

body {
  font-style: normal;
  letter-spacing: 0; }

h1, h2, h3, h4, h5, h6, p, a {
  line-height: 2; }

img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover; }

a {
  text-decoration: none; }

::placeholder {
  font-size: 1em; }

input, textarea, button {
  display: block;
  outline: none; }

.slick-slide div {
  font-size: 0; }

.slick-arrow.slick-prev::before {
  left: -6rem; }

.slick-arrow.slick-next::before {
  right: 6rem; }

#page {
  opacity: 0;
  transition: all 0.8s cubic-bezier(0.215, 0.61, 0.355, 1); }
  #page.start {
    opacity: 1; }

.hide {
  opacity: 0;
  pointer-events: none; }

.pc {
  display: flex !important;
  pointer-events: auto !important; }
  @media all and (max-width: 980px) {
    .pc {
      display: flex !important;
      pointer-events: auto !important; } }
  @media all and (max-width: 750px) {
    .pc {
      display: none !important;
      pointer-events: none !important; } }
  @media all and (max-width: 480px) {
    .pc {
      display: none !important;
      pointer-events: none !important; } }

.sp {
  display: none !important;
  pointer-events: none !important; }
  @media all and (max-width: 980px) {
    .sp {
      display: none !important;
      pointer-events: none !important; } }
  @media all and (max-width: 750px) {
    .sp {
      display: flex !important;
      pointer-events: auto !important; } }
  @media all and (max-width: 480px) {
    .sp {
      display: flex !important;
      pointer-events: auto !important; } }

.slick-dots {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center; }

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 1rem;
  height: 1rem;
  padding: 0;
  cursor: pointer; }

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: inherit;
  height: inherit;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent; }

.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none; }

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1; }

.slick-dots li button:before {
  font-size: inherit;
  line-height: inherit;
  width: inherit;
  height: inherit;
  content: '●';
  text-align: center;
  opacity: .25;
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.slick-dots li.slick-active button:before {
  opacity: .75;
  color: black; }

.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0; }

.slick-list:focus {
  outline: none; }

.slick-list.dragging {
  cursor: pointer;
  cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-arrow {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 4rem;
  height: 4rem;
  margin: auto;
  z-index: 500;
  background-size: cover; }

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }

.slick-track:before,
.slick-track:after {
  display: table;
  content: ''; }

.slick-track:after {
  clear: both; }

.slick-loading .slick-track {
  visibility: hidden; }

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 0.1rem; }

[dir='rtl'] .slick-slide {
  float: right; }

.slick-slide img {
  display: block; }

.slick-slide.slick-loading img {
  display: none; }

.slick-slide.dragging img {
  pointer-events: none; }

.slick-initialized .slick-slide {
  display: block; }

.slick-loading .slick-slide {
  visibility: hidden; }

.slick-vertical .slick-slide {
  display: block;
  height: auto; }

.slick-arrow.slick-hidden {
  display: none; }

.slick-slider {
  position: relative; }

body.compensate-for-scrollbar {
  overflow: hidden; }

.fancybox-active {
  height: auto; }

.fancybox-is-hidden {
  left: -9999px;
  margin: 0;
  position: absolute !important;
  top: -9999px;
  visibility: hidden; }

.fancybox-container {
  -webkit-backface-visibility: hidden;
  height: 100%;
  left: 0;
  outline: none;
  position: fixed;
  -webkit-tap-highlight-color: transparent;
  top: 0;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  transform: translateZ(0);
  width: 100%;
  z-index: 99992; }

.fancybox-container * {
  box-sizing: border-box; }

.fancybox-outer,
.fancybox-inner,
.fancybox-bg,
.fancybox-stage {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0; }

.fancybox-outer {
  -webkit-overflow-scrolling: touch;
  overflow-y: auto; }

.fancybox-bg {
  background: #1e1e1e;
  opacity: 0;
  transition-duration: inherit;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.47, 0, 0.74, 0.71); }

.fancybox-is-open .fancybox-bg {
  opacity: .9;
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1); }

.fancybox-infobar,
.fancybox-toolbar,
.fancybox-caption,
.fancybox-navigation .fancybox-button {
  direction: ltr;
  opacity: 0;
  position: absolute;
  transition: opacity .25s ease, visibility 0s ease .25s;
  visibility: hidden;
  z-index: 99997; }

.fancybox-show-infobar .fancybox-infobar,
.fancybox-show-toolbar .fancybox-toolbar,
.fancybox-show-caption .fancybox-caption,
.fancybox-show-nav .fancybox-navigation .fancybox-button {
  opacity: 1;
  transition: opacity .25s ease 0s, visibility 0s ease 0s;
  visibility: visible; }

.fancybox-infobar {
  color: #ccc;
  font-size: 13px;
  -webkit-font-smoothing: subpixel-antialiased;
  height: 44px;
  left: 0;
  line-height: 44px;
  min-width: 44px;
  mix-blend-mode: difference;
  padding: 0 10px;
  pointer-events: none;
  top: 0;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

.fancybox-toolbar {
  right: 0;
  top: 0; }

.fancybox-stage {
  direction: ltr;
  overflow: visible;
  transform: translateZ(0);
  z-index: 99994; }

.fancybox-is-open .fancybox-stage {
  overflow: hidden; }

.fancybox-slide {
  -webkit-backface-visibility: hidden;
  /* Using without prefix would break IE11 */
  display: none;
  height: 100%;
  left: 0;
  outline: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 44px;
  position: absolute;
  text-align: center;
  top: 0;
  transition-property: transform, opacity;
  white-space: normal;
  width: 100%;
  z-index: 99994; }

.fancybox-slide::before {
  content: '';
  display: inline-block;
  font-size: 0;
  height: 100%;
  vertical-align: middle;
  width: 0; }

.fancybox-is-sliding .fancybox-slide,
.fancybox-slide--previous,
.fancybox-slide--current,
.fancybox-slide--next {
  display: block; }

.fancybox-slide--image {
  overflow: hidden;
  padding: 44px 0; }

.fancybox-slide--image::before {
  display: none; }

.fancybox-slide--html {
  padding: 6px; }

.fancybox-content {
  background: #fff;
  display: inline-block;
  margin: 0;
  max-width: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 44px;
  position: relative;
  text-align: left;
  vertical-align: middle; }

.fancybox-slide--image .fancybox-content {
  animation-timing-function: cubic-bezier(0.5, 0, 0.14, 1);
  -webkit-backface-visibility: hidden;
  background: transparent;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  left: 0;
  max-width: none;
  overflow: visible;
  padding: 0;
  position: absolute;
  top: 0;
  -ms-transform-origin: top left;
  transform-origin: top left;
  transition-property: transform, opacity;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  z-index: 99995; }

.fancybox-can-zoomOut .fancybox-content {
  cursor: zoom-out; }

.fancybox-can-zoomIn .fancybox-content {
  cursor: zoom-in; }

.fancybox-can-swipe .fancybox-content,
.fancybox-can-pan .fancybox-content {
  cursor: -webkit-grab;
  cursor: grab; }

.fancybox-is-grabbing .fancybox-content {
  cursor: -webkit-grabbing;
  cursor: grabbing; }

.fancybox-container [data-selectable='true'] {
  cursor: text; }

.fancybox-image,
.fancybox-spaceball {
  background: transparent;
  border: 0;
  height: 100%;
  left: 0;
  margin: 0;
  max-height: none;
  max-width: none;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width: 100%; }

.fancybox-spaceball {
  z-index: 1; }

.fancybox-slide--video .fancybox-content,
.fancybox-slide--map .fancybox-content,
.fancybox-slide--pdf .fancybox-content,
.fancybox-slide--iframe .fancybox-content {
  height: 100%;
  overflow: visible;
  padding: 0;
  width: 100%; }

.fancybox-slide--video .fancybox-content {
  background: #000; }

.fancybox-slide--map .fancybox-content {
  background: #e5e3df; }

.fancybox-slide--iframe .fancybox-content {
  background: #fff; }

.fancybox-video,
.fancybox-iframe {
  background: transparent;
  border: 0;
  display: block;
  height: 100%;
  margin: 0;
  overflow: hidden;
  padding: 0;
  width: 100%; }

/* Fix iOS */
.fancybox-iframe {
  left: 0;
  position: absolute;
  top: 0; }

.fancybox-error {
  background: #fff;
  cursor: default;
  max-width: 400px;
  padding: 40px;
  width: 100%; }

.fancybox-error p {
  color: #444;
  font-size: 16px;
  line-height: 20px;
  margin: 0;
  padding: 0; }

/* Buttons */
.fancybox-button {
  background: rgba(30, 30, 30, 0.6);
  border: 0;
  border-radius: 0;
  box-shadow: none;
  cursor: pointer;
  display: inline-block;
  height: 44px;
  margin: 0;
  padding: 10px;
  position: relative;
  transition: color .2s;
  vertical-align: top;
  visibility: inherit;
  width: 44px; }

.fancybox-button,
.fancybox-button:visited,
.fancybox-button:link {
  color: #ccc; }

.fancybox-button:hover {
  color: #fff; }

.fancybox-button:focus {
  outline: none; }

.fancybox-button.fancybox-focus {
  outline: 1px dotted; }

.fancybox-button[disabled],
.fancybox-button[disabled]:hover {
  color: #888;
  cursor: default;
  outline: none; }

/* Fix IE11 */
.fancybox-button div {
  height: 100%; }

.fancybox-button svg {
  display: block;
  height: 100%;
  overflow: visible;
  position: relative;
  width: 100%; }

.fancybox-button svg path {
  fill: currentColor;
  stroke-width: 0; }

.fancybox-button--play svg:nth-child(2),
.fancybox-button--fsenter svg:nth-child(2) {
  display: none; }

.fancybox-button--pause svg:nth-child(1),
.fancybox-button--fsexit svg:nth-child(1) {
  display: none; }

.fancybox-progress {
  background: #ff5268;
  height: 2px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  -ms-transform: scaleX(0);
  transform: scaleX(0);
  -ms-transform-origin: 0;
  transform-origin: 0;
  transition-property: transform;
  transition-timing-function: linear;
  z-index: 99998; }

/* Close button on the top right corner of html content */
.fancybox-close-small {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: #ccc;
  cursor: pointer;
  opacity: .8;
  padding: 8px;
  position: absolute;
  right: -12px;
  top: -44px;
  z-index: 401; }

.fancybox-close-small:hover {
  color: #fff;
  opacity: 1; }

.fancybox-slide--html .fancybox-close-small {
  color: currentColor;
  padding: 10px;
  right: 0;
  top: 0; }

.fancybox-slide--image.fancybox-is-scaling .fancybox-content {
  overflow: hidden; }

.fancybox-is-scaling .fancybox-close-small,
.fancybox-is-zoomable.fancybox-can-pan .fancybox-close-small {
  display: none; }

/* Navigation arrows */
.fancybox-navigation .fancybox-button {
  background-clip: content-box;
  height: 100px;
  opacity: 0;
  position: absolute;
  top: calc(50% - 50px);
  width: 70px; }

.fancybox-navigation .fancybox-button div {
  padding: 7px; }

.fancybox-navigation .fancybox-button--arrow_left {
  left: 0;
  left: env(safe-area-inset-left);
  padding: 31px 26px 31px 6px; }

.fancybox-navigation .fancybox-button--arrow_right {
  padding: 31px 6px 31px 26px;
  right: 0;
  right: env(safe-area-inset-right); }

/* Caption */
.fancybox-caption {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.15) 65%, rgba(0, 0, 0, 0.075) 75.5%, rgba(0, 0, 0, 0.037) 82.85%, rgba(0, 0, 0, 0.019) 88%, rgba(0, 0, 0, 0) 100%);
  bottom: 0;
  color: #eee;
  font-size: 14px;
  font-weight: 400;
  left: 0;
  line-height: 1.5;
  padding: 75px 44px 25px 44px;
  pointer-events: none;
  right: 0;
  text-align: center;
  z-index: 99996; }

.fancybox-caption--separate {
  margin-top: -50px; }

.fancybox-caption__body {
  max-height: 50vh;
  overflow: auto;
  pointer-events: all; }

.fancybox-caption a,
.fancybox-caption a:link,
.fancybox-caption a:visited {
  color: #ccc;
  text-decoration: none; }

.fancybox-caption a:hover {
  color: #fff;
  text-decoration: underline; }

/* Loading indicator */
.fancybox-loading {
  animation: fancybox-rotate 1s linear infinite;
  background: transparent;
  border: 4px solid #888;
  border-bottom-color: #fff;
  border-radius: 50%;
  height: 50px;
  left: 50%;
  margin: -25px 0 0 -25px;
  opacity: .7;
  padding: 0;
  position: absolute;
  top: 50%;
  width: 50px;
  z-index: 99999; }

@keyframes fancybox-rotate {
  100% {
    transform: rotate(360deg); } }
/* Transition effects */
.fancybox-animated {
  transition-timing-function: cubic-bezier(0, 0, 0.25, 1); }

/* transitionEffect: slide */
.fancybox-fx-slide.fancybox-slide--previous {
  opacity: 0;
  transform: translate3d(-100%, 0, 0); }

.fancybox-fx-slide.fancybox-slide--next {
  opacity: 0;
  transform: translate3d(100%, 0, 0); }

.fancybox-fx-slide.fancybox-slide--current {
  opacity: 1;
  transform: translate3d(0, 0, 0); }

/* transitionEffect: fade */
.fancybox-fx-fade.fancybox-slide--previous,
.fancybox-fx-fade.fancybox-slide--next {
  opacity: 0;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1); }

.fancybox-fx-fade.fancybox-slide--current {
  opacity: 1; }

/* transitionEffect: zoom-in-out */
.fancybox-fx-zoom-in-out.fancybox-slide--previous {
  opacity: 0;
  transform: scale3d(1.5, 1.5, 1.5); }

.fancybox-fx-zoom-in-out.fancybox-slide--next {
  opacity: 0;
  transform: scale3d(0.5, 0.5, 0.5); }

.fancybox-fx-zoom-in-out.fancybox-slide--current {
  opacity: 1;
  transform: scale3d(1, 1, 1); }

/* transitionEffect: rotate */
.fancybox-fx-rotate.fancybox-slide--previous {
  opacity: 0;
  -ms-transform: rotate(-360deg);
  transform: rotate(-360deg); }

.fancybox-fx-rotate.fancybox-slide--next {
  opacity: 0;
  -ms-transform: rotate(360deg);
  transform: rotate(360deg); }

.fancybox-fx-rotate.fancybox-slide--current {
  opacity: 1;
  -ms-transform: rotate(0deg);
  transform: rotate(0deg); }

/* transitionEffect: circular */
.fancybox-fx-circular.fancybox-slide--previous {
  opacity: 0;
  transform: scale3d(0, 0, 0) translate3d(-100%, 0, 0); }

.fancybox-fx-circular.fancybox-slide--next {
  opacity: 0;
  transform: scale3d(0, 0, 0) translate3d(100%, 0, 0); }

.fancybox-fx-circular.fancybox-slide--current {
  opacity: 1;
  transform: scale3d(1, 1, 1) translate3d(0, 0, 0); }

/* transitionEffect: tube */
.fancybox-fx-tube.fancybox-slide--previous {
  transform: translate3d(-100%, 0, 0) scale(0.1) skew(-10deg); }

.fancybox-fx-tube.fancybox-slide--next {
  transform: translate3d(100%, 0, 0) scale(0.1) skew(10deg); }

.fancybox-fx-tube.fancybox-slide--current {
  transform: translate3d(0, 0, 0) scale(1); }

/* Styling for Small-Screen Devices */
@media all and (max-height: 576px) {
  .fancybox-slide {
    padding-left: 6px;
    padding-right: 6px; }

  .fancybox-slide--image {
    padding: 6px 0; }

  .fancybox-close-small {
    right: -6px; }

  .fancybox-slide--image .fancybox-close-small {
    background: #4e4e4e;
    color: #f2f4f6;
    height: 36px;
    opacity: 1;
    padding: 6px;
    right: 0;
    top: 0;
    width: 36px; }

  .fancybox-caption {
    padding-left: 12px;
    padding-right: 12px; } }
/* Share */
.fancybox-share {
  background: #f4f4f4;
  border-radius: 3px;
  max-width: 90%;
  padding: 30px;
  text-align: center; }

.fancybox-share h1 {
  color: #222;
  font-size: 35px;
  font-weight: 700;
  margin: 0 0 20px 0; }

.fancybox-share p {
  margin: 0;
  padding: 0; }

.fancybox-share__button {
  border: 0;
  border-radius: 3px;
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  line-height: 40px;
  margin: 0 5px 10px 5px;
  min-width: 130px;
  padding: 0 15px;
  text-decoration: none;
  transition: all .2s;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  white-space: nowrap; }

.fancybox-share__button:visited,
.fancybox-share__button:link {
  color: #fff; }

.fancybox-share__button:hover {
  text-decoration: none; }

.fancybox-share__button--fb {
  background: #3b5998; }

.fancybox-share__button--fb:hover {
  background: #344e86; }

.fancybox-share__button--pt {
  background: #bd081d; }

.fancybox-share__button--pt:hover {
  background: #aa0719; }

.fancybox-share__button--tw {
  background: #1da1f2; }

.fancybox-share__button--tw:hover {
  background: #0d95e8; }

.fancybox-share__button svg {
  height: 25px;
  margin-right: 7px;
  position: relative;
  top: -1px;
  vertical-align: middle;
  width: 25px; }

.fancybox-share__button svg path {
  fill: #fff; }

.fancybox-share__input {
  background: transparent;
  border: 0;
  border-bottom: 1px solid #d7d7d7;
  border-radius: 0;
  color: #5d5b5b;
  font-size: 14px;
  margin: 10px 0 0 0;
  outline: none;
  padding: 10px 15px;
  width: 100%; }

/* Thumbs */
.fancybox-thumbs {
  background: #ddd;
  bottom: 0;
  display: none;
  margin: 0;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
  padding: 2px 2px 4px 2px;
  position: absolute;
  right: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  top: 0;
  width: 212px;
  z-index: 99995; }

.fancybox-thumbs-x {
  overflow-x: auto;
  overflow-y: hidden; }

.fancybox-show-thumbs .fancybox-thumbs {
  display: block; }

.fancybox-show-thumbs .fancybox-inner {
  right: 212px; }

.fancybox-thumbs__list {
  font-size: 0;
  height: 100%;
  list-style: none;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 0;
  position: absolute;
  position: relative;
  white-space: nowrap;
  width: 100%; }

.fancybox-thumbs-x .fancybox-thumbs__list {
  overflow: hidden; }

.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar {
  width: 7px; }

.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar-track {
  background: #fff;
  border-radius: 10px;
  box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3); }

.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar-thumb {
  background: #2a2a2a;
  border-radius: 10px; }

.fancybox-thumbs__list a {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background-color: rgba(0, 0, 0, 0.1);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  cursor: pointer;
  float: left;
  height: 75px;
  margin: 2px;
  max-height: calc(100% - 8px);
  max-width: calc(50% - 4px);
  outline: none;
  overflow: hidden;
  padding: 0;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  width: 100px; }

.fancybox-thumbs__list a::before {
  border: 6px solid #ff5268;
  bottom: 0;
  content: '';
  left: 0;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 99991; }

.fancybox-thumbs__list a:focus::before {
  opacity: .5; }

.fancybox-thumbs__list a.fancybox-thumbs-active::before {
  opacity: 1; }

/* Styling for Small-Screen Devices */
@media all and (max-width: 576px) {
  .fancybox-thumbs {
    width: 110px; }

  .fancybox-show-thumbs .fancybox-inner {
    right: 110px; }

  .fancybox-thumbs__list a {
    max-width: calc(100% - 10px); } }
.header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  font-family: "Yu Mincho", "YuMincho", serif;
  z-index: 990; }

.header-array {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  height: 6rem;
  background-color: #fff;
  z-index: 991; }

.header-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 28rem;
  width: 25%;
  padding-left: 1.8rem; }
  .header-logo a {
    display: block;
    font-size: 0; }

.header-nav {
  display: flex;
  height: 6rem; }

.header-nav-block {
  display: flex; }

.header-nav-href {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 100%;
  padding: 0 0.90625vw;
  letter-spacing: 0.2rem;
  font-size: 0.89375vw;
  font-weight: 500;
  font-family: "Yu Mincho", "YuMincho", serif;
  transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .header-nav-href:after {
    content: '';
    display: block;
    position: absolute;
    right: 0;
    bottom: 20%;
    left: 0;
    width: 50%;
    height: 0.2rem;
    margin: auto;
    background-color: #A38D50;
    transform: scale(0, 1);
    transform-origin: center;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .header-nav-href:hover, .header-nav-href.current {
    color: #A38D50; }
    .header-nav-href:hover::after, .header-nav-href.current::after {
      transform: scale(1, 1); }

.header-nav-href-fb {
  display: none; }
  .header-nav-href-fb img {
    width: 2.4rem;
    height: 2.4rem;
    object-fit: cover; }

.header-ext {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-left: 1.4rem;
  border-left: 0.2rem solid #A38D50; }
  .header-ext:after {
    content: '';
    display: block;
    position: absolute;
    top: -0.1rem;
    right: -0.1rem;
    bottom: -0.1rem;
    left: -0.1rem;
    width: auto;
    height: auto;
    background-color: #A38D50;
    transform: scale(1, 1);
    transform-origin: right;
    z-index: 1;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .header-ext:hover:after {
    transform: scale(0, 1); }
  .header-ext .header-nav-href {
    width: 14rem;
    color: #fff;
    z-index: 2; }
    .header-ext .header-nav-href:after {
      display: none; }
    .header-ext .header-nav-href:hover {
      color: #A38D50; }
  .header-ext .header-nav-href-pc {
    display: flex; }
  .header-ext .header-nav-href-sp {
    display: none; }

.header-help {
  display: none; }

.selectable-reserve {
  position: relative;
  width: 100%;
  height: 0;
  margin: 0 auto;
  background-color: #000;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  overflow: hidden; }
  .selectable-reserve > form {
    padding: 0 2.34375%; }

.selectable-reserve.expand {
  height: 5rem; }

.selectable-reserve-nav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 5rem;
  background-color: #000; }
  .selectable-reserve-nav li {
    display: flex;
    align-items: center;
    font-size: 1.015625vw;
    color: #fff; }
  .selectable-reserve-nav p {
    margin-right: 0.625vw;
    line-height: 1; }

.selectable-reserve-nav-item {
  margin-right: 1.5625vw; }

.selectable-reserve-nav-selectwrap {
  display: flex;
  height: 2.4rem;
  margin-right: 0.625vw;
  border-radius: 0.2rem;
  color: #000;
  font-family: "Hiragino Sans", ヒラギノ角ゴシック, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", sans-serif;
  overflow: hidden; }
  .selectable-reserve-nav-selectwrap select {
    border-radius: 0;
    padding: 0 0.6em;
    background-color: #fff;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .selectable-reserve-nav-selectwrap select:focus {
      background-color: rgba(163, 141, 80, 0.6);
      color: #fff; }
  .selectable-reserve-nav-selectwrap img {
    height: 100%; }
  .selectable-reserve-nav-selectwrap label {
    position: relative;
    width: 2rem;
    border-radius: 0;
    background-color: #A38D50; }
    .selectable-reserve-nav-selectwrap label::before {
      content: '';
      display: block;
      position: absolute;
      top: 0.6rem;
      right: 0;
      left: 0;
      width: 0.7rem;
      height: 0.7rem;
      margin: auto;
      border-top: 0.1rem solid #fff;
      border-left: 0.1rem solid #fff;
      transform: rotateZ(45deg); }
    .selectable-reserve-nav-selectwrap label::after {
      content: '';
      display: block;
      position: absolute;
      right: 0;
      bottom: 0.6rem;
      left: 0;
      width: 0.7rem;
      height: 0.7rem;
      margin: auto;
      border-right: 0.1rem solid #fff;
      border-bottom: 0.1rem solid #fff;
      transform: rotateZ(45deg); }

.selectable-reserve-nav-item-lang {
  position: relative;
  border-bottom: 0.1rem solid #A38D50;
  border-radius: 0;
  padding-bottom: 0.28rem; }
  .selectable-reserve-nav-item-lang::after {
    content: '';
    display: block;
    position: absolute;
    top: 20%;
    right: 0;
    width: 0.625vw;
    height: 0.625vw;
    margin: auto;
    border-right: 0.1rem solid #fff;
    border-bottom: 0.1rem solid #fff;
    transform: rotateZ(45deg);
    pointer-events: none; }

.selectable-reserve-nav-item.selectable-reserve-nav-item-tel {
  display: flex;
  align-items: center;
  margin-right: 0; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel p {
    margin-top: 0.4rem;
    line-height: 1;
    font-size: 1.25vw;
    letter-spacing: 0.1em; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel em {
    display: inline-block;
    margin-top: 0.28rem;
    margin-right: 1.71875vw;
    line-height: 1;
    font-size: 1.5625vw;
    font-style: normal;
    letter-spacing: 0.1em; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel a, .selectable-reserve-nav-item.selectable-reserve-nav-item-tel img {
    display: block;
    width: 2rem;
    height: 2rem; }

.rerserve_submit {
  border-radius: 0.2rem;
  padding: 0.6rem 1.2rem;
  background-color: #A38D50;
  line-height: 1;
  transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .rerserve_submit:hover {
    opacity: 0.8;
    background-color: #fff;
    color: #A38D50; }

#js-header-help-form-select {
  appearance: none; }

.selectable-reserve-nav-label {
  display: none; }

.header-help-form-select {
  outline: none; }

.header-help-form-select option{
    color:#000;
  }

.header-help-form-select option[selected]{
  color:inherit;
}

@media (min-width: 1281px) {
  .header-nav-href {
    padding: 0 1.08rem;
    font-size: 1.3rem; }

  .selectable-reserve-nav li {
    font-size: 1.3rem; }

  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel p {
    font-size: 1.6rem; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel em {
    font-size: 2rem; } }
@media all and (max-width: 1100px) {
  .header-nav-href {
    padding: 0 0.50625vw;
    font-size: 0.99375vw; } }
@media all and (max-width: 990px) {
  .header-nav-href {
    padding: 0 0.40625vw;
    font-size: 0.89375vw; } }
@media all and (max-width: 980px) {
  .header-logo {
    width: 20%; }

  .header-nav-href {
    padding: 0 0.40625vw;
    font-size: 0.89375vw; }

  .selectable-reserve-nav li {
    font-size: 0.815625vw; }

  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel p {
    font-size: 1.05vw; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel em {
    font-size: 1.3625vw; } }
@media all and (max-width: 950px) {
  .selectable-reserve-nav li {
    font-size: 0.615625vw; }

  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel p {
    font-size: 0.85vw; }
  .selectable-reserve-nav-item.selectable-reserve-nav-item-tel em {
    font-size: 1.1625vw; } }
@media all and (max-width: 900px) {
  .selectable-reserve {
    display: none; } }
@media all and (max-width: 780px) {
  .header-array {
    position: relative;
    height: 7rem;
    border-bottom: 0.1rem solid #A38D50; }

  .header-logo {
    width: 25.8rem;
    padding-left: 1.6rem; }

  .header-spmenu {
    display: block;
    position: relative;
    width: 4.8rem;
    height: 4.8rem;
    margin-right: 1.3rem;
    background-color: #A38D50; }

  .header-spmenu-bar {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 2rem;
    height: 0.2rem;
    margin: auto;
    background-color: #fff;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform-origin: center; }
    .header-spmenu-bar:first-of-type {
      top: -1.1rem; }
    .header-spmenu-bar:last-of-type {
      bottom: -1.3rem; }

  .header-spmenu.open span:first-of-type {
    top: 0;
    transform: rotateZ(45deg); }
  .header-spmenu.open span:nth-of-type(2) {
    opacity: 0; }
  .header-spmenu.open span:last-of-type {
    bottom: 0;
    transform: rotateZ(-45deg); }

  .header-nav {
    display: block;
    position: absolute;
    top: 7rem;
    right: 0;
    left: 0;
    height: 0;
    background-color: #fff;
    overflow: hidden;
    pointer-events: none;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }

  .header-nav.open {
    height: 56.5rem;
    pointer-events: auto; }

  .header-nav-block {
    flex-wrap: wrap;
    margin: 0 0 2.8rem; }

  .header-nav-href {
    width: 50%;
    height: 6.12rem;
    border-bottom: 0.1rem solid #A38D50;
    padding: 0;
    font-size: 1.4rem; }
    .header-nav-href:nth-of-type(2n) {
      border-left: 0.1rem solid #A38D50; }
    .header-nav-href:after {
      width: 10%; }

  .header-nav-href-pc {
    display: none !important; }

  .header-nav-href-sp {
    display: flex !important; }

  .header-nav-href-fb {
    display: flex; }

  .header-ext {
    width: 82%;
    margin: 0 auto 3rem;
    border: 0.2rem solid #A38D50; }
    .header-ext .header-nav-href {
      width: 100%;
      border-bottom: 0; }
    .header-ext::before {
      content: '';
      position: absolute;
      top: 40.8%;
      right: 1.2rem;
      width: 2.6rem;
      height: 0.8rem;
      margin: auto;
      background-size: contain;
      background-image: url("../imgs/img/arrow_w.png");
      z-index: 4;
      transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .header-ext:hover::before {
      background-image: url("../imgs/img/arrow_g.png"); }

  .header-help {
    display: block; }

  .header-help-tel {
    display: flex;
    justify-content: center;
    align-items: baseline;
    width: 26rem;
    margin: 0 auto 3rem;
    font-family: inherit;
    font-weight: 200;
    font-size: 1.2rem;
    line-height: 1.2;
    color: #A38D50;
    letter-spacing: 0.2rem; }
    .header-help-tel em {
      display: inline-block;
      margin-left: 0.2rem;
      font-style: normal;
      font-weight: inherit;
      font-size: 3rem; }

  .header-help-form {
    position: relative;
    letter-spacing: 0.22rem;
    font-family: inherit;
    font-size: 1.6rem;
    font-weight: 200; }
    .header-help-form::after {
      content: '';
      display: block;
      position: absolute;
      top: 0;
      right: 32.8%;
      bottom: 0;
      width: 0.6rem;
      height: 0.6rem;
      margin: auto;
      border-right: 0.12rem solid #A38D50;
      border-bottom: 0.12rem solid #A38D50;
      transform: rotateZ(45deg); }

  .header-help-form-select {
    display: block;
    width: 12rem;
    height: 1.6em;
    margin: 0 auto;
    letter-spacing: inherit;
    outline: none;
    text-align: center; }

  .header-help-form-select option {
    text-align: center; }

  .selectable-reserve {
    display: none; } }
.footer {
  padding: 4rem 0 14rem;
  background-color: #000;
  background-image: url("../imgs/img/footer_bg.png");
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: contain; }
  .footer > div {
    width: 84.375%;
    margin: 0 auto; }

.parts-contact {
  display: flex;
  justify-content: center;
  flex-direction: column;
  margin-bottom: 7.6rem; }
  .parts-contact > div {
    margin: 0 auto; }

.parts-contact-head {
  margin-bottom: 2.8rem;
  text-align: center;
  color: #fff;
  font-size: 2.4rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.24em; }

.parts-contact-tel {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 2.8rem;
  text-align: center; }

.parts-contact-tel-ic {
  width: 2.4rem;
  height: 2.4rem;
  margin-right: 2.2rem; }

.parts-contact-tel-text {
  color: #A38D50;
  font-size: 2.6rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.2em; }

.parts-contact-tel-href {
  position: relative;
  max-width: 36rem;
  width: 28.125vw;
  max-height: 8rem;
  height: 5.15625vw;
  margin: 0 auto;
  border: 0.2rem solid #A38D50;
  padding: 0 2rem;
  background-color: #fff;
  color: #fff;
  font-size: 1.25vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .parts-contact-tel-href span {
    text-align: center;
    z-index: 2; }
  .parts-contact-tel-href::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #A38D50;
    z-index: 1;
    transform-origin: right;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .parts-contact-tel-href:hover {
    border: 0.2rem solid #fff;
    color: #A38D50; }
    .parts-contact-tel-href:hover:before {
      transform: scale(0, 1); }

.footer-nav-top {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6rem; }

.footer-nav-logo {
  display: flex;
  width: 50%;
  padding-left: 2.1875vw; }

.footer-nav-logo-body {
  width: 7.34375vw;
  margin-right: 4.53125vw; }

.footer-nav-logo-text {
  width: calc( 100% - 7.34375vw ); }

.footer-nav-logo-text-body {
  margin-bottom: 1.8rem;
  color: #fff;
  font-size: 1.3rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.1em; }
  .footer-nav-logo-text-body span {
    display: inline-block;
    width: 4.6rem; }

.footer-nav-logo-text-fb {
  display: flex;
  width: 2.8rem;
  height: 2.8rem; }

.footer-nav-list {
  display: flex;
  width: 50%;
  padding-left: 1.71875vw; }
  .footer-nav-list ul:first-of-type {
    margin-right: 13.28125vw; }

.footer-nav-list-item {
  display: block;
  min-width: 10rem;
  margin-bottom: 0.8rem;
  color: #fff;
  font-size: 1.4rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .footer-nav-list-item::before {
    content: '●';
    display: inline-block;
    margin-right: 0.625vw;
    color: #A38D50;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .footer-nav-list-item:hover {
    color: #A38D50; }
  .footer-nav-list-item a {
    color: inherit; }

.footer-nav-fpstd {
  display: flex;
  align-items: center;
  margin-bottom: 1.8rem;
  border-bottom: 0.1rem solid #323232;
  padding-bottom: 2.6rem; }

.footer-nav-fpstd-body {
  width: 6rem; }

.footer-nav-fpstd-text {
  margin-left: 2rem;
  color: #959595;
  font-size: 1.2rem; }

.copyright {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  color: #959595; }

.copyright-href {
  color: inherit;
  font-size: 1.2rem; }
  .copyright-href a {
    color: inherit; }

.copyright-text {
  color: inherit;
  font-size: 1rem; }

@media all and (max-width: 768px) {
  .footer {
    padding: 2rem 0 6rem; }

  .parts-contact > div {
    width: 100%; }

  /*.parts-contact-head {
    font-size: 6.4vw;
  }*/
  .footer-nav-top {
    display: block; }

  .footer-nav-logo {
    display: flex;
    width: 100%;
    margin-bottom: 4.4rem;
    padding-left: 0; }

  .footer-nav-logo-body {
    width: 7rem;
    margin-right: 0; }

  .footer-nav-logo-text {
    width: calc( 100% - 7rem );
    margin-left: 3rem; }

  .footer-nav-logo-text-body {
    font-size: 1.1rem; }
    .footer-nav-logo-text-body span {
      width: auto; }

  .footer-nav-logo-text-fb {
    width: 2.4rem;
    height: 2.4rem; }

  .parts-contact-tel {
    width: 100%; }

  .parts-contact-tel-ic {
    width: 2.3rem;
    height: 2.3rem; }

  .parts-contact-tel-text {
    font-size: 2.4rem; }

  .parts-contact-tel-href.bt-has-arrow-r {
    width: 31rem;
    height: 7rem;
    margin-right: auto;
    margin-left: auto;
    font-size: 1.68rem; }
    .parts-contact-tel-href.bt-has-arrow-r > span {
      font-size: inherit; }
      .parts-contact-tel-href.bt-has-arrow-r > span::after {
        width: 2.65rem;
        height: 0.7rem; }

  .footer-nav-list {
    width: 100%;
    padding-left: 0; }
    .footer-nav-list ul:first-of-type {
      width: 50%;
      margin-right: 0; }

  .footer-nav-list-item {
    min-width: auto;
    margin-bottom: 2rem; }

  .footer-nav-fpstd {
    margin-bottom: 1.3rem;
    padding-bottom: 1.3rem; }

  .footer-nav-fpstd-body {
    width: 4rem; }

  .footer-nav-fpstd-text {
    font-size: 1.1rem; }

  .copyright {
    display: block; }

  .copyright-href {
    margin-bottom: 0.8rem;
    font-size: 1.1rem; }

  .copyright-text {
    font-size: 1.1rem; } }
@keyframes top-fv-scroll-move {
  0% {
    transform: translateY(-5rem); }
  100% {
    transform: translateY(5rem); } }
@keyframes lower-header {
  0% {
    width: 100%; }
  100% {
    width: 95.3125%; } }
@keyframes loader {
  0% {
    opacity: 0;
    filter: brightness(0) invert(1); }
  5% {
    transform: translate3d(0, 0vw, 0);
    opacity: 1;
    filter: brightness(0) invert(1); }
  10% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  15% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  20% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  25% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  30% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  35% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  40% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  45% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  50% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  55% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  60% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  65% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  70% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  75% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  80% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  85% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  90% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; }
  95% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(0) invert(1);
    opacity: 1; }
  100% {
    transform: translate3d(0, 0vw, 0);
    filter: brightness(1) invert(0);
    opacity: 1; } }
@keyframes loader_delete {
  0% {
    filter: blur(0);
    opacity: 1;
    pointer-events: auto;
    z-index: 9999;
    transform: translate3d(0, 0vw, 0); }
  100% {
    filter: blur(1rem);
    opacity: 0;
    pointer-events: none;
    z-index: -9999;
    transform: translate3d(0, 0vw, 0); } }
.lower___ #loader {
  display: none; }

#loader {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 100%;
  height: 100vh;
  background-color: #000;
  z-index: 9999; }

#loader.delete {
  animation: loader_delete 1s cubic-bezier(0.215, 0.61, 0.355, 1) forwards; }

.loader-block, .loader-logo {
  display: block;
  width: 6vw;
  height: 6vw;
  overflow: hidden;
  filter: blur(0); }

.loader-logo {
  opacity: 0;
  transform: translate3d(0, 5vw, 0);
  transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
  animation: loader 40s cubic-bezier(0.215, 0.61, 0.355, 1) forwards; }

::selection {
  background: #A38D50;
  color: #fff; }

/*2406モーダル追加に伴い以下修正*/

  *:not(.modal-inner)::-webkit-scrollbar {
  display: none; }

main {
  margin-top: 6rem; }

.t_r {
  text-align: right; }

.t_l {
  text-align: left; }

.lt-0 {
  letter-spacing: 0; }

.ic-pdf {
  display: flex;
  align-items: center;
  text-decoration: underline; }
  .ic-pdf::before {
    content: '';
    display: inline-block;
    width: 2.34375vw;
    height: 2.34375vw;
    margin-right: 0.625vw;
    background-image: url("../imgs/img/ic_pdf.png");
    background-size: cover; }

.backtop {
  display: block;
  position: fixed;
  right: 2.5rem;
  bottom: -6rem;
  width: 4.8rem;
  height: 4.8rem;
  transition: bottom 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  z-index: 800;
  cursor: pointer; }
  .backtop:after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 100%;
    background-color: #A38D50;
    opacity: 0;
    isolation: isolate;
    mix-blend-mode: difference;
    transition: opacity 0.28s cubic-bezier(0.215, 0.61, 0.355, 1);
    z-index: 801; }
  .backtop:hover::after {
    opacity: 1; }

.bt-large {
  width: 28.125vw;
  height: 6.25vw; }

.lower .bt-has-arrow-r {
  position: relative;
  border: 0.1rem solid #fff; }
  .lower .bt-has-arrow-r::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #A38D50;
    transform: scale(0, 1);
    transform-origin: left;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1);
    opacity: 0.8;
    z-index: 2; }
  .lower .bt-has-arrow-r:hover {
    border: 0.1rem solid #A38D50; }
    .lower .bt-has-arrow-r:hover::after {
      transform: scale(1, 1); }

.bt-has-arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 0 1vw; }
  .bt-has-arrow > span {
    display: block;
    position: relative;
    width: 100%;
    text-align: center;
    color: #fff;
    font-size: 1.25vw;
    font-family: "Yu Mincho", "YuMincho", serif;
    font-weight: 200;
    z-index: 6; }
    .bt-has-arrow > span::after {
      content: '';
      display: block;
      position: absolute;
      top: -0.4rem;
      right: 0;
      bottom: 0;
      left: auto;
      width: 2.0703125vw;
      height: 0.546875vw;
      margin: auto;
      background-size: contain;
      background-image: url("../imgs/img/arrow_w.png");
      transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .bt-has-arrow:hover > span::after {
    right: -1rem; }

.bt-has-arrow-r {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 0 1vw; }
  .bt-has-arrow-r > span {
    display: block;
    position: relative;
    width: 100%;
    text-align: center;
    letter-spacing: 0.1em;
    color: #fff;
    font-size: 1.25vw;
    font-family: "Yu Mincho", "YuMincho", serif;
    font-weight: 200;
    z-index: 6; }
    .bt-has-arrow-r > span::after {
      content: '';
      display: block;
      position: absolute;
      top: -0.4rem;
      right: 0;
      bottom: 0;
      left: auto;
      width: 2.0703125vw;
      height: 0.546875vw;
      margin: auto;
      background-size: contain;
      background-image: url("../imgs/img/arrow_w.png");
      transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .bt-has-arrow-r:hover > span::after {
    right: -1rem; }

.bt-has-arrow-r.hover-gold:hover > span {
  color: #A38D50; }
  .bt-has-arrow-r.hover-gold:hover > span::after {
    background-image: url("../imgs/img/arrow_g.png"); }

.bt-has-arrow-r.f-gold {
  border: 0.1rem solid #A38D50; }
  .bt-has-arrow-r.f-gold::after {
    transform: scale(1, 1);
    transform-origin: right; }
  .bt-has-arrow-r.f-gold:hover {
    border: 0.1rem solid #fff; }
    .bt-has-arrow-r.f-gold:hover::after {
      transform: scale(0, 1); }

.lower-has-pandbb {
  margin-bottom: 1.09375vw;
  border-bottom: 0.1rem solid #313131;
  padding-bottom: 0.78125vw;
  padding-left: 1.2em;
  text-indent: -1.2em;
  line-height: 2;
  color: #fff;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }
  .lower-has-pandbb em {
    color: #A38D50;
    font-style: normal; }
  .lower-has-pandbb dt {
    width: 15.625vw; }
  .lower-has-pandbb dd {
    width: calc(100% - 15.625vw); }

dl.lower-has-pandbb {
  display: flex;
  padding-left: 0;
  text-indent: 0; }

@media all and (min-width: 1281px) {
  .bt-has-arrow-r > span {
    font-size: 1vw; } }
@media all and (max-width: 768px) {
  .loader-block, .loader-logo {
    width: 12vw;
    height: 12vw; }

  main {
    margin-top: 7rem; }

  .backtop {
    right: 1.05rem;
    bottom: -4.8rem; } }
@media all and (max-width: 750px) {
  .lower-has-pandbb {
    margin-top: 3vw;
    padding-bottom: 2.48125vw;
    font-size: 3.7333333333333334vw; }
    .lower-has-pandbb dt {
      display: inline-block;
      width: auto;
      margin-right: 4vw;
      font-size: 4.333333333333334vw; }
    .lower-has-pandbb dd {
      display: inline-block;
      width: auto; }

  .ic-pdf {
    letter-spacing: -0.08em; }
    .ic-pdf::before {
      width: 6vw;
      height: 6vw;
      margin-right: 2.625vw; }

  .bt-large {
    width: 100%; }

  dl.lower-has-pandbb {
    align-items: baseline;
    flex-wrap: wrap; }

  .bt-has-arrow-r, .bt-has-arrow {
    width: 90%;
    height: auto; }
    .bt-has-arrow-r span, .bt-has-arrow span {
      padding: 3vw 0;
      font-size: 3.3333333333333334vw; }
      .bt-has-arrow-r span:after, .bt-has-arrow span:after {
        width: 2em;
        height: 0.4em;
        background-size: contain; } }
.top .bt-has-arrow-r {
  margin-right: auto;
  margin-left: auto; }
.top .top-alternate-block-text-link span::after {
  background-size: contain; }
.top .top-info-block-body-header-link {
  margin-right: 0; }
  .top .top-info-block-body-header-link span {
    text-align: left; }

.top-fv {
  position: relative;
  width: 100%;
  padding: 5rem 2.28vw 7.4rem;
  background-color: #000;
  overflow: hidden; }
  .top-fv .slick-arrow {
    position: relative;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 4.6rem;
    margin: 0;
    font-size: 0; }
    .top-fv .slick-arrow::before {
      content: '';
      display: block;
      position: absolute;
      top: 0;
      bottom: 0;
      width: 0.6rem;
      height: 0.9rem;
      margin: auto;
      background-size: cover; }
  .top-fv .slick-prev::before, .top-fv .slick-next::before {
    right: 0;
    left: 0; }
  .top-fv .slick-prev:before {
    background-image: url("../imgs/img/slide-arrow-prev.png"); }
  .top-fv .slick-next:before {
    background-image: url("../imgs/img/slide-arrow-next.png"); }

.top-fv-slide-block {
  position: relative; }

.top-fv-slide {
  font-size: 0; }
  .top-fv-slide img {
    width: 100%;
    object-fit: cover; }

.top-fv-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  top: auto;
  right: 0;
  bottom: 0;
  left: auto;
  width: 18rem;
  height: 4rem;
  background-color: #000; }

.top-fv-nav-counter {
  color: #fff;
  letter-spacing: 0.2rem;
  font-size: 1.2rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.top-fv-nav-counter-current::before, .top-fv-nav-counter-total::before {
  content: '0';
  display: inline; }

.top-fv-cc {
  position: absolute;
  top: 12.5rem;
  right: 16.8rem;
  width: 13rem;
  height: 24.8rem;
  z-index: 4; }

.top-fv-scroll {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  top: auto;
  right: 0;
  bottom: 2.8rem;
  left: 0;
  width: 6.2rem;
  height: 8.68rem;
  margin: auto;
  color: #fff;
  overflow: hidden;
  z-index: 4;
  cursor: pointer; }

.top-fv-scroll-text {
  padding-top: 1rem;
  letter-spacing: 0.2rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 1.2rem;
  font-weight: 200; }

.top-fv-scroll-bar {
  overflow: hidden; }

.top-fv-scroll-bar-item {
  display: block;
  width: 0.1rem;
  height: 5rem;
  background-color: #fff;
  transition: all 0.28 cubic-bezier(0.215, 0.61, 0.355, 1);
  animation: top-fv-scroll-move 1.68s cubic-bezier(0.62, 0.27, 0.57, 0.68) infinite forwards;
  overflow: hidden; }

.top-alternate {
  position: relative;
  padding: 0 0 4rem;
  background-color: #000; }

.top-alternate > div {
  position: relative;
  top: -2.8rem; }

.top-alternate-reserve {
  display: none;
  pointer-events: none; }

.top-alternate-block {
  display: flex;
  align-items: center;
  margin-bottom: 2rem; }
  .top-alternate-block:nth-of-type(2n) {
    flex-direction: row-reverse; }

.top-alternate-block-head {
  position: relative;
  width: 65.625%;
  opacity: 0; }
  .top-alternate-block-head img {
    width: 100%;
    object-fit: cover; }
  .top-alternate-block-head::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #A38D50;
    z-index: 4;
    opacity: 0.8;
    isolation: isolate;
    mix-blend-mode: exclusion;
    transition: all 0.8s cubic-bezier(0.15, -0.28, 0.74, 0.94) 0.28s; }

.top-alternate-block-head-cc {
  position: absolute;
  top: 5vw;
  width: 60%;
  z-index: 6; }

.top-alternate-block-head-cc01 {
  left: -15%; }

.top-alternate-block-head-cc02 {
  right: -15%; }

.top-alternate-block-head-cc03 {
  left: -28%;
  width: 90%; }

.top-alternate-block-text {
  position: relative;
  width: 42%;
  margin-top: 13.28vw;
  background-color: #000;
  opacity: 0; }
  .top-alternate-block-text p {
    color: #fff;
    font-size: 1.5rem;
    font-family: "Yu Mincho", "YuMincho", serif;
    font-weight: 200; }
  .top-alternate-block-text::after {
    content: '';
    display: block;
    position: absolute;
    top: -0.2rem;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #A38D50;
    z-index: 4;
    opacity: 0.8;
    isolation: isolate;
    mix-blend-mode: exclusion;
    transition: all 0.8s cubic-bezier(0.15, -0.28, 0.74, 0.94) 0.28s; }

.top-alternate-block:nth-of-type(2n+1) .top-alternate-block-head {
  left: -50%;
  transition: left 1s cubic-bezier(0.15, -0.28, 0.74, 0.94), opacity 1s cubic-bezier(0.15, -0.28, 0.74, 0.94); }
  .top-alternate-block:nth-of-type(2n+1) .top-alternate-block-head::after {
    transform-origin: right; }
.top-alternate-block:nth-of-type(2n+1) .top-alternate-block-text {
  right: -50%;
  transition: right 1s cubic-bezier(0.15, -0.28, 0.74, 0.94), opacity 1s cubic-bezier(0.15, -0.28, 0.74, 0.94); }
  .top-alternate-block:nth-of-type(2n+1) .top-alternate-block-text::after {
    transform-origin: left; }

.top-alternate-block:nth-of-type(2n) .top-alternate-block-head {
  right: -50%;
  transition: right 1s cubic-bezier(0.15, -0.28, 0.74, 0.94), opacity 1s cubic-bezier(0.15, -0.28, 0.74, 0.94); }
  .top-alternate-block:nth-of-type(2n) .top-alternate-block-head::after {
    transform-origin: left; }
.top-alternate-block:nth-of-type(2n) .top-alternate-block-text {
  left: -50%;
  transition: left 1s cubic-bezier(0.15, -0.28, 0.74, 0.94), opacity 1s cubic-bezier(0.15, -0.28, 0.74, 0.94); }
  .top-alternate-block:nth-of-type(2n) .top-alternate-block-text::after {
    transform-origin: right; }

.top-alternate-block:nth-of-type(2n+1).played .top-alternate-block-head {
  left: 0;
  opacity: 1; }
  .top-alternate-block:nth-of-type(2n+1).played .top-alternate-block-head::after {
    transform: scale(0, 1); }
.top-alternate-block:nth-of-type(2n+1).played .top-alternate-block-text {
  right: 0;
  opacity: 1; }
  .top-alternate-block:nth-of-type(2n+1).played .top-alternate-block-text::after {
    transform: scale(0, 1); }

.top-alternate-block:nth-of-type(2n).played .top-alternate-block-head {
  right: 0;
  opacity: 1; }
  .top-alternate-block:nth-of-type(2n).played .top-alternate-block-head::after {
    transform: scale(0, 1); }
.top-alternate-block:nth-of-type(2n).played .top-alternate-block-text {
  left: 0;
  opacity: 1; }
  .top-alternate-block:nth-of-type(2n).played .top-alternate-block-text::after {
    transform: scale(0, 1); }

.top-alternate-block-text-head {
  position: absolute;
  top: -1.71875vw;
  left: 3.125vw;
  max-width: 18rem;
  width: 14vw; }

.top-alternate-block-text-l {
  margin-left: -7.8vw;
  padding: 14.8375vw 7.8125vw 7.5vw 6.09375vw; }

.top-alternate-block-text-r {
  margin-right: -7.8vw;
  padding: 14.8375vw 6.09375vw 7.5vw 7.8125vw; }

.top-alternate-block-text-link {
  display: flex;
  align-items: center;
  position: relative;
  width: 18.75vw;
  height: 3.125vw;
  margin-top: 4.8rem;
  border: 0.1rem solid #fff;
  padding: 0 2rem;
  color: #fff; }
  .top-alternate-block-text-link::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #A38D50;
    transform: scale(0, 1);
    transform-origin: left;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1);
    opacity: 0.8;
    z-index: 2; }
  .top-alternate-block-text-link:hover {
    border: 0.1rem solid #A38D50; }
    .top-alternate-block-text-link:hover::after {
      transform: scale(1, 1); }

.top-alternate-block-text-link-text {
  position: relative;
  width: 100%;
  color: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  z-index: 6; }

.top-info {
  padding: 8.4rem 0 4.2rem;
  background-image: url("../imgs/img/checktile_bg.jpg");
  background-size: cover;
  background-repeat: repeat-y; }
  .top-info > div {
    width: 84.2%;
    margin: 0 auto; }
  .top-info .slick-arrow {
    width: 4rem;
    height: 4rem;
    font-size: 0; }
  .top-info .slick-prev {
    left: -6rem;
    background-image: url("../imgs/img/slide_arrow_l.png"); }
  .top-info .slick-next {
    right: -6rem;
    background-image: url("../imgs/img/slide_arrow_r.png"); }

.top-info-block {
  display: flex;
  justify-content: space-between;
  margin-bottom: 3.6rem; }

.top-info-block-body {
  width: calc( 100% - 31.25vw ); }

.top-info-block-body-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 2rem;
  border-bottom: 0.1rem solid #fff;
  padding-bottom: 1rem;
  font-weight: 200;
  font-family: "Yu Mincho", "YuMincho", serif;
  color: #fff; }

.top-info-block-body-header-text {
  font-size: 2.36171875vw;
  font-weight: inherit;
  letter-spacing: 0.4rem; }

.top-info-block-body-header-link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 10.8vw;
  height: 2vw;
  margin-right: 0; }
  .top-info-block-body-header-link span {
    width: 100%;
    color: #fff;
    font-size: 1.0796875vw; }

.top-info-block-body-list-item {
  margin-bottom: 1.44rem;
  border-bottom: 0.1rem solid #fff;
  padding-bottom: 1.44rem; }
  .top-info-block-body-list-item:hover .top-info-block-body-list-item-catch img {
    transform: scale(1.05); }

.top-info-block-body-list-item-block {
  display: flex; }

.top-info-block-body-list-item-catch {
  width: 12rem;
  height: 8rem;
  margin-right: 2rem;
  overflow: hidden; }
  .top-info-block-body-list-item-catch img {
    width: inherit;
    height: inherit;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }

.top-info-block-body-list-item-body {
  width: calc( 100% - 14rem ); }

.top-info-block-body-list-item-body-date {
  display: block;
  margin-bottom: 1.2rem;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 400;
  font-style: normal;
  line-height: 1; }

.top-info-block-body-list-item-body-text {
  color: #fff;
  font-size: 1.8rem;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
line-height: 1.3;}

.top-info-block-body-fb {
  width: 28.125vw; }

.top-info-banner-static {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 2.6rem; }

.top-info-banner-static-item {
  width: calc( 50% - 1rem );
  margin-bottom: 1rem; }
  .top-info-banner-static-item:nth-of-type(2n) {
    margin-left: 2rem; }

.top-info-banner-slide {
  max-width: 108rem;
  width: 88.8%;
  margin: 0 auto; }

.top-info-banner-slide-item a {
  display: block;
  width: 93.75%;
  margin: 0 auto; }

.top-banner {
  padding: 5.2rem 0 5rem;
  background-color: #000; }
  .top-banner > div {
    max-width: 108rem !important;
    width: 84.2%;
    margin: 0 auto; }
  .top-banner .slick-arrow {
    width: 4rem;
    height: 4rem;
    font-size: 0; }
  .top-banner .slick-prev {
    left: -6rem;
    background-image: url("../imgs/img/slide_arrow_l.png"); }
  .top-banner .slick-next {
    right: -6rem;
    background-image: url("../imgs/img/slide_arrow_r.png"); }

.top-banner-slide {
  width: 88.8%;
  margin: 0 auto; }

.top-banner-slide-item a {
  display: block;
  width: 93.4%;
  margin: 0 auto; }

@media all and (min-width: 1281px) {
  .top-alternate-block-text p {
    font-size: 1.171875vw; }

  .top-alternate-block-text-head {
    width: 12vw; }

  .top-info-block-body-header-link > span {
    font-size: 1.09375vw; }

  .top-alternate-block-head-cc {
    position: absolute;
    top: 5vw;
    z-index: 6; }

  .top-alternate-block-head-cc01 {
    left: -10vw;
    width: 39.375vw; }

  .top-alternate-block-head-cc02 {
    right: -10vw;
    width: 39.375vw; }

  .top-alternate-block-head-cc03 {
    left: -18vw;
    width: 54vw; }

  .top-info > div {
    width: 108rem; }

  .top-info-block-body {
    width: calc(100% - 40rem);
 height: 400px;
 overflow: scroll;}

  .top-info-block-body-fb {
    width: 36rem;
 padding-top: 30px;}

  .top-info-block-body-header-text {
    font-size: 3.023rem; }

  .top-info-block-body-header-link {
    width: 12rem;
    height: 1.4rem; }

  .top-info-block-body-header-link {
    padding: 0; }
    .top-info-block-body-header-link > span {
      font-size: 1.382rem; }
      .top-info-block-body-header-link > span::after {
        width: 2.6rem;
        height: 1rem; } }
@media all and (max-width: 980px) {
  .top-info-block-body-header-link > span {
    font-size: 1.4rem; } }
@media all and (max-width: 768px) {
  .top-fv {
    margin-bottom: -1px;
    padding: 1.5rem 1.5rem 7.4rem; }
    .top-fv .slick-arrow {
      width: 3.5rem; }

  .top-fv-cc {
    position: absolute;
    top: 4.75rem;
    right: 4.8vw;
    width: 13rem;
    height: 24.8rem;
    z-index: 4; }

  .top-fv-nav {
    width: 13.5rem; }

  .top-fv-nav-counter {
    font-size: 1rem; }

  .top-alternate {
    margin-top: 0;
    padding-top: 2.4rem; }

  .top-alternate > div {
    position: static;
    top: 0; }

  .top-alternate-reserve {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: -0.2rem;
    right: 0;
    left: 0;
    width: 18rem;
    height: 5rem;
    margin: auto;
    color: #fff;
    font-size: 1.4rem;
    font-family: "Yu Mincho", "YuMincho", serif;
    font-weight: 200;
    background-color: #A38D50;
    pointer-events: auto;
    z-index: 888; }

  .top-alternate-reserve.fixed {
    position: fixed;
    top: auto;
    bottom: 2.8rem;
    z-index: 899; }

  .top-alternate-block {
    display: block;
    margin-bottom: 8rem; }

  .top-alternate-block-head {
    width: 100%; }

  .top-alternate-block-head-cc {
    position: absolute;
    top: 5vw;
    width: 80%;
    z-index: 6; }

  .top-alternate-block-head-cc01 {
    left: -25%; }

  .top-alternate-block-head-cc02 {
    right: -25%; }

  .top-alternate-block-head-cc03 {
    width: 100%;
    left: -36%; }

  .top-alternate-block-text {
    width: 100%;
    padding: 8.4rem 13.333vw 0; }
    .top-alternate-block-text p {
      font-size: 1.5rem; }

  .top-alternate-block-text-head {
    top: -10rem;
    right: 0;
    left: 0;
    width: 16rem;
    margin: auto; }

  .top-alternate-block-text-r {
    margin-right: auto; }

  .top-alternate-block-text-l {
    margin-left: auto; }

  .top-alternate-block-text-link {
    width: 100%;
    height: 4.8rem;
    margin-top: 3rem; }

  .top-info {
    padding: 5.4rem 0 4.2rem; }
    .top-info > div {
      width: 91.5%; }
    .top-info .slick-arrow {
      width: 3rem;
      height: 3rem;
      font-size: 0; }
    .top-info .slick-prev {
      left: -3.8rem; }
    .top-info .slick-next {
      right: -3.8rem; }

  .top-info-block {
    display: block;
    margin-bottom: 1.6rem; }

  .top-info-block-body {
    width: 100%;
    margin-bottom: 3.5rem; }

  .top-info-block-body-header {
    justify-content: center;
    align-items: center;
    flex-direction: column;
    margin-bottom: 1.5rem;
    padding-bottom: 3rem; }

  .top-info-block-body-header-text {
    font-size: 3rem; }

  .top .top-info-block-body-header-link {
    width: 13rem;
    font-size: 1.4rem; }
    .top .top-info-block-body-header-link .bt-has-arrow-r {
      font-size: inherit; }

  .top .top-info-block-body-header-link {
    margin-right: auto; }

  .top-info-block-body-list-item-catch {
    width: 10.5rem;
    height: 7rem;
    margin-right: 1.5rem; }

  .top-info-block-body-list-item-body-text {
    font-size: 1.2rem; }

  .top-info-block-body-fb {
    width: 50rem;
    margin: 0 auto; }

  .fb_iframe_widget_fluid {
    display: block !important;
    width: 100%;
    margin: 0 auto; }

  .top-info-banner-static {
    display: block;
    width: 91%;
    margin: 0 auto 4.25rem;
    font-size: 0; }

  .top-info-banner-static-item {
    width: 100%;
    margin-bottom: 1.5rem; }

  .top-info-banner-slide {
    width: 76%; }

  .top-banner > div {
    width: 91.5%; }
  .top-banner .slick-arrow {
    width: 3rem;
    height: 3rem;
    font-size: 0; }
  .top-banner .slick-prev {
    left: -3.8rem; }
  .top-banner .slick-next {
    right: -3.8rem; }

  .top-banner-slide {
    width: 76%; } }
@media all and (max-width: 750px) {
  .top-info-block-body-header-text {
    margin-bottom: 2vw; }

  .top-alternate-block-head-cc03 {
    right: -42.8%;
    left: auto;
    max-width: 1000% !important;
    width: 44rem; } }
@media all and (max-width: 480px) {
  .top-info-block-body-fb {
    width: 91%;
    margin: 0 auto; } }
.lower {
  padding-top: 5rem;
  padding-bottom: 7.03125vw;
  background-color: #000; }
  .lower > section:not(.lower-header) {
    width: 84.375%;
    margin-right: auto;
    margin-left: auto; }
  .lower p {
    letter-spacing: 0.05em; }

.about {
  padding-bottom: 0; }

.access .lower-cc-text {
  width: 100%;
  text-align: center; }

.cuisine {
  padding-bottom: 7.03125vw; }
  .cuisine .lower-indetail-images {
    flex-direction: column; }
    .cuisine .lower-indetail-images img:first-of-type {
      margin-right: 0;
      margin-bottom: 1.5625vw; }
    .cuisine .lower-indetail-images img {
      width: 100%; }
  .cuisine .lower-links .bt-has-arrow:first-of-type {
    width: 36vw; }
  .cuisine .lower-links .bt-has-arrow:last-of-type {
    width: 30vw; }

.gallery {
  padding-bottom: 9.53125vw; }
  .gallery .lower-cc {
    margin-bottom: 6.25vw; }
  .gallery .lower-cc-text {
    text-align: center; }
  .gallery .lower-cc-nav-item:not(:last-of-type) {
    margin-right: 6.09375vw; }

.spa .lower-alternate-item-body-head {
  margin-left: -0.5em;
  text-indent: 0.5em;
  letter-spacing: 0.1em; }
.spa .lower-links .bt-has-arrow-r {
  width: 37.5vw;
  height: 4.6875vw;
  margin: 0 auto; }

.facilities .lower-links {
  padding-top: 10.46875vw;
  padding-bottom: 3.59375vw; }
  .facilities .lower-links .bt-has-arrow-r {
    margin: 0 auto; }

.info .wp-pagenavi {
  display: flex;
  justify-content: center;
  align-items: center; }
.info .wp-pagenavi > * {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 3.4375vw;
  height: 3.4375vw;
  margin-right: 1.171875vw;
  border-radius: 100%;
  font-size: 1.40625vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  color: #fff;
  transition: background-color 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .info .wp-pagenavi > *:last-child {
    margin-right: 0; }
.info .wp-pagenavi a:not(.previouspostslink):not(.nextpostslink), .info .wp-pagenavi span {
  border: 0.1rem solid #fff; }
  .info .wp-pagenavi a:not(.previouspostslink):not(.nextpostslink):hover, .info .wp-pagenavi span:hover {
    background-color: #A38D50;
    border-color: #A38D50; }
.info .wp-pagenavi .current {
  border: 0.1rem solid #A38D50;
  background-color: #A38D50; }
.info .previouspostslink, .info .nextpostslink {
  width: 0.78125vw;
  height: 0.78125vw;
  border-top: 0.1rem solid #A38D50;
  border-radius: 0;
  font-size: 0; }
.info .previouspostslink {
  border-left: 0.1rem solid #A38D50;
  transform: rotateZ(-45deg); }
.info .nextpostslink {
  border-right: 0.1rem solid #A38D50;
  transform: rotateZ(45deg); }

.post .lower-date {
  margin-right: 1.25vw;
  color: #fff; }
.post .lower-cate {
  width: 8.59375vw;
  height: 0.8em; }
.post .lower-info-detail {
  margin-bottom: 2.34375vw; }
.post .wp-pagenavi > span {
  font-size: 1.40625vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  color: #fff; }

.cc-walking .lower-indetail-amount-text span {
  display: inline-block;
  margin-top: 2rem;
  letter-spacing: 0.05em; }

.lower-header {
  position: relative;
  margin: 0 auto 9.375vw;
  transition: width 0.4s cubic-bezier(0.215, 0.61, 0.355, 1); }

.loaded .lower-header {
  animation: lower-header 1s cubic-bezier(0.215, 0.61, 0.355, 1) forwards; }

.lower-header-img {
  transition: all 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 0.2s;
  max-height: 100vh; }

.loaded .post .lower-header-img {
  max-height: 12.5vw;
  object-position: top; }

.lower-header-head {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  right: 0;
  bottom: -5.078125vw;
  left: 0;
  width: 57.8125vw;
  height: 10.15625vw;
  margin: 0 auto;
  background-image: url("../imgs/img/checktile_bg.jpg");
  background-repeat: repeat;
  background-position: 20% 20%;
  text-align: center;
  line-height: 1.2;
  color: #fff;
  letter-spacing: 0.24em;
  font-size: 2.5vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  line-height: 1;
  z-index: 4; }

  .lower-header-head_eng{
    letter-spacing: 0.1em;
    font-family: serif;
  }

.lower-cc {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin-bottom: 5.46875vw; }
  .lower-cc > div {
    width: 100%; }

.lower-cc-head {
  text-align: center;
  color: #A38D50;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.24em; }

  .lower-cc-head_eng{
    font-family:serif;
    letter-spacing: 0.1em;
  }


.lower-cc-text {
  width: 66%;
  margin: auto;
  padding-top: 2.325vw;
  line-height: 2.2;
  color: #fff;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-cc-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 6.25vw;
  margin-top: 3.90625vw;
  background-color: #171717; }

.lower-cc-nav-item {
  display: block;
  position: relative;
  text-align: center;
  color: #A38D50;
  line-height: 1;
  font-size: 1.421875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }
  .lower-cc-nav-item:not(:last-of-type) {
    margin-right: 9.375vw; }
  .lower-cc-nav-item::after {
    content: '';
    display: block;
    position: absolute;
    right: 0;
    bottom: -1.25vw;
    left: 0;
    width: 0.625vw;
    height: 0.625vw;
    margin: auto;
    border-right: 0.1rem solid #fff;
    border-bottom: 0.1rem solid #fff;
    transform: rotateZ(45deg);
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .lower-cc-nav-item:hover::after {
    bottom: -1.48vw; }

.lower-split-block {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

.lower-split-item {
  width: calc(50% - 3.125vw);
  margin-right: 6.25vw;
  margin-bottom: 6.25vw; }
  .lower-split-item:nth-of-type(2n) {
    margin-right: 0; }

.lower-split-item-block-head {
  margin-bottom: 2.5vw; }

.lower-split-item-block-body {
  width: 91%;
  margin: 0 auto; }

.lower-split-item-block-body-head {
  display: block;
  margin-bottom: 1.875vw;
  line-height: 1;
  color: #A38D50;
  font-size: 1.875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  font-style: normal;
  letter-spacing: 0.28em; }

.lower-split-item-block-body-text {
  color: #fff;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-alternate {
  margin-bottom: 8.59375vw; }
  .lower-alternate .lower-alternate-item:nth-of-type(odd) .lower-alternate-item-body {
    padding-left: 6.09375%; }
  .lower-alternate .lower-alternate-item:nth-of-type(odd) .slick-prev {
    right: 3.2vw;
    left: auto; }
  .lower-alternate .lower-alternate-item:nth-of-type(odd) .slick-next {
    right: 0;
    left: auto; }
  .lower-alternate .lower-alternate-item:nth-of-type(even) {
    flex-direction: row-reverse; }
    .lower-alternate .lower-alternate-item:nth-of-type(even) .lower-alternate-item-body {
      padding-right: 6.09375%; }
    .lower-alternate .lower-alternate-item:nth-of-type(even) .slick-prev {
      right: auto;
      left: 0; }
    .lower-alternate .lower-alternate-item:nth-of-type(even) .slick-next {
      right: auto;
      left: 3.2vw; }
  .lower-alternate .lower-alternate-item:last-of-type {
    margin-bottom: 0; }

.lower-alternate-item {
  display: flex;
  justify-content: space-between;
  margin-bottom: 7.03125vw; }

.lower-alternate-item-head {
  width: 59.25%; }

.lower-alternate-item-body {
  width: 40.75%;
  padding-top: 3.125vw; }
  .lower-alternate-item-body > span {
    color: #fff;
    font-size: 1.015625vw; }

.lower-alternate-item-body-head {
  margin-top: -1.5625vw;
  margin-bottom: 2.8125vw;
  color: #A38D50;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.28em; }

.lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head {
  display: inline-block;
  position: relative;
  margin-top: 2.34375vw;
  margin-bottom: 1.875vw;
  border-bottom: 0.1rem solid #A38D50;
  padding-right: 3.90625vw;
  padding-bottom: 0.9375vw;
  color: #fff;
  line-height: 1;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  cursor: pointer; }
  .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head::before, .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head::after {
    content: '';
    display: block;
    position: absolute;
    top: 24%;
    right: 0.6vw;
    width: 1rem;
    height: 0.1rem;
    margin: auto;
    background-color: #fff;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head::after {
    transform: rotateZ(90deg); }
.lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-text {
  max-height: 0;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  pointer-events: none; }
.lower-alternate-item-body-hasexpand .lower-has-pandbb {
  margin-bottom: 0;
  border-bottom: 0;
  padding-bottom: 0; }
.lower-alternate-item-body-hasexpand.expand .lower-alternate-item-body-hasexpand-head::after {
  transform: rotateX(90deg); }
.lower-alternate-item-body-hasexpand.expand .lower-alternate-item-body-hasexpand-text {
  max-height: 20vw;
  opacity: 1;
  pointer-events: auto; }
.lower-alternate-item-body-hasexpand.expand .lower-has-pandbb {
  margin-bottom: 1.09375vw;
  border-bottom: 0.1rem solid #313131;
  padding-bottom: 0.78125vw; }

.lower-alternate-item-body-text {
  margin-bottom: 0.4vw;
  color: #fff;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }
  .lower-alternate-item-body-text em {
    color: #A38D50;
    font-style: normal; }

.lower-slide .slick-arrow {
  top: auto;
  right: auto;
  bottom: 0;
  left: auto;
  width: 3.125vw;
  height: 3.125vw;
  background-color: #A38D50;
  font-size: 0;
  overflow: hidden; }
  .lower-slide .slick-arrow::before {
    content: '';
    display: block;
    width: 0.46875vw;
    height: 0.703125vw;
    margin: auto;
    background-size: cover; }
.lower-slide .slick-prev {
  right: 3.2vw; }
  .lower-slide .slick-prev:before {
    background-image: url("../imgs/img/slide-arrow-prev.png"); }
.lower-slide .slick-next {
  right: 0; }
  .lower-slide .slick-next:before {
    background-image: url("../imgs/img/slide-arrow-next.png"); }

.lower-midimg {
  margin-bottom: 4.6875vw; }
  .lower-midimg .bt-has-arrow-r {
    margin: 0 auto; }

.lower-midimg-body {
  width: 100%;
  height: 35.9375vw;
  margin-bottom: 3.90625vw; }

.lower-midtexts {
  margin-bottom: 6.71875vw; }
  .lower-midtexts > div {
    width: 78.2%;
    margin: 0 auto; }

.lower-midtexts-head {
  margin-bottom: 4.375vw;
  text-align: center;
  color: #fff;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.24em; }

  .lower-midtexts-head_eng{
    font-family: serif;
    letter-spacing: 0.1em;
  }

.lower-midtexts-text:first-of-type {
  border-top: 0.1rem solid #313131;
  padding-top: 1.09375vw; }

.lower-annotation {
  padding: 3.125vw 0 6.25vw;
  background-image: url("../imgs/img/lower/anno_bg.jpg");
  background-repeat: repeat; }
  .lower-annotation > div {
    width: 84%;
    margin: 0 auto; }

.lower-annotation-head {
  margin-bottom: 3.125vw;
  text-align: center;
  color: #000;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.1em; }

.lower-annotation-body {
  display: flex;
  justify-content: space-between; }

.lower-annotation-body-item {
  width: 47%;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-indetail > div {
  width: 78.2%;
  margin: 0 auto;
  border: 0.1rem solid #A38D50;
  padding: 4.6875vw 7.5vw 6.71875vw; }

.lower-indetail-head {
  margin-bottom: 2.65625vw; }

.lower-indetail-head-main {
  margin-bottom: 2.1875vw;
  text-align: center;
  color: #A38D50;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.24em;
  line-height: 1; }

.lower-indetail-head-text {
  text-align: center;
  color: #fff;
  font-size: 1.171875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-indetail-images {
  display: flex;
  justify-content: space-between;
  margin-bottom: 1.5625vw; }
  .lower-indetail-images img:first-of-type {
    margin-right: 0.078125vw; }
  .lower-indetail-images img:last-of-type {
    margin-left: 0.078125vw; }
  .lower-indetail-images img {
    width: 50%;
    height: 100%; }

.lower-indetail-amount {
  margin-bottom: 2.1875vw; }

.lower-indetail-amount-text {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }
  .lower-indetail-amount-text span {
    font-size: 1.5625vw; }
  .lower-indetail-amount-text em {
    font-size: 2.1875vw;
    font-style: normal; }
  .lower-indetail-amount-text i {
    display: block;
    font-size: 1.171875vw;
    font-style: normal; }

.lower-indetail-body-text-comment {
  color: #fff;
  font-size: 1.015625vw;
  letter-spacing: 0.01em; }

.lower-banner {
  padding: 4.0625vw 0 3.90625vw;
  background-color: #000; }
  .lower-banner .slick-arrow {
    width: 4rem;
    height: 4rem;
    font-size: 0; }
  .lower-banner .slick-prev {
    left: -6rem;
    background-image: url("../imgs/img/slide_arrow_l.png"); }
  .lower-banner .slick-next {
    right: -6rem;
    background-image: url("../imgs/img/slide_arrow_r.png"); }

.lower-banner-slide {
  width: 88.8%;
  margin: 0 auto; }

.lower-banner-slide-item a {
  display: block;
  width: 93.4%;
  margin: 0 auto; }

.lower-links {
  padding: 4.6875vw 0 4.6875vw; }
  .lower-links .bt-has-arrow {
    margin: 0 auto 2.8125vw; }
    .lower-links .bt-has-arrow:last-of-type {
      margin-bottom: 0; }

.lower-haslimg {
  margin-bottom: 4.84375vw; }
  .lower-haslimg .bt-has-arrow-r {
    margin: 3.28125vw auto 0; }

.lower-haslimg-head {
  margin-bottom: 3.90625vw;
  padding-top: 1.40625vw;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.24em;
  color: #fff;
  font-size: 2.34375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-haslimg-body {
  height: 40.625vw; }

.lower-gallery:not(:last-of-type) {
  margin-bottom: 9.0625vw; }

.lower-gallery-head {
  margin-bottom: 5.625vw;
  text-align: center;
  line-height: 1;
  color: #A38D50;
  font-size: 2.8125vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  letter-spacing: 0.24em; }

.lower-gallery-body {
  display: flex;
  flex-wrap: wrap; }

.lower-gallery-body-item {
  width: calc(16.66667% - 1.575vw);
  margin-right: 1.875vw;
  margin-bottom: 1.875vw;
  overflow: hidden; }
  .lower-gallery-body-item:nth-of-type(6n) {
    margin-right: 0; }
  .lower-gallery-body-item img {
    width: 12.5vw;
    height: 9.375vw;
    transition: transform 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .lower-gallery-body-item:hover img {
    transform: scale(1.05); }

.lower-lists-body-item {
  margin-bottom: 3.125vw;
  border-bottom: 0.2rem solid #313131;
  padding-bottom: 3.125vw; }

.cate_test .lower-cate:before {
  content: 'カテゴリ'; }

.info a:hover .lower-lists-body-item-body-detail-href:after {
  right: -1rem; }

.lower-lists-body-item-block {
  display: flex;
  justify-content: space-between; }
  .lower-lists-body-item-block:hover .lower-lists-body-item-head img {
    transform: scale(1.05); }

.lower-lists-body-item-head {
  width: 23.4375vw;
  height: 13.28125vw;
  overflow: hidden; }
  .lower-lists-body-item-head img {
    width: inherit;
    height: inherit;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }

.lower-lists-body-item-body {
  width: calc( 100% - 26.5625vw );
  padding-top: 0.78125vw; }

.lower-info-detail {
  display: flex;
  align-items: center; }

.lower-date {
  display: block;
  margin-right: 0.9375vw;
  color: #A38D50;
  line-height: 1;
  font-style: normal;
  font-size: 1.09375vw;
  font-family: "Hiragino Sans", ヒラギノ角ゴシック, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em; }

.lower-cate {
  display: none;
  justify-content: center;
  align-items: center;
  width: 6.25vw;
  height: 1.40625vw;
  border: 0.1rem solid #fff;
  font-family: "Hiragino Sans", ヒラギノ角ゴシック, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", sans-serif; }
  .lower-cate::before {
    width: 100%;
    top: 0;
    bottom: 0;
    height: 1em;
    margin: auto;
    color: #fff;
    text-align: center;
    font-size: 0.9375vw;
    line-height: 1; }

.lower-lists {
  padding: 6vw 0 0; }

.lower-lists-body-item-body-head {
  display: block;
  margin-bottom: 1.875vw;
  padding-top: 1.09375vw;
  color: #fff;
  font-style: normal;
  font-size: 1.40625vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-lists-body-item-body-detail-href {
  display: flex;
  align-items: center;
  width: 100%;
  line-height: 1;
  color: #A38D50;
  font-size: 1.09375vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }
  .lower-lists-body-item-body-detail-href::after {
    content: '';
    display: block;
    position: relative;
    right: 0;
    width: 1.8em;
    height: 0.6em;
    margin-top: -0.28em;
    background-size: contain;
    background-image: url("../imgs/img/arrow_w.png");
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }

.lower-lists-body-item-body-detail-href span {
  display: block;
  margin-right: 1.5625vw; }

.lower-post > div {
  width: 57.8125vw;
  margin: 0 auto; }

.lower-post-header {
  margin-bottom: 3.125vw;
  color: #A38D50;
  font-size: 2.1875vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200; }

.lower-post-header-head {
  font-size: 2.1875vw;
  font-weight: 200; }

.lower-post-bottom {
  margin-top: -3.90625vw;
  padding-top: 9.375vw; }

.lower-post-bottom-head {
  margin-bottom: 2.34375vw;
  text-align: center;
  color: #fff;
  font-size: 1.25vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  line-height: 1; }

.lower-post-body p {
  color: #fff;
  font-size: 1.25vw;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: 200;
  word-wrap: break-word; }
  .lower-post-body p a {
    color: #fff;
    text-decoration: underline;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .lower-post-body p a:hover {
      text-decoration: none; }
.lower-post-body > * {
  margin-bottom: 3.90625vw; }

.lower-post-bottom-sns {
  display: flex;
  justify-content: space-between;
  width: 22.65625vw;
  margin: 0 auto 5.078125vw; }

.lower-post-bottom-sns-item {
  width: calc(50% - 0.390625vw); }

.lower-post-pager {
  display: flex;
  justify-content: space-between;
  border-top: 0.1rem solid #232323;
  padding-top: 3.515625vw; }

.lower-post-pager-block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%; }

.lower-post-pager-item {
  width: 8vw; }
  .lower-post-pager-item a {
    display: flex;
    align-items: center;
    color: #fff;
    font-size: 1.09375vw; }

.lower-post-pager-item-mid {
  width: 1.4vw; }

.lower-post-pager-item-prev, .lower-post-pager-item-next {
  display: flex;
  align-items: center;
  color: #fff;
  font-size: 1.09375vw; }
  .lower-post-pager-item-prev a::before, .lower-post-pager-item-prev a::after, .lower-post-pager-item-next a::before, .lower-post-pager-item-next a::after {
    display: inline-block;
    width: 0.8rem;
    height: 0.8rem;
    border-top: 0.1rem solid #A38D50; }

.lower-post-pager-item-prev a::before {
  content: '';
  margin-right: 1.2rem;
  border-left: 0.1rem solid #A38D50;
  transform: rotateZ(-45deg); }

.lower-post-pager-item-next a::after {
  content: '';
  margin-left: 1.2rem;
  border-right: 0.1rem solid #A38D50;
  transform: rotateZ(45deg); }

@media all and (max-width: 900px) {
  .lower {
    padding-top: 2rem; } }
@media all and (max-width: 768px) {
  .lower-gallery-body-item {
    width: 31.8%; }
    .lower-gallery-body-item:nth-of-type(3n) {
      margin-right: 0; }

  .lower-gallery-body-item img {
    width: 100%;
    height: 18vw; } }
@media all and (max-width: 750px) {
  .lower {
    padding-top: 0; }

  .lower > section:not(.lower-header):not(.lower-banner) {
    width: 82.6%;
    margin-bottom: 13.3334vw; }

  .lower-slide .slick-arrow {
    width: 8vw;
    height: 8vw; }

  .lower-slide .slick-arrow:before {
    width: 1.6vw;
    height: 1.6vw;
    background-size: contain; }

  .lower-slide .slick-prev {
    right: 8.4vw; }

  .lower-alternate .lower-alternate-item:nth-of-type(odd) .slick-prev {
    right: 8.4vw; }

  .lower-alternate .lower-alternate-item:nth-of-type(2n) .slick-next {
    left: 8.4vw; }

  .lower-header {
    margin-bottom: 25.3334vw; }

  .loaded .lower-header {
    animation: none; }

  .lower-header-head {
    bottom: -10.6667vw;
    width: 77.3334vw;
    height: 21.3334vw;
    font-size: 5.3334vw; }

  .lower-cc-head {
    letter-spacing: 0.18em;
    font-size: 5.3334vw; }

  .lower-cc-text {
    width: 85.334%;
    padding-top: 4.6875vw;
    font-size: 3.7333333333333334vw; }

  .lower-cc-nav {
    justify-content: space-between;
    flex-wrap: wrap;
    height: auto;
    margin-top: 7.03125vw;
    background-color: transparent; }

  .lower-cc-nav-item {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: calc( 50% - 0.15625vw);
    height: 21.334vw;
    margin-bottom: 0.3125vw;
    background-color: #171717;
    line-height: 1.2;
    font-size: 4vw;
    letter-spacing: 0.28em; }

  .lower-cc-nav-item:not(:last-of-type) {
    margin-right: 0 !important; }

  .lower-cc-nav-item:after {
    position: absolute;
    bottom: 3.2vw;
    width: 1.6vw;
    height: 1.6vw;
    border-right: 0.2rem solid #fff;
    border-bottom: 0.2rem solid #fff; }

  .lower-cc-nav-item:hover:after {
    bottom: 2vw; }

  .lower-alternate-item {
    margin-bottom: 25.3334vw; }

  .lower-alternate-item, .lower-alternate .lower-alternate-item:nth-of-type(2n) {
    flex-direction: column; }

  .lower-alternate-item-head {
    width: 100%; }

  .lower-alternate-item-body {
    width: 100%;
    padding-top: 8vw; }
    .lower-alternate-item-body > span {
      font-size: 3.0333333333333334vw; }

  .lower-alternate .lower-alternate-item:nth-of-type(odd) .lower-alternate-item-body {
    padding-right: 5.6vw;
    padding-left: 5.6vw; }

  .lower-alternate .lower-alternate-item:nth-of-type(2n) .lower-alternate-item-body {
    padding-right: 5.6vw;
    padding-left: 5.6vw; }

  .lower-alternate-item-body-head {
    line-height: 1.6;
    font-size: 8vw; }

  .lower-alternate-item-body-text {
    font-size: 3.7333333333333334vw; }

  .lower-alternate-item-body > *:not(:last-child):not(.lower-alternate-item-body-head) {
    margin-bottom: 8.533334vw; }

  .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head {
    padding-right: 10.6667vw;
    padding-bottom: 3.2vw;
    font-size: 3.7333333333333334vw; }

  .lower-alternate-item-body-hasexpand.expand .lower-alternate-item-body-hasexpand-text {
    max-height: 400px; }

  .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head:after, .lower-alternate-item-body-hasexpand .lower-alternate-item-body-hasexpand-head:before {
    top: 36%;
    width: 2.6667vw;
    height: 0.1rem; }

  .lower-annotation {
    padding: 8.533334vw 0 17.0666667vw; }

  .lower-annotation-head {
    margin-bottom: 6.666667vw;
    font-size: 5.333333333333333vw; }

  .lower-annotation-body {
    flex-direction: column; }

  .lower-annotation-body-item {
    width: 100%; }

  .lower-annotation-body-item:first-of-type {
    margin-bottom: 4.8vw;
    font-size: 3.7333333333333334vw; }

  .lower-split-block {
    flex-direction: column; }

  .lower-split-item {
    width: 100%;
    margin-right: 0;
    margin-bottom: 8vw; }

  .lower-split-item-block-head {
    margin-bottom: 4vw; }

  .lower-split-item-block-body-head {
    margin-bottom: 2.666667vw;
    font-size: 4.4vw; }

  .lower-split-item-block-body-text {
    font-size: 3.7333333333333334vw; }

  .lower-midtexts > div {
    width: 100%; }

  .lower-midtexts-head {
    font-size: 5.3334vw; }

  .lower-indetail > div {
    width: 100%;
    padding: 8.7875vw 7.5vw 10.71875vw; }

  .lower-indetail-head {
    margin-bottom: 6vw; }

  .lower-indetail-head-main {
    margin-bottom: 6.375vw;
    font-size: 5.3334vw; }

  .lower-indetail-head-text {
    text-align: left;
    font-size: 3.7333333333333334vw; }

  .lower-indetail-images {
    flex-direction: column;
    margin-bottom: 6vw; }

  .lower-indetail-images img {
    width: 100%; }

  .lower-indetail-images img:first-of-type {
    margin-right: 0;
    margin-bottom: 2vw; }

  .lower-indetail-images img:last-of-type {
    margin-right: 0; }

  .lower-indetail-amount-text span {
    font-size: 3.7333333333333334vw; }

  .lower-indetail-amount-text i {
    font-size: 3.0333333333333334vw; }

  .lower-indetail-amount-text em {
    font-size: 3.7333333333333334vw; }

  .lower-indetail-body-text-comment {
    font-size: 2.78vw; }

  .lower-indetail-body-text-comment {
    margin-top: 4vw; }

  .spa .lower-links .bt-has-arrow-r {
    width: 90%;
    height: auto; }
    .spa .lower-links .bt-has-arrow-r span {
      font-size: 3.3333333333333334vw; }

  .cuisine .lower-links .bt-has-arrow:first-of-type, .cuisine .lower-links .bt-has-arrow:last-of-type {
    width: auto; }

  .lower-haslimg .bt-has-arrow-r {
    margin-top: 6.5625vw; }

  .lower-links {
    width: 90%;
    height: auto; }
    .lower-links .bt-has-arrow {
      width: auto;
      margin: 0 auto 5.625vw; }
      .lower-links .bt-has-arrow > span {
        font-size: 3.3333333333333334vw; }
        .lower-links .bt-has-arrow > span::after {
          width: 2em;
          height: 0.4em;
          background-size: contain; }

  .lower-midimg-body {
    margin-bottom: 6vw; }

  .lower-banner {
    padding-top: 12vw; }

  .lower-banner > div {
    width: 88%;
    margin: 0 auto; }

  .lower-haslimg-head {
    font-size: 5.334vw; }

  .lower-gallery {
    margin-bottom: 15.3334vw; }

  .lower-gallery-head {
    margin-bottom: 9.33334vw;
    font-size: 5.3334vw; }

  .lower-gallery-body {
    grid-template-columns: 1fr 1fr; }

  .lower-gallery-body-item img {
    width: 100%;
    height: 26vw; }

  .lower-lists-body-item {
    margin-bottom: 6.25vw;
    padding-bottom: 6.25vw; }

  .lower-lists-body-item-block {
    flex-direction: column; }

  .lower-lists-body-item-head {
    width: 100%;
    height: auto;
    overflow: hidden; }

  .lower-lists-body-item-body {
    width: 100%;
    padding-top: 3.3333333333333334vw; }

  .lower-lists-body-item-body-head {
    margin-bottom: 4.8vw;
    padding-top: 3.3333333333333334vw;
    font-size: 3.3333333333333334vw; }

  .lower-lists-body-item-body-detail-href {
    font-size: 3.3333333333333334vw; }

  .lower-date {
    margin-top: 0.1em;
    margin-right: 2.4vw;
    font-size: 3.3333333333333334vw; }

  .lower-cate {
    width: 20vw;
    height: 1.8em; }

  .lower-cate:before {
    font-size: 2.4vw; }

  .lower-post > div {
    width: 77.3334vw; }

  .lower-post-header {
    margin-bottom: 7.733334vw; }

  .lower-post-header-head {
    font-size: 5.3334vw; }

  .post .lower-date {
    margin-right: 3vw; }

  .post .lower-cate {
    width: 10em;
    height: 1.8em; }

  .post .lower-info-detail {
    margin-bottom: 5.333334vw; }

  .lower-post-body > * {
    margin-bottom: 2em; }

  .lower-post-body p {
    font-size: 3.3333333333333334vw; }

  .lower-post-bottom-head {
    margin-bottom: 1.6em;
    font-size: 3.3333333333333334vw; }

  .lower-post-bottom-sns {
    width: 70%;
    margin-bottom: 1.8em;
    font-size: 3.3333333333333334vw; }

  .lower-post-pager {
    padding-top: 2em; }

  .lower-post-pager-item-mid {
    width: 1.4em;
    height: 1.4em; }

  .lower-post-pager-item-prev, .lower-post-pager-item-next {
    width: 8rem; }

  .lower-post-pager-item a {
    font-size: 3.3333333333333334vw; }

  .access iframe {
    height: 30rem; }

  .info .wp-pagenavi > * {
    width: 5rem;
    height: 5rem;
    font-size: 1.6rem; }

  .lower-alternate-item-body-text.ic-pdf {
    margin-top: -4rem;
    margin-bottom: 6rem; }

  .lower-gallery-body-item {
    width: calc(50% - 0.9375vw); }
    .lower-gallery-body-item:nth-of-type(3n) {
      margin-right: 1.875vw; }
    .lower-gallery-body-item*:nth-of-type(6n) {
      margin-right: 1.875vw; }
    .lower-gallery-body-item:nth-of-type(2n) {
      margin-right: 0; } }


/*1910*/
.bus_information {
width: 760px !important;
padding: 50px 80px;
margin: 0 auto 10rem;
color: #fff;
border: #A68C4A solid 1px;
font-size: 150%;
}
.bus_information dl dt {
padding-bottom: 0.5em;
}
.bus_information dl dt:before {
content: "● ";
color: #A68C4A;
}
.bus_information dl dd {
padding: 0 0 2em 1em;
}
.bus_information dl dd.fontl {
font-size: 140%;
}
.bus_information i {
font-style: normal;
}
.wrapsky {
width: 62% !important;
padding: 50px 100px;
margin: 0 auto 10rem;
color: #fff;
border: #A68C4A solid 1px;
font-size: 150%;
font-family: "Yu Mincho", "YuMincho", serif;
}
.wrapsky span.skyimg {
padding: 5% 0;
display: block;
}
.wrapsky p.pdf a {
padding: 5%;
text-decoration: underline;
color: #fff;
padding: 2% 7%;
background: url(../imgs/img/lower/cc-sky/ic-pdf.png) no-repeat left center;
display: block;
}
.wrapsky p.pdf a:hover {
text-decoration: none;
}
.wrapsky .planA, .wrapsky .planB {
width: 100%;
margin: 0 auto 1.75em;
border-bottom: #313131 solid 1px;
padding-bottom: 1.75em;
}
.wrapsky .planA h4, .wrapsky .planB h4 {
color: #a78d45;
margin-bottom: 1.75em;
font-size: 130%;
}
.wrapsky .planA dl {
overflow: hidden;
margin-bottom: 1.75em;
font-size: 130%;
}
.wrapsky .planA dl dt {
float: left;
}
.wrapsky .planA dl dd {
font-size: 140%;
display: inline-block;
float: right;
}
.wrapsky .planB dl {
overflow: hidden;
margin-bottom: 1.75em;
}
.wrapsky .planB dl dt {
width: 40%;
float: left;
}
.wrapsky .planB dl dd {
width: 58%;
display: inline-block;
float: right;
font-size: 130%;
}

@media screen and (max-width: 750px) {
.bus_information {
width: 90% !important;
padding: 5%;
}
.wrapsky {
width: 90% !important;
padding: 5%;
font-size: 100%;
}
.wrapsky h1 {
font-size: 150%;
}
.wrapsky p.pdf a {
background-size: 8%;
padding: 2% 12%;
}
}
p span.btext {
font-size: 120%;
}
.lower-post-body img {
width: auto;
}

/*2024追記*/
.cycle-info {
  padding: 50px 80px;
  margin: 0 auto 10rem;
  color: #fff;
  font-size: 150%;
  }
  .cycle-info dl dt {
  padding-bottom: 0.5em;
  }
  .cycle-info dl dt:before {
  content: "● ";
  color: #A68C4A;
  }
  .cycle-info dl dd {
  padding: 0 0 2em 1em;
  }
  .cycle-info dl dd.fontl {
  font-size: 140%;
  }
  .cycle-info i {
  font-style: normal;
  }

  .cycle-price span{
    width:7.2em;
    display:inline-block;
  }

  .cycle-price_eng span{
    width:10em;
    display:inline-block;
  }

  .cycle-subtext{
    padding:1.5em 0;
    border-top:solid 1px #737373;
    display:block;
  }

  .cycle-img{
    display:flex;
    width:100%;
    flex-wrap: wrap;
  }

  .cycle-img img{
    width:50%;
  }

  br.sp-only{
    display: none;
  }

  .lower-header-head_multi{
    line-height: 1.5em;
  }

  .lower-cc-text_junbi{
    text-align: center;
    font-size:1.4vw;
  }

  @media screen and (max-width:750px){
    .cycle-img img{
      width:100%;
    }

    .cycle-img img:nth-child(1){
      margin-bottom: 15px;
    }

    .cycle-info {
      width: 90% !important;
      padding: 5%;
      }

      br.sp-only{
        display: block;
      }

      .lower-cc-text_junbi{
        font-size:3.373333vw;
      }
  }

  .banner-cc{
    padding-bottom: 60px;
  }

  .top-banner > div.banner-cc_double {
    width: 56.2%;
    max-width: 72rem !important;
  }

  .banner-cc ul{
    width:100%;
    display:flex;
    /*justify-content: space-between;*/
    justify-content: center;
  }

  .banner-cc__item{
    width:30%;
    border:solid 1px #fff;
    padding:28.2% 12px 24px 12px;
    position:relative;
  }

  .banner-cc_double .banner-cc__item{
    width:46%;
  }


  .banner-cc__item:nth-child(1){
    background-image: url('../imgs/img/top/img-cc.jpg');
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top;
  }

  .banner-cc__item:nth-child(2){
    background-image: url('../imgs/img/top/img-cycle.jpg');
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top;
  }

  .banner-cc__item:nth-child(3){
    background-image: url('../imgs/img/top/img-retreat.jpg');
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top;
  }

  .banner-gradient{
    width:100%;
    padding-top:71.5%;
    position:absolute;
    z-index:1;
    top:0;
    left:0;
    background: linear-gradient(to top,#000 0%,rgba(0,0,0,0) 40%);
  }

  .banner-button{
    width:100%;
    position:relative;
    z-index:2;
    margin-bottom: 16px;
    display:block;
  }

  .banner-button:last-child{
    margin-bottom: 0;
  }

  @media screen and (max-width:768px){
    .top-banner > div.banner-cc_double {
      width: 91.5%;
    }
    .banner-cc_double .banner-cc__item{
      width:100%;
    }
    .banner-cc ul{
      display: block;
    }
    .banner-cc__item{
      width:100%;
      padding:62.5% 12px 24px 12px;
      margin-bottom: 40px;
    }
    .banner-cc__item:last-child{
      margin-bottom: 0;
    }
  }

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

  .banner-block{
    display:flex;
    justify-content: space-between;
    max-width:720px!important;
    margin:auto;
  }

  .banner-block__item li{
    width:100%;
  }

  .banner-block__item li a{
    width:100%;
  }

  .banner-block__item1{
    width:45.6%;
  }

  .banner-block__item2{
    width:51.38%;
    display:flex;
    flex-direction: column;
    justify-content: space-between;
  }

  .banner-wide{
    width:100%;
    max-width:720px!important;
    margin:auto;
    padding-top:20px;
  }

  .banner-wide li{
    width:100%;
  }

  @media screen and (max-width:768px){
    .banner-block{
      display: block;
    }
    .banner-block__item1{
      width:100%;
      margin-bottom: 16px;
    }
    .banner-block__item2{
      width: 100%;
      display:block;
    }
    .banner-block__item2 li{
      margin-bottom: 16px;
    }
    .banner-wide{
      padding-top: 0;
      margin-bottom: 16px;
    }
  }


  .top-info-banner-slide-item.modal-trigger img{
    display: block;
  width: 93.75%;
  margin: 0 auto;
  cursor:pointer;
  }

  .modal-content{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
    z-index:900;
    display:none;
  }

  .modal-content__background{
    background-color: rgba(0,0,0,0.75);
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    z-index:2;
  }

  .modal-content.show{
    display:block;
  }

  .modal-close{
    width:32px;
    height:32px;
    border-radius:50%;
    background-color:rgba(255,255,255,0.2);
    position:absolute;
    top:16px;
    right:24px;
    cursor: pointer;
  }

  .modal-close img{
    width:40%;
    display:block;
    margin:auto;
    margin-top: 30%;
  }

  .modal-inner__wrapper{
    position:absolute;
    top:50%;
    left:50%;
    width:1280px;
    max-width:calc(100vw - 160px)!important;
    height:auto;
    max-height:calc(100vh - 400px);
    border:solid 1px #fff;
    transform: translate(-50%,-50%);
    z-index:3;
    overflow: hidden;

  }

  .modal-inner{
    height:100%;
    max-height:calc(100vh - 400px);
    width:100%;
    padding:60px 40px;
    background-color: #000;
    color:#fff;    
    font-family: "Yu Mincho", "YuMincho", serif;    
    overflow-y:scroll;
  }
  .modal-head{
    color: #A38D50;
    font-size: 30px;
    margin-bottom: 30px;
    display:block;
  }

  .modal-inner p{
    font-size: 20px;
    line-height:2em;
    margin-bottom: 2em;
  }

  .modal-inner p.date{
    line-height:4em;
  }

  .modal-inner a{
    color: #fff;
    text-decoration: underline;
    transition: all 0.28s cubic-bezier(0.215, 0.61, 0.355, 1);
    display:block;
    width:fit-content;
    margin-bottom: 2em;
  }

  .modal-inner a:hover{
    text-decoration: none;
  }

  @media screen and (max-width:768px){
    .modal-close{
      width:26px;
      height:26px;
      top:16px;
      right:16px;
    }

    .modal-inner__wrapper{
      max-width:100%!important;
      width:91.5%;
      max-height:calc(100vh - 280px);
    }

    .modal-inner{
      max-height:calc(100vh - 280px);
      padding:40px 20px;
    }

    .modal-head{
      font-size: 5.3334vw;
    }

    .modal-inner p{
      font-size: 3.3333333333333334vw;
    }
  }