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

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

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

body {
  color: var(--text);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 0.9375rem;
  line-height: 2;
  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 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
@keyframes mvTitle {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
/*----------------------------------
  zoom
----------------------------------*/
@-webkit-keyframes zoom {
  0% {
    -webkit-transform: scale(1.15);
            transform: scale(1.15);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes zoom {
  0% {
    -webkit-transform: scale(1.15);
            transform: scale(1.15);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
/*----------------------------------
  無限ループスライダー
----------------------------------*/
@-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%;
  container-type: inline-size;
  position: absolute;
  top: 0;
  z-index: 10;
}
.header_sticky {
  position: fixed;
  background-color: rgba(255, 255, 255, 0.9);
}
.header__title {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
  clip-path: inset(0px 0px 99.9% 99.9%);
  overflow: hidden;
  height: 1px;
  width: 1px;
  padding: 0;
  border: 0;
}
.header__inner {
  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;
  padding: 10px 2.7777777778cqw;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
@media (max-width: 768px) {
  .header__inner {
    padding-right: 20px;
    padding-left: 30px;
  }
}
.header__logo {
  max-width: clamp(18rem, 11.7683494784rem + 12.9657228018vw, 23.4375rem);
  width: 100%;
  background-color: var(--base);
}
@media (max-width: 768px) {
  .header__logo {
    max-width: 218px;
    background-color: transparent;
    margin-top: 5px;
  }
}
.header__logo-link {
  display: block;
  padding: 10px;
}
@media (max-width: 768px) {
  .header__logo-link {
    padding: 0;
  }
}
.header__menu {
  max-width: 742px;
  width: 100%;
  height: 35px;
  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: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
  line-height: 1;
}
@media (max-width: 1200px) {
  .header__menu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
    row-gap: 5px;
  }
}
@media (max-width: 768px) {
  .header__menu {
    display: none;
  }
}
.header__access {
  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: "Zen Old Mincho", serif;
  font-size: 15px;
}
.header__access::before {
  content: "";
  min-width: 35px;
  aspect-ratio: 1/1;
  background: url(../images/icon-train.svg) no-repeat center center/contain;
}
.header__group {
  max-width: 331px;
  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: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
}
.header__tel {
  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: "Zen Old Mincho", serif;
  font-size: 15px;
}
.header__tel::before {
  content: "";
  min-width: 35px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel.svg) no-repeat center center/contain;
}
.header__insta {
  max-width: 35px;
  width: 100%;
  aspect-ratio: 1/1;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-insta.svg);
          mask-image: url(../images/icon-insta.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.header__youtube {
  max-width: 112px;
  width: 100%;
}

@media (max-width: 768px) {
  .header-nav {
    display: none;
  }
}

@media (hover: hover) and (pointer: fine) {
  .header-nav__link {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .header-nav__link:hover, .header-nav__link:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  g-nav（module）
###################################################################*/
.g-nav {
  width: 100%;
  position: relative;
  z-index: 10;
}
@media (max-width: 768px) {
  .g-nav {
    display: none;
  }
}
.g-nav.is-sticky {
  width: 100%;
  height: 70px;
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.9);
}
.g-nav.is-sticky .g-nav__inner {
  max-width: 1139px;
  width: 100%;
  height: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  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: 30px;
  padding: 10px clamp(0.625rem, -1.972972973rem + 5.4054054054vw, 1.875rem);
  margin-inline: auto;
}
.g-nav.is-sticky .g-nav__items {
  width: clamp(25rem, 0.0594594595rem + 51.8918918919vw, 37rem);
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 0;
     -moz-column-gap: 0;
          column-gap: 0;
}
.g-nav.is-sticky .g-nav__link,
.g-nav.is-sticky .g-nav__summary-text {
  gap: 3px;
}
.g-nav.is-sticky .g-nav__jp {
  font-size: clamp(0.8125rem, 0.4228040541rem + 0.8108108108vw, 1rem);
}
.g-nav.is-sticky .g-nav__en {
  font-size: clamp(0.6875rem, 0.2978040541rem + 0.8108108108vw, 0.875rem);
}
.g-nav.is-sticky .g-nav__contact {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(0.9375rem, 0.2880067568rem + 1.3513513514vw, 1.25rem);
}
.g-nav.is-sticky .g-nav__tel {
  font-size: clamp(0.8125rem, 0.5527027027rem + 0.5405405405vw, 0.9375rem);
  -webkit-column-gap: clamp(0.5rem, 0.2402027027rem + 0.5405405405vw, 0.625rem);
     -moz-column-gap: clamp(0.5rem, 0.2402027027rem + 0.5405405405vw, 0.625rem);
          column-gap: clamp(0.5rem, 0.2402027027rem + 0.5405405405vw, 0.625rem);
}
.g-nav.is-sticky .g-nav__tel::before {
  min-width: clamp(1.875rem, 1.2255067568rem + 1.3513513514vw, 2.1875rem);
}
.g-nav.is-sticky .g-nav__insta {
  width: clamp(1.875rem, 1.2255067568rem + 1.3513513514vw, 2.1875rem);
}
.g-nav.is-sticky .g-nav__youtube {
  width: clamp(5.9375rem, 3.729222973rem + 4.5945945946vw, 7rem);
  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;
}
.g-nav.is-sticky .g-nav__submenu {
  padding: clamp(0.9375rem, 0.2880067568rem + 1.3513513514vw, 1.25rem);
}
.g-nav.is-sticky .g-nav__subitems {
  gap: clamp(0.9375rem, 0.2880067568rem + 1.3513513514vw, 1.25rem);
}
.g-nav.is-sticky .g-nav__sublink {
  font-size: clamp(0.8125rem, 0.4228040541rem + 0.8108108108vw, 1rem);
}
.g-nav__inner {
  max-width: 1240px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 32px 30px 20px;
}
.g-nav__items {
  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(1.875rem, -3.1389716841rem + 10.4321907601vw, 6.25rem);
     -moz-column-gap: clamp(1.875rem, -3.1389716841rem + 10.4321907601vw, 6.25rem);
          column-gap: clamp(1.875rem, -3.1389716841rem + 10.4321907601vw, 6.25rem);
}
.g-nav__link {
  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;
  gap: 5px;
  color: var(--text);
  line-height: 1.2;
}
.g-nav__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.125rem;
  white-space: nowrap;
}
.g-nav__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 0.9375rem;
  text-align: center;
  white-space: nowrap;
}
.g-nav__details {
  position: relative;
  color: var(--text);
}
.g-nav__summary {
  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;
  gap: 10px;
  cursor: pointer;
  list-style: none;
}
.g-nav__summary::-webkit-details-marker {
  display: none;
}
.g-nav__summary-text {
  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;
  gap: 5px;
  line-height: 1.2;
}
.g-nav__chevron {
  min-width: 9px;
  aspect-ratio: 9/6;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-menu-arrow.svg);
          mask-image: url(../images/icon-menu-arrow.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-transition: background-color 0.4s, -webkit-transform 0.3s;
  transition: background-color 0.4s, -webkit-transform 0.3s;
  transition: transform 0.3s, background-color 0.4s;
  transition: transform 0.3s, background-color 0.4s, -webkit-transform 0.3s;
}
.g-nav__details[open] .g-nav__chevron {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.g-nav__submenu {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  overflow: hidden;
  background-color: var(--main);
  padding: 20px;
}
.g-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;
  gap: 20px;
  line-height: 1;
}
.g-nav__sublink {
  display: inline-block;
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1rem;
  line-height: 1.2;
  white-space: nowrap;
}
.g-nav__contact {
  display: none;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.g-nav__tel {
  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;
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: 0.9375rem;
  line-height: 1.2;
  white-space: nowrap;
}
.g-nav__tel::before {
  content: "";
  min-width: 35px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel.svg) no-repeat center center/contain;
}
.g-nav__insta {
  width: 35px;
  aspect-ratio: 1/1;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-insta.svg);
          mask-image: url(../images/icon-insta.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
}
.g-nav__youtube {
  width: 112px;
}

@media (hover: hover) and (pointer: fine) {
  .g-nav__link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .g-nav__link:hover, .g-nav__link:focus {
    color: var(--main-d);
  }
  .g-nav__summary {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .g-nav__summary:hover, .g-nav__summary:focus {
    color: var(--main-d);
  }
  .g-nav__summary:hover .g-nav__chevron, .g-nav__summary:focus .g-nav__chevron {
    background-color: var(--main-d);
  }
  .g-nav__sublink {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .g-nav__sublink:hover, .g-nav__sublink:focus {
    color: var(--main-d);
  }
}
/*###################################################################
  footer（module）
###################################################################*/
.footer__copy {
  height: 78px;
  display: grid;
  place-items: center;
  background: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.75rem, 0.5710877863rem + 0.7633587786vw, 0.9375rem);
  font-weight: bold;
}

.footer1 {
  background-color: var(--base2);
}
.footer1_top {
  margin-top: clamp(2.5rem, 0.1145038168rem + 10.1781170483vw, 5rem);
}
.footer1_pos {
  margin-top: 120px;
}
.footer1__inner {
  max-width: 1114px;
  -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;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
}
@media (max-width: 1280px) {
  .footer1__inner {
    padding: clamp(1.25rem, -1.1354961832rem + 10.1781170483vw, 3.75rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
  }
}
@media (max-width: 768px) {
  .footer1__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;
    row-gap: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.footer1__group {
  max-width: 494px;
  width: 100%;
  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;
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  line-height: 1.2;
  margin-top: 11px;
}
@media (max-width: 768px) {
  .footer1__group {
    max-width: clamp(20.9375rem, 11.4551526718rem + 40.4580152672vw, 30.875rem);
  }
}
.footer1__name {
  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: 7px;
  text-align: center;
}
.footer1__name-jp {
  font-size: clamp(1.625rem, 0.9233576642rem + 1.4598540146vw, 2rem);
}
@media (max-width: 768px) {
  .footer1__name-jp {
    font-size: clamp(1.25rem, 0.534351145rem + 3.0534351145vw, 2rem);
  }
}
.footer1__name-en {
  font-size: clamp(1rem, 0.7661192214rem + 0.4866180049vw, 1.125rem);
}
@media (max-width: 768px) {
  .footer1__name-en {
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
  }
}
.footer1__contact {
  width: 100%;
  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: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
  margin-top: clamp(1.25rem, 0.7729007634rem + 2.0356234097vw, 1.75rem);
}
.footer1__tel {
  max-width: 240px;
  width: 100%;
  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-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;
  row-gap: 4px;
  background-color: var(--main);
  color: var(--base);
  padding: 10px;
}
@media (max-width: 768px) {
  .footer1__tel {
    max-width: clamp(10rem, 5.2290076336rem + 20.3562340967vw, 15rem);
    padding: clamp(0.375rem, 0.1364503817rem + 1.0178117048vw, 0.625rem) clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
  }
}
.footer1__tel-label {
  font-size: 12px;
}
@media (max-width: 768px) {
  .footer1__tel-label {
    font-size: clamp(0.6875rem, 0.6278625954rem + 0.2544529262vw, 0.75rem);
  }
}
.footer1__tel-row {
  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: 9px;
     -moz-column-gap: 9px;
          column-gap: 9px;
}
.footer1__tel-icon {
  min-width: 35px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel-2.svg) no-repeat center center/contain;
  -webkit-mask-position: center;
          mask-position: center;
}
@media (max-width: 768px) {
  .footer1__tel-icon {
    min-width: clamp(1.5625rem, 0.9661259542rem + 2.5445292621vw, 2.1875rem);
  }
}
.footer1__tel-num {
  font-size: 18px;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .footer1__tel-num {
    font-size: clamp(1rem, 0.8807251908rem + 0.5089058524vw, 1.125rem);
  }
}
.footer1__insta {
  max-width: 84px;
  width: 100%;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  background-color: var(--main-d);
}
@media (max-width: 768px) {
  .footer1__insta {
    max-width: clamp(3.4375rem, 1.7080152672rem + 7.3791348601vw, 5.25rem);
  }
}
.footer1__insta::after {
  content: "";
  max-width: 35px;
  width: 100%;
  aspect-ratio: 1/1;
  background-color: var(--base);
  -webkit-mask-image: url(../images/icon-insta.svg);
          mask-image: url(../images/icon-insta.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.footer1__youtube {
  max-width: 160px;
  width: 100%;
  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;
  background-color: var(--base);
  padding: 0 16px;
}
@media (max-width: 768px) {
  .footer1__youtube {
    max-width: clamp(6.875rem, 3.893129771rem + 12.7226463104vw, 10rem);
    padding: 0;
  }
}
.footer1__youtube img {
  max-width: 100px;
}
.footer1__address {
  width: 100%;
  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: 15px;
  line-height: 1.6;
  margin-top: clamp(0.6875rem, 0.0911259542rem + 2.5445292621vw, 1.3125rem);
}
@media (max-width: 768px) {
  .footer1__address {
    font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
    line-height: 1.2;
    -webkit-column-gap: clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
       -moz-column-gap: clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
            column-gap: clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
  }
}
.footer1__address-icon {
  min-width: 35px;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  background-color: var(--text);
  border-radius: 50%;
}
@media (max-width: 768px) {
  .footer1__address-icon {
    min-width: clamp(1.5625rem, 0.9661259542rem + 2.5445292621vw, 2.1875rem);
  }
}
.footer1__address-icon::before {
  content: "";
  width: 55%;
  aspect-ratio: 1/1;
  background-color: var(--base);
  -webkit-mask-image: url(../images/icon-map.svg);
          mask-image: url(../images/icon-map.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
}
.footer1__info {
  max-width: 560px;
  width: 100%;
}

@media (hover: hover) and (pointer: fine) {
  .footer1__tel, .footer1__insta, .footer1__youtube {
    -webkit-transition: opacity 0.4s ease;
    transition: opacity 0.4s ease;
  }
  .footer1__tel:hover, .footer1__tel:focus, .footer1__insta:hover, .footer1__insta:focus, .footer1__youtube:hover, .footer1__youtube:focus {
    opacity: 0.7;
  }
}
.footer2 {
  height: 480px;
  overflow: hidden;
  position: relative;
}
.footer2__map-link {
  width: 280px;
  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: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-column-gap: 60px;
     -moz-column-gap: 60px;
          column-gap: 60px;
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 1;
  background-color: var(--main);
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 18px;
  line-height: 1.2;
  padding: 15px 0 15px 40px;
}
@media (max-width: 768px) {
  .footer2__map-link {
    width: clamp(12.5rem, 7.7290076336rem + 20.3562340967vw, 17.5rem);
    -webkit-column-gap: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
       -moz-column-gap: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
            column-gap: clamp(1.875rem, 0.0858778626rem + 7.6335877863vw, 3.75rem);
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
    padding: clamp(0.625rem, 0.3268129771rem + 1.272264631vw, 0.9375rem) 0 clamp(0.625rem, 0.3268129771rem + 1.272264631vw, 0.9375rem) 40px;
  }
}
.footer2__map-link::before {
  content: "";
  width: 20px;
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--accent);
  -webkit-clip-path: polygon(0 0, 100% 0, 0 100%);
          clip-path: polygon(0 0, 100% 0, 0 100%);
}
.footer2__map-link::after {
  content: "";
  width: 40px;
  height: 1px;
  background-color: var(--base);
}
@media (max-width: 768px) {
  .footer2__map-link::after {
    width: clamp(1.75rem, 1.034351145rem + 3.0534351145vw, 2.5rem);
  }
}
.footer2__map {
  position: absolute;
  inset: -200px;
  width: calc(100% + 400px);
  height: calc(100% + 400px);
}
@media (hover: hover) and (pointer: fine) {
  .footer2 .footer2__map-link {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .footer2 .footer2__map-link:hover {
    background-color: var(--main-d);
  }
}

.footer-nav {
  background-color: var(--base2);
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  line-height: 1.2;
}
.footer-nav__inner {
  max-width: 1279px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 30px 74px;
  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: 39px;
     -moz-column-gap: 39px;
          column-gap: 39px;
  row-gap: 20px;
}
@media (max-width: 1280px) {
  .footer-nav__inner {
    padding: clamp(1.875rem, 0rem + 8vw, 5rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(1.8125rem, 0.125rem + 7.2vw, 4.625rem);
  }
}
@media (max-width: 600px) {
  .footer-nav__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.footer-nav__col {
  max-width: 620px;
  width: 100%;
  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;
}
@media (max-width: 600px) {
  .footer-nav__col {
    row-gap: 10px;
  }
}
.footer-nav__col_site {
  max-width: clamp(13.125rem, -7.7148173207rem + 55.4803788904vw, 38.75rem);
}
@media (max-width: 600px) {
  .footer-nav__col_site {
    max-width: 620px;
    min-height: 248px;
  }
}
.footer-nav__title {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.25rem, 0.2399299475rem + 2.1015761821vw, 2rem);
  letter-spacing: 0.1em;
  border-bottom: 1px solid rgba(95, 100, 119, 0.3);
  padding-bottom: 20px;
}
@media (max-width: 600px) {
  .footer-nav__title {
    font-size: 20px;
    padding-bottom: 10px;
  }
}
.footer-nav__list {
  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;
  font-size: 15px;
}
@media (max-width: 600px) {
  .footer-nav__list {
    row-gap: 19px;
    font-size: 15px;
  }
}
.footer-nav__list_grid {
  display: grid;
  grid-template-columns: repeat(2, fit-content(100%));
  -webkit-column-gap: clamp(2.5rem, -10.9676007005rem + 28.0210157618vw, 12.5rem);
     -moz-column-gap: clamp(2.5rem, -10.9676007005rem + 28.0210157618vw, 12.5rem);
          column-gap: clamp(2.5rem, -10.9676007005rem + 28.0210157618vw, 12.5rem);
  row-gap: 9px;
  font-size: 16px;
}
@media (max-width: 600px) {
  .footer-nav__list_grid {
    grid-template-columns: 1fr;
  }
}
.footer-nav__link, .footer-nav__summary {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-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;
}
.footer-nav__arrow {
  min-width: 9px;
  aspect-ratio: 9/14;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-footer-nav-arrow.svg);
          mask-image: url(../images/icon-footer-nav-arrow.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -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;
}
.footer-nav__summary {
  list-style: none;
  cursor: pointer;
}
.footer-nav__summary::-webkit-details-marker {
  display: none;
}
.footer-nav__details {
  overflow: hidden;
}
.footer-nav__details[open] .footer-nav__summary .footer-nav__arrow {
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}
.footer-nav__acc-body {
  overflow: hidden;
}
.footer-nav__sublist {
  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: 15px 0 0 16px;
}
.footer-nav__sublink {
  font-size: 14px;
}
@media (max-width: 600px) {
  .footer-nav__sublink {
    font-size: clamp(0.8125rem, 0.7083333333rem + 0.4444444444vw, 0.875rem);
  }
}

@media (hover: hover) and (pointer: fine) {
  .footer-nav__link, .footer-nav__summary, .footer-nav__sublink {
    -webkit-transition: color 0.4s ease;
    transition: color 0.4s ease;
  }
  .footer-nav__link .footer-nav__arrow, .footer-nav__summary .footer-nav__arrow, .footer-nav__sublink .footer-nav__arrow {
    -webkit-transition: background-color 0.4s ease, -webkit-transform 0.3s ease;
    transition: background-color 0.4s ease, -webkit-transform 0.3s ease;
    transition: transform 0.3s ease, background-color 0.4s ease;
    transition: transform 0.3s ease, background-color 0.4s ease, -webkit-transform 0.3s ease;
  }
  .footer-nav__link:hover, .footer-nav__link:focus, .footer-nav__summary:hover, .footer-nav__summary:focus, .footer-nav__sublink:hover, .footer-nav__sublink:focus {
    color: var(--main);
  }
  .footer-nav__link:hover .footer-nav__arrow, .footer-nav__link:focus .footer-nav__arrow, .footer-nav__summary:hover .footer-nav__arrow, .footer-nav__summary:focus .footer-nav__arrow, .footer-nav__sublink:hover .footer-nav__arrow, .footer-nav__sublink:focus .footer-nav__arrow {
    background-color: var(--main);
  }
}
/*###################################################################
  sp-nav（module）
###################################################################*/
.sp-nav {
  width: 100%;
  height: 45px;
  display: none;
  -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(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
     -moz-column-gap: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
          column-gap: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 10;
  background-color: var(--base);
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  line-height: 1.2;
  border-top: 1px solid var(--text);
  border-bottom: 1px solid var(--text);
}
@media (max-width: 768px) {
  .sp-nav {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
.sp-nav__tel {
  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-size: 13px;
}
.sp-nav__tel-icon {
  width: 25px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel.svg) no-repeat center center/contain;
}
.sp-nav__divider {
  width: 0;
  height: 20px;
  border-left: 1px solid var(--text);
}
.sp-nav__insta {
  width: 25px;
  aspect-ratio: 1/1;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-insta.svg);
          mask-image: url(../images/icon-insta.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
}
.sp-nav__youtube {
  width: 89px;
  aspect-ratio: 89/20;
}

/*###################################################################
  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-link（module）
###################################################################*/
.c-link-more {
  max-width: clamp(12.5rem, 7.7290076336rem + 20.3562340967vw, 17.5rem);
  width: 100%;
  min-height: clamp(2.5rem, 1.784351145rem + 3.0534351145vw, 3.25rem);
  display: block;
  -webkit-align-content: center;
      -ms-flex-line-pack: center;
          align-content: center;
  position: relative;
  background-color: var(--main);
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
  padding-left: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem);
}
.c-link-more::before, .c-link-more::after {
  content: "";
  position: absolute;
}
.c-link-more::before {
  width: 20px;
  aspect-ratio: 1/1;
  top: 0;
  left: 0;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 0);
          clip-path: polygon(0 0, 0% 100%, 100% 0);
  background-color: #ebbf42;
}
.c-link-more::after {
  width: 40px;
  height: 1px;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: var(--base);
}

@media (hover: hover) and (pointer: fine) {
  .c-link-more {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .c-link-more:hover, .c-link-more:focus {
    background-color: var(--main-d);
  }
}
/*###################################################################
  c-margin（module）
###################################################################*/
.c-mt-top {
  margin-top: clamp(3.125rem, 2.1111641221rem + 4.3256997455vw, 4.1875rem);
}

.c-mt108 {
  margin-top: clamp(5rem, 3.3301526718rem + 7.1246819338vw, 6.75rem);
}

.c-mt60 {
  margin-top: clamp(2.1875rem, 0.6965648855rem + 6.3613231552vw, 3.75rem);
}

.c-mt40 {
  margin-top: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem);
}

/*###################################################################
  c-title（module）
###################################################################*/
.c-title-1 {
  position: relative;
  background-image: -webkit-repeating-linear-gradient(45deg, var(--base3), var(--base3) 3px, transparent 3px, transparent 6px);
  background-image: repeating-linear-gradient(45deg, var(--base3), var(--base3) 3px, transparent 3px, transparent 6px);
  border: 1px solid #d9d9d9;
  padding: 15px 0;
}
.c-title-1::before {
  content: "";
  width: clamp(1.875rem, 1.4606353591rem + 1.7679558011vw, 2.875rem);
  aspect-ratio: 46/61;
  position: absolute;
  top: calc(clamp(1.0625rem, 0.6999309392rem + 1.546961326vw, 1.9375rem) * -1);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background: url(../images/icon-teeth.svg) no-repeat center center/contain;
}
.c-title-1__main {
  min-height: clamp(3.625rem, 3.1070441989rem + 2.2099447514vw, 4.875rem);
  display: grid;
  place-items: center;
  background-color: var(--base3);
  padding: clamp(0.625rem, 0.5057251908rem + 0.5089058524vw, 0.75rem) 0;
}
.c-title-1__text {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.375rem, 1.1160220994rem + 1.1049723757vw, 2rem);
  line-height: 1.6;
  text-align: center;
}

.c-title-2 {
  min-height: clamp(3rem, 2.3266574586rem + 2.8729281768vw, 4.625rem);
  display: grid;
  place-items: center;
  position: relative;
  background-color: var(--main-d);
  padding: clamp(0.625rem, 0.5057251908rem + 0.5089058524vw, 0.75rem) 0;
}
.c-title-2::before, .c-title-2::after {
  content: "";
  width: clamp(2.5rem, -1.5659530387rem + 17.3480662983vw, 12.3125rem);
  height: 100%;
  position: absolute;
  background-image: -webkit-repeating-linear-gradient(135deg, #4c598b, #4c598b 3px, transparent 3px, transparent 6px);
  background-image: repeating-linear-gradient(-45deg, #4c598b, #4c598b 3px, transparent 3px, transparent 6px);
}
.c-title-2::before {
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 0);
          clip-path: polygon(0 0, 0% 100%, 100% 0);
  left: 0;
}
.c-title-2::after {
  -webkit-clip-path: polygon(100% 0, 0% 100%, 100% 100%);
          clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  right: 0;
}
.c-title-2__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-column-gap: clamp(0.25rem, 0.0169198895rem + 0.9944751381vw, 0.8125rem);
     -moz-column-gap: clamp(0.25rem, 0.0169198895rem + 0.9944751381vw, 0.8125rem);
          column-gap: clamp(0.25rem, 0.0169198895rem + 0.9944751381vw, 0.8125rem);
  position: relative;
  z-index: 1;
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.0625rem, 0.7776243094rem + 1.2154696133vw, 1.75rem);
  line-height: 1.6;
  text-align: center;
}
.c-title-2__text::before, .c-title-2__text::after {
  content: "";
  width: clamp(1.25rem, 0.9910220994rem + 1.1049723757vw, 1.875rem);
  height: 1px;
  -webkit-transform: rotate(120deg);
      -ms-transform: rotate(120deg);
          transform: rotate(120deg);
  background-color: var(--base);
}

/*###################################################################
  c-icon-list（module）
###################################################################*/
.c-icon-list {
  max-width: 1120px;
  width: 100%;
  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, 1.54875rem + 1.392vw, 2.41875rem);
  margin-inline: auto;
}
.c-icon-list__item {
  width: 100%;
  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.625rem, 0.25rem + 1.6vw, 1.25rem);
}
.c-icon-list__head {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: clamp(0.625rem, -0.0125rem + 2.72vw, 1.6875rem);
     -moz-column-gap: clamp(0.625rem, -0.0125rem + 2.72vw, 1.6875rem);
          column-gap: clamp(0.625rem, -0.0125rem + 2.72vw, 1.6875rem);
  border-bottom: 1px solid var(--text);
  padding-bottom: clamp(0.625rem, 0.3625rem + 1.12vw, 1.0625rem);
}
.c-icon-list__icon {
  min-width: clamp(1.5rem, 1.0875rem + 1.76vw, 2.1875rem);
  aspect-ratio: 1/1;
  background-image: -webkit-linear-gradient(315deg, #737B98 50%, #5F6477 50%);
  background-image: linear-gradient(135deg, #737B98 50%, #5F6477 50%);
  margin-top: calc(clamp(-0.15rem, -0.17625rem + 0.112vw, -0.10625rem) * -1);
}
.c-icon-list__title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.9rem + 0.96vw, 1.5rem);
  line-height: 1.6;
}
.c-icon-list__text {
  font-size: clamp(0.8125rem, 0.7375rem + 0.32vw, 0.9375rem);
  white-space: pre-line;
}

/*###################################################################
  br（module）
###################################################################*/
.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;
  }
}
.br-400-b {
  display: none;
}
@media (max-width: ss) {
  .br-400-b {
    display: block;
  }
}

/*###################################################################
  hamburger（module）
###################################################################*/
.hamburger {
  width: 50px;
  height: 50px;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-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;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4px;
  position: relative;
  z-index: 30;
  background-color: var(--main-d);
}
@media (min-width: 769px) {
  .hamburger {
    display: none;
  }
}
.hamburger[aria-expanded=true] .hamburger__line {
  height: 18px;
}
.hamburger[aria-expanded=true] .hamburger__line::before {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
      -ms-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.hamburger[aria-expanded=true] .hamburger__line::after {
  bottom: 50%;
  -webkit-transform: translateY(50%) rotate(-45deg);
      -ms-transform: translateY(50%) rotate(-45deg);
          transform: translateY(50%) rotate(-45deg);
}
.hamburger[aria-expanded=true] .hamburger__text::before {
  content: "CLOSE";
}
.hamburger__line {
  width: 25px;
  height: 7px;
  position: relative;
  -webkit-transition: height 0.5s;
  transition: height 0.5s;
}
.hamburger__line::before, .hamburger__line::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  background-color: var(--base);
  -webkit-transition: top 0.5s, bottom 0.5s, -webkit-transform 0.5s;
  transition: top 0.5s, bottom 0.5s, -webkit-transform 0.5s;
  transition: top 0.5s, bottom 0.5s, transform 0.5s;
  transition: top 0.5s, bottom 0.5s, transform 0.5s, -webkit-transform 0.5s;
}
.hamburger__line::before {
  top: 0;
}
.hamburger__line::after {
  bottom: 0;
}
.hamburger__text {
  color: var(--base);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 0.546875rem;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
}
.hamburger__text::before {
  content: "MENU";
}

@media (hover: hover) and (pointer: fine) {
  .hamburger {
    -webkit-transition: background-color 0.4s ease;
    transition: background-color 0.4s ease;
  }
  .hamburger:hover {
    background-color: var(--main);
  }
}
/*###################################################################
  drawer（module）
###################################################################*/
.drawer {
  width: 240px;
  height: 100vh;
  -webkit-transform: translateX(240px);
      -ms-transform: translateX(240px);
          transform: translateX(240px);
  -webkit-transition: 0.5s;
  transition: 0.5s;
  background-color: var(--base);
  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: 80px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--base);
  z-index: 1;
}
.drawer__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;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 20px;
  padding-inline: 40px;
  line-height: 1;
}
.drawer__link {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: var(--text);
  line-height: 1.2;
}
.drawer__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.125rem;
  white-space: nowrap;
}
.drawer__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 0.9375rem;
  white-space: nowrap;
}
.drawer__details {
  max-width: 152px;
  color: var(--text);
}
.drawer__summary {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  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;
  gap: 10px;
  cursor: pointer;
  list-style: none;
  line-height: 1.2;
}
.drawer__summary::-webkit-details-marker {
  display: none;
}
.drawer__summary-text {
  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;
  gap: 5px;
}
.drawer__chevron {
  min-width: 9px;
  aspect-ratio: 9/6;
  background-color: var(--text);
  -webkit-mask-image: url(../images/icon-menu-arrow.svg);
          mask-image: url(../images/icon-menu-arrow.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.drawer__details[open] .drawer__chevron {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.drawer__sub {
  background-color: var(--main);
  padding: 20px;
  margin-top: 10px;
}
.drawer__sub-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;
  gap: 20px;
}
.drawer__sub-link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: inline-block;
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1rem;
  line-height: 1.2;
}

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

@media (hover: hover) and (pointer: fine) {
  .drawer__link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__link:hover, .drawer__link:focus {
    color: var(--main-d);
  }
  .drawer__summary {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__summary .drawer__chevron {
    -webkit-transition: background-color 0.4s, -webkit-transform 0.3s;
    transition: background-color 0.4s, -webkit-transform 0.3s;
    transition: background-color 0.4s, transform 0.3s;
    transition: background-color 0.4s, transform 0.3s, -webkit-transform 0.3s;
  }
  .drawer__summary:hover, .drawer__summary:focus {
    color: var(--main-d);
  }
  .drawer__summary:hover .drawer__chevron, .drawer__summary:focus .drawer__chevron {
    background-color: var(--main-d);
  }
  .drawer__sub-link {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
  .drawer__sub-link:hover, .drawer__sub-link:focus {
    color: var(--main-d);
  }
}
.drawer-bg {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  background-color: transparent;
  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;
}

/*###################################################################
  info（module）診療時間表
###################################################################*/
.info__table {
  width: 100%;
  max-width: 560px;
  table-layout: fixed;
  background-color: var(--base);
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.75rem, 0.0809164733rem + 1.3921113689vw, 1.125rem);
  line-height: 1.2;
  text-align: center;
  border: 1px solid #cfcfcf;
  border-collapse: collapse;
}
@media (max-width: 768px) {
  .info__table {
    font-size: clamp(0.8125rem, 0.5143129771rem + 1.272264631vw, 1.125rem);
  }
}
.info__col {
  width: 9.82%;
}
.info__col_time {
  width: 26.79%;
}
.info__col_narrow {
  width: 9.02%;
}
.info__col_dual {
  width: 15.71%;
}
.info__table thead {
  position: relative;
}
.info__table thead::after {
  content: "";
  height: 1px;
  position: absolute;
  left: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  right: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  bottom: 0;
  background-color: #cfcfcf;
}
@media (max-width: 768px) {
  .info__table thead::after {
    left: clamp(0.5rem, -0.215648855rem + 3.0534351145vw, 1.25rem);
    right: clamp(0.5rem, -0.215648855rem + 3.0534351145vw, 1.25rem);
  }
}
.info__th, .info__td {
  padding: 0 clamp(0.25rem, 0.25rem + 0vw, 0.25rem);
  font-weight: normal;
  text-align: center;
  vertical-align: middle;
  line-height: 1;
}
@media (max-width: 768px) {
  .info__th, .info__td {
    padding-left: clamp(0.125rem, 0.0057251908rem + 0.5089058524vw, 0.25rem);
    padding-right: clamp(0.125rem, 0.0057251908rem + 0.5089058524vw, 0.25rem);
  }
}
@media (min-width: 769px) and (max-width: 1200px) {
  .info tr > :last-child {
    padding-right: clamp(4px, 4px + (1200px - 100vw) * 6 / 431, 10px);
  }
}
.info__th {
  padding-top: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  padding-bottom: clamp(0.5rem, 0.2769721578rem + 0.464037123vw, 0.625rem);
}
@media (max-width: 768px) {
  .info__th {
    padding-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
    padding-bottom: clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
  }
}
.info__td {
  padding-top: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  padding-bottom: 0;
}
@media (max-width: 768px) {
  .info__td {
    padding-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  }
}
tbody tr:last-child .info__td, tbody tr:last-child .info__time {
  padding-bottom: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
}
@media (max-width: 768px) {
  tbody tr:last-child .info__td, tbody tr:last-child .info__time {
    padding-bottom: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  }
}
.info__th_label, .info__time {
  text-align: left;
  white-space: nowrap;
  padding-left: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  padding-right: clamp(0.125rem, -1.88225058rem + 4.1763341067vw, 1.25rem);
  font-weight: normal;
  vertical-align: middle;
  line-height: 1;
}
@media (max-width: 768px) {
  .info__th_label, .info__time {
    padding-left: clamp(0.5rem, -0.215648855rem + 3.0534351145vw, 1.25rem);
    padding-right: clamp(0.5rem, -0.215648855rem + 3.0534351145vw, 1.25rem);
  }
}
.info__th_label {
  padding-top: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  padding-bottom: clamp(0.5rem, 0.2769721578rem + 0.464037123vw, 0.625rem);
}
@media (max-width: 768px) {
  .info__th_label {
    padding-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
    padding-bottom: clamp(0.5rem, 0.3807251908rem + 0.5089058524vw, 0.625rem);
  }
}
.info__time {
  padding-top: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
  padding-bottom: 0;
}
@media (max-width: 768px) {
  .info__time {
    padding-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  }
}
.info__th_dual span {
  display: inline-block;
}
.info__th_dual span + span {
  margin-left: clamp(0.0625rem, -0.0490139211rem + 0.2320185615vw, 0.125rem);
}
@media (max-width: 768px) {
  .info__th_dual span + span {
    margin-left: clamp(0.0625rem, 0.0028625954rem + 0.2544529262vw, 0.125rem);
  }
}
.info__circle {
  width: clamp(0.9375rem, -0.1776392111rem + 2.3201856148vw, 1.5625rem);
  aspect-ratio: 1/1;
  display: inline-block;
  vertical-align: middle;
  background-color: var(--main);
  border-radius: 50%;
}
@media (max-width: 768px) {
  .info__circle {
    width: clamp(0.9375rem, 0.3411259542rem + 2.5445292621vw, 1.5625rem);
  }
}
.info__slash {
  width: clamp(0.75rem, -0.1421113689rem + 1.8561484919vw, 1.25rem);
  height: 1px;
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: rotate(135deg);
      -ms-transform: rotate(135deg);
          transform: rotate(135deg);
  background-color: var(--text);
}
@media (max-width: 768px) {
  .info__slash {
    width: clamp(0.75rem, 0.2729007634rem + 2.0356234097vw, 1.25rem);
  }
}
.info__note {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, 0.4779582367rem + 0.6960556845vw, 1rem);
  line-height: 1.8;
  margin-top: clamp(0.625rem, -0.4901392111rem + 2.3201856148vw, 1.25rem);
}
@media (max-width: 768px) {
  .info__note {
    font-size: clamp(0.8125rem, 0.6335877863rem + 0.7633587786vw, 1rem);
    margin-top: clamp(0.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
  }
}

/*###################################################################
  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 {
  container-type: inline-size;
}
.lower-mv__inner {
  padding: 55px 2.7777777778cqw 0;
}
@media (max-width: 768px) {
  .lower-mv__inner {
    padding: 70px 0 0;
  }
}
.lower-mv__body {
  height: clamp(9.375rem, 3.8732394366rem + 23.4741784038vw, 25rem);
  display: grid;
  place-items: center;
  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);
}
.lower-mv__title {
  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.75rem, 0.5959507042rem + 0.6572769953vw, 1.1875rem);
  color: var(--base);
  line-height: 1;
  margin-top: clamp(0.75rem, 0.5299295775rem + 0.9389671362vw, 1.375rem);
}
.lower-mv__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.5rem, 0.9718309859rem + 2.2535211268vw, 3rem);
}
.lower-mv__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.125rem, 0.8169014085rem + 1.3145539906vw, 2rem);
}

/*###################################################################
  WordPressテスト環境用設定
###################################################################*/
/*###################################################################
  top（page）
###################################################################*/
.top-mv {
  container-type: inline-size;
  position: relative;
}
.top-mv::after {
  content: "";
  width: 100%;
  height: 34.8611111111cqw;
  position: absolute;
  bottom: 0;
  z-index: -1;
  background-color: var(--base3);
}
@media (max-width: 768px) {
  .top-mv::after {
    content: none;
  }
}
.top-mv__inner {
  padding: 55px 2.7777777778cqw 0;
}
@media (max-width: 768px) {
  .top-mv__inner {
    padding: 70px 0 0;
  }
}
.top-mv__body {
  position: relative;
}
@media (max-width: 768px) {
  .top-mv__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: 5.3333333333cqw;
  }
}
.top-mv__box {
  position: absolute;
  bottom: 2.7777777778cqw;
  left: 2.7777777778cqw;
  z-index: 3;
}
@media (max-width: 768px) {
  .top-mv__box {
    position: static;
  }
}
.top-mv__title {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.6944444444cqw;
}
@media (max-width: 768px) {
  .top-mv__title {
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.3333333333cqw;
  }
}
.top-mv__title-row {
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  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: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-bottom: 1px solid var(--text);
  padding: 0.6944444444cqw;
}
@media (max-width: 768px) {
  .top-mv__title-row {
    text-align: center;
    padding: 1.3333333333cqw 2.6666666667cqw;
  }
}
.top-mv__title-row_1 {
  -webkit-animation: mvTitle 0.3s ease-in 1s forwards;
          animation: mvTitle 0.3s ease-in 1s forwards;
}
.top-mv__title-row_2 {
  -webkit-animation: mvTitle 0.3s ease-in 1.5s forwards;
          animation: mvTitle 0.3s ease-in 1.5s forwards;
}
.top-mv__title-text {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: 2.7777777778cqw;
  line-height: 1.6;
  letter-spacing: 0.1em;
  white-space: nowrap;
  -webkit-text-stroke: 1px var(--base);
  paint-order: stroke;
}
@media (max-width: 768px) {
  .top-mv__title-text {
    font-size: 5.3333333333cqw;
    -webkit-text-stroke: 0;
    paint-order: normal;
  }
}
.top-mv__title-lead {
  font-size: 3.3333333333cqw;
  letter-spacing: 0.1em;
}
@media (max-width: 768px) {
  .top-mv__title-lead {
    font-size: 6.4cqw;
  }
}
.top-mv__title-lead_main {
  color: var(--main);
}
.top-mv__title-lead_accent {
  color: var(--accent);
}
.top-mv__movie {
  line-height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.top-mv__video {
  width: 100%;
  aspect-ratio: 16/9;
}

.top-bg-1 {
  position: relative;
}
.top-bg-1::before {
  content: "";
  width: 100%;
  height: 514px;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 23.7%, 0% 100%);
          clip-path: polygon(0 0, 100% 0, 100% 23.7%, 0% 100%);
  position: absolute;
  top: 0;
  z-index: -1;
  background-color: var(--base3);
}
@media (max-width: 768px) {
  .top-bg-1::before {
    content: none;
  }
}

.top-group-1_pos {
  margin-top: 39px;
}
.top-group-1__inner {
  max-width: 1182px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-group-1__inner {
    max-width: clamp(20.9375rem, 7.5190839695rem + 57.2519083969vw, 35rem);
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-group-1__body {
  max-width: 1164px;
  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.3125rem, -0.4169847328rem + 7.3791348601vw, 3.125rem) 15px;
}
@media (max-width: 768px) {
  .top-group-1__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;
  }
}
.top-group-1__item {
  max-width: 560px;
  width: 100%;
}
.top-group-1__title {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.5rem, 0.8181818182rem + 2.9090909091vw, 3rem);
  line-height: 1.2;
  text-align: center;
}
.top-group-1__title::first-letter {
  color: var(--main);
}

.top-news__body {
  background-color: var(--base);
  border: 1px solid #cfcfcf;
  -webkit-box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
          box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
  margin-top: clamp(0.5rem, -0.8120229008rem + 5.5979643766vw, 1.875rem);
  padding: 40px 12px 25px;
}
@media (max-width: 768px) {
  .top-news__body {
    padding: clamp(1.1875rem, -0.0648854962rem + 5.3435114504vw, 2.5rem) 27px 25px;
  }
}
.top-news__main {
  max-width: 486px;
  overflow-y: auto;
  margin-inline: auto;
  padding-right: 10px;
}
@media (max-width: 768px) {
  .top-news__main {
    padding-right: 17px;
  }
}
.top-news__main::-webkit-scrollbar {
  width: 3px;
}
.top-news__main::-webkit-scrollbar-track {
  background-color: transparent;
}
.top-news__main::-webkit-scrollbar-thumb {
  background-color: var(--text);
}
.top-news__items {
  max-width: 446px;
  height: 235px;
  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.5625rem, -0.6898854962rem + 5.3435114504vw, 1.875rem);
}
@media (max-width: 768px) {
  .top-news__items {
    height: 236px;
  }
}
.top-news__post-link {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: grid;
  grid-template-columns: clamp(4.25rem, 2.24274942rem + 4.1763341067vw, 5.375rem) 1fr;
  font-size: clamp(0.8125rem, 0.5894721578rem + 0.464037123vw, 0.9375rem);
  line-height: 1.8;
}
@media (max-width: 768px) {
  .top-news__post-link {
    grid-template-columns: 1fr;
    row-gap: 5px;
    font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
  }
}
.top-news__more {
  text-align: center;
  padding-left: 0;
  margin-top: 10px;
  margin-inline: auto;
}
.top-news__no-post {
  height: 235px;
  display: grid;
  place-items: center;
  font-size: clamp(0.9375rem, 0.7585877863rem + 0.7633587786vw, 1.125rem);
  text-align: center;
}

@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-info__body {
  margin-top: clamp(0.625rem, -0.6273854962rem + 5.3435114504vw, 1.9375rem);
}
.top-info__body .info__table {
  -webkit-box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
          box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
}

.top-group-2 {
  overflow: hidden;
}
.top-group-2_pos {
  margin-top: clamp(2.5rem, 1.3072519084rem + 5.0890585242vw, 3.75rem);
}

.top-concept__outer {
  max-width: 1440px;
  position: relative;
  z-index: 1;
  margin-inline: auto;
}
.top-concept__outer::before, .top-concept__outer::after {
  content: "";
  max-width: clamp(11.25rem, -5.9407600596rem + 35.7675111773vw, 26.25rem);
  width: 100%;
  aspect-ratio: 1/1;
  position: absolute;
  z-index: -1;
}
@media (max-width: 768px) {
  .top-concept__outer::before, .top-concept__outer::after {
    content: none;
  }
}
.top-concept__outer::before {
  top: 213px;
  left: -4.2%;
  background: url(../images/top-concept-deco-1.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-concept-deco-1.webp) 1x, url(../images/top-concept-deco-1@2x.webp) 2x);
  background-image: image-set(url(../images/top-concept-deco-1.webp) 1x, url(../images/top-concept-deco-1@2x.webp) 2x);
}
.top-concept__outer::after {
  top: 0;
  right: -4.2%;
  background: url(../images/top-concept-deco-2.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-concept-deco-2.webp) 1x, url(../images/top-concept-deco-2@2x.webp) 2x);
  background-image: image-set(url(../images/top-concept-deco-2.webp) 1x, url(../images/top-concept-deco-2@2x.webp) 2x);
}
.top-concept__inner {
  max-width: 883px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-top: 54px;
}
@media (max-width: 768px) {
  .top-concept__inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) 0;
  }
}
.top-concept__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-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 10px;
}
@media (max-width: 768px) {
  .top-concept__title {
    row-gap: 21px;
  }
}
.top-concept__jp-box {
  display: grid;
  grid-template-columns: clamp(2.6875rem, 1.4351145038rem + 5.3435114504vw, 4rem) 1fr clamp(2.6875rem, 1.4351145038rem + 5.3435114504vw, 4rem);
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.625rem, 0.2075381679rem + 1.7811704835vw, 1.0625rem);
     -moz-column-gap: clamp(0.625rem, 0.2075381679rem + 1.7811704835vw, 1.0625rem);
          column-gap: clamp(0.625rem, 0.2075381679rem + 1.7811704835vw, 1.0625rem);
}
.top-concept__title-deco {
  width: clamp(2.75rem, 1.5572519084rem + 5.0890585242vw, 4rem);
  height: 29.5px;
  position: relative;
}
.top-concept__title-deco::before, .top-concept__title-deco::after {
  content: "";
  height: 1px;
  position: absolute;
  background-color: var(--text);
}
.top-concept__title-deco::before {
  width: clamp(2rem, 0.9265267176rem + 4.5801526718vw, 3.125rem);
  top: 0;
  left: 0;
}
@media (max-width: 768px) {
  .top-concept__title-deco::before {
    top: 3px;
  }
}
.top-concept__title-deco::after {
  width: clamp(1.5rem, 0.9930820611rem + 2.1628498728vw, 2.03125rem);
  top: 0;
  left: clamp(2rem, 0.9265267176rem + 4.5801526718vw, 3.125rem);
  -webkit-transform-origin: top left;
      -ms-transform-origin: top left;
          transform-origin: top left;
  -webkit-transform: rotate(60deg);
      -ms-transform: rotate(60deg);
          transform: rotate(60deg);
}
@media (max-width: 768px) {
  .top-concept__title-deco::after {
    top: 3px;
  }
}
.top-concept__title-deco_r {
  -webkit-transform: scaleX(-1);
      -ms-transform: scaleX(-1);
          transform: scaleX(-1);
}
.top-concept__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.75rem, 0.6213307241rem + 2.3483365949vw, 2.5rem);
  line-height: 1.6;
  text-align: center;
}
@media (max-width: 768px) {
  .top-concept__jp {
    font-size: clamp(1.25rem, 0.7729007634rem + 2.0356234097vw, 1.75rem);
  }
}
.top-concept__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(2.5rem, 1.0497237569rem + 6.1878453039vw, 6rem);
  line-height: 1;
}
.top-concept__en::first-letter {
  color: var(--accent);
}
.top-concept__text {
  max-width: clamp(29.0625rem, 16.5275707899rem + 26.0804769001vw, 40rem);
  font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
  margin-top: clamp(1.25rem, 0.5939885496rem + 2.7989821883vw, 1.9375rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-concept__text {
    max-width: clamp(18.4375rem, 0.2480916031rem + 77.6081424936vw, 37.5rem);
  }
}
.top-concept__img {
  display: none;
}
@media (max-width: 768px) {
  .top-concept__img {
    max-width: clamp(20.9375rem, 11.0973282443rem + 41.9847328244vw, 31.25rem);
    display: block;
    margin-top: clamp(1.1875rem, -0.0648854962rem + 5.3435114504vw, 2.5rem);
    margin-inline: auto;
  }
}

.top-feature_pos {
  margin-top: clamp(0.625rem, -2.2237569061rem + 12.1546961326vw, 7.5rem);
}
.top-feature__bg {
  position: relative;
}
.top-feature__bg::after {
  content: "";
  inset: 0;
  -webkit-clip-path: polygon(0 0, 100% 8.5%, 100% 100%, 0% 100%);
          clip-path: polygon(0 0, 100% 8.5%, 100% 100%, 0% 100%);
  position: absolute;
  top: 0;
  z-index: -1;
  background-color: var(--base2);
}
@media (max-width: 768px) {
  .top-feature__bg::after {
    -webkit-clip-path: polygon(0 0, 100% 4.4%, 100% 100%, 0% 100%);
            clip-path: polygon(0 0, 100% 4.4%, 100% 100%, 0% 100%);
  }
}
.top-feature__inner {
  max-width: 1440px;
  margin-inline: auto;
  padding-top: clamp(1.875rem, 1.1239640884rem + 3.2044198895vw, 3.6875rem);
  padding-bottom: 80px;
}
@media (max-width: 768px) {
  .top-feature__inner {
    max-width: 600px;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    padding: clamp(1.875rem, 1.1239640884rem + 3.2044198895vw, 3.6875rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(2.5625rem, 1.5524861878rem + 4.3093922652vw, 5rem);
  }
}
.top-feature__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-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: clamp(0.625rem, 0.3919198895rem + 0.9944751381vw, 1.1875rem);
  line-height: 1;
}
.top-feature__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1rem, 0.5856353591rem + 1.7679558011vw, 2rem);
}
.top-feature__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(2.5rem, 1.0497237569rem + 6.1878453039vw, 6rem);
}
.top-feature__en::first-letter {
  color: var(--main);
}
.top-feature__items {
  max-width: 1440px;
  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(2rem, -0.0055886736rem + 4.172876304vw, 3.75rem);
  margin-top: clamp(2.5rem, 1.7837183308rem + 1.4903129657vw, 3.125rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-feature__items {
    max-width: 600px;
    row-gap: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
    margin-top: clamp(1.5625rem, 0.6679389313rem + 3.8167938931vw, 2.5rem);
  }
}
.top-feature__item {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  z-index: 0;
}
@media (max-width: 768px) {
  .top-feature__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.top-feature__item_reverse {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.top-feature__item_reverse .top-feature__img {
  right: auto;
  left: 0;
}
.top-feature__item_reverse .top-feature__deco {
  left: auto;
  right: clamp(5rem, -9.325633383rem + 29.8062593145vw, 17.5rem);
  -webkit-transform: scaleX(-1);
      -ms-transform: scaleX(-1);
          transform: scaleX(-1);
}
@media (max-width: 768px) {
  .top-feature__item_reverse .top-feature__img {
    left: auto;
  }
}
.top-feature__img {
  max-width: clamp(24.0625rem, 0.0670640835rem + 49.9254843517vw, 45rem);
  width: 50%;
  aspect-ratio: 720/440;
  position: absolute;
  top: 0;
  right: 0;
  overflow: hidden;
}
@media (max-width: 768px) {
  .top-feature__img {
    max-width: 100%;
    width: 100%;
    position: relative;
  }
}
.top-feature__img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-feature__box {
  max-width: clamp(26.75rem, 0.1043219076rem + 55.4396423249vw, 50rem);
  width: 55.5%;
  min-height: clamp(14.375rem, 0.049366617rem + 29.8062593145vw, 26.875rem);
  position: relative;
  background-color: var(--base);
  margin-top: clamp(5rem, -0.0139716841rem + 10.4321907601vw, 9.375rem);
  padding: clamp(4rem, 2.7823211624rem + 2.5335320417vw, 5.0625rem) 30px clamp(2.6875rem, 0.0372578241rem + 5.5141579732vw, 5rem);
  z-index: 1;
}
@media (max-width: 768px) {
  .top-feature__box {
    max-width: 100%;
    width: 100%;
    min-height: auto;
    padding: clamp(2.1875rem, -0.4961832061rem + 11.4503816794vw, 5rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(2rem, -0.8625954198rem + 12.213740458vw, 5rem);
    margin-top: 0;
  }
}
.top-feature__box::before {
  content: "";
  position: absolute;
  top: calc(clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem) * -1);
  right: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  bottom: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  left: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  border: 1px solid var(--text);
  pointer-events: none;
}
@media (max-width: 768px) {
  .top-feature__box::before {
    top: calc(clamp(0.625rem, 0.1479007634rem + 2.0356234097vw, 1.125rem) * -1);
    right: clamp(0.625rem, 0.1479007634rem + 2.0356234097vw, 1.125rem);
    bottom: clamp(0.625rem, 0.2075381679rem + 1.7811704835vw, 1.0625rem);
    left: clamp(0.625rem, 0.1479007634rem + 2.0356234097vw, 1.125rem);
  }
}
.top-feature__box-inner {
  max-width: 560px;
  width: 100%;
  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(1rem, -0.0027943368rem + 2.086438152vw, 1.875rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-feature__box-inner {
    row-gap: clamp(0.625rem, 0.1479007634rem + 2.0356234097vw, 1.125rem);
  }
}
.top-feature__deco {
  max-width: clamp(6.9375rem, -0.0104321908rem + 14.4560357675vw, 13rem);
  width: 100%;
  aspect-ratio: 208/279;
  position: absolute;
  top: calc(clamp(6.0625rem, -0.0258941878rem + 12.6676602086vw, 11.375rem) * -1);
  left: clamp(5rem, -9.325633383rem + 29.8062593145vw, 17.5rem);
  z-index: -1;
}
@media (max-width: 768px) {
  .top-feature__deco {
    display: none;
  }
}
.top-feature__badge {
  max-width: clamp(4.6875rem, -1.4008941878rem + 12.6676602086vw, 10rem);
  width: 100%;
  aspect-ratio: 1/1;
  position: absolute;
  top: calc(clamp(2.3125rem, -0.0512295082rem + 4.9180327869vw, 4.375rem) * -1);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
@media (max-width: 768px) {
  .top-feature__badge {
    max-width: clamp(4.1875rem, 1.0267175573rem + 13.4860050891vw, 7.5rem);
    top: calc(clamp(1.8125rem, 0.4408396947rem + 5.8524173028vw, 3.25rem) * -1);
  }
}
.top-feature__sub-title {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.9375rem, 0.0063338301rem + 1.9374068554vw, 1.75rem);
  line-height: 1.6;
  text-align: center;
  position: relative;
  padding-bottom: clamp(1rem, -0.0027943368rem + 2.086438152vw, 1.875rem);
}
@media (max-width: 768px) {
  .top-feature__sub-title {
    font-size: clamp(1rem, 0.7614503817rem + 1.0178117048vw, 1.25rem);
    padding-bottom: clamp(0.625rem, 0.1479007634rem + 2.0356234097vw, 1.125rem);
  }
}
.top-feature__sub-title::after {
  content: "";
  width: clamp(6.6875rem, 0.0260804769rem + 13.8599105812vw, 12.5rem);
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: var(--text);
}
@media (max-width: 768px) {
  .top-feature__sub-title::after {
    width: clamp(5.25rem, 4.2958015267rem + 4.0712468193vw, 6.25rem);
  }
}
.top-feature__text {
  color: var(--text);
  font-size: clamp(0.8125rem, 0.6692436662rem + 0.2980625931vw, 0.9375rem);
  line-height: 2;
}
@media (max-width: 768px) {
  .top-feature__text {
    font-size: clamp(0.8125rem, 0.7528625954rem + 0.2544529262vw, 0.875rem);
  }
}

.top-greet {
  max-width: 1440px;
  min-height: clamp(31.625rem, -0.0346497765rem + 65.8718330849vw, 59.25rem);
  position: relative;
  margin-inline: auto;
  z-index: 0;
}
@media (max-width: 768px) {
  .top-greet {
    max-width: 600px;
    min-height: clamp(43.5625rem, 28.4742366412rem + 64.3765903308vw, 59.375rem);
  }
}
.top-greet_pos {
  margin-top: clamp(2.5rem, 2.0598591549rem + 1.8779342723vw, 3.75rem);
}
.top-greet__bg {
  width: 100vw;
  height: clamp(20rem, 0.0157414307rem + 41.5797317437vw, 37.4375rem);
  position: absolute;
  top: clamp(11.6875rem, 0.0837369598rem + 24.1430700447vw, 21.8125rem);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
  background: url(../images/top-greeting-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-greeting-bg.webp) 1x, url(../images/top-greeting-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-greeting-bg.webp) 1x, url(../images/top-greeting-bg@2x.webp) 2x);
}
@media (max-width: 768px) {
  .top-greet__bg {
    height: auto;
    top: clamp(10.6875rem, 4.5448473282rem + 26.2086513995vw, 17.125rem);
    bottom: 0;
    background: url(../images/top-greeting-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-greeting-bg_sp.webp) 1x, url(../images/top-greeting-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-greeting-bg_sp.webp) 1x, url(../images/top-greeting-bg_sp@2x.webp) 2x);
  }
}
.top-greet__title {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  row-gap: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
  position: absolute;
  top: 0;
  left: clamp(2.6875rem, 0.0372578241rem + 5.5141579732vw, 5rem);
  line-height: 1;
}
@media (max-width: 768px) {
  .top-greet__title {
    row-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
    left: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-greet__en {
  color: var(--text);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(3.1875rem, -0.0357675112rem + 6.7064083458vw, 6rem);
  line-height: 1;
}
@media (max-width: 768px) {
  .top-greet__en {
    font-size: clamp(2.5rem, 1.0687022901rem + 6.106870229vw, 4rem);
  }
}
.top-greet__first {
  color: #ebbf42;
}
.top-greet__jp {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.0625rem, -0.0119225037rem + 2.2354694486vw, 2rem);
  line-height: 1.6;
}
@media (max-width: 768px) {
  .top-greet__jp {
    font-size: clamp(1rem, 0.7614503817rem + 1.0178117048vw, 1.25rem);
  }
}
.top-greet__img {
  max-width: clamp(16.0625rem, 0.0894187779rem + 33.2339791356vw, 30rem);
  width: 33.33%;
  aspect-ratio: 480/600;
  position: absolute;
  top: clamp(6.5625rem, -0.0272913562rem + 13.7108792846vw, 12.3125rem);
  left: clamp(2.6875rem, 0.0372578241rem + 5.5141579732vw, 5rem);
  overflow: hidden;
}
@media (max-width: 768px) {
  .top-greet__img {
    max-width: clamp(18.4375rem, 8.5973282443rem + 41.9847328244vw, 28.75rem);
    width: 78.66%;
    aspect-ratio: 295/369;
    top: clamp(5.6875rem, 1.572519084rem + 17.5572519084vw, 10rem);
    left: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-greet__img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-greet__caption {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: clamp(0.75rem, -0.0379098361rem + 1.6393442623vw, 1.4375rem);
     -moz-column-gap: clamp(0.75rem, -0.0379098361rem + 1.6393442623vw, 1.4375rem);
          column-gap: clamp(0.75rem, -0.0379098361rem + 1.6393442623vw, 1.4375rem);
  position: absolute;
  top: clamp(1.625rem, -0.022447839rem + 3.4277198212vw, 3.0625rem);
  left: clamp(29.0625rem, 0.0530923994rem + 60.3576751118vw, 54.375rem);
  background: -webkit-gradient(linear, left top, left bottom, from(#f3e1af), to(#ffffff));
  background: -webkit-linear-gradient(top, #f3e1af 0%, #ffffff 100%);
  background: linear-gradient(to bottom, #f3e1af 0%, #ffffff 100%);
  padding: clamp(1.3125rem, -0.334947839rem + 3.4277198212vw, 2.75rem) clamp(2rem, -0.0055886736rem + 4.172876304vw, 3.75rem) clamp(1.3125rem, 0.5962183308rem + 1.4903129657vw, 1.9375rem);
}
@media (max-width: 768px) {
  .top-greet__caption {
    -webkit-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
       -moz-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
            column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
    top: clamp(4.125rem, 1.5009541985rem + 11.1959287532vw, 6.875rem);
    left: auto;
    right: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
    padding: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-greet__caption::before {
  content: "";
  position: absolute;
  top: calc(clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem) * -1);
  right: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
  bottom: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
  left: calc(clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem) * -1);
  border: 1px solid #74675a;
  pointer-events: none;
}
@media (max-width: 768px) {
  .top-greet__caption::before {
    top: calc(clamp(0.3125rem, 0.1335877863rem + 0.7633587786vw, 0.5rem) * -1);
    right: clamp(0.3125rem, 0.1335877863rem + 0.7633587786vw, 0.5rem);
    bottom: clamp(0.3125rem, 0.1335877863rem + 0.7633587786vw, 0.5rem);
    left: calc(clamp(0.3125rem, 0.1335877863rem + 0.7633587786vw, 0.5rem) * -1);
  }
}
.top-greet__caption-text {
  width: clamp(1.0625rem, -0.0119225037rem + 2.2354694486vw, 2rem);
  color: #74675a;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.0625rem, -0.0119225037rem + 2.2354694486vw, 2rem);
  line-height: 1.2;
  letter-spacing: 0.2em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
@media (max-width: 768px) {
  .top-greet__caption-text {
    width: clamp(1rem, 0.6421755725rem + 1.5267175573vw, 1.375rem);
    font-size: clamp(1rem, 0.6421755725rem + 1.5267175573vw, 1.375rem);
  }
}
.top-greet__name {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: clamp(0.5rem, -0.0013971684rem + 1.043219076vw, 0.9375rem);
     -moz-column-gap: clamp(0.5rem, -0.0013971684rem + 1.043219076vw, 0.9375rem);
          column-gap: clamp(0.5rem, -0.0013971684rem + 1.043219076vw, 0.9375rem);
  position: absolute;
  top: clamp(23.875rem, 0.0944485842rem + 49.478390462vw, 44.625rem);
  left: clamp(2.6875rem, 0.0372578241rem + 5.5141579732vw, 5rem);
  padding: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem) clamp(1rem, -0.0027943368rem + 2.086438152vw, 1.875rem);
  color: var(--base);
  background-color: #2f3f7b;
  border-bottom: 1px solid var(--base);
}
@media (max-width: 768px) {
  .top-greet__name {
    -webkit-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
       -moz-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
            column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
    top: clamp(24.75rem, 16.1622137405rem + 36.641221374vw, 33.75rem);
    left: clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
    padding: clamp(1.25rem, 0.7729007634rem + 2.0356234097vw, 1.75rem) clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem);
  }
}
.top-greet__name-pre {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  line-height: 1.2;
}
@media (max-width: 768px) {
  .top-greet__name-pre {
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
  }
}
.top-greet__name-main {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.1875rem, -0.0301788376rem + 2.5335320417vw, 2.25rem);
  line-height: 1.2;
}
@media (max-width: 768px) {
  .top-greet__name-main {
    font-size: clamp(1.25rem, 0.7729007634rem + 2.0356234097vw, 1.75rem);
  }
}
.top-greet__name-en {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  line-height: 1.2;
}
@media (max-width: 768px) {
  .top-greet__name-en {
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
  }
}
.top-greet__career {
  max-width: clamp(16.0625rem, 0.0894187779rem + 33.2339791356vw, 30rem);
  width: 33.33%;
  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.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
  position: absolute;
  top: clamp(20.875rem, 0.0312034277rem + 43.3681073025vw, 39.0625rem);
  right: clamp(15.375rem, -1.3859910581rem + 34.8733233979vw, 30rem);
  padding: clamp(1.3125rem, -0.0484351714rem + 2.8315946349vw, 2.5rem) clamp(2rem, -0.0055886736rem + 4.172876304vw, 3.75rem);
  background-color: var(--base);
}
@media (max-width: 768px) {
  .top-greet__career {
    max-width: clamp(18.4375rem, 8.5973282443rem + 41.9847328244vw, 28.75rem);
    width: 78.66%;
    row-gap: clamp(0.625rem, 0.2671755725rem + 1.5267175573vw, 1rem);
    top: clamp(30rem, 19.2652671756rem + 45.8015267176vw, 41.25rem);
    right: clamp(3.75rem, 1.6030534351rem + 9.1603053435vw, 6rem);
    padding: clamp(1.875rem, 0.9804389313rem + 3.8167938931vw, 2.8125rem);
  }
}
.top-greet__career-title {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, 0.0245901639rem + 1.6393442623vw, 1.5rem);
  line-height: 1.6;
  text-align: center;
  position: relative;
  padding-bottom: clamp(0.6875rem, 0.0428464978rem + 1.3412816692vw, 1.25rem);
}
@media (max-width: 768px) {
  .top-greet__career-title {
    font-size: clamp(1.125rem, 0.8864503817rem + 1.0178117048vw, 1.375rem);
    padding-bottom: clamp(0.625rem, 0.2671755725rem + 1.5267175573vw, 1rem);
  }
}
.top-greet__career-title::after {
  content: "";
  width: clamp(12rem, -0.0335320417rem + 25.0372578241vw, 22.5rem);
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: var(--text);
}
@media (max-width: 768px) {
  .top-greet__career-title::after {
    width: clamp(14.6875rem, 9.6183206107rem + 21.6284987277vw, 20rem);
  }
}
.top-greet__career-list {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-align-self: flex-start;
      -ms-flex-item-align: start;
          align-self: flex-start;
  row-gap: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
}
@media (max-width: 768px) {
  .top-greet__career-list {
    row-gap: clamp(0.625rem, 0.3864503817rem + 1.0178117048vw, 0.875rem);
  }
}
.top-greet__career-item {
  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(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
     -moz-column-gap: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
          column-gap: clamp(0.3125rem, -0.0456408346rem + 0.7451564829vw, 0.625rem);
  color: var(--text);
  font-size: clamp(0.8125rem, 0.6692436662rem + 0.2980625931vw, 0.9375rem);
  line-height: 1.2;
}
@media (max-width: 768px) {
  .top-greet__career-item {
    -webkit-column-gap: clamp(0.625rem, 0.3864503817rem + 1.0178117048vw, 0.875rem);
       -moz-column-gap: clamp(0.625rem, 0.3864503817rem + 1.0178117048vw, 0.875rem);
            column-gap: clamp(0.625rem, 0.3864503817rem + 1.0178117048vw, 0.875rem);
    font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
  }
}
.top-greet__career-item::before {
  content: "";
  min-width: clamp(0.5rem, -0.0013971684rem + 1.043219076vw, 0.9375rem);
  aspect-ratio: 1/1;
  background-color: var(--text);
  border-radius: 50%;
}
@media (max-width: 768px) {
  .top-greet__career-item::before {
    min-width: clamp(0.9375rem, 0.7585877863rem + 0.7633587786vw, 1.125rem);
  }
}

.top-staff__bg {
  background: url(../images/top-staff-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-staff-bg.webp) 1x, url(../images/top-staff-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-staff-bg.webp) 1x, url(../images/top-staff-bg@2x.webp) 2x);
}
@media (max-width: 768px) {
  .top-staff__bg {
    background: url(../images/top-staff-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-staff-bg_sp.webp) 1x, url(../images/top-staff-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-staff-bg_sp.webp) 1x, url(../images/top-staff-bg_sp@2x.webp) 2x);
  }
}
.top-staff__inner {
  max-width: 1380px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 100px 30px 100px;
  position: relative;
  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: 30px;
}
@media (max-width: 1000px) {
  .top-staff__inner {
    padding: clamp(3.75rem, 2.25rem + 6.4vw, 6.25rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(3.6875rem, 2.15rem + 6.56vw, 6.25rem);
  }
}
.top-staff__title {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, 0.7729007634rem + 2.0356234097vw, 1.75rem);
  line-height: 1.6;
  text-align: center;
}
.top-staff__sep {
  max-width: clamp(20.9375rem, 12.2900763359rem + 36.8956743003vw, 30rem);
  width: 100%;
  height: 1px;
  display: block;
  background-color: var(--text);
}
.top-staff__text {
  max-width: 1120px;
  width: 100%;
  color: var(--text);
  font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
  line-height: 2;
  text-align: center;
  white-space: pre-line;
}
@media (max-width: 768px) {
  .top-staff__text {
    text-align: left;
  }
}
.top-staff__link {
  position: relative;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  margin-top: calc(clamp(0rem, -0.1789122137rem + 0.7633587786vw, 0.1875rem) * -1);
  margin-inline: auto;
  padding-left: clamp(1.5rem, 0.6650763359rem + 3.5623409669vw, 2.375rem);
}

.top-med_pos {
  margin-top: clamp(1.25rem, -0.7776717557rem + 8.6513994911vw, 3.375rem);
}
.top-med__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-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: clamp(0.625rem, 0.3919198895rem + 0.9944751381vw, 1.1875rem);
  line-height: 1;
}
.top-med__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1rem, 0.5856353591rem + 1.7679558011vw, 2rem);
}
.top-med__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(2.5rem, 1.0497237569rem + 6.1878453039vw, 6rem);
}
.top-med__en::first-letter {
  color: var(--accent);
}
.top-med__bg {
  background-color: var(--base3);
  margin-top: clamp(1.5625rem, 0.0715648855rem + 6.3613231552vw, 3.125rem);
}
.top-med__inner {
  max-width: 1278px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 30px 170px;
}
@media (max-width: 1000px) {
  .top-med__inner {
    padding: clamp(1.25rem, -1rem + 9.6vw, 5rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) clamp(6.25rem, 3.625rem + 11.2vw, 10.625rem);
  }
}
.top-med__items1 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -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: 40px clamp(0.9375rem, -1.1045994065rem + 3.2640949555vw, 1.625rem);
}
@media (max-width: 1000px) {
  .top-med__items1 {
    gap: 40px clamp(0.9375rem, -1.3511904762rem + 4.7619047619vw, 1.625rem);
  }
}
@media (max-width: 768px) {
  .top-med__items1 {
    gap: 20px 15px;
  }
}
.top-med__item1 {
  width: calc((100% - 3 * clamp(0.9375rem, -1.1045994065rem + 3.2640949555vw, 1.625rem)) / 4);
  max-width: 300px;
}
@media (max-width: 1000px) {
  .top-med__item1 {
    width: calc((100% - 2 * clamp(0.9375rem, -1.3511904762rem + 4.7619047619vw, 1.625rem)) / 3);
  }
}
@media (max-width: 768px) {
  .top-med__item1 {
    width: calc((100% - 15px) / 2);
    max-width: 160px;
  }
}
.top-med__link {
  min-height: clamp(6.25rem, -1.1758160237rem + 11.8694362018vw, 8.75rem);
  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(0.5rem, 0.1287091988rem + 0.5934718101vw, 0.625rem);
     -moz-column-gap: clamp(0.5rem, 0.1287091988rem + 0.5934718101vw, 0.625rem);
          column-gap: clamp(0.5rem, 0.1287091988rem + 0.5934718101vw, 0.625rem);
  position: relative;
  background-color: var(--base);
  padding: 20px 0 20px clamp(0.625rem, -1.2314540059rem + 2.9673590504vw, 1.25rem);
}
@media (max-width: 1000px) {
  .top-med__link {
    min-height: clamp(6.25rem, -2.0725108225rem + 17.316017316vw, 8.75rem);
    -webkit-column-gap: clamp(0.5rem, 0.0838744589rem + 0.8658008658vw, 0.625rem);
       -moz-column-gap: clamp(0.5rem, 0.0838744589rem + 0.8658008658vw, 0.625rem);
            column-gap: clamp(0.5rem, 0.0838744589rem + 0.8658008658vw, 0.625rem);
    padding: 20px 0 20px clamp(0.625rem, -1.4556277056rem + 4.329004329vw, 1.25rem);
  }
}
@media (max-width: 768px) {
  .top-med__link {
    min-height: 171px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    row-gap: 10px;
    padding: 20px 0 40px;
  }
}
.top-med__icon {
  max-width: clamp(3.75rem, -3.6758160237rem + 11.8694362018vw, 6.25rem);
  width: 100%;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  aspect-ratio: 1/1;
}
@media (max-width: 1000px) {
  .top-med__icon {
    max-width: clamp(3.75rem, -4.5725108225rem + 17.316017316vw, 6.25rem);
  }
}
@media (max-width: 768px) {
  .top-med__icon {
    max-width: 60px;
  }
}
.top-med__sub-title {
  border-bottom: 1px solid var(--text);
  padding: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem) 10px;
}
.top-med__sub-title-text {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, -0.4870178042rem + 2.0771513353vw, 1.25rem);
  line-height: 1.6;
}
@media (max-width: 1000px) {
  .top-med__sub-title-text {
    font-size: clamp(0.8125rem, -0.6439393939rem + 3.0303030303vw, 1.25rem);
  }
}
@media (max-width: 768px) {
  .top-med__sub-title-text {
    font-size: 13px;
  }
}
.top-med__arrow {
  width: 30px;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  position: absolute;
  right: 0;
  bottom: 0;
  background-color: var(--main);
}
.top-med__arrow::before {
  content: "";
  width: 10px;
  height: 3px;
  background-color: var(--base);
  -webkit-mask-image: url(../images/icon-arrow-right.svg);
          mask-image: url(../images/icon-arrow-right.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.top-med__slider {
  overflow: hidden;
  margin-top: calc(clamp(4.375rem, 3.1822519084rem + 5.0890585242vw, 5.625rem) * -1);
}
.top-med__wrapper {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.top-med__items2 {
  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-med__slide {
  max-width: clamp(11.25rem, 6.75rem + 19.2vw, 18.75rem);
  margin-right: clamp(0.625rem, 0.25rem + 1.6vw, 1.25rem);
}

@media (hover: hover) and (pointer: fine) {
  .top-med__link {
    -webkit-transition: background-color 0.4s ease;
    transition: background-color 0.4s ease;
  }
  .top-med__link:hover, .top-med__link:focus {
    background-color: var(--base2);
  }
  .top-med__link:hover .top-med__arrow, .top-med__link:focus .top-med__arrow {
    background-color: var(--main-d);
  }
  .top-med__arrow {
    -webkit-transition: background-color 0.4s ease;
    transition: background-color 0.4s ease;
  }
}
.top-recruit_pos {
  margin-top: clamp(1.875rem, -1.106870229rem + 12.7226463104vw, 5rem);
}
.top-recruit__inner {
  max-width: 960px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-recruit__inner {
    max-width: clamp(20.9375rem, 5.1335877863rem + 67.4300254453vw, 37.5rem);
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.top-recruit__body {
  aspect-ratio: 96/32;
  container-type: inline-size;
  position: relative;
  background-color: var(--base2);
}
@media (max-width: 768px) {
  .top-recruit__body {
    aspect-ratio: auto;
    padding-bottom: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  }
}
.top-recruit__head {
  width: 100%;
  height: 16.7708333333cqw;
  display: grid;
  place-items: center;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
  position: absolute;
  top: 0;
  background-image: -webkit-repeating-linear-gradient(left, #bdad9d, #bdad9d 4px, #b2a292 4px, #b2a292 8px);
  background-image: repeating-linear-gradient(90deg, #bdad9d, #bdad9d 4px, #b2a292 4px, #b2a292 8px);
}
@media (max-width: 768px) {
  .top-recruit__head {
    height: inherit;
    aspect-ratio: 335/85;
  }
}
.top-recruit__triangle {
  width: 85.625cqw;
  aspect-ratio: 822/140;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: url(../images/icon-triangle-pc.svg) no-repeat center center/contain;
}
@media (max-width: 768px) {
  .top-recruit__triangle {
    width: 85.671641791%;
    aspect-ratio: 287/74;
    background: url(../images/icon-triangle-sp.svg) no-repeat center center/contain;
  }
}
.top-recruit__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-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 1.25cqw;
  color: var(--base);
  line-height: 1;
  margin-top: -1.4583333333cqw;
}
@media (max-width: 768px) {
  .top-recruit__title {
    row-gap: clamp(0.375rem, 0.1364503817rem + 1.0178117048vw, 0.625rem);
    margin-top: -13px;
  }
}
.top-recruit__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.0833333333cqw;
}
@media (max-width: 768px) {
  .top-recruit__jp {
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
  }
}
.top-recruit__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 6.6666666667cqw;
}
@media (max-width: 768px) {
  .top-recruit__en {
    font-size: clamp(2rem, 1.0458015267rem + 4.0712468193vw, 3rem);
  }
}
.top-recruit__img {
  max-width: 50cqw;
  width: 100%;
  position: absolute;
  right: 0;
}
.top-recruit__text {
  max-width: 43.9583333333cqw;
  position: absolute;
  bottom: 4.1666666667cqw;
  left: 3.9583333333cqw;
  font-size: 1.5625cqw;
  white-space: pre-line;
}
@media (max-width: 768px) {
  .top-recruit__text {
    max-width: clamp(17.1875rem, 8.4208015267rem + 37.4045801527vw, 26.375rem);
    position: static;
    font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
    margin-top: clamp(6.3125rem, 1.6011450382rem + 20.1017811705vw, 11.25rem);
    margin-inline: auto;
  }
}
.top-recruit__link {
  max-width: 29.1666666667cqw;
  width: 100%;
  min-height: 5.4166666667cqw;
  display: block;
  -webkit-align-content: center;
      -ms-flex-line-pack: center;
          align-content: center;
  position: absolute;
  bottom: 4.1666666667cqw;
  right: 10.4166666667cqw;
  background-color: #bdad9d;
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.875cqw;
  padding-left: 11.25cqw;
}
@media (max-width: 768px) {
  .top-recruit__link {
    max-width: clamp(12.5rem, 7.7290076336rem + 20.3562340967vw, 17.5rem);
    width: 100%;
    min-height: clamp(2.5rem, 1.784351145rem + 3.0534351145vw, 3.25rem);
    position: relative;
    bottom: inherit;
    right: inherit;
    font-size: clamp(0.875rem, 0.6364503817rem + 1.0178117048vw, 1.125rem);
    margin-top: clamp(1.1875rem, -0.8998091603rem + 8.9058524173vw, 3.375rem);
    margin-inline: auto;
    padding-left: clamp(4rem, 1.3759541985rem + 11.1959287532vw, 6.75rem);
  }
}
.top-recruit__link::before, .top-recruit__link::after {
  content: "";
  position: absolute;
}
.top-recruit__link::before {
  width: 20px;
  aspect-ratio: 1/1;
  top: 0;
  left: 0;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 0);
          clip-path: polygon(0 0, 0% 100%, 100% 0);
  background-color: #ebbf42;
}
.top-recruit__link::after {
  width: 40px;
  height: 1px;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: var(--base);
}

@media (hover: hover) and (pointer: fine) {
  .top-recruit__link {
    -webkit-transition: background-color 0.4s ease;
    transition: background-color 0.4s ease;
  }
  .top-recruit__link:hover {
    background-color: #a89687;
  }
}
/*###################################################################
  clinic（page）
###################################################################*/
.clinic1__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.75rem, 1.3645038168rem + 10.1781170483vw, 6.25rem);
  margin-top: clamp(3.75rem, 2.5572519084rem + 5.0890585242vw, 5rem);
}
@media (max-width: 768px) {
  .clinic1__items {
    max-width: clamp(20.9375rem, 5.1335877863rem + 67.4300254453vw, 37.5rem);
    margin-inline: auto;
  }
}
.clinic1__item {
  width: 100%;
  position: relative;
  color: var(--text);
  border: 2px solid var(--text);
  padding: clamp(3.4375rem, 0.6941793893rem + 11.7048346056vw, 6.3125rem) 15px clamp(2.5rem, 1.366889313rem + 4.834605598vw, 3.6875rem);
}
.clinic1__item::before {
  content: "";
  width: clamp(4.6875rem, -0.4855675147rem + 10.7632093933vw, 8.125rem);
  aspect-ratio: 1/1;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 100%);
          clip-path: polygon(0 0, 0% 100%, 100% 100%);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  background-image: -webkit-repeating-linear-gradient(45deg, #4c598b, #4c598b 3px, transparent 3px, transparent 6px);
  background-image: repeating-linear-gradient(45deg, #4c598b, #4c598b 3px, transparent 3px, transparent 6px);
}
.clinic1__num {
  max-width: clamp(6.875rem, 5.0858778626rem + 7.6335877863vw, 8.75rem);
  width: 100%;
  height: clamp(4.0625rem, 2.8101145038rem + 5.3435114504vw, 5.375rem);
  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;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(2.375rem, 1.7786259542rem + 2.5445292621vw, 3rem);
  font-weight: 500;
}
.clinic1__num::before, .clinic1__num::after {
  content: "";
  width: clamp(2.25rem, 1.4150763359rem + 3.5623409669vw, 3.125rem);
  height: 2px;
  position: absolute;
  background-color: var(--text);
  -webkit-transform: rotate(-58deg);
      -ms-transform: rotate(-58deg);
          transform: rotate(-58deg);
}
.clinic1__num::before {
  top: clamp(1rem, 0.7018129771rem + 1.272264631vw, 1.3125rem);
  left: calc(clamp(0.5625rem, 0.3835877863rem + 0.7633587786vw, 0.75rem) * -1);
}
.clinic1__num::after {
  bottom: clamp(1rem, 0.7018129771rem + 1.272264631vw, 1.3125rem);
  right: calc(clamp(0.5625rem, 0.3835877863rem + 0.7633587786vw, 0.75rem) * -1);
}
.clinic1__body {
  max-width: 1120px;
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .clinic1__body {
    max-width: clamp(18.8125rem, 6.9446564885rem + 50.6361323155vw, 31.25rem);
    -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(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  }
}
.clinic1__box {
  max-width: 560px;
  width: 100%;
  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.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
}
.clinic1__title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.4375rem, 0.967221135rem + 0.9784735812vw, 1.75rem);
  line-height: 2;
}
@media (max-width: 768px) {
  .clinic1__title {
    font-size: clamp(1.125rem, 0.6479007634rem + 2.0356234097vw, 1.625rem);
  }
}
.clinic1__text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: clamp(0.8125rem, 0.6932251908rem + 0.5089058524vw, 0.9375rem);
  line-height: 2;
}
.clinic1__img {
  max-width: 520px;
  width: 100%;
}

.clinic2__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -webkit-column-gap: clamp(0.5rem, -0.2772020725rem + 3.3160621762vw, 2.5rem);
     -moz-column-gap: clamp(0.5rem, -0.2772020725rem + 3.3160621762vw, 2.5rem);
          column-gap: clamp(0.5rem, -0.2772020725rem + 3.3160621762vw, 2.5rem);
}
.clinic2__link {
  overflow: hidden;
  display: block;
}

@media (hover: hover) and (pointer: fine) {
  .clinic2__link:hover img, .clinic2__link:focus img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
  .clinic2__link 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;
  }
}
.clinic3__body {
  background-color: var(--base2);
}
.clinic3__body-inner {
  max-width: 1040px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 30px 80px;
}
@media (max-width: 1280px) {
  .clinic3__body-inner {
    padding: 80px clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem) 80px;
  }
}
.clinic3__dl {
  display: grid;
  grid-template-columns: clamp(3.75rem, -6.9847328244rem + 45.8015267176vw, 15rem) 1fr;
  -webkit-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
     -moz-column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
          column-gap: clamp(0.3125rem, 0.0143129771rem + 1.272264631vw, 0.625rem);
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, 0.6335877863rem + 0.7633587786vw, 1rem);
  line-height: 2;
  letter-spacing: 0.1em;
}
.clinic3__dt {
  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: 400;
  text-align: center;
  padding: clamp(0.3125rem, 0.0500954198rem + 1.1195928753vw, 0.5875rem) 0;
  border-bottom: 1px solid var(--text);
}
.clinic3__dd {
  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-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: clamp(0.3125rem, 0.0500954198rem + 1.1195928753vw, 0.5875rem) clamp(0rem, -3rem + 8vw, 2.5rem);
  border-bottom: 1px solid var(--text);
}

.clinic4__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(0.625rem, 0.3338509317rem + 1.2422360248vw, 1.25rem);
}
.clinic4__table {
  width: 100%;
  table-layout: fixed;
  background-color: var(--base);
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, 0.6669254658rem + 0.6211180124vw, 1.125rem);
  line-height: 1.2;
  text-align: center;
  border: 1px solid #cfcfcf;
  border-collapse: collapse;
  -webkit-box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
          box-shadow: 4px 4px 30px rgba(0, 0, 0, 0.15);
}
.clinic4__col {
  width: 8.59%;
}
.clinic4__col_time {
  width: 28.83%;
}
.clinic4__col_narrow {
  width: 8.44%;
}
.clinic4__col_dual {
  width: 20%;
}
.clinic4__table thead {
  position: relative;
}
.clinic4__table thead::after {
  content: "";
  height: 1px;
  position: absolute;
  left: clamp(0.5rem, -1.5962732919rem + 8.9440993789vw, 5rem);
  right: clamp(0.5rem, -1.5962732919rem + 8.9440993789vw, 5rem);
  bottom: 0;
  background-color: #cfcfcf;
}
.clinic4__th, .clinic4__td {
  padding: 0 clamp(0.125rem, 0.0667701863rem + 0.248447205vw, 0.25rem);
  font-weight: 400;
  text-align: center;
  vertical-align: middle;
  line-height: 1;
}
.clinic4 tr > :last-child {
  padding-right: clamp(0.5rem, -3.3431677019rem + 16.397515528vw, 8.75rem);
}
.clinic4__th {
  padding-top: clamp(0.625rem, 0.0427018634rem + 2.4844720497vw, 1.875rem);
  padding-bottom: clamp(0.5rem, 0.0341614907rem + 1.9875776398vw, 1.5rem);
}
.clinic4__td {
  padding-top: clamp(0.625rem, 0.3338509317rem + 1.2422360248vw, 1.25rem);
  padding-bottom: 0;
}
tbody tr:last-child .clinic4__td {
  padding-bottom: clamp(0.625rem, -0.248447205rem + 3.7267080745vw, 2.5rem);
}
tbody tr:last-child .clinic4__time {
  padding-bottom: clamp(0.625rem, -0.4813664596rem + 4.7204968944vw, 3rem);
}
.clinic4__th_label, .clinic4__time {
  text-align: left;
  white-space: nowrap;
  padding-left: clamp(0.5rem, -4.4204192547rem + 20.9937888199vw, 11.0625rem);
  padding-right: clamp(0.125rem, -0.399068323rem + 2.2360248447vw, 1.25rem);
  font-weight: 400;
  vertical-align: middle;
  line-height: 1;
}
.clinic4__th_label {
  padding-top: clamp(0.625rem, 0.0427018634rem + 2.4844720497vw, 1.875rem);
  padding-bottom: clamp(0.5rem, 0.0341614907rem + 1.9875776398vw, 1.5rem);
}
.clinic4__time {
  padding-top: clamp(0.625rem, 0.2173913043rem + 1.7391304348vw, 1.5rem);
  padding-bottom: clamp(0rem, -0.2329192547rem + 0.9937888199vw, 0.5rem);
}
.clinic4__th_dual span {
  display: inline-block;
}
.clinic4__th_dual span + span {
  margin-left: clamp(0.0625rem, 0.0333850932rem + 0.1242236025vw, 0.125rem);
}
.clinic4__circle {
  width: clamp(0.9375rem, 0.5007763975rem + 1.8633540373vw, 1.875rem);
  aspect-ratio: 1/1;
  display: inline-block;
  vertical-align: middle;
  background-color: var(--main);
  border-radius: 50%;
}
.clinic4__slash {
  width: clamp(0.75rem, 0.225931677rem + 2.2360248447vw, 1.875rem);
  height: 1px;
  display: inline-block;
  vertical-align: middle;
  background-color: var(--text);
  -webkit-transform: rotate(150deg);
      -ms-transform: rotate(150deg);
          transform: rotate(150deg);
}
.clinic4__note {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.8125rem, 0.7251552795rem + 0.3726708075vw, 1rem);
  line-height: 1.8;
}

/*###################################################################
  staff（page）
###################################################################*/
.staff1__doctor {
  max-width: 1120px;
  margin-inline: auto;
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: clamp(1.875rem, -2.8277886497rem + 9.7847358121vw, 5rem);
     -moz-column-gap: clamp(1.875rem, -2.8277886497rem + 9.7847358121vw, 5rem);
          column-gap: clamp(1.875rem, -2.8277886497rem + 9.7847358121vw, 5rem);
}
@media (max-width: 768px) {
  .staff1__doctor {
    -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(1.875rem, 0.6822519084rem + 5.0890585242vw, 3.125rem);
    max-width: clamp(20.9375rem, 5.1335877863rem + 67.4300254453vw, 37.5rem);
    margin-inline: auto;
  }
}
.staff1__doctor_2 {
  margin-top: clamp(2.5rem, 1.4640883978rem + 4.4198895028vw, 5rem);
}
.staff1__text {
  max-width: 560px;
  width: 100%;
  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;
}
.staff1__name {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.5rem, 0.747553816rem + 1.5655577299vw, 2rem);
  font-weight: 400;
  line-height: 2;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--text);
}
@media (max-width: 768px) {
  .staff1__name {
    font-size: clamp(1.375rem, 1.0171755725rem + 1.5267175573vw, 1.75rem);
  }
}
.staff1__role {
  font-size: clamp(1.125rem, 0.560665362rem + 1.1741682975vw, 1.5rem);
}
@media (max-width: 768px) {
  .staff1__role {
    font-size: clamp(1rem, 0.6421755725rem + 1.5267175573vw, 1.375rem);
  }
}
.staff1__space {
  font-size: clamp(1.25rem, 0.497553816rem + 1.5655577299vw, 1.75rem);
}
@media (max-width: 768px) {
  .staff1__space {
    font-size: clamp(1.125rem, 0.7671755725rem + 1.5267175573vw, 1.5rem);
  }
}
.staff1__desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: clamp(0.875rem, 0.8153625954rem + 0.2544529262vw, 0.9375rem);
  line-height: 2;
}
.staff1__img {
  max-width: clamp(22.5rem, 11.2133072407rem + 23.4833659491vw, 30rem);
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 4px;
}
.staff1__img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.staff1__history {
  background-color: var(--base2);
  padding: clamp(2.5rem, 1.75rem + 3.2vw, 3.75rem) clamp(0.9375rem, 0.0429389313rem + 3.8167938931vw, 1.875rem);
  margin-top: clamp(1.25rem, 0.7320441989rem + 2.2099447514vw, 2.5rem);
}
.staff1__history-inner {
  max-width: 1120px;
  margin-inline: auto;
  background-color: var(--base);
  padding: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem) clamp(1.25rem, -0.625rem + 8vw, 4.375rem);
}
.staff1__history-box {
  max-width: 960px;
  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;
  margin-inline: auto;
}
.staff1__history-title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
  font-weight: 400;
  line-height: 1.2;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--text);
}
.staff1__history-list {
  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;
}
.staff1__history-item {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: clamp(0.875rem, 0.8153625954rem + 0.2544529262vw, 0.9375rem);
  line-height: 2;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--text);
}

.staff2__list-wrap {
  background-color: var(--base2);
}
.staff2__list-inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 60px 30px 60px;
}
@media (max-width: 768px) {
  .staff2__list-inner {
    padding: clamp(2.5rem, 1.75rem + 3.2vw, 3.75rem) clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.staff2__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.25rem, -3.2347670251rem + 7.1684587814vw, 2.5rem);
}
@media (max-width: 1000px) {
  .staff2__list {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(1.25rem, -2.9112554113rem + 8.658008658vw, 2.5rem);
  }
}
@media (max-width: 768px) {
  .staff2__list {
    max-width: 400px;
    grid-template-columns: 1fr;
    gap: 20px;
    margin-inline: auto;
  }
}
.staff2__item {
  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(1.25rem, -0.54390681rem + 2.8673835125vw, 1.75rem);
  background-color: var(--base);
  padding: clamp(1.25rem, -3.2347670251rem + 7.1684587814vw, 2.5rem);
}
@media (max-width: 1000px) {
  .staff2__item {
    padding: clamp(1.25rem, -2.9112554113rem + 8.658008658vw, 2.5rem);
  }
  .staff2__item:last-child {
    grid-column: 1/-1;
    max-width: calc((100% - clamp(1.25rem, -2.9112554113rem + 8.658008658vw, 2.5rem)) / 2);
    margin-inline: auto;
  }
}
@media (max-width: 768px) {
  .staff2__item {
    padding: clamp(1.25rem, 0.0572519084rem + 5.0890585242vw, 2.5rem);
  }
  .staff2__item:last-child {
    max-width: none;
    grid-column: auto;
    margin-inline: 0;
  }
}
.staff2__head {
  width: 100%;
  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(0.75rem, -0.6608365949rem + 2.9354207436vw, 1.6875rem);
     -moz-column-gap: clamp(0.75rem, -0.6608365949rem + 2.9354207436vw, 1.6875rem);
          column-gap: clamp(0.75rem, -0.6608365949rem + 2.9354207436vw, 1.6875rem);
  border-bottom: 1px solid var(--text);
  padding-bottom: 20px;
}
.staff2__icon {
  min-width: clamp(1.75rem, 1.091609589rem + 1.3698630137vw, 2.1875rem);
  aspect-ratio: 1/1;
  background-image: -webkit-linear-gradient(315deg, #737b98 50%, var(--text) 50%);
  background-image: linear-gradient(135deg, #737b98 50%, var(--text) 50%);
}
.staff2__name {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, -0.54390681rem + 2.8673835125vw, 1.75rem);
  font-weight: 400;
  line-height: 1.2;
}
@media (max-width: 1000px) {
  .staff2__name {
    font-size: clamp(1.375rem, 0.1266233766rem + 2.5974025974vw, 1.75rem);
  }
}
@media (max-width: 768px) {
  .staff2__name {
    font-size: clamp(1.375rem, 1.1364503817rem + 1.0178117048vw, 1.625rem);
  }
}
.staff2__role {
  font-size: clamp(0.875rem, -0.021953405rem + 1.4336917563vw, 1.125rem);
}
@media (max-width: 1000px) {
  .staff2__role {
    font-size: clamp(0.875rem, 0.0427489177rem + 1.7316017316vw, 1.125rem);
  }
}
@media (max-width: 768px) {
  .staff2__role {
    font-size: clamp(0.875rem, 0.7557251908rem + 0.5089058524vw, 1rem);
  }
}
.staff2__img {
  max-width: clamp(11.25rem, -2.2043010753rem + 21.5053763441vw, 15rem);
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media (max-width: 1000px) {
  .staff2__img {
    max-width: 240px;
  }
}
.staff2__img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*###################################################################
  fee（page）
###################################################################*/
.fee1__group {
  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: 40px;
}
.fee1__group + .fee1__group {
  margin-top: 60px;
}
.fee1__subcat {
  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;
}
.fee1__subcat-head {
  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(0.9375rem, -0.1911692759rem + 2.3483365949vw, 1.6875rem);
     -moz-column-gap: clamp(0.9375rem, -0.1911692759rem + 2.3483365949vw, 1.6875rem);
          column-gap: clamp(0.9375rem, -0.1911692759rem + 2.3483365949vw, 1.6875rem);
  border-bottom: 1px solid var(--text);
  padding-bottom: 20px;
}
.fee1__subcat-icon {
  min-width: clamp(1.75rem, 1.091609589rem + 1.3698630137vw, 2.1875rem);
  aspect-ratio: 1/1;
  background-image: -webkit-linear-gradient(315deg, #737b98 50%, var(--text) 50%);
  background-image: linear-gradient(135deg, #737b98 50%, var(--text) 50%);
}
.fee1__subcat-title {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, 0.873776908rem + 0.782778865vw, 1.5rem);
  font-weight: 400;
  line-height: 1.2;
}
@media (max-width: 768px) {
  .fee1__subcat-title {
    font-size: clamp(1.125rem, 0.8864503817rem + 1.0178117048vw, 1.375rem);
  }
}
.fee1__table-wrap {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden !important;
}
.fee1__table-wrap.is-scrollable {
  cursor: -webkit-grab;
  cursor: grab;
}
.fee1__table-wrap.is-scrollable:active {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
.fee1__table-wrap .scroll-hint-icon {
  top: 10px;
}
.fee1__table {
  width: 100%;
  min-width: 453px;
  border-collapse: collapse;
  table-layout: fixed;
}
.fee1__th, .fee1__td {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.875rem, 0.686888454rem + 0.3913894325vw, 1rem);
  font-weight: 400;
  line-height: 2;
  text-align: center;
  vertical-align: middle;
  padding: 10px 0;
}
.fee1__th {
  width: 25%;
  background-color: var(--text);
  color: #fff;
  border-right: 1px solid #fff;
}
.fee1__th:last-child {
  border-right: none;
}
.fee1__th_main {
  width: 50%;
}
.fee1__td {
  width: 25%;
  color: var(--text);
  border-bottom: 1px solid var(--text);
  border-left: 1px solid var(--text);
}
.fee1__td:last-child {
  border-right: 1px solid var(--text);
}
.fee1__td_main {
  width: 50%;
}

/*###################################################################
  medical（page）
###################################################################*/
.med-col1 {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: clamp(1.875rem, 1.2786259542rem + 2.5445292621vw, 2.5rem) 15px;
}
@media (max-width: 768px) {
  .med-col1 {
    -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;
  }
}
.med-col1__box {
  max-width: 640px;
  width: 100%;
  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.625rem, 0.0286259542rem + 2.5445292621vw, 1.25rem);
}
.med-col1__title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, 0.497553816rem + 1.5655577299vw, 1.75rem);
}
@media (max-width: 768px) {
  .med-col1__title {
    font-size: clamp(1.25rem, 1.0114503817rem + 1.0178117048vw, 1.5rem);
  }
}
.med-col1__desc {
  font-size: clamp(0.875rem, 0.8153625954rem + 0.2544529262vw, 0.9375rem);
  white-space: pre-line;
}
.med-col1__img {
  max-width: 600px;
  width: 100%;
}

.med-trouble {
  position: relative;
  background-color: var(--base2);
  border-top: 5px solid #c8b9ab;
}
.med-trouble__deco {
  width: 100%;
  height: 82.0388349515%;
  -webkit-clip-path: polygon(100% 0, 100% 44.6%, 50% 100%, 0 44.6%, 0 0);
          clip-path: polygon(100% 0, 100% 44.6%, 50% 100%, 0 44.6%, 0 0);
  position: absolute;
  z-index: 0;
  background-color: #f9ebdc;
  pointer-events: none;
}
@media (max-width: 768px) {
  .med-trouble__deco {
    -webkit-clip-path: polygon(100% 0, 100% 33.6%, 50% 100%, 0 33.6%, 0 0);
            clip-path: polygon(100% 0, 100% 33.6%, 50% 100%, 0 33.6%, 0 0);
  }
}
.med-trouble__inner {
  max-width: 1120px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 30px 20px 40px;
  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;
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) {
  .med-trouble__inner {
    max-width: 600px;
    padding: 30px clamp(0.9375rem, 0.6393129771rem + 1.272264631vw, 1.25rem) 40px;
  }
}
.med-trouble__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-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 11px;
}
.med-trouble__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(2rem, 1.4rem + 2.56vw, 3rem);
  line-height: 1.2;
  text-align: center;
  letter-spacing: 4.8px;
}
.med-trouble__heading {
  width: 100%;
  background-color: var(--text);
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.9rem + 0.96vw, 1.5rem);
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  padding: 0.95625rem 10px;
}
.med-trouble__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -webkit-column-gap: clamp(0.9375rem, -1.4138943249rem + 4.8923679061vw, 2.5rem);
     -moz-column-gap: clamp(0.9375rem, -1.4138943249rem + 4.8923679061vw, 2.5rem);
          column-gap: clamp(0.9375rem, -1.4138943249rem + 4.8923679061vw, 2.5rem);
}
@media (max-width: 768px) {
  .med-trouble__list {
    max-width: 480px;
    width: 100%;
    grid-template-columns: 1fr;
    margin-inline: auto;
  }
}
.med-trouble__item {
  max-width: 540px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  border-bottom: 1px solid var(--text);
  padding-block: 16.8px;
}
.med-trouble__check {
  min-width: 20px;
  aspect-ratio: 1/1;
  background: url(../images/icon-check.svg) no-repeat center center/contain;
  margin-top: 2.8px;
}
.med-trouble__text {
  font-family: "Zen Old Mincho", serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}

.med1__cavity-intro {
  text-align: center;
  margin-top: 30px;
}
.med1__cavity-sub {
  max-width: 1120px;
  width: 100%;
  color: var(--main-d);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.9rem + 0.96vw, 1.5rem);
  line-height: 1.2;
  text-align: center;
  border-bottom: 2px solid var(--main-d);
  margin: 40px auto 0;
  padding: 19px 10px;
}
.med1__cavity-bg {
  background-color: var(--base2);
  margin-top: 40px;
  padding-block: clamp(2.5rem, 1.75rem + 3.2vw, 3.75rem);
}
.med1__cavity-inner {
  max-width: 1120px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  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.25rem + 6.4vw, 3.75rem);
}
@media (max-width: 768px) {
  .med1__cavity-inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}
.med1__cavity-summary {
  font-size: clamp(0.8125rem, 0.7375rem + 0.32vw, 0.9375rem);
  white-space: pre-line;
}

.med6__diva {
  max-width: 1120px;
  width: 100%;
  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;
  margin-inline: auto;
}
.med6__diva-title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, 0.497553816rem + 1.5655577299vw, 1.75rem);
}
@media (max-width: 768px) {
  .med6__diva-title {
    font-size: clamp(1.125rem, 0.7671755725rem + 1.5267175573vw, 1.5rem);
  }
}
.med6__diva-desc {
  font-size: clamp(0.875rem, 0.8153625954rem + 0.2544529262vw, 0.9375rem);
  white-space: pre-line;
}
.med6__price-table {
  max-width: 1120px;
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  margin-inline: auto;
}
.med6__price-th, .med6__price-td {
  width: 50%;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(0.875rem, 0.686888454rem + 0.3913894325vw, 1rem);
  line-height: 2;
  text-align: center;
  vertical-align: middle;
  padding: 10px;
}
.med6__price-th {
  background-color: var(--text);
  color: #fff;
  font-weight: 400;
  border: 1px solid var(--text);
}
.med6__price-td {
  border: 1px solid var(--text);
}
.med6__diva-sub {
  max-width: 1120px;
  width: 100%;
  color: var(--main-d);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.9rem + 0.96vw, 1.5rem);
  line-height: 1.2;
  text-align: center;
  border-bottom: 2px solid var(--main-d);
  margin-inline: auto;
  padding: 19px 10px;
}
.med6__diva-bg {
  background-color: var(--base2);
  margin-top: 40px;
  padding-block: clamp(2.5rem, 1.75rem + 3.2vw, 3.75rem);
}
.med6__diva-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) {
  .med6__diva-inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}

.med5__trouble {
  margin-top: clamp(1.875rem, 1.6364503817rem + 1.0178117048vw, 2.125rem);
}
.med5__link {
  margin-inline: auto;
  padding-left: clamp(0.9375rem, -0.5534351145rem + 6.3613231552vw, 2.5rem);
}

.med4__method-bg {
  background-color: var(--base2);
  padding-block: clamp(2.5rem, 1.75rem + 3.2vw, 3.75rem);
}
.med4__method-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) {
  .med4__method-inner {
    padding: 0 clamp(1.25rem, 0.6536259542rem + 2.5445292621vw, 1.875rem);
  }
}

.med7__link {
  margin-inline: auto;
  padding-left: clamp(0.9375rem, -0.5534351145rem + 6.3613231552vw, 2.5rem);
}

/*###################################################################
  news（page）
###################################################################*/
.news-list_pos {
  margin-top: clamp(3.125rem, 2.5286259542rem + 2.5445292621vw, 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);
}
@media (max-width: 600px) {
  .news-list__items {
    row-gap: 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.5286259542rem + 2.5445292621vw, 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-family: "Zen Old Mincho", serif;
  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.5286259542rem + 2.5445292621vw, 3.75rem);
}
.page-404__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-bottom: 100px;
}
@media (max-width: 768px) {
  .page-404__inner {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) 100px;
  }
}
.page-404__title {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.75;
}
.page-404__text {
  white-space: pre-line;
  margin-top: 50px;
}
.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制御用）
###################################################################*/