@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: "iowan-old-style-bt-regular";
  src: url("../fonts/iowan-old-style-bt-regular.woff2") format("woff2"), url("../fonts/iowan-old-style-bt-regular.woff") format("woff");
  font-display: swap;
}
html {
  scroll-behavior: smooth;
}

@media screen and (min-width: 1025px) {
  body {
    column-gap: 3.75vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  body {
    column-gap: 5.85938vw;
  }
}
@media screen and (max-width: 600px) {
  body {
    column-gap: 12vw;
  }
}

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: 1025px) {
  body {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  body {
    font-size: 1.66016vw;
  }
}
@media screen and (max-width: 600px) {
  body {
    font-size: 3.75vw;
  }
}
@media screen and (min-width: 1025px) {
  body {
    letter-spacing: 0.16em;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  body {
    letter-spacing: 0.16em;
  }
}
@media screen and (max-width: 600px) {
  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: 1025px) {
  p.sentence:not(:last-of-type) {
    padding-block-end: 0.83333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  p.sentence:not(:last-of-type) {
    padding-block-end: 1.5625vw;
  }
}
@media screen and (max-width: 600px) {
  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: "Lusitana-Regular", "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;
}
.en-lang-serif-special {
  font-family: "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}

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

.only-tab {
  display: none;
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .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: 1025px) {
  .ly-inner-area {
    padding-block-start: 6.25vw;
    padding-block-end: 6.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-inner-area {
    padding-block-start: 10.54688vw;
    padding-block-end: 10.54688vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-inner-area {
    padding-block-start: 20vw;
    padding-block-end: 20vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-inner-area-btm {
    padding-block-end: 6.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-inner-area-btm {
    padding-block-end: 10.54688vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-inner-area-btm {
    padding-block-end: 20vw;
  }
}

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

@media screen and (min-width: 1025px) {
  .ly-space-btm-large {
    padding-block-end: 3.75vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-large {
    padding-block-end: 5.27344vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-large {
    padding-block-end: 9vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-space-btm-large-mgn {
    margin-block-end: 3.75vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-large-mgn {
    margin-block-end: 5.27344vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-large-mgn {
    margin-block-end: 9vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-space-btm-medium {
    padding-block-end: 2.5vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-medium {
    padding-block-end: 3.51563vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-medium {
    padding-block-end: 6vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-space-btm-medium-mgn {
    margin-block-end: 2.5vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-medium-mgn {
    margin-block-end: 3.51563vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-medium-mgn {
    margin-block-end: 6vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-space-btm-small {
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-small {
    padding-block-end: 1.95313vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-small {
    padding-block-end: 4vw;
  }
}
@media screen and (min-width: 1025px) {
  .ly-space-btm-small-mgn {
    margin-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .ly-space-btm-small-mgn {
    margin-block-end: 1.95313vw;
  }
}
@media screen and (max-width: 600px) {
  .ly-space-btm-small-mgn {
    margin-block-end: 4vw;
  }
}

@media screen and (min-width: 1025px) {
  .g-heading-primary .string.main {
    font-size: 1.97917vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-primary .string.main {
    font-size: 3.51563vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-primary .string.main {
    font-size: 6vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-heading-primary .string.sub {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-primary .string.sub {
    font-size: 1.5625vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-primary .string.sub {
    font-size: 3.25vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-heading-secondary .string.main {
    font-size: 1.66667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-secondary .string.main {
    font-size: 2.92969vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-secondary .string.main {
    font-size: 4.5vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-heading-secondary .string.sub {
    font-size: 1.45833vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-secondary .string.sub {
    font-size: 2.53906vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-secondary .string.sub {
    font-size: 5vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-heading-tertiary .string {
    font-size: 1.45833vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-tertiary .string {
    font-size: 2.53906vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-tertiary .string {
    font-size: 5vw;
  }
}
.g-heading-primary .string {
  display: inline-block;
  color: #713B17;
}
.g-heading-primary .string.main {
  text-transform: capitalize;
}
.g-heading-primary .string:nth-of-type(1) {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .g-heading-primary .string:nth-of-type(1) {
    padding-block-end: 0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-primary .string:nth-of-type(1) {
    padding-block-end: 0.78125vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-primary .string:nth-of-type(1) {
    padding-block-end: 2vw;
  }
}
.g-heading-primary .string:nth-of-type(1)::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  inset-inline-start: 50%;
  display: inline-block;
  inline-size: 100%;
  background-color: #713b17;
  translate: -50% -100%;
}
@media screen and (min-width: 1025px) {
  .g-heading-primary .string:nth-of-type(1)::after {
    max-inline-size: 4.16667vw;
    block-size: 0.10417vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-heading-primary .string:nth-of-type(1)::after {
    max-inline-size: 7.03125vw;
    block-size: 0.19531vw;
  }
}
@media screen and (max-width: 600px) {
  .g-heading-primary .string:nth-of-type(1)::after {
    max-inline-size: 14vw;
    block-size: 0.5vw;
  }
}
.g-heading-secondary {
  display: flex;
  flex-direction: column;
}
.g-heading-tertiary .string {
  color: #c79a57;
  font-weight: normal;
}

.g-btn-primary .link, .g-btn-secondary .link, .g-btn-read-more .link {
  display: inline-block;
  color: currentColor;
  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: 1025px) {
  .g-btn-primary .link {
    grid-template-columns: 1fr 3.75vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link {
    grid-template-columns: 1fr 6.25vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link {
    grid-template-columns: 1fr 12vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link {
    max-inline-size: 14.58333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link {
    max-inline-size: 25.39063vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link {
    max-inline-size: 50vw;
  }
}
.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: 1025px) {
  .g-btn-primary .link .string {
    padding-block-end: 0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link .string {
    padding-block-end: 0.78125vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link .string {
    padding-block-end: 1vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link .string {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link .string {
    font-size: 1.66016vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link .string {
    font-size: 3.75vw;
  }
}
.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: #4c4b4b;
  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: #4c4b4b;
  transform-origin: right;
  rotate: 30deg;
  translate: 0 -50%;
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link .mark.arrow::after {
    max-inline-size: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link .mark.arrow::after {
    max-inline-size: 2.14844vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link .mark.arrow::after {
    max-inline-size: 4vw;
  }
}
.g-btn-primary .link .mark.circle {
  grid-area: circle;
  position: relative;
  inline-size: 100%;
  margin-inline-start: -4px;
  border-color: #4c4b4b;
  border-style: solid;
  border-block-width: 1px;
  border-inline-width: 1px;
  border-radius: 50%;
  translate: 0 -50%;
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link .mark.circle {
    block-size: 3.75vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link .mark.circle {
    block-size: 6.25vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link .mark.circle {
    block-size: 12vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link .mark.circle {
    inset-block-start: 1.875vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link .mark.circle {
    inset-block-start: 3.125vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-primary .link .mark.circle {
    inset-block-start: 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(199, 154, 87, 0.25);
  transition: scale 0.4s ease-in-out;
  scale: 0;
}
@media screen and (min-width: 1025px) {
  .g-btn-primary .link:hover .mark.arrow {
    inset-inline-start: 1.25vw;
    inset-inline-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-primary .link:hover .mark.arrow {
    inset-inline-start: 2.34375vw;
    inset-inline-end: 2.34375vw;
  }
}
@media screen and (max-width: 600px) {
  .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: 1025px) {
  .g-btn-secondary .link {
    max-inline-size: 10.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-secondary .link {
    max-inline-size: 17.57813vw;
  }
}
@media screen and (max-width: 600px) {
  .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: #4c4b4b;
  transition: inset-inline-end 0.4s ease-in-out;
}
@media screen and (min-width: 1025px) {
  .g-btn-secondary .link::after {
    max-inline-size: 2.91667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-secondary .link::after {
    max-inline-size: 4.6875vw;
  }
}
@media screen and (max-width: 600px) {
  .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;
  align-items: center;
}
.g-btn-read-more .link {
  position: relative;
  inline-size: 100%;
}
@media screen and (min-width: 1025px) {
  .g-btn-read-more .link {
    max-inline-size: 10.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-read-more .link {
    max-inline-size: 17.57813vw;
  }
}
@media screen and (max-width: 600px) {
  .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: #4c4b4b;
  transition: inset-inline-end 0.4s ease-in-out;
}
@media screen and (min-width: 1025px) {
  .g-btn-read-more .link::after {
    max-inline-size: 2.91667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-read-more .link::after {
    max-inline-size: 5.07813vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-read-more .link::after {
    max-inline-size: 12vw;
  }
}
.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: #c79a57;
  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: 1025px) {
  .g-back-scroll-btn {
    inset-block-end: 24px;
    inset-inline-end: 24px;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-back-scroll-btn {
    inset-block-end: 16px;
    inset-inline-end: 16px;
  }
}
@media screen and (max-width: 600px) {
  .g-back-scroll-btn {
    inset-block-end: 8px;
    inset-inline-end: 8px;
  }
}
@media screen and (min-width: 1025px) {
  .g-back-scroll-btn {
    max-inline-size: 2.8125vw;
    block-size: 2.8125vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-back-scroll-btn {
    max-inline-size: 4.6875vw;
    block-size: 4.6875vw;
  }
}
@media screen and (max-width: 600px) {
  .g-back-scroll-btn {
    max-inline-size: 9vw;
    block-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: 1025px) {
  .g-back-scroll-btn .mark {
    max-inline-size: 0.83333vw;
    block-size: 0.83333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-back-scroll-btn .mark {
    max-inline-size: 1.36719vw;
    block-size: 1.36719vw;
  }
}
@media screen and (max-width: 600px) {
  .g-back-scroll-btn .mark {
    max-inline-size: 3vw;
    block-size: 3vw;
  }
}
.g-back-scroll-btn .mark {
  border-block-start-color: #fff;
  border-block-start-style: solid;
}
@media screen and (min-width: 1025px) {
  .g-back-scroll-btn .mark {
    border-block-start-width: 0.10417vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-back-scroll-btn .mark {
    border-block-start-width: 0.19531vw;
  }
}
@media screen and (max-width: 600px) {
  .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: 1025px) {
  .g-back-scroll-btn .mark {
    border-inline-start-width: 0.10417vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-back-scroll-btn .mark {
    border-inline-start-width: 0.19531vw;
  }
}
@media screen and (max-width: 600px) {
  .g-back-scroll-btn .mark {
    border-inline-start-width: 0.5vw;
  }
}
.g-back-scroll-btn:hover {
  background-color: #a92522;
}

#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: 1025px) {
  #errorMessage {
    padding-block-start: 1.25vw;
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  #errorMessage {
    padding-block-start: 2.34375vw;
    padding-block-end: 2.34375vw;
  }
}
@media screen and (max-width: 600px) {
  #errorMessage {
    padding-block-start: 6vw;
    padding-block-end: 6vw;
  }
}
@media screen and (min-width: 1025px) {
  #errorMessage {
    padding-inline-start: 1.25vw;
    padding-inline-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  #errorMessage {
    padding-inline-start: 2.34375vw;
    padding-inline-end: 2.34375vw;
  }
}
@media screen and (max-width: 600px) {
  #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;
  }
}
.site-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 100;
  inline-size: 100%;
}
.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: 1025px) {
  .site-header .body .site-title .heading {
    padding-inline-start: 0.83333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .site-title .heading {
    padding-inline-start: 1.36719vw;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .site-title .heading {
    padding-inline-start: 3vw;
  }
}
.site-header .body .site-title .heading .link {
  display: inline-block;
  color: currentColor;
  text-decoration: none;
  position: relative;
  z-index: 100;
  display: inline-grid;
  grid-template-areas: "logo" "str_main" "str_sub";
  grid-template-columns: 1fr;
  grid-template-rows: repeat(3, max-content);
}
.site-header .body .site-title .heading .link .logo {
  grid-area: logo;
}
.site-header .body .site-title .heading .link .string.main {
  grid-area: str_main;
}
.site-header .body .site-title .heading .link .string.sub {
  grid-area: str_sub;
}
.site-header .body .site-title .heading .link {
  text-align: center;
}
.site-header .body .site-title .heading .link .logo {
  margin-inline-start: auto;
  margin-inline-end: auto;
}
@media screen and (min-width: 1025px) {
  .site-header .body .site-title .heading .link .logo {
    max-inline-size: 2.1875vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .site-title .heading .link .logo {
    max-inline-size: 3.90625vw;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .site-title .heading .link .logo {
    max-inline-size: 8vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-header .body .site-title .heading .link .logo {
    padding-block-start: 0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .site-title .heading .link .logo {
    padding-block-start: 0.58594vw;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .site-title .heading .link .logo {
    padding-block-start: 1vw;
  }
}
.site-header .body .site-title .heading .link .logo .icon {
  display: inline-block;
  inline-size: 100%;
  object-fit: cover;
  aspect-ratio: 2 / 3;
}
.site-header .body .site-title .heading .link .string {
  color: #a92522;
  font-family: "iowan-old-style-bt-regular", "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  letter-spacing: 0.08em;
}
.site-header .body .site-title .heading .link .string.main {
  text-align: center;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .site-header .body .site-title .heading .link .string.main {
    font-size: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .site-title .heading .link .string.main {
    font-size: 2.14844vw;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .site-title .heading .link .string.main {
    font-size: 4.5vw;
  }
}
.site-header .body .site-title .heading .link .string.main::after {
  content: attr(data-text);
  position: static;
  font-family: "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}
.site-header .body .site-title .heading .link .string.sub {
  text-align: left;
  font-weight: normal;
  text-transform: capitalize;
}
@media screen and (min-width: 1025px) {
  .site-header .body .site-title .heading .link .string.sub {
    font-size: 0.52083vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .site-title .heading .link .string.sub {
    font-size: 0.87891vw;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .site-title .heading .link .string.sub {
    font-size: 2vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-header .body .g-header-navi-icon {
    line-height: 1;
    appearance: none;
    cursor: pointer;
    position: absolute;
    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;
  }
}
@media screen and (min-width: 1025px) and (min-width: 1025px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 0.83333vw;
  }
}
@media screen and (min-width: 1025px) and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 1.17188vw;
  }
}
@media screen and (min-width: 1025px) and (max-width: 600px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 2vw;
  }
}
@media screen and (min-width: 1025px) {
  .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(33% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(2) {
    inset-block-start: calc(50% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(3) {
    inset-block-start: calc(67% - 0.5px);
    transform-origin: left;
  }
  .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.is_active .mark:nth-of-type(3) {
    scale: 0 1;
  }
  .site-header .body .g-header-navi {
    position: absolute;
    inline-size: 100%;
    transition: inset 0.4s ease-in-out;
  }
  .site-header .body .g-header-navi .list-navi {
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    inline-size: 100%;
    background-color: rgba(255, 255, 255, 0.8);
  }
  .site-header .body .g-header-navi .list-navi .item {
    inline-size: 100%;
  }
  .site-header .body .g-header-navi .list-navi .item .link {
    display: inline-block;
    color: currentColor;
    text-decoration: none;
    inline-size: 100%;
    text-align: center;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    color: #a92522;
    text-transform: capitalize;
  }
  .site-header .body .g-header-navi {
    inset-inline-start: -120%;
  }
  .site-header .body .g-header-navi.is_active {
    inset-inline-start: 0;
  }
  .site-header .body .g-header-navi {
    inset-block-start: 0;
  }
  .site-header .body .g-header-navi .list-navi {
    max-inline-size: 100%;
    block-size: 100vh;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    padding-block-start: 0.83333vw;
    padding-block-end: 0.83333vw;
  }
  .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: 1024px) and (min-width: 601px) {
  .site-header .body .g-header-navi-icon {
    line-height: 1;
    appearance: none;
    cursor: pointer;
    position: absolute;
    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;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) and (min-width: 1025px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 0.83333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 1.17188vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) and (max-width: 600px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 2vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .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(33% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(2) {
    inset-block-start: calc(50% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(3) {
    inset-block-start: calc(67% - 0.5px);
    transform-origin: left;
  }
  .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.is_active .mark:nth-of-type(3) {
    scale: 0 1;
  }
  .site-header .body .g-header-navi {
    position: absolute;
    inline-size: 100%;
    transition: inset 0.4s ease-in-out;
  }
  .site-header .body .g-header-navi .list-navi {
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    inline-size: 100%;
    background-color: rgba(255, 255, 255, 0.8);
  }
  .site-header .body .g-header-navi .list-navi .item {
    inline-size: 100%;
  }
  .site-header .body .g-header-navi .list-navi .item .link {
    display: inline-block;
    color: currentColor;
    text-decoration: none;
    inline-size: 100%;
    text-align: center;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    color: #a92522;
    text-transform: capitalize;
  }
  .site-header .body .g-header-navi {
    inset-inline-start: -120%;
  }
  .site-header .body .g-header-navi.is_active {
    inset-inline-start: 0;
  }
  .site-header .body .g-header-navi {
    inset-block-start: 0;
  }
  .site-header .body .g-header-navi .list-navi {
    max-inline-size: 100%;
    block-size: 100vh;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    padding-block-start: 1.5625vw;
    padding-block-end: 1.5625vw;
  }
  .site-header .body .g-header-navi-icon {
    inset-inline-end: 2.34375vw;
    max-inline-size: 5.07813vw;
    block-size: 5.07813vw;
  }
  .site-header .body .g-header-navi-icon .mark {
    max-inline-size: 4.29688vw;
    block-size: 1px;
  }
}
@media screen and (max-width: 600px) {
  .site-header .body .g-header-navi-icon {
    line-height: 1;
    appearance: none;
    cursor: pointer;
    position: absolute;
    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;
  }
}
@media screen and (max-width: 600px) and (min-width: 1025px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 0.83333vw;
  }
}
@media screen and (max-width: 600px) and (max-width: 1024px) and (min-width: 601px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 1.17188vw;
  }
}
@media screen and (max-width: 600px) and (max-width: 600px) {
  .site-header .body .g-header-navi-icon {
    inset-block-start: 2vw;
  }
}
@media screen and (max-width: 600px) {
  .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(33% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(2) {
    inset-block-start: calc(50% - 0.5px);
  }
  .site-header .body .g-header-navi-icon .mark:nth-of-type(3) {
    inset-block-start: calc(67% - 0.5px);
    transform-origin: left;
  }
  .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.is_active .mark:nth-of-type(3) {
    scale: 0 1;
  }
  .site-header .body .g-header-navi {
    position: absolute;
    inline-size: 100%;
    transition: inset 0.4s ease-in-out;
  }
  .site-header .body .g-header-navi .list-navi {
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    inline-size: 100%;
    background-color: rgba(255, 255, 255, 0.8);
  }
  .site-header .body .g-header-navi .list-navi .item {
    inline-size: 100%;
  }
  .site-header .body .g-header-navi .list-navi .item .link {
    display: inline-block;
    color: currentColor;
    text-decoration: none;
    inline-size: 100%;
    text-align: center;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    color: #a92522;
    text-transform: capitalize;
  }
  .site-header .body .g-header-navi {
    inset-inline-start: -120%;
  }
  .site-header .body .g-header-navi.is_active {
    inset-inline-start: 0;
  }
  .site-header .body .g-header-navi {
    inset-block-start: 0;
  }
  .site-header .body .g-header-navi .list-navi {
    max-inline-size: 100%;
    block-size: 100vh;
  }
  .site-header .body .g-header-navi .list-navi .item .link .string {
    padding-block-start: 4vw;
    padding-block-end: 4vw;
    font-size: 3.75vw;
  }
  .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;
  }
}

.g-btn-related {
  position: fixed;
  z-index: 9999;
  inline-size: 100%;
  border-radius: 50%;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.8s ease, visibility 0.8s ease;
}
@media screen and (min-width: 1025px) {
  .g-btn-related {
    max-inline-size: 7.5vw;
    block-size: 7.5vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related {
    max-inline-size: 11.71875vw;
    block-size: 11.71875vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related {
    max-inline-size: 21vw;
    block-size: 21vw;
  }
}
.g-btn-related .link {
  display: inline-block;
  color: currentColor;
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  inline-size: 100%;
  block-size: 100%;
}
.g-btn-related .link .string {
  color: #fff;
  font-family: "Sarpanch-Regular", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
@media screen and (min-width: 1025px) {
  .g-btn-related .link .string {
    font-size: 0.72917vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related .link .string {
    font-size: 1.26953vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related .link .string {
    font-size: 2.75vw;
  }
}
.g-btn-related.online-shop {
  background-color: #81d8d0;
}
@media screen and (min-width: 601px) {
  .g-btn-related.online-shop {
    inset-block-start: 5vw;
    inset-inline-end: 0.83333vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.online-shop {
    inset-block-start: 15vw;
    inset-inline-end: 2vw;
  }
}
.g-btn-related.online-shop .link .string {
  text-transform: uppercase;
}
@media screen and (min-width: 1025px) {
  .g-btn-related.online-shop .link .string {
    padding-block-end: 0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.online-shop .link .string {
    padding-block-end: 0.58594vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.online-shop .link .string {
    padding-block-end: 1vw;
  }
}
.g-btn-related.online-shop .link .image {
  inline-size: 100%;
  aspect-ratio: 1/1;
}
@media screen and (min-width: 1025px) {
  .g-btn-related.online-shop .link .image {
    max-inline-size: 2.91667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.online-shop .link .image {
    max-inline-size: 4.6875vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.online-shop .link .image {
    max-inline-size: 7vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-btn-related.online-shop .link .image {
    margin-block-start: -0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.online-shop .link .image {
    margin-block-start: -0.78125vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.online-shop .link .image {
    margin-block-start: -2vw;
  }
}
.g-btn-related.instagram {
  background-color: #cf2e92;
}
@media screen and (min-width: 601px) {
  .g-btn-related.instagram {
    inset-block-start: 15vw;
    inset-inline-end: 0.83333vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.instagram {
    inset-block-start: 42vw;
    inset-inline-end: 2vw;
  }
}
.g-btn-related.instagram .link .string {
  text-transform: capitalize;
}
@media screen and (min-width: 1025px) {
  .g-btn-related.instagram .link .string {
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.instagram .link .string {
    padding-block-end: 1.95313vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.instagram .link .string {
    padding-block-end: 4vw;
  }
}
.g-btn-related.instagram .link .image {
  inline-size: 100%;
  aspect-ratio: 1/1;
}
@media screen and (min-width: 1025px) {
  .g-btn-related.instagram .link .image {
    max-inline-size: 3.33333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.instagram .link .image {
    max-inline-size: 6.25vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.instagram .link .image {
    max-inline-size: 10vw;
  }
}
@media screen and (min-width: 1025px) {
  .g-btn-related.instagram .link .image {
    margin-block-start: -0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .g-btn-related.instagram .link .image {
    margin-block-start: -0.78125vw;
  }
}
@media screen and (max-width: 600px) {
  .g-btn-related.instagram .link .image {
    margin-block-start: -2vw;
  }
}
.g-btn-related.is_hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.site-footer {
  position: relative;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 100%;
  background-color: rgba(199, 154, 87, 0.5);
  z-index: -2;
}
@media screen and (min-width: 1025px) {
  .site-footer .body {
    padding-block-start: 2.5vw;
    padding-block-end: 2.5vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body {
    padding-block-start: 3.51563vw;
    padding-block-end: 3.51563vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body {
    padding-block-start: 6vw;
    padding-block-end: 6vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title .heading {
    padding-inline-start: 0.83333vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title .heading {
    padding-inline-start: 1.36719vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title .heading {
    padding-inline-start: 3vw;
  }
}
.site-footer .body .site-title .heading .link {
  display: inline-block;
  color: currentColor;
  text-decoration: none;
  position: relative;
  z-index: 100;
  display: inline-grid;
  grid-template-areas: "logo" "str_main" "str_sub";
  grid-template-columns: 1fr;
  grid-template-rows: repeat(3, max-content);
}
.site-footer .body .site-title .heading .link .logo {
  grid-area: logo;
}
.site-footer .body .site-title .heading .link .string.main {
  grid-area: str_main;
}
.site-footer .body .site-title .heading .link .string.sub {
  grid-area: str_sub;
}
.site-footer .body .site-title .heading .link {
  text-align: center;
}
.site-footer .body .site-title .heading .link .logo {
  margin-inline-start: auto;
  margin-inline-end: auto;
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title .heading .link .logo {
    max-inline-size: 2.1875vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title .heading .link .logo {
    max-inline-size: 3.90625vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title .heading .link .logo {
    max-inline-size: 8vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title .heading .link .logo {
    padding-block-start: 0.41667vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title .heading .link .logo {
    padding-block-start: 0.58594vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title .heading .link .logo {
    padding-block-start: 1vw;
  }
}
.site-footer .body .site-title .heading .link .logo .icon {
  display: inline-block;
  inline-size: 100%;
  object-fit: cover;
  aspect-ratio: 2 / 3;
}
.site-footer .body .site-title .heading .link .string {
  color: #a92522;
  font-family: "iowan-old-style-bt-regular", "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  letter-spacing: 0.08em;
}
.site-footer .body .site-title .heading .link .string.main {
  text-align: center;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title .heading .link .string.main {
    font-size: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title .heading .link .string.main {
    font-size: 2.14844vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title .heading .link .string.main {
    font-size: 4.5vw;
  }
}
.site-footer .body .site-title .heading .link .string.main::after {
  content: attr(data-text);
  position: static;
  font-family: "Times New Roman", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
}
.site-footer .body .site-title .heading .link .string.sub {
  text-align: left;
  font-weight: normal;
  text-transform: capitalize;
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title .heading .link .string.sub {
    font-size: 0.52083vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title .heading .link .string.sub {
    font-size: 0.87891vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title .heading .link .string.sub {
    font-size: 2vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-footer .body .site-title {
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .site-title {
    padding-block-end: 1.95313vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .site-title {
    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: 1025px) {
  .site-footer .body .g-footer-navi .list-navi .item {
    max-inline-size: calc(calc(100% - 7.5vw) / 3);
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .g-footer-navi .list-navi .item {
    max-inline-size: calc(calc(100% - 11.71876vw) / 3);
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .g-footer-navi .list-navi .item {
    max-inline-size: calc(calc(100% - 24vw) / 3);
  }
}
.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: currentColor;
  text-decoration: none;
  inline-size: 100%;
}
.site-footer .body .g-footer-navi .list-navi .item .link .string {
  inline-size: 100%;
  color: #fff;
  text-align: center;
  text-transform: capitalize;
}
@media screen and (min-width: 1025px) {
  .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: 1024px) and (min-width: 601px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    padding-block-start: 1.17188vw;
    padding-block-end: 1.17188vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    padding-block-start: 2vw;
    padding-block-end: 2vw;
  }
}
@media screen and (min-width: 1025px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    font-size: 1.66016vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .body .g-footer-navi .list-navi .item .link .string {
    font-size: 3.25vw;
  }
}
.site-footer .foot {
  position: relative;
}
.site-footer .foot::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: -2;
  inline-size: 100%;
  block-size: 100%;
  background-color: rgb(84.5, 18.5, 17);
}
.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 year name";
}
.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: #fff;
}
@media screen and (min-width: 1025px) {
  .site-footer .foot .copyright .sentence {
    padding-block-start: 1.25vw;
    padding-block-end: 1.25vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .foot .copyright .sentence {
    padding-block-start: 1.95313vw;
    padding-block-end: 1.95313vw;
  }
}
@media screen and (max-width: 600px) {
  .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: 1025px) {
  .site-footer .foot .copyright .sentence .year {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .foot .copyright .sentence .year {
    font-size: 1.36719vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .foot .copyright .sentence .year {
    font-size: 3vw;
  }
}
.site-footer .foot .copyright .sentence .name {
  letter-spacing: 0.08em;
}
@media screen and (min-width: 1025px) {
  .site-footer .foot .copyright .sentence .name {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 1024px) and (min-width: 601px) {
  .site-footer .foot .copyright .sentence .name {
    font-size: 1.36719vw;
  }
}
@media screen and (max-width: 600px) {
  .site-footer .foot .copyright .sentence .name {
    font-size: 3vw;
  }
}
.site-footer .foot .copyright .sentence .name .string.main {
  position: relative;
}
.site-footer .foot .copyright .sentence .name .string.main::after {
  content: attr(data-text);
  position: static;
}
.site-footer .foot .copyright .sentence .name .string.sub {
  text-transform: capitalize;
}
/*# sourceMappingURL=project-common.css.map */
