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

file name	: common.css
author		 : Abilive
style info : 基本・共通設定
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
/**
 * Swiper 8.4.4
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2022 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: October 12, 2022
 */
@font-face {
  font-family: "swiper-icons";
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-pointer-events {
  touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* 3D Effects */
.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-centered > .swiper-wrapper::before {
  content: "";
  flex-shrink: 0;
  order: 9999;
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
}

.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}

.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-lock {
  display: none;
}

:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-bullet-size: 8px;
  --swiper-pagination-bullet-width: 8px;
  --swiper-pagination-bullet-height: 8px;
  --swiper-pagination-bullet-inactive-color: #000;
  --swiper-pagination-bullet-inactive-opacity: 0.2;
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-horizontal-gap: 4px;
  --swiper-pagination-bullet-vertical-gap: 6px;
  */
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 300ms opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 10px;
  left: 0;
  width: 100%;
}

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-vertical > .swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}

.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform, 200ms top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms right;
}

/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-vertical > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

/* Scrollbar */
.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-scrollbar-disabled > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-vertical > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-vertical {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

/* Preloader */
:root {
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  */
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* a11y */
.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev,
.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-slide-shadow-top,
.swiper-cube .swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: "";
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}

.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-flip .swiper-slide-shadow-top,
.swiper-flip .swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height;
}

.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}

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

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
:root {
  --abi-title-color: var(--abi-color-title);
  --abi-title-en-color: var(--abi-color-title);
  --abi-title-en-font: var(--abi-font-en);
  --abi-title-jp-color: var(--abi-color-title);
  --abi-title-jp-font: var(--abi-font-jp-serif);
}

.c-title {
  font-weight: normal;
}
.c-title__en {
  font-weight: 400;
  display: block;
  color: var(--abi-title-en-color);
  font-family: var(--abi-title-en-font);
  line-height: 1;
  letter-spacing: 0.25em;
}
.c-title__en--ls-normal {
  letter-spacing: 0;
}
.c-title__jp {
  display: block;
  font-weight: 500;
  line-height: 1;
  color: var(--abi-title-jp-color);
  font-family: var(--abi-title-jp-font);
}
.c-title:has(.c-title__en):has(.c-title__jp) .c-title__jp {
  margin-top: calc(10 / 13 / (11 / 13) * 1em);
}
.c-title.u-align--c .o-icon {
  margin-right: auto;
  margin-left: auto;
}
.c-title .o-icon {
  order: -9;
}
.c-title--gold {
  --abi-title-jp-color: var(--abi-color-acc2);
}
:root {
  --abi-catch-color: var(--abi-color-catch);
  --abi-catch-font: var(--abi-font-jp-title);
}

[data-abi-theme=blue] {
  --abi-catch-color: #fff;
}

.c-catch {
  font-family: var(--abi-catch-font);
  line-height: 1.5;
  color: var(--abi-catch-color);
  font-weight: 500;
}
.c-catch--base, .c-catch--m {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 28;
}
.c-catch--s {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 24;
}
.c-catch--xs {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 22;
}
.c-catch--2xs {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 18;
}
.c-catch--3xs {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 15;
}

:root {
  --abi-btn-color: inherit;
  --abi-btn-font-size: inherit;
  --abi-btn-bg: transparent;
  --abi-btn-border-width: 1px;
  --abi-btn-border-color: var(--abi-color-black);
  --abi-btn-active-color: #fff;
  --abi-btn-active-bg: var(--abi-color-black);
  --abi-btn-active-border-color: var(--abi-color-black);
}

[data-abi-theme=dark] {
  --abi-btn-border-color: #fff;
  --abi-btn-bg: none;
}

.c-btn {
  display: flex;
  justify-content: flex-start;
}
.c-btn__link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: left;
  max-width: none;
  border-radius: 1000px;
  z-index: 1;
  text-decoration: none !important;
  will-change: transform;
  box-shadow: none;
  padding-left: calc(20 / var(--abi-parent-font-size) * 1rem);
  padding-right: calc(30 / var(--abi-parent-font-size) * 1rem);
  padding-top: calc(5 / var(--abi-parent-font-size) * 1rem);
  padding-bottom: calc(5 / var(--abi-parent-font-size) * 1rem);
  min-height: calc(40 / var(--abi-parent-font-size) * 1rem);
  min-width: calc(160 / var(--abi-parent-font-size) * 1rem);
  font-size: var(--abi-btn-font-size);
  color: var(--abi-btn-color);
  fill: var(--abi-btn-color);
  background: var(--abi-btn-bg);
  border: var(--abi-btn-border-width) solid var(--abi-btn-border-color);
  transition-property: transform, opacity, background-color, border-color;
  transition-duration: 0.15s;
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
@media only screen and (min-width: 768px) {
  .c-btn__link {
    padding-top: 5px;
    padding-bottom: 5px;
  }
}
.c-btn__link[aria-current=page] {
  color: var(--abi-btn-active-color);
  fill: var(--abi-btn-active-color);
  background: var(--abi-btn-active-bg);
  border: var(--abi-btn-border-width) solid var(--abi-btn-active-border-color);
}
.mouse .c-btn__link:hover, .touch .c-btn__link.touchstart {
  color: var(--abi-btn-active-color);
  fill: var(--abi-btn-active-color);
  background: var(--abi-btn-active-bg);
  border: var(--abi-btn-border-width) solid var(--abi-btn-active-border-color);
}
.touch .c-btn__link {
  -webkit-tap-highlight-color: transparent;
}
.touch .c-btn__link.touchend {
  transition-delay: 200ms;
}
.c-btn__link > .o-icon {
  fill: var(--abi-btn-color);
  margin-right: 0;
  margin-left: auto;
}
.c-btn__text {
  line-height: 1.3;
  display: flex;
  align-items: center;
}
.c-btn__text:not(:only-child) {
  padding-right: 0.5em;
}
.c-btn__text:has(> .o-icon:first-child) > .o-icon {
  margin-right: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.c-btn__text:has(> .o-icon:last-child) > .o-icon {
  margin-left: calc(15.5 / var(--abi-parent-font-size) * 1rem);
}
.c-btn--cv {
  --abi-btn-color: var(--abi-color-body);
  --abi-btn-border-color: var(--abi-color-cv);
  --abi-btn-bg: var(--abi-color-cv);
  --abi-btn-active-color: var(--abi-color-body);
  --abi-btn-active-border-color: var(--abi-color-cv);
  --abi-btn-active-bg: #fff;
}
.c-btn--l .c-btn__link {
  min-height: calc(50 / var(--abi-parent-font-size) * 1rem);
  --abi-btn-font-size: calc(16 / var(--abi-parent-font-size) * 1rem);
}
.c-btn--xl .c-btn__link {
  min-height: calc(60 / var(--abi-parent-font-size) * 1rem);
}
.c-btn--s .c-btn__link {
  min-height: calc(30 / var(--abi-parent-font-size) * 1rem);
  --abi-btn-font-size: calc(12 / var(--abi-parent-font-size) * 1rem);
}

:root {
  --abi-link-color: inherit;
  --abi-link-border-color: red;
  --abi-link-active-color: red;
}

.c-link {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.c-link__link {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  text-align: left;
  max-width: none;
  height: 100%;
  z-index: 1;
  text-decoration: none !important;
  will-change: transform;
  color: var(--abi-link-color);
  transition-property: transform, opacity, background-color, border-color;
  transition-duration: 0.15s;
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
  transition-delay: 0.1s;
}
.c-link__link:hover .c-link__text {
  color: var(--abi-link-active-color);
}
.c-link__text {
  display: flex;
  align-items: center;
  line-height: 1.3;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  z-index: 1;
  order: 0;
  border-bottom: 1px solid var(--abi-link-border-color);
  padding: 0.65em 0;
}
.c-link__text--serif {
  font-family: var(--abi-font-jp-serif);
}
.c-link__text--sans-serif {
  font-family: var(--abi-font-jp-sans-serif);
}
.c-link__text + .o-icon {
  margin-left: calc(10 / var(--abi-parent-font-size) * 1rem);
}
.c-link__text .o-icon {
  margin-left: calc(13 / var(--abi-parent-font-size) * 1rem);
  fill: var(--abi-color-acc1);
}
.c-link > *:not(:only-child):not(:first-child) {
  margin-left: calc(25 / var(--abi-parent-font-size) * 1rem);
}

:root {
  --abi-table-font-size: calc(11 / var(--abi-parent-font-size) * 1rem);
  --abi-table-color: inherit;
  --abi-table-border-color: black;
  --abi-table-th-bg: silver;
  --abi-table-th-color: black;
  --abi-table-th-highlight-bg: green;
}

.c-table {
  font-size: var(--abi-table-font-size);
  color: var(--abi-table-color);
  width: 100%;
}
.c-table .c-table__table {
  width: 100%;
}
.c-table .c-table__caption {
  width: 100%;
}
.c-table .c-table__tr {
  border-top: 1px solid var(--abi-table-border-color);
  width: 100%;
}
.c-table .c-table__tr:last-child {
  border-bottom: 1px solid var(--abi-table-border-color);
}
.c-table .c-table__tr:not(tr) {
  display: flex;
}
.c-table .c-table__th, .c-table .c-table__td {
  padding: 0.785em 1em;
  --lh: 1.6;
  line-height: var(--lh);
}
.c-table .c-table__th:not(:last-child), .c-table .c-table__td:not(:last-child) {
  border-right: 1px solid var(--abi-table-border-color);
}
.c-table .c-table__th {
  font-weight: normal;
  text-align: center;
  color: var(--abi-table-th-color);
  background-color: var(--abi-table-th-bg);
}
.c-table .c-table__th:not(th) {
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
}
.c-table .c-table__th--normal {
  background-color: transparent;
}
.c-table .c-table__td {
  padding-left: calc(20 / var(--abi-parent-font-size) * 1rem);
  padding-right: 1em;
}
.c-table .c-table__td:not(td) {
  display: flex;
  align-items: center;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .c-table .c-tabledl div {
    flex-direction: column;
  }
}
@media only screen and (max-width: 767px) {
  .c-table--sp-column:not(table) .c-table__tr {
    flex-direction: column;
    --th: 100%;
    --td: 100%;
  }
  .c-table--sp-column:not(table) .c-table__th, .c-table--sp-column:not(table) .c-table__td {
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .c-table--sp-column:not(table) .c-table__th {
    background-color: var(--abi-table-th-highlight-bg);
    border-top: var(--td-bd);
    border-bottom: var(--td-bd);
  }
  .c-table--sp-column:not(table) .c-table__td {
    padding-left: 1em;
    padding-right: 1em;
    border-top: none;
    padding-bottom: 1.5em;
    line-height: 2;
  }
  .c-table--sp-column:not(table):not(:last-child) .c-table__td {
    border-bottom: none;
  }
}
.c-table--s {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 11;
}
.c-table--s .c-table__th, .c-table--s .c-table__td {
  padding: 0.88em 0;
}
.c-table--s .c-table__th {
  background-color: transparent;
}
.c-table--width-auto {
  width: auto;
}
@media only screen and (max-width: 767px) {
  .c-table--sp--125 {
    width: 125%;
  }
  .c-table--sp--150 {
    width: 150%;
  }
  .c-table--sp--175 {
    width: 175%;
  }
  .c-table--sp--200 {
    width: 200%;
  }
}
@media only screen and (max-width: 767px) {
  .c-table__wrp--sp-scroll {
    padding-bottom: 0.75em;
    overflow-x: scroll;
  }
  .c-table__wrp--sp-scroll .c-table {
    width: 150%;
  }
}

:root {
  --abi-accordion-button-border-color: black;
  --abi-accordion-button-icon-bg: black;
  --abi-accordion-button-icon-color: white;
  --abi-accordion-button-bg: transparent;
  --abi-accordion-target-bg: inherit;
}

.c-accordion {
  overflow: hidden;
  --text-padding-left: calc(30 / var(--abi-parent-font-size) * 1rem);
}
.c-accordion:not([class*="--s"]):not([class*="--ts"]) {
  border: 1px solid var(--abi-accordion-button-border-color);
}
@media only screen and (max-width: 767px) {
  .c-accordion {
    --text-padding-left: calc(10 / var(--abi-parent-font-size) * 1rem);
  }
}
.c-accordion__button {
  --icon-size: calc(50 / var(--abi-parent-font-size) * 1rem);
  position: relative;
  background-color: var(--abi-accordion-button-bg);
  display: flex;
  align-items: baseline;
  width: 100%;
  padding-left: var(--text-padding-left);
  padding-right: var(--icon-size);
}
@media only screen and (max-width: 767px) {
  .c-accordion__button {
    --icon-size: calc(40 / var(--abi-parent-font-size) * 1rem);
  }
}
.c-accordion__button[class*=u-align--c] .c-accordion__button {
  padding-left: var(--icon-size);
}
.c-accordion__button__text {
  min-height: var(--icon-size);
  padding: 1em 0;
  display: flex;
  align-items: center;
}
.c-accordion__button__icon {
  background-color: var(--abi-accordion-button-icon-bg);
  fill: var(--abi-accordion-button-icon-color);
  display: block;
  width: var(--icon-size);
  min-height: var(--icon-size);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 0;
  margin-left: auto;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.c-accordion__button[aria-expanded=false] .o-icon--minus {
  display: none;
}
.c-accordion__button[aria-expanded=true] .o-icon--plus {
  display: none;
}
.c-accordion__button--border-top {
  border-top: 2px solid var(--abi-accordion-button-border-color);
}
.c-accordion__target {
  background-color: var(--abi-accordion-target-bg);
}
.c-accordion__target:not([class*=target--s]):not([class*=target--ts]) {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.5s, height 0.5s;
  visibility: hidden;
}
.c-accordion__target-text {
  padding-top: calc(16 / var(--abi-parent-font-size) * 1rem);
  padding-bottom: calc(20 / var(--abi-parent-font-size) * 1rem);
  padding-right: calc(20 / var(--abi-parent-font-size) * 1rem);
  display: block;
  padding-left: var(--text-padding-left);
}
@media only screen and (min-width: 768px) {
  .c-accordion__target--s {
    height: auto !important;
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .c-accordion__target--s {
    height: 0;
    opacity: 0;
    overflow: hidden;
    transition: opacity 0.5s, height 0.5s;
    visibility: hidden;
  }
}
@media only screen and (min-width: 1025px) {
  .c-accordion__target--ts {
    height: auto !important;
    opacity: 1;
  }
}
@media only screen and (max-width: 1024px) {
  .c-accordion__target--ts {
    height: 0;
    opacity: 0;
    overflow: hidden;
    transition: opacity 0.5s, height 0.5s;
    visibility: hidden;
  }
}
.c-accordion + .c-accordion {
  margin-top: -1px;
}

:root {
  --abi-tab-color: var(--abi-body-color);
  --abi-tab-border-color: black;
  --abi-tab-icon-color: silver;
  --abi-tab-bg: silver;
  --abi-tab-active-bg: black;
}

.c-tab {
  --item-width: 220;
  --item-margin: 0;
}
.c-tab--col1 {
  --col: 1;
}
.c-tab--col2 {
  --col: 2;
}
.c-tab--col3 {
  --col: 3;
}
.c-tab--col4 {
  --col: 4;
}
.c-tab--col5 {
  --col: 5;
}
.c-tab[class*="--col"] {
  --parent: calc(var(--item-width) * var(--col) + var(--item-margin) * (var(--col) - 1));
}
@media only screen and (min-width: 768px) {
  .c-tab[class*="--col"] .c-tab__list {
    max-width: calc(var(--parent) * 1px);
  }
}
@media only screen and (min-width: 768px) {
  .c-tab[class*="--col"] .c-tab__item {
    width: calc(var(--item-width) / var(--parent) * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .c-tab[class*="--col"] .c-tab__item {
    min-width: calc(100 / var(--abi-parent-font-size) * 1rem);
  }
}
.c-tab:not([class*="--col"]) .c-tab__item {
  width: 100%;
}
.c-tab__list {
  display: flex;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 1024px) {
  .c-tab__list {
    overflow: scroll;
    padding-bottom: 0.5em;
  }
}
.c-tab__text .o-icon {
  margin-right: 0.25em;
}
.c-tab__item {
  white-space: wrap;
  margin-left: -1px;
  position: relative;
}
.c-tab__button {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 13;
  font-family: var(--abi-font-jp-serif);
  background: var(--abi-tab-bg);
  height: calc(60 / var(--abi-parent-font-size) * 1rem);
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  padding-right: calc(15 / var(--abi-parent-font-size) * 1rem);
  padding-left: calc(15 / var(--abi-parent-font-size) * 1rem);
  text-decoration: none;
  width: 100%;
  color: var(--abi-tab-color);
  border-top: 1px solid var(--abi-tab-border-color);
  border-left: 1px solid var(--abi-tab-border-color);
  border-right: 1px solid var(--abi-tab-border-color);
  opacity: 0.7;
}
.c-tab__button[aria-selected=true], .c-tab__button:hover, .c-tab__button.is-active {
  background: var(--abi-active-tab-bg);
  border-color: var(--abi-tab-active-border-color);
  opacity: 1;
}
@media only screen and (max-width: 767px) {
  .c-tab--pt .c-tab__panel--pt[hidden] {
    display: block !important;
  }
}

:root {
  --abi-anchor-color: inherit;
  --abi-anchor-border-color: black;
  --abi-anchor-bg: transparent;
  --abi-anchor-active-color: blue;
  --abi-anchor-active-border-color: gold;
  --abi-anchor-active-bg: transparent;
}

.c-anchor {
  --parent: calc(var(--item-width) * var(--col) + var(--item-margin) * (var(--col) - 1));
  --item-width: 220;
  --item-margin: 0;
  --item-padding: calc(10 / var(--abi-parent-font-size) * 1rem);
  --icon-width: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.c-anchor--col1 {
  --col: 1;
}
.c-anchor--col2 {
  --col: 2;
}
.c-anchor--col3 {
  --col: 3;
}
.c-anchor--col4 {
  --col: 4;
}
.c-anchor--col5 {
  --col: 5;
}
@media only screen and (max-width: 767px) {
  .c-anchor {
    --item-padding: calc(7 / var(--abi-parent-font-size) * 1rem);
  }
}
@media only screen and (min-width: 768px) {
  .c-anchor[class*="--col"] .c-anchor__item {
    width: calc(var(--item-width) / var(--parent) * 100%);
  }
  .c-anchor[class*="--col"] .c-anchor__item:last-child {
    margin-right: auto;
  }
}
@media only screen and (max-width: 767px) {
  .c-anchor[class*="--col"] .c-anchor__item {
    width: 50%;
  }
}
@media only screen and (min-width: 768px) {
  .c-anchor:not([class*="--col"]) .c-anchor__list {
    flex-wrap: nowrap;
  }
}
.c-anchor__list {
  margin-left: calc(var(--item-padding) * -1);
  margin-right: calc(var(--item-padding) * -1);
  display: flex;
  position: relative;
  flex-wrap: wrap;
  z-index: 2;
}
@media only screen and (min-width: 768px) {
  .c-anchor__list {
    justify-content: center;
  }
}
@media only screen and (max-width: 767px) {
  .c-anchor__list {
    flex-wrap: wrap;
    align-items: flex-end;
  }
}
@media only screen and (min-width: 1025px) {
  .c-anchor__list--max-width--1 {
    max-width: var(--abi-content-1);
    margin-right: auto;
    margin-left: auto;
  }
}
@media only screen and (min-width: 1025px) {
  .c-anchor__list--max-width--2 {
    margin-right: auto;
    margin-left: auto;
    max-width: calc(calc(var(--abi-content-2) * 1px) * (var(--abi-parent-font-size) + 2 + 0) / var(--abi-parent-font-size));
  }
}
@media only screen and (min-width: 1025px) {
  .c-anchor__list--max-width--3 {
    margin-right: auto;
    margin-left: auto;
    max-width: calc(calc(var(--abi-content-3) * 1px) * (var(--abi-parent-font-size) + 2 + 0) / var(--abi-parent-font-size));
  }
}
@media only screen and (min-width: 1025px) {
  .c-anchor__list--max-width--4 {
    margin-right: auto;
    margin-left: auto;
    max-width: calc(calc(var(--abi-content-4) * 1px) * (var(--abi-parent-font-size) + 2 + 0) / var(--abi-parent-font-size));
  }
}
@media only screen and (min-width: 1025px) {
  .c-anchor__list--max-width--5 {
    margin-right: auto;
    margin-left: auto;
    max-width: calc(calc(var(--abi-content-5) * 1px) * (var(--abi-parent-font-size) + 2 + 0) / var(--abi-parent-font-size));
  }
}
.c-anchor__item {
  padding-right: var(--item-padding);
  padding-left: var(--item-padding);
  width: 100%;
}
.c-anchor__item .t {
  padding-right: 1em;
}
.c-anchor__item--width-auto {
  width: auto;
}
.c-anchor__item--width-auto .t {
  padding-right: 2em;
}
@media only screen and (max-width: 767px) {
  .c-anchor__item {
    width: 50%;
  }
  .c-anchor__item:nth-child(n+3) {
    margin-top: 0.75rem;
  }
}
.c-anchor__link {
  border-bottom: 1px solid black;
  text-decoration: none;
  min-height: calc(45 / var(--abi-parent-font-size) * 1rem);
  align-items: center;
  display: flex;
}
.c-anchor__link .t {
  line-height: 1.4;
  width: calc(100% - var(--icon-width));
}
.c-anchor__link .o-icon--down {
  width: var(--icon-width);
}
.c-anchor__link:hover {
  color: var(--abi-anchor-active-color);
}
.c-anchor__link:hover .t::before {
  opacity: 1;
}
.c-anchor__link:hover .o-icon--anchor-line {
  fill: var(--abi-anchor-active-border-color);
}

:root {
  --abi-slider-arrow-width: calc(35 / var(--abi-parent-font-size) * 1rem);
  --abi-slider-arrow-height: calc(70 / var(--abi-parent-font-size) * 1rem);
  --abi-slider-arrow-color: var(--abi-color-cv);
  --abi-slider-pagination-pt: 8px;
  --abi-slider-pagination-area-size: 18px;
  --abi-slider-pagination-size: 8px;
  --abi-slider-pagination-color: silver;
  --abi-slider-pagination-active-color: var(--abi-color-cv);
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-slider-pagination-pt: calc(25 / var(--abi-parent-font-size) * 1rem);
    --abi-slider-pagination-area-size: calc(20 / var(--abi-parent-font-size) * 1rem);
    --abi-slider-pagination-size: calc(8 / var(--abi-parent-font-size) * 1rem);
  }
}

[data-abi-theme=dark] {
  --abi-slider-pagination-color: rgba(255, 255, 255, 0.3);
  --abi-slider-pagination-active-color: #fff;
}

.c-slider:has(.not-slide) .c-slider__btn {
  display: none !important;
}
.c-slider .c-slider__element:not(.swiper-initialized) + .c-slider__ctrls {
  display: none !important;
}
.c-slider .c-slider__wrapper {
  position: relative;
}
.c-slider .c-slider__btn {
  width: var(--abi-slider-arrow-width);
  height: var(--abi-slider-arrow-height);
}
.c-slider .c-slider__btn {
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  cursor: pointer;
}
.c-slider .c-slider__btn button {
  width: var(--abi-slider-arrow-width);
  height: var(--abi-slider-arrow-height);
  position: relative;
  transition-property: transform;
  transition-duration: 0.2s;
  transition-timing-function: ease-out;
}
.c-slider .c-slider__btn button span {
  display: block;
  width: calc(var(--abi-slider-arrow-width) * 1);
  height: 1px;
  background-color: var(--abi-slider-arrow-color);
  position: absolute;
  top: 50%;
  left: 0;
  transform: rotate(-60deg);
  transform-origin: 0 0;
}
.c-slider .c-slider__btn button span:nth-child(2) {
  transform: rotate(60deg);
}
@media only screen and (min-width: 1025px) {
  .c-slider .c-slider__btn:hover button {
    transform: translateX(-1rem);
  }
}
.c-slider .c-slider__btn--prev {
  left: calc(25 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .c-slider .c-slider__btn--prev {
    left: 0.5em;
  }
}
.c-slider .c-slider__btn--next {
  right: calc(25 / var(--abi-parent-font-size) * 1rem);
  transform: translateY(-50%) scaleX(-1);
}
@media only screen and (max-width: 767px) {
  .c-slider .c-slider__btn--next {
    right: 0.5em;
  }
}
.c-slider .c-slider__pagination {
  position: static;
  display: flex;
  width: auto;
  padding: var(--abi-slider-pagination-pt) 0 0 0;
}
@media only screen and (max-width: 1024px) {
  .c-slider .c-slider__pagination {
    justify-content: center;
  }
}
.c-slider .c-slider__pagination .swiper-pagination-bullet {
  opacity: 1;
  background: none;
  width: var(--abi-slider-pagination-area-size);
  height: var(--abi-slider-pagination-area-size);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}
.c-slider .c-slider__pagination .swiper-pagination-bullet::before {
  content: "";
  background-color: var(--abi-slider-pagination-color);
  width: var(--abi-slider-pagination-size);
  display: block;
  aspect-ratio: 1;
  border-radius: 1000px;
}
.c-slider .c-slider__pagination .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
  --abi-slider-pagination-color: var(--abi-slider-pagination-active-color);
}
.c-slider .c-slider__ctrls {
  display: flex;
  align-items: center;
}
.c-slider .c-slider__ctrls .c-slider__pagination {
  margin-right: calc(10 / var(--abi-parent-font-size) * 1rem);
}
.mouse .c-slider .c-slider__pause {
  transition: opacity 0.15s ease-in;
}
.mouse .c-slider .c-slider__pause:hover, .touch .c-slider .c-slider__pause.touchstart {
  opacity: 0.7;
}
.touch .c-slider .c-slider__pause {
  -webkit-tap-highlight-color: transparent;
}
.touch .c-slider .c-slider__pause.touchend {
  transition-delay: 200ms;
}
.c-slider .c-slider__pause .o-icon--play {
  display: none;
}
.c-slider .c-slider__pause.is-stop .o-icon--pause {
  display: none;
}
.c-slider .c-slider__pause.is-stop .o-icon--play {
  display: inline-flex;
}
.c-slider .c-slider__thumbs {
  display: flex;
}
.c-slider .c-slider__thumbs__wrapper {
  display: flex;
}
.c-slider .c-slider__thumbs__slide {
  width: calc(100 / var(--abi-parent-font-size) * 1rem);
  position: relative;
}
.c-slider .c-slider__thumbs__slide::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  opacity: 0;
  border: 4px solid var(--abi-color-cv);
}
.c-slider .c-slider__thumbs__slide.swiper-slide-thumb-active::after {
  opacity: 1;
}
.c-slider .c-slider__dots_pause {
  display: flex;
  justify-content: center;
}
.c-slider .c-slider__dots_pause .c-slider__pause {
  align-items: center;
  display: flex;
  margin-left: calc(6 / var(--abi-parent-font-size) * 1rem);
}

@keyframes scroll-left {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes scroll-top {
  0% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(-50%);
  }
}
.c-marquee {
  --marquee-element-size: calc(400 / var(--abi-parent-font-size) * 1rem);
  --marquee-speed: calc(10 / var(--abi-parent-font-size) * 1rem);
  --marquee-animation-duration: calc(var(--marquee-element-size) / var(--marquee-speed) * 1s);
  --marquee-scale: 1;
}
@media only screen and (max-width: 1024px) {
  .c-marquee {
    --marquee-scale: .75;
  }
}
.c-marquee__scroll-area {
  animation: scroll-left var(--marquee-animation-duration) linear infinite;
  display: flex;
  white-space: nowrap;
  width: fit-content;
}
.c-marquee__slide-set {
  display: flex;
  white-space: nowrap;
}
.c-marquee__slide-set p {
  width: calc(var(--marquee-element-size) * var(--marquee-scale));
}
.c-marquee--to-right .c-marquee__scroll-area {
  animation-direction: reverse;
}
@media only screen and (min-width: 1025px) {
  .c-marquee--to-top {
    overflow: hidden;
    height: 100%;
  }
  .c-marquee--to-top .c-marquee__scroll-area {
    display: block;
    width: 100%;
    animation-name: scroll-top;
  }
  .c-marquee--to-top .c-marquee__slide-set {
    display: block;
    width: 100%;
  }
}

.c-fade-up {
  transition: 0.75s ease-in-out opacity 0.2s, 0.75s ease-in-out transform 0.2s;
}
.c-fade-up.lazyload {
  transform: translateY(40px);
  opacity: 0;
}
@media only screen and (max-width: 767px) {
  .c-fade-up.lazyload {
    transform: translateY(2em);
  }
}
.c-fade-up.lazyloaded {
  transform: translateY(0);
  opacity: 1;
}

.c-fade-in {
  transition: opacity 0.75s ease-in-out 0.2s;
}
.c-fade-in.lazyload {
  opacity: 0;
}
.c-fade-in.lazyloaded {
  opacity: 1;
}

.c-fade-up-stagger > * {
  opacity: 0;
  transform: translateY(40px);
  transition: 0.75s ease-in-out opacity, 0.75s ease-in-out transform;
}
@media only screen and (max-width: 767px) {
  .c-fade-up-stagger > * {
    transform: translateY(2em);
  }
}
.c-fade-up-stagger.lazyloaded > *:nth-child(1) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.5s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(2) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 1s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(3) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 1.5s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(4) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 2s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(5) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 2.5s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(6) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 3s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(7) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 3.5s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(8) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 4s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(9) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 4.5s;
}
.c-fade-up-stagger.lazyloaded > *:nth-child(10) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 5s;
}

:root {
  --abi-list-color: var(--abi-body-color);
  --abi-list-dot-color: var(--abi-body-color);
  --abi-list-dot-size: 4px;
  --abi-list-dot-margin: calc(7 / var(--abi-parent-font-size) * 1rem);
}

[data-abi-theme=dark] {
  --abi-list-dot-color: #fff;
}

.c-list {
  color: var(--abi-list-color);
}
.c-list__item {
  display: flex;
  position: relative;
  padding-left: calc(var(--abi-list-dot-size) + var(--abi-list-dot-margin) * 2);
}
.c-list__item::before {
  content: "";
  display: block;
  width: var(--abi-list-dot-size);
  background-color: var(--abi-list-dot-color);
  aspect-ratio: 1;
  border-radius: 100px;
  transform: translate(-50%, -50%);
  line-height: 2;
  position: absolute;
  top: calc(2 / 2 * 1em);
  left: calc((var(--abi-list-dot-size) + var(--abi-list-dot-margin) * 2) / 2);
}

.c-tags {
  display: inline-flex;
  align-items: center;
}
.c-tags:not(:first-child) {
  margin-left: calc(10 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .c-tags:not(:first-child) {
    margin-left: calc(5 / var(--abi-parent-font-size) * 1rem);
  }
}
.c-tags__item {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 11;
  border-radius: calc(5 / var(--abi-parent-font-size) * 1rem);
  color: #fff;
  height: calc(25 / var(--abi-parent-font-size) * 1rem);
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-right: calc(8 / var(--abi-parent-font-size) * 1rem);
  padding-left: calc(8 / var(--abi-parent-font-size) * 1rem);
  background-color: black;
}
@media only screen and (max-width: 767px) {
  .c-tags__item {
    height: calc(22 / var(--abi-parent-font-size) * 1rem);
  }
}
.c-tags__item::before {
  content: "#";
}
.c-tags__item:not(:first-child) {
  margin-left: calc(4 / var(--abi-parent-font-size) * 1rem);
}
.c-tags__item--point {
  height: calc(21 / var(--abi-parent-font-size) * 1rem);
  border-radius: 100px;
  background-color: blue;
}
.c-tags__item--point::before {
  display: none;
}

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

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.u-font-size--80 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 80;
}
.u-font-size--70 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 70;
}
.u-font-size--60 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 60;
}
.u-font-size--50 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 50;
}
.u-font-size--40 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 40;
}
.u-font-size--30 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 30;
}
.u-font-size--20 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 20;
}
.u-font-size--10 {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (min-width: 768px) {
  .u-font-size--10 {
    --abi-target-font-size: 10;
  }
}
@media only screen and (max-width: 767px) {
  .u-font-size--fix {
    --abi-parent-font-size: 14 !important;
  }
}

.u-font--serif {
  font-family: var(--abi-font-jp-serif);
}
.u-font--sans-serif {
  font-family: var(--abi-font-jp-sans-serif);
}
.u-font--en {
  font-family: var(--abi-font-en);
}
.u-font--title {
  font-family: var(--abi-font-jp-title);
}
.u-font--num {
  font-family: var(--abi-font-num);
}

.u-font-weight--100 {
  font-weight: 100;
}
.u-font-weight--200 {
  font-weight: 200;
}
.u-font-weight--300 {
  font-weight: 300;
}
.u-font-weight--400 {
  font-weight: 400;
}
.u-font-weight--500 {
  font-weight: 500;
}
.u-font-weight--600 {
  font-weight: 600;
}
.u-font-weight--700 {
  font-weight: 700;
}
.u-font-weight--800 {
  font-weight: 800;
}
.u-font-weight--900 {
  font-weight: 900;
}
.u-font-weight--normal {
  font-weight: normal;
}
.u-font-weight--bold {
  font-weight: bold;
}

.u-note {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 11;
  color: var(--abi-color-sub);
  line-height: 1.6;
}
.u-note li::before {
  content: "※";
}

.u-letter-spacing--normal, .u-ls--normal {
  letter-spacing: normal;
}
.u-letter-spacing--5, .u-ls--5 {
  letter-spacing: 0.05em;
}
.u-letter-spacing--10, .u-ls--10 {
  letter-spacing: 0.1em;
}
.u-letter-spacing--25, .u-ls--25 {
  letter-spacing: 0.25em;
}

.u-line-height--10, .u-lh--10 {
  line-height: 1;
}
.u-line-height--13, .u-lh--13 {
  line-height: 1.3;
}
.u-line-height--15, .u-lh--15 {
  line-height: 1.5;
}
.u-line-height--20, .u-lh--20 {
  line-height: 2;
}

.u-color--white {
  color: #fff;
}
.u-color--body {
  color: var(--abi-color-body);
}
.u-color--title {
  color: var(--abi-color-title);
}
.u-color--primary {
  color: var(--abi-color-primary);
}
.u-color--cv {
  color: var(--abi-color-cv);
}
.u-color--cv2 {
  color: var(--abi-color-cv2);
}
.u-color--alert {
  color: var(--abi-color-alert);
}
.u-color--gray-c {
  color: var(--abi-color-gray-c);
}
.u-color--gray-ca {
  color: var(--abi-color-gray-ca);
}
.u-color--gray-8 {
  color: var(--abi-color-gray-8);
}
.u-color--gray-5 {
  color: var(--abi-color-gray-5);
}
.u-color--category-activity {
  --abi-color-category: var(--abi-color-activity);
}
.u-color--category-course {
  --abi-color-category: var(--abi-color-course);
}
.u-color--category-stay {
  --abi-color-category: var(--abi-color-stay);
}
.u-color--category-spots {
  --abi-color-category: var(--abi-color-spots);
}
.u-color--category-flavors {
  --abi-color-category: var(--abi-color-flavors);
}
.u-color--category-spa {
  --abi-color-category: var(--abi-color-spa);
}
.u-color--category-event {
  --abi-color-category: var(--abi-color-event);
}
.u-color--category-access {
  --abi-color-category: var(--abi-color-access);
}

.u-zoom-hover *:has(> img), .u-zoom-hover *:has(> picture > img) {
  position: relative;
  overflow: hidden;
}
.u-zoom-hover__target img {
  transition-property: transform, opacity, filter;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
  transition-delay: 0.1s;
  backface-visibility: hidden;
  transform: translateZ(0);
}
.u-zoom-hover--t2 .u-zoom-hover__target {
  position: relative;
}
.u-zoom-hover--t2 .u-zoom-hover__target::before {
  content: "";
  position: absolute;
  background-color: #D78133;
  display: block;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
.u-zoom-hover--t2 .u-zoom-hover__target img {
  z-index: 1;
  position: relative;
}
.u-zoom-hover:hover .u-zoom-hover__target img {
  transform: translateZ(0) scale(1.1);
}
.u-zoom-hover:hover[class*="--t2"] .u-zoom-hover__target img {
  filter: blur(0.2em);
  opacity: 0.75;
}

.u-visually-hidden:not([class*=u-visually-hidden--]) {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
@media only screen and (min-width: 1025px) {
  .u-visually-hidden--p {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
  }
}
@media only screen and (min-width: 768px) {
  .u-visually-hidden--pt {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
  }
}
@media only screen and (max-width: 1024px) {
  .u-visually-hidden--ts {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
  }
}
@media only screen and (max-width: 767px) {
  .u-visually-hidden--s {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
  }
}

@media only screen and (min-width: 1025px) {
  .u-view--ts, .u-view--t {
    display: none !important;
  }
}
@media only screen and (min-width: 768px) {
  .u-view--s {
    display: none !important;
  }
}
@media only screen and (max-width: 1024px) {
  .u-view--p {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  .u-view--pt, .u-view--t {
    display: none !important;
  }
}

:root {
  --transition-duration: 1s;
  --transition-timing: cubic-bezier(0.39, 0.58, 0.57, 1);
  --transform-y: 1.5rem;
}

.u-animation {
  opacity: 0;
  transform: translateY(var(--transform-y));
  transition-property: opacity, transform;
  transition-duration: calc(var(--transition-duration));
  transition-timing-function: var(--transition-timing);
}
.is-1st-scrolled .u-animation.is-inview {
  opacity: 1;
  transform: translateY(0);
}

.u-animation-grp {
  --animation-delay-multiplier: .5;
}
@media only screen and (max-width: 767px) {
  .u-animation-grp {
    --transform-y: 1rem;
    --animation-delay-multiplier: .3;
  }
}
@media (prefers-reduced-motion: reduce) {
  .u-animation-grp {
    --transition-duration: 0.1s;
    --animation-delay-multiplier: 0.1;
  }
}
.u-animation-grp [data-anm] {
  transition-property: opacity, transform;
  transition-duration: var(--transition-duration);
  transition-timing-function: var(--transition-timing);
  opacity: 0;
  transform: translateY(var(--transform-y));
}
.u-animation-grp [data-img-anm] img {
  transition-property: opacity, transform;
  transition-duration: var(--transition-duration);
  transition-timing-function: var(--transition-timing);
  transform: scale(1.1);
  opacity: 0;
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm] img {
  opacity: 1;
  transform: scale(1);
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="0"] img {
  transition-delay: calc(0s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="1"] img {
  transition-delay: calc(1s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="2"] img {
  transition-delay: calc(2s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="3"] img {
  transition-delay: calc(3s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="4"] img {
  transition-delay: calc(4s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="5"] img {
  transition-delay: calc(5s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="6"] img {
  transition-delay: calc(6s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="7"] img {
  transition-delay: calc(7s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="8"] img {
  transition-delay: calc(8s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="9"] img {
  transition-delay: calc(9s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="10"] img {
  transition-delay: calc(10s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="11"] img {
  transition-delay: calc(11s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="12"] img {
  transition-delay: calc(12s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="13"] img {
  transition-delay: calc(13s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="14"] img {
  transition-delay: calc(14s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="15"] img {
  transition-delay: calc(15s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="16"] img {
  transition-delay: calc(16s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="17"] img {
  transition-delay: calc(17s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="18"] img {
  transition-delay: calc(18s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="19"] img {
  transition-delay: calc(19s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-img-anm="20"] img {
  transition-delay: calc(20s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm] {
  transform: none;
  opacity: 1;
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="0"] {
  transition-delay: calc(0s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="1"] {
  transition-delay: calc(1s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="2"] {
  transition-delay: calc(2s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="3"] {
  transition-delay: calc(3s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="4"] {
  transition-delay: calc(4s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="5"] {
  transition-delay: calc(5s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="6"] {
  transition-delay: calc(6s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="7"] {
  transition-delay: calc(7s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="8"] {
  transition-delay: calc(8s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="9"] {
  transition-delay: calc(9s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="10"] {
  transition-delay: calc(10s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="11"] {
  transition-delay: calc(11s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="12"] {
  transition-delay: calc(12s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="13"] {
  transition-delay: calc(13s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="14"] {
  transition-delay: calc(14s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="15"] {
  transition-delay: calc(15s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="16"] {
  transition-delay: calc(16s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="17"] {
  transition-delay: calc(17s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="18"] {
  transition-delay: calc(18s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="19"] {
  transition-delay: calc(19s * var(--animation-delay-multiplier));
}
.is-1st-scrolled .u-animation-grp.is-inview [data-anm="20"] {
  transition-delay: calc(20s * var(--animation-delay-multiplier));
}

@media (prefers-reduced-motion: reduce) {
  .u-animation-grp {
    --transition-duration: 0.1s;
    --animation-delay-multiplier: 0.1;
  }
}

.u-align--c {
  text-align: center;
  justify-content: center;
}
.u-align--c > * {
  text-align: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .u-align--cl {
    text-align: center;
    justify-content: center;
  }
}
@media only screen and (max-width: 767px) {
  .u-align--cl {
    text-align: left;
    justify-content: flex-start;
  }
}
@media only screen and (min-width: 1025px) {
  .u-align--cll {
    text-align: center;
    justify-content: center;
  }
}
@media only screen and (max-width: 1024px) {
  .u-align--cll {
    text-align: left;
    justify-content: flex-start;
  }
}
@media only screen and (min-width: 768px) {
  .u-align--lc {
    text-align: left;
    justify-content: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  .u-align--lc {
    text-align: center;
    justify-content: center;
  }
  .u-align--lc > * {
    text-align: center;
    justify-content: center;
  }
}
@media only screen and (min-width: 1025px) {
  .u-align--lcc {
    text-align: left;
    justify-content: flex-start;
  }
}
@media only screen and (max-width: 1024px) {
  .u-align--lcc {
    text-align: center;
    justify-content: center;
  }
  .u-align--lcc > * {
    text-align: center;
    justify-content: center;
  }
}
.u-align--r {
  text-align: right;
  justify-content: flex-end;
}
@media only screen and (min-width: 768px) {
  .u-align--rc {
    text-align: right;
    justify-content: flex-end;
  }
}
@media only screen and (max-width: 767px) {
  .u-align--rc {
    justify-content: center;
    text-align: center;
  }
}
@media only screen and (min-width: 1025px) {
  .u-align--rcc {
    text-align: right;
    justify-content: flex-end;
  }
}
@media only screen and (max-width: 1024px) {
  .u-align--rcc {
    justify-content: center;
    text-align: center;
  }
}
@media only screen and (min-width: 768px) {
  .u-align--rl {
    text-align: right;
    justify-content: flex-end;
  }
}
@media only screen and (max-width: 767px) {
  .u-align--lr {
    text-align: right;
    justify-content: flex-end;
  }
}

.u-crop {
  display: block;
  overflow: hidden;
}
.u-crop img {
  display: block;
}
.u-crop img {
  margin-bottom: -2px;
}
.u-crop--right {
  display: block;
  overflow: hidden;
}
.u-crop--right img {
  display: block;
}
.u-crop--right img {
  margin-right: -2px;
}
.u-crop--top {
  display: block;
  overflow: hidden;
}
.u-crop--top img {
  display: block;
}
.u-crop--top img {
  margin-top: -2px;
}

.u-radius {
  --image-radius: calc(3 / var(--abi-parent-font-size) * 1rem);
  border-radius: var(--image-radius, calc(3 / var(--abi-parent-font-size) * 1rem));
  overflow: hidden;
}
.u-radius--m, .u-radius--3 {
  --image-radius: calc(3 / var(--abi-parent-font-size) * 1rem);
}
.u-radius--l, .u-radius--5 {
  --image-radius: calc(5 / var(--abi-parent-font-size) * 1rem);
}
.u-radius--circle {
  --image-radius: 1000px;
}
.u-radius--no-left {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.u-radius--no-right {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.u-scrollable-table-notice {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 11;
  margin-top: 0.75em;
}

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

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.o-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: auto;
  width: var(--abi-icon-width);
}
.o-icon--xxx {
  --abi-icon-width: calc(11 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--external {
  --abi-icon-width: calc(12 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--pdf {
  --abi-icon-width: calc(11 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--arrow {
  --abi-icon-width: calc(6 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--down {
  --abi-icon-width: calc(9 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--language {
  --abi-icon-width: calc(15 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--t-arrow {
  --abi-icon-width: calc(5 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--pause {
  --abi-icon-width: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--play {
  --abi-icon-width: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--down {
  --abi-icon-width: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--calendar {
  --abi-icon-width: calc(18 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--select {
  --abi-icon-width: calc(13 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--slider-arrow {
  --abi-icon-width: calc(8 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--rotate90 {
  transform: rotate(90deg);
}
.o-icon--flip-h {
  transform: scaleX(-1);
}
.o-icon--flip-v {
  transform: scaleY(-1);
}
.o-icon--plus, .o-icon--minus {
  --abi-icon-width: calc(14 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--instagram {
  --abi-icon-width: calc(15 / var(--abi-parent-font-size) * 1rem);
}
.o-icon--menu {
  background-color: #fff;
  width: calc(80 / var(--abi-parent-font-size) * 1rem);
  display: flex;
  position: relative;
  padding-right: calc(25 / var(--abi-parent-font-size) * 1rem);
  padding-left: calc(25 / var(--abi-parent-font-size) * 1rem);
  --line-color: var(--abi-color-acc1);
  height: 100%;
}
@media only screen and (max-width: 767px) {
  .o-icon--menu {
    width: calc(80 / var(--abi-parent-font-size) * 1rem);
    padding-right: calc(20 / var(--abi-parent-font-size) * 1rem);
    padding-left: calc(20 / var(--abi-parent-font-size) * 1rem);
  }
}
.o-icon--menu .inn {
  position: relative;
  width: calc(30 / var(--abi-parent-font-size) * 1rem);
  aspect-ratio: 30/20;
  overflow: hidden;
  pointer-events: none;
}
@media only screen and (max-width: 767px) {
  .o-icon--menu .inn {
    width: calc(40 / var(--abi-parent-font-size) * 1rem);
    aspect-ratio: 40/24;
  }
}
.o-icon--menu .inn span {
  height: 1px;
  background-color: var(--line-color);
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  top: 50%;
}
.o-icon--menu .inn::before, .o-icon--menu .inn::after {
  content: "";
  width: 120%;
  display: block;
  height: 1px;
  background-color: var(--line-color);
  position: absolute;
  transition-property: top, transform;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
}
.o-icon--menu .inn::before {
  left: 0;
  top: 0;
  transform-origin: top left;
}
.o-icon--menu .inn::after {
  left: 0;
  bottom: 0;
  transform-origin: bottom left;
}
.o-icon--menu.is-active, .is-modal-menu-show .o-icon--menu {
  --deg: 32deg;
}
@media only screen and (max-width: 767px) {
  .o-icon--menu.is-active, .is-modal-menu-show .o-icon--menu {
    --deg: 29deg;
  }
}
.o-icon--menu.is-active .inn span, .is-modal-menu-show .o-icon--menu .inn span {
  display: none;
}
.o-icon--menu.is-active .inn::before, .is-modal-menu-show .o-icon--menu .inn::before {
  transform: rotate(calc(var(--deg)));
}
.o-icon--menu.is-active .inn::after, .is-modal-menu-show .o-icon--menu .inn::after {
  transform: rotate(calc(var(--deg) * -1));
}
.o-icon--play {
  --color: #fff;
  color: var(--color);
  fill: var(--color);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.o-icon--play-icon {
  border: 1px solid var(--color);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: calc(40 / var(--abi-parent-font-size) * 1rem);
  aspect-ratio: 1;
  border-radius: 100px;
  margin-right: auto;
  margin-left: auto;
}
.o-icon--play-icon svg {
  width: calc(20 / 40 * 100%);
}
.o-icon--play-text {
  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: 22;
  line-height: 1;
  width: 100%;
  text-align: center;
  margin-top: 1em;
  width: calc(100% + 2em);
  margin-right: -1em;
  margin-left: -1em;
}
.o-icon--category {
  width: calc(32 / var(--abi-parent-font-size) * 1rem);
  aspect-ratio: 1;
  background-color: var(--abi-color-category, black);
  border-radius: 100px;
  display: flex;
  align-items: center;
  color: #fff;
  fill: #fff;
}
.o-icon--category svg {
  width: calc(24 / 32 * 100%);
  height: auto;
}
/* ===================================================================
CSS information

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

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.l-breadcrumb {
  margin-right: auto;
  margin-left: auto;
  --abi-container-width: var(--abi-content-0);
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .l-breadcrumb {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-1);
  }
}
@media only screen and (min-width: 768px) {
  .l-breadcrumb {
    width: calc(1080 / 1440 * 100%);
  }
}
@media only screen and (min-width: 768px) {
  .l-breadcrumb {
    --abi-target-font-size: 11;
  }
}
.l-breadcrumb {
  position: relative;
  margin-top: calc(90 / var(--abi-parent-font-size) * 1rem);
  min-height: calc(60 / var(--abi-parent-font-size) * 1rem);
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .l-breadcrumb {
    padding: 1em 0;
    margin-top: calc(80 / var(--abi-parent-font-size) * 1rem);
  }
}
.l-breadcrumb .c-breadcrumb .o-icon--arrow {
  --abi-icon-width: calc(6.83 / var(--abi-parent-font-size) * 1rem);
  margin-right: calc(15 / var(--abi-parent-font-size) * 1rem);
  margin-left: calc(15 / var(--abi-parent-font-size) * 1rem);
  transform: translateY(0.25em);
}
.l-breadcrumb .c-breadcrumb__item {
  display: inline;
}
.l-breadcrumb .c-breadcrumb__item .c-breadcrumb__link {
  color: inherit;
  padding: 0.5em 0;
}
.l-breadcrumb .c-breadcrumb__item .o-icon {
  display: inline-flex;
}

.l-footer__main {
  margin-right: auto;
  margin-left: auto;
  --abi-container-width: var(--abi-content-0);
  border: 1px solid var(--abi-color-black);
  box-sizing: content-box;
  border-radius: calc(12 / var(--abi-parent-font-size) * 1rem);
  flex-wrap: wrap;
  display: flex;
  margin-top: calc(60 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (min-width: 1025px) {
  .l-footer__main {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-1);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) {
  .l-footer__main {
    max-width: calc(var(--abi-child-width) * 1px * (13 + 2 + 0) / 13);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1025px) and (max-width: 1440px) {
  .l-footer__main {
    max-width: calc(var(--abi-child-width) * 1px);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-footer__main {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-1);
  }
}
@media only screen and (max-width: 767px) {
  .l-footer__main {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-1);
  }
}
@media only screen and (min-width: 768px) {
  .l-footer__main {
    padding-top: calc(20 / var(--abi-parent-font-size) * 1rem);
    padding-bottom: calc(20 / var(--abi-parent-font-size) * 1rem);
    min-height: calc(270 / var(--abi-parent-font-size) * 1rem);
  }
}
@media only screen and (max-width: 767px) {
  .l-footer__main {
    flex-direction: column;
    margin-top: 4em;
    padding-top: 4em;
    padding-bottom: 4em;
  }
}
.l-footer__box-l {
  flex-shrink: 0;
  width: calc(300 / 1320 * 100%);
  position: relative;
  display: flex;
  align-content: center;
  flex-wrap: wrap;
  border-right: 1px solid var(--abi-color-black);
}
@media only screen and (max-width: 767px) {
  .l-footer__box-l {
    width: calc(372 / 400 * 100%);
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 2em;
    padding-bottom: 2em;
    border-right: 0;
    border-bottom: 1px solid var(--abi-color-black);
  }
}
.l-footer__logo {
  width: 100%;
  margin-bottom: 0;
}
@media only screen and (max-width: 767px) {
  .l-footer__logo {
    width: calc(187 / var(--abi-parent-font-size) * 1rem);
    margin-right: auto;
    margin-left: auto;
  }
}
.l-footer__logo-link {
  width: 100%;
  display: block;
  text-decoration: none;
}
.l-footer__logo-image {
  width: calc(107 / var(--abi-parent-font-size) * 1rem);
  display: block;
  margin-inline: auto;
}
@media only screen and (max-width: 767px) {
  .l-footer__logo-image {
    width: calc(87 / var(--abi-parent-font-size) * 1rem);
  }
}
.l-footer__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(25 / var(--abi-parent-font-size) * 1rem);
}
.l-footer__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;
  font-weight: bold;
  line-height: 1;
}
.l-footer__sub {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: calc(20 / var(--abi-parent-font-size) * 1rem);
}
.l-footer__sub-item {
  display: flex;
  align-items: center;
  padding: calc(10 / var(--abi-parent-font-size) * 1rem) calc(25 / var(--abi-parent-font-size) * 1rem);
  position: relative;
  text-decoration: none;
}
.l-footer__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%);
}
.l-footer__sub-contact {
  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;
}
.l-footer__box-r {
  padding-left: calc(42 / 1060 * 100%);
  width: calc(1020 / 1320 * 100%);
  display: flex;
  flex-wrap: wrap;
  align-content: center;
}
@media only screen and (max-width: 767px) {
  .l-footer__box-r {
    width: calc(344 / 400 * 100%);
    margin-right: auto;
    margin-left: auto;
    padding-left: 0;
    padding-right: calc(14 / 372 * 100%);
    padding-left: calc(14 / 372 * 100%);
  }
}
.l-footer__nav {
  margin-bottom: calc(40 / var(--abi-parent-font-size) * 1rem);
  width: 100%;
  max-width: calc(820 / var(--abi-parent-font-size) * 1rem);
  --item-vertical-padding: calc(9 / 13 / (13 / 13) * 1em);
  --item-horizontal-padding: calc(24 / 13 / (13 / 13) * 1em);
}
@media only screen and (max-width: 767px) {
  .l-footer__nav {
    --item-vertical-padding: calc(12 / 13 / (13 / 13) * 1em);
    --item-horizontal-padding: calc(15 / 13 / (13 / 13) * 1em);
  }
}
.l-footer__nav-list {
  display: flex;
  flex-wrap: wrap;
  margin-left: calc(var(--item-horizontal-padding) * -1);
  margin-top: calc(var(--item-vertical-padding) * -1);
  margin-bottom: calc(var(--item-vertical-padding) * -1);
}
.l-footer__nav-item:not(:last-child) {
  position: relative;
}
.l-footer__nav-item:not(:last-child)::before {
  content: "";
  display: block;
  width: 1px;
  background-color: var(--abi-color-black);
  position: absolute;
  height: calc(18 / 13 / (13 / 13) * 1em);
  top: 50%;
  transform: translateY(-50%);
  right: 0;
}
.l-footer__nav-link {
  font-family: var(--abi-font-jp-serif);
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 13;
  line-height: 1;
  display: block;
  font-weight: bold;
  padding: var(--item-vertical-padding) var(--item-horizontal-padding);
  text-decoration: none;
}
.l-footer__address {
  width: 100%;
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  .l-footer__address {
    text-align: center;
  }
}
.l-footer__address-top {
  display: block;
}
.l-footer__address-bottom {
  display: flex;
  gap: 1em;
  margin-top: calc(10 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .l-footer__address-bottom {
    justify-content: center;
  }
}
.l-footer__address-bottom .item {
  display: block;
}
.l-footer__copyright {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 12;
  height: calc(50 / var(--abi-parent-font-size) * 1rem);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .l-footer__copyright {
    height: 6rem;
  }
}

/**************************\
	Basic Modal Styles
\**************************/
.l-modal {
  --close-size: calc(40 / var(--abi-parent-font-size) * 1rem);
}
.l-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(var(--abi-color-black-rgb), .8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}
.l-modal__container {
  height: calc(var(--vh) * 100);
  margin-left: auto;
  margin-right: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.l-modal__main--movie {
  width: 100%;
  position: relative;
}
.l-modal__main--movie figure {
  margin-right: auto;
  margin-left: auto;
  --abi-container-width: var(--abi-content-0);
}
@media only screen and (min-width: 1025px) {
  .l-modal__main--movie figure {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-3);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) {
  .l-modal__main--movie figure {
    max-width: calc(var(--abi-child-width) * 1px * (13 + 2 + 0) / 13);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1025px) and (max-width: 1440px) {
  .l-modal__main--movie figure {
    max-width: calc(var(--abi-child-width) * 1px);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-modal__main--movie figure {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-3);
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__main--movie figure {
    width: calc(var(--abi-child-width) / var(--abi-container-width) * 100%);
    --abi-child-width: var(--abi-content-1);
  }
}
.l-modal__main--movie video {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .l-modal {
    --close-size: 2rem;
  }
}
.l-modal__close {
  width: var(--close-size);
  aspect-ratio: 1;
  position: absolute;
  right: calc(14 / 428 * 100%);
  bottom: calc(100% + 1em);
}
.l-modal__close::before, .l-modal__close::after {
  content: "";
  display: block;
  width: 141.4%;
  height: 1px;
  background-color: var(--abi-color-black);
  background-color: #fff;
  position: absolute;
  left: 50%;
  top: 50%;
  transform-origin: 0 0;
}
.l-modal__close::before {
  transform: rotate(45deg) translateX(-50%);
}
.l-modal__close::after {
  transform: rotate(-45deg) translateX(-50%);
}
.l-modal__close--black {
  --close-color: black;
}

/**************************\
  Demo Animation Style
\**************************/
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(15%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-10%);
  }
}
.l-modal {
  display: none;
}
.l-modal.is-open {
  display: block;
  position: relative;
  z-index: 1000;
}
.l-modal .modal__container {
  will-change: transform;
}
.l-modal .modal__overlay {
  will-change: transform;
}
.l-modal[aria-hidden=false] .l-modal__overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.l-modal[aria-hidden=true] .l-modal__overlay {
  animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.l-modal .l-modal__container,
.l-modal .l-modal__overlay {
  will-change: transform;
}

#main {
  opacity: 1;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: var(--focus-outline);
}

.mouse .over, .mouse .u-over {
  transition: opacity 0.15s ease-in;
}
.mouse .over:hover, .touch .over.touchstart, .mouse .u-over:hover, .touch .u-over.touchstart {
  opacity: 0.7;
}
.touch .over, .touch .u-over {
  -webkit-tap-highlight-color: transparent;
}
.touch .over.touchend, .touch .u-over.touchend {
  transition-delay: 200ms;
}

.jump_menu {
  display: block;
  left: 0;
  top: 0;
  position: fixed;
  transform: translate(-100px, -100px);
  z-index: 9999;
  width: 18rem;
}
.jump_menu button, .jump_menu a {
  width: 100%;
  display: block;
  padding: 1em;
  background-color: black;
  color: #fff;
  text-align: left;
  text-decoration: none;
}
.jump_menu:focus-within {
  transform: none;
}

.flatpickr-calendar {
  letter-spacing: 0;
}
.flatpickr-calendar:not(.open) {
  display: none !important;
}

.c-hr {
  width: 100%;
  height: 1px;
  margin-top: calc(120 / var(--abi-parent-font-size) * 1rem);
  margin-bottom: calc(120 / var(--abi-parent-font-size) * 1rem);
  background-color: var(--abi-color-acc1);
}
@media only screen and (max-width: 767px) {
  .c-hr {
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
}/*# sourceMappingURL=common.css.map */