/* =====================================
Common
===================================== */
:root {
  --font-ja__gothic: "Noto Sans JP", serif;
  --font-ja__mincho: "Noto Serif JP", serif;
  --color-primary: #6a1222;
}
html {
  overflow: auto;
}
body {
  position: relative;
  overflow: clip;
  line-height: 1;
  font-weight: 500;
  font-size: clamp(9.6px, 1.25vw, 24px);
  color: #333;
  font-family: var(--font-ja__gothic);
  letter-spacing: 0.02em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: justify;
}
a {
  display: inline-block;
  color: inherit;
  word-break: break-all;
  transition: opacity 0.6s ease;
}
a:hover,
a:focus {
  opacity: 0.5;
}
img {
  width: 100%;
  object-fit: cover;
}
/* .js-fadeinbottom {
  opacity: 0;
  transform: translateY(clamp(12px, 1.5625vw, 30px));
  visibility: hidden;
  transition: opacity 0.9s, transform 0.9s cubic-bezier(0.3, 1, 0.7, 1),
    visibility 0.9s;
}
.js-fadeinbottom.in-fadeinbottom {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}
.js-fadein {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.9s, visibility 0.9s;
}
.js-fadein.in-fadein {
  opacity: 1;
  visibility: visible;
} */
.sp {
  display: none;
}
.container {
  position: relative;
  max-width: 1840px;
  margin-inline: auto;
  padding: 0 clamp(48px, 6.25vw, 120px);
  padding: 0 clamp(65px, 8.5156vw, 163.5px);
  width: 100%;
}
.color-primary {
  color: var(--color-primary);
}
.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12.6px, 1.640625vw, 31.5px) clamp(18px, 2.34375vw, 45px);
  min-width: clamp(150px, 19.53125vw, 375px);
  width: clamp(150px, 19.53125vw, 375px);
  background-color: #fff;
  color: #333;
  line-height: 1.3;
  transition: 0.4s opacity ease;
}
.button::before {
  position: absolute;
  content: "";
  top: clamp(11.4px, 1.484375vw, 28.5px);
  right: clamp(13.2px, 1.71875vw, 33px);
  transition: 0.4s right ease;
  width: clamp(14.4px, 1.875vw, 36px);
  height: clamp(14.4px, 1.875vw, 36px);
  background-image: url(../images/icon__arrow--primary.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transform: rotate(-90deg);
  transition: 0.4s right ease;
}
.button::after {
  position: absolute;
  content: "";
  height: 100%;
  width: 0;
  background-color: transparent;
  top: 0;
  bottom: 0;
  left: 0;
  transition: 0.4s width ease, 0.4s background-color ease;
  opacity: 0.2;
  z-index: 1;
}
.button__text {
  position: relative;
  z-index: 2;
}
.button.--color-primary {
  background-color: var(--color-primary);
  color: #fff;
}
.button.--align-left {
  justify-content: flex-start;
}
.button.--color-primary::before {
  background-color: var(--color-primary);
  background-image: url(../images/icon__arrow--white.svg);
}
.section-head {
}
.section-title {
  font-size: clamp(20.4px, 2.65625vw, 51px);
  line-height: 0.8;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: var(--font-ja__mincho);
}
.section-head.--horizontal {
  display: flex;
  align-items: flex-end;
}
.section-subtitle {
  margin-top: clamp(18px, 2.34375vw, 45px);
}
.section-subtitle.--horizontal {
  margin-top: 0;
  margin-left: clamp(9px, 1.171875vw, 22.5px);
  letter-spacing: -0.07em;
}
@media screen and (max-width: 769px) {
  /* =====================================
  Common
  ===================================== */
  html {
  }
  body {
    font-size: calc(16 / 390 * 100vw);
  }
  a {
  }
  a:hover,
  a:focus {
  }
  img {
  }
  .fadeInUp {
  }
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .container {
    padding: 0;
    width: 87.2%;
  }
  .color-primary {
  }
  .button {
    padding: calc(16 / 390 * 100vw) calc(30 / 390 * 100vw);
    font-size: calc(15 / 390 * 100vw);
    width: calc(250 / 390 * 100vw);
    text-align: center;
  }
  .button::before {
    width: calc(24 / 390 * 100vw);
    height: calc(24 / 390 * 100vw);
    right: calc(15 / 390 * 100vw);
    top: calc(14 / 390 * 100vw);
  }
  .button.--color-primary {
  }
  .button.--align-left {
  }
  .button.--color-primary::before {
  }
  .section-head {
  }
  .section-title {
    font-size: calc(28 / 390 * 100vw);
  }
  .section-head.--horizontal {
  }
  .section-subtitle {
    font-size: calc(15 / 390 * 100vw);
    margin-top: calc(20 / 390 * 100vw);
  }
  .section-subtitle.--horizontal {
    margin-left: calc(15 / 390 * 100vw);
  }
}
@media (hover: hover) and (pointer: fine) {
  .button:hover {
    opacity: 1;
  }
  .button:hover::before {
    right: clamp(10.8px, 1.40625vw, 27px);
    opacity: 1;
  }
  .button:hover::after {
    width: 100%;
    background-color: var(--color-primary);
  }
  .button.--color-primary::after {
    background-color: #fff;
  }
}
