@charset "UTF-8";
/*###################################################################
※※※※ 直接編集禁止 ※※※※
このCSSファイルはSassから生成されていますので直接編集しないようご注意ください。
  編集は拡張子「.scss」ファイルを編集して当ファイルにコンパイルしてください。
  もしくは別途cssファイルを作成して読み込ませてください。
###################################################################*/
:root {
  --base: #fff;
  --base2: #f5f1eb;
  --main: #d0bca1;
  --main2: #b8a791;
  --accent: #9f815b;
  --text: #8d8983;
}

/*###################################################################
  base（共通設定）
###################################################################*/
/*----------------------------------
  html
----------------------------------*/
html {
  scroll-behavior: smooth;
}

[id] {
  scroll-margin-top: clamp(4.375rem, 2.2261549925rem + 4.4709388972vw, 6.25rem);
}
@media (max-width: 768px) {
  [id] {
    scroll-margin-top: 60px;
  }
}

body {
  color: var(--text);
  font-family: "M PLUS 1p", sans-serif;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

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

/*###################################################################
  animation（共通設定）
###################################################################*/
/*----------------------------------
  mv-title
----------------------------------*/
@-webkit-keyframes mvTitle {
  0% {
    -webkit-clip-path: inset(0 0 100% 0);
            clip-path: inset(0 0 100% 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
@keyframes mvTitle {
  0% {
    -webkit-clip-path: inset(0 0 100% 0);
            clip-path: inset(0 0 100% 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
/*----------------------------------
  無限ループスライダー
----------------------------------*/
@-webkit-keyframes infinity-scroll {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes infinity-scroll {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
/*###################################################################
  header（module）
###################################################################*/
.header {
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 10;
  background-color: var(--base);
}
.header_sticky {
  position: fixed;
}
.header__inner {
  height: clamp(3.75rem, 0.8848733234rem + 5.9612518629vw, 6.25rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
  padding: 0 clamp(1.25rem, -3.0476900149rem + 8.9418777943vw, 5rem);
}
@media (max-width: 768px) {
  .header__inner {
    height: 55px;
  }
}
.header__logo {
  max-width: clamp(11.875rem, -4.6711065574rem + 34.4262295082vw, 26.3125rem);
  width: 100%;
}
@media (max-width: 768px) {
  .header__logo {
    max-width: 210px;
  }
}
.header__menu {
  max-width: clamp(30.5625rem, 9.0740499255rem + 44.7093889717vw, 49.3125rem);
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
@media (max-width: 768px) {
  .header__menu {
    max-width: 45px;
    margin-left: auto;
  }
}
.header__tel {
  max-width: clamp(9.125rem, 5.758476155rem + 7.0044709389vw, 12.0625rem);
  width: 100%;
  height: clamp(2.5rem, 1.640461997rem + 1.7883755589vw, 3.25rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
  border: 2px solid var(--accent);
  border-radius: 10px;
}
@media (max-width: 768px) {
  .header__tel {
    height: 45px;
  }
}
.header__tel::before {
  content: "";
  min-width: clamp(0.9375rem, 0.7226154993rem + 0.4470938897vw, 1.125rem);
  aspect-ratio: 1/1;
  background-color: var(--accent);
  -webkit-mask-image: url(../images/icon-tel.svg);
          mask-image: url(../images/icon-tel.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.header__tel-number {
  color: var(--accent);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(0.9375rem, 0.7226154993rem + 0.4470938897vw, 1.125rem);
  font-weight: bold;
}
@media (max-width: 768px) {
  .header__tel-number {
    display: none;
  }
}

@media (hover: hover) and (pointer: fine) {
  .header__tel {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .header__tel:hover, .header__tel:focus {
    background-color: var(--accent);
  }
  .header__tel:hover::before, .header__tel:focus::before {
    background-color: var(--base);
  }
  .header__tel:hover .header__tel-number, .header__tel:focus .header__tel-number {
    color: var(--base);
  }
  .header__tel::before {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .header__tel-number {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
}
.header-nav {
  max-width: 521px;
  width: 100%;
}
@media (max-width: 768px) {
  .header-nav {
    display: none;
  }
}
.header-nav__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.header-nav__item {
  position: relative;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: bold;
  font-size: clamp(0.875rem, 0.5884873323rem + 0.5961251863vw, 1.125rem);
}
.header-nav__summary {
  display: inline-block;
  cursor: pointer;
}
.header-nav__summary::-webkit-details-marker {
  display: none;
}
.header-nav__submenu {
  width: clamp(7.5rem, 5.3511549925rem + 4.4709388972vw, 9.375rem);
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: var(--base);
}
.header-nav__subitems {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
.header-nav__subitem:not(:last-of-type) {
  border-bottom: 1px solid var(--text);
}
.header-nav__sublink {
  display: block;
  padding: 8px 10px;
}

@media (hover: hover) and (pointer: fine) {
  .header-nav__link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .header-nav__link:hover, .header-nav__link:focus {
    color: var(--accent);
  }
  .header-nav__summary-text {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .header-nav__summary-text:hover, .header-nav__summary-text:focus {
    color: var(--accent);
  }
  .header-nav__sublink {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .header-nav__sublink:hover, .header-nav__sublink:focus {
    background-color: var(--base2);
  }
}
/*###################################################################
  footer（module）
###################################################################*/
.footer__inner {
  max-width: 680px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 60px 30px 60px;
}
@media (max-width: 768px) {
  .footer__inner {
    padding: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.footer__logo {
  max-width: clamp(14.800625rem, 3.8160114504rem + 46.8676844784vw, 26.3125rem);
  display: block;
  margin-inline: auto;
}
.footer__nav {
  margin-inline: auto;
}
.footer__gmap {
  width: 100%;
  height: clamp(18.75rem, 12.786259542rem + 25.4452926209vw, 25rem);
}
.footer__copy {
  height: clamp(3.6875rem, 3.5085877863rem + 0.7633587786vw, 3.875rem);
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-size: clamp(0.75rem, 0.6307251908rem + 0.5089058524vw, 0.875rem);
  font-weight: bold;
}

.footer-contact {
  background-color: var(--base2);
}
.footer-contact__inner {
  max-width: 680px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 60px 30px 60px;
}
@media (max-width: 768px) {
  .footer-contact__inner {
    padding: clamp(2.5rem, 1.3072519084rem + 5.0890585242vw, 3.75rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.footer-contact__text {
  text-align: center;
}
@media (max-width: 768px) {
  .footer-contact__text {
    text-align: left;
  }
}
.footer-contact__contact {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(0.625rem, -0.5677480916rem + 5.0890585242vw, 1.875rem) 15px;
}
@media (max-width: 768px) {
  .footer-contact__contact {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.footer-contact__btn {
  max-width: clamp(15rem, 10.2290076336rem + 20.3562340967vw, 20rem);
  width: 100%;
  height: clamp(3.375rem, 2.4804389313rem + 3.8167938931vw, 4.3125rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  font-size: clamp(1rem, 0.5229007634rem + 2.0356234097vw, 1.5rem);
  border-radius: 10px;
}
.footer-contact__btn::before {
  content: "";
}
.footer-contact__btn_tel {
  background-color: var(--base);
  color: var(--accent);
  border: 2px solid var(--accent);
}
.footer-contact__btn_tel::before {
  min-width: 24px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel.svg) no-repeat center center/contain;
}
.footer-contact__btn_mail {
  background-color: var(--accent);
  color: var(--base);
}
.footer-contact__btn_mail::before {
  min-width: 30px;
  aspect-ratio: 30/24;
  background: url(../images/icon-mail.svg) no-repeat center center/contain;
}

.footer-nav {
  max-width: 522px;
  width: 100%;
}
.footer-nav__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.footer-nav__item {
  position: relative;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
}
.footer-nav__summary {
  display: inline-block;
  cursor: pointer;
}
.footer-nav__summary::-webkit-details-marker {
  display: none;
}
.footer-nav__submenu {
  width: clamp(7.5rem, 5.3511549925rem + 4.4709388972vw, 9.375rem);
  position: absolute;
  top: 100%;
  left: 0;
  background-color: var(--base);
}
.footer-nav__subitems {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 10px;
}

@media (hover: hover) and (pointer: fine) {
  .footer-nav__link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .footer-nav__link:hover, .footer-nav__link:focus {
    color: var(--accent);
  }
  .footer-nav__summary-text {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .footer-nav__summary-text:hover, .footer-nav__summary-text:focus {
    color: var(--accent);
  }
  .footer-nav__sublink {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .footer-nav__sublink:hover, .footer-nav__sublink:focus {
    color: var(--accent);
  }
}
/*###################################################################
  c-bg（module）
###################################################################*/
.c-bg-lower {
  background: url(../images/lower-bg.webp) repeat top center/auto auto;
  background-image: -webkit-image-set(url(../images/lower-bg.webp) 1x, url(../images/lower-bg@2x.webp) 2x);
  background-image: image-set(url(../images/lower-bg.webp) 1x, url(../images/lower-bg@2x.webp) 2x);
  margin-top: -61px;
  padding-top: 121px;
  padding-bottom: clamp(2.5rem, -0.5rem + 12.8vw, 7.5rem);
}

/*###################################################################
  c-inner（module）
###################################################################*/
.c-inner-1 {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .c-inner-1 {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}

/*###################################################################
  c-margin（module）
###################################################################*/
.c-mt40 {
  margin-top: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
}

.c-mt60 {
  margin-top: clamp(1.875rem, 0.75rem + 4.8vw, 3.75rem);
}

.c-mt80 {
  margin-top: clamp(2.5rem, 1rem + 6.4vw, 5rem);
}

.c-mt100 {
  margin-top: clamp(2.5rem, 0.25rem + 9.6vw, 6.25rem);
}

.c-mt120 {
  margin-top: clamp(2.5rem, -0.5rem + 12.8vw, 7.5rem);
}

/*###################################################################
  c-text（module）
###################################################################*/
.c-t16 {
  font-size: clamp(0.8125rem, 0.6335877863rem + 0.7633587786vw, 1rem);
  font-weight: 500;
  line-height: 2.4;
  white-space: pre-line;
}

.c-t16lh2 {
  font-size: clamp(0.8125rem, 0.6335877863rem + 0.7633587786vw, 1rem);
  font-weight: bold;
  line-height: 2;
  white-space: pre-line;
}

/*###################################################################
  c-title（module）
###################################################################*/
.c-title-jp {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 9px;
  color: var(--main);
  font-size: clamp(2.5rem, 1.6rem + 3.84vw, 4rem);
  font-weight: bold;
  line-height: 1;
}
.c-title-jp::after {
  content: "";
  width: clamp(4.9375rem, 3.4rem + 6.56vw, 7.5rem);
  aspect-ratio: 120/47;
  background: url(../images/icon-title-deco.svg) no-repeat center center/contain;
}

.c-title-en {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 9px;
  color: var(--main);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(2.5rem, 1.6rem + 3.84vw, 4rem);
  font-weight: bold;
  line-height: 1;
}
.c-title-en::after {
  content: "";
  width: clamp(4.9375rem, 3.4rem + 6.56vw, 7.5rem);
  aspect-ratio: 120/47;
  background: url(../images/icon-title-deco.svg) no-repeat center center/contain;
}

.c-title-line {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.5rem, 0.425rem + 0.32vw, 0.625rem);
     -moz-column-gap: clamp(0.5rem, 0.425rem + 0.32vw, 0.625rem);
          column-gap: clamp(0.5rem, 0.425rem + 0.32vw, 0.625rem);
  color: var(--main);
  font-size: clamp(1.75rem, 1.3rem + 1.92vw, 2.5rem);
  font-weight: bold;
  line-height: 1;
}
.c-title-line::before, .c-title-line::after {
  content: "";
  width: clamp(1.75rem, 1.3rem + 1.92vw, 2.5rem);
  height: clamp(0.1875rem, 0.1125rem + 0.32vw, 0.3125rem);
  background-color: var(--main);
  margin-top: calc(clamp(0.0625rem, -0.0875rem + 0.64vw, 0.3125rem) * -1);
}

/*###################################################################
  br（module）
###################################################################*/
.br-1050-b {
  display: none;
}
@media (max-width: 1050px) {
  .br-1050-b {
    display: block;
  }
}
.br-1000-b {
  display: none;
}
@media (max-width: 1000px) {
  .br-1000-b {
    display: block;
  }
}
.br-900-b {
  display: none;
}
@media (max-width: 900px) {
  .br-900-b {
    display: block;
  }
}
.br-800-b {
  display: none;
}
@media (max-width: 800px) {
  .br-800-b {
    display: block;
  }
}
.br-sp-b {
  display: none;
}
@media (max-width: 768px) {
  .br-sp-b {
    display: block;
  }
}
.br-600-b {
  display: none;
}
@media (max-width: 600px) {
  .br-600-b {
    display: block;
  }
}
.br-500-b {
  display: none;
}
@media (max-width: 500px) {
  .br-500-b {
    display: block;
  }
}

/*###################################################################
  hamburger（module）
###################################################################*/
.hamburger {
  width: 35px;
  height: 8px;
  display: inline-block;
  position: relative;
  z-index: 30;
}
@media (min-width: 769px) {
  .hamburger {
    display: none;
  }
}
.hamburger[aria-expanded=true] .hamburger__line {
  background-color: transparent;
}
.hamburger[aria-expanded=true] .hamburger__line::before {
  -webkit-transform: translateY(-3px) rotate(165deg);
      -ms-transform: translateY(-3px) rotate(165deg);
          transform: translateY(-3px) rotate(165deg);
  background-color: var(--base);
}
.hamburger[aria-expanded=true] .hamburger__line::after {
  -webkit-transform: translateY(3px) rotate(-165deg);
      -ms-transform: translateY(3px) rotate(-165deg);
          transform: translateY(3px) rotate(-165deg);
  background-color: var(--base);
}
.hamburger__line {
  width: 100%;
  height: 0.10875rem;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
  background-color: transparent;
}
.hamburger__line::before {
  content: "";
  width: 100%;
  height: 0.10875rem;
  display: inline-block;
  position: absolute;
  top: 3px;
  left: 0;
  -webkit-transition: -webkit-transform 0.5s;
  transition: -webkit-transform 0.5s;
  transition: transform 0.5s;
  transition: transform 0.5s, -webkit-transform 0.5s;
  background-color: var(--main);
}
.hamburger__line::after {
  content: "";
  width: 100%;
  height: 0.10875rem;
  display: inline-block;
  position: absolute;
  bottom: 3px;
  left: 0;
  -webkit-transition: -webkit-transform 0.5s;
  transition: -webkit-transform 0.5s;
  transition: transform 0.5s;
  transition: transform 0.5s, -webkit-transform 0.5s;
  background-color: var(--main);
}

@media (hover: hover) and (pointer: fine) {
  .hamburger {
    -webkit-transition: opacity 0.4s;
    transition: opacity 0.4s;
  }
  .hamburger:hover {
    opacity: 0.7;
  }
}
/*###################################################################
  drawer（module）
###################################################################*/
.drawer {
  width: 270px;
  height: 100vh;
  -webkit-transform: translateX(270px);
      -ms-transform: translateX(270px);
          transform: translateX(270px);
  -webkit-transition: 0.5s;
  transition: 0.5s;
  background-color: var(--main);
  z-index: 15;
  overflow: auto;
  overscroll-behavior-y: contain;
  visibility: hidden;
}
.drawer[aria-hidden=false] {
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
  visibility: visible;
}
.drawer_position {
  position: fixed;
  top: 0;
  right: 0;
}
.drawer__inner {
  padding-bottom: 100px;
}
.drawer__top {
  width: 100%;
  height: 55px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--main);
  z-index: 1;
}
.drawer__items {
  max-width: 160px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 41px;
  margin-inline: auto;
  padding-top: 106px;
}
.drawer__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  color: var(--base);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: 18px;
  font-weight: bold;
}
.drawer__link::after {
  content: "";
  min-width: 8px;
  aspect-ratio: 8/14;
  background-color: var(--base);
  -webkit-mask-image: url(../images/icon-drawer.svg);
          mask-image: url(../images/icon-drawer.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.drawer__details[open] .drawer__summary-text::after {
  -webkit-transform: rotate(270deg);
      -ms-transform: rotate(270deg);
          transform: rotate(270deg);
}
.drawer__summary {
  display: block;
  cursor: pointer;
}
.drawer__summary::-webkit-details-marker {
  display: none;
}
.drawer__summary-text {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  color: var(--base);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: 18px;
  font-weight: bold;
}
.drawer__summary-text::after {
  content: "";
  min-width: 8px;
  aspect-ratio: 8/14;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
  background-color: var(--base);
  -webkit-mask-image: url(../images/icon-drawer.svg);
          mask-image: url(../images/icon-drawer.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.drawer__submenu-body {
  padding-top: 15px;
}
.drawer__subitems {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 15px;
  padding-left: 17px;
}
.drawer__sublink {
  color: var(--base);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: bold;
}

.is-drawer-active {
  overflow: hidden;
}

@media (hover: hover) and (pointer: fine) {
  .drawer__link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__link::after {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .drawer__link:hover, .drawer__link:focus {
    color: var(--accent);
  }
  .drawer__link:hover::after, .drawer__link:focus::after {
    background-color: var(--accent);
  }
  .drawer__summary-text {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__summary-text::after {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .drawer__summary-text:hover, .drawer__summary-text:focus {
    color: var(--accent);
  }
  .drawer__summary-text:hover::after, .drawer__summary-text:focus::after {
    background-color: var(--accent);
  }
  .drawer__sublink {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__sublink:hover, .drawer__sublink:focus {
    color: var(--accent);
  }
}
.drawer-bg {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  background-color: #000;
  visibility: hidden;
  opacity: 0;
  z-index: 5;
}

.is-drawer-active {
  height: 100%;
  overflow: hidden;
}
.is-drawer-active .drawer-bg {
  visibility: visible;
  opacity: 0.8;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

/*###################################################################
  hover（module）
###################################################################*/
@media (hover: hover) and (pointer: fine) {
  .op {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op:hover, .op:focus {
    opacity: 0.7;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-fn {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-fn:hover {
    opacity: 0.7;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-im {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-im:hover, .op-im:focus {
    opacity: 0.7 !important;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-fnim {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-fnim:hover {
    opacity: 0.7 !important;
  }
}
/*###################################################################
  lower（module）
###################################################################*/
.lower-mv {
  padding-top: clamp(3.75rem, 0.8848733234rem + 5.9612518629vw, 6.25rem);
}
@media (max-width: 768px) {
  .lower-mv {
    padding-top: 55px;
  }
}
.lower-mv__bg {
  display: grid;
  place-items: center;
  aspect-ratio: 1440/400;
  background: url(../images/lower-mv-1.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/lower-mv-1.webp) 1x, url(../images/lower-mv-1@2x.webp) 2x);
  background-image: image-set(url(../images/lower-mv-1.webp) 1x, url(../images/lower-mv-1@2x.webp) 2x);
}
@media (max-width: 768px) {
  .lower-mv__bg {
    height: clamp(9.6875rem, 6.2285305344rem + 14.7582697201vw, 13.3125rem);
    aspect-ratio: inherit;
  }
}
.lower-mv__title {
  color: var(--base);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(2.25rem, 1.0845994475rem + 4.9723756906vw, 5.0625rem);
  font-weight: bold;
  text-shadow: 2px 2px 20px rgba(0, 0, 0, 0.8);
  margin-top: 3px;
}

/*###################################################################
  WordPressテスト環境用設定
###################################################################*/
/*###################################################################
  top（page）
###################################################################*/
.top-mv {
  padding-top: clamp(3.75rem, 0.8848733234rem + 5.9612518629vw, 6.25rem);
}
@media (max-width: 768px) {
  .top-mv {
    padding-top: 55px;
  }
}
.top-mv__body {
  container-type: inline-size;
  position: relative;
}
.top-mv__title-box {
  max-width: 10.9722222222cqw;
  width: 100%;
  position: absolute;
  top: 2.9861111111cqw;
  right: 8.8194444444cqw;
  z-index: 3;
}
@media (max-width: 768px) {
  .top-mv__title-box {
    max-width: 74px;
    top: 17.8666666667cqw;
    right: inherit;
    left: 8.5333333333cqw;
  }
}
.top-mv__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: var(--base);
  font-size: 4.4444444444cqw;
  font-weight: bold;
  line-height: 1.4;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  letter-spacing: 0.406em;
  text-shadow: 2px 2px 20px rgba(0, 0, 0, 0.8);
}
@media (max-width: 768px) {
  .top-mv__title {
    font-size: 8.5333333333cqw;
  }
}

.top-news {
  position: relative;
  padding-top: 9px;
}
@media (max-width: 768px) {
  .top-news {
    padding-top: 0;
  }
}
.top-news::before {
  content: "";
  max-width: clamp(11.4375rem, 1.6125rem + 41.92vw, 27.8125rem);
  width: 100%;
  aspect-ratio: 445/360;
  position: absolute;
  top: 0;
  right: 0;
  background: url(../images/top-news-deco-1.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-news-deco-1.webp) 1x, url(../images/top-news-deco-1@2x.webp) 2x);
  background-image: image-set(url(../images/top-news-deco-1.webp) 1x, url(../images/top-news-deco-1@2x.webp) 2x);
}
@media (max-width: 768px) {
  .top-news::before {
    top: inherit;
    bottom: calc(clamp(7.9375rem, 0.4828244275rem + 31.8066157761vw, 15.75rem) * -1);
  }
}
.top-news_pos {
  margin-top: calc(clamp(3.375rem, -0.1991193738rem + 7.4363992172vw, 5.75rem) * -1);
}
@media (max-width: 768px) {
  .top-news_pos {
    margin-top: -65px;
  }
}
.top-news__inner {
  max-width: 640px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-news__inner {
    max-width: clamp(18.4375rem, -2.1374045802rem + 87.786259542vw, 40rem);
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-news__body {
  position: relative;
  z-index: 1;
  background-color: var(--base);
  border-radius: 20px;
  border: 1px solid var(--main);
  padding: 20px 20px 20px;
}
.top-news__title {
  color: var(--main);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1rem, 0.5229007634rem + 2.0356234097vw, 1.5rem);
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
.top-news__post {
  margin-top: 9px;
}
.top-news__post-link {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: grid;
  grid-template-columns: 101px 1fr;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  font-size: clamp(0.8125rem, 0.6335877863rem + 0.7633587786vw, 1rem);
  line-height: 1.4;
  font-weight: bold;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-news__post-link {
    grid-template-columns: 1fr;
    justify-items: center;
    row-gap: 9px;
  }
}
.top-news__date {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
}
.top-news__no-post {
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
.top-news__more {
  max-width: clamp(6.6875rem, 6.3296755725rem + 1.5267175573vw, 7.0625rem);
  height: clamp(1.75rem, 1.6307251908rem + 0.5089058524vw, 1.875rem);
  display: grid;
  place-items: center;
  color: var(--main);
  font-size: clamp(0.8125rem, 0.7528625954rem + 0.2544529262vw, 0.875rem);
  font-weight: bold;
  border: 2px solid var(--main);
  border-radius: 10px;
  margin-top: clamp(0.5625rem, 0.2046755725rem + 1.5267175573vw, 0.9375rem);
  margin-inline: auto;
}

@media (hover: hover) and (pointer: fine) {
  .top-news__post-link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .top-news__post-link:hover, .top-news__post-link:focus {
    color: var(--main);
  }
  .top-news__more {
    -webkit-transition: background-color 0.4s, color 0.4s;
    transition: background-color 0.4s, color 0.4s;
  }
  .top-news__more:hover, .top-news__more:focus {
    background-color: var(--main);
    color: var(--base);
  }
}
.top-calendar {
  position: relative;
}
.top-calendar::before {
  content: "";
  max-width: clamp(11.4375rem, -0.7875rem + 52.16vw, 31.8125rem);
  width: 100%;
  aspect-ratio: 509/568;
  position: absolute;
  top: 51px;
  left: -8px;
  z-index: -1;
  background: url(../images/top-calendar-deco-1.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-calendar-deco-1.webp) 1x, url(../images/top-calendar-deco-1@2x.webp) 2x);
  background-image: image-set(url(../images/top-calendar-deco-1.webp) 1x, url(../images/top-calendar-deco-1@2x.webp) 2x);
}
@media (max-width: 768px) {
  .top-calendar::before {
    top: inherit;
    bottom: -44px;
    left: 0;
  }
}
.top-calendar_pos {
  margin-top: clamp(2.5rem, 1.366889313rem + 4.834605598vw, 3.6875rem);
}
.top-calendar__inner {
  max-width: 1180px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-calendar__inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-calendar__title::after {
  width: 120px;
}
.top-calendar__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
  margin-top: clamp(1.1875rem, -0.0648854962rem + 5.3435114504vw, 2.5rem);
}
@media (max-width: 768px) {
  .top-calendar__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 20px;
  }
}
.top-calendar__item {
  max-width: 560px;
  width: 100%;
}
.top-calendar__iframe {
  height: 400px;
}
@media (max-width: 768px) {
  .top-calendar__iframe {
    aspect-ratio: 335/239;
    height: 100%;
  }
}

.top-concept__img img {
  border-radius: 20px;
}
.top-concept__body {
  max-width: 1129px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-concept__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    row-gap: 20px;
  }
}
.top-concept__subtitle {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(1.375rem, -2.0819315545rem + 7.192575406vw, 3.3125rem);
     -moz-column-gap: clamp(1.375rem, -2.0819315545rem + 7.192575406vw, 3.3125rem);
          column-gap: clamp(1.375rem, -2.0819315545rem + 7.192575406vw, 3.3125rem);
  color: var(--main);
  font-size: clamp(1.5rem, 0.6078886311rem + 1.8561484919vw, 2rem);
  font-weight: bold;
  line-height: 1;
}
@media (max-width: 768px) {
  .top-concept__subtitle {
    font-size: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
    -webkit-column-gap: clamp(0.875rem, -0.0791984733rem + 4.0712468193vw, 1.875rem);
       -moz-column-gap: clamp(0.875rem, -0.0791984733rem + 4.0712468193vw, 1.875rem);
            column-gap: clamp(0.875rem, -0.0791984733rem + 4.0712468193vw, 1.875rem);
  }
}
.top-concept__subtitle::after {
  content: "";
  width: 2px;
  height: clamp(1.25rem, -0.5391221374rem + 7.6335877863vw, 3.125rem);
  background-color: var(--main);
  -webkit-transform: rotate(30deg);
      -ms-transform: rotate(30deg);
          transform: rotate(30deg);
}
.top-concept__text {
  max-width: clamp(21.875rem, -8.6798143852rem + 63.5730858469vw, 39rem);
}
@media (max-width: 768px) {
  .top-concept__text {
    max-width: 100%;
  }
}

.top-service {
  overflow: hidden;
}
.top-service__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-service__inner {
    padding: 0 30px;
  }
}
.top-service__text1 {
  text-align: center;
}
.top-service__main {
  position: relative;
}
.top-service__swiper {
  max-width: clamp(41.25rem, -3.1594634873rem + 92.3994038748vw, 80rem);
  overflow: visible;
}
@media (max-width: 768px) {
  .top-service__swiper {
    max-width: 100%;
  }
}
.top-service__slide {
  height: auto;
  background-color: var(--base);
  border: 1px solid var(--main);
  border-radius: 30px;
  -webkit-box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
          box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
  padding: clamp(1.25rem, -1.1354961832rem + 10.1781170483vw, 3.75rem) 20px;
}
.top-service__slide-inner {
  max-width: 1180px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px 15px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-service__slide-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.top-service__box {
  max-width: 560px;
  width: 100%;
}
.top-service__box-title {
  position: relative;
  color: var(--main);
  font-size: clamp(1.5rem, 0.747553816rem + 1.5655577299vw, 2rem);
  font-weight: bold;
  line-height: 1;
  padding-bottom: 20px;
}
@media (max-width: 768px) {
  .top-service__box-title {
    font-size: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-service__box-title::after {
  content: "";
  width: 100px;
  height: 2px;
  background-color: var(--main);
  position: absolute;
  bottom: 0;
  left: 0;
}
.top-service__box-text {
  margin-top: 20px;
}
.top-service__link {
  display: grid;
  place-items: center;
  width: clamp(2.5rem, 1.9036259542rem + 2.5445292621vw, 3.125rem);
  aspect-ratio: 1/1;
  background-color: var(--main);
  border-radius: 50%;
  margin-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  margin-left: auto;
}
.top-service__link::after {
  content: "";
  width: 13px;
  aspect-ratio: 13/24;
  background: url(../images/icon-link-arrow.svg) no-repeat center center/cover;
}
.top-service__control {
  max-width: 480px;
  position: relative;
  margin-top: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  margin-inline: auto;
}
.top-service__pagination {
  position: static;
}
.top-service__pagination .swiper-pagination-bullet {
  width: clamp(0.625rem, 0.2671755725rem + 1.5267175573vw, 1rem);
  height: clamp(0.625rem, 0.2671755725rem + 1.5267175573vw, 1rem);
  opacity: 1;
  background-color: #d9d9d9;
  margin: 5px clamp(0.3125rem, -0.2838740458rem + 2.5445292621vw, 0.9375rem) 0 !important;
}
.top-service__pagination .swiper-pagination-bullet-active {
  background-color: var(--main);
}
.top-service__prev, .top-service__next {
  width: 17px;
  height: inherit;
  aspect-ratio: 17/30;
  top: 85%;
}
.top-service__prev::after, .top-service__next::after {
  content: "";
  width: 100%;
  aspect-ratio: 17/30;
  background-image: url(../images/icon-swiper-btn.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin: auto;
}
.top-service__prev {
  left: 0;
}
.top-service__prev::after {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.top-service__next {
  right: 0;
}
.top-service__img {
  max-width: 560px;
  width: 100%;
}
.top-service__img img {
  border-radius: 20px;
}

@media (hover: hover) and (pointer: fine) {
  .top-service__link {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .top-service__link:hover, .top-service__link:focus {
    background-color: var(--accent);
  }
}
.top-cmt__inner {
  max-width: 1160px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-cmt__inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-cmt__body {
  position: relative;
  padding-top: calc(clamp(-11rem, -20.7961783439rem + 20.3821656051vw, -5rem) * -1);
}
@media (max-width: 768px) {
  .top-cmt__body {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: clamp(0.625rem, -0.5677480916rem + 5.0890585242vw, 1.875rem);
    padding-top: 0;
  }
}
.top-cmt__box {
  max-width: clamp(30.5rem, 14.9893842887rem + 32.2717622081vw, 40rem);
  width: 100%;
  background-color: var(--base2);
  border-radius: 20px;
  padding: 40px 20px;
}
@media (max-width: 768px) {
  .top-cmt__box {
    max-width: 560px;
    padding: 40px 40px;
  }
}
.top-cmt__box-inner {
  max-width: 480px;
  margin-inline: auto;
}
.top-cmt__box-title {
  position: relative;
  color: var(--main);
  font-size: clamp(1.5rem, 0.6836518047rem + 1.6985138004vw, 2rem);
  font-weight: bold;
  line-height: 1.6;
}
@media (max-width: 768px) {
  .top-cmt__box-title {
    font-size: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-cmt__text {
  margin-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
}
.top-cmt__more {
  max-width: clamp(8.9375rem, 6.4923664122rem + 10.4325699746vw, 11.5rem);
  height: clamp(2.375rem, 1.7786259542rem + 2.5445292621vw, 3rem);
  display: grid;
  place-items: center;
  background-color: var(--base);
  color: var(--main);
  font-size: clamp(1rem, 0.7614503817rem + 1.0178117048vw, 1.25rem);
  font-weight: bold;
  border: 2px solid var(--main);
  border-radius: 10px;
  margin-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
}
.top-cmt__l {
  font-size: clamp(1.75rem, 0.9336518047rem + 1.6985138004vw, 2.25rem);
}
@media (max-width: 768px) {
  .top-cmt__l {
    font-size: clamp(1.5rem, 0.9036259542rem + 2.5445292621vw, 2.125rem);
  }
}
.top-cmt__img {
  max-width: clamp(22.5rem, 2.0912951168rem + 42.4628450106vw, 35rem);
  width: 100%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}
@media (max-width: 768px) {
  .top-cmt__img {
    max-width: 560px;
    position: static;
  }
}
.top-cmt__img img {
  border-radius: 20px;
}

.top-link {
  background-color: var(--base2);
}
.top-link__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 60px 30px 60px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px 15px;
}
@media (max-width: 768px) {
  .top-link__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    padding: clamp(2.5rem, 1.3072519084rem + 5.0890585242vw, 3.75rem) clamp(0.9375rem, 0.0429389313rem + 3.8167938931vw, 1.875rem);
  }
}
.top-link__btn {
  max-width: clamp(20.9375rem, 12.2900763359rem + 36.8956743003vw, 30rem);
  width: 100%;
  height: clamp(3.6875rem, 1.8983778626rem + 7.6335877863vw, 5.5625rem);
  display: grid;
  place-items: center;
  background-color: var(--base);
  color: var(--accent);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1rem, 0.5229007634rem + 2.0356234097vw, 1.5rem);
  font-weight: bold;
  border: 2px solid var(--accent);
  border-radius: 10px;
}

@media (hover: hover) and (pointer: fine) {
  .top-link__btn {
    -webkit-transition: background-color 0.4s, color 0.4s;
    transition: background-color 0.4s, color 0.4s;
  }
  .top-link__btn:hover, .top-link__btn:focus {
    background-color: var(--accent);
    color: var(--base);
  }
}
.top-gallery {
  padding-bottom: clamp(2.5rem, -0.5rem + 12.8vw, 7.5rem);
}
.top-gallery__slider {
  overflow: hidden;
}
.top-gallery__wrapper {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.top-gallery__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-animation: infinity-scroll 60s linear infinite both;
          animation: infinity-scroll 60s linear infinite both;
}
.top-gallery__slide {
  max-width: clamp(10rem, 2.5rem + 32vw, 17.5rem);
  margin-right: clamp(0.625rem, -1.1641221374rem + 7.6335877863vw, 2.5rem);
}
.top-gallery__slide img {
  border-radius: 20px;
}

/*###################################################################
  about（page）
###################################################################*/
.about1__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
}
.about1__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) 15px;
}
@media (max-width: 768px) {
  .about1__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.about1__item:not(:last-of-type) {
  background-image: -webkit-repeating-linear-gradient(left, var(--main), var(--main) 2px, transparent 2px, transparent 4px);
  background-image: repeating-linear-gradient(90deg, var(--main), var(--main) 2px, transparent 2px, transparent 4px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 2px;
  padding-bottom: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
}
.about1__item_r {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .about1__item_r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.about1__mt40 {
  margin-top: clamp(1.25rem, -0.4334500876rem + 3.5026269702vw, 2.5rem);
}
@media (max-width: 768px) {
  .about1__mt40 {
    margin-top: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  }
}
.about1__box {
  max-width: 600px;
  width: 100%;
}
.about1__number {
  color: var(--main);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3rem, 1.6532399299rem + 2.8021015762vw, 4rem);
  font-weight: bold;
  line-height: 1;
}
@media (max-width: 768px) {
  .about1__number {
    font-size: clamp(2.5rem, 1.4265267176rem + 4.5801526718vw, 3.625rem);
  }
}
.about1__box-title {
  color: var(--main);
  font-size: clamp(1.5rem, 0.826619965rem + 1.4010507881vw, 2rem);
  font-weight: bold;
  line-height: 1;
}
@media (max-width: 768px) {
  .about1__box-title {
    font-size: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.about1__img {
  max-width: 600px;
  width: 100%;
}
.about1__img img {
  border-radius: 30px;
}

.about2__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(3.125rem, 2.2304389313rem + 3.8167938931vw, 4.0625rem);
}
.about2__item {
  position: relative;
  background-color: var(--base2);
  border-radius: 20px;
  padding: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem) 20px;
}
.about2__item:not(:last-of-type)::after {
  content: "";
  width: 80px;
  aspect-ratio: 80/25;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
  position: absolute;
  bottom: calc(clamp(2.4375rem, 2.1393129771rem + 1.272264631vw, 2.75rem) * -1);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: var(--main);
}
.about2__item-inner {
  max-width: 1140px;
  display: grid;
  grid-template-columns: clamp(11.125rem, -0.8274956217rem + 24.8686514886vw, 20rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .about2__item-inner {
    grid-template-columns: 1fr;
  }
}
.about2__title-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  color: var(--main);
  line-height: 1;
}
.about2__number {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3rem, 1.6532399299rem + 2.8021015762vw, 4rem);
  font-weight: bold;
}
@media (max-width: 768px) {
  .about2__number {
    font-size: clamp(2.5rem, 1.4265267176rem + 4.5801526718vw, 3.625rem);
  }
}
.about2__number::before, .about2__number::after {
  content: "";
  width: 40px;
  height: 2px;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  position: relative;
  background-color: var(--main);
}
.about2__item-title {
  font-size: clamp(1.5rem, 0.826619965rem + 1.4010507881vw, 2rem);
  font-weight: bold;
  line-height: 1;
}
@media (max-width: 768px) {
  .about2__item-title {
    font-size: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}

/*###################################################################
  menu（page）
###################################################################*/
.menu-c__text {
  text-align: center;
}
@media (max-width: 768px) {
  .menu-c__text {
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
    text-align: left;
    margin-inline: auto;
  }
}

.menu-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.25rem, 0.4082749562rem + 1.7513134851vw, 1.875rem) clamp(0.75rem, -0.4284150613rem + 2.4518388792vw, 1.625rem);
}
@media (max-width: 768px) {
  .menu-gallery {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(0.9375rem, 0.6393129771rem + 1.272264631vw, 1.25rem);
  }
}
.menu-gallery_rg20 {
  gap: 20px clamp(0.75rem, -0.4284150613rem + 2.4518388792vw, 1.625rem);
}
@media (max-width: 768px) {
  .menu-gallery_rg20 {
    gap: clamp(0.9375rem, 0.6393129771rem + 1.272264631vw, 1.25rem);
  }
}
.menu-gallery__link {
  display: block;
  overflow: hidden;
}
.menu-gallery__link img {
  border-radius: clamp(0.625rem, -0.2167250438rem + 1.7513134851vw, 1.25rem);
}

@media (hover: hover) and (pointer: fine) {
  .menu-gallery__link img {
    -webkit-transition: -webkit-transform 0.4s;
    transition: -webkit-transform 0.4s;
    transition: transform 0.4s;
    transition: transform 0.4s, -webkit-transform 0.4s;
  }
  .menu-gallery__link:hover img, .menu-gallery__link:focus img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.menu-fee {
  overflow-x: auto;
}
.menu-fee__table {
  min-width: 534px;
  width: 100%;
  font-size: clamp(0.8125rem, 0.53125rem + 0.75vw, 1rem);
}
.menu-fee__th {
  height: clamp(2.75rem, 2rem + 2vw, 3.25rem);
  background-color: var(--main2);
  color: var(--base);
  font-weight: 400;
  text-align: center;
  vertical-align: middle;
  border: 1px solid #e6d3bb;
}
.menu-fee__th_320 {
  width: 25%;
}
.menu-fee__th_240 {
  width: 18.75%;
}
.menu-fee__th_160 {
  width: 12.5%;
}
.menu-fee__td {
  background-color: var(--base);
  text-align: center;
  vertical-align: middle;
  border: 1px solid #e6d3bb;
}

.menu7__text {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  text-indent: hanging 1em;
  margin-inline: auto;
}

/*###################################################################
  price（page）
###################################################################*/
.fee1__formula {
  max-width: 1072px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.3125rem, 0.125rem + 0.8vw, 0.625rem);
     -moz-column-gap: clamp(0.3125rem, 0.125rem + 0.8vw, 0.625rem);
          column-gap: clamp(0.3125rem, 0.125rem + 0.8vw, 0.625rem);
  font-size: clamp(0.9375rem, 0.6rem + 1.44vw, 1.5rem);
  font-weight: bold;
  margin-inline: auto;
}
.fee1__formula-addend {
  max-width: clamp(5.25rem, -3.6rem + 37.76vw, 20rem);
  width: 100%;
  height: clamp(5rem, 3.2rem + 7.68vw, 8rem);
  display: grid;
  place-items: center;
  background-color: var(--main2);
  color: var(--base);
  text-align: center;
}
.fee1__dl {
  display: grid;
  grid-template-columns: clamp(15.3125rem, 5.7189119171rem + 40.932642487vw, 40rem) 1fr;
  font-size: clamp(0.9375rem, 0.9132124352rem + 0.103626943vw, 1rem);
  line-height: 2;
}
.fee1__dt {
  display: grid;
  place-items: center;
  background-color: var(--main2);
  color: var(--base);
  font-weight: 400;
  text-align: center;
  white-space: pre-line;
  border-bottom: 1px solid #e6d3bb;
  border-right: 1px solid #e6d3bb;
  border-left: 1px solid #e6d3bb;
  padding: 9.5px 8px;
}
.fee1__dd {
  display: grid;
  place-items: center;
  background-color: var(--base);
  white-space: pre-line;
  border-bottom: 1px solid #e6d3bb;
  border-right: 1px solid #e6d3bb;
}
.fee1__dd:first-of-type {
  border-top: 1px solid #e6d3bb;
}

.fee2__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 40px 20px;
}
@media (max-width: 1100px) {
  .fee2__items {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: clamp(1.25rem, -2.9112554113rem + 8.658008658vw, 2.5rem);
  }
}
@media (max-width: 768px) {
  .fee2__items {
    gap: 30px;
  }
}
.fee2__item {
  max-width: clamp(20.875rem, 7.1428571429rem + 28.5714285714vw, 25rem);
  width: 100%;
  background-color: var(--base);
  border-radius: 30px;
  border: 1px solid var(--main);
  padding: clamp(1.5625rem, 0.6679389313rem + 3.8167938931vw, 2.5rem) 15px;
}
@media (max-width: 768px) {
  .fee2__item {
    max-width: 400px;
  }
}
.fee2__item-inner {
  max-width: 320px;
  margin-inline: auto;
}
.fee2__item-title {
  position: relative;
  color: var(--main);
  font-size: clamp(1.625rem, 1.2671755725rem + 1.5267175573vw, 2rem);
  font-weight: bold;
  line-height: 1;
  margin-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  padding-bottom: clamp(1rem, 0.7614503817rem + 1.0178117048vw, 1.25rem);
}
.fee2__item-title::after {
  content: "";
  width: 100px;
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: var(--main);
}
.fee2__item-text {
  margin-top: 20px;
}

.fee2-2 {
  background-color: var(--base2);
}
.fee2-2__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 68px 30px 80px;
}
@media (max-width: 1280px) {
  .fee2-2__inner {
    padding: clamp(2.1875rem, 0.2194656489rem + 8.3969465649vw, 4.25rem) clamp(0.9375rem, 0.0429389313rem + 3.8167938931vw, 1.875rem) clamp(2.5rem, 0.1145038168rem + 10.1781170483vw, 5rem);
  }
}
.fee2-2__title {
  color: var(--main);
  font-size: clamp(1.1875rem, 0.4122137405rem + 3.3078880407vw, 2rem);
  font-weight: bold;
  line-height: 1.75;
  text-align: center;
}
.fee2-2__text {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  text-indent: hanging 1em;
  margin-inline: auto;
  margin-top: 18px;
}
.fee2-2__links {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) 15px;
}
@media (max-width: 1000px) {
  .fee2-2__links {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.fee2-2__link {
  max-width: clamp(18.75rem, 8.0152671756rem + 45.8015267176vw, 30rem);
  width: 100%;
  height: clamp(4.375rem, 3.241889313rem + 4.834605598vw, 5.5625rem);
  display: grid;
  place-items: center;
  background-color: var(--base);
  color: var(--main2);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
  font-weight: bold;
  border-radius: 10px;
  border: 2px solid var(--main2);
}

.fee2-3__inner {
  max-width: 1100px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .fee2-3__inner {
    max-width: clamp(19.375rem, 9.2366412214rem + 43.2569974555vw, 30rem);
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.fee2-3__title {
  color: var(--main);
  font-size: clamp(1.5rem, 1.0229007634rem + 2.0356234097vw, 2rem);
  font-weight: bold;
  text-align: center;
  line-height: 1;
}

/*###################################################################
  information（page）
###################################################################*/
.info1__col {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) 15px;
}
@media (max-width: 768px) {
  .info1__col {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.info1__box {
  max-width: 640px;
  width: 100%;
}
.info1__name {
  color: var(--main);
  font-size: clamp(2rem, 1.5229007634rem + 2.0356234097vw, 2.5rem);
  font-weight: bold;
  line-height: 1.2;
  text-align: right;
}
.info1__job {
  font-size: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
}
.info1__space {
  font-size: clamp(0.875rem, 0.7557251908rem + 0.5089058524vw, 1rem);
}
.info1__img {
  max-width: 600px;
  width: 100%;
}

.info2__inner {
  max-width: 618px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .info2__inner {
    max-width: 420px;
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.info2__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(3.125rem, 1.3358778626rem + 7.6335877863vw, 5rem);
  position: relative;
  padding-bottom: 40px;
}
.info2__items::after {
  content: "";
  width: 3px;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: clamp(0.875rem, 0.5768129771rem + 1.272264631vw, 1.1875rem);
  background-color: var(--main);
}
@media (max-width: 768px) {
  .info2__items::after {
    height: 97%;
  }
}
.info2__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 12px;
     -moz-column-gap: 12px;
          column-gap: 12px;
}
.info2__dot {
  min-width: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem);
  aspect-ratio: 1/1;
  background-color: var(--main);
  border-radius: 50%;
}
.info2__box {
  max-width: 538px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 36px;
     -moz-column-gap: 36px;
          column-gap: 36px;
  font-size: clamp(1rem, 0.8807251908rem + 0.5089058524vw, 1.125rem);
  font-weight: bold;
  line-height: 1;
}
@media (max-width: 768px) {
  .info2__box {
    max-width: 342px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 15px;
  }
}

.info3__dl {
  display: grid;
  grid-template-columns: 1fr clamp(15.625rem, 6.1528497409rem + 40.414507772vw, 40rem);
  font-size: clamp(0.9375rem, 0.8778625954rem + 0.2544529262vw, 1rem);
  line-height: 2;
}
.info3__dt {
  display: grid;
  place-items: center;
  background-color: var(--main2);
  color: var(--base2);
  font-weight: 400;
  border-bottom: 1px solid #e6d3bb;
  border-right: 1px solid #e6d3bb;
  border-left: 1px solid #e6d3bb;
}
.info3__dd {
  display: grid;
  place-items: center;
  background-color: var(--base);
  text-align: center;
  border-bottom: 1px solid #e6d3bb;
  border-right: 1px solid #e6d3bb;
  padding: 9.5px 5px;
}
.info3__dd:first-of-type {
  border-top: 1px solid #e6d3bb;
}
.info3__gmap {
  width: 100%;
  height: 560px;
}

.info4__inner {
  max-width: 1120px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .info4__inner {
    padding: 0 clamp(0.9375rem, 0.0429389313rem + 3.8167938931vw, 1.875rem);
  }
}
.info4__title {
  font-size: clamp(2rem, 0.8rem + 5.12vw, 4rem);
}
.info4__body {
  background-color: var(--base2);
  border-radius: clamp(0.9375rem, 0.0429389313rem + 3.8167938931vw, 1.875rem);
  padding: clamp(3.125rem, 1.9322519084rem + 5.0890585242vw, 4.375rem) clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem) 31px;
}
.info4__body-inner {
  max-width: 960px;
  margin-inline: auto;
}

.form__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(1.25rem, 0.325620229rem + 3.9440203562vw, 2.21875rem);
}
.form__paragraph {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(0.9375rem, 0.013120229rem + 3.9440203562vw, 1.90625rem);
  border-bottom: 1px solid var(--main2);
  padding-bottom: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
}
.form__address {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 20px;
}
.form__subparagraph_region {
  max-width: 320px;
  position: relative;
}
.form__subparagraph_region::after {
  content: "";
  width: 12px;
  aspect-ratio: 12/7;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../images/icon-select-arrow.svg) no-repeat center center/contain;
  pointer-events: none;
}
.form__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
}
.form__required {
  width: 52px;
  height: 39px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
}
.form__input {
  width: 100%;
  height: 50px;
  background-color: var(--base);
  border: 2px solid #e8e8e8;
  border-radius: 10px;
  padding: 10px 10px;
}
.form__input::-webkit-input-placeholder {
  color: #cacaca;
}
.form__input::-moz-placeholder {
  color: #cacaca;
}
.form__input:-ms-input-placeholder {
  color: #cacaca;
}
.form__input::-ms-input-placeholder {
  color: #cacaca;
}
.form__input::placeholder {
  color: #cacaca;
}
.form__input_s {
  max-width: 320px;
}
.form__input_message {
  min-height: 360px;
  resize: vertical;
}
.form__select {
  max-width: 320px;
  width: 100%;
  height: 50px;
  background-color: var(--base);
  border: 2px solid #e8e8e8;
  border-radius: 10px;
  cursor: pointer;
  padding: 10px 10px;
}
.form__select.is-placeholder {
  color: #cacaca;
}
.form__select:not(.is-placeholder) {
  color: var(--text);
}
.form__select option {
  color: var(--text);
  background-color: #fff;
}
.form__select option:first-child {
  color: #cacaca;
}
.form__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 5px;
  margin-top: 50px;
}
.form__action-button {
  width: clamp(16.25rem, 12.6717557252rem + 15.2671755725vw, 20rem);
  height: clamp(3.25rem, 2.2361641221rem + 4.3256997455vw, 4.3125rem);
  background-color: var(--main2);
  color: var(--base);
  font-size: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  border-radius: 10px;
}
.form[data-status=sent] .form__button-wrapper {
  display: none;
}
.form[data-status=sent] .form__select.is-placeholder {
  color: #cacaca;
}
.form[data-status=sent] .form__select option:first-child {
  color: #cacaca;
}

/*###################################################################
  news（page）
###################################################################*/
.news-list_pos {
  margin-top: clamp(3.125rem, 2.3298816568rem + 2.9585798817vw, 3.75rem);
}
.news-list__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-bottom: 150px;
}
@media (max-width: 768px) {
  .news-list__inner {
    padding: 0 clamp(0.9375rem, -0.625rem + 5.2083333333vw, 1.875rem) 150px;
  }
}
@media (max-width: 600px) {
  .news-list__inner {
    max-width: 400px;
  }
}
.news-list__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(1.875rem, -0.3571428571rem + 5.9523809524vw, 2.5rem);
  margin-top: 100px;
}
@media (max-width: 600px) {
  .news-list__items {
    row-gap: 50px;
    margin-top: 50px;
  }
}
.news-list__post-link {
  display: grid;
  grid-template-columns: clamp(11.25rem, -4.375rem + 41.6666666667vw, 15.625rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
     -moz-column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
          column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
  background-color: var(--base);
  border: 1px solid #75778d;
}
@media (max-width: 600px) {
  .news-list__post-link {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
.news-list__thumbnail {
  max-width: 300px;
  height: 100%;
  overflow: hidden;
}
@media (max-width: 600px) {
  .news-list__thumbnail {
    max-width: 100%;
  }
}
.news-list__thumbnail img {
  height: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}
.news-list__text-box {
  padding-top: 15px;
  padding-bottom: 15px;
}
@media (max-width: 600px) {
  .news-list__text-box {
    padding-top: 0;
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 20px;
  }
}
.news-list__date {
  display: block;
  color: var(--main);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.75;
}
.news-list__post-title {
  font-size: clamp(1.125rem, 0.6785714286rem + 1.1904761905vw, 1.25rem);
  line-height: 1.75;
  text-align: start;
  word-break: break-all;
  padding-right: 15px;
}
@media (max-width: 600px) {
  .news-list__post-title {
    padding-right: 0;
  }
}
.news-list__no-post {
  height: 200px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-size: 1.25rem;
  font-weight: 500;
}
.news-list__pagination {
  font-size: 1.25rem;
  margin-top: 150px;
}
@media (max-width: 768px) {
  .news-list__pagination {
    margin-top: 80px;
  }
}
.news-list__pagination ul.page-numbers {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(1.125rem, -0.875rem + 8vw, 2.125rem);
  margin-inline: auto;
}
.news-list__pagination ul.page-numbers li {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
}
.news-list__pagination ul.page-numbers li .page-numbers {
  --spacing: 0;
}
.news-list__pagination .page-numbers.current {
  color: var(--main);
}

@media (hover: hover) and (pointer: fine) {
  .news-list__post-link {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .news-list__post-link:hover .news-list__thumbnail img, .news-list__post-link:focus .news-list__thumbnail img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
  .news-list__post-link:hover .news-list__post-title, .news-list__post-link:focus .news-list__post-title {
    color: var(--main);
    text-decoration: underline;
  }
  .news-list__thumbnail img {
    -webkit-transition: -webkit-transform ease 0.4s;
    transition: -webkit-transform ease 0.4s;
    transition: transform ease 0.4s;
    transition: transform ease 0.4s, -webkit-transform ease 0.4s;
  }
  .news-list__post-title {
    -webkit-transition: color ease 0.4s;
    transition: color ease 0.4s;
    -webkit-text-decoration-color: var(--main);
            text-decoration-color: var(--main);
  }
  .news-list__pagination a {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .news-list__pagination a:hover, .news-list__pagination a:focus {
    opacity: 0.7;
  }
}
.news-post_pos {
  margin-top: clamp(3.125rem, 2.3298816568rem + 2.9585798817vw, 3.75rem);
}
.news-post__inner {
  max-width: 840px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-bottom: 150px;
}
@media (max-width: 768px) {
  .news-post__inner {
    padding: 0 clamp(0.9375rem, -0.625rem + 5.2083333333vw, 1.875rem) 150px;
  }
}
.news-post__bg {
  background-color: var(--base);
  border: 1px solid #75778d;
  padding: 50px 20px 100px;
}
@media (max-width: 768px) {
  .news-post__bg {
    padding: 50px clamp(0.9375rem, -0.625rem + 5.2083333333vw, 1.875rem) 100px;
  }
}
.news-post__date {
  display: block;
  color: var(--main);
  font-size: 1.25rem;
  font-weight: 500;
}
@media (max-width: 768px) {
  .news-post__date {
    font-size: 1.125rem;
  }
}
.news-post__title {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.75;
  word-break: break-all;
  margin-top: 10px;
}
@media (max-width: 768px) {
  .news-post__title {
    font-size: 1.375rem;
    margin-top: 10px;
  }
}
.news-post__thumbnail {
  margin-top: 40px;
}
.news-post__editor {
  margin-top: 40px;
}

.news-post-pager {
  background-color: var(--base);
  border: 1px solid #75778d;
}
.news-post-pager_pos {
  max-width: 840px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .news-post-pager_pos {
    margin-top: 60px;
  }
}
.news-post-pager__nav {
  height: 70px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  color: var(--main);
  font-size: clamp(1rem, 0.1071428571rem + 3.8095238095vw, 1.25rem);
  font-weight: 500;
  padding-right: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem);
  padding-left: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem);
}
.news-post-pager__link {
  --spacing: 0;
}
.news-post-pager__blank {
  min-width: 106px;
  min-width: clamp(5.4375rem, 0.5267857143rem + 20.9523809524vw, 6.8125rem);
}

@media (hover: hover) and (pointer: fine) {
  .news-post-pager__link {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .news-post-pager__link:hover, .news-post-pager__link:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  page-404（page）
###################################################################*/
.page-404_pos {
  margin-top: clamp(3.125rem, 2.7083333333rem + 1.6666666667vw, 3.75rem);
}
.page-404__inner {
  max-width: 800px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-bottom: 130px;
}
@media (max-width: 768px) {
  .page-404__inner {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) 130px;
  }
}
.page-404__title {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.75;
}
.page-404__text {
  line-height: 2;
  white-space: pre-line;
  margin-top: 40px;
}
.page-404__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.page-404__button {
  width: 175px;
  height: 48px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  border: 1px solid var(--text);
  margin: 54px auto 0;
}

@media (hover: hover) and (pointer: fine) {
  .page-404__button {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .page-404__button:hover, .page-404__button:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  js-（js制御用）
###################################################################*/