@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:not(:hidden),
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;
  border-bottom: 1px solid var(--abi-color-black);
}

.p-home-kv {
  width: calc(100% - var(--abi-gnav-width));
  height: calc(var(--vh) * 100);
  position: relative;
}
@media only screen and (min-width: 1025px) {
  .p-home-kv {
    order: -1;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-kv {
    height: auto;
  }
}
@media only screen and (max-width: 1024px) {
  .p-home-kv {
    width: 100%;
    overflow: hidden;
  }
}
.p-home-kv__play {
  position: absolute;
  left: 50%;
  top: calc((100% - var(--abi-kv-catch-height)) / 2);
  width: 10rem;
  aspect-ratio: 1;
  align-items: center;
  align-content: center;
  transform: translate(-50%, -50%);
}
.p-home-kv__figure {
  width: 100%;
  height: calc(100% - var(--abi-kv-catch-height));
  overflow: hidden;
  border-bottom-right-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
  border-left: 1px solid var(--abi-color-black);
  border-right: 1px solid var(--abi-color-black);
  border-bottom: 1px solid var(--abi-color-black);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-kv__figure {
    height: auto;
    aspect-ratio: 768/432;
    width: calc(100% + 2px);
    margin-left: -1px;
    margin-right: -1px;
    border-bottom-left-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
  }
}
.p-home-kv__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-home-kv__box-catch {
  display: flex;
  position: relative;
  z-index: 1;
  height: var(--abi-kv-catch-height);
  --gose-width: 320;
}
@media only screen and (max-width: 1024px) {
  .p-home-kv__box-catch {
    width: calc(400 / 428 * 100%);
    margin-right: auto;
    margin-left: auto;
  }
}
@media only screen and (max-width: 1024px) {
  .p-home-kv__box-catch {
    --gose-width: 120;
  }
}
.p-home-kv__box-catch-gose {
  width: calc(351 / var(--abi-parent-font-size) * 1rem);
  height: 100%;
  display: flex;
  align-items: flex-end;
  margin-left: calc(40 / var(--abi-parent-font-size) * 1rem);
  padding-bottom: calc(25 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 1024px) {
  .p-home-kv__box-catch-gose {
    width: calc(var(--gose-width) / var(--abi-parent-font-size) * 1rem);
    margin-left: auto;
  }
}
.p-home-kv__box-catch-gose .go {
  width: calc(151 / var(--gose-width) * 100%);
}
.p-home-kv__box-catch-gose .se {
  width: calc(153 / var(--gose-width) * 100%);
  margin-right: 0;
  margin-left: auto;
}
.p-home-kv__box-catch-gose .inner {
  display: flex;
  width: 100%;
}
@media only screen and (max-width: 1024px) {
  .p-home-kv__box-catch-gose .inner {
    flex-direction: column;
  }
}
.p-home-kv__box-catch-text {
  font-family: var(--abi-font-jp-serif-special);
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 24;
  display: flex;
  font-weight: 400;
  line-height: 1.4;
  height: 100%;
  width: calc(100% - var(--gose-width));
  align-items: center;
}
@media only screen and (max-width: 1024px) {
  .p-home-kv__box-catch-text {
    font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
    --abi-target-font-size: 18;
    order: -1;
  }
}
.p-home-kv__image {
  height: calc(100% - var(--abi-kv-catch-height));
  overflow: hidden;
  border-left: 1px solid var(--abi-color-black);
  border-right: 1px solid var(--abi-color-black);
  border-bottom: 1px solid var(--abi-color-black);
  border-bottom-right-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
  border-bottom-left-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
  width: calc(100% + 2px);
  margin-left: -1px;
  margin-right: -1px;
}
.p-home-kv__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.o-gnav {
  width: var(--abi-gnav-width);
  height: calc(var(--vh) * 100 - var(--abi-kv-catch-height));
}
@media only screen and (min-width: 1025px) {
  .o-gnav {
    padding-top: calc(30 / var(--abi-parent-font-size) * 1rem);
    display: flex;
    flex-direction: column;
  }
}
@media only screen and (max-width: 1024px) {
  .o-gnav {
    width: 100%;
    height: 0;
    overflow: visible;
    z-index: 1;
    position: relative;
    display: flex;
  }
}
.o-gnav__logo {
  width: 100%;
  margin-bottom: 0;
}
@media only screen and (max-width: 1024px) {
  .o-gnav__logo {
    width: calc(187 / var(--abi-parent-font-size) * 1rem);
    margin-left: 0;
    margin-right: auto;
  }
}
.o-gnav__logo-link {
  width: 100%;
  display: block;
  text-decoration: none;
}
@media only screen and (max-width: 1024px) {
  .o-gnav__logo-link {
    padding-top: calc(17 / var(--abi-parent-font-size) * 1rem);
    padding-bottom: calc(17 / var(--abi-parent-font-size) * 1rem);
    background-color: var(--abi-color-bg1);
    border-bottom-right-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
    border-right: 1px solid var(--abi-color-black);
    border-bottom: 1px solid var(--abi-color-black);
  }
}
.o-gnav__logo-image {
  width: calc(107 / var(--abi-parent-font-size) * 1rem);
  display: block;
  margin-inline: auto;
}
@media only screen and (max-width: 1024px) {
  .o-gnav__logo-image {
    width: calc(87 / var(--abi-parent-font-size) * 1rem);
  }
}
.o-gnav__logo-text-en {
  font-family: var(--abi-font-en);
  font-optical-sizing: auto;
  font-weight: 700;
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 18;
  line-height: 1;
  display: block;
  text-align: center;
  margin-top: calc(15 / var(--abi-parent-font-size) * 1rem);
}
.o-gnav__logo-text {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 13;
  margin-top: calc(10 / var(--abi-parent-font-size) * 1rem);
  display: block;
  text-align: center;
  line-height: 1;
}
.o-gnav__nav-list {
  width: calc(180 / 195 * 100%);
  margin-left: auto;
  margin-right: 0;
  display: flex;
  flex-direction: column;
  gap: calc(8 / var(--abi-parent-font-size) * 1rem);
  overflow: hidden;
}
.o-gnav__nav-item {
  height: calc(48 / var(--abi-parent-font-size) * 1rem);
}
.o-gnav__nav-link {
  font-family: var(--abi-font-en);
  font-optical-sizing: auto;
  font-weight: 700;
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 18;
  border: 1px solid var(--abi-color-body);
  color: var(--abi-color-category);
  border-right: none;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  text-decoration: none;
  border-top-left-radius: calc(8 / var(--abi-parent-font-size) * 1rem);
  border-bottom-left-radius: calc(8 / var(--abi-parent-font-size) * 1rem);
  padding-left: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.o-gnav__nav-link .o-icon {
  max-width: 32px;
}
.o-gnav__nav-link .t {
  line-height: 1;
  padding-left: 0.5em;
  margin-right: -2em;
}
.o-gnav__language {
  display: flex;
  justify-content: center;
  align-items: center;
  height: calc(75 / var(--abi-parent-font-size) * 1rem);
  width: 100%;
}
@media only screen and (max-width: 1024px) {
  .o-gnav__language {
    margin-top: 0;
    margin-bottom: 0;
    height: calc(60 / var(--abi-parent-font-size) * 1rem);
    align-items: center;
    width: calc(125 / var(--abi-parent-font-size) * 1rem);
    margin-right: 0;
    margin-left: auto;
  }
}
.o-gnav__language-item {
  position: relative;
}
.o-gnav__language-item:not(:first-child)::before {
  content: "";
  display: block;
  width: 1px;
  height: calc(18 / var(--abi-parent-font-size) * 1rem);
  background-color: #1D1D1D;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.o-gnav__language-link {
  font-family: var(--abi-font-en);
  font-optical-sizing: auto;
  font-weight: 700;
  padding: calc(12 / var(--abi-parent-font-size) * 1rem) calc(16 / var(--abi-parent-font-size) * 1rem);
  display: flex;
  align-items: center;
  justify-content: center;
}
.o-gnav__menu {
  height: 100%;
}
.o-gnav__sub {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-bottom: 0;
  margin-top: auto;
}
.o-gnav__sub-item {
  display: flex;
  align-items: center;
  padding: calc(15 / var(--abi-parent-font-size) * 1rem);
  position: relative;
  text-decoration: none;
}
.o-gnav__sub-item:not(:first-child)::before {
  content: "";
  display: block;
  width: 1px;
  height: calc(18 / var(--abi-parent-font-size) * 1rem);
  background-color: #1D1D1D;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.o-gnav__sub-contact {
  font-family: var(--abi-font-en);
  font-optical-sizing: auto;
  font-weight: 700;
  font-weight: normal;
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 18;
}
.o-gnav__btn {
  margin-right: 0;
}

:root {
  --abi-content-0: 1440;
  --abi-content-1: 1320;
  --abi-content-2: 1200;
  --abi-content-3: 1080;
  --abi-content-4: 960;
  --abi-root-font-size: 13;
  --abi-parent-font-size: 13;
  --abi-target-font-size: 13;
  --abi-color-black: #1D1D1D;
  --abi-color-black-rgb: 29, 29, 29;
  --abi-color-green1: #868D5E;
  --abi-color-green1-rgb: 134, 141, 94;
  --abi-color-green2: #32622A;
  --abi-color-green2-rgb: 50, 98, 42;
  --abi-color-point1: #D13852;
  --abi-color-point1-rgb: 209, 56, 82;
  --abi-color-point2: #5FB8D0;
  --abi-color-point2-rgb: 95, 184, 208;
  --abi-color-pink: #C7586B;
  --abi-color-pink-rgb: 199, 88, 107;
  --abi-color-blue: #4064A6;
  --abi-color-blue-rgb: 64, 100, 166;
  --abi-color-green: #51A06D;
  --abi-color-green-rgb: 81, 160, 109;
  --abi-color-purple: #9285BB;
  --abi-color-purple-rgb: 146, 133, 187;
  --abi-color-yellow: #E4C570;
  --abi-color-yellow-rgb: 228, 197, 112;
  --abi-color-orange: #D97837;
  --abi-color-orange-rgb: 217, 120, 55;
  --abi-color-sky: #6CBAC6;
  --abi-color-sky-rgb: 108, 186, 198;
  --abi-color-brown: #896743;
  --abi-color-brown-rgb: 137, 103, 67;
  --abi-color-activity: #C7586B;
  --abi-color-activity-rgb: 199, 88, 107;
  --abi-color-course: #4064A6;
  --abi-color-course-rgb: 64, 100, 166;
  --abi-color-stay: #51A06D;
  --abi-color-stay-rgb: 81, 160, 109;
  --abi-color-spots: #9285BB;
  --abi-color-spots-rgb: 146, 133, 187;
  --abi-color-flavors: #E4C570;
  --abi-color-flavors-rgb: 228, 197, 112;
  --abi-color-spa: #D97837;
  --abi-color-spa-rgb: 217, 120, 55;
  --abi-color-event: #6CBAC6;
  --abi-color-event-rgb: 108, 186, 198;
  --abi-color-access: #896743;
  --abi-color-access-rgb: 137, 103, 67;
  --abi-color-gray-0: #ffffff;
  --abi-color-gray-0-rgb: 255, 255, 255;
  /* 最も明るい（白） */
  --abi-color-gray-5: #f2f2f2;
  --abi-color-gray-5-rgb: 242, 242, 242;
  --abi-color-gray-10: #e6e6e6;
  --abi-color-gray-10-rgb: 230, 230, 230;
  --abi-color-gray-15: #d9d9d9;
  --abi-color-gray-15-rgb: 217, 217, 217;
  --abi-color-gray-20: #cccccc;
  --abi-color-gray-20-rgb: 204, 204, 204;
  --abi-color-gray-25: #bfbfbf;
  --abi-color-gray-25-rgb: 191, 191, 191;
  --abi-color-gray-30: #b3b3b3;
  --abi-color-gray-30-rgb: 179, 179, 179;
  --abi-color-gray-35: #a6a6a6;
  --abi-color-gray-35-rgb: 166, 166, 166;
  --abi-color-gray-40: #999999;
  --abi-color-gray-40-rgb: 153, 153, 153;
  --abi-color-gray-45: #8c8c8c;
  --abi-color-gray-45-rgb: 140, 140, 140;
  --abi-color-gray-50: #808080;
  --abi-color-gray-50-rgb: 128, 128, 128;
  --abi-color-gray-55: #737373;
  --abi-color-gray-55-rgb: 115, 115, 115;
  --abi-color-gray-60: #666666;
  --abi-color-gray-60-rgb: 102, 102, 102;
  --abi-color-gray-65: #595959;
  --abi-color-gray-65-rgb: 89, 89, 89;
  --abi-color-gray-70: #4d4d4d;
  --abi-color-gray-70-rgb: 77, 77, 77;
  --abi-color-gray-75: #404040;
  --abi-color-gray-75-rgb: 64, 64, 64;
  --abi-color-gray-80: #333333;
  --abi-color-gray-80-rgb: 51, 51, 51;
  --abi-color-gray-85: #262626;
  --abi-color-gray-85-rgb: 38, 38, 38;
  --abi-color-gray-90: #1a1a1a;
  --abi-color-gray-90-rgb: 26, 26, 26;
  --abi-color-gray-95: #0d0d0d;
  --abi-color-gray-95-rgb: 13, 13, 13;
  /* 最も暗い */
  --abi-color-body: #1D1D1D;
  --abi-color-body-rgb: 29, 29, 29;
  --abi-color-title: #1b1b1b;
  --abi-color-title-rgb: 27, 27, 27;
  --abi-color-catch: #1b1b1b;
  --abi-color-catch-rgb: 27, 27, 27;
  --abi-color-cv: orange;
  --abi-color-cv-rgb: 255, 165, 0;
  --abi-color-accent: #7D663B;
  --abi-color-accent-rgb: 125, 102, 59;
  --abi-color-accent2: #D0BA90;
  --abi-color-accent2-rgb: 208, 186, 144;
  --abi-color-primary: orange;
  --abi-color-primary-rgb: 255, 165, 0;
  --abi-color-alert: #A91A1A;
  --abi-color-alert-rgb: 169, 26, 26;
  --abi-color-bg1: #EFEADB;
  --abi-color-bg2: #F5F3ED;
  --abi-color-bg3: #EEEEEE;
  --abi-color-bg-dark: #120E0D;
  --abi-color-bg-light: #F5F3ED;
  --abi-font-jp-serif: Noto Serif JP, 游明朝, Yu Mincho, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HGS明朝E, ＭＳ Ｐ明朝, MS PMincho, Times New Roman, Times, Garamond, Georgia, serif;
  --abi-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;
  --abi-font-jp-serif-special: Shippori Mincho, 游明朝, Yu Mincho, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HGS明朝E, ＭＳ Ｐ明朝, MS PMincho, Times New Roman, Times, Garamond, Georgia, serif;
  --abi-font-jp-title: var(--abi-font-jp-serif);
  --abi-font-jp-body: var(--abi-font-jp-sans-serif);
  --abi-font-en: Amiri, serif;
  --abi-font-num: var(--abi-font-en);
  --abi-icon-width: 1em;
  --focus-outline: 3px black solid;
  --abi-gnav-width: calc(195 / var(--abi-parent-font-size) * 1rem);
  --abi-kv-catch-height: calc(75 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-content-0: 428;
    --abi-content-1: 400;
    --abi-content-2: 372;
    --abi-content-3: 344;
    --abi-content-4: 344;
  }
}
@media only screen and (min-width: 1441px) {
  :root {
    --abi-base-font-size: 15;
  }
}
@media only screen and (min-width: 1441px) and (max-width: 1600px) {
  :root {
    --abi-base-font-size: 14;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1440px) {
  :root {
    --abi-base-font-size: 13;
  }
}
@media only screen and (min-width: 897px) and (max-width: 1024px) {
  :root {
    --abi-base-font-size: 13;
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  :root {
    --abi-base-font-size: 12;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-parent-font-size: 14;
  }
}

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

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

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

[data-abi-theme=bg1] {
  background: var(--abi-color-bg1);
}

[data-abi-theme=bg2] {
  background: var(--abi-color-bg2);
}

[data-abi-theme=bg3] {
  background: var(--abi-color-bg3);
}

html {
  font-size: calc(var(--abi-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;
  }
}

:root {
  --abi-body-color: var(--abi-color-body);
  --abi-body-bg: var(--abi-color-bg-light);
  --abi-body-font: var(--abi-font-jp-sans-serif);
}

body {
  color: var(--abi-body-color);
  fill: var(--abi-body-color);
  font-weight: 400;
  background: var(--abi-body-bg);
  -webkit-text-size-adjust: none;
}
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;
}
body.is-bodylock {
  overflow: hidden;
}

body,
pre,
input,
textarea,
select {
  font-family: var(--abi-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%;
}
.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;
}

[id*=svg_defs] {
  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 {
  position: relative;
}
.js-accordion[aria-expanded=false] .o-icon--minus {
  display: none;
}
.js-accordion[aria-expanded=true] .o-icon--plus {
  display: none;
}
.js-accordion[aria-expanded=true] .o-icon--down {
  transform: scaleY(-1);
}

.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;
}/*# sourceMappingURL=first_load.css.map */