@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 {
  width: 100%;
  border-bottom: 1px solid var(--tsuruga-color-gray-c8);
}
.l-breadcrumb > .inner {
  margin-right: auto;
  margin-left: auto;
  --tsuruga-container-width: var(--tsuruga-content-0);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: calc(60 / var(--tsuruga-parent-font-size) * 1rem);
  position: relative;
}
@media only screen and (min-width: 768px) {
  .l-breadcrumb > .inner {
    width: calc(1760 / 1920 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .l-breadcrumb > .inner {
    width: calc(var(--tsuruga-child-width) / var(--tsuruga-container-width) * 100%);
    --tsuruga-child-width: var(--tsuruga-content-1);
  }
}
.l-breadcrumb .c-breadcrumb .o-icon--btn-arrow {
  --tsuruga--icon-width: calc(9 / var(--tsuruga-parent-font-size) * 1rem);
  margin-right: calc(17 / var(--tsuruga-parent-font-size) * 1rem);
  margin-left: calc(17 / var(--tsuruga-parent-font-size) * 1rem);
}
.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;
  margin-right: calc(12 / var(--tsuruga-parent-font-size) * 1rem);
}

@keyframes fall {
  0% {
    translate: 0 -100%;
  }
  100% {
    translate: 0 200%;
  }
}
.l-header {
  position: relative;
  flex-wrap: wrap;
  display: flex;
  --logo-width: calc(180 / 1440 * 100%);
  --image-width: calc(1260 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .l-header {
    --logo-width: 100%;
  }
}
.l-header .l-header__box {
  display: flex;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__box {
    width: var(--logo-width);
    position: relative;
    z-index: 1;
  }
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__box > .inner {
    display: flex;
    flex-direction: column;
    width: calc(87 / var(--tsuruga-parent-font-size) * 1rem);
    margin-top: calc(45 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.l-header .l-header__box-title {
  margin-right: auto;
  margin-left: auto;
  --tsuruga-container-width: var(--tsuruga-content-0);
  position: absolute;
  top: 50%;
  left: calc(400 / 1920 * 100%);
  right: calc(400 / 1920 * 100%);
  display: flex;
  align-items: center;
  height: 0;
}
@media only screen and (min-width: 1025px) {
  .l-header .l-header__box-title {
    width: calc(var(--tsuruga-child-width) / var(--tsuruga-container-width) * 100%);
    --tsuruga-child-width: var(--tsuruga-content-5);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-header .l-header__box-title {
    width: calc(var(--tsuruga-child-width) / var(--tsuruga-container-width) * 100%);
    --tsuruga-child-width: var(--tsuruga-content-2);
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__box-title {
    width: calc(var(--tsuruga-child-width) / var(--tsuruga-container-width) * 100%);
    --tsuruga-child-width: var(--tsuruga-content-2);
  }
}
.l-header .l-header__box-title[data-tsuruga-theme="dark"] {
  background-color: transparent;
}
.l-header .l-header__kv {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.l-header .l-header__kv__box-catch {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  z-index: 2;
  top: 50%;
  height: 0;
  left: 0;
  right: 0;
}
.l-header .l-header__kv__box-catch > .inner {
  position: relative;
}
.l-header .l-header__kv__catch {
  font-size: calc(var(--tsuruga-target-font-size) / var(--tsuruga-parent-font-size) * 1rem);
  font-weight: 700;
  line-height: 1.9;
  letter-spacing: .14em;
  display: flex;
  flex-wrap: wrap;
  width: 13.25em;
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__kv__catch {
    --tsuruga-target-font-size: 42;
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch {
    --tsuruga-target-font-size: 25;
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch {
    width: fit-content;
    flex-wrap: nowrap;
    flex-direction: column;
  }
}
.l-header .l-header__kv__catch .line {
  border-bottom: 1px solid #fff;
  display: block;
  width: fit-content;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch .line {
    padding-left: calc(10 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.l-header .l-header__kv__catch em {
  position: relative;
  --deco-width: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
  padding-left: var(--deco-width);
  padding-right: var(--deco-width);
  display: inline-flex;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch em {
    --deco-width: calc(10 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.l-header .l-header__kv__catch em span {
  line-height: 1em;
}
.l-header .l-header__kv__catch em::before, .l-header .l-header__kv__catch em::after {
  font-size: calc(var(--tsuruga-target-font-size) / var(--tsuruga-parent-font-size) * 1rem);
  opacity: .5;
  display: block;
  width: var(--deco-width);
  height: .5em;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__kv__catch em::before, .l-header .l-header__kv__catch em::after {
    --tsuruga-target-font-size: 30;
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch em::before, .l-header .l-header__kv__catch em::after {
    --tsuruga-target-font-size: 22;
  }
}
.l-header .l-header__kv__catch em::before {
  content: "“";
  left: 0;
  bottom: calc(100% - .25em);
}
.l-header .l-header__kv__catch em::after {
  content: "”";
  right: 0;
  top: calc(100% + .25em);
  top: calc(100%);
}
.l-header .l-header__kv__catch2 {
  display: flex;
  align-items: center;
  height: calc(16 / var(--tsuruga-parent-font-size) * 1rem);
  margin-top: calc(35 / var(--tsuruga-parent-font-size) * 1rem);
  padding-left: calc(10 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__catch2 {
    margin-top: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.l-header .l-header__kv__en {
  font-family: var(--tsuruga-font-en);
  font-size: calc(var(--tsuruga-target-font-size) / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (min-width: 768px) {
  .l-header .l-header__kv__en {
    --tsuruga-target-font-size: 16;
  }
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__en {
    --tsuruga-target-font-size: 13;
  }
}
.l-header .l-header__kv__cursive {
  margin-top: 1em;
  width: calc(178 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__cursive {
    width: calc(120 / var(--tsuruga-parent-font-size) * 1rem);
    position: absolute;
    left: calc(100% - 3em);
    bottom: calc(-1em);
  }
}
.l-header .l-header__kv__image {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__image img {
    object-fit: cover;
    left: 0;
    width: 100%;
    height: 100%;
  }
}
.l-header .l-header__kv__image--homepage {
  height: calc(var(--vh) * 100);
  width: 100%;
  overflow: hidden;
}
.l-header .l-header__kv__image--homepage .c-slider__element {
  height: 100%;
}
.l-header .l-header__kv__image--homepage .c-slider__element img {
  object-fit: cover;
  height: 100%;
  transform: scale(1.2);
  transition: 7s 1s ease-out;
}
.l-header .l-header__kv__image--homepage .c-slider__element .swiper-slide[class*=-active] img {
  transform: scale(1);
  transition-delay: 0s;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__image--lower img {
    aspect-ratio: 300 / 200;
  }
}
.l-header .l-header__kv__ctrls {
  z-index: 9;
  position: absolute;
  right: calc(60 / var(--tsuruga-parent-font-size) * 1rem);
  bottom: 0;
  left: auto;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__ctrls {
    right: 1.5em;
  }
}
.l-header .l-header__kv__ctrls .down {
  color: #fff;
  width: 1px;
  background-color: rgba(255, 255, 255, 0.5);
  height: calc(260 / var(--tsuruga-parent-font-size) * 1rem);
  display: flex;
  margin-right: auto;
  margin-left: auto;
  margin-top: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
  position: relative;
}
@media only screen and (max-width: 767px) {
  .l-header .l-header__kv__ctrls .down {
    height: calc(150 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.l-header .l-header__kv__ctrls .down::before {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 100px;
  position: absolute;
  bottom: 100%;
  left: 100%;
  background-color: #fff;
  transform: translateX(-3px);
}
.l-header .l-header__kv__ctrls .down .line {
  overflow: hidden;
  display: block;
  width: 100%;
  height: 100%;
}
.l-header .l-header__kv__ctrls .down .line::after {
  content: "";
  display: block;
  height: 50%;
  width: 100%;
  background-color: #fff;
  animation: 3s cubic-bezier(0.47, 0.32, 0.23, 0.55) 0.6s infinite fall;
}
.l-header .l-header__kv__ctrls .down .text {
  font-family: var(--tsuruga-font-en);
  writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  text-align: left;
  display: inline-block;
  position: absolute;
  line-height: 1;
  left: calc(100% + calc(5.5 / var(--tsuruga-parent-font-size) * 1rem));
  top: 25%;
  transform: translateY(-50%);
}
.l-header .l-header__kv .c-slider__pagination {
  flex-direction: column;
}

.o-gnav {
  z-index: 3;
  width: 100%;
}
.o-gnav--normal {
  position: absolute;
  top: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
  left: 0;
  right: 0;
}
.o-gnav--normal[data-tsuruga-theme="dark"] {
  background: transparent;
}
.o-gnav--normal .o-gnav__menu .o-icon--menu {
  --line-color: #fff;
}
.o-gnav--sticky {
  transform: translateY(calc(-100% - var(--gnav-sticky-position)));
  position: fixed;
  top: var(--gnav-sticky-position);
  right: 0;
  transition-property: transform, opacity;
  transition-duration: .2s;
  transition-timing-function: ease-out;
  z-index: 999;
}
.is-parts-sticky .o-gnav--sticky {
  transform: translateY(0);
  opacity: 1;
}
.o-gnav--sticky .o-gnav__box-r {
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 0 calc(30 / var(--tsuruga-parent-font-size) * 1rem) rgba(0, 44, 81, 0.1);
  backdrop-filter: blur(calc(30 / var(--tsuruga-parent-font-size) * 1rem));
  overflow: hidden;
}
.o-gnav--modal {
  position: fixed;
  top: var(--gnav-sticky-position);
  right: 0;
  transition-property: transform, opacity;
  transition-duration: .2s;
  transition-timing-function: ease-out;
  z-index: 1001;
  transform: translateY(0);
  opacity: 1;
}
.o-gnav--modal .o-gnav__box-r {
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 0 calc(30 / var(--tsuruga-parent-font-size) * 1rem) rgba(0, 44, 81, 0.1);
  backdrop-filter: blur(calc(30 / var(--tsuruga-parent-font-size) * 1rem));
  overflow: hidden;
}
.o-gnav--modal2 {
  z-index: 1001 !important;
}
.o-gnav > .inner {
  height: var(--gnav-height);
  align-items: center;
  display: flex;
}
.o-gnav__box-l {
  display: flex;
  align-items: center;
  margin-left: 0;
  margin-right: auto;
  padding-left: calc(30 / 1920 * 100%);
}
@media only screen and (max-width: 767px) {
  .o-gnav__box-l {
    padding-left: calc(30 / 390 * 100%);
  }
}
.o-gnav__logo {
  order: -1;
}
.o-gnav__logo a {
  display: block;
  padding-left: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  padding-right: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  margin-left: calc(calc(30 / var(--tsuruga-parent-font-size) * 1rem) * -1);
  box-sizing: content-box;
  width: calc(90 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .o-gnav__logo a {
    padding-right: calc(10 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
@media only screen and (max-width: 767px) {
  .o-gnav__logo a {
    width: calc(70 / var(--tsuruga-parent-font-size) * 1rem);
    padding-right: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.o-gnav__seo {
  font-size: calc(var(--tsuruga-target-font-size) / var(--tsuruga-parent-font-size) * 1rem);
  --tsuruga-target-font-size: 12;
  font-weight: normal;
  line-height: 1.2;
  width: 15em;
}
@media only screen and (max-width: 767px) {
  .o-gnav__seo {
    width: 10em;
  }
}
.o-gnav__box-r {
  border-top-left-radius: 100px;
  border-bottom-left-radius: 100px;
  padding-left: calc(50 / var(--tsuruga-parent-font-size) * 1rem);
  display: flex;
  align-items: center;
  margin-right: 0;
  margin-left: auto;
  padding-right: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  padding-top: calc(15 / var(--tsuruga-parent-font-size) * 1rem);
  padding-bottom: calc(15 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .o-gnav__box-r {
    padding-left: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
@media only screen and (max-width: 767px) {
  .o-gnav__box-r {
    width: calc(155 / var(--tsuruga-parent-font-size) * 1rem);
    height: var(--gnav-height);
    padding-top: 0;
    padding-bottom: 0;
    padding-left: calc(28 / var(--tsuruga-parent-font-size) * 1rem);
    padding-right: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.o-gnav__nav {
  margin-right: 0;
}
.o-gnav__nav__list {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}
.o-gnav__nav__item {
  height: 100%;
}
@media only screen and (max-width: 1300px) {
  .o-gnav__nav__item--concept {
    width: 10em;
  }
}
.o-gnav__nav__link {
  padding: 0 calc(12.5 / var(--tsuruga-parent-font-size) * 1rem);
  display: block;
  text-decoration: none;
  height: 100%;
  line-height: 1.3;
}
.o-gnav__nav__link .o-gnav__nav__arrow {
  opacity: 0;
}
.o-gnav__nav__link:hover .o-gnav__nav__arrow, .o-gnav__nav__link[aria-current="page"] .o-gnav__nav__arrow {
  opacity: 1;
}
.o-gnav__nav__arrow {
  width: calc(10 / var(--tsuruga-parent-font-size) * 1rem);
  bottom: 100%;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  opacity: 0;
  transition-property: opacity;
  transition-duration: .4s;
  transition-timing-function: ease-out;
}
.o-gnav__nav__arrow .o-icon {
  width: calc(9 / 10 * 100%);
}
.o-gnav__nav__text {
  position: relative;
}
.o-gnav__menu {
  margin-right: 0;
  display: flex;
  align-items: center;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .o-gnav__menu {
    order: 2;
    margin-left: calc(30 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
.o-gnav__menu__text {
  font-family: var(--tsuruga-font-en);
  margin-right: calc(12 / var(--tsuruga-parent-font-size) * 1rem);
}
.o-gnav__btn {
  margin-right: 0;
  margin-left: calc(6 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .o-gnav__btn {
    order: 1;
  }
}
.o-gnav__btn .c-btn__link {
  backdrop-filter: blur(6px);
}
@media only screen and (min-width: 1025px) and (max-width: 1440px) {
  .o-gnav__btn .c-btn__link {
    min-width: calc(200 / var(--tsuruga-parent-font-size) * 1rem);
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .o-gnav__btn .c-btn__link {
    min-width: auto;
  }
}
.o-gnav[data-tsuruga-theme="dark"] .c-btn--primary {
  --tsuruga-btn-active-color: #fff;
}

:root {
  --tsuruga-content-0: 1920;
  --tsuruga-content-1: 1760;
  --tsuruga-content-2: 1600;
  --tsuruga-content-3: 1440;
  --tsuruga-content-4: 1280;
  --tsuruga-content-5: 1120;
  --tsuruga-content-6: 960;
  --tsuruga-root-font-size: 13;
  --tsuruga-parent-font-size: 16;
  --tsuruga-target-font-size: 13;
  --tsuruga-color-txt-blue: #002C51;
  --tsuruga-color-txt-blue-rgb: 0, 44, 81;
  --tsuruga-color-body: #002C51;
  --tsuruga-color-body-rgb: 0, 44, 81;
  --tsuruga-color-title: #002C51;
  --tsuruga-color-title-rgb: 0, 44, 81;
  --tsuruga-color-cv: orange;
  --tsuruga-color-cv-rgb: 255, 165, 0;
  --tsuruga-color-cv2: gold;
  --tsuruga-color-cv2-rgb: 255, 215, 0;
  --tsuruga-color-accent: #346896;
  --tsuruga-color-accent-rgb: 52, 104, 150;
  --tsuruga-color-accent2: #D0BA90;
  --tsuruga-color-accent2-rgb: 208, 186, 144;
  --tsuruga-color-primary: skyblue;
  --tsuruga-color-primary-rgb: 135, 206, 235;
  --tsuruga-color-alert: red;
  --tsuruga-color-alert-rgb: 255, 0, 0;
  --tsuruga-color-gray-f2: #f2f2f2;
  --tsuruga-color-gray-f2-rgb: 242, 242, 242;
  --tsuruga-color-gray-e7: #e7e7e7;
  --tsuruga-color-gray-e7-rgb: 231, 231, 231;
  --tsuruga-color-gray-c: #cccccc;
  --tsuruga-color-gray-c-rgb: 204, 204, 204;
  --tsuruga-color-gray-ca: #cacaca;
  --tsuruga-color-gray-ca-rgb: 202, 202, 202;
  --tsuruga-color-gray-c8: #c8c8c8;
  --tsuruga-color-gray-c8-rgb: 200, 200, 200;
  --tsuruga-color-gray-8: #888888;
  --tsuruga-color-gray-8-rgb: 136, 136, 136;
  --tsuruga-color-gray-7: #777777;
  --tsuruga-color-gray-7-rgb: 119, 119, 119;
  --tsuruga-color-gray-5: #555555;
  --tsuruga-color-gray-5-rgb: 85, 85, 85;
  --tsuruga-color-gray-43: #434343;
  --tsuruga-color-gray-43-rgb: 67, 67, 67;
  --tsuruga-color-gray-2f: #2f2f2f;
  --tsuruga-color-gray-2f-rgb: 47, 47, 47;
  --tsuruga-color-gray-5b: #2f2f2f;
  --tsuruga-color-gray-5b-rgb: 47, 47, 47;
  --tsuruga-color-line-gray: #c8c8c8;
  --tsuruga-color-line-gray-rgb: 200, 200, 200;
  --tsuruga-color-bg-gray: #F5F7F8;
  --tsuruga-color-bg-gray-rgb: 245, 247, 248;
  --tsuruga-color-bg-dark: #002C51;
  --tsuruga-color-bg-light: #FFF;
  --tsuruga-font-jp-serif: Shippori Mincho, 游明朝, Yu Mincho, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HGS明朝E, ＭＳ Ｐ明朝, MS PMincho, Times New Roman, Times, Garamond, Georgia, serif;
  --tsuruga-font-jp-sans-serif: Zen Kaku Gothic New, ヒラギノ角ゴ Pro, Hiragino Kaku Gothic Pro, 游ゴシック体, Yu Gothic, YuGothic, MS Ｐゴシック, MS PGothic, Lucida Sans Unicode, Lucida Grande, Verdana, Arial, sans-serif;
  --tsuruga-font-en: Josefin Sans, serif;
  --tsuruga-font-num: var(--tsuruga-font-en);
  --tsuruga-icon-width: 1em;
  --tsuruga-color-acc1: #346896;
  --tsuruga-color-acc1-rgb: 52, 104, 150;
  --tsuruga-color-acc2: #D0BA90;
  --tsuruga-color-acc2-rgb: 208, 186, 144;
  --tsuruga-color-sub1: #777777;
  --tsuruga-color-sub1-rgb: 119, 119, 119;
  --tsuruga-color-sub2: #cccccc;
  --tsuruga-color-sub2-rgb: 204, 204, 204;
  --tsuruga-color-akanko: #2E6898;
  --tsuruga-color-akanko-rgb: 46, 104, 152;
  --tsuruga-color-saroma: #4FBEC4;
  --tsuruga-color-saroma-rgb: 79, 190, 196;
  --tsuruga-color-sapporo: #4463BA;
  --tsuruga-color-sapporo-rgb: 68, 99, 186;
  --tsuruga-color-shikotsu: #60B0B1;
  --tsuruga-color-shikotsu-rgb: 96, 176, 177;
  --tsuruga-color-hakodate: #138BAD;
  --tsuruga-color-hakodate-rgb: 19, 139, 173;
  --focus-outline: 3px black solid;
  --gnav-height: calc(70 / var(--tsuruga-parent-font-size) * 1rem);
  --gnav-sticky-position: calc(20 / var(--tsuruga-parent-font-size) * 1rem);
}
@media only screen and (max-width: 767px) {
  :root {
    --tsuruga-content-0: 390;
    --tsuruga-content-1: 350;
    --tsuruga-content-2: 310;
    --tsuruga-content-3: 270;
    --tsuruga-content-4: 270;
    --tsuruga-content-5: 270;
    --tsuruga-content-6: 270;
  }
}
@media only screen and (min-width: 1441px) {
  :root {
    --tsuruga-base-font-size: 16;
  }
}
@media only screen and (min-width: 1441px) and (max-width: 1600px) {
  :root {
    --tsuruga-base-font-size: 14.5;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1440px) {
  :root {
    --tsuruga-base-font-size: 13;
  }
}
@media only screen and (min-width: 897px) and (max-width: 1024px) {
  :root {
    --tsuruga-base-font-size: 13;
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  :root {
    --tsuruga-base-font-size: 12;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --tsuruga-parent-font-size: 14;
  }
}
@media only screen and (max-width: 767px) {
  :root {
    --gnav-sticky-position: calc(35 / var(--tsuruga-parent-font-size) * 1rem);
    --gnav-height: calc(45 / var(--tsuruga-parent-font-size) * 1rem);
  }
}

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

[data-tsuruga-theme="light-blue"] {
  --tsuruga-body-bg: #F5F7F8;
  background: var(--tsuruga-body-bg);
}

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

html {
  font-size: calc(var(--tsuruga-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 {
  --tsuruga-body-color: var(--tsuruga-color-body);
  --tsuruga-body-bg: var(--tsuruga-color-bg-light);
  --tsuruga-body-font: var(--tsuruga-font-jp-sans-serif);
}

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

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

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

* {
  box-sizing: border-box;
}

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

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

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

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

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

.jump_menu {
  display: none;
}

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

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

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

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