@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 : 汎用設定
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.l-breadcrumb {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  width: calc(1360 / 1440 * 100%);
  margin-inline: auto;
}
@media only screen and (min-width: 1025px) {
  .l-breadcrumb {
    --abi-target-font-size: 13;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-breadcrumb {
    --abi-target-font-size: 13;
  }
}
@media only screen and (max-width: 767px) {
  .l-breadcrumb {
    --abi-target-font-size: 17;
  }
}
.l-breadcrumb {
  margin-top: calc(calc(30 / var(--abi-parent-font-size) * 1rem) * var(--abi-value-zoom));
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.l-breadcrumb .c-breadcrumb .o-icon--breadcrumb-arrow {
  --abi-icon-width: calc(10 / var(--abi-parent-font-size) * 1rem);
  margin-inline: calc(calc(24 / var(--abi-parent-font-size) * 1rem) * var(--abi-value-zoom));
}
.l-breadcrumb .c-breadcrumb__item {
  display: inline;
}
.l-breadcrumb .c-breadcrumb__item .c-breadcrumb__link {
  color: inherit;
  padding: .5em 0;
}
.l-breadcrumb .c-breadcrumb__item .o-icon {
  display: inline-flex;
}

.l-header {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}

.p-home-kv {
  width: 100%;
  position: relative;
}
@media only screen and (max-width: 1024px) {
  .p-home-kv {
    width: 100%;
    overflow: hidden;
  }
}
.p-home-kv__figure {
  width: 100%;
  height: calc(var(--vh) * 100 - var(--gnav-height));
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-kv__figure {
    height: auto;
    aspect-ratio: 768 / 432;
  }
}
.p-home-kv__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-home-kv__image {
  overflow: hidden;
}
.p-home-kv__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-lower-kv {
  margin-inline: auto;
  width: calc(1360 / 1440 * 100%);
  position: relative;
}
@media only screen and (max-width: 767px) {
  .p-lower-kv {
    width: calc(388 / 428 * 100%);
  }
}
@media only screen and (min-width: 1025px) {
  .p-lower-kv__image + .p-lower-kv__title {
    margin-top: calc(70 / var(--abi-parent-font-size) * 1rem);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-kv__image + .p-lower-kv__title {
    margin-top: calc(70 / var(--abi-parent-font-size) * 1rem);
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-kv__image + .p-lower-kv__title {
    margin-top: calc(26 / var(--abi-parent-font-size) * 1rem);
  }
}
.p-lower-kv__title {
  margin-top: calc(calc(160 / var(--abi-parent-font-size) * 1rem) * var(--abi-value-zoom));
  padding-bottom: calc(calc(35 / var(--abi-parent-font-size) * 1rem) * var(--abi-value-zoom));
  flex-wrap: wrap;
  display: flex;
  text-transform: uppercase;
}
.p-lower-kv__title::after {
  content: "";
  display: block;
  --border-top-width: 2px;
  --border-margin: 4px;
  --border-bottom-width: 3px;
  border-top: var(--border-top-width) solid black;
  height: var(--border-margin);
  border-bottom: var(--border-bottom-width) solid black;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  right: 0;
}
@media only screen and (max-width: 767px) {
  .p-lower-kv__title .c-title__en {
    font-size: calc(56 / var(--abi-parent-font-size) * 1rem) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-kv__title .c-title__jp {
    font-size: calc(28 / var(--abi-parent-font-size) * 1rem) !important;
    margin-top: 1rem !important;
  }
}

.o-gnav {
  height: var(--gnav-height);
  display: flex;
  background-color: #fff;
  align-items: center;
  order: -1;
  z-index: 999;
  padding-right: calc(40 / 1440 * 100%);
  padding-left: calc(40 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .o-gnav {
    padding-right: calc(20 / 428 * 100%);
    padding-left: calc(20 / 428 * 100%);
  }
}
.o-gnav__logo {
  margin-left: 0;
  margin-right: auto;
  width: calc(324 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .o-gnav__logo {
    width: calc(288 / 360 * 100%);
  }
}
.o-gnav__logo-link {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 12;
  font-family: var(--abi-font-en);
  font-optical-sizing: auto;
  display: flex;
  width: 100%;
  text-decoration: none;
  align-items: baseline;
}
.o-gnav__btn {
  margin-right: 0;
  margin-left: auto;
}
.o-gnav__btn .c-btn__link {
  font-size: calc(var(--abi-target-font-size) / var(--abi-parent-font-size) * 1rem);
  --abi-target-font-size: 12;
  min-height: calc(38 / var(--abi-parent-font-size) * 1rem);
  min-width: auto;
  width: calc(190 / var(--abi-parent-font-size) * 1rem);
  padding-right: calc(10 / var(--abi-parent-font-size) * 1rem);
  padding-left: calc(10 / var(--abi-parent-font-size) * 1rem);
}
@media only screen and (min-width: 768px) {
  .o-gnav__btn .c-btn__link {
    padding-top: 5px;
    padding-bottom: 5px;
  }
}
.o-gnav__menu {
  height: 100%;
  margin-right: 0;
  margin-left: calc(24 / var(--abi-parent-font-size) * 1rem);
}
.o-gnav--sticky {
  transition-property: transform, opacity;
  transition-duration: .15s;
  transition-timing-function: ease-out;
  transform: translateY(-100%);
  opacity: 0;
}
.is-parts-sticky .o-gnav--sticky {
  opacity: 1;
  left: 0;
  right: 0;
  top: 0;
  position: fixed;
  transform: none;
}

:root {
  --abi-content-0: 1440;
  --abi-content-1: 1360;
  --abi-content-2: 1260;
  --abi-content-3: 1100;
  --abi-content-4: 900;
  --abi-root-font-size: 15;
  --abi-parent-font-size: 15;
  --abi-target-font-size: 15;
  --abi-color-body: #101010;
  --abi-color-body-rgb: 16, 16, 16;
  --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: #000;
  --abi-color-cv-rgb: 0, 0, 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: #000;
  --abi-color-primary-rgb: 0, 0, 0;
  --abi-color-alert: #A91A1A;
  --abi-color-alert-rgb: 169, 26, 26;
  --abi-color-10: #101010;
  --abi-color-10-rgb: 16, 16, 16;
  --abi-color-f: #FFF;
  --abi-color-f-rgb: 255, 255, 255;
  --abi-color-e9: #E9E9E9;
  --abi-color-e9-rgb: 233, 233, 233;
  --abi-color-f3: #F3F3F3;
  --abi-color-f3-rgb: 243, 243, 243;
  --abi-color-1e: #1E1E1E;
  --abi-color-1e-rgb: 30, 30, 30;
  --abi-color-b: #BBB;
  --abi-color-b-rgb: 187, 187, 187;
  --abi-color-e5: #E5E5E5;
  --abi-color-e5-rgb: 229, 229, 229;
  --abi-color-bg-dark: #101010;
  --abi-color-bg-light: #fdfdfd;
  --abi-bg-noize: url("../images/common/bg_noize.png") repeat center top;
  --abi-font-jp-serif: Shippori Mincho, 游明朝, 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-title: var(--abi-font-jp-serif);
  --abi-font-jp-body: var(--abi-font-jp-sans-serif);
  --abi-font-en: Cormorant Garamond, serif;
  --abi-font-num: var(--abi-font-en);
  --abi-icon-width: 1em;
  --focus-outline: 3px black solid;
  --gnav-height: calc(56 / var(--abi-parent-font-size) * 1rem);
  --abi-value-zoom: 1;
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-content-0: 428;
    --abi-content-1: 388;
    --abi-content-2: 348;
    --abi-content-3: 300;
    --abi-content-4: 300;
  }
}
@media only screen and (min-width: 1441px) {
  :root {
    --abi-base-font-size: 16;
  }
}
@media only screen and (min-width: 1441px) and (max-width: 1600px) {
  :root {
    --abi-base-font-size: 15.5;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1440px) {
  :root {
    --abi-base-font-size: 15;
  }
}
@media only screen and (min-width: 897px) and (max-width: 1024px) {
  :root {
    --abi-base-font-size: 15;
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  :root {
    --abi-base-font-size: 14;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-parent-font-size: 18;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --gnav-height: calc(71 / var(--abi-parent-font-size) * 1rem);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  :root {
    --abi-value-zoom: 0.75;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --abi-value-zoom: 0.9;
  }
}

[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="noise"] {
  --abi-body-bg: var(--abi-bg-noize);
  background: var(--abi-body-bg);
}

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;
}

#svg_defs,
#svg_defs1,
#svg_defs2,
#svg_defs3,
#svg_defs4,
#svg_defs99 {
  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;
}
