:where(body) {
  margin: 0;
  position: relative;
  z-index: 0;
}

:where(a) {
  touch-action: manipulation;
}

a {
  color: inherit;
  text-decoration: none;
}

:where(img) {
  max-width: 100%;
  height: auto;
}

:where(figure img) {
  display: block;
}

:where(button, label) {
  touch-action: manipulation;
  cursor: pointer;
}

:where(button) {
  border-radius: 0;
  border: 0;
  outline: 0;
  background: none;
}

@media print, screen and (min-width: 768.1px) {
  .pc-none {
    display: none !important;
  }
}

@media screen and (max-width: 768px) {
  .sp-none {
    display: none !important;
  }
}

:where(.font-palt) {
  font-feature-settings: "palt";
}

:where(.pre-line) {
  white-space: pre-line;
}

[hidden] {
  display: none !important;
}

.sr-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

:root {
  color: #323232;
  background: #fff;
  font-family: YakuHanJP, "Noto Sans JP", "Noto Sans CJK JP", "Noto Sans Japanese", sans-serif;
}

:where(.font-en) {
  font-family: Arial, sans-serif;
}

:root {
  --theme-color: #0088BC;
}
@media print, screen and (min-width: 768.1px) {
  :root {
    --header-height: 90px;
    --pxvw-coefficient: 1px;
  }
}
@media screen and (max-width: 768px) {
  :root {
    --header-height: 12vw;
    --pxvw-coefficient: 0.1333333333vw;
  }
}

:where(.bl-header) {
  height: var(--header-height);
  opacity: 0;
}

:where(.bl-main) {
  overflow: clip;
}

.ac-eyecatch {
  position: relative;
}
.ac-eyecatch__title {
  line-height: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
}
.ac-eyecatch__ja {
  margin-bottom: 0.5em;
  font-weight: 500;
  font-size: calc(37 * var(--pxvw-coefficient));
  letter-spacing: 0;
}
.ac-eyecatch__en {
  font-weight: 400;
  letter-spacing: 0.05em;
}
.ac-eyecatch__image {
  margin: 0;
}
.ac-eyecatch__image img {
  width: 100%;
}
@media print, screen and (min-width: 768.1px) {
  .ac-eyecatch__en {
    font-size: 17px;
  }
}
@media screen and (max-width: 768px) {
  .ac-eyecatch__en {
    font-size: 2.9333333333vw;
  }
}

:where(body) {
  margin-top: calc(var(--header-height) * -1);
}

[id] {
  scroll-margin: var(--header-height);
}

@view-transition {
  navigation: auto;
}
::view-transition-old(root),
::view-transition-new(root) {
  -webkit-animation: fade 1s ease both;
          animation: fade 1s ease both;
}

@-webkit-keyframes fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/*# sourceMappingURL=init.css.map */