@font-face {
  font-family: "NotoSerifJP-Regular";
  src: url("../fonts/NotoSerifJP-Regular.woff2") format("woff2"), url("../fonts/NotoSerifJP-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "NotoSerifJP-Black";
  src: url("../fonts/NotoSerifJP-Black.woff2") format("woff2"), url("../fonts/NotoSerifJP-Black.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "ZenOldMincho-Regular";
  src: url("../fonts/ZenOldMincho-Regular.woff2") format("woff2"), url("../fonts/ZenOldMincho-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Mistral-Graff";
  src: url("../fonts/OPTIMistral-Graff.woff2") format("woff2"), url("../fonts/OPTIMistral-Graff.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "MervaleScript-R";
  src: url("../fonts/MervaleScript-Regular.woff2") format("woff2"), url("../fonts/MervaleScript-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Lusitana-Regular";
  src: url("../fonts/Lusitana-Regular.woff2") format("woff2"), url("../fonts/Lusitana-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Condiment-Regular";
  src: url("../fonts/Condiment-Regular.woff2") format("woff2"), url("../fonts/Condiment-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Taprom-Regular";
  src: url("../fonts/Taprom-Regular.woff2") format("woff2"), url("../fonts/Taprom-Regular.woff") format("woff");
  font-display: swap;
}
html {
  scroll-behavior: smooth;
}

@media screen and (min-width: 769px) {
  body {
    column-gap: 2.5vw;
  }
}
@media screen and (max-width: 768px) {
  body {
    column-gap: 6vw;
  }
}

body {
  position: relative;
  inline-size: 100%;
  background-color: white;
  color: #555;
  font-family: "ZenOldMincho-Regular", "Yu Mincho", "YuMincho", "Times New Roman", "Hiragino Mincho ProN", "MS PMincho", serif;
  line-height: 1.6;
  overflow-x: hidden;
}
@media screen and (min-width: 769px) {
  body {
    font-size: 0.88542vw;
  }
}
@media screen and (max-width: 768px) {
  body {
    font-size: 3.5vw;
  }
}
@media screen and (min-width: 769px) {
  body {
    letter-spacing: 0.16em;
  }
}
@media screen and (max-width: 768px) {
  body {
    letter-spacing: 0.08em;
  }
}

.wrapper {
  inline-size: 100%;
}

.string {
  display: inline-block;
  text-box-trim: trim-both;
  text-box-edge: text;
}

p.sentence {
  text-box-trim: trim-both;
  text-box-edge: text;
}
@media screen and (min-width: 769px) {
  p.sentence:not(:last-of-type) {
    padding-block-end: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  p.sentence:not(:last-of-type) {
    padding-block-end: 4vw;
  }
}

.en-lang-sans {
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
.en-lang-serif {
  font-family: "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}
.en-lang-serif-sub {
  font-family: "Mistral-Graff", "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}

.none-pc {
  display: none;
}
@media screen and (max-width: 768px) {
  .none-pc {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .none-tab {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .none-sp {
    display: none;
  }
}

.only-tab {
  display: none;
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .only-tab {
    display: block;
  }
}

.sr-only {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  border: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.lazy_bg_image {
  position: relative;
}
.lazy_bg_image::before {
  content: "";
  position: absolute;
  z-index: -3;
  display: inline-block;
  inline-size: 100%;
}

@media screen and (min-width: 769px) {
  .ly-inner-area {
    padding-block-start: 6.25vw;
    padding-block-end: 6.25vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-inner-area {
    padding-block-start: 16vw;
    padding-block-end: 16vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-inner-area-btm {
    padding-block-end: 6.25vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-inner-area-btm {
    padding-block-end: 16vw;
  }
}

.ly-fixed-width {
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .ly-fixed-width {
    max-inline-size: 66.66667vw;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }
}
@media screen and (max-width: 768px) {
  .ly-fixed-width {
    padding-inline-start: 4vw;
    padding-inline-end: 4vw;
  }
}
.ly-fixed-width-large {
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .ly-fixed-width-large {
    max-inline-size: 83.33333vw;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }
}
@media screen and (max-width: 768px) {
  .ly-fixed-width-large {
    padding-inline-start: 4vw;
    padding-inline-end: 4vw;
  }
}
.ly-fixed-width-small {
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .ly-fixed-width-small {
    max-inline-size: 50vw;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }
}
@media screen and (max-width: 768px) {
  .ly-fixed-width-small {
    padding-inline-start: 4vw;
    padding-inline-end: 4vw;
  }
}

@media screen and (min-width: 769px) {
  .ly-space-btm-large {
    padding-block-end: 3.75vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-large {
    padding-block-end: 9vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-space-btm-large-mgn {
    margin-block-end: 3.75vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-large-mgn {
    margin-block-end: 9vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-space-btm-medium {
    padding-block-end: 2.5vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-medium {
    padding-block-end: 6vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-space-btm-medium-mgn {
    margin-block-end: 2.5vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-medium-mgn {
    margin-block-end: 6vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-space-btm-small {
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-small {
    padding-block-end: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .ly-space-btm-small-mgn {
    margin-block-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .ly-space-btm-small-mgn {
    margin-block-end: 4vw;
  }
}

.g-heading-primary {
  text-box-trim: trim-both;
  text-box-edge: text;
}
.g-heading-primary .string.main {
  text-transform: uppercase;
}
@media screen and (min-width: 769px) {
  .g-heading-primary .string.main {
    font-size: 2.29167vw;
  }
}
@media screen and (max-width: 768px) {
  .g-heading-primary .string.main {
    font-size: 6.5vw;
  }
}
@media screen and (min-width: 769px) {
  .g-heading-primary .string.sub {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 768px) {
  .g-heading-primary .string.sub {
    font-size: 3.25vw;
  }
}
.g-heading-secondary {
  text-box-trim: trim-both;
  text-box-edge: text;
}
.g-heading-secondary .string {
  font-weight: normal;
}
@media screen and (min-width: 769px) {
  .g-heading-secondary .string.main {
    font-size: 1.66667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-heading-secondary .string.main {
    font-size: 4.5vw;
  }
}
@media screen and (min-width: 769px) {
  .g-heading-secondary .string.sub {
    font-size: 1.45833vw;
  }
}
@media screen and (max-width: 768px) {
  .g-heading-secondary .string.sub {
    font-size: 5vw;
  }
}

.g-heading-primary .string.main {
  text-transform: uppercase;
}
.g-heading-secondary {
  display: flex;
  flex-direction: column;
}
.g-heading-secondary .string {
  letter-spacing: 0.04em;
}
.g-heading-secondary .string:last-of-type {
  position: relative;
}
.g-heading-secondary .string:last-of-type::after {
  content: "";
  position: absolute;
  inset-block-end: 24%;
  max-inline-size: 72%;
  inline-size: 100%;
  block-size: 1px;
  background-color: #888888;
}

.g-btn-primary .link, .g-btn-secondary .link, .g-btn-read-more .link {
  display: inline-block;
  color: #555;
  text-decoration: none;
}
.g-btn-primary {
  inline-size: 100%;
}
.g-btn-primary .link {
  display: grid;
  grid-template-areas: "string circle" "arrow circle";
  grid-template-rows: repeat(2, 1fr);
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link {
    grid-template-columns: 1fr 2.08333vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link {
    grid-template-columns: 1fr 6vw;
  }
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link {
    max-inline-size: 12.5vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link {
    max-inline-size: 32vw;
  }
}
.g-btn-primary .link .string {
  grid-area: string;
  text-transform: capitalize;
  font-weight: bold;
  font-family: "Lusitana-Regular", "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link .string {
    padding-block-end: 0.41667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link .string {
    padding-block-end: 1vw;
  }
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link .string {
    font-size: 0.88542vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link .string {
    font-size: 3.5vw;
  }
}
.g-btn-primary .link .mark {
  display: inline-block;
}
.g-btn-primary .link .mark.arrow {
  grid-area: arrow;
  position: relative;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 1px;
  background-color: #888888;
  transition: left 0.4s ease-in-out;
}
.g-btn-primary .link .mark.arrow::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-end: 0;
  inline-size: 100%;
  block-size: 1px;
  background-color: #888888;
  transform-origin: right;
  rotate: 30deg;
  translate: 0 -50%;
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link .mark.arrow::after {
    max-inline-size: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link .mark.arrow::after {
    max-inline-size: 4vw;
  }
}
.g-btn-primary .link .mark.circle {
  grid-area: circle;
  position: relative;
  inset-block-start: 50%;
  inline-size: 100%;
  margin-inline-start: -4px;
  border-color: #888;
  border-style: solid;
  border-block-width: 1px;
  border-inline-width: 1px;
  border-radius: 50%;
  translate: 0 -50%;
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link .mark.circle {
    block-size: 2.08333vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link .mark.circle {
    block-size: 6vw;
  }
}
.g-btn-primary .link .mark.circle::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  display: inline-block;
  inline-size: 100%;
  block-size: 100%;
  border-radius: 50%;
  background-color: rgba(102, 102, 102, 0.25);
  transition: scale 0.4s ease-in-out;
  scale: 0;
}
@media screen and (min-width: 769px) {
  .g-btn-primary .link:hover .mark.arrow {
    inset-inline-start: 1.25vw;
    inset-inline-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-primary .link:hover .mark.arrow {
    inset-inline-start: 3vw;
    inset-inline-end: 3vw;
  }
}
.g-btn-primary .link:hover .mark.circle::before {
  scale: 1;
}
.g-btn-secondary {
  display: flex;
}
.g-btn-secondary .link {
  position: relative;
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .g-btn-secondary .link {
    max-inline-size: 10.41667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-secondary .link {
    max-inline-size: 40vw;
  }
}
.g-btn-secondary .link::after {
  content: "";
  position: absolute;
  inset-block-start: calc(50% - 0.5px);
  inset-inline-end: 0;
  inline-size: 100%;
  block-size: 1px;
  background-color: #888888;
  transition: inset-inline-end 0.4s ease-in-out;
}
@media screen and (min-width: 769px) {
  .g-btn-secondary .link::after {
    max-inline-size: 2.91667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-secondary .link::after {
    max-inline-size: 10vw;
  }
}
.g-btn-secondary .link .string {
  text-transform: capitalize;
  transition: letter-spacing 0.4s ease-in-out;
}
.g-btn-secondary .link:hover::after {
  inset-inline-end: 16%;
}
.g-btn-secondary .link:hover .string {
  letter-spacing: 0.4em;
}
.g-btn-read-more {
  display: flex;
}
.g-btn-read-more .link {
  position: relative;
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .g-btn-read-more .link {
    max-inline-size: 10.41667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-read-more .link {
    max-inline-size: 40vw;
  }
}
.g-btn-read-more .link::after {
  content: "";
  position: absolute;
  inset-block-start: calc(50% - 0.5px);
  inset-inline-end: 0;
  inline-size: 100%;
  block-size: 1px;
  background-color: #888888;
  transition: inset-inline-end 0.4s ease-in-out;
}
@media screen and (min-width: 769px) {
  .g-btn-read-more .link::after {
    max-inline-size: 2.91667vw;
  }
}
@media screen and (max-width: 768px) {
  .g-btn-read-more .link::after {
    max-inline-size: 10vw;
  }
}
.g-btn-read-more .link .string {
  text-transform: capitalize;
  transition: letter-spacing 0.4s ease-in-out;
}
.g-btn-read-more .link:hover::after {
  inset-inline-end: 16%;
}
.g-btn-read-more .link:hover .string {
  letter-spacing: 0.4em;
}

.g-back-scroll-btn {
  line-height: 1;
  appearance: none;
  cursor: pointer;
  position: fixed;
  z-index: 899;
  inline-size: 100%;
  padding: 0;
  border-style: none;
  border-radius: 50%;
  background-color: #666666;
  text-align: center;
  box-shadow: clamp(2px, 1.472px + 0.132vw, 4px) clamp(2px, 1.472px + 0.132vw, 4px) 4px rgba(0, 0, 0, 0.5);
  transition: background-color 0.4s ease-in-out;
  visibility: hidden;
}
@media screen and (min-width: 769px) {
  .g-back-scroll-btn {
    inset-block-end: 24px;
    inset-inline-end: 24px;
  }
}
@media screen and (max-width: 768px) {
  .g-back-scroll-btn {
    inset-block-end: 8px;
    inset-inline-end: 8px;
  }
}
@media screen and (min-width: 769px) {
  .g-back-scroll-btn {
    max-inline-size: 2.8125vw;
  }
}
@media screen and (max-width: 768px) {
  .g-back-scroll-btn {
    max-inline-size: 9vw;
  }
}
.g-back-scroll-btn .mark {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: inline-block;
  inline-size: 100%;
  translate: -50% -17.5%;
  rotate: 45deg;
}
@media screen and (min-width: 769px) {
  .g-back-scroll-btn .mark {
    max-inline-size: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .g-back-scroll-btn .mark {
    max-inline-size: 3vw;
  }
}
.g-back-scroll-btn .mark {
  border-block-start-color: #fff;
  border-block-start-style: solid;
}
@media screen and (min-width: 769px) {
  .g-back-scroll-btn .mark {
    border-block-start-width: 0.10417vw;
  }
}
@media screen and (max-width: 768px) {
  .g-back-scroll-btn .mark {
    border-block-start-width: 0.5vw;
  }
}
.g-back-scroll-btn .mark {
  border-inline-start-color: #fff;
  border-inline-start-style: solid;
}
@media screen and (min-width: 769px) {
  .g-back-scroll-btn .mark {
    border-inline-start-width: 0.10417vw;
  }
}
@media screen and (max-width: 768px) {
  .g-back-scroll-btn .mark {
    border-inline-start-width: 0.5vw;
  }
}
.g-back-scroll-btn:hover {
  background-color: #ffaa00;
}

#errorMessage {
  position: fixed;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  margin: auto;
  background-color: rgba(0, 0, 0, 0.75);
  font-size: 30px;
  color: #fff;
  translate: -50% -50%;
}
@media screen and (min-width: 769px) {
  #errorMessage {
    padding-block-start: 1.25vw;
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  #errorMessage {
    padding-block-start: 6vw;
    padding-block-end: 6vw;
  }
}
@media screen and (min-width: 769px) {
  #errorMessage {
    padding-inline-start: 1.25vw;
    padding-inline-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  #errorMessage {
    padding-inline-start: 6vw;
    padding-inline-end: 6vw;
  }
}

.from_left {
  opacity: 0;
  translate: -100px;
}

.from_bottom {
  opacity: 0;
  translate: 0 100px;
}

.slide_door {
  opacity: 0;
}

.fadeInSlideDoor {
  animation: fadeInSlideDoor 1s ease-in-out 1 forwards;
}

@keyframes fadeInSlideDoor {
  0% {
    opacity: 0;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0 100%);
  }
}
.fadeInFromLeft {
  animation: fadeInFromLeft 0.8s ease-in-out 1 forwards;
}

@keyframes fadeInFromLeft {
  0% {
    opacity: 0;
    translate: -100px;
  }
  100% {
    opacity: 1;
    translate: 0;
  }
}
.fadeInFromBottom {
  animation: fadeInFromBottom 0.8s ease-in-out 1 forwards;
}

@keyframes fadeInFromBottom {
  0% {
    opacity: 0;
    translate: 0 100px;
  }
  100% {
    opacity: 1;
    translate: 0;
  }
}
.fadeInDisp {
  animation: fadeInDisp 0.4s ease-in-out 1 forwards;
}

@keyframes fadeInDisp {
  0% {
    display: none;
    opacity: 0;
  }
  100% {
    display: block;
    opacity: 1;
  }
}
.fadeOutDisp {
  animation: fadeOutDisp 0.4s ease-in-out 1 forwards;
}

@keyframes fadeOutDisp {
  0% {
    display: block;
    opacity: 1;
  }
  100% {
    display: none;
    opacity: 0;
  }
}
.fadeInOpacity {
  animation: fadeInOpacity 0.8s ease-in-out 1 forwards;
}

@keyframes fadeInOpacity {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fadeOutOpacity {
  animation: fadeOutOpacity 0.8s ease-in-out 1 forwards;
}

@keyframes fadeOutOpacity {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
body::after {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  display: inline-block;
  inline-size: 100%;
  block-size: 100%;
}
@media screen and (min-width: 769px) {
  body::after {
    max-inline-size: 4.16667vw;
  }
}
@media screen and (max-width: 768px) {
  body::after {
    max-inline-size: 9vw;
  }
}

.site-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 100;
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .site-header {
    block-size: 4.16667vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header {
    block-size: 12vw;
  }
}
.site-header .inner-header {
  block-size: 100%;
}
.site-header .body {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  block-size: 100%;
}
@media screen and (min-width: 769px) {
  .site-header .body .site-title .heading {
    padding-inline-start: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .site-title .heading {
    padding-inline-start: 3vw;
  }
}
.site-header .body .site-title .heading .link {
  display: inline-block;
  color: #555;
  text-decoration: none;
  position: relative;
  z-index: 100;
  display: flex;
  align-items: center;
}
.site-header .body .site-title .heading .link .logo {
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .site-header .body .site-title .heading .link .logo {
    max-inline-size: 2.70833vw;
    block-size: 2.70833vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .site-title .heading .link .logo {
    max-inline-size: 9vw;
    block-size: 9vw;
  }
}
.site-header .body .site-title .heading .link .logo .icon {
  display: inline-block;
  inline-size: 100%;
  vertical-align: baseline;
  object-fit: cover;
}
.site-header .body .site-title .heading .link .string {
  color: #000;
}
.site-header .body .site-title .heading .link .string.main {
  text-transform: uppercase;
  letter-spacing: 0.24em;
}
@media screen and (min-width: 769px) {
  .site-header .body .site-title .heading .link .string.main {
    padding-inline-start: 0.83333vw;
    padding-inline-end: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .site-title .heading .link .string.main {
    padding-inline-start: 3vw;
    padding-inline-end: 3vw;
  }
}
@media screen and (min-width: 769px) {
  .site-header .body .site-title .heading .link .string.main {
    font-size: 1.35417vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .site-title .heading .link .string.main {
    font-size: 5vw;
  }
}
.site-header .body .site-title .heading .link .string.sub {
  font-weight: normal;
  text-transform: capitalize;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 769px) {
  .site-header .body .site-title .heading .link .string.sub {
    font-size: 1.14583vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .site-title .heading .link .string.sub {
    font-size: 4.25vw;
  }
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi-icon {
    line-height: 1;
    appearance: none;
    cursor: pointer;
    position: absolute;
    inset-block-start: 50%;
    display: inline-block;
    inline-size: 100%;
    z-index: 731;
    margin-block-start: auto;
    margin-block-end: auto;
    padding: 0;
    border-style: none;
    background-color: transparent;
    translate: 0 -50%;
  }
  .site-header .body .g-header-navi-icon .mark {
    position: absolute;
    inset-inline-start: 50%;
    display: inline-block;
    inline-size: 100%;
    background-color: black;
    transition-property: inset-block, rotate, scale;
    transition-duration: 0.4s;
    transition-timing-function: ease-in-out;
    translate: -50% 0;
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(1) {
    inset-block-start: calc(40% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(2) {
    inset-block-start: calc(60% - 0.5px);
  }
  .site-header .body .g-header-navi-icon.is_active .mark:nth-of-type(1) {
    inset-block-start: calc(50% - 0.5px);
    rotate: 45deg;
  }
  .site-header .body .g-header-navi-icon.is_active .mark:nth-of-type(2) {
    inset-block-start: calc(50% - 0.5px);
    rotate: 315deg;
  }
  .site-header .body .g-header-navi-icon {
    inset-inline-end: 1.25vw;
    max-inline-size: 2.91667vw;
    block-size: 2.91667vw;
  }
  .site-header .body .g-header-navi-icon .mark {
    max-inline-size: 2.5vw;
    block-size: 1px;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi-icon {
    line-height: 1;
    appearance: none;
    cursor: pointer;
    position: absolute;
    inset-block-start: 50%;
    display: inline-block;
    inline-size: 100%;
    z-index: 731;
    margin-block-start: auto;
    margin-block-end: auto;
    padding: 0;
    border-style: none;
    background-color: transparent;
    translate: 0 -50%;
  }
  .site-header .body .g-header-navi-icon .mark {
    position: absolute;
    inset-inline-start: 50%;
    display: inline-block;
    inline-size: 100%;
    background-color: black;
    transition-property: inset-block, rotate, scale;
    transition-duration: 0.4s;
    transition-timing-function: ease-in-out;
    translate: -50% 0;
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(1) {
    inset-block-start: calc(40% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(2) {
    inset-block-start: calc(60% - 0.5px);
  }
  .site-header .body .g-header-navi-icon.is_active .mark:nth-of-type(1) {
    inset-block-start: calc(50% - 0.5px);
    rotate: 45deg;
  }
  .site-header .body .g-header-navi-icon.is_active .mark:nth-of-type(2) {
    inset-block-start: calc(50% - 0.5px);
    rotate: 315deg;
  }
  .site-header .body .g-header-navi-icon {
    inset-inline-end: 0;
    max-inline-size: 12vw;
    block-size: 12vw;
  }
  .site-header .body .g-header-navi-icon .mark {
    max-inline-size: 9vw;
    block-size: 1px;
  }
}
.site-header .body .g-header-navi {
  position: fixed;
  inset-block-start: 0;
  z-index: 73;
  inline-size: 100%;
  background-color: white;
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi {
    max-inline-size: 28.125vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi {
    max-inline-size: 90vw;
  }
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi {
    inset-inline-end: -28.125vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi {
    inset-inline-end: -90vw;
  }
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi {
    padding-block-start: 6vw;
    padding-block-end: 2.5vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi {
    padding-block-start: 16vw;
    padding-block-end: 6.25vw;
  }
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi {
    padding-inline-start: 1.25vw;
    padding-inline-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi {
    padding-inline-start: 4vw;
    padding-inline-end: 4vw;
  }
}
.site-header .body .g-header-navi .list-navi {
  text-align: center;
}
.site-header .body .g-header-navi .list-navi > .item .link {
  display: inline-block;
  color: #555;
  text-decoration: none;
  inline-size: 100%;
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi .list-navi > .item .link {
    padding-block-start: 0.83333vw;
    padding-block-end: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi .list-navi > .item .link {
    padding-block-start: 3vw;
    padding-block-end: 3vw;
  }
}
.site-header .body .g-header-navi .list-navi > .item .link .string {
  text-transform: capitalize;
  letter-spacing: 0.04em;
}
.site-header .body .g-header-navi .list-navi > .item .link.tel {
  margin-block-end: 8px;
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi .list-navi > .item .link.tel {
    padding-block-start: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi .list-navi > .item .link.tel {
    padding-block-start: 3vw;
  }
}
.site-header .body .g-header-navi .list-navi > .item .link.tel .string {
  border-bottom-color: #888;
  border-bottom-style: solid;
  border-bottom-width: 1px;
}
.site-header .body .g-header-navi .list-navi > .item .text .sentence {
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  .site-header .body .g-header-navi .list-navi > .item .text .sentence {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 768px) {
  .site-header .body .g-header-navi .list-navi > .item .text .sentence {
    font-size: 0.67708vw;
  }
}
.site-header .body .g-header-navi.is_active {
  animation: fadeInOut 0.4s ease-in-out 1 forwards;
}
@keyframes fadeInOut {
  0% {
    inset-inline-end: -100%;
    filter: opacity(0);
  }
  1% {
    inset-inline-end: 0;
    filter: opacity(0);
  }
  100% {
    inset-inline-end: 0;
    filter: opacity(1);
  }
}

.area-catch-copy {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 3;
  inline-size: 100%;
}
.area-catch-copy .overview .text {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text {
    inset-block-start: 3.75vw;
    inset-block-end: 3.75vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text {
    inset-block-start: 18vw;
    inset-block-end: 18vw;
  }
}
.area-catch-copy .overview .text .phrase {
  writing-mode: vertical-rl;
  white-space: nowrap;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text .phrase {
    padding-inline-start: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text .phrase {
    padding-inline-start: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text.pos-left {
    inset-inline-start: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text.pos-left {
    inset-inline-start: 1vw;
  }
}
.area-catch-copy .overview .text.pos-left .phrase {
  color: #dddddd;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text.pos-left .phrase {
    font-size: 1.66667vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text.pos-left .phrase {
    font-size: 5vw;
  }
}
.area-catch-copy .overview .text.pos-left .phrase::first-letter {
  text-transform: uppercase;
}
.area-catch-copy .overview .text.pos-right {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text.pos-right {
    inset-inline-end: 1.875vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text.pos-right {
    inset-inline-end: 3vw;
  }
}
.area-catch-copy .overview .text.pos-right::after {
  content: "";
  position: absolute;
  inset-inline-start: 44%;
  display: inline-block;
  inline-size: 1px;
  margin-block-start: clamp(12px, 8.844px + 0.789vw, 24px);
  background-color: black;
  filter: opacity(1);
  scale: 1 0;
  animation: fadeOutBar 2s linear infinite;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text.pos-right::after {
    block-size: 7.5vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text.pos-right::after {
    block-size: 18vw;
  }
}
@keyframes fadeOutBar {
  0% {
    filter: opacity(0);
    scale: 1 0;
    transform-origin: top;
  }
  10% {
    filter: opacity(0.25);
    scale: 1 0;
  }
  40% {
    filter: opacity(1);
    scale: 1 1;
    transform-origin: top;
  }
  60% {
    filter: opacity(1);
    scale: 1 1;
    transform-origin: bottom;
  }
  90% {
    filter: opacity(0.25);
    scale: 1 0;
  }
  100% {
    filter: opacity(0);
    scale: 1 0;
    transform-origin: bottom;
  }
}
.area-catch-copy .overview .text.pos-right .phrase {
  font-weight: bold;
  text-transform: capitalize;
  color: #000;
}
@media screen and (min-width: 769px) {
  .area-catch-copy .overview .text.pos-right .phrase {
    font-size: 1.14583vw;
  }
}
@media screen and (max-width: 768px) {
  .area-catch-copy .overview .text.pos-right .phrase {
    font-size: 3vw;
  }
}

.site-footer .body {
  border-top-color: #888;
  border-top-style: solid;
  border-top-width: 1px;
}
@media screen and (min-width: 769px) {
  .site-footer .body {
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .body {
    padding-block-end: 4vw;
  }
}
.site-footer .body .g-footer-navi .list-navi {
  display: flex;
  justify-content: space-around;
  align-items: center;
  column-gap: clamp(16px, 13.896px + 0.526vw, 24px);
  row-gap: clamp(12px, 10.948px + 0.263vw, 16px);
  flex-wrap: wrap;
}
@media screen and (min-width: 769px) {
  .site-footer .body .g-footer-navi .list-navi .item {
    max-inline-size: calc(calc(100% - 5vw) / 3);
  }
}
@media screen and (max-width: 768px) {
  .site-footer .body .g-footer-navi .list-navi .item {
    max-inline-size: calc(calc(100% - 6vw) / 2);
  }
}
.site-footer .body .g-footer-navi .list-navi .item {
  inline-size: 100%;
}
.site-footer .body .g-footer-navi .list-navi .item .link {
  display: inline-block;
  color: #555;
  text-decoration: none;
  inline-size: 100%;
}
.site-footer .body .g-footer-navi .list-navi .item .link .string {
  inline-size: 100%;
  color: #555;
  text-align: center;
  text-transform: capitalize;
}
@media screen and (min-width: 769px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    padding-block-start: 0.83333vw;
    padding-block-end: 0.83333vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    padding-block-start: 2vw;
    padding-block-end: 2vw;
  }
}
@media screen and (min-width: 769px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    font-size: 3.75vw;
  }
}
.site-footer .foot .copyright {
  text-align: center;
}
.site-footer .foot .copyright .sentence {
  display: inline-grid;
  align-items: baseline;
  column-gap: 8px;
  grid-template-areas: "mark name year";
}
.site-footer .foot .copyright .sentence .mark {
  grid-area: mark;
}
.site-footer .foot .copyright .sentence .year {
  grid-area: year;
}
.site-footer .foot .copyright .sentence .name {
  grid-area: name;
}
.site-footer .foot .copyright .sentence {
  color: #555;
}
@media screen and (min-width: 769px) {
  .site-footer .foot .copyright .sentence {
    padding-block-start: 1.25vw;
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .foot .copyright .sentence {
    padding-block-start: 4vw;
    padding-block-end: 4vw;
  }
}
.site-footer .foot .copyright .sentence .mark {
  font-family: "Arial", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "YuGothic", "Helvetica Neue", "Helvetica", "Meiryo", sans-serif;
}
@media screen and (min-width: 769px) {
  .site-footer .foot .copyright .sentence .year {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .foot .copyright .sentence .year {
    font-size: 3vw;
  }
}
.site-footer .foot .copyright .sentence .name {
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  .site-footer .foot .copyright .sentence .name {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 768px) {
  .site-footer .foot .copyright .sentence .name {
    font-size: 3vw;
  }
}
.site-footer .foot .copyright .sentence .name .string.main {
  text-transform: uppercase;
}
.site-footer .foot .copyright .sentence .name .string.sub {
  text-transform: capitalize;
}
/*# sourceMappingURL=project-common.css.map */
