@charset "UTF-8";
/* ===================================================================
CSS information

file name  : first_load.css
author     : Abilive
style info : 最初に読むCSS
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
/* ===================================================================
CSS information

file name  : default.css
author     : Abilive
style info : 汎用リセット記述
=================================================================== */
html,
article,
aside,
audio,
blockquote,
body,
dd,
dialog,
div,
dl,
dt,
fieldset,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
input,
li,
mark,
menu,
nav,
ol,
p,
pre,
section,
td,
textarea,
th,
time,
ul,
video,
main {
  margin: 0;
  padding: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

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

caption,
th {
  text-align: left;
}

q:after,
q:before {
  content: "";
}

embed,
object {
  vertical-align: top;
}

legend {
  padding-left: 0;
  padding-right: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
}

abbr,
acronym,
fieldset,
img {
  border: 0;
}

li {
  list-style-type: none;
}

sup {
  vertical-align: super;
  font-size: 0.5em;
}

img {
  vertical-align: top;
}

i {
  font-style: normal;
}

svg {
  vertical-align: middle;
}

article,
aside,
dialog,
figure,
footer,
header,
hgroup,
nav,
section,
main {
  display: block;
}

nav,
ul {
  list-style: none;
}

/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.l-header {
  position: relative;
  flex-wrap: wrap;
  display: flex;
  --logo-width: calc(180 / 1440 * 100%);
  --image-width: calc(1260 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .l-header {
    --logo-width: 100%;
  }
}
.l-header .l-header__box {
  display: flex;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__box {
    z-index: 1;
    position: relative;
    width: var(--logo-width);
  }
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__box > .inner {
    display: flex;
    flex-direction: column;
    width: calc(87 / var(--akekure-parent-font-size) * 1rem);
    margin-top: calc(45 / var(--akekure-parent-font-size) * 1rem);
  }
}
.l-header .l-header__kv {
  position: relative;
  width: 100%;
}
.l-header .l-header__kv::before, .l-header .l-header__kv::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  z-index: 2;
}
.l-header .l-header__kv::before {
  top: 0;
  height: calc(var(--vh) * 100 * 176 / 750);
  background: linear-gradient(180deg, #120E0D 0%, rgba(18, 14, 13, 0) 100%);
}
.l-header .l-header__kv::after {
  bottom: 0;
  height: calc(130 / var(--akekure-parent-font-size) * 1rem);
  background: linear-gradient(180deg, rgba(18, 14, 13, 0) 0%, #120E0D 64.96%);
}
.l-header .l-header__kv__box-text {
  z-index: 3;
  position: absolute;
  top: calc(80 / 750 * 100%);
  bottom: calc(100 / 750 * 100%);
  margin-right: auto;
  margin-left: auto;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__box-text {
    top: calc(var(--gnav-height) + calc(80 / var(--akekure-parent-font-size) * 1rem));
    left: 0;
    right: 0;
    transform: none;
    bottom: 0;
  }
}
.l-header .l-header__kv__catch {
  writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -webkit-text-orientation: upright;
  -moz-text-orientation: upright;
  -ms-text-orientation: upright;
  text-orientation: upright;
  text-align: left;
  display: inline-block;
  font-size: calc(var(--akekure-target-font-size) / var(--akekure-parent-font-size) * 1rem);
  text-shadow: calc(2 / var(--akekure-parent-font-size) * 1rem) calc(2 / var(--akekure-parent-font-size) * 1rem) calc(20 / var(--akekure-parent-font-size) * 1rem) #000000;
  width: fit-content;
  margin-right: auto;
  margin-left: auto;
  display: block;
  letter-spacing: .15em;
  height: calc(245 / var(--akekure-parent-font-size) * 1rem);
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__kv__catch {
    --akekure-target-font-size: 22;
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch {
    --akekure-target-font-size: 20;
  }
}
.l-header .l-header__kv__logo {
  width: calc(243 / var(--akekure-parent-font-size) * 1rem);
  margin-right: auto;
  margin-left: auto;
}
.l-header .l-header__kv__time {
  font-family: var(--akekure-font-num);
  letter-spacing: .1em;
  color: #F2D6A4;
  margin-top: calc(30 / var(--akekure-parent-font-size) * 1rem);
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}
.l-header .l-header__kv__btn {
  margin-top: calc(50 / var(--akekure-parent-font-size) * 1rem);
  margin-right: auto;
  margin-left: auto;
}
.l-header .l-header__kv__btn .c-btn__link {
  width: calc(220 / var(--akekure-parent-font-size) * 1rem);
}
.l-header .l-header__kv .c-slider__dots_pause {
  margin-bottom: 0;
  margin-top: auto;
  display: flex;
  align-items: center;
}
.l-header .l-header__kv .c-slider__dots_pause .c-slider__pagination {
  padding-top: 0;
}
.l-header .l-header__kv__image {
  height: 100%;
  width: 100%;
}
.l-header .l-header__kv__slider {
  height: calc(var(--vh) * 100 - var(--gnav-height));
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__slider {
    height: calc(var(--vh) * 100);
  }
}
.l-header .l-header__kv__slider .c-slider__wrapper {
  height: 100%;
}
.l-header .l-header__kv__slider .c-slider__slide {
  height: 100%;
  width: 100%;
}
.l-header .l-header__kv__slider .c-slider__slide picture {
  display: block;
  width: 100%;
  height: 100%;
}
.l-header .l-header__kv__slider .c-slider__slide picture img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.o-gnav {
  z-index: 3;
  width: 100%;
  height: var(--gnav-height);
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .o-gnav--normal {
    --akekure-body-bg: none !important;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
  }
  .o-gnav--normal::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    height: calc(175 / var(--akekure-parent-font-size) * 1rem);
    background: linear-gradient(180deg, #120E0D 0%, rgba(18, 14, 13, 0) 100%);
  }
}
.o-gnav > .inner {
  width: calc(var(--akekure-content-1) / var(--akekure-content-0) * 100%);
  margin-right: auto;
  margin-left: auto;
  display: flex;
  align-items: center;
  align-content: center;
}
@media only screen and (max-width: 767px) {
  .o-gnav > .inner {
    z-index: 3;
    position: relative;
  }
}
.o-gnav__logo {
  margin-right: auto;
  margin-left: 0;
  width: calc(85 / var(--akekure-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .o-gnav__logo {
    width: calc(95 / var(--akekure-parent-font-size) * 1rem);
  }
}
.o-gnav__logo a {
  display: block;
}
.o-gnav__logo img {
  height: auto;
}
.o-gnav__sns {
  margin-left: auto;
  margin-right: 0;
  display: flex;
  justify-content: center;
}
.o-gnav__sns__list {
  display: flex;
  align-items: center;
}
.o-gnav__sns__link {
  padding: calc(7.5 / var(--akekure-parent-font-size) * 1rem);
  display: flex;
  align-items: center;
}
.o-gnav__sns .o-icon--line {
  --akekure-icon-width: calc(13.44 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__sns .o-icon--x {
  --akekure-icon-width: calc(10.35 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__sns .o-icon--instagram {
  --akekure-icon-width: calc(12.8 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__sns .o-icon--facebook {
  --akekure-icon-width: calc(12.8 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__sns .o-icon--youtube {
  --akekure-icon-width: calc(13.44 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__sns .o-icon--tripadvisor {
  --akekure-icon-width: calc(14.72 / var(--akekure-parent-font-size) * 1rem);
}
.o-gnav__language {
  width: calc(50 / var(--akekure-parent-font-size) * 1rem);
  font-family: var(--akekure-font-en);
  margin-right: calc(25 / var(--akekure-parent-font-size) * 1rem);
  margin-left: calc(25 / var(--akekure-parent-font-size) * 1rem);
  position: relative;
}
@media only screen and (max-width: 767px) {
  .o-gnav__language {
    margin-right: 0;
    margin-left: auto;
  }
}
.o-gnav__language__button {
  height: var(--gnav-height);
  display: flex;
  align-items: center;
  align-content: center;
  text-align: center;
  flex-wrap: wrap;
  margin-right: auto;
  margin-left: auto;
  justify-content: center;
}
.o-gnav__language__button__text {
  width: 100%;
  margin-top: calc(12 / var(--akekure-parent-font-size) * 1rem);
  line-height: 1;
  display: block;
  text-align: center;
}
.o-gnav__language__box {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.5s, height 0.5s;
  visibility: hidden;
  background-color: #fff;
  position: absolute;
  left: -2em;
  right: -2em;
  top: calc(100%);
  text-align: center;
  padding: .5em .5em;
}
.o-gnav__menu {
  font-family: var(--akekure-font-en);
  display: flex;
  align-items: center;
  width: calc(50 / var(--akekure-parent-font-size) * 1rem);
  flex-direction: column;
  margin-right: calc(25 / var(--akekure-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .o-gnav__menu {
    order: 9;
    width: calc(92 / var(--akekure-parent-font-size) * 1rem);
    margin-right: 0;
    margin-left: 0;
    padding-right: calc(25 / var(--akekure-parent-font-size) * 1rem);
    padding-left: calc(25 / var(--akekure-parent-font-size) * 1rem);
    margin-right: calc(-25 / var(--akekure-parent-font-size) * 1rem);
  }
}
.o-gnav__menu__text {
  margin-top: calc(12 / var(--akekure-parent-font-size) * 1rem);
  line-height: 1;
  display: block;
  text-align: center;
}
.o-gnav__btn {
  margin-right: 0;
}
.o-gnav__btn .c-btn__link {
  width: calc(160 / var(--akekure-parent-font-size) * 1rem);
  min-width: auto;
  min-height: calc(35 / var(--akekure-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .o-gnav__btn .c-btn__link {
    min-height: calc(50 / var(--akekure-parent-font-size) * 1rem);
  }
}
.o-gnav--sticky {
  --gnav-height: calc(60 / var(--akekure-parent-font-size) * 1rem);
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  opacity: 0;
  z-index: 999;
  transition-property: transform, opacity;
  transition-duration: .15s;
  transition-timing-function: ease-out;
}
@media only screen and (min-width: 768px) {
  .o-gnav--sticky {
    transform: translateY(-100%);
  }
}
@media only screen and (max-width: 767px) {
  .o-gnav--sticky {
    transform: translateY(100%);
    --gnav-height: calc(70 / var(--akekure-parent-font-size) * 1rem);
    top: auto;
    bottom: 0;
  }
}
.is-parts-sticky .o-gnav--sticky {
  transform: translateY(0);
  opacity: 1;
}
.o-gnav--menu {
  --gnav-height: calc(60 / var(--akekure-parent-font-size) * 1rem);
}

:root {
  --akekure-content-0: 1440;
  --akekure-content-1: 1360;
  --akekure-content-2: 1260;
  --akekure-content-3: 1100;
  --akekure-root-font-size: 12;
  --akekure-parent-font-size: 12;
  --akekure-target-font-size: 12;
  --akekure-color-cv: #8F7A53;
  --akekure-color-cv2: gold;
  --akekure-color-accent: #7D663B;
  --akekure-color-accent2: #D0BA90;
  --akekure-color-primary: skyblue;
  --akekure-color-alert: #A91A1A;
  --akekure-color-gray-c: #cccccc;
  --akekure-color-gray-ca: #cacaca;
  --akekure-color-gray-8: #888888;
  --akekure-color-gray-5: #555555;
  --akekure-color-gray-7: #777777;
  --akekure-color-gray-e7: #E7E7E7;
  --akekure-color-gray-2f: #2f2f2f;
  --akekure-color-gray-f2: #f2f2f2;
  --akekure-color-gray-43: #434343;
  --akekure-color-bg-dark: #120E0D;
  --akekure-color-bg-light: #F2F2F1;
  --akekure-font-jp-serif: Shippori Mincho, 游明朝, Yu Mincho, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HGS明朝E, ＭＳ Ｐ明朝, MS PMincho, Times New Roman, Times, Garamond, Georgia, serif;
  --akekure-font-jp-sans-serif: Noto Sans JP, ヒラギノ角ゴ Pro, Hiragino Kaku Gothic Pro, 游ゴシック体, Yu Gothic, YuGothic, MS Ｐゴシック, MS PGothic, Lucida Sans Unicode, Lucida Grande, Verdana, Arial, sans-serif;
  --akekure-font-en: Nanum Myeongjo, serif;
  --akekure-font-num: var(--akekure-font-en);
  --akekure-body-color: #4a4a4a;
  --akekure-body-bg: #fff;
  --akekure-body-font: var(--akekure-font-jp-serif);
  --akekure-icon-width: 1em;
  --akekure-color-title: #1b1b1b;
  --akekure-color-catch: #1b1b1b;
  --akekure-color-acc1: var(--akekure-color-accent);
  --akekure-color-acc2: var(--akekure-color-accent2);
  --akekure-color-sub1: var(--akekure-color-gray-7);
  --akekure-color-sub2: var(--akekure-color-gray-c);
  --focus-outline: 3px black solid;
  --gnav-height: calc(80 / var(--akekure-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  :root {
    --akekure-content-0: 428;
    --akekure-content-1: 376;
    --akekure-content-2: 320;
    --akekure-content-3: 280;
  }
}
@media only screen and (min-width: 1441px) {
  :root {
    --akekure-base-font-size: 15;
  }
}
@media only screen and (min-width: 1441px) and (max-width: 1600px) {
  :root {
    --akekure-base-font-size: 13.5;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1440px) {
  :root {
    --akekure-base-font-size: 12;
  }
}
@media only screen and (min-width: 897px) and (max-width: 1024px) {
  :root {
    --akekure-base-font-size: 12;
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  :root {
    --akekure-base-font-size: 11;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --akekure-parent-font-size: 15;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --gnav-height: calc(70 / var(--akekure-parent-font-size) * 1rem);
  }
}

[data-akekure-theme="light"] {
  --akekure-body-bg: var(--akekure-color-bg-light);
  color: var(--akekure-body-color);
  fill: var(--akekure-body-color);
}

[data-akekure-theme="light-gray"] {
  --akekure-body-bg: black;
  background: var(--akekure-body-bg);
  color: #fff;
  fill: #fff;
}

[data-akekure-theme="dark"] {
  --akekure-body-bg: var(--akekure-color-bg-dark);
  background: var(--akekure-body-bg);
  color: #fff;
  fill: #fff;
}

html {
  font-size: calc(var(--akekure-base-font-size) / 16 * 100%);
}
@media only screen and (min-width: 768px) {
  html {
    line-height: 2;
  }
}
@media only screen and (max-width: 767px) {
  html {
    line-height: 2;
  }
}

body {
  color: var(--akekure-body-color);
  fill: var(--akekure-body-color);
  -webkit-text-size-adjust: none;
  background: var(--akekure-body-bg);
  width: 100%;
}
body a {
  color: inherit;
  fill: inherit;
  text-decoration: underline;
}
body a:hover {
  text-decoration: none;
}
body img {
  max-width: 100%;
  -webkit-touch-callout: none;
  line-height: 1;
}
.lower body {
  overflow-x: hidden;
}
body.is-bodylock {
  overflow: hidden;
}

body,
pre,
input,
textarea,
select {
  font-family: var(--akekure-body-font);
}

input,
select,
textarea {
  font-size: 100%;
}

* {
  box-sizing: border-box;
}

#abi_page {
  max-width: 2560px;
  margin-right: auto;
  margin-left: auto;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  #homepage #abi_page {
    overflow: hidden;
  }
}
.lower #abi_page {
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  #abi_page {
    font-size: 100% !important;
  }
}

svg:not([width][height]) {
  width: 1rem;
}

img {
  width: 100%;
  height: auto;
}

button {
  background: none;
  border: none;
  border-radius: 0;
  appearance: none;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
  color: inherit;
  line-height: inherit;
  cursor: pointer;
  text-align: left;
}

#svg_defs,
#svg_defs1,
#svg_defs2,
#svg_defs3,
#svg_defs4 {
  display: none;
}

.jump_menu {
  display: none;
}

.js-swiper-wrp [class*=" js-swiper-"]:not(.swiper-initialized) .swiper-wrapper .swiper-slide:not(:first-child), .js-swiper-wrp [class^="js-swiper-"]:not(.swiper-initialized) .swiper-wrapper .swiper-slide:not(:first-child) {
  display: none;
}

.js-accordion + [data-accordion-target],
.accordion_p + [data-accordion-target] {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.5s, height 0.5s;
  visibility: hidden;
}

[data-accordion-target]:has(+ .js-accordion) {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.5s, height 0.5s;
  visibility: hidden;
}

#tripla-cookie-consent .style-wrapper-99c7fa {
  z-index: 999999999999999 !important;
}
