@charset "UTF-8";
/* another test */
/*
 * Mixins
 * 再利用可能なスタイルパターンを定義
 */
/**
 * シンプル化したレスポンシブサイズ関数 - 縮小率を直接指定可能
 * 
 * @param {Number} $max-size - 最大サイズ（PC向け1440pxでの値）
 * @param {Number} $ratio - 縮小率（デフォルト0.74）
 * @return {String} - 計算されたcalc()式
 * 
 * 使用例:
 * font-size: fs(20);           // 基本使用法（デフォルト縮小率0.74）
 * font-size: fs(20, 0.5);      // 縮小率0.5で計算
 * font-size: fs(20, 1.2);      // 拡大率1.2で計算
 */
/**
 * 768px以下（モバイル）専用のレスポンシブサイズ関数
 * 比率を維持して画面幅に比例してスケール
 * 
 * @param {Number} $size-480 - 480pxでの基準サイズ
 * @return {String} - 計算されたvw値
 */
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
*:focus {
  outline: none !important;
}
*:focus-visible {
  outline: 2px solid #007bff !important;
  outline-offset: 2px !important;
}

html {
  font-size: 100%;
  line-height: 1.6;
  scroll-behavior: smooth;
}

[id] {
  scroll-margin-top: 100px;
}

body {
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  line-height: 1.6;
  color: #3f3f3f;
  background-color: #ffffff;
}

ul,
ol {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
}
a:focus {
  outline: none;
}
a:focus-visible {
  outline: 2px solid #007bff;
  outline-offset: 2px;
}

button {
  font-family: inherit;
  font-size: inherit;
  background: none;
  border: none;
  cursor: pointer;
}
button:focus {
  outline: none;
}
button:focus-visible {
  outline: 2px solid #007bff;
  outline-offset: 2px;
}

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

.wp-block-image {
  margin: 0;
}

.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.alignright {
  float: right;
  margin-left: 1rem;
}

.alignleft {
  float: left;
  margin-right: 1rem;
}

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

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

.pc-only-inline {
  display: inline;
}
@media (max-width: 767px) {
  .pc-only-inline {
    display: none;
  }
}

.sp-only-inline {
  display: none;
}
@media (max-width: 767px) {
  .sp-only-inline {
    display: inline;
  }
}

@media (max-width: 767px) {
  br.pc-only {
    display: none !important;
  }
}

br.sp-only {
  display: none !important;
}
@media (max-width: 767px) {
  br.sp-only {
    display: initial !important;
  }
}

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

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

.header__container {
  margin: 0 auto;
  padding: calc(15px + (15) * (100vw - 768px) / (672)) calc(40px + (40) * (100vw - 768px) / (672)) calc(5px + (5) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 767px) {
  .header__container {
    padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(6px, 2.0833333333vw, 18px);
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media (max-width: 767px) {
  .header__navigation-desktop {
    display: none;
  }
}
.header__hamburger {
  display: none;
}
@media (max-width: 767px) {
  .header__hamburger {
    display: block;
    position: absolute;
    right: clamp(12px, 4.1666666667vw, 36px);
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: clamp(24px, 8.3333333333vw, 72px);
    height: clamp(24px, 8.3333333333vw, 72px);
    background: none;
    border: none;
    cursor: pointer;
    padding: clamp(4.8px, 1.6666666667vw, 14.4px);
    z-index: 10000;
  }
}
@media (max-width: 767px) {
  .header__hamburger-line {
    display: block;
    width: clamp(14.4px, 5vw, 43.2px);
    height: clamp(1.2px, 0.4166666667vw, 3.6px);
    background: #000;
    margin: clamp(2.4px, 0.8333333333vw, 7.2px) 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    position: relative;
  }
}
.header__navigation-mobile {
  display: none;
}
@media (max-width: 767px) {
  .header__navigation-mobile.is-open {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: white;
    z-index: 9999;
  }
}

.branding__logo {
  display: block;
}
@media (max-width: 767px) {
  .branding__logo {
    margin: 0 auto;
  }
}
.branding__image {
  height: auto;
  max-height: calc(37px + (13) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .branding__image {
    max-height: clamp(24px, 8.3333333333vw, 72px);
  }
}

@media (max-width: 767px) {
  .header.is-open .header__hamburger-line {
    background: #000 !important;
    display: block !important;
    opacity: 1 !important;
    position: absolute !important;
    top: 50% !important;
    left: 0 !important;
    -webkit-transform-origin: center center !important;
    transform-origin: center center !important;
    margin: 0 !important;
  }
  .header.is-open .header__hamburger-line:first-child {
    -webkit-transform: translateY(-50%) rotate(45deg) !important;
    transform: translateY(-50%) rotate(45deg) !important;
  }
  .header.is-open .header__hamburger-line:last-child {
    -webkit-transform: translateY(-50%) rotate(-45deg) !important;
    transform: translateY(-50%) rotate(-45deg) !important;
  }
}
.navigation__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .navigation__menu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
    width: 100%;
  }
}
.navigation__link {
  font-family: "Noto Serif JP", serif;
  font-size: calc(12.8px + (3.2) * (100vw - 768px) / (672));
  display: block;
  color: #3f3f3f;
  text-decoration: none;
  font-weight: 400;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
@media (max-width: 767px) {
  .navigation__link {
    font-size: clamp(12px, 4.1666666667vw, 36px);
    padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px);
    text-align: center;
    font-weight: 500;
  }
}
.navigation__link:hover {
  color: #e74c3c;
}
.navigation__link:focus {
  outline: none;
}
.navigation__link:focus-visible {
  outline: 2px solid #3498db;
  outline-offset: 2px;
}
.navigation__item--current .navigation__link {
  color: #e74c3c;
}

.camera-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  width: calc(225.7px + (79.3) * (100vw - 768px) / (672));
  height: calc(48.84px + (17.16) * (100vw - 768px) / (672));
  padding: calc(17.76px + (6.24) * (100vw - 768px) / (672)) calc(47.36px + (16.64) * (100vw - 768px) / (672));
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  border-radius: calc(11.1px + (3.9) * (100vw - 768px) / (672));
  border: 1px solid #a99f3c;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: relative;
}
@media (max-width: 767px) {
  .camera-button {
    width: clamp(168px, 58.3333333333vw, 504px);
    height: clamp(31.2px, 10.8333333333vw, 93.6px);
    padding: clamp(9.6px, 3.3333333333vw, 28.8px) clamp(19.2px, 6.6666666667vw, 57.6px);
    border-radius: clamp(7.2px, 2.5vw, 21.6px);
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.camera-button::before {
  content: "";
  position: absolute;
  top: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  left: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  right: calc(-3.7px + (-1.3) * (100vw - 768px) / (672));
  bottom: calc(-3.7px + (-1.3) * (100vw - 768px) / (672));
  background: #fff;
  border-radius: calc(11.1px + (3.9) * (100vw - 768px) / (672));
  z-index: -1;
}
@media (max-width: 767px) {
  .camera-button::before {
    top: clamp(4.2px, 1.4583333333vw, 12.6px);
    left: clamp(4.2px, 1.4583333333vw, 12.6px);
    right: clamp(-4.2px, -1.4583333333vw, -12.6px);
    bottom: clamp(-4.2px, -1.4583333333vw, -12.6px);
    border-radius: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.camera-button:hover {
  background: #a99f3c;
}
.camera-button:hover .camera-button__text {
  color: #fff;
}
.camera-button:hover .camera-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}
.camera-button__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
}
@media (max-width: 767px) {
  .camera-button__content {
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.camera-button__icon {
  width: 21px;
  height: 18px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .camera-button__icon {
    width: clamp(10.8px, 3.75vw, 32.4px);
    height: clamp(9px, 3.125vw, 27px);
  }
}
.camera-button__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 500;
  line-height: 160%;
  letter-spacing: calc(2.96px + (1.04) * (100vw - 768px) / (672));
  color: #a99f3c;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .camera-button__text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  }
}
.camera-button--blue-bg {
  border: 1px solid #3f3f3f;
}
.camera-button--blue-bg::before {
  background: #c0d5dd;
}
.camera-button--blue-bg:hover {
  background: #3f3f3f;
}
.camera-button--blue-bg .camera-button__text {
  color: #3f3f3f;
}
.camera-button--blue-bg .camera-button__icon {
  -webkit-filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
  filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
}
.camera-button--blue-bg:hover .camera-button__text {
  color: #fff;
}
.camera-button--blue-bg:hover .camera-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}
.camera-button--reservation {
  border: 1px solid #3f3f3f;
}
.camera-button--reservation::before {
  background: #fcf6de !important;
}
.camera-button--reservation:hover {
  background: #3f3f3f;
}
.camera-button--reservation .camera-button__text {
  color: #3f3f3f;
}
.camera-button--reservation .camera-button__icon {
  -webkit-filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
  filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
}
.camera-button--reservation:hover .camera-button__text {
  color: #fff;
}
.camera-button--reservation:hover .camera-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}
.camera-button--send {
  border: 1px solid #3f3f3f;
}
.camera-button--send::before {
  background: #c0d5dd;
}
.camera-button--send:hover {
  background: #3f3f3f;
}
.camera-button--send .camera-button__text {
  color: #3f3f3f;
}
.camera-button--send .camera-button__icon {
  -webkit-filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
  filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
}
.camera-button--send:hover .camera-button__text {
  color: #fff;
}
.camera-button--send:hover .camera-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}
.camera-button--detail {
  border-radius: calc(3px + (3) * (100vw - 768px) / (672)) !important;
  border: 1px solid #3f3f3f !important;
}
@media (max-width: 767px) {
  .camera-button--detail {
    border-radius: clamp(7.2px, 2.5vw, 21.6px) !important;
  }
}
.camera-button--detail::before {
  background: #f5e2cf !important;
}
.camera-button--detail:hover {
  background: #3f3f3f !important;
}
.camera-button--detail .camera-button__text {
  color: #3f3f3f;
}
.camera-button--detail:hover .camera-button__text {
  color: #fff;
}
.camera-button--detail-card {
  border-radius: calc(5px + (5) * (100vw - 768px) / (672)) !important;
  border: 1px solid #3f3f3f !important;
  padding: calc(4.8px + (7.2) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672)) !important;
  height: auto !important;
}
@media (max-width: 767px) {
  .camera-button--detail-card {
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px) !important;
    padding: clamp(8.4px, 2.9166666667vw, 25.2px) clamp(12px, 4.1666666667vw, 36px) !important;
  }
}
.camera-button--detail-card::before {
  background: #f5e2cf !important;
  border-radius: calc(5px + (5) * (100vw - 768px) / (672)) !important;
}
@media (max-width: 767px) {
  .camera-button--detail-card::before {
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px) !important;
  }
}
.camera-button--detail-card:hover {
  background: #3f3f3f !important;
}
.camera-button--detail-card .camera-button__text {
  color: #3f3f3f;
  font-size: calc(8px + (8) * (100vw - 768px) / (672)) !important;
}
@media (max-width: 767px) {
  .camera-button--detail-card .camera-button__text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px) !important;
  }
}
.camera-button--detail-card:hover .camera-button__text {
  color: #fff;
}
.camera-button--contact {
  border: 1px solid #3f3f3f;
}
.camera-button--contact::before {
  background: #f5e2cf !important;
}
.camera-button--contact:hover {
  background: #3f3f3f;
}
.camera-button--contact .camera-button__text {
  color: #3f3f3f;
}
.camera-button--contact .camera-button__icon {
  -webkit-filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
  filter: brightness(0) saturate(100%) invert(25%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
}
.camera-button--contact:hover .camera-button__text {
  color: #fff;
}
.camera-button--contact:hover .camera-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}

.detail-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: calc(5.92px + (2.08) * (100vw - 768px) / (672)) calc(17.76px + (6.24) * (100vw - 768px) / (672));
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  border-radius: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  border: 1px solid #3f3f3f;
  background: transparent;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: relative;
  height: auto;
  min-width: calc(150.22px + (52.78) * (100vw - 768px) / (672));
}
.detail-button::before {
  content: "";
  position: absolute;
  top: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  left: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  right: calc(-3.7px + (-1.3) * (100vw - 768px) / (672));
  bottom: calc(-3.7px + (-1.3) * (100vw - 768px) / (672));
  background: #fff;
  border-radius: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  z-index: -1;
  min-width: calc(150.22px + (52.78) * (100vw - 768px) / (672));
}
.detail-button:hover {
  background: #3f3f3f;
}
.detail-button:hover .detail-button__text {
  color: #fff;
}
.detail-button:hover .detail-button__icon {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}
.detail-button__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(5.92px + (2.08) * (100vw - 768px) / (672));
}
.detail-button__icon {
  width: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  height: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: -webkit-filter 0.3s ease;
  transition: -webkit-filter 0.3s ease;
  transition: filter 0.3s ease;
  transition: filter 0.3s ease, -webkit-filter 0.3s ease;
}
.detail-button__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: calc(0.74px + (0.26) * (100vw - 768px) / (672));
  color: #3f3f3f;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .detail-button {
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(14.4px, 5vw, 43.2px);
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px);
    min-width: clamp(108px, 37.5vw, 324px);
  }
  .detail-button::before {
    top: clamp(2.4px, 0.8333333333vw, 7.2px);
    left: clamp(2.4px, 0.8333333333vw, 7.2px);
    right: clamp(-2.4px, -0.8333333333vw, -7.2px);
    bottom: clamp(-2.4px, -0.8333333333vw, -7.2px);
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px);
    min-width: clamp(108px, 37.5vw, 324px);
  }
  .detail-button__content {
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
  .detail-button__icon {
    width: clamp(9.6px, 3.3333333333vw, 28.8px);
    height: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
  .detail-button__text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
  }
}
.detail-button--contact::before {
  background: #f5e2cf;
}
.detail-button--contact:hover {
  background: #3f3f3f;
}
.detail-button--gallery::before {
  background: #fff;
}
.detail-button--gallery:hover {
  background: #3f3f3f;
}
.detail-button--detail::before {
  background: #fff;
}
.detail-button--detail:hover {
  background: #3f3f3f;
}
.detail-button--online-booking {
  border: 1px solid #547e8f;
}
.detail-button--online-booking::before {
  background: #fff;
}
.detail-button--online-booking .detail-button__text {
  color: #547e8f;
}
.detail-button--online-booking:hover {
  background: #547e8f;
}
.detail-button--online-booking:hover .detail-button__text {
  color: #fff;
}
.detail-button--phone-booking {
  border: 1px solid #547e8f;
}
.detail-button--phone-booking::before {
  background: #fff;
}
.detail-button--phone-booking .detail-button__text {
  color: #547e8f;
}
.detail-button--phone-booking:hover {
  background: #547e8f;
}
.detail-button--phone-booking:hover .detail-button__text {
  color: #fff;
}

.thoughts-label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: calc(7.2px + (4.8) * (100vw - 768px) / (672)) calc(9.6px + (6.4) * (100vw - 768px) / (672));
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  background-color: #4a4a4a;
}
@media (max-width: 767px) {
  .thoughts-label {
    padding: clamp(4.8px, 1.6666666667vw, 14.4px) clamp(7.2px, 2.5vw, 21.6px);
    gap: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.thoughts-label__text {
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 700;
  line-height: 160%; /* 25.6px */
  letter-spacing: 1.6px;
  margin: 0;
}
@media (max-width: 767px) {
  .thoughts-label__text {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    letter-spacing: clamp(0.72px, 0.25vw, 2.16px);
  }
}

.thoughts-title {
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
.thoughts-title__text {
  color: #3f3f3f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(23.436px + (15.624) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 500;
  line-height: 200%; /* 78.12px */
  letter-spacing: 3.906px;
  margin: 0;
  display: block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .thoughts-title__text {
    font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
    line-height: 1.8;
    letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  }
}
.thoughts-title__line {
  position: relative;
  display: block;
  width: 100%;
  padding-bottom: calc(6px + (4) * (100vw - 768px) / (672));
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
@media (max-width: 767px) {
  .thoughts-title__line {
    padding-bottom: clamp(6px, 2.0833333333vw, 18px);
  }
}
.thoughts-title__underline {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: auto;
  display: block;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.thoughts-text {
  color: #3f3f3f;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 500;
  line-height: 250%; /* 40px */
  letter-spacing: 3.2px;
  margin: 0;
  text-align: justify;
}
@media (max-width: 767px) {
  .thoughts-text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.6;
    letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
    text-align: left;
  }
}

.thoughts-section {
  padding: calc(59.2px + (20.8) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .thoughts-section {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.thoughts-section__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: 0 calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .thoughts-section__inner {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
}
.thoughts-section__label {
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  text-align: left;
}
@media (max-width: 767px) {
  .thoughts-section__label {
    margin-bottom: clamp(12px, 4.1666666667vw, 36px);
  }
}
.thoughts-section__title {
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  text-align: left;
}
@media (max-width: 767px) {
  .thoughts-section__title {
    margin-bottom: clamp(12px, 4.1666666667vw, 36px);
  }
}
.thoughts-section__content {
  text-align: left;
}

.thoughts-main-title-section {
  width: 100%;
  padding: 0;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
  text-align: left;
}
@media (max-width: 767px) {
  .thoughts-main-title-section {
    gap: clamp(12px, 4.1666666667vw, 36px);
  }
}
.thoughts-main-title-section .title-section__label {
  margin-bottom: 0;
}
.thoughts-main-title-section .title-section__title {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .thoughts-main-title-section .title-section__title .thoughts-title__text {
    line-height: 1.8;
  }
}
.thoughts-main-title-section .title-section__content {
  margin-bottom: 0;
}

.title-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  padding: calc(28.8px + (19.2) * (100vw - 768px) / (672));
  gap: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .title-section {
    gap: clamp(14.4px, 5vw, 43.2px);
  }
}
.title-section--default {
  --width: 448;
  --width-scale: 0.7;
  --padding: 48;
  --padding-scale: 0.6;
  --gap: 24;
  --gap-scale: 0.5;
}
@media (max-width: 767px) {
  .title-section--default {
    gap: clamp(14.4px, 5vw, 43.2px);
  }
}
.title-section--about {
  --width: 368;
  --width-scale: 0.7;
  --padding: 32;
  --padding-scale: 0.5;
  --gap: 24;
  --gap-scale: 0.5;
}
.title-section--small {
  --width: 300;
  --width-scale: 0.6;
  --padding: 16;
  --padding-scale: 0.4;
  --gap: 16;
  --gap-scale: 0.4;
}
.title-section--large {
  --width: 600;
  --width-scale: 0.8;
  --padding: 48;
  --padding-scale: 0.6;
  --gap: 32;
  --gap-scale: 0.6;
}
.title-section__title-text {
  color: #3f3f3f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(23.436px + (15.624) * (100vw - 768px) / (672));
  font-style: normal;
  font-weight: 500;
  line-height: 200%; /* 78.12px */
  letter-spacing: 3.906px;
  margin: 0;
  display: block;
  width: 100%;
}
@media (max-width: 767px) {
  .title-section__title-text {
    font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
    line-height: 1.8;
    letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  }
}
.title-section__title-line {
  position: relative;
  padding-bottom: calc(6px + (4) * (100vw - 768px) / (672));
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline-block;
}
@media (max-width: 767px) {
  .title-section__title-line {
    display: block;
    width: 100%;
    padding-bottom: clamp(6px, 2.0833333333vw, 18px);
  }
}
.title-section__title-underline {
  position: absolute;
  left: 0;
  bottom: 0;
  height: auto;
  display: block;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  pointer-events: none;
  width: 100%;
}
@media (max-width: 767px) {
  .title-section__title-underline {
    width: 100%;
    height: 5px;
  }
}

.breadcrumb {
  width: 100%;
  padding: calc(8px + (8) * (100vw - 768px) / (672)) 0;
  border-bottom: 1px solid #eee;
}
.breadcrumb__container {
  max-width: calc(1065.6px + (374.4) * (100vw - 768px) / (672));
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
.breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: calc(3.2px + (4.8) * (100vw - 768px) / (672));
}
.breadcrumb__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(3.2px + (4.8) * (100vw - 768px) / (672));
}
.breadcrumb__link {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(7px + (7) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #666;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.breadcrumb__link:hover {
  color: #333;
  text-decoration: underline;
}
.breadcrumb__current {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(7px + (7) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
}
.breadcrumb__separator {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(7px + (7) * (100vw - 768px) / (672));
  color: #999;
  margin: 0 calc(1.2px + (2.8) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .breadcrumb {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
  .breadcrumb__container {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
  .breadcrumb__list {
    gap: clamp(3.6px, 1.25vw, 10.8px);
  }
  .breadcrumb__item {
    gap: clamp(3.6px, 1.25vw, 10.8px);
  }
  .breadcrumb__link, .breadcrumb__current {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
  .breadcrumb__separator {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    margin: 0 clamp(2.4px, 0.8333333333vw, 7.2px);
  }
}

.about-link {
  width: 100%;
  padding: calc(42.66px + (42.66) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .about-link {
    padding: clamp(43.2px, 15vw, 129.6px) 0;
  }
}
.about-link__container {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .about-link__container {
    gap: clamp(24px, 8.3333333333vw, 72px);
  }
}
.about-link__title-area {
  text-align: center;
}
@media (max-width: 767px) {
  .about-link__title-area {
    text-align: left;
  }
}
.about-link__title {
  font-family: "Noto Serif JP", serif;
  font-size: calc(19.2px + (12.8) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 1.4;
  margin: 0;
}
.about-link__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .about-link__nav {
    gap: clamp(19.2px, 6.6666666667vw, 57.6px);
  }
}
.about-link__description {
  text-align: center;
}
@media (max-width: 767px) {
  .about-link__description {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
}
.about-link__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #3f3f3f;
  line-height: 2;
  margin: 0;
}
@media (max-width: 767px) {
  .about-link__text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    text-align: left;
  }
}

/**
 * Contact & Booking Section Component
 * お問い合わせ・ご予約セクション
 */
.contact-booking {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
  background: #ffffff;
  position: relative;
  z-index: 10;
}
@media (max-width: 767px) {
  .contact-booking {
    padding: clamp(36px, 12.5vw, 108px) 0;
  }
}
.contact-booking__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-booking__container {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
}
.contact-booking__header {
  text-align: center;
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-booking__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.contact-booking__label {
  margin-bottom: calc(32px + (32) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-booking__label {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.contact-booking__label-text {
  display: inline-block;
  background: #3f3f3f;
  color: #ffffff;
  font-size: calc(7px + (7) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  padding: calc(8px + (8) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
@media (max-width: 767px) {
  .contact-booking__label-text {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.contact-booking__title {
  font-size: calc(19.53px + (19.53) * (100vw - 768px) / (672));
  font-weight: 700;
  color: #333333;
  margin-bottom: calc(16px + (16) * (100vw - 768px) / (672));
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .contact-booking__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
    margin-bottom: clamp(14.4px, 5vw, 43.2px);
    letter-spacing: 0.05em;
  }
}
.contact-booking__description {
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: #3f3f3f;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.6;
  margin: 0;
}
@media (max-width: 767px) {
  .contact-booking__description {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    line-height: 1.5;
  }
}
.contact-booking__buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .contact-booking__buttons {
    gap: clamp(12px, 4.1666666667vw, 36px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
  }
}
.footer {
  width: 100%;
  padding-top: calc(64px + (64) * (100vw - 768px) / (672));
}
.footer__nav-section {
  background-color: #e9edf0;
  padding: calc(30px + (30) * (100vw - 768px) / (672)) 0;
}
.footer__copyright-section {
  background-color: #fff;
  padding: calc(22px + (22) * (100vw - 768px) / (672)) 0;
}
.footer__container {
  width: 100%;
  max-width: calc(1065.6px + (374.4) * (100vw - 768px) / (672));
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
.footer__logo {
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  text-align: center;
}
.footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(10px + (10) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
}
.footer__nav-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
.footer__nav-row--primary {
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
.footer__nav-row--secondary {
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
.footer__nav-link {
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  color: #333;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.footer__nav-link:hover {
  color: #666;
}
.footer__copyright {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(7px + (7) * (100vw - 768px) / (672));
  color: #a5c3cf;
  text-align: center;
  margin: 0;
  letter-spacing: calc(1px + (1) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .footer {
    padding-top: clamp(48px, 16.6666666667vw, 144px);
  }
  .footer__nav-section {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
  .footer__copyright-section {
    padding: clamp(18px, 6.25vw, 54px) 0;
  }
  .footer__container {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
    gap: clamp(18px, 6.25vw, 54px);
  }
  .footer__logo {
    font-size: clamp(12px, 4.1666666667vw, 36px);
  }
  .footer__nav {
    gap: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
  .footer__nav-row {
    gap: clamp(12px, 4.1666666667vw, 36px);
  }
  .footer__nav-row--primary {
    gap: clamp(12px, 4.1666666667vw, 36px);
  }
  .footer__nav-row--secondary {
    gap: clamp(12px, 4.1666666667vw, 36px);
  }
  .footer__nav-link {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
  .footer__copyright {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
  }
}

.scroll-animate-item {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  will-change: transform, opacity, filter;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.no-js .scroll-animate-item {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
  -webkit-filter: none;
  filter: none;
}

@media (prefers-reduced-motion: reduce) {
  .scroll-animate-item {
    -webkit-transition: none !important;
    transition: none !important;
    -webkit-animation: none !important;
    animation: none !important;
    -webkit-transform: none !important;
    transform: none !important;
    -webkit-filter: none !important;
    filter: none !important;
    opacity: 1 !important;
  }
}
/**
 * Modern Beautiful Page Transitions
 * 現代的で美しいページ遷移アニメーション
 * - グラデーションオーバーレイ
 * - 高品質ブラー効果
 * - 微妙なスケールアニメーション
 * - GPUアクセラレーション最適化
 */
.page-transition-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: none;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0;
  will-change: opacity;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.98) 50%, rgba(255, 255, 255, 0.95) 100%);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
}

.page-transition-content {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.page-transition-gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at center, rgba(165, 195, 207, 0.1) 0%, rgba(165, 195, 207, 0.05) 50%, transparent 100%);
  opacity: 0;
  -webkit-animation: gradientPulse 3s ease-in-out infinite;
  animation: gradientPulse 3s ease-in-out infinite;
}

.page-transition-blur-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

@-webkit-keyframes gradientPulse {
  0%, 100% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
}

@keyframes gradientPulse {
  0%, 100% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
}
body:not(.page-ready) .main-content {
  -webkit-filter: blur(12px) brightness(1.05);
  filter: blur(12px) brightness(1.05);
  opacity: 0;
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
  will-change: filter, opacity, transform;
}

body.page-ready .main-content {
  -webkit-transition: opacity 0.8s cubic-bezier(0, 0, 0.2, 1), -webkit-filter 1s cubic-bezier(0, 0, 0.2, 1), -webkit-transform 0.8s cubic-bezier(0, 0, 0.2, 1);
  transition: opacity 0.8s cubic-bezier(0, 0, 0.2, 1), -webkit-filter 1s cubic-bezier(0, 0, 0.2, 1), -webkit-transform 0.8s cubic-bezier(0, 0, 0.2, 1);
  transition: filter 1s cubic-bezier(0, 0, 0.2, 1), opacity 0.8s cubic-bezier(0, 0, 0.2, 1), transform 0.8s cubic-bezier(0, 0, 0.2, 1);
  transition: filter 1s cubic-bezier(0, 0, 0.2, 1), opacity 0.8s cubic-bezier(0, 0, 0.2, 1), transform 0.8s cubic-bezier(0, 0, 0.2, 1), -webkit-filter 1s cubic-bezier(0, 0, 0.2, 1), -webkit-transform 0.8s cubic-bezier(0, 0, 0.2, 1);
}

body.page-transitioning {
  overflow: hidden;
}
body.page-transitioning .main-content {
  pointer-events: none;
  will-change: filter, opacity, transform;
  -webkit-transform-origin: center center;
  transform-origin: center center;
}

.main-content {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-perspective: 1000px;
  perspective: 1000px;
}

@media (prefers-reduced-motion: no-preference) {
  .page-transition-overlay {
    -webkit-transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1);
    transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1);
  }
}
@media (prefers-reduced-motion: reduce) {
  .page-transition-overlay,
  .main-content {
    -webkit-transition: opacity 0.3s ease !important;
    transition: opacity 0.3s ease !important;
  }
  .page-transition-gradient {
    -webkit-animation: none !important;
    animation: none !important;
  }
}
.hero-section {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.hero-section__pc {
  display: block;
}
@media (max-width: 767px) {
  .hero-section__pc {
    display: none;
  }
}
.hero-section__sp {
  display: none;
}
@media (max-width: 767px) {
  .hero-section__sp {
    display: block;
  }
}
.hero-section__image-container {
  position: relative;
  width: 100%;
}
.hero-section__image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  display: block;
}
.hero-section__title-image {
  width: calc(171px + (114) * (100vw - 768px) / (672));
  position: absolute;
  top: calc(54px + (36) * (100vw - 768px) / (672));
  left: calc(90px + (60) * (100vw - 768px) / (672));
  z-index: 2;
}
.hero-section__title-svg {
  width: 100%;
  height: 100%;
  display: block;
}
.hero-section__content {
  position: absolute;
  bottom: calc(60px + (40) * (100vw - 768px) / (672));
  right: calc(57.6px + (38.4) * (100vw - 768px) / (672));
  text-align: center;
  color: #fff;
  z-index: 2;
  width: calc(225.7px + (79.3) * (100vw - 768px) / (672));
  padding: 0 calc(14.8px + (5.2) * (100vw - 768px) / (672));
}
.hero-section__title {
  font-family: "Noto Serif JP", serif;
  font-size: calc(35.52px + (12.48) * (100vw - 768px) / (672));
  font-weight: 700;
  margin-bottom: calc(17.76px + (6.24) * (100vw - 768px) / (672));
  line-height: 1.2;
}
.hero-section__subtitle {
  font-family: "Noto Serif JP", serif;
  font-size: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  font-weight: 400;
  margin-bottom: calc(35.52px + (12.48) * (100vw - 768px) / (672));
  line-height: 1.6;
}
.hero-section__mobile-grid {
  display: grid;
  grid-template-columns: clamp(111.6px, 38.75vw, 334.8px) clamp(142.2px, 49.375vw, 426.6px) 1fr;
  grid-template-rows: clamp(221.4px, 76.875vw, 664.2px) clamp(162.6px, 56.4583333333vw, 487.8px) 1fr;
  width: 100%;
  height: auto;
  overflow: hidden;
}
.hero-section__mobile-item--1 {
  grid-column: 1/-1;
  grid-row: 1/-1;
  overflow: hidden;
}
.hero-section__mobile-item--1 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.hero-section__mobile-item--2 {
  grid-column: 2/3;
  grid-row: 2/3;
  position: relative;
}
.hero-section__mobile-item--2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  display: block;
}
@media (max-width: 767px) {
  .hero-section__image-container {
    position: relative;
    height: 100vh;
  }
  .hero-section__image {
    -o-object-fit: cover;
    object-fit: cover;
    height: 100%;
  }
  .hero-section__title-image {
    width: clamp(120px, 41.6666666667vw, 360px);
    top: clamp(30px, 10.4166666667vw, 90px);
    left: clamp(18px, 6.25vw, 54px);
  }
}

.user-count-section {
  padding: calc(59.2px + (20.8) * (100vw - 768px) / (672)) 0;
  background-color: #ffffff;
  text-align: center;
}
.user-count-section__container {
  margin: 0 auto;
  padding: 0 20px;
}
.user-count-section__heading {
  font-size: calc(23.4px + (15.6) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333333;
  margin-bottom: 30px;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .user-count-section__heading {
    font-size: clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(12px, 4.1666666667vw, 36px);
  }
}
.user-count-section__number {
  font-size: calc(36.624px + (24.416) * (100vw - 768px) / (672));
  font-weight: 700;
  color: #e59d5c;
  display: inline-block;
  margin: 0 10px;
  font-family: "Noto Sans JP", sans-serif;
  position: relative;
}
@media (max-width: 767px) {
  .user-count-section__number {
    font-size: clamp(29.298px, 10.1729166667vw, 87.894px);
  }
}
.user-count-section__asterisk {
  font-size: calc(12px + (8) * (100vw - 768px) / (672));
  color: #e59d5c;
  font-weight: 400;
  position: absolute;
  top: 0;
  margin-left: 2px;
}
@media (max-width: 767px) {
  .user-count-section__asterisk {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.user-count-section__line {
  display: block;
  width: calc(436.8px + (291.2) * (100vw - 768px) / (672));
  height: auto;
  margin: 0 auto calc(24px + (16) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .user-count-section__line {
    width: clamp(240px, 83.3333333333vw, 720px);
    margin: 0 auto clamp(12px, 4.1666666667vw, 36px);
  }
}
.user-count-section__description p {
  font-size: calc(12px + (8) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.8;
  color: #666666;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .user-count-section__description p {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.user-count-section__description p:last-child {
  margin-bottom: 0;
}
.user-count-section__note {
  font-size: calc(8.4px + (5.6) * (100vw - 768px) / (672)) !important;
  color: #999999 !important;
  margin-top: 15px !important;
  margin-bottom: 0 !important;
}
@media (max-width: 767px) {
  .user-count-section__note {
    font-size: clamp(7.2px, 2.5vw, 21.6px) !important;
    margin-top: clamp(6px, 2.0833333333vw, 18px) !important;
  }
}

.media-slider-section {
  padding: 0 0 calc(59.2px + (20.8) * (100vw - 768px) / (672)) 0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .media-slider-section {
    padding: 0 0 clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.media-slider-section__container {
  margin: 0 auto;
}
.media-slider-section__heading {
  font-size: calc(23.4px + (15.6) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333333;
  text-align: center;
  margin-bottom: calc(37px + (13) * (100vw - 768px) / (672));
  line-height: 1.6;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .media-slider-section__heading {
    font-size: clamp(14.4px, 5vw, 43.2px);
  }
}
.media-slider-section__wrapper {
  position: relative;
  margin-bottom: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .media-slider-section__wrapper {
    margin-bottom: clamp(12px, 4.1666666667vw, 36px);
  }
}
.media-slider-section__track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: none;
  transition: none;
}
.media-slider-section__item {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-right: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: calc(285.64px + (100.36) * (100vw - 768px) / (672));
  background: #a5c3cf;
}
@media (max-width: 767px) {
  .media-slider-section__item {
    margin-right: clamp(12px, 4.1666666667vw, 36px);
    width: clamp(168px, 58.3333333333vw, 504px);
  }
}
.media-slider-section__item:nth-child(3n+2) {
  background: #c0d5dd;
}
.media-slider-section__item:nth-child(3n+3) {
  background: #cad5d9;
}
.media-slider-section__image-box {
  width: 100%;
  height: calc(103.6px + (36.4) * (100vw - 768px) / (672));
  background: transparent;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: calc(11.1px + (3.9) * (100vw - 768px) / (672));
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .media-slider-section__image-box {
    height: clamp(72px, 25vw, 216px);
    padding: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.media-slider-section__image-box img {
  width: 100%;
  height: auto;
  max-height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
.media-slider-section__text-box {
  width: 100%;
  background: transparent;
  padding: calc(11.1px + (3.9) * (100vw - 768px) / (672)) calc(11.84px + (4.16) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  min-height: calc(63.64px + (22.36) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .media-slider-section__text-box {
    padding: clamp(9px, 3.125vw, 27px) clamp(9.6px, 3.3333333333vw, 28.8px);
    min-height: clamp(42px, 14.5833333333vw, 126px);
  }
}
.media-slider-section__title {
  font-size: calc(10.8px + (7.2) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #ffffff;
  margin-bottom: calc(4.44px + (1.56) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 767px) {
  .media-slider-section__title {
    font-size: clamp(9px, 3.125vw, 27px);
  }
}
.media-slider-section__subtitle {
  font-size: calc(10.4px + (2.6) * (100vw - 768px) / (672));
  color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  opacity: 0.9;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 767px) {
  .media-slider-section__subtitle {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.media-slider-section__slider {
  overflow: hidden;
  width: 100%;
}

.thoughts-layout-section {
  width: 100%;
  margin-bottom: calc(80px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .thoughts-layout-section {
    display: none;
  }
}
.thoughts-layout-section__container {
  width: 100%;
  overflow: visible;
}
.thoughts-layout-section__wrapper {
  width: 100%;
  padding-right: calc(40px + (40) * (100vw - 768px) / (672));
  display: grid;
  grid-template-columns: repeat(18, 1fr);
  grid-template-rows: repeat(17, calc(25px + (25) * (100vw - 768px) / (672))) calc(12.5px + (12.5) * (100vw - 768px) / (672));
  gap: 0;
}
.thoughts-layout-section__box-1 {
  grid-column: 1/12;
  grid-row: 1/16;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 10;
}
.thoughts-layout-section__box-1 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  image-orientation: none;
  -webkit-transform: none;
  transform: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.thoughts-layout-section__box-2 {
  grid-column: 6/19;
  grid-row: 2/17;
  background: #fcf6de;
  color: #333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: bold;
  z-index: -10;
}
.thoughts-layout-section__box-3 {
  grid-column: 12/19;
  grid-row: 7/19;
  margin-top: calc(12.5px + (12.5) * (100vw - 768px) / (672));
  background: #fff;
  color: #333;
  font-weight: bold;
  z-index: 10;
}
.thoughts-layout-section__inner {
  width: calc(313.6px + (134.4) * (100vw - 768px) / (672));
  height: calc(252.5px + (252.5) * (100vw - 768px) / (672));
  padding-left: calc(16px + (16) * (100vw - 768px) / (672));
  padding-top: calc(16px + (16) * (100vw - 768px) / (672));
}

.about-section {
  width: 100%;
}
@media (max-width: 767px) {
  .about-section {
    display: none;
  }
}
.about-section__container {
  width: 100%;
  display: grid;
  grid-template-columns: calc(264px + (264) * (100vw - 768px) / (672)) calc(40px + (40) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(44px + (44) * (100vw - 768px) / (672)) calc(153px + (153) * (100vw - 768px) / (672)) calc(203px + (203) * (100vw - 768px) / (672)) calc(36px + (36) * (100vw - 768px) / (672));
  gap: 0;
}
.about-section__left {
  grid-column: 1;
  grid-row: 1/4;
  background: #fff;
  margin-top: calc(-24px + (-24) * (100vw - 768px) / (672));
  padding-left: calc(48px + (112) * (100vw - 768px) / (672));
}
.about-section__right {
  grid-column: 3/-1;
  grid-row: 3/-1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding-right: calc(40px + (40) * (100vw - 768px) / (672));
}
.about-section__bottom {
  grid-column: 1/-1;
  grid-row: 1/5;
  background: #f5e2cf;
  height: 100%;
  z-index: -1;
}

.about-title-section {
  width: 100%;
  padding: 0;
  gap: calc(6px + (6) * (100vw - 768px) / (672));
}
.about-cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: calc(16px + (16) * (100vw - 768px) / (672));
  width: 100%;
}

.about-card {
  width: 100%;
  height: calc(115px + (115) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #fff;
  overflow: hidden;
}
.about-card__image {
  height: 100%;
  overflow: hidden;
}
.about-card__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.about-card__content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: calc(6.4px + (9.6) * (100vw - 768px) / (672)) calc(6.4px + (9.6) * (100vw - 768px) / (672)) calc(6.4px + (9.6) * (100vw - 768px) / (672)) calc(16px + (24) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
.about-card__tag {
  margin-bottom: calc(4.8px + (7.2) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.05em;
  background: #a5c3cf;
  color: #fff;
  padding: calc(2.96px + (1.04) * (100vw - 768px) / (672)) calc(8.88px + (3.12) * (100vw - 768px) / (672));
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 600;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.about-card__text {
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  line-height: 1.6;
  color: #333;
}
.about-card--reverse .about-card__content {
  padding: calc(6.4px + (9.6) * (100vw - 768px) / (672)) calc(16px + (24) * (100vw - 768px) / (672)) calc(6.4px + (9.6) * (100vw - 768px) / (672)) calc(6.4px + (9.6) * (100vw - 768px) / (672));
}
.recommend-section {
  width: 100%;
  margin-right: calc(96px + (64) * (100vw - 768px) / (672));
  padding-top: calc(36px + (24) * (100vw - 768px) / (672));
  padding-bottom: calc(36px + (24) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .recommend-section {
    margin-right: 0;
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.recommend-section__container {
  margin: 0 auto;
  padding: calc(32.4px + (21.6) * (100vw - 768px) / (672)) calc(64px + (96) * (100vw - 768px) / (672));
  margin: calc(48px + (32) * (100vw - 768px) / (672)) calc(96px + (64) * (100vw - 768px) / (672));
  text-align: center;
  background: #f8f4e6;
}
@media (max-width: 767px) {
  .recommend-section__container {
    margin: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.recommend-section__header {
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .recommend-section__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.recommend-section__icon {
  margin-bottom: calc(8px + (12) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .recommend-section__icon {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.recommend-section__sun-icon {
  width: calc(57.36px + (38.24) * (100vw - 768px) / (672));
  height: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .recommend-section__sun-icon {
    width: clamp(43.2px, 15vw, 129.6px);
    height: clamp(27px, 9.375vw, 81px);
  }
}
.recommend-section__title {
  font-size: calc(19.2px + (12.8) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .recommend-section__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
  }
}
.recommend-section__tags {
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .recommend-section__tags {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.recommend-section__tag-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: calc(8px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(8px + (12) * (100vw - 768px) / (672));
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.recommend-section__tag-row:last-child {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .recommend-section__tag-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(7.2px, 2.5vw, 21.6px);
    margin-bottom: 0;
  }
}
.recommend-section__tag {
  min-width: calc(64px + (64) * (100vw - 768px) / (672));
  background: #fff;
  color: #3f3f3f;
  padding: calc(6px + (6) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  border-radius: calc(20px + (30) * (100vw - 768px) / (672));
  border: 1px solid #3f3f3f;
  font-size: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .recommend-section__tag {
    min-width: auto;
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(9.6px, 3.3333333333vw, 28.8px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    border-radius: clamp(14.4px, 5vw, 43.2px);
    text-align: center;
  }
}
.recommend-section__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .recommend-section__button {
    margin-top: clamp(12px, 4.1666666667vw, 36px);
  }
}

.studio-search-section {
  width: 100%;
  padding: calc(43.2px + (28.8) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .studio-search-section {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.studio-search-section__container {
  margin: 0 calc(89.6px + (134.4) * (100vw - 768px) / (672));
  padding-top: calc(43.2px + (28.8) * (100vw - 768px) / (672));
  padding-bottom: calc(43.2px + (28.8) * (100vw - 768px) / (672));
  background: #e9edf0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  z-index: 0;
}
@media (max-width: 767px) {
  .studio-search-section__container {
    margin: 0 clamp(12px, 4.1666666667vw, 36px);
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.studio-search-section__header {
  text-align: center;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-search-section__header {
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.studio-search-section__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: calc(32px + (32) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-search-section__label {
    margin-bottom: clamp(19.2px, 6.6666666667vw, 57.6px);
  }
}
.studio-search-section__title {
  font-size: calc(16.8px + (11.2) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(24px + (24) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  letter-spacing: calc(0.74px + (0.26) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-search-section__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
    margin-bottom: clamp(14.4px, 5vw, 43.2px);
    letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
  }
}
.studio-search-section__subtitle {
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  color: #3f3f3f;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .studio-search-section__subtitle {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.studio-search-section__search {
  width: calc(403.2px + (172.8) * (100vw - 768px) / (672));
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .studio-search-section__search {
    width: 100%;
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
    padding: 0 clamp(6px, 2.0833333333vw, 18px);
  }
}
.studio-search-section__search-box {
  position: relative;
  width: 100%;
  padding: calc(8px + (8) * (100vw - 768px) / (672)) calc(16px + (16) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background: #fff;
  border: 2px solid #e5e7eb;
  border-radius: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  -webkit-transition: border-color 0.15s ease;
  transition: border-color 0.15s ease;
}
.studio-search-section__search-box:focus-within {
  border-color: #3f3f3f;
  -webkit-box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
@media (max-width: 767px) {
  .studio-search-section__search-box {
    padding: clamp(8.4px, 2.9166666667vw, 25.2px) clamp(12px, 4.1666666667vw, 36px);
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.studio-search-section__search-icon {
  width: calc(8px + (12) * (100vw - 768px) / (672));
  height: calc(8px + (12) * (100vw - 768px) / (672));
  fill: #666;
  margin-left: calc(4.8px + (7.2) * (100vw - 768px) / (672));
  margin-right: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .studio-search-section__search-icon {
    width: clamp(10.8px, 3.75vw, 32.4px);
    height: clamp(10.8px, 3.75vw, 32.4px);
    margin-left: clamp(4.8px, 1.6666666667vw, 14.4px);
    margin-right: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.studio-search-section__search-input {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  border: none !important;
  outline: none !important;
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  background: transparent;
  padding: calc(4.8px + (7.2) * (100vw - 768px) / (672)) calc(4.8px + (7.2) * (100vw - 768px) / (672));
  color: #374151;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.studio-search-section__search-input::-webkit-input-placeholder {
  color: #9ca3af;
}
.studio-search-section__search-input::-moz-placeholder {
  color: #9ca3af;
}
.studio-search-section__search-input:-ms-input-placeholder {
  color: #9ca3af;
}
.studio-search-section__search-input::-ms-input-placeholder {
  color: #9ca3af;
}
.studio-search-section__search-input::placeholder {
  color: #9ca3af;
}
.studio-search-section__search-input:focus, .studio-search-section__search-input:active, .studio-search-section__search-input:focus-visible {
  outline: none !important;
  border: none !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}
@media (max-width: 767px) {
  .studio-search-section__search-input {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.studio-search-section__cards {
  width: calc(100% + 64px + (64) * (100vw - 768px) / (672));
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(9.6px + (14.4) * (100vw - 768px) / (672));
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-search-section__cards {
    width: 100%;
    grid-template-columns: 1fr;
    gap: clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.studio-search-section__pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(3.6px + (8.4) * (100vw - 768px) / (672));
  padding: calc(12.8px + (19.2) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .studio-search-section__pagination {
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
    padding: clamp(14.4px, 5vw, 43.2px) clamp(6px, 2.0833333333vw, 18px);
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

.studio-card {
  display: grid;
  grid-template-rows: auto 1fr;
  background: #fff;
  min-height: calc(280.8px + (187.2) * (100vw - 768px) / (672));
  border-radius: calc(5px + (5) * (100vw - 768px) / (672));
  padding: calc(8px + (8) * (100vw - 768px) / (672));
  text-align: center;
  overflow: visible;
  position: relative;
  z-index: 1;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}
@media (max-width: 767px) {
  .studio-card {
    min-height: clamp(192px, 66.6666666667vw, 576px);
    border-radius: clamp(6px, 2.0833333333vw, 18px);
    padding: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.studio-card__image {
  position: relative;
  width: 100%;
  height: calc(96px + (64) * (100vw - 768px) / (672));
  background: #e0e0e0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .studio-card__image {
    height: clamp(96px, 33.3333333333vw, 288px);
  }
}
.studio-card__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  image-orientation: none;
  -webkit-transform: none;
  transform: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.studio-card__location {
  position: absolute;
  bottom: 0;
  right: 0;
  background: #fff;
  color: #a99f3c;
  padding: calc(1.2px + (2.8) * (100vw - 768px) / (672)) calc(3.6px + (8.4) * (100vw - 768px) / (672));
  border-radius: calc(1.2px + (2.8) * (100vw - 768px) / (672)) 0 0 0;
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .studio-card__location {
    padding: clamp(2.4px, 0.8333333333vw, 7.2px) clamp(6px, 2.0833333333vw, 18px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px) 0 0 0;
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.studio-card__content {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: calc(4.8px + (7.2) * (100vw - 768px) / (672));
  padding: calc(6.4px + (9.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-card__content {
    gap: clamp(18px, 6.25vw, 54px);
    padding: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.studio-card__name {
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: calc(0.74px + (0.26) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-card__name {
    font-size: clamp(10.8px, 3.75vw, 32.4px);
    letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
  }
}
.studio-card__address {
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  text-align: left;
  color: #666;
  line-height: 1.5;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .studio-card__address {
    font-size: clamp(9px, 3.125vw, 27px);
  }
}
.studio-card__details {
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-card__details {
    font-size: clamp(9px, 3.125vw, 27px);
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.studio-card__hours {
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-card__hours {
    font-size: clamp(9px, 3.125vw, 27px);
  }
}
.studio-card__hour-item {
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  color: #666;
  line-height: 1.4;
  font-family: "Noto Sans JP", sans-serif;
  text-align: left;
}
@media (max-width: 767px) {
  .studio-card__hour-item {
    font-size: clamp(9px, 3.125vw, 27px);
  }
}
.studio-card__contact-btn {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  overflow: visible;
  padding: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .studio-card__contact-btn {
    padding: clamp(12px, 4.1666666667vw, 36px) clamp(4.8px, 1.6666666667vw, 14.4px) clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.studio-card__contact-btn .camera-button {
  width: 100%;
}

.pagination-btn {
  background: transparent;
  border: 1px solid #e5e7eb;
  padding: calc(3px + (7) * (100vw - 768px) / (672)) calc(4.2px + (9.8) * (100vw - 768px) / (672));
  border-radius: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  cursor: pointer;
  -webkit-transition: all 0.15s ease;
  transition: all 0.15s ease;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  color: #6b7280;
  font-weight: 500;
  min-width: calc(16px + (24) * (100vw - 768px) / (672));
  min-height: calc(16px + (24) * (100vw - 768px) / (672));
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-decoration: none;
}
@media (max-width: 767px) {
  .pagination-btn {
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(7.2px, 2.5vw, 21.6px);
    border-radius: clamp(3.6px, 1.25vw, 10.8px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    min-width: clamp(24px, 8.3333333333vw, 72px);
    min-height: clamp(24px, 8.3333333333vw, 72px);
  }
}
.pagination-btn:hover:not(.disabled) {
  background: #f9fafb;
  border-color: #d1d5db;
  color: #374151;
}
.pagination-btn.disabled {
  background: transparent;
  border-color: #f3f4f6;
  color: #d1d5db;
  cursor: not-allowed;
}
.pagination-btn.disabled svg {
  opacity: 0.5;
}
.pagination-btn--prev, .pagination-btn--next {
  padding: calc(3px + (7) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .pagination-btn--prev, .pagination-btn--next {
    padding: clamp(6px, 2.0833333333vw, 18px);
  }
}
.pagination-btn--prev svg, .pagination-btn--next svg {
  width: calc(4.8px + (11.2) * (100vw - 768px) / (672));
  height: calc(4.8px + (11.2) * (100vw - 768px) / (672));
  fill: currentColor;
}
@media (max-width: 767px) {
  .pagination-btn--prev svg, .pagination-btn--next svg {
    width: clamp(9.6px, 3.3333333333vw, 28.8px);
    height: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}

.pagination-numbers {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(1.2px + (4.8) * (100vw - 768px) / (672));
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .pagination-numbers {
    gap: clamp(2.4px, 0.8333333333vw, 7.2px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.pagination-numbers a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: calc(16px + (24) * (100vw - 768px) / (672));
  height: calc(16px + (24) * (100vw - 768px) / (672));
  border-radius: 50%;
  cursor: pointer;
  -webkit-transition: all 0.15s ease;
  transition: all 0.15s ease;
  text-decoration: none;
  font-weight: 500;
  color: #6b7280;
  background: transparent;
  border: 1px solid transparent;
}
@media (max-width: 767px) {
  .pagination-numbers a {
    width: clamp(24px, 8.3333333333vw, 72px);
    height: clamp(24px, 8.3333333333vw, 72px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.pagination-numbers a:hover {
  background: #f9fafb;
  color: #374151;
}
.pagination-numbers a.active {
  background: #3f3f3f;
  color: #fff;
  font-weight: 600;
}

.thoughts-layout-mobile {
  width: 100%;
  padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px) 0;
  overflow: hidden;
  display: none;
}
@media (max-width: 767px) {
  .thoughts-layout-mobile {
    display: block;
  }
}
.thoughts-layout-mobile__container {
  width: 100%;
  max-width: 100%;
}
.thoughts-layout-mobile__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(18px, 6.25vw, 54px);
  width: 100%;
  padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px) 0;
  position: relative;
}
.thoughts-layout-mobile__content::after {
  content: "";
  position: absolute;
  width: calc(100% + clamp(12px, 4.1666666667vw, 36px));
  height: calc(100% - clamp(24px, 8.3333333333vw, 72px));
  top: clamp(24px, 8.3333333333vw, 72px);
  left: clamp(-6px, -2.0833333333vw, -18px);
  z-index: 0;
}
.thoughts-layout-mobile__content > * {
  position: relative;
  z-index: 1;
}
.thoughts-layout-mobile__title {
  width: 100%;
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
  padding: clamp(12px, 4.1666666667vw, 36px);
}
.thoughts-layout-mobile__image {
  width: 100%;
  -webkit-box-ordinal-group: 3;
  -ms-flex-order: 2;
  order: 2;
  margin-bottom: clamp(6px, 2.0833333333vw, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-shadow: 20px 20px 0 0 #fcf6de;
  box-shadow: 20px 20px 0 0 #fcf6de;
}
.thoughts-layout-mobile__image img {
  width: 90%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  max-width: 100%;
  display: block;
  image-orientation: none;
  -webkit-transform: none;
  transform: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-perspective: 1000;
  perspective: 1000;
}
.thoughts-layout-mobile__button {
  width: 100%;
  -webkit-box-ordinal-group: 4;
  -ms-flex-order: 3;
  order: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(6px, 2.0833333333vw, 18px);
}

.thoughts-layout-mobile-title-section {
  width: 100%;
  padding: 0;
  gap: clamp(7.2px, 2.5vw, 21.6px);
  text-align: left;
}
.thoughts-layout-mobile-title-section .title-section__label {
  font-family: "Oswald", sans-serif;
  font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  font-weight: 400;
  color: #333;
  text-transform: uppercase;
  letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  margin-bottom: clamp(4.8px, 1.6666666667vw, 14.4px);
}
.thoughts-layout-mobile-title-section .title-section__title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
  font-weight: 400;
  color: #333;
  line-height: 1.4;
  margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
}
.thoughts-layout-mobile-title-section .title-section__content {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  font-weight: 400;
  color: #666;
  line-height: 1.6;
}

.about-mobile {
  width: 100%;
  padding: clamp(24px, 8.3333333333vw, 72px) 0;
  overflow: hidden;
  display: none;
}
@media (max-width: 767px) {
  .about-mobile {
    display: block;
  }
}
.about-mobile__container {
  width: 100%;
  max-width: 100%;
}
.about-mobile__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(18px, 6.25vw, 54px);
  width: 100%;
  padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
  position: relative;
}
.about-mobile__content::after {
  content: "";
  position: absolute;
  width: calc(100% + clamp(12px, 4.1666666667vw, 36px));
  height: calc(100% - clamp(126px, 43.75vw, 378px));
  top: clamp(126px, 43.75vw, 378px);
  left: clamp(-6px, -2.0833333333vw, -18px);
  z-index: 0;
  background: #f5e2cf;
}
.about-mobile__content > * {
  position: relative;
  z-index: 1;
}
.about-mobile__title {
  width: 100%;
  padding: clamp(12px, 4.1666666667vw, 36px) 0;
  background: #fff;
}
.about-mobile__cards {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(14.4px, 5vw, 43.2px);
}

.about-mobile-title-section {
  width: 100%;
  padding: 0;
  gap: clamp(12px, 4.1666666667vw, 36px);
  text-align: left;
}
.about-mobile-title-section .title-section__label {
  font-family: "Oswald", sans-serif;
  font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  font-weight: 400;
  color: #333;
  text-transform: uppercase;
  letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  margin-bottom: clamp(4.8px, 1.6666666667vw, 14.4px);
}
.about-mobile-title-section .title-section__title-text {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
  font-weight: 400;
  color: #333;
  line-height: 1.8;
  letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
}
.about-mobile-title-section .title-section__content .thoughts-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  font-weight: 400;
  color: #666;
  line-height: 1.6;
  letter-spacing: clamp(0.6px, 0.2083333333vw, 1.8px);
}

.about-mobile-card {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  background: #fff;
  overflow: hidden;
}
.about-mobile-card__image {
  width: 100%;
  height: clamp(120px, 41.6666666667vw, 360px);
  overflow: hidden;
}
.about-mobile-card__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  image-orientation: none;
  -webkit-transform: none;
  transform: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.about-mobile-card__content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: clamp(9.6px, 3.3333333333vw, 28.8px) clamp(9.6px, 3.3333333333vw, 28.8px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4.8px, 1.6666666667vw, 14.4px);
}
.about-mobile-card__tag {
  margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.05em;
  background: #a5c3cf;
  color: #fff;
  padding: clamp(2.4px, 0.8333333333vw, 7.2px) clamp(7.2px, 2.5vw, 21.6px);
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  font-weight: 600;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.about-mobile-card__text {
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  line-height: 1.6;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
}
.gallery-section {
  width: 100%;
}
@media (max-width: 767px) {
  .gallery-section {
    display: none;
  }
}
.gallery-section__container {
  width: 100%;
  display: grid;
  grid-template-columns: calc(80px + (80) * (100vw - 768px) / (672)) calc(320px + (320) * (100vw - 768px) / (672)) calc(113px + (113) * (100vw - 768px) / (672)) calc(100px + (100) * (100vw - 768px) / (672)) calc(42px + (42) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(44px + (44) * (100vw - 768px) / (672)) calc(93px + (93) * (100vw - 768px) / (672)) calc(142px + (142) * (100vw - 768px) / (672)) calc(44px + (44) * (100vw - 768px) / (672));
  gap: 0;
}
.gallery-section .gallery-box--1 {
  grid-column: 1/3;
  grid-row: 3/-1;
  background: #bcb5b5;
}
.gallery-section .gallery-box--1 .gallery-box__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.gallery-section .gallery-box--2 {
  grid-column: 2/6;
  grid-row: 2/5;
  background: #fcf6de;
  z-index: -1;
}
.gallery-section .gallery-box--3 {
  grid-column: 3/-1;
  grid-row: 1/4;
  background: #fff;
  z-index: -1;
}
.gallery-section .gallery-box--4 {
  grid-column: 3/6;
  grid-row: 4;
  z-index: 1;
  position: relative;
  padding-top: calc(80px + (80) * (100vw - 768px) / (672));
  padding-left: calc(45.2px + (180.8) * (100vw - 768px) / (672));
}

.gallery-mobile {
  width: 100%;
  padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  margin-bottom: clamp(48px, 16.6666666667vw, 144px);
  overflow: hidden;
  display: none;
}
@media (max-width: 767px) {
  .gallery-mobile {
    display: block;
  }
}
.gallery-mobile__container {
  width: 100%;
  max-width: 100%;
}
.gallery-mobile__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(18px, 6.25vw, 54px);
  width: 100%;
  padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
  position: relative;
}
.gallery-mobile__content::after {
  content: "";
  position: absolute;
  background: #fcf6de;
  width: 100%;
  height: calc(100% - clamp(24px, 8.3333333333vw, 72px));
  top: clamp(24px, 8.3333333333vw, 72px);
  right: clamp(-2.4px, -0.8333333333vw, -7.2px);
  z-index: 0;
}
.gallery-mobile__content > * {
  position: relative;
  z-index: 1;
}
.gallery-mobile__image {
  width: 100%;
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
  margin-bottom: clamp(6px, 2.0833333333vw, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
.gallery-mobile__image img {
  width: 90%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}
.gallery-mobile__title {
  width: 100%;
  -webkit-box-ordinal-group: 3;
  -ms-flex-order: 2;
  order: 2;
  padding: clamp(12px, 4.1666666667vw, 36px) 0;
}
.gallery-mobile__button {
  width: 100%;
  -webkit-box-ordinal-group: 4;
  -ms-flex-order: 3;
  order: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(6px, 2.0833333333vw, 18px);
}

.gallery-mobile-title-section {
  width: 100%;
  padding: 0;
  gap: clamp(7.2px, 2.5vw, 21.6px);
  text-align: left;
}
.gallery-mobile-title-section .title-section__label {
  font-family: "Oswald", sans-serif;
  font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  font-weight: 400;
  color: #333;
  text-transform: uppercase;
  letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  margin-bottom: clamp(4.8px, 1.6666666667vw, 14.4px);
}
.gallery-mobile-title-section .title-section__title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
  font-weight: 400;
  color: #333;
  line-height: 1.4;
  margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
}
.gallery-mobile-title-section .title-section__content {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  font-weight: 400;
  color: #666;
  line-height: 1.6;
}

.plan-section {
  width: 100%;
  margin-top: calc(60px + (60) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .plan-section {
    display: none;
  }
}
.plan-section__container {
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: calc(40px + (40) * (100vw - 768px) / (672)) calc(280px + (280) * (100vw - 768px) / (672)) calc(360px + (360) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(33px + (33) * (100vw - 768px) / (672)) calc(117px + (117) * (100vw - 768px) / (672)) calc(130px + (130) * (100vw - 768px) / (672)) calc(44.5px + (44.5) * (100vw - 768px) / (672));
  gap: 0;
  position: relative;
}
.plan-section .plan-box--1 {
  grid-column: 1/3;
  grid-row: 1/4;
  position: relative;
  z-index: 2;
  background-color: #fff;
  padding-left: calc(65px + (65) * (100vw - 768px) / (672));
}
.plan-section .plan-box--2 {
  grid-column: 2/4;
  grid-row: 2/5;
  background: #f5e9e0;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding-bottom: calc(38px + (38) * (100vw - 768px) / (672));
  padding-left: calc(40px + (40) * (100vw - 768px) / (672));
}
.plan-section .plan-box--3 {
  grid-column: 3;
  grid-row: 3/6;
  position: relative;
  z-index: 2;
  overflow: hidden;
}
.plan-section .plan-box--3 .plan-box__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}

.plan-label {
  display: inline-block;
  background: #3f3f3f;
  color: #fff;
  padding: calc(5.92px + (2.08) * (100vw - 768px) / (672)) calc(17.76px + (6.24) * (100vw - 768px) / (672));
  font-family: "Oswald", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 400;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: calc(1.48px + (0.52) * (100vw - 768px) / (672));
}

/* test change */
/* final test - #午後 */
/* final cleanup test - #午後 */
.plan-mobile {
  width: 100%;
  padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  margin-bottom: clamp(12px, 4.1666666667vw, 36px);
  overflow: hidden;
  display: none;
}
@media (max-width: 767px) {
  .plan-mobile {
    display: block;
  }
}
.plan-mobile__container {
  width: 100%;
  max-width: 100%;
}
.plan-mobile__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(18px, 6.25vw, 54px);
  width: 100%;
  padding: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
  position: relative;
}
.plan-mobile__content::after {
  content: "";
  position: absolute;
  background: #f5e9e0;
  width: calc(100% + clamp(12px, 4.1666666667vw, 36px));
  height: calc(100% - clamp(24px, 8.3333333333vw, 72px));
  top: clamp(24px, 8.3333333333vw, 72px);
  left: clamp(-6px, -2.0833333333vw, -18px);
  z-index: 0;
}
.plan-mobile__content > * {
  position: relative;
  z-index: 1;
}
.plan-mobile__image {
  width: 100%;
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
  margin-bottom: clamp(6px, 2.0833333333vw, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
.plan-mobile__image img {
  width: 90%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}
.plan-mobile__title {
  width: 100%;
  -webkit-box-ordinal-group: 3;
  -ms-flex-order: 2;
  order: 2;
  padding: clamp(12px, 4.1666666667vw, 36px) 0;
}
.plan-mobile__button {
  width: 100%;
  -webkit-box-ordinal-group: 4;
  -ms-flex-order: 3;
  order: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(6px, 2.0833333333vw, 18px);
}

.plan-mobile-title-section {
  width: 100%;
  padding: 0;
  gap: clamp(7.2px, 2.5vw, 21.6px);
  text-align: left;
}
.plan-mobile-title-section .title-section__label {
  font-family: "Oswald", sans-serif;
  font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  font-weight: 400;
  color: #333;
  text-transform: uppercase;
  letter-spacing: clamp(1.2px, 0.4166666667vw, 3.6px);
  margin-bottom: clamp(4.8px, 1.6666666667vw, 14.4px);
}
.plan-mobile-title-section .title-section__title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16.8px, 5.8333333333vw, 50.4px);
  font-weight: 400;
  color: #333;
  line-height: 1.4;
  margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
}
.plan-mobile-title-section .title-section__content {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  font-weight: 400;
  color: #666;
  line-height: 1.6;
}

.intro-section {
  padding: 48px 0;
}
.intro-section__content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.about-page {
  width: 100%;
}
.about-page .breadcrumb {
  border-bottom: 1px solid #eee;
}

.about-fv {
  width: 100%;
  background: white;
}
.about-fv__container {
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr calc(428px + (428) * (100vw - 768px) / (672));
  grid-template-rows: 1fr;
  gap: 0;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.about-fv__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding-left: calc(40px + (40) * (100vw - 768px) / (672));
  padding-right: calc(20px + (20) * (100vw - 768px) / (672));
}
.about-fv__text {
  max-width: calc(336px + (144) * (100vw - 768px) / (672));
}
.about-fv__title-section .title-section__title .thoughts-title {
  font-family: "Noto Serif JP", serif;
  font-size: calc(28.8px + (19.2) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 1.3;
  margin-bottom: calc(12px + (12) * (100vw - 768px) / (672));
}
.about-fv__title-section .title-section__title .thoughts-title .about-fv__subtitle {
  display: block;
  margin-top: calc(3.2px + (4.8) * (100vw - 768px) / (672));
}
.about-fv__title-section .title-section__content .thoughts-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #666;
  line-height: 1.7;
  margin: 0;
}
.about-fv__image {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.about-fv__image-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}

.about-mobile-fv {
  display: none;
  width: 100%;
  background: white;
}
@media (max-width: 767px) {
  .about-mobile-fv {
    display: block;
  }
}
.about-mobile-fv__container {
  width: 100%;
  padding: 0 clamp(12px, 4.1666666667vw, 36px);
}
@media (max-width: 767px) {
  .about-mobile-fv__container {
    padding: 0;
  }
}
.about-mobile-fv__grid {
  display: grid;
  grid-template-columns: clamp(12px, 4.1666666667vw, 36px) clamp(171.6px, 59.5833333333vw, 514.8px) clamp(109.2px, 37.9166666667vw, 327.6px);
  grid-template-rows: clamp(241.2px, 83.75vw, 723.6px) clamp(145.2px, 50.4166666667vw, 435.6px) clamp(25.8px, 8.9583333333vw, 77.4px);
  gap: 0;
  width: 100%;
  height: auto;
  overflow: hidden;
}
.about-mobile-fv__item1 {
  grid-column: 1/-1;
  grid-row: 1/-1;
}
.about-mobile-fv__item1 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.about-mobile-fv__item2 {
  grid-column: 2;
  grid-row: 2;
}
.about-mobile-fv__item2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  display: block;
}

@media (max-width: 767px) {
  .about-fv {
    display: none;
  }
}
.single-store .store-hero {
  padding: calc(30px + (30) * (100vw - 768px) / (672)) 0;
  background: white;
}
@media (max-width: 767px) {
  .single-store .store-hero {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.single-store .store-hero__container {
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-hero__container {
    gap: clamp(14.4px, 5vw, 43.2px);
    padding: 0 clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.single-store .store-hero__info {
  text-align: center;
}
.single-store .store-hero__category {
  display: inline-block;
  background: #3f3f3f;
  color: white;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 400;
  padding: calc(4px + (4) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(12px + (12) * (100vw - 768px) / (672));
  letter-spacing: 0.12em;
}
@media (max-width: 767px) {
  .single-store .store-hero__category {
    font-size: clamp(10.8px, 3.75vw, 32.4px);
    padding: clamp(3.6px, 1.25vw, 10.8px) clamp(9.6px, 3.3333333333vw, 28.8px);
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
    letter-spacing: 0.08em;
  }
}
.single-store .store-hero__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(9.6px + (6.4) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 1.4;
  margin: 0;
  text-align: center;
}
@media (max-width: 767px) {
  .single-store .store-hero__title {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    line-height: 1.6;
  }
}
.single-store .store-hero__image {
  width: calc(672px + (288) * (100vw - 768px) / (672));
  overflow: hidden;
}
@media (max-width: 767px) {
  .single-store .store-hero__image {
    width: 100%;
    max-width: clamp(240px, 83.3333333333vw, 720px);
  }
}
.single-store .store-hero__image-img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 767px) {
  .single-store .store-hero__image-img {
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.single-store .store-basic-info {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .single-store .store-basic-info {
    padding: clamp(36px, 12.5vw, 108px) 0;
  }
}
.single-store .store-basic-info__container {
  width: 100%;
  max-width: calc(710.4px + (249.6) * (100vw - 768px) / (672));
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-basic-info__container {
    padding: 0 clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.single-store .store-basic-info__heading {
  font-family: "Noto Serif JP", serif;
  font-size: calc(19.2px + (12.8) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media (max-width: 767px) {
  .single-store .store-basic-info__heading {
    font-size: clamp(14.4px, 5vw, 43.2px);
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.single-store .store-basic-info__underline {
  width: 100%;
  height: 4px;
  margin-top: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-basic-info__underline {
    margin-top: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.single-store .store-basic-info__list {
  margin: 0;
  width: 100%;
}
.single-store .store-basic-info__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: calc(8px + (12) * (100vw - 768px) / (672)) 0;
  border-bottom: 1px solid #eee;
}
.single-store .store-basic-info__item:last-child {
  border-bottom: none;
}
@media (max-width: 767px) {
  .single-store .store-basic-info__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
    padding: clamp(9.6px, 3.3333333333vw, 28.8px) 0;
  }
}
.single-store .store-basic-info__label {
  font-family: "Noto Serif JP", serif;
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #666;
  width: calc(60px + (60) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin: 0;
}
@media (max-width: 767px) {
  .single-store .store-basic-info__label {
    width: auto;
    font-weight: 600;
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    color: #3f3f3f;
  }
}
.single-store .store-basic-info__data {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin: 0;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .single-store .store-basic-info__data {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.8;
  }
}
.single-store .store-basic-info__phone {
  color: #333;
  text-decoration: none;
}
.single-store .store-basic-info__phone:hover {
  color: #3f3f3f;
  text-decoration: underline;
}
@media (max-width: 767px) {
  .single-store .store-basic-info__phone {
    color: #3f3f3f;
    font-weight: 500;
  }
}
.single-store .store-info {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.single-store .store-info__container {
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
.single-store .store-info__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: calc(40px + (40) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-info__grid {
    grid-template-columns: 1fr;
    gap: clamp(36px, 12.5vw, 108px);
  }
}
.single-store .store-info__heading {
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(16px + (16) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  border-bottom: 2px solid #a99f3c;
  padding-bottom: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
.single-store .store-info__list {
  margin: 0;
}
.single-store .store-info__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #eee;
  padding: calc(6.4px + (9.6) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .single-store .store-info__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.single-store .store-info__label {
  font-weight: 600;
  color: #3f3f3f;
  width: calc(60px + (60) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
}
.single-store .store-info__data {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  line-height: 1.6;
  color: #333;
  margin: 0;
}
.single-store .store-info__phone {
  color: #3f3f3f;
  text-decoration: none;
  font-weight: 600;
}
.single-store .store-info__phone:hover {
  text-decoration: underline;
}
.single-store .store-info__features-content .store-features-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.single-store .store-info__features-content .store-features-list__item {
  position: relative;
  padding-left: calc(8px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(4.8px + (7.2) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  line-height: 1.6;
  color: #333;
}
.single-store .store-info__features-content .store-features-list__item::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #a99f3c;
  font-weight: bold;
}
.single-store .store-gallery {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.single-store .store-gallery__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
.single-store .store-gallery__heading {
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  text-align: center;
  border-bottom: 2px solid #a99f3c;
  padding-bottom: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  display: inline-block;
  width: 100%;
}
.single-store .store-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(calc(140px + (140) * (100vw - 768px) / (672)), 1fr));
  gap: calc(15px + (15) * (100vw - 768px) / (672));
}
.single-store .store-gallery__item {
  background: white;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.single-store .store-gallery__item:hover {
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
}
.single-store .store-gallery__image {
  width: 100%;
  height: calc(100px + (100) * (100vw - 768px) / (672));
  -o-object-fit: cover;
  object-fit: cover;
}
.single-store .store-gallery__caption {
  padding: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  color: #666;
  text-align: center;
  margin: 0;
}
.single-store .store-access {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .single-store .store-access {
    padding: clamp(36px, 12.5vw, 108px) 0;
  }
}
.single-store .store-access__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-access__container {
    padding: 0 clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.single-store .store-access__heading {
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  text-align: center;
  border-bottom: 2px solid #a99f3c;
  padding-bottom: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  display: inline-block;
  width: 100%;
}
@media (max-width: 767px) {
  .single-store .store-access__heading {
    font-size: clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.single-store .store-access__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-access__content {
    grid-template-columns: 1fr;
    gap: clamp(24px, 8.3333333333vw, 72px);
  }
}
.single-store .store-access__map-placeholder {
  background: #f0f0f0;
  padding: calc(30px + (30) * (100vw - 768px) / (672));
  text-align: center;
  color: #666;
  font-family: "Noto Sans JP", sans-serif;
  min-height: calc(150px + (150) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media (max-width: 767px) {
  .single-store .store-access__map-placeholder {
    padding: clamp(24px, 8.3333333333vw, 72px);
    min-height: clamp(150px, 52.0833333333vw, 450px);
  }
}
.single-store .store-access__map iframe {
  width: 100%;
  height: calc(320px + (80) * (100vw - 768px) / (672));
  border: none;
  border-radius: calc(2.4px + (5.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-access__map iframe {
    height: clamp(180px, 62.5vw, 540px);
    border-radius: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.single-store .store-access__info-title {
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(10px + (10) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
}
@media (max-width: 767px) {
  .single-store .store-access__info-title {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.single-store .store-access__info-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.single-store .store-access__info-item {
  position: relative;
  padding-left: calc(8px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  line-height: 1.6;
  color: #333;
}
@media (max-width: 767px) {
  .single-store .store-access__info-item {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    line-height: 1.8;
    margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
    padding-left: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.single-store .store-access__info-item::before {
  content: "●";
  position: absolute;
  left: 0;
  top: 0;
  color: #a99f3c;
  font-size: calc(4.8px + (7.2) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-access__info-item::before {
    font-size: clamp(6px, 2.0833333333vw, 18px);
  }
}
.single-store .store-access__station {
  margin-top: calc(15px + (15) * (100vw - 768px) / (672));
  text-align: left;
}
@media (max-width: 767px) {
  .single-store .store-access__station {
    margin-top: clamp(14.4px, 5vw, 43.2px);
    text-align: center;
  }
}
.single-store .store-access__station-text {
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  color: #333;
  margin: 0;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .single-store .store-access__station-text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    font-weight: 600;
    color: #3f3f3f;
  }
}
.single-store .store-staff {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
  background: #f9f9f9;
}
.single-store .store-staff__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
}
.single-store .store-staff__heading {
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  text-align: center;
  border-bottom: 2px solid #a99f3c;
  padding-bottom: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  display: inline-block;
  width: 100%;
}
.single-store .store-staff__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(calc(150px + (150) * (100vw - 768px) / (672)), 1fr));
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
.single-store .store-staff__member {
  background: white;
  border-radius: calc(6px + (6) * (100vw - 768px) / (672));
  padding: calc(15px + (15) * (100vw - 768px) / (672));
  text-align: center;
  -webkit-box-shadow: 0 2px 15px rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.1);
}
.single-store .store-staff__photo {
  width: calc(60px + (60) * (100vw - 768px) / (672));
  height: calc(60px + (60) * (100vw - 768px) / (672));
  margin: 0 auto calc(8px + (12) * (100vw - 768px) / (672));
  border-radius: 50%;
  overflow: hidden;
}
.single-store .store-staff__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.single-store .store-staff__name {
  font-size: calc(10px + (10) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(2.4px + (5.6) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
}
.single-store .store-staff__role {
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  color: #a99f3c;
  margin-bottom: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
}
.single-store .store-staff__experience {
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  line-height: 1.6;
  color: #666;
  font-family: "Noto Sans JP", sans-serif;
  margin: 0;
}
.single-store .store-cta {
  padding: calc(30px + (30) * (100vw - 768px) / (672)) 0;
  background: white;
}
.single-store .store-cta__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(10px + (10) * (100vw - 768px) / (672));
  text-align: center;
}
.single-store .store-cta__heading {
  font-size: calc(16.8px + (11.2) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  margin-bottom: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
}
.single-store .store-cta__text {
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  color: #666;
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.6;
}
.single-store .store-cta__buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(15px + (15) * (100vw - 768px) / (672));
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .single-store .store-cta__buttons {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(12px, 4.1666666667vw, 36px);
  }
}
.single-store .store-gallery {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .single-store .store-gallery {
    padding: clamp(36px, 12.5vw, 108px) 0;
  }
}
.single-store .store-gallery__slider {
  width: 100%;
  overflow: hidden;
  cursor: -webkit-grab;
  cursor: grab;
  padding-top: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-gallery__slider {
    padding-top: clamp(12px, 4.1666666667vw, 36px);
    -ms-touch-action: pan-x;
    touch-action: pan-x;
  }
}
.single-store .store-gallery__slider:active {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
.single-store .store-gallery__track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(10px + (10) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-gallery__track {
    gap: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.single-store .store-gallery__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  width: calc(240px + (60) * (100vw - 768px) / (672));
  height: calc(320px + (80) * (100vw - 768px) / (672));
  position: relative;
  cursor: pointer;
  overflow: hidden;
}
@media (max-width: 767px) {
  .single-store .store-gallery__item {
    width: clamp(144px, 50vw, 432px);
    height: clamp(192px, 66.6666666667vw, 576px);
  }
}
@media (max-width: 479px) {
  .single-store .store-gallery__item {
    width: clamp(120px, 41.6666666667vw, 360px);
    height: clamp(168px, 58.3333333333vw, 504px);
  }
}
.single-store .store-gallery__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.single-store .store-gallery__item:hover img, .single-store .store-gallery__item:active img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}
.single-store .store-gallery__item:hover .store-gallery__overlay, .single-store .store-gallery__item:active .store-gallery__overlay {
  opacity: 1;
}
@media (max-width: 767px) {
  .single-store .store-gallery__item:active img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .single-store .store-gallery__item:active .store-gallery__overlay {
    opacity: 1;
  }
}
.single-store .store-gallery__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
@media (max-width: 767px) {
  .single-store .store-gallery__overlay {
    background-color: rgba(0, 0, 0, 0.3);
  }
}
.single-store .store-gallery__icon {
  width: calc(48px + (12) * (100vw - 768px) / (672));
  height: calc(48px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .single-store .store-gallery__icon {
    width: clamp(24px, 8.3333333333vw, 72px);
    height: clamp(24px, 8.3333333333vw, 72px);
  }
}

.lightbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: none;
}
.lightbox--active {
  display: block;
  -webkit-animation: fadeIn 0.3s ease;
  animation: fadeIn 0.3s ease;
}
.lightbox__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
}
.lightbox__content {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: calc(30px + (30) * (100vw - 768px) / (672));
}
.lightbox__image {
  max-width: 90%;
  max-height: 90%;
  width: auto;
  height: auto;
  -o-object-fit: contain;
  object-fit: contain;
  -webkit-animation: zoomIn 0.3s ease;
  animation: zoomIn 0.3s ease;
}
@media (min-width: 768px) {
  .lightbox__image {
    min-width: 600px;
    min-height: 400px;
  }
}
@media (min-width: 1200px) {
  .lightbox__image {
    min-width: 800px;
    min-height: 600px;
  }
}
.lightbox__close {
  position: absolute;
  top: calc(10px + (10) * (100vw - 768px) / (672));
  right: calc(10px + (10) * (100vw - 768px) / (672));
  width: calc(40px + (10) * (100vw - 768px) / (672));
  height: calc(40px + (10) * (100vw - 768px) / (672));
  background-color: rgba(0, 0, 0, 0.5);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.lightbox__close:hover {
  background-color: rgba(0, 0, 0, 0.8);
}
.lightbox__close svg {
  width: calc(19.2px + (4.8) * (100vw - 768px) / (672));
  height: calc(19.2px + (4.8) * (100vw - 768px) / (672));
}

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

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes zoomIn {
  from {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    opacity: 0;
  }
  to {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
}
@keyframes zoomIn {
  from {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    opacity: 0;
  }
  to {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
}
.contact-section {
  background-color: #e9edf0;
  width: 100%;
  padding: 0 calc(60px + (60) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
}
.contact-section .contact-header-container {
  background-color: #fff;
  padding: calc(11.84px + (4.16) * (100vw - 768px) / (672)) 0;
  text-align: center;
  margin-bottom: calc(11.84px + (4.16) * (100vw - 768px) / (672));
}
.contact-section .contact-header-container .contact-header {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: calc(11.84px + (4.16) * (100vw - 768px) / (672));
}
.contact-section .contact-header-container .contact-header__title {
  color: #fff;
  text-decoration: none;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.12em;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 500;
  background-color: #3f3f3f;
  padding: calc(7.4px + (2.6) * (100vw - 768px) / (672)) calc(14.8px + (5.2) * (100vw - 768px) / (672));
  width: calc(118.4px + (41.6) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.contact-section .contact__main-title {
  width: 100%;
  text-align: center;
  margin-top: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  margin-bottom: calc(74px + (26) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  font-size: calc(28.86px + (10.14) * (100vw - 768px) / (672));
  color: #3f3f3f;
  font-weight: 400;
  letter-spacing: 0.12em;
}
.contact-section .contact-main-text {
  padding: calc(11.84px + (4.16) * (100vw - 768px) / (672)) 0;
  color: #333;
  margin-bottom: calc(17.76px + (6.24) * (100vw - 768px) / (672));
}
.contact-section .contact-main-text p {
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
}
.contact-section .contact-content {
  padding: calc(32.56px + (11.44) * (100vw - 768px) / (672)) calc(74px + (26) * (100vw - 768px) / (672));
  background-color: #fff;
  border: 1px solid #547e8f;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .contact-section .contact-content {
    padding: clamp(26.4px, 9.1666666667vw, 79.2px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.contact-section .contact-content .h1 {
  text-align: center;
}
.contact-section .contact-content .user-count-section__line {
  width: 100%;
  height: calc(2.96px + (1.04) * (100vw - 768px) / (672));
  margin-bottom: calc(17.76px + (6.24) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: calc(17.76px + (6.24) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-title {
  font-family: "Noto Serif JP", serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 300;
  margin-top: calc(74px + (26) * (100vw - 768px) / (672));
  margin-bottom: calc(19.24px + (6.76) * (100vw - 768px) / (672));
  color: #547e8f;
  text-align: center;
}
.contact-section .contact-content .contact-search {
  margin-bottom: calc(17.76px + (6.24) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-search__label {
  display: block;
  color: #547e8f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  margin-bottom: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  font-weight: 500;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-search__label {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    margin-bottom: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.contact-section .contact-content .contact-search .contact-select {
  width: 100%;
  height: calc(37px + (13) * (100vw - 768px) / (672));
  padding: calc(8.88px + (3.12) * (100vw - 768px) / (672)) calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-family: "Noto Serif JP", serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: white;
  background-color: #7996a1;
  border: none;
  border-radius: calc(2.96px + (1.04) * (100vw - 768px) / (672));
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right calc(7.4px + (2.6) * (100vw - 768px) / (672)) center;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-search .contact-select {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    height: clamp(27px, 9.375vw, 81px);
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.contact-section .contact-content .contact-search .contact-select option {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: white;
  background-color: #547e8f;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-search .contact-select option {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.contact-section .contact-content .contact-details {
  margin-top: calc(59.2px + (20.8) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: calc(29.6px + (10.4) * (100vw - 768px) / (672));
  border: 1px solid #547e8f;
  border-radius: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  padding: calc(18.5px + (6.5) * (100vw - 768px) / (672));
  width: 100%;
}
.contact-section .contact-content .contact-details[style*="display: none"] {
  display: none !important;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(14.4px, 5vw, 43.2px);
    padding: clamp(12px, 4.1666666667vw, 36px);
  }
}
.contact-section .contact-content .contact-details .contact-image {
  width: 50%;
  max-width: calc(296px + (104) * (100vw - 768px) / (672));
  height: calc(241.98px + (85.02) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-image {
    width: 100%;
    height: clamp(150px, 52.0833333333vw, 450px);
    max-width: none;
  }
}
.contact-section .contact-content .contact-details .contact-image img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
  object-fit: cover;
}
.contact-section .contact-content .contact-details .contact-info {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  min-width: 0;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-info {
    width: 100%;
  }
}
.contact-section .contact-content .contact-details .contact-info table {
  width: 100%;
  height: calc(241.98px + (85.02) * (100vw - 768px) / (672));
  border-collapse: separate;
  border-spacing: 0;
  border: 0.5px solid #547e8f;
  border-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
  overflow: hidden;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-info table {
    height: auto;
    border-radius: clamp(1.8px, 0.625vw, 5.4px);
    width: 100%;
  }
}
.contact-section .contact-content .contact-details .contact-info table td {
  padding: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  border: 0.5px solid #547e8f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  color: #547e8f;
  text-align: center;
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-info table td {
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(4.8px, 1.6666666667vw, 14.4px);
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    text-align: left;
  }
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-info table td:first-child {
    background-color: #f8f9fa;
    font-weight: 600;
    white-space: nowrap;
    min-width: clamp(48px, 16.6666666667vw, 144px);
    width: 30%;
  }
}
@media (max-width: 767px) {
  .contact-section .contact-content .contact-details .contact-info table td:last-child {
    width: 70%;
    word-break: break-word;
  }
}
.contact-section .contact-content .contact-details .contact-info table tr:first-child td:first-child {
  border-top-left-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-details .contact-info table tr:first-child td:last-child {
  border-top-right-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-details .contact-info table tr:last-child td:first-child {
  border-bottom-left-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
}
.contact-section .contact-content .contact-details .contact-info table tr:last-child td:last-child {
  border-bottom-right-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
}
.contact-section .schedule-container {
  margin-top: calc(59.2px + (20.8) * (100vw - 768px) / (672));
  width: 100%;
  padding: 0;
  font-family: "Noto Serif JP", serif;
}
.contact-section .schedule-container h1 {
  margin-top: calc(29.6px + (10.4) * (100vw - 768px) / (672));
  text-align: center;
  color: #3f3f3f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(28.86px + (10.14) * (100vw - 768px) / (672));
  margin-bottom: calc(32.56px + (11.44) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .text-block {
  margin-top: calc(65.12px + (22.88) * (100vw - 768px) / (672));
  margin-bottom: calc(59.2px + (20.8) * (100vw - 768px) / (672));
  text-align: center;
  font-family: "Noto Serif JP", serif;
  color: #547e8f;
}
.contact-section .schedule-container .big-text {
  font-size: calc(18.5px + (6.5) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .small-text {
  padding-top: calc(29.6px + (10.4) * (100vw - 768px) / (672));
  font-size: calc(11.1px + (3.9) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: calc(14.8px + (5.2) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options .option-card {
  background-color: #fcf6de;
  padding: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  border-radius: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  width: 60%;
  -webkit-box-shadow: 0 calc(1.48px + (0.52) * (100vw - 768px) / (672)) calc(3.7px + (1.3) * (100vw - 768px) / (672)) rgba(0, 0, 0, 0.1);
  box-shadow: 0 calc(1.48px + (0.52) * (100vw - 768px) / (672)) calc(3.7px + (1.3) * (100vw - 768px) / (672)) rgba(0, 0, 0, 0.1);
}
.contact-section .schedule-container .schedule-options .option-card h2 {
  margin-top: calc(29.6px + (10.4) * (100vw - 768px) / (672));
  color: #547e8f;
  margin-bottom: calc(44.4px + (15.6) * (100vw - 768px) / (672));
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: calc(18.5px + (6.5) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options .option-card ul {
  list-style-type: none;
  padding: 0;
  color: #547e8f;
  margin-bottom: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options .option-card ul li {
  margin-bottom: calc(7.4px + (2.6) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options .option-card ul li:nth-child(1)::after, .contact-section .schedule-container .schedule-options .option-card ul li:nth-child(2)::after, .contact-section .schedule-container .schedule-options .option-card ul li:nth-child(3)::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #547e8f;
  margin-top: calc(22.2px + (7.8) * (100vw - 768px) / (672));
  margin-bottom: calc(22.2px + (7.8) * (100vw - 768px) / (672));
}
.contact-section .schedule-container .schedule-options .option-card button {
  background-color: #547e8f;
  color: white;
  border: none;
  padding: calc(7.4px + (2.6) * (100vw - 768px) / (672)) calc(14.8px + (5.2) * (100vw - 768px) / (672));
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  cursor: pointer;
  width: 100%;
  text-align: center;
}
.contact-section .schedule-container .schedule-options .option-card button:hover {
  background-color: rgb(65.127753304, 97.6916299559, 110.872246696);
}
.contact-section .form-container {
  width: 100%;
  margin-top: 0;
  font-family: "Noto Serif JP", serif;
}
.contact-section .form-container h1 {
  margin-bottom: calc(44.4px + (15.6) * (100vw - 768px) / (672));
  text-align: center;
  color: #547e8f;
  font-family: "Noto Serif JP", serif;
  font-size: calc(18.5px + (6.5) * (100vw - 768px) / (672));
}
.contact-section .input-field,
.contact-section .dropdown-field,
.contact-section .textarea-field,
.contact-section .confirmation-field {
  margin-bottom: calc(25.9px + (9.1) * (100vw - 768px) / (672));
}
.contact-section .input-field label,
.contact-section .dropdown-field label,
.contact-section .textarea-field label,
.contact-section .confirmation-field label {
  display: block;
  color: #547e8f;
  margin-bottom: calc(11.1px + (3.9) * (100vw - 768px) / (672));
}
.contact-section .input-field input,
.contact-section .input-field select,
.contact-section .input-field textarea,
.contact-section .dropdown-field input,
.contact-section .dropdown-field select,
.contact-section .dropdown-field textarea,
.contact-section .textarea-field input,
.contact-section .textarea-field select,
.contact-section .textarea-field textarea,
.contact-section .confirmation-field input,
.contact-section .confirmation-field select,
.contact-section .confirmation-field textarea {
  width: 100%;
  height: calc(44.4px + (15.6) * (100vw - 768px) / (672));
  padding: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  border: 1px solid #547e8f;
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-section .input-field input::-webkit-input-placeholder, .contact-section .input-field select::-webkit-input-placeholder, .contact-section .input-field textarea::-webkit-input-placeholder, .contact-section .dropdown-field input::-webkit-input-placeholder, .contact-section .dropdown-field select::-webkit-input-placeholder, .contact-section .dropdown-field textarea::-webkit-input-placeholder, .contact-section .textarea-field input::-webkit-input-placeholder, .contact-section .textarea-field select::-webkit-input-placeholder, .contact-section .textarea-field textarea::-webkit-input-placeholder, .contact-section .confirmation-field input::-webkit-input-placeholder, .contact-section .confirmation-field select::-webkit-input-placeholder, .contact-section .confirmation-field textarea::-webkit-input-placeholder {
  color: #9cbecd;
  font-size: 14px;
  font-family: "Noto Sans JP", medium;
}
.contact-section .input-field input::-moz-placeholder, .contact-section .input-field select::-moz-placeholder, .contact-section .input-field textarea::-moz-placeholder, .contact-section .dropdown-field input::-moz-placeholder, .contact-section .dropdown-field select::-moz-placeholder, .contact-section .dropdown-field textarea::-moz-placeholder, .contact-section .textarea-field input::-moz-placeholder, .contact-section .textarea-field select::-moz-placeholder, .contact-section .textarea-field textarea::-moz-placeholder, .contact-section .confirmation-field input::-moz-placeholder, .contact-section .confirmation-field select::-moz-placeholder, .contact-section .confirmation-field textarea::-moz-placeholder {
  color: #9cbecd;
  font-size: 14px;
  font-family: "Noto Sans JP", medium;
}
.contact-section .input-field input:-ms-input-placeholder, .contact-section .input-field select:-ms-input-placeholder, .contact-section .input-field textarea:-ms-input-placeholder, .contact-section .dropdown-field input:-ms-input-placeholder, .contact-section .dropdown-field select:-ms-input-placeholder, .contact-section .dropdown-field textarea:-ms-input-placeholder, .contact-section .textarea-field input:-ms-input-placeholder, .contact-section .textarea-field select:-ms-input-placeholder, .contact-section .textarea-field textarea:-ms-input-placeholder, .contact-section .confirmation-field input:-ms-input-placeholder, .contact-section .confirmation-field select:-ms-input-placeholder, .contact-section .confirmation-field textarea:-ms-input-placeholder {
  color: #9cbecd;
  font-size: 14px;
  font-family: "Noto Sans JP", medium;
}
.contact-section .input-field input::-ms-input-placeholder, .contact-section .input-field select::-ms-input-placeholder, .contact-section .input-field textarea::-ms-input-placeholder, .contact-section .dropdown-field input::-ms-input-placeholder, .contact-section .dropdown-field select::-ms-input-placeholder, .contact-section .dropdown-field textarea::-ms-input-placeholder, .contact-section .textarea-field input::-ms-input-placeholder, .contact-section .textarea-field select::-ms-input-placeholder, .contact-section .textarea-field textarea::-ms-input-placeholder, .contact-section .confirmation-field input::-ms-input-placeholder, .contact-section .confirmation-field select::-ms-input-placeholder, .contact-section .confirmation-field textarea::-ms-input-placeholder {
  color: #9cbecd;
  font-size: 14px;
  font-family: "Noto Sans JP", medium;
}
.contact-section .input-field input::placeholder,
.contact-section .input-field select::placeholder,
.contact-section .input-field textarea::placeholder,
.contact-section .dropdown-field input::placeholder,
.contact-section .dropdown-field select::placeholder,
.contact-section .dropdown-field textarea::placeholder,
.contact-section .textarea-field input::placeholder,
.contact-section .textarea-field select::placeholder,
.contact-section .textarea-field textarea::placeholder,
.contact-section .confirmation-field input::placeholder,
.contact-section .confirmation-field select::placeholder,
.contact-section .confirmation-field textarea::placeholder {
  color: #9cbecd;
  font-size: 14px;
  font-family: "Noto Sans JP", medium;
}
.contact-section .input-field textarea,
.contact-section .dropdown-field textarea,
.contact-section .textarea-field textarea,
.contact-section .confirmation-field textarea {
  height: calc(111px + (39) * (100vw - 768px) / (672));
  resize: vertical;
}
@media (max-width: 767px) {
  .contact-section .input-field textarea,
  .contact-section .dropdown-field textarea,
  .contact-section .textarea-field textarea,
  .contact-section .confirmation-field textarea {
    height: clamp(108px, 37.5vw, 324px);
    min-height: clamp(60px, 20.8333333333vw, 180px);
  }
}
.contact-section .input-field select,
.contact-section .dropdown-field select,
.contact-section .textarea-field select,
.contact-section .confirmation-field select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23547E8F' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right calc(7.4px + (2.6) * (100vw - 768px) / (672)) center;
  cursor: pointer;
}
.contact-section .input-field select::-ms-expand,
.contact-section .dropdown-field select::-ms-expand,
.contact-section .textarea-field select::-ms-expand,
.contact-section .confirmation-field select::-ms-expand {
  display: none;
  /* Hide default arrow in IE */
}
.contact-section .privacy-policy-section {
  margin-bottom: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .privacy-policy-section {
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.contact-section .privacy-policy-text {
  margin-bottom: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  padding: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  background-color: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .privacy-policy-text {
    margin-bottom: clamp(9px, 3.125vw, 27px);
    padding: clamp(9px, 3.125vw, 27px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px);
  }
}
.contact-section .privacy-policy-text h3 {
  font-family: "Noto Serif JP", serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: #547e8f;
  margin-bottom: calc(11.1px + (3.9) * (100vw - 768px) / (672));
  font-weight: 600;
}
@media (max-width: 767px) {
  .contact-section .privacy-policy-text h3 {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.contact-section .privacy-policy-text p {
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  color: #547e8f;
  line-height: 1.6;
  margin-bottom: calc(8.88px + (3.12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .privacy-policy-text p {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    margin-bottom: clamp(6px, 2.0833333333vw, 18px);
  }
}
.contact-section .privacy-policy-text p:last-child {
  margin-bottom: 0;
}
.contact-section .confirmation-field-check {
  width: 100%;
  padding: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  border: 1px solid #547e8f;
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  text-align: center;
  margin-bottom: calc(44.4px + (15.6) * (100vw - 768px) / (672));
}
.contact-section .confirmation-field-check label {
  color: #547e8f;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  cursor: pointer;
}
@media (max-width: 767px) {
  .contact-section .confirmation-field-check label {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.contact-section .confirmation-field-check label input[type=checkbox] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  height: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  border: 1px solid #547e8f;
  border-radius: calc(2.22px + (0.78) * (100vw - 768px) / (672));
  margin-right: calc(5.92px + (2.08) * (100vw - 768px) / (672));
  position: relative;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.contact-section .confirmation-field-check label input[type=checkbox]:checked {
  background-color: #547e8f;
  border-color: #547e8f;
}
.contact-section .confirmation-field-check label input[type=checkbox]:checked::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: calc(4.44px + (1.56) * (100vw - 768px) / (672));
  height: calc(7.4px + (2.6) * (100vw - 768px) / (672));
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: translate(-50%, -60%) rotate(45deg);
  transform: translate(-50%, -60%) rotate(45deg);
}
.contact-section .confirmation-field-check label input[type=checkbox]:hover {
  border-color: rgb(65.127753304, 97.6916299559, 110.872246696);
}
.contact-section .confirm-button {
  background-color: transparent;
  color: #547e8f;
  border: 1px solid #547e8f;
  padding: calc(11.1px + (3.9) * (100vw - 768px) / (672)) calc(29.6px + (10.4) * (100vw - 768px) / (672));
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  cursor: pointer;
  font-family: "Noto Serif JP", serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 400;
  max-width: calc(222px + (78) * (100vw - 768px) / (672));
  width: 100%;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  margin: 0 auto;
  display: block;
}
@media (max-width: 767px) {
  .contact-section .confirm-button {
    max-width: none;
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(18px, 6.25vw, 54px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.contact-section .confirm-button:hover {
  background-color: #547e8f;
  color: white;
}
.contact-section .confirm-button:active {
  background-color: rgb(65.127753304, 97.6916299559, 110.872246696);
  border-color: rgb(65.127753304, 97.6916299559, 110.872246696);
}
@media (max-width: 767px) {
  .contact-section .confirm-button:active {
    background-color: #547e8f;
    color: white;
  }
}
.contact-section .form-step,
.contact-section .confirmation-step {
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
}
.contact-section .confirmation-step__title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: calc(18.5px + (6.5) * (100vw - 768px) / (672));
  color: #547e8f;
  margin-bottom: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__title {
    font-size: clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.contact-section .confirmation-step__content {
  margin-bottom: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__content {
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.contact-section .confirmation-step__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin-bottom: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  padding: calc(11.1px + (3.9) * (100vw - 768px) / (672));
  border: 1px solid #547e8f;
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: clamp(9px, 3.125vw, 27px);
    padding: clamp(7.2px, 2.5vw, 21.6px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px);
  }
}
.contact-section .confirmation-step__item--textarea {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}
.contact-section .confirmation-step__item--textarea .confirmation-step__label {
  margin-bottom: calc(7.4px + (2.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__item--textarea .confirmation-step__label {
    margin-bottom: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.contact-section .confirmation-step__label {
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  color: #547e8f;
  font-weight: 500;
  min-width: calc(88.8px + (31.2) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-right: calc(14.8px + (5.2) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__label {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
    min-width: auto;
    margin-right: 0;
    margin-bottom: clamp(3px, 1.0416666667vw, 9px);
    font-weight: 600;
  }
}
.contact-section .confirmation-step__value {
  font-family: "Noto Serif JP", serif;
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  color: #547e8f;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  word-wrap: break-word;
  white-space: pre-wrap;
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__value {
    font-size: clamp(7.8px, 2.7083333333vw, 23.4px);
  }
}
.contact-section .confirmation-step__buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(14.8px + (5.2) * (100vw - 768px) / (672));
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: calc(29.6px + (10.4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .confirmation-step__buttons {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(9px, 3.125vw, 27px);
    margin-top: clamp(18px, 6.25vw, 54px);
  }
}
.contact-section .back-button,
.contact-section .submit-button {
  padding: calc(11.1px + (3.9) * (100vw - 768px) / (672)) calc(29.6px + (10.4) * (100vw - 768px) / (672));
  border-radius: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  cursor: pointer;
  font-family: "Noto Serif JP", serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 400;
  max-width: calc(148px + (52) * (100vw - 768px) / (672));
  width: 100%;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 2px solid #547e8f;
}
@media (max-width: 767px) {
  .contact-section .back-button,
  .contact-section .submit-button {
    max-width: none;
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(18px, 6.25vw, 54px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    border-width: 1px;
  }
}
.contact-section .back-button {
  background-color: transparent;
  color: #547e8f;
}
.contact-section .back-button:hover {
  background-color: #547e8f;
  color: white;
}
@media (max-width: 767px) {
  .contact-section .back-button:active {
    background-color: #547e8f;
    color: white;
  }
}
.contact-section .submit-button {
  background-color: #547e8f;
  color: white;
}
.contact-section .submit-button:hover {
  background-color: rgb(65.127753304, 97.6916299559, 110.872246696);
  border-color: rgb(65.127753304, 97.6916299559, 110.872246696);
}
@media (max-width: 767px) {
  .contact-section .submit-button:active {
    background-color: rgb(55.6916299559, 83.5374449339, 94.8083700441);
    border-color: rgb(55.6916299559, 83.5374449339, 94.8083700441);
  }
}
.contact-section .error-message {
  color: #e74c3c;
  font-family: "Noto Serif JP", serif;
  font-size: calc(8.88px + (3.12) * (100vw - 768px) / (672));
  margin-top: calc(3.7px + (1.3) * (100vw - 768px) / (672));
  margin-left: calc(3.7px + (1.3) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .contact-section .error-message {
    font-size: clamp(6.6px, 2.2916666667vw, 19.8px);
    margin-top: clamp(2.4px, 0.8333333333vw, 7.2px);
    margin-left: clamp(2.4px, 0.8333333333vw, 7.2px);
  }
}
.contact-section .input-field.error input,
.contact-section .input-field.error textarea,
.contact-section .input-field.error select,
.contact-section .textarea-field.error input,
.contact-section .textarea-field.error textarea,
.contact-section .textarea-field.error select,
.contact-section .contact-search.error input,
.contact-section .contact-search.error textarea,
.contact-section .contact-search.error select,
.contact-section .confirmation-field-check.error input,
.contact-section .confirmation-field-check.error textarea,
.contact-section .confirmation-field-check.error select {
  border-color: #e74c3c;
  background-color: rgba(231, 76, 60, 0.05);
}
.contact-section .input-field.error input:focus,
.contact-section .input-field.error textarea:focus,
.contact-section .input-field.error select:focus,
.contact-section .textarea-field.error input:focus,
.contact-section .textarea-field.error textarea:focus,
.contact-section .textarea-field.error select:focus,
.contact-section .contact-search.error input:focus,
.contact-section .contact-search.error textarea:focus,
.contact-section .contact-search.error select:focus,
.contact-section .confirmation-field-check.error input:focus,
.contact-section .confirmation-field-check.error textarea:focus,
.contact-section .confirmation-field-check.error select:focus {
  border-color: #e74c3c;
  -webkit-box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.2);
  box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.2);
}
.contact-section .confirm-button:disabled {
  background-color: #bdc3c7;
  color: #7f8c8d;
  border-color: #bdc3c7;
  cursor: not-allowed;
  opacity: 0.6;
}
.contact-section .confirm-button:disabled:hover {
  background-color: #bdc3c7;
  color: #7f8c8d;
  border-color: #bdc3c7;
}

.confirmation-field-level label {
  display: block;
  color: #547e8f;
  margin-top: calc(11.1px + (3.9) * (100vw - 768px) / (672));
}

.gallery-header {
  width: 100%;
  padding: calc(40px + (40) * (100vw - 768px) / (672)) calc(40px + (40) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .gallery-header {
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.gallery-header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
}
@media (max-width: 767px) {
  .gallery-header__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.gallery-header__title {
  font-size: calc(12.8px + (3.2) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  letter-spacing: 0.12em;
  background-color: #333;
  color: #fff;
  padding: calc(7.2px + (4.8) * (100vw - 768px) / (672)) calc(24px + (16) * (100vw - 768px) / (672));
  margin: 0;
  display: inline-block;
  -ms-flex-negative: 1;
  flex-shrink: 1;
  max-width: 60%;
}
@media (max-width: 767px) {
  .gallery-header__title {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    padding: clamp(7.2px, 2.5vw, 21.6px) clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(12px, 4.1666666667vw, 36px);
    max-width: none;
  }
}
.gallery-header__filters {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(8px + (8) * (100vw - 768px) / (672));
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  .gallery-header__filters {
    position: static;
    -webkit-transform: none;
    transform: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: clamp(7.2px, 2.5vw, 21.6px);
    width: 100%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

.gallery-select-wrapper {
  position: relative;
}
.gallery-select-wrapper::after {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(10px + (10) * (100vw - 768px) / (672));
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12" fill="none"><path d="M3 4.5L6 7.5L9 4.5" stroke="%23fff" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
}
@media (max-width: 767px) {
  .gallery-select-wrapper::after {
    right: clamp(15px, 5.2083333333vw, 45px);
    width: clamp(7.2px, 2.5vw, 21.6px);
    height: clamp(7.2px, 2.5vw, 21.6px);
  }
}

.gallery-select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #a5c3cf;
  color: #fff;
  border: none;
  border-radius: calc(15px + (15) * (100vw - 768px) / (672));
  padding: calc(7px + (7) * (100vw - 768px) / (672)) calc(25px + (25) * (100vw - 768px) / (672)) calc(7px + (7) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-weight: 500;
  min-width: calc(100px + (100) * (100vw - 768px) / (672));
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (max-width: 767px) {
  .gallery-select {
    width: clamp(156px, 54.1666666667vw, 468px);
    min-width: unset;
    max-width: unset;
    padding: clamp(8.4px, 2.9166666667vw, 25.2px) clamp(30px, 10.4166666667vw, 90px) clamp(8.4px, 2.9166666667vw, 25.2px) clamp(12px, 4.1666666667vw, 36px);
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    border-radius: clamp(15px, 5.2083333333vw, 45px);
    text-align: left;
  }
}
.gallery-select:hover {
  background-color: rgb(213.0806451613, 231.3064516129, 240.4193548387);
}
.gallery-select:focus {
  outline: none;
}
.gallery-select option {
  padding: calc(6px + (6) * (100vw - 768px) / (672)) calc(10px + (10) * (100vw - 768px) / (672));
  background-color: #a5c3cf;
  color: #fff;
  font-size: calc(11.2px + (2.8) * (100vw - 768px) / (672));
  font-weight: 400;
  border: none;
}
@media (max-width: 767px) {
  .gallery-select option {
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(9.6px, 3.3333333333vw, 28.8px);
    font-size: clamp(7.8px, 2.7083333333vw, 23.4px);
  }
}
.gallery-select option:hover, .gallery-select option:focus {
  background-color: rgb(131.7391304348, 172.8260869565, 189.2608695652);
}
.gallery-select option:checked {
  background-color: rgb(115.1086956522, 161.7391304348, 180.3913043478);
  font-weight: 600;
}

.gallery-grid {
  padding: 0 calc(40px + (40) * (100vw - 768px) / (672));
}
.gallery-grid__inner {
  -webkit-column-count: 4;
  -moz-column-count: 4;
  column-count: 4;
  -webkit-column-gap: calc(12px + (12) * (100vw - 768px) / (672));
  -moz-column-gap: calc(12px + (12) * (100vw - 768px) / (672));
  column-gap: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 1023px) {
  .gallery-grid__inner {
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
  }
}
@media (max-width: 767px) {
  .gallery-grid__inner {
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
    -webkit-column-gap: calc(8px + (8) * (100vw - 768px) / (672));
    -moz-column-gap: calc(8px + (8) * (100vw - 768px) / (672));
    column-gap: calc(8px + (8) * (100vw - 768px) / (672));
  }
}
@media (max-width: 479px) {
  .gallery-grid__inner {
    -webkit-column-count: 1;
    -moz-column-count: 1;
    column-count: 1;
    -webkit-column-gap: calc(6px + (6) * (100vw - 768px) / (672));
    -moz-column-gap: calc(6px + (6) * (100vw - 768px) / (672));
    column-gap: calc(6px + (6) * (100vw - 768px) / (672));
  }
}
.gallery-grid__item {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  z-index: 1;
  display: inline-block;
  width: 100%;
  margin-bottom: calc(12px + (12) * (100vw - 768px) / (672));
  -webkit-column-break-inside: avoid;
  -moz-column-break-inside: avoid;
  break-inside: avoid;
}
@media (max-width: 767px) {
  .gallery-grid__item {
    margin-bottom: calc(8px + (8) * (100vw - 768px) / (672));
  }
}
@media (max-width: 479px) {
  .gallery-grid__item {
    margin-bottom: calc(6px + (6) * (100vw - 768px) / (672));
  }
}
.gallery-grid__item img {
  width: 100%;
  height: auto;
  display: block;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.gallery-grid__item:hover img, .gallery-grid__item:active img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}
.gallery-grid__item:hover .gallery-grid__overlay, .gallery-grid__item:active .gallery-grid__overlay {
  opacity: 1;
}
@media (max-width: 767px) {
  .gallery-grid__item:active img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .gallery-grid__item:active .gallery-grid__overlay {
    opacity: 1;
  }
}
.gallery-grid__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
@media (max-width: 767px) {
  .gallery-grid__overlay {
    background-color: rgba(0, 0, 0, 0.3);
  }
}
.gallery-grid__icon {
  width: 40px;
  height: 40px;
  pointer-events: none;
}

.lightbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: none;
}
.lightbox--active {
  display: block;
  -webkit-animation: fadeIn 0.3s ease;
  animation: fadeIn 0.3s ease;
}
.lightbox__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
}
.lightbox__content {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: calc(30px + (30) * (100vw - 768px) / (672));
}
.lightbox__image {
  max-width: 90%;
  max-height: 90%;
  width: auto;
  height: auto;
  -o-object-fit: contain;
  object-fit: contain;
  -webkit-animation: zoomIn 0.3s ease;
  animation: zoomIn 0.3s ease;
}
@media (min-width: 768px) {
  .lightbox__image {
    min-width: 600px;
    min-height: 400px;
  }
}
@media (min-width: 1200px) {
  .lightbox__image {
    min-width: 800px;
    min-height: 600px;
  }
}
.lightbox__close {
  position: absolute;
  top: calc(10px + (10) * (100vw - 768px) / (672));
  right: calc(10px + (10) * (100vw - 768px) / (672));
  width: calc(24px + (24) * (100vw - 768px) / (672));
  height: calc(24px + (24) * (100vw - 768px) / (672));
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  z-index: 10;
}
.lightbox__close:hover {
  opacity: 0.7;
}
.lightbox__close svg {
  width: 24px;
  height: 24px;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes zoomIn {
  from {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    opacity: 0;
  }
  to {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
}
/**
 * Gallery Beautiful Fade Animations
 * Pure CSS-based fade effects for gallery images
 */
.gallery-fade-item {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: opacity, transform;
}

.gallery-fade-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.gallery-fade-visible .gallery-grid__item {
  -webkit-transition: -webkit-transform 0.3s ease-out, -webkit-box-shadow 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out, -webkit-box-shadow 0.3s ease-out;
  transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
  transition: transform 0.3s ease-out, box-shadow 0.3s ease-out, -webkit-transform 0.3s ease-out, -webkit-box-shadow 0.3s ease-out;
}
.gallery-fade-visible .gallery-grid__item:hover {
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
  -webkit-box-shadow: 0 8px 24px rgba(165, 195, 207, 0.2);
  box-shadow: 0 8px 24px rgba(165, 195, 207, 0.2);
}

.gallery-grid__item img {
  -webkit-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
}
.gallery-grid__item img[src=""] {
  opacity: 0;
}
.gallery-grid__item img.loaded {
  opacity: 1;
}

@media (prefers-reduced-motion: no-preference) {
  .gallery-fade-item {
    -webkit-transition-duration: 0.8s;
    transition-duration: 0.8s;
  }
}
@media (prefers-reduced-motion: reduce) {
  .gallery-fade-item {
    -webkit-transition-duration: 0.2s !important;
    transition-duration: 0.2s !important;
    -webkit-transform: none !important;
    transform: none !important;
  }
}
.gallery-grid__inner {
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.gallery-grid__inner.updating {
  opacity: 0.6;
}

.privacy-policy {
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
  background-color: #f8f9fa;
}
@media (max-width: 767px) {
  .privacy-policy {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.privacy-policy__container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__container {
    padding: 0 clamp(12px, 4.1666666667vw, 36px);
  }
}
.privacy-policy__header {
  text-align: center;
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.privacy-policy__title {
  font-size: calc(25.6px + (6.4) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #333;
  margin-bottom: calc(8px + (8) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
    margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.privacy-policy__date {
  font-size: calc(11.2px + (2.8) * (100vw - 768px) / (672));
  color: #666;
  margin: 0;
}
@media (max-width: 767px) {
  .privacy-policy__date {
    font-size: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.privacy-policy__content {
  line-height: 1.8;
}
.privacy-policy__section {
  margin-bottom: calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__section {
    margin-bottom: clamp(18px, 6.25vw, 54px);
  }
}
.privacy-policy__section:last-child {
  margin-bottom: 0;
}
.privacy-policy__section-title {
  font-size: calc(16px + (4) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 600;
  color: #333;
  margin-bottom: calc(8px + (8) * (100vw - 768px) / (672));
  padding-bottom: calc(4px + (4) * (100vw - 768px) / (672));
  border-bottom: 2px solid #a5c3cf;
}
@media (max-width: 767px) {
  .privacy-policy__section-title {
    font-size: clamp(10.8px, 3.75vw, 32.4px);
    margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
    padding-bottom: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.privacy-policy__text {
  font-size: calc(12.8px + (3.2) * (100vw - 768px) / (672));
  color: #333;
  line-height: 1.8;
  margin-bottom: calc(8px + (8) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__text {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    margin-bottom: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.privacy-policy__text:last-child {
  margin-bottom: 0;
}
.privacy-policy__text a {
  color: #a5c3cf;
  text-decoration: underline;
}
.privacy-policy__text a:hover {
  color: rgb(131.7391304348, 172.8260869565, 189.2608695652);
}
.privacy-policy__list {
  margin: calc(8px + (8) * (100vw - 768px) / (672)) 0;
  padding-left: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__list {
    margin: clamp(7.2px, 2.5vw, 21.6px) 0;
    padding-left: clamp(12px, 4.1666666667vw, 36px);
  }
}
.privacy-policy__list li {
  font-size: calc(12.8px + (3.2) * (100vw - 768px) / (672));
  color: #333;
  line-height: 1.8;
  margin-bottom: calc(4px + (4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__list li {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    margin-bottom: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.privacy-policy__list li:last-child {
  margin-bottom: 0;
}
.privacy-policy__contact {
  background-color: #f8f9fa;
  padding: calc(10px + (10) * (100vw - 768px) / (672));
  border-radius: calc(4px + (4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__contact {
    padding: clamp(9.6px, 3.3333333333vw, 28.8px);
    border-radius: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.privacy-policy__contact-info {
  margin-top: calc(8px + (8) * (100vw - 768px) / (672));
  padding: calc(8px + (8) * (100vw - 768px) / (672));
  background-color: #fff;
  border-radius: calc(3px + (3) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__contact-info {
    margin-top: clamp(7.2px, 2.5vw, 21.6px);
    padding: clamp(7.2px, 2.5vw, 21.6px);
    border-radius: clamp(2.4px, 0.8333333333vw, 7.2px);
  }
}
.privacy-policy__contact-info p {
  font-size: calc(11.2px + (2.8) * (100vw - 768px) / (672));
  color: #333;
  margin-bottom: calc(4px + (4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__contact-info p {
    font-size: clamp(7.8px, 2.7083333333vw, 23.4px);
    margin-bottom: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.privacy-policy__contact-info p:last-child {
  margin-bottom: 0;
}
.privacy-policy__contact-info p strong {
  font-weight: 600;
}
.privacy-policy__footer {
  margin-top: calc(30px + (30) * (100vw - 768px) / (672));
  padding-top: calc(15px + (15) * (100vw - 768px) / (672));
  border-top: 1px solid #eee;
  text-align: center;
}
@media (max-width: 767px) {
  .privacy-policy__footer {
    margin-top: clamp(24px, 8.3333333333vw, 72px);
    padding-top: clamp(12px, 4.1666666667vw, 36px);
  }
}
.privacy-policy__company {
  font-size: calc(12.8px + (3.2) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  margin-bottom: calc(4px + (4) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .privacy-policy__company {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    margin-bottom: clamp(3.6px, 1.25vw, 10.8px);
  }
}

.memorial-photography {
  width: 100%;
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.memorial-photography__container {
  margin: 0 auto;
  width: 100%;
}
.memorial-photography__grid {
  display: grid;
  grid-template-columns: calc(239.5px + (239.5) * (100vw - 768px) / (672)) calc(121.5px + (121.5) * (100vw - 768px) / (672)) calc(39px + (39) * (100vw - 768px) / (672)) calc(279.5px + (279.5) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(71px + (71) * (100vw - 768px) / (672)) calc(121.5px + (121.5) * (100vw - 768px) / (672)) calc(95.5px + (95.5) * (100vw - 768px) / (672)) calc(40px + (40) * (100vw - 768px) / (672));
  width: 100%;
}
@media (max-width: 767px) {
  .memorial-photography__grid {
    grid-template-columns: clamp(12px, 4.1666666667vw, 36px) clamp(230.4px, 80vw, 691.2px) clamp(33.6px, 11.6666666667vw, 100.8px) clamp(12px, 4.1666666667vw, 36px);
    grid-template-rows: clamp(123.6px, 42.9166666667vw, 370.8px) clamp(28.8px, 10vw, 86.4px) clamp(230.4px, 80vw, 691.2px) clamp(28.8px, 10vw, 86.4px);
  }
}
.memorial-photography__item {
  position: relative;
  overflow: hidden;
}
.memorial-photography__item--1 {
  grid-column: 1/4;
  grid-row: 1/5;
  background-color: #f5e9e0;
  z-index: 1;
}
@media (max-width: 767px) {
  .memorial-photography__item--1 {
    grid-column: 1/3;
    grid-row: 2/4;
    z-index: 1;
  }
}
.memorial-photography__item--2 {
  grid-column: 2/5;
  grid-row: 2/-1;
  background: #fcf6de;
  z-index: 0;
}
@media (max-width: 767px) {
  .memorial-photography__item--2 {
    grid-column: 2/4;
    grid-row: 3/-1;
  }
}
.memorial-photography__item--3 {
  grid-column: 3/5;
  grid-row: 3/4;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  z-index: 2;
}
@media (max-width: 767px) {
  .memorial-photography__item--3 {
    grid-column: 2/4;
    grid-row: 1/3;
    z-index: 0;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.memorial-photography__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.memorial-photography__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .memorial-photography__content {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
}
.memorial-photography__title-box {
  background-color: #3f3f3f;
  padding: calc(6px + (6) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(10px + (10) * (100vw - 768px) / (672));
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 0;
}
@media (max-width: 767px) {
  .memorial-photography__title-box {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.memorial-photography__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  letter-spacing: 0.11em;
  font-weight: 400;
  color: white;
  margin: 0;
  text-align: center;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .memorial-photography__title {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.memorial-photography__text-content {
  padding: 0 calc(7.5px + (7.5) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .memorial-photography__text-content {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
}
.memorial-photography__description {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 2.2;
  margin: 0;
  text-align: left;
}
@media (max-width: 767px) {
  .memorial-photography__description {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.5;
  }
}

.portrait-photography {
  width: 100%;
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.portrait-photography__container {
  margin: 0 auto;
  width: 100%;
}
.portrait-photography__grid {
  display: grid;
  grid-template-columns: calc(42.5px + (42.5) * (100vw - 768px) / (672)) calc(279.5px + (279.5) * (100vw - 768px) / (672)) calc(35px + (35) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(71.5px + (71.5) * (100vw - 768px) / (672)) calc(190px + (190) * (100vw - 768px) / (672)) calc(58.5px + (58.5) * (100vw - 768px) / (672)) calc(28.5px + (28.5) * (100vw - 768px) / (672));
  width: 100%;
}
@media (max-width: 767px) {
  .portrait-photography__grid {
    grid-template-columns: clamp(12px, 4.1666666667vw, 36px) clamp(230.4px, 80vw, 691.2px) clamp(33.6px, 11.6666666667vw, 100.8px) clamp(12px, 4.1666666667vw, 36px);
    grid-template-rows: clamp(123.6px, 42.9166666667vw, 370.8px) clamp(28.8px, 10vw, 86.4px) clamp(230.4px, 80vw, 691.2px) clamp(28.8px, 10vw, 86.4px);
  }
}
.portrait-photography__item {
  position: relative;
  overflow: hidden;
}
.portrait-photography__item--1 {
  grid-column: 2/4;
  grid-row: 3/4;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  z-index: 2;
}
@media (max-width: 767px) {
  .portrait-photography__item--1 {
    grid-column: 2/4;
    grid-row: 1/3;
    z-index: 0;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.portrait-photography__item--2 {
  grid-column: 2/5;
  grid-row: 2/-1;
  background: #f5e9e0;
  z-index: 0;
}
@media (max-width: 767px) {
  .portrait-photography__item--2 {
    grid-column: 2/4;
    grid-row: 3/-1;
  }
}
.portrait-photography__item--3 {
  grid-column: 3/-1;
  grid-row: 1/5;
  background-color: #fcf6de;
  z-index: 1;
}
@media (max-width: 767px) {
  .portrait-photography__item--3 {
    grid-column: 1/3;
    grid-row: 2/4;
    z-index: 1;
  }
}
.portrait-photography__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}
.portrait-photography__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .portrait-photography__content {
    padding: 0;
  }
}
.portrait-photography__title-box {
  background-color: #3f3f3f;
  padding: calc(6px + (6) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(10px + (10) * (100vw - 768px) / (672));
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 0;
}
@media (max-width: 767px) {
  .portrait-photography__title-box {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.portrait-photography__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  letter-spacing: 0.11em;
  font-weight: 400;
  color: white;
  margin: 0;
  text-align: center;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .portrait-photography__title {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.portrait-photography__text-content {
  padding: 0 calc(7.5px + (7.5) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .portrait-photography__text-content {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
}
.portrait-photography__description {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 2.2;
  margin: 0 0 calc(10px + (10) * (100vw - 768px) / (672)) 0;
  text-align: left;
}
@media (max-width: 767px) {
  .portrait-photography__description {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.5;
  }
}
.portrait-photography__features {
  list-style: none;
  margin: 0;
  padding: 0;
}
.portrait-photography__feature {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(5px + (5) * (100vw - 768px) / (672));
  margin-bottom: calc(7.5px + (7.5) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .portrait-photography__feature {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
  }
}
.portrait-photography__feature:last-child {
  margin-bottom: 0;
}
.portrait-photography__check {
  width: calc(10px + (10) * (100vw - 768px) / (672));
  height: calc(10px + (10) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.family-photography {
  width: 100%;
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.family-photography__container {
  margin: 0 auto;
  width: 100%;
}
.family-photography__grid {
  display: grid;
  grid-template-columns: calc(239.5px + (239.5) * (100vw - 768px) / (672)) calc(121.5px + (121.5) * (100vw - 768px) / (672)) calc(39px + (39) * (100vw - 768px) / (672)) calc(279.5px + (279.5) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(71px + (71) * (100vw - 768px) / (672)) calc(121.5px + (121.5) * (100vw - 768px) / (672)) calc(95.5px + (95.5) * (100vw - 768px) / (672)) calc(40px + (40) * (100vw - 768px) / (672));
  width: 100%;
}
@media (max-width: 767px) {
  .family-photography__grid {
    grid-template-columns: clamp(12px, 4.1666666667vw, 36px) clamp(230.4px, 80vw, 691.2px) clamp(33.6px, 11.6666666667vw, 100.8px) clamp(12px, 4.1666666667vw, 36px);
    grid-template-rows: clamp(90px, 31.25vw, 270px) clamp(28.8px, 10vw, 86.4px) clamp(230.4px, 80vw, 691.2px) clamp(28.8px, 10vw, 86.4px);
  }
}
.family-photography__item {
  position: relative;
  overflow: hidden;
}
.family-photography__item--1 {
  grid-column: 1/4;
  grid-row: 1/5;
  background-color: #f5e9e0;
  z-index: 1;
}
@media (max-width: 767px) {
  .family-photography__item--1 {
    grid-column: 1/3;
    grid-row: 2/4;
    z-index: 1;
  }
}
.family-photography__item--2 {
  grid-column: 2/5;
  grid-row: 2/-1;
  background: #fcf6de;
  z-index: 0;
}
@media (max-width: 767px) {
  .family-photography__item--2 {
    grid-column: 2/4;
    grid-row: 3/-1;
  }
}
.family-photography__item--3 {
  grid-column: 3/5;
  grid-row: 3/4;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  z-index: 2;
}
@media (max-width: 767px) {
  .family-photography__item--3 {
    grid-column: 2/4;
    grid-row: 1/3;
    z-index: 0;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.family-photography__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.family-photography__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: calc(12px + (12) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .family-photography__content {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
}
.family-photography__title-box {
  background-color: #3f3f3f;
  padding: calc(6px + (6) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(10px + (10) * (100vw - 768px) / (672));
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 0;
}
@media (max-width: 767px) {
  .family-photography__title-box {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
    padding: clamp(6px, 2.0833333333vw, 18px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.family-photography__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  letter-spacing: 0.11em;
  font-weight: 400;
  color: white;
  margin: 0;
  text-align: center;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .family-photography__title {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.family-photography__text-content {
  padding: 0 calc(7.5px + (7.5) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .family-photography__text-content {
    padding: clamp(7.2px, 2.5vw, 21.6px) 0;
  }
}
.family-photography__description {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(8px + (8) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  line-height: 2.2;
  margin: 0;
  text-align: left;
}
@media (max-width: 767px) {
  .family-photography__description {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.5;
  }
}

.photography-plans {
  width: 100%;
  padding: calc(40px + (40) * (100vw - 768px) / (672)) 0;
}
.photography-plans__container {
  margin: 0 auto;
  width: 100%;
}
.photography-plans__grid {
  display: grid;
  grid-template-columns: calc(192px + (192) * (100vw - 768px) / (672)) calc(72px + (72) * (100vw - 768px) / (672)) calc(410px + (410) * (100vw - 768px) / (672)) 1fr;
  grid-template-rows: calc(24px + (24) * (100vw - 768px) / (672)) calc(28px + (28) * (100vw - 768px) / (672)) calc(169px + (169) * (100vw - 768px) / (672)) calc(175px + (175) * (100vw - 768px) / (672)) calc(28px + (28) * (100vw - 768px) / (672));
  gap: 0;
  width: 100%;
}
@media (max-width: 767px) {
  .photography-plans__grid {
    grid-template-columns: clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px) clamp(72px, 25vw, 216px) clamp(72px, 25vw, 216px) 1fr;
    grid-template-rows: 1fr clamp(28.8px, 10vw, 86.4px) clamp(12px, 4.1666666667vw, 36px) clamp(138px, 47.9166666667vw, 414px) clamp(28.8px, 10vw, 86.4px);
  }
}
.photography-plans__item {
  position: relative;
  overflow: hidden;
}
.photography-plans__item--1 {
  grid-column: 1/3;
  grid-row: 1/4;
  background-color: #ffffff;
  padding: calc(20px + (20) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 2;
}
@media (max-width: 767px) {
  .photography-plans__item--1 {
    grid-column: 2/5;
    grid-row: 1/3;
    z-index: 1;
    padding: 0;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
    margin-top: clamp(24px, 8.3333333333vw, 72px);
    -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  }
}
.photography-plans__item--2 {
  grid-column: 1/-1;
  grid-row: 2/6;
  background: #e9edf0;
  z-index: 0;
}
@media (max-width: 767px) {
  .photography-plans__item--2 {
    grid-column: 1/-1;
    grid-row: 2/-1;
  }
}
.photography-plans__item--3 {
  grid-column: 2/4;
  grid-row: 3/5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 1;
  width: 100%;
  height: 100%;
}
@media (max-width: 767px) {
  .photography-plans__item--3 {
    grid-column: 3/-1;
    grid-row: 4/-1;
    z-index: 0;
    margin-top: clamp(12px, 4.1666666667vw, 36px);
  }
}
.photography-plans__content {
  text-align: center;
}
.photography-plans__content h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(12px + (12) * (100vw - 768px) / (672));
  color: #333;
}
.photography-plans__item--3 .photography-plans__content {
  width: 100%;
  height: 100%;
}
.photography-plans__item--3 .photography-plans__content img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}
.photography-plans .tax-included {
  font-size: 0.7em;
  font-weight: 400;
}

.options-section {
  width: 100%;
  margin-right: calc(96px + (64) * (100vw - 768px) / (672));
  padding-top: calc(36px + (24) * (100vw - 768px) / (672));
  padding-bottom: calc(36px + (24) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .options-section {
    margin-right: 0;
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.options-section__container {
  margin: 0 auto;
  padding: calc(32.4px + (21.6) * (100vw - 768px) / (672)) calc(64px + (96) * (100vw - 768px) / (672));
  margin: calc(48px + (32) * (100vw - 768px) / (672)) calc(96px + (64) * (100vw - 768px) / (672));
  text-align: center;
  background: #f8f4e6;
}
@media (max-width: 767px) {
  .options-section__container {
    margin: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.options-section__header {
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .options-section__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.options-section__icon {
  margin-bottom: calc(8px + (12) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .options-section__icon {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.options-section__sun-icon {
  width: calc(57.36px + (38.24) * (100vw - 768px) / (672));
  height: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .options-section__sun-icon {
    width: clamp(48px, 16.6666666667vw, 144px);
    height: clamp(30px, 10.4166666667vw, 90px);
  }
}
.options-section__title {
  font-size: calc(19.2px + (12.8) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .options-section__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
  }
}
.options-section__content {
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .options-section__content {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.options-section__text-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: calc(8px + (12) * (100vw - 768px) / (672));
  margin-bottom: calc(8px + (12) * (100vw - 768px) / (672));
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .options-section__text-row {
    gap: clamp(7.2px, 2.5vw, 21.6px);
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.options-section__text-row:last-child {
  margin-bottom: 0;
}
.options-section__text {
  font-size: calc(9px + (9) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .options-section__text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.5;
  }
}

.photography-flow-section {
  width: 100%;
  padding: calc(43.2px + (28.8) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .photography-flow-section {
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.photography-flow-section__container {
  margin: 0 calc(89.6px + (134.4) * (100vw - 768px) / (672));
  padding-top: calc(43.2px + (28.8) * (100vw - 768px) / (672));
  padding-bottom: calc(43.2px + (28.8) * (100vw - 768px) / (672));
  background: #e9edf0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  z-index: 0;
}
@media (max-width: 767px) {
  .photography-flow-section__container {
    margin: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px);
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.photography-flow-section__header {
  text-align: center;
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .photography-flow-section__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.photography-flow-section__label {
  display: inline-block;
  background: #3f3f3f;
  color: white;
  padding: calc(3.2px + (4.8) * (100vw - 768px) / (672)) calc(9.6px + (14.4) * (100vw - 768px) / (672));
  margin-bottom: calc(16px + (16) * (100vw - 768px) / (672));
  font-size: calc(5.6px + (8.4) * (100vw - 768px) / (672));
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .photography-flow-section__label {
    padding: clamp(4.8px, 1.6666666667vw, 14.4px) clamp(12px, 4.1666666667vw, 36px);
    margin-bottom: clamp(14.4px, 5vw, 43.2px);
    font-size: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.photography-flow-section__title {
  font-size: calc(16.8px + (11.2) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #3f3f3f;
  font-family: "Noto Serif JP", serif;
  letter-spacing: calc(0.74px + (0.26) * (100vw - 768px) / (672));
  margin: 0;
}
@media (max-width: 767px) {
  .photography-flow-section__title {
    font-size: clamp(12px, 4.1666666667vw, 36px);
    letter-spacing: clamp(0.3px, 0.1041666667vw, 0.9px);
  }
}
.photography-flow-section__cards {
  width: calc(100% + 64px + (64) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: calc(20px + (20) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .photography-flow-section__cards {
    width: 100%;
    gap: clamp(14.4px, 5vw, 43.2px);
  }
}

.flow-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background: #fff;
  border-radius: calc(5px + (5) * (100vw - 768px) / (672));
  padding: calc(21.5px + (21.5) * (100vw - 768px) / (672)) calc(19px + (19) * (100vw - 768px) / (672));
  overflow: visible;
  position: relative;
  z-index: 1;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  gap: calc(16px + (16) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .flow-card {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: clamp(12px, 4.1666666667vw, 36px);
    gap: clamp(9.6px, 3.3333333333vw, 28.8px);
    border-radius: clamp(4.8px, 1.6666666667vw, 14.4px);
  }
}
.flow-card__image {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: calc(235.2px + (156.8) * (100vw - 768px) / (672));
  height: calc(150px + (100) * (100vw - 768px) / (672));
  border-radius: calc(3.2px + (4.8) * (100vw - 768px) / (672));
  overflow: hidden;
}
@media (max-width: 767px) {
  .flow-card__image {
    width: 100%;
    height: clamp(120px, 41.6666666667vw, 360px);
    border-radius: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.flow-card__image-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.flow-card__content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: calc(6.4px + (9.6) * (100vw - 768px) / (672));
  padding: calc(2.4px + (5.6) * (100vw - 768px) / (672)) 0;
}
@media (max-width: 767px) {
  .flow-card__content {
    gap: clamp(7.2px, 2.5vw, 21.6px);
    padding: 0;
    text-align: center;
  }
}
.flow-card__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(6.4px + (9.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .flow-card__header {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.flow-card__number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: calc(3.2px + (4.8) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .flow-card__number {
    gap: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.flow-card__number-icon {
  width: calc(22.8px + (34.2) * (100vw - 768px) / (672));
  height: calc(22.8px + (34.2) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .flow-card__number-icon {
    width: clamp(24px, 8.3333333333vw, 72px);
    height: clamp(24px, 8.3333333333vw, 72px);
  }
}
.flow-card__number-text {
  font-size: calc(36.624px + (24.416) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #3f3f3f;
  font-family: "Noto Serif JP", serif;
  line-height: 1;
}
@media (max-width: 767px) {
  .flow-card__number-text {
    font-size: clamp(21.6px, 7.5vw, 64.8px);
  }
}
.flow-card__badge {
  display: inline-block;
  background: #a5c3cf;
  color: white;
  padding: calc(4.44px + (1.56) * (100vw - 768px) / (672)) calc(11.84px + (4.16) * (100vw - 768px) / (672));
  font-size: calc(10.36px + (3.64) * (100vw - 768px) / (672));
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media (max-width: 767px) {
  .flow-card__badge {
    padding: clamp(3.6px, 1.25vw, 10.8px) clamp(7.2px, 2.5vw, 21.6px);
    font-size: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.flow-card__underline {
  width: 100%;
  margin: calc(2.4px + (5.6) * (100vw - 768px) / (672)) 0;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: left center;
  object-position: left center;
}
@media (max-width: 767px) {
  .flow-card__underline {
    margin: clamp(3.6px, 1.25vw, 10.8px) 0;
    -o-object-position: center;
    object-position: center;
  }
}
.flow-card__description {
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: #333;
  line-height: 1.8;
  font-family: "Noto Sans JP", sans-serif;
  margin: 0;
  text-align: left;
}
@media (max-width: 767px) {
  .flow-card__description {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    line-height: 1.6;
  }
}

.faq-section {
  width: 100%;
  margin-right: calc(96px + (64) * (100vw - 768px) / (672));
  padding-top: calc(36px + (24) * (100vw - 768px) / (672));
  padding-bottom: calc(36px + (24) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .faq-section {
    margin-right: 0;
    padding: clamp(24px, 8.3333333333vw, 72px) 0;
  }
}
.faq-section__container {
  margin: 0 auto;
  padding: calc(32.4px + (21.6) * (100vw - 768px) / (672)) calc(32px + (128) * (100vw - 768px) / (672));
  margin: calc(48px + (32) * (100vw - 768px) / (672)) calc(96px + (64) * (100vw - 768px) / (672));
  text-align: center;
  background: #f8f4e6;
}
@media (max-width: 767px) {
  .faq-section__container {
    margin: clamp(12px, 4.1666666667vw, 36px) clamp(12px, 4.1666666667vw, 36px) clamp(24px, 8.3333333333vw, 72px);
    padding: clamp(24px, 8.3333333333vw, 72px) clamp(12px, 4.1666666667vw, 36px);
  }
}
.faq-section__header {
  margin-bottom: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .faq-section__header {
    margin-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}
.faq-section__icon {
  margin-bottom: calc(8px + (12) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .faq-section__icon {
    margin-bottom: clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.faq-section__sun-icon {
  width: calc(57.36px + (38.24) * (100vw - 768px) / (672));
  height: calc(30px + (30) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .faq-section__sun-icon {
    width: clamp(48px, 16.6666666667vw, 144px);
    height: clamp(30px, 10.4166666667vw, 90px);
  }
}
.faq-section__title {
  font-size: calc(19.2px + (12.8) * (100vw - 768px) / (672));
  font-weight: 600;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 767px) {
  .faq-section__title {
    font-size: clamp(14.4px, 5vw, 43.2px);
  }
}
.faq-section__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: calc(8px + (12) * (100vw - 768px) / (672));
  text-align: left;
  padding-bottom: calc(37px + (13) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .faq-section__list {
    gap: clamp(9.6px, 3.3333333333vw, 28.8px);
    padding-bottom: clamp(24px, 8.3333333333vw, 72px);
  }
}

.faq-item {
  background: #fff;
  border-radius: calc(3.2px + (4.8) * (100vw - 768px) / (672));
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
@media (max-width: 767px) {
  .faq-item {
    border-radius: clamp(3.6px, 1.25vw, 10.8px);
  }
}
.faq-item__question {
  padding: calc(12px + (12) * (100vw - 768px) / (672)) calc(16px + (16) * (100vw - 768px) / (672));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
@media (max-width: 767px) {
  .faq-item__question {
    padding: clamp(9.6px, 3.3333333333vw, 28.8px) clamp(12px, 4.1666666667vw, 36px);
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.faq-item__question:hover {
  background-color: #f9f9f9;
}
.faq-item__q-text {
  font-size: calc(12.5px + (12.5) * (100vw - 768px) / (672));
  font-weight: 400;
  color: #333;
  font-family: "Noto Serif JP", serif;
  line-height: 1.6;
  letter-spacing: 0.05em;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-right: calc(6.4px + (9.6) * (100vw - 768px) / (672));
}
@media (max-width: 767px) {
  .faq-item__q-text {
    font-size: clamp(9.6px, 3.3333333333vw, 28.8px);
    line-height: 1.5;
    margin-right: clamp(7.2px, 2.5vw, 21.6px);
  }
}
.faq-item__icon {
  width: calc(9.6px + (14.4) * (100vw - 768px) / (672));
  height: calc(9.6px + (14.4) * (100vw - 768px) / (672));
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
@media (max-width: 767px) {
  .faq-item__icon {
    width: clamp(12px, 4.1666666667vw, 36px);
    height: clamp(12px, 4.1666666667vw, 36px);
    margin-top: clamp(1.2px, 0.4166666667vw, 3.6px);
  }
}
.faq-item__answer {
  overflow: hidden;
  height: 0;
  opacity: 0;
  -webkit-transition: height 0.4s ease, opacity 0.4s ease;
  transition: height 0.4s ease, opacity 0.4s ease;
}
.faq-item__a-content {
  padding: 0 calc(16px + (16) * (100vw - 768px) / (672)) calc(12px + (12) * (100vw - 768px) / (672));
  border-top: 1px solid #eee;
}
@media (max-width: 767px) {
  .faq-item__a-content {
    padding: 0 clamp(12px, 4.1666666667vw, 36px) clamp(9.6px, 3.3333333333vw, 28.8px);
  }
}
.faq-item__a-text {
  font-size: calc(11.84px + (4.16) * (100vw - 768px) / (672));
  color: #666;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.8;
  margin: calc(12px + (12) * (100vw - 768px) / (672)) 0 0;
}
@media (max-width: 767px) {
  .faq-item__a-text {
    font-size: clamp(8.4px, 2.9166666667vw, 25.2px);
    line-height: 1.6;
    margin: clamp(9.6px, 3.3333333333vw, 28.8px) 0 0;
  }
}
.faq-item.is-open .faq-item__answer {
  height: auto;
  opacity: 1;
}