@charset "UTF-8";
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  word-break: break-all;
}
@media screen and (max-width: 767px) {
  html {
    font-size: min(16 / 390 * 100vw, 20.5128205128px);
  }
}
@media (min-width: 768px) and (max-width: 1530px) {
  html {
    font-size: 1.045751634vw;
  }
}
@media (min-width: 1531px) {
  html {
    font-size: 16px;
  }
}

body {
  font-size: 1.25rem;
  color: #064B80;
  font-family: "Noto Serif JP", serif;
}
body.no-scroll {
  overflow: hidden;
  height: 100vh;
}

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

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

.container {
  max-width: 91.6875rem;
  padding-inline: 1.5625rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .container {
    max-width: 21.25rem;
    padding-inline: 0.9375rem;
  }
}

.section-title {
  font-family: "Afacad", sans-serif;
  font-size: 3rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .section-title {
    font-size: 1.375rem;
  }
}

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

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

.footer {
  background: #064B80;
  padding-top: 25.9375rem;
  padding-left: 9.375rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .footer {
    padding-top: 2.0625rem;
    padding-left: 1.875rem;
    padding-bottom: 1.75rem;
  }
}

.footer__inner {
  color: #FFFFFF;
}

.footer__logo {
  max-width: 31.25rem;
}
@media screen and (max-width: 767px) {
  .footer__logo {
    max-width: 8.125rem;
  }
}

.footer__info {
  margin-top: 3.75rem;
  font-weight: 400;
  line-height: 1.7666666667;
  font-size: 1.875rem;
}
@media screen and (max-width: 767px) {
  .footer__info {
    margin-top: 1.875rem;
    font-size: 0.5625rem;
  }
}

.header {
  height: 11.5rem;
}
@media screen and (max-width: 767px) {
  .header {
    height: 5.25rem;
  }
}

.header__inner {
  height: 100%;
  display: flex;
  align-items: center;
  padding-left: 4.6875rem;
}
@media screen and (max-width: 767px) {
  .header__inner {
    display: block;
    height: auto;
    align-items: initial;
    padding-top: 2.5rem;
    padding-left: 1.0625rem;
    padding-bottom: 1.25rem;
  }
}

.header__logo {
  margin: 0;
}

.header__logo-link {
  display: block;
}

.header__logo-img {
  width: 15.625rem;
  height: 3.125rem;
}
@media screen and (max-width: 767px) {
  .header__logo-img {
    width: 7.125rem;
    height: 1.375rem;
  }
}

.hero__inner {
  position: relative;
}

.hero-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 17.0625rem;
  height: 17.0625rem;
  border-radius: 50%;
  background: #004a80;
  /* 紺色 */
  color: #fff;
  border: 1.125rem solid #FFFFFF;
  text-decoration: none;
  font-family: "Afacad", sans-serif;
  position: absolute;
  top: 42.8125rem;
  left: 1.75rem;
}
@media screen and (max-width: 767px) {
  .hero-btn {
    top: 17.6875rem;
    left: 0.1875rem;
    width: 6.875rem;
    height: 6.875rem;
    border: 0.5rem solid #FFFFFF;
  }
}

/* 中央線（3本目） */
.hero-btn::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 1.75rem;
  width: 0.0625rem;
  height: 0.8125rem;
  background: #FFFFFF;
}
@media screen and (max-width: 767px) {
  .hero-btn::before {
    height: 0.3125rem;
    top: 0.625rem;
  }
}

.hero__top {
  position: relative;
  margin-bottom: -1rem;
  font-size: 1.375rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .hero__top {
    font-size: 0.5625rem;
  }
}

.hero__top {
  /* 左線 */
  /* 右線 */
}
.hero__top::before, .hero__top::after {
  content: "";
  position: absolute;
  top: -1.4375rem;
  width: 1px;
  height: 0.75rem;
  background: #FFFFFF;
}
@media screen and (max-width: 767px) {
  .hero__top::before, .hero__top::after {
    height: 0.3125rem;
    top: -0.75rem;
  }
}
.hero__top::before {
  left: 30%;
  transform: rotate(-25deg);
}
.hero__top::after {
  right: 30%;
  transform: rotate(25deg);
}

.hero__main {
  font-weight: 500;
  font-size: 3.75rem;
  border-bottom: 0.0625rem dashed #FFFFFF; /* 白い点線 */
  padding-bottom: 0.3125rem; /* 文字との余白 */
  margin-bottom: 1.0625rem; /* 下のテキストとの間隔 */
}
@media screen and (max-width: 767px) {
  .hero__main {
    font-size: 1.5rem;
    padding-bottom: 0.25rem;
    padding-bottom: 0;
    /* 文字との余白 */
    margin-bottom: 0.375rem;
    /* 下のテキストとの間隔 */
    margin-top: 0.625rem;
  }
}

.hero__bottom {
  font-weight: 700;
  font-size: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .hero__bottom {
    font-size: 0.5rem;
  }
}

.hero__figure--sub {
  margin-top: 4.0625rem;
}
@media screen and (max-width: 767px) {
  .hero__figure--sub {
    margin-top: 3.75rem;
  }
}

.concept {
  background-image: url(../assets/img/common/concept-bg.png);
  background-repeat: no-repeat;
  background-size: 92.25rem 51.4375rem; /* デザイン通りの実寸 */
  background-position: right 4.375rem top 8.125rem; /* 右から30px、上から130px */
  padding-top: 6.875rem;
  padding-bottom: 34.375rem;
  background-image: url("../assets/img/common/concept-bg.png");
  background-repeat: no-repeat;
  background-size: 85.4vw auto; /* 画像を幅基準で縮める */
  background-position: right 4.05vw top 7.53vw; /* 右70px、上130px */
  padding-top: 6.4vw; /* 110 ÷ 1728 ≒ 6.37vw */
  padding-bottom: 31.8vw; /* 550 ÷ 1728 ≒ 31.8vw */
}
@media screen and (max-width: 767px) {
  .concept {
    background-image: url("../assets/img/common/concept-sp-bg.png");
    padding-top: 5.3125rem;
    background-position: right 0.05vw top 7.53vw; /* 右70px、上130px */
  }
}

@media screen and (max-width: 767px) {
  .concept__inner {
    max-width: 21.5625rem;
  }
}

@media screen and (max-width: 767px) {
  .concept-title {
    text-align: center;
  }
}

.concept__text {
  margin-top: 2.8125rem;
}
@media screen and (max-width: 767px) {
  .concept__text {
    margin-top: 0.9375rem;
    max-width: 21.5625rem;
  }
}
.concept__text p {
  font-size: 1.875rem;
  line-height: 1.7;
  line-height: 1.7666666667;
}
@media screen and (max-width: 767px) {
  .concept__text p {
    font-size: 0.8125rem;
    line-height: 2;
  }
}

.menu {
  padding-top: 13.125rem;
}
@media screen and (max-width: 767px) {
  .menu {
    padding-top: 4.0625rem;
  }
}

.menu-title {
  text-align: left;
}
@media screen and (max-width: 767px) {
  .menu-title {
    text-align: center;
  }
}

.menu__group {
  margin-top: 2.625rem;
}

.menu__group-header {
  text-align: center;
}

.menu-cut__title {
  display: block;
  max-width: 94.8125rem;
  height: 10.6875rem;
  margin-inline: -1.5625rem;
  background: url("../assets/img/common/decoration.png") no-repeat center top;
  background-size: contain;
  font-size: 3rem;
  font-weight: bold;
  line-height: 10.6875rem;
  padding-top: 3.4375rem;
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767px) {
  .menu-cut__title {
    height: auto;
    line-height: 1;
    max-width: 21.25rem;
    font-size: 1.125rem;
    padding-top: 1.875rem;
    margin-inline: auto;
  }
}

.menu-color__title {
  display: block;
  max-width: 94.8125rem;
  height: 10.6875rem;
  margin-inline: -1.5625rem;
  background: url("../assets/img/common/decoration.png") no-repeat center top;
  background-size: contain;
  font-size: 3rem;
  font-weight: bold;
  line-height: 10.6875rem;
  padding-top: 3.4375rem;
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767px) {
  .menu-color__title {
    height: auto;
    line-height: 1;
    max-width: 21.25rem;
    font-size: 1.125rem;
    padding-top: 1.875rem;
    margin-inline: auto;
  }
}

.menu-other__title {
  display: block;
  max-width: 94.8125rem;
  height: 10.6875rem;
  margin-inline: -1.5625rem;
  background: url("../assets/img/common/decoration.png") no-repeat center top;
  background-size: contain;
  font-size: 3rem;
  font-weight: bold;
  line-height: 10.6875rem;
  padding-top: 3.4375rem;
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767px) {
  .menu-other__title {
    height: auto;
    line-height: 1;
    max-width: 21.25rem;
    font-size: 1.125rem;
    padding-top: 1.875rem;
    margin-inline: auto;
  }
}

.menu__list-color {
  margin-top: 5.625rem;
}
@media screen and (max-width: 767px) {
  .menu__list-color {
    margin-top: 1.25rem;
  }
}

.menu__list-cut {
  margin-top: 5.625rem;
}
@media screen and (max-width: 767px) {
  .menu__list-cut {
    margin-top: 1.25rem;
  }
}

.menu__list-other {
  margin-top: 5.625rem;
}
@media screen and (max-width: 767px) {
  .menu__list-other {
    margin-top: 1.875rem;
  }
}

.menu__item {
  display: flex;
  align-items: center;
  max-width: 83.4375rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .menu__item {
    position: relative;
    justify-content: space-between;
    padding-bottom: 0.25em;
  }
}

.menu__item:not(:first-child) {
  margin-top: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .menu__item:not(:first-child) {
    margin-top: 0.9375rem;
  }
}

.menu__name {
  display: flex;
  align-items: center;
  flex: 1;
  white-space: nowrap;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  .menu__name {
    padding-left: 1.25rem;
    font-size: 0.875rem;
  }
}
.menu__name::after {
  content: "";
  flex: 1;
  border-bottom: 1px dotted #999;
  margin: 0 1em;
}
@media screen and (max-width: 767px) {
  .menu__name::after {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    border-bottom: 1px dotted #999;
  }
}

.menu__price {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 1.5rem;
  white-space: nowrap;
  margin-left: 0.5em;
}
@media screen and (max-width: 767px) {
  .menu__price {
    font-size: 0.875rem;
    padding-right: 1.25rem;
  }
}

.menu__group--color {
  margin-top: 15.625rem;
}
@media screen and (max-width: 767px) {
  .menu__group--color {
    margin-top: 2.1875rem;
  }
}

.menu__group--other {
  margin-top: 10rem;
}
@media screen and (max-width: 767px) {
  .menu__group--other {
    margin-top: 2.1875rem;
  }
}

.menu__footer {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  .menu__footer {
    margin-top: 1.875rem;
  }
}

.menu__decoration {
  display: block;
  max-width: 94.8125rem;
  height: 10.6875rem;
  margin-inline: -1.5625rem;
  background: url("../assets/img/common/decoration.png") no-repeat center top;
  background-size: contain;
  padding-top: 3.4375rem;
  padding-bottom: 1.25rem;
  transform: scaleY(-1);
}
@media screen and (max-width: 767px) {
  .menu__decoration {
    max-width: 21.25rem;
    height: 0;
    margin-inline: auto;
  }
}

.profile {
  background-image: url("../assets/img/common/profile-bg.png");
  background-repeat: no-repeat;
  background-size: 65.9vw auto; /* 画像を幅基準で縮める */
  background-position: left 0 bottom 6vw; /* 右70px、上130px */
  padding-top: 6.4vw;
  /* 110 ÷ 1728 ≒ 6.37vw */
  padding-bottom: 43.9vw; /* 550 ÷ 1728 ≒ 31.8vw */
}
@media screen and (max-width: 767px) {
  .profile {
    background-position: left 0 bottom 8vw; /* 右70px、上130px */
    background-size: 47vw auto; /* 画像を幅基準で縮める */
  }
}

@media screen and (max-width: 767px) {
  .profile-title {
    text-align: center;
  }
}

.profile__grid {
  max-width: 53.75rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .profile__grid {
    max-width: 18.125rem;
  }
}

.profile__figure {
  margin-top: 10.625rem;
}
@media screen and (max-width: 767px) {
  .profile__figure {
    margin-top: 1.25rem;
  }
}

.profile__caption {
  margin-top: 10rem;
  font-size: 2.5rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  column-gap: 2.5rem;
}
@media screen and (max-width: 767px) {
  .profile__caption {
    font-size: 0.625rem;
    column-gap: 0.3125rem;
    margin-top: 1.5625rem;
  }
}

.profile__role {
  position: relative;
}
.profile__role + .profile__role {
  padding-left: 1em;
}
.profile__role + .profile__role::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-25%);
  width: 0.09375rem;
  height: 0.5em;
  background-color: #D9D9D9;
}
@media screen and (max-width: 767px) {
  .profile__role + .profile__role::before {
    width: 0.03125rem;
    height: 0.8em;
  }
}

.profile__name {
  margin-top: 0.625rem;
  font-weight: 500;
}

.profile__name-ja {
  font-size: 3rem;
  line-height: 2;
  margin-right: 2.5rem;
}
@media screen and (max-width: 767px) {
  .profile__name-ja {
    font-size: 1rem;
    margin-right: 0.75rem;
  }
}

.profile__name-en {
  font-size: 2.1875rem;
}
@media screen and (max-width: 767px) {
  .profile__name-en {
    font-size: 0.625rem;
  }
}

.profile__text {
  font-size: 1.875rem;
  margin-top: 0.9375rem;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .profile__text {
    font-size: 0.75rem;
  }
}

.profile__sns {
  margin-top: 15rem;
  display: flex;
}
@media screen and (max-width: 767px) {
  .profile__sns {
    margin-top: 1.25rem;
  }
}

.profile__sns-link {
  margin-left: auto;
  display: block;
  width: 4.9375rem;
  height: 4.75rem;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 767px) {
  .profile__sns-link {
    width: 1.6875rem;
    height: 1.625rem;
  }
}
.profile__sns-link:hover, .profile__sns-link:focus {
  opacity: 0.7;
}

.profile__sns-icon {
  width: 100%;
  height: auto;
  display: block;
}

.access {
  padding-bottom: 31.25rem;
  background-image: url("../assets/img/common/access-bg.png");
  background-repeat: no-repeat;
  background-size: 36vw auto; /* 画像を幅基準で縮める */
  background-position: right -4vw top 80vw; /* 右70px、上130px */
  /* 110 ÷ 1728 ≒ 6.37vw */
  padding-bottom: 29vw;
}
@media screen and (max-width: 767px) {
  .access {
    padding-bottom: 13vw;
  }
}

@media screen and (max-width: 767px) {
  .access__inner {
    max-width: 18.125rem;
  }
}

.access__top {
  max-width: 74.375rem;
  margin-inline: auto;
}

@media screen and (max-width: 767px) {
  .access-title {
    text-align: center;
  }
}

.access__map {
  margin-top: 4.0625rem;
  aspect-ratio: 1194/1034;
}
@media screen and (max-width: 767px) {
  .access__map {
    margin-top: 1.5625rem;
  }
}
.access__map iframe {
  width: 100%;
  height: 100%;
}

.access__title {
  text-align: center;
  margin-top: 7.8125rem;
}
@media screen and (max-width: 767px) {
  .access__title {
    margin-top: 1.875rem;
  }
}

.access__logo {
  max-width: 40.625rem;
}
@media screen and (max-width: 767px) {
  .access__logo {
    max-width: 8.125rem;
  }
}

.access__info {
  line-height: 1.7666666667;
  font-size: 1.875rem;
  margin-top: 9.375rem;
}
@media screen and (max-width: 767px) {
  .access__info {
    font-size: 0.625rem;
    margin-top: 1.25rem;
    line-height: 2.1;
  }
}

.access__payment {
  margin-top: 3.125rem;
  line-height: 1.7666666667;
  font-size: 1.875rem;
}
@media screen and (max-width: 767px) {
  .access__payment {
    font-size: 0.625rem;
    margin-top: 1.875rem;
    line-height: 2.1;
  }
}

.access__bottom {
  max-width: 89.375rem;
  margin-top: 10.625rem;
}
@media screen and (max-width: 767px) {
  .access__bottom {
    margin-top: 2.5rem;
  }
}

.access__transport {
  border-top: 2px dashed #064B80;
  border-bottom: 2px dashed #064B80;
  padding-top: 6.875rem;
  padding-bottom: 7.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .access__transport {
    border-top: 1px dashed #064B80;
    border-bottom: 1px dashed #064B80;
    padding-top: 1.5625rem;
    padding-bottom: 1.875rem;
  }
}

.access__subtitle {
  font-size: 3.25rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .access__subtitle {
    font-size: 0.75rem;
  }
}

.access__summary {
  margin-top: 5.3125rem;
  font-size: 2.5rem;
  line-height: 2.075;
}
@media screen and (max-width: 767px) {
  .access__summary {
    margin-top: 0.625rem;
    font-size: 0.6875rem;
  }
}

.reserve {
  padding-top: 6.25rem;
  padding-bottom: 6.25rem;
}
@media screen and (max-width: 767px) {
  .reserve {
    padding-top: 3.125rem;
    padding-bottom: 3.125rem;
  }
}

@media screen and (max-width: 767px) {
  .reserve__inner {
    max-width: 21.5625rem;
  }
}

@media screen and (max-width: 767px) {
  .reserve-title {
    text-align: center;
  }
}

.reserve__content {
  background-color: rgba(154, 154, 154, 0.2);
  padding: 3.75rem 2.5rem;
  margin-top: 3.75rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .reserve__content {
    padding: 1.875rem 1.25rem;
    margin-top: 1.875rem;
  }
}

.reserve__text {
  font-size: 1.875rem;
  line-height: 1.7666666667;
  color: #064B80;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .reserve__text {
    font-size: 0.75rem;
    line-height: 2;
    margin-bottom: 1.25rem;
  }
}

.reserve__line-btn {
  display: inline-block;
  background-color: #064B80;
  color: #FFFFFF;
  padding: 1.25rem 5rem;
  font-size: 2.1875rem;
  text-decoration: none;
  margin-bottom: 2.5rem;
  font-family: "Noto Serif JP", serif;
  transition: opacity 0.3s;
}
@media screen and (max-width: 767px) {
  .reserve__line-btn {
    padding: 0.25rem 4.0625rem;
    font-size: 0.875rem;
    margin-bottom: 1.25rem;
  }
}
@media (hover: hover) {
  .reserve__line-btn:hover {
    opacity: 0.8;
  }
}

.reserve__qr {
  display: flex;
  justify-content: center;
  align-items: center;
}

.reserve__qr-img {
  max-width: 18.75rem;
  height: auto;
}
@media screen and (max-width: 767px) {
  .reserve__qr-img {
    max-width: 12.5rem;
  }
}

.reserve__tel {
  background-color: #064B80;
  color: #FFFFFF;
  text-align: center;
  padding: 1.875rem 0;
}
@media screen and (max-width: 767px) {
  .reserve__tel {
    padding: 1.25rem 0;
  }
}

.reserve__tel-text {
  font-size: 1.875rem;
  font-family: "Noto Serif JP", serif;
}
@media screen and (max-width: 767px) {
  .reserve__tel-text {
    font-size: 1.0625rem;
  }
}

.reserve-page .header {
  border-bottom: 1px solid #064B80;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fade-in {
  opacity: 0;
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
  transform: translateY(30px);
}

.fade-in.is-animated {
  opacity: 1;
  transform: translateY(0);
}/*# sourceMappingURL=bundle.css.map */