@charset "utf-8";

/* Figma Styles of your File */
:root {
  /* Colors */
  --toda-recruit: linear-gradient(
    -82.41deg,
    rgba(229, 232, 255, 1) 0%,
    rgba(213, 237, 255, 1) 25.999999046325684%,
    rgba(230, 254, 255, 1) 62.00000047683716%,
    rgba(255, 250, 233, 1) 100%
  );
  --: linear-gradient(
    86.9deg,
    rgba(0, 64, 136, 1) 0%,
    rgba(123, 131, 213, 1) 100%
  );
  --: linear-gradient(
    56.81deg,
    rgba(237, 240, 255, 1) 0%,
    rgba(235, 247, 255, 1) 100%
  );
  --2: radial-gradient(
    closest-side,
    rgba(47, 116, 221, 1) 8.267606794834137%,
    rgba(5, 64, 153, 1) 49.11906123161316%
  );
  --22: radial-gradient(
    closest-side,
    rgba(47, 116, 221, 1) 8.267606794834137%,
    rgba(5, 64, 153, 1) 49.11906123161316%
  );
  --2: linear-gradient(
    255.07deg,
    rgba(241, 240, 255, 1) 0%,
    rgba(234, 245, 255, 1) 100%
  );

  /* Fonts */
  /* Effects */
  --button-tertiary-shadow: 2px 2px 8px 0px rgba(0, 0, 0, 0.2);
  --button-main-shadow: 2px 2px 12px 0px rgba(0, 0, 0, 0.1);
  --deco-box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.08);
  --1-box-shadow: 2px 2px 12px 0px rgba(0, 0, 0, 0.08);
  --2-box-shadow: 2px 2px 8px 0px rgba(0, 0, 0, 0.08);
  --accordion-box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.1);

  /* color */
  --color-main: #054c8e;
  --color-accent: #ed8a00;
  --color-base: #f3f9fe;
  --color-base2: #fff6e9;
  --color-base3: #ffffff;
  --color-bace4: #f3f5f8;
  --color-text: #3c3c3c;
  --color-text-sub: #666666;
  --color-line: #cacfd4;
  --color-titleline: #e6e8ea;
  --color-caution: #ffefef;
  --color-caution2: #ce1302;
  --color-tab-event: #0b7923;
  --color-tab-recruit: #362ea1;
}

html {
  scroll-padding-top: 120px;
}
@media screen and (max-width: 1200px) {
  html {
    scroll-padding-top: 60px;
  }
}

/***** style *****/
body {
  font-size: 16px;
	font-family: "Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Helvetica Neue","Meiryo",sans-serif;
	font-weight: 400;
	line-height: 1.5;
	color: #3c3c3c;
  text-wrap: wrap;
  font-feature-settings: "palt";
  position: relative;
}
body::after {
  content: "";
  display: block;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5);
  position: fixed;
  top: 0;
  left: 0;
  z-index: -10;
  opacity: 0;
}
body.body--fixed {
  height: 100%;
  overflow: hidden;
  position: relative;
}

.inner {
  width: min(92%,1200px);
  margin: auto;
}
.inner-s {
  width: min(92%,1000px);
  margin: auto;
}

.pc_none {
  display: none;
}
.pc_s_none {
  display: none;
}
.pc_s_view {
  display: block;
}
@media screen and (max-width: 1200px) {
  .pc_s_none {
    display: block;
  }
  .pc_s_view {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .pc_none {
    display: block;
  }
  .sp_none {
    display: none;
  }
}

button:focus-visible,
a:focus-visible {
  border: 2px solid #000 !important;
}

.header {
  background: var(--color-base3);
  padding: 20px 2% 0 2%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  height: 120px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  transition: top .5s;
}
.header--view {
  box-shadow: 0px 0px 16px 0px rgba(0, 0, 0, 0.24);
}
.header__logo {
  width: min(428px,30%);
  padding: 16px 0 0;
}
.header__logo-link {
  display: block;
}
@media (any-hover: hover) {
  .header__logo-link:hover {
    opacity: 0.7;
    transition: opacity 0.25s ease-in-out;
  }
}
.header__menu {
  display: none;
}
.nav {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-end;
}
.nav-over {
  display: flex;
  gap: 40px 24px;
  align-items: center;
  justify-content: flex-start;
}
.nav-over__sns {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: flex-start;
}
.nav-over__sns-icon {
  display: block;
  width: 36px;
}
@media (any-hover: hover) {
  .nav-over__sns-icon:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.nav-over__list {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: flex-start;
}
.nav-over__info-btn {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background: var(--color-base3);
  border-radius: 20px;
  border: 1px solid var(--color-main);
  padding: 4px 16px 4px 16px;
  box-shadow: var( --button-tertiary-shadow);
  color: var(--color-main);
  text-align: center;
  font-weight: 700;
}
.nav-over__info-btn.nav-over__info-btn-em {
  background: var(--color-main);
  color: var(--color-base3);
}
@media (any-hover: hover) {
  .nav-over__info-btn:hover {
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
    opacity: 0.7;
    transition: 0.15s ease-in-out;
    transition-property: box-shadow opacity;
  }
}
.nav-over__tel-link {
  display: block;
  color: var(--color-main);
  font-size: 28px;
  line-height: 1;
  font-weight: 700;
  padding: 0 0 0 32px;
  background: url(../images/icon_call_01.svg) no-repeat left center / 28px;
}
@media (any-hover: hover) {
  .nav-over__tel-link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.nav-main {
  display: flex;
  gap: 12px 4px;
  align-items: center;
  justify-content: flex-end;
}
.nav-main__link {
  display: block;
  padding: 20px 12px;
  font-weight: 700;
  position: relative;
  transition: color 0.25s ease-in-out;
  cursor: pointer;
}
.nav-main__link.nav-main__link-sp {
  display: none;
}
.nav-main__link::after {
  content: "";
  display: block;
  width: calc(100% - 24px);
  height: 5px;
  background: var(--color-main);
  margin: auto;
  position: absolute;
  bottom: 0;
  opacity: 0;
  transition: opacity 0.25s ease-in-out;
}
.nav-main__link:last-child {
  padding: 20px 0 20px 12px;
}
.nav-main__link:last-child::after {
  width: calc(100% - 12px);
}
.nav-main__link-btn {
  display: none;
}
@media (any-hover: hover) {
  .nav-main__link:hover,
  .nav-main__item:has(.nav-modal:hover) .nav-main__link {
    color: var(--color-main);
    transition: color 0.25s ease-in-out;
  }
  .nav-main__link:hover::after,
  .nav-main__item:has(.nav-modal:hover) .nav-main__link::after {
    opacity: 1;
    transition: opacity 0.25s ease-in-out;
  }
}

.nav-modal {
  width: 100%;
  background: var(--color-base3);
  border-top: 1px solid var(--color-line);
  position: absolute;
  top: 120px;
  left: 0;
  opacity: 0;
  visibility: hidden;
  transition: .2s ease-in-out;
  transition-property: visibility, opacity;
  pointer-events: none;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.24);
}
@media (any-hover: hover) {
  .nav-main__item:has(.nav-main__link:hover) .nav-modal,
  .nav-modal:hover {
    opacity: 1;
    visibility: visible;
    transition: .2s ease-in-out;
    transition-property: visibility, opacity;
    pointer-events: initial;
  }
  body:has(.nav-main__link:hover)::after,
  body:has(.nav-modal:hover)::after {
    opacity: 1;
    z-index: 5;
  }
}
.nav-modal__inner {
  width: min(92%, 1200px);
  margin: auto;
  padding: 60px 0 64px;
}
.nav-modal__head {
  padding: 0 0 20px;
  border-bottom: 1px solid var(--color-main);
}
.nav-modal__head-link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 20px;
  color: var(--color-main);
  font-size: 24px;
  font-weight: 700;
}
a.nav-modal__head-link::after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/icon_arr_link.svg) no-repeat center center / contain;
  transition: transform 0.2s ease-in-out;
}
@media (any-hover: hover) {
  .nav-modal__head-link:hover::after {
    transform: scale(1.1);
    transition: transform 0.2s ease-in-out;
  }
}
.nav-modal__list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 0 32px;
}
.nav-common__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 0 28px;
  min-height: 78px;
  border-bottom: 1px solid var(--color-line);
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
.nav-common__link::after {
  content: "";
  display: block;
  width: 28px;
  height: 28px;
  background: url(../images/icon_arr_link_nomal_01.svg) no-repeat center center / contain;
}
@media (any-hover: hover) {
  .nav-common__link:hover {
    background: var(--color-base);
    color: var(--color-main);
    transition: color 0.25s ease-in-out;
  }
}
.nav-modal__sub-block {
  padding: 44px 0 0;
}
.nav-modal__sub-ttl {
  color: var(--color-main);
  font-size: 22px;
  font-weight: 700;
}
.nav-modal__sub-ttl.cont__ttl-mark::before {
  background: var(--color-main);
}
.nav-modal__sub-list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 0 32px;
  padding: 16px 32px 0;
}

/* main */
.main {
  margin: 120px 0 0;
}
.mv {
  position: relative;
}
.mv-img {
  padding: 0 16px;
  position: relative;
}
.mv__slide {
  border-radius: 12px;
  overflow: hidden;
  opacity: 0;
}
.mv__slide.slick-slider {
  opacity: 1;
  transition: opacity 0.8s linear;
}
.mv__slide-img {
  aspect-ratio: 352/135;
  position: relative;
}
.mv__slide-img img {
  width: auto;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.mv__slide-animation {
  -webkit-animation: mv_slide 20s 0s forwards;
          animation: mv_slide 20s 0s forwards;
}
@-webkit-keyframes mv_slide {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100px);
  }
}
@keyframes mv_slide {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100px);
  }
}

.mv__copy {
  display: block;
  width: min(605px,43%);
  position: absolute;
  bottom: 36px;
  left: 2.7%;
}
.mv__btn {
  display: block;
  width: min(212px,15%);
  position: absolute;
  bottom: 10px;
  right: 2.2%;
  transition: transform 0.2s ease-in-out;
}
.mv__copy,
.mv__btn {
  opacity: 0;
  transform: translateY(20px)
}
.mv__copy.mv__copy--view,
.mv__btn.mv__btn--view {
  opacity: 1;
  transform: none;
  transition: 1s ease;
  transition-delay: 0.8s;
  transition-property: opacity, transform;
}
.mv__btn.mv__btn--view {
  transition-delay: 1.5s;
}
@media (any-hover: hover) {
  .mv__btn.mv__btn--view:hover {
    transform: scale(1.1);
    transition: transform 0.2s ease-in-out;
    transition-delay: 0;
  }
}
.mv-news {
  width: min(998px,92%);
  background: var(--color-caution);
  border-radius: 12px;
  padding: 16px;
  margin: 48px auto 0;
}
.mv-news__link {
  padding: 12px 24px 12px 92px;
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: flex-start;
  background: url(../images/icon_error.svg) no-repeat left 40px center / 36px;
}
@media (any-hover: hover) {
  .mv-news__link:hover {
    background: url(../images/icon_error.svg) no-repeat left 40px center / 36px, #fcdddd;
  }
}
.mv-news__date {
  color: var(--color-text-sub);
  font-size: 18px;
}
.mv-news__txt {
  font-weight: 500;
}
/* ttl */
.cont__ttl {
  padding: 0px 0px 40px 0px;
}
.page__ttl-txt {
  color: var(--color-main);
  font-size: 40px;
  font-weight: 700;
}
.cont__ttl-txt-en {
  color: var(--color-accent);
  font-size: 24px;
  letter-spacing: 0.1em;
}
.cont__block-list {
  display: grid;
  gap: 8px;
}
.cont__ttl-mark {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
}
.cont__ttl-mark::before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background: var(--color-accent);
  border-radius: 50%;
}
.cont__ttl-num {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  justify-content: flex-start;
  gap: 8px;
}
.cont__ttl-num-txt {
  background: var(--color-main);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--color-base3);
  font-size: 16px;
  font-weight: 500;
}
.cont__ttl-num-nomal {
  display: block;
  min-width: 20px;
  font-size: 16px;
  font-weight: 500;
  text-align: right;
}
.note-box .cont__ttl-mark::before {
  background: var(--color-caution2);
}
.cont__ttl-mark-s {
  align-items: flex-start;
  gap: 6px;
}
.cont__ttl-mark-s::before {
  width: 10px;
  height: 10px;
  margin: 9px 0 0;
}
.cont__ttl--vertical {
  display: grid;
  grid-template-columns: 60px 36px;
}
.cont__ttl--vertical .cont__ttl-txt {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.cont__ttl--vertical .cont__ttl-txt-en {
  min-width: 180px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  transform: rotate(90deg) translateY(-36px);
  transform-origin: 0 0;
}

.list-item-num {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 4px;
}
.list-item-num-txt {
  background: var(--color-main);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--color-base3);
  font-size: 16px;
  font-weight: 500;
}

/* btn */
.btn-center {
  width: fit-content;
  margin: 20px auto 0;
}

.btn-main {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-width: 340px;
  min-height: 78px;
  border-radius: 100vw;
  background: var(--color-base3,#ffffff);
  border: 2px solid var(--color-main);
  padding: 0 20px 0 36px;
  box-shadow: var(--button-main-shadow);
  font-size: 20px;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
  line-height: 1.3;
  position: relative;
  z-index: 2;
}
.btn-main::after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  z-index: 2;
  background: url(../images/icon_btn_arr_main.svg) no-repeat center center / contain;
  transition: transform 0.25s ease-in-out;
}
.btn-main.btn-main-sepatab {
  color: var(--color-text);
}
.btn-main.btn-main-sepatab::after {
  background-image: url(../images/icon_btn_sepatab_01.svg);
}
.btn-main:has(.btn-head-icon) {
  padding: 0 24px 0 20px;
}
.btn-main:has(.btn-head-icon) {
  color: var(--color-text);
}
.btn-main.btn-main-accent {
  border-color: var(--color-accent);
  color: var(--color-text);
}
.btn-main.btn-main-accent::after {
  background-image: url(../images/icon_btn_arr_trans_03.svg);
}
.btn-mail-txt {
  display: block;
  width: calc(100% - 80px);
  text-align: left;
}
@media (any-hover: hover) {
  .btn-main:hover:not(.cont-guide__link-other) {
    background: var(--color-main);
    color: var(--color-base3,#ffffff);
    transition: 0.25s ease-in-out;
  }
  .btn-main:hover {
    color: var(--color-base3,#ffffff);
  }
  .btn-main:hover::after {
    transform: scale(1.2);
    transition: transform 0.25s ease-in-out;
  }
  .btn-main-sepatab:hover::after {
    transform: scale(1);
    background-image: url(../images/icon_btn_sepatab_02.svg);
    background-image: transform 0.25s ease-in-out;
  }
  .btn-main.btn-main-accent:hover {
    background: var(--color-accent);
    color: var(--color-base3,#ffffff);
  }
  .btn-main.btn-main-accent:hover::after {
    background-image: url(../images/icon_btn_arr_trans_01.svg);
  }
}

.btn-trans {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 6px 12px 6px 32px;
  background: var(--color-main);
  border-radius: 50px;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-base3);
  border: 2px solid var(--color-main);
  box-shadow: var(--button-tertiary-shadow);
  transition: box-shadow 0.25s ease-in-out;
}
.btn-trans::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(../images/icon_btn_arr_trans_01.svg) no-repeat center center / contain;
}
.btn-trans.btn-sepatab::after {
  gap: 12px;
  padding: 6px 16px 6px 32px;
  background-image: url(../images/icon_bnr_sepatab_02.svg);
}
@media (any-hover: hover) {
  .btn-trans:hover {
    background: var(--color-base3);
    color: var(--color-main);
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
    transition: box-shadow 0.25s ease-in-out;
  }
  .btn-trans:hover::after {
    background: url(../images/icon_btn_arr_trans_02.svg) no-repeat center center / contain;
  }
  .btn-trans.btn-sepatab:hover::after {
    background-image: url(../images/icon_bnr_sepatab_01.svg);
  }
}
.btn-icon {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 6px 12px 6px 32px;
  background: var(--color-base3);
  border-radius: 50px;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-main);
  border: 2px solid var(--color-main);
  box-shadow: var(--button-tertiary-shadow);
  transition: box-shadow 0.25s ease-in-out;
  cursor: pointer;
}
.btn-icon::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(../images/icon_btn_arr_trans_02.svg) no-repeat center center / contain;
}
.btn-icon-pdf {
  padding: 6px 24px 6px 32px;
}
.btn-icon-pdf::after {
  background: url(../images/icon_btn_pdf_01.svg) no-repeat center center / contain;
}
.btn-icon-movie::after,
.btn-icon-audio::after {
  content: none;
}
.btn-icon-movie,
.btn-icon-audio {
  gap: 8px;
  padding: 6px 24px 6px 16px;
}
.audio-wrap {
  display: none;
}
.audio {
  display: none;
  width: 100%;
  min-height: 68px;
}
.btn-icon-movie {
  background: var(--color-main);
  color: var(--color-base3);
}
.btn-icon-movie::before,
.btn-icon-audio::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
}
.btn-icon-movie::before {
  background: url(../images/icon_btn_movie_02.svg) no-repeat center center / contain;
}
.btn-icon-audio::before {
  background: url(../images/icon_btn_audio_01.svg) no-repeat center center / contain;
}
.btn-icon-line {
  border-color: #07b53b;
  color: #07b53b;
}
.btn-icon-line::after {
  background: url(../images/icon_btn_arr_line.svg) no-repeat center center / contain;
}
.btn-icon-book {
  gap: 8px;
  padding: 6px 24px 6px 16px;
}
.btn-icon-book::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(../images/icon_btn_book_01.svg) no-repeat center center / contain;
}
.btn-icon-book::after {
  content: none;
}
@media (any-hover: hover) {
  .btn-icon:hover {
    background: var(--color-main);
    color: var(--color-base3);
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
    transition: box-shadow 0.15s ease-in-out;
  }
  .btn-icon:hover::after {
    background: url(../images/icon_btn_arr_trans_01.svg) no-repeat center center / contain;
  }
  .btn-icon-pdf:hover::after {
    background: url(../images/icon_btn_pdf_02.svg) no-repeat center center / contain;
  }
  .btn-icon-line:hover {
    background: #07b53b;
  }
  .btn-icon-movie:hover {
    background: var(--color-base3);
    color: var(--color-main);
  }
  .btn-icon-movie:hover::before {
    background: url(../images/icon_btn_movie_01.svg) no-repeat center center / contain;
  }
  .btn-icon-audio:hover::before {
    background: url(../images/icon_btn_audio_02.svg) no-repeat center center / contain;
  }
  .btn-icon-book:hover::before {
    background: url(../images/icon_btn_book_02.svg) no-repeat center center / contain;
  }
}

.page__link-sub {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
  padding: 6px 0;
  color: var(--color-text);
}
.page__link-sub::before {
  content: "";
  display: block;
  background: var(--color-main);
  width: 10px;
  height: 1px;
}
@media (any-hover: hover) {
  .page__link-sub:hover {
    color: var(--color-main);
    transition: color 0.25s ease-in-out;
  }
  .page__link-sub:hover::before {
    transform: translateX(4px);
    transition: transform 0.25s ease-in-out;
  }
}

.cont-guide {
  margin: 72px 0 0 0;
  padding: 0 0 60px;
  position: relative;
}
.cont-guide::after {
  content: "";
  display: block;
  background: var(--color-base);
  border-radius: 180px 0px 0px 12px;
  width: min(
          calc(1200px - 82px + ((100vw - 1200px) / 2)),
          calc(100vw - 4% - 82px)
         );
  height: calc(100% - 36px);
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -1;
}
.cont-guide__list-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.cont-guide__item-main {
  width: 19%;
  box-shadow: var( --button-main-shadow);
  border-radius: 8px;
  overflow: hidden;
}
.cont-guide__img {
  display: block;
  border-radius: 8px 8px 0 0;
  overflow: hidden;
  position: relative;
}
.cont-guide__img::after {
  content: "";
  width: 100%;
  height: 19%;
  border-radius: 32px 8px 0 0;
  background: var(--color-base3);
  position: absolute;
  bottom: 0;
  left: 0;
}
.cont-guide__img img {
  aspect-ratio: 55/43;
  transition: transform 0.25s ease-in-out;
}
.cont-guide__box {
  display: grid;
  justify-items: center;
  background: var(--color-base3);
  border-radius: 0 0 8px 8px;
  padding: 36px 12px 24px 12px;
  position: relative;
}
.cont-guide__head {
  margin: 0 0 20px 0;
}
.cont-guide__icon {
  width: 24%;
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translate(-50%);
  z-index: 2;
}
.cont-guide__ttl {
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.05em;
  font-weight: 700;
  line-height: 1.3;
}
.cont-guide__txt {
  text-align: center;
  font-size: 14px;
}
.cont-guide__hover-main {
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  mix-blend-mode: multiply;
}
.cont-guide__hover-main::before,
.cont-guide__hover-main::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin: auto;
  background: var(--color-main);
  border-radius: 100%;
  position: absolute;
  transform: translateX(-50%) translateY(-50%);
  opacity: 0;
  transition-property: opacity, width, height;
  transition-duration: 0.45s;
  transition-timing-function: cubic-bezier(0,.7,.59,.99)
}
.cont-guide__link {
  position: relative;
}
.cont-guide__link::after {
  content: "";
  inset: 0;
  width: 0;
  height: 0;
  margin: auto;
  border-radius: 100%;
  background: var(--color-base3,#ffffff);
  transition: 0.4s ease-in-out;
  transition-property: opacity, width, height;
  transition-duration: 0.3s;
  transition-delay: 0.4s;
  opacity: 0;
  transition-timing-function: ease-in-out;
  position: absolute;
  top: 30px;
  z-index: 1;
}
.cont-guide__item-main:nth-child(1) .cont-guide__hover-main::before {
  background: #fdd8e6;
}
.cont-guide__item-main:nth-child(1) .cont-guide__hover-main::after {
  background: #ffb8d3;
}
.cont-guide__item-main:nth-child(2) .cont-guide__hover-main::before {
  background: #ffe7a4;
}
.cont-guide__item-main:nth-child(2) .cont-guide__hover-main::after {
  background: #ffcf70;
}
.cont-guide__item-main:nth-child(3) .cont-guide__hover-main::before {
  background: #bae4bd;
}
.cont-guide__item-main:nth-child(3) .cont-guide__hover-main::after {
  background: #81d388;
}
.cont-guide__item-main:nth-child(4) .cont-guide__hover-main::before {
  background: #b0d4f3;
}
.cont-guide__item-main:nth-child(4) .cont-guide__hover-main::after {
  background: #7ab8ef;
}
.cont-guide__item-main:nth-child(5) .cont-guide__hover-main::before {
  background: #e4cfe9;
}
.cont-guide__item-main:nth-child(5) .cont-guide__hover-main::after {
  background: #d3a6df;
}
@media (any-hover: hover) {
  .cont-guide__link:hover::after {
    width: 60px;
    height: 60px;
    opacity: 1;
  }
  .cont-guide__link:hover .cont-guide__img img {
    transform: scale(1.05);
    transition: transform 0.3s ease-in-out;
    transition-delay: 0.1s;
  }
  .cont-guide__link:hover .cont-guide__hover-main::before,
  .cont-guide__link:hover .cont-guide__hover-main::after {
    width: 700px;
    height: 700px;
    opacity: 1;
  }
  .cont-guide__link:hover .cont-guide__hover-main::after {
    transition-delay: 0.2s;
  }
}
.cont-guide__list-other {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 20px 2%;
  margin: 44px 0 0;
}
.cont-guide__item-other {
  width: 32%;
}
.cont-guide__item-other .cont-guide__link::after {
  top: 0;
  left: calc(-100% + 80px);
}
.cont-guide__link-other.btn-main {
  border: none;
}
.cont-guide__hover-other {
  display: block;
  position: absolute;
  top: 50%;
  right: 100%;
  transform: translateY(-50%);
  z-index: -1;
}
.cont-guide__hover-other::before,
.cont-guide__hover-other::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin: auto;
  background: var(--color-main);
  border-radius: 100%;
  position: absolute;
  transform: translateX(-50%) translateY(-50%);
  opacity: 0;
  transition-property: opacity, width, height;
  transition-duration: 0.3s;
  transition: 0.6s ease-in-out;
}
.cont-guide__item-other .cont-guide__hover-other::before {
  background: #779fc5;
}
.cont-guide__item-other .cont-guide__hover-other::after {
  background: #054c8e;
}
.btn-main:has(.cont-guide__hover-other) {
  overflow: hidden;
}
.btn-main:has(.cont-guide__hover-other) {
  transition: color 0.25s ease-in-out;
}
@media (any-hover: hover) {
  .cont-guide__link-other:hover .cont-guide__hover-other::before,
  .cont-guide__link-other:hover .cont-guide__hover-other::after {
    width: 100vw;
    height: 100vw;
    opacity: 1;
  }
  .cont-guide__link-other:hover .cont-guide__hover-other::after {
    transition-delay: 0.25s;
  }
  .btn-main:has(.cont-guide__hover-other):hover {
    color: var(--color-base3,#ffffff);
    transition: color 0.25s ease-in-out;
  }
}

.cont-feature {
  margin: 140px 0 0;
}
.cont-feature-inner {
  padding: 52px 0 0;
  position: relative;
}
.cont-feature__main-ttl {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}
.cont-feature__block {
  position: relative;
}
.cont-feature__block-02 {
  padding: 0 0 124px 0;
}
.cont-feature__txtarea {
  display: grid;
  gap: 28px;
  width: 62%;
  background: var(--color-base);
}
.cont-feature__txtarea-01 {
  margin: 0 0 0 33%;
  padding: min(10vw,190px) 84px 194px 160px;
  border-radius: 12px 180px 12px 12px;
}
.cont-feature__txtarea-02 {
  margin: 120px 0 0 0;
  padding: min(10vw,190px) 160px 190px 84px;
  border-radius: 180px 12px 12px 12px;
}
.cont-feature__txtarea-03 {
  margin: 140px 0 0 33%;
  padding: min(10vw,190px) 84px 194px 160px;
  border-radius: 12px 180px 12px 12px;
}
.cont-feature__ttl {
  font-size: 28px;
  font-weight: 700;
  color: var(--color-main);
  position: relative;
}
.cont-feature__deco {
  width: 133px;
  position: absolute;
  top: -50px;
  left: -24px;
}
.cont-feature__txt {
  display: block;
  line-height: 1.8;
}
.cont-feature__imgl {
  width: 46%;
  overflow: hidden;
  position: absolute;
  bottom: 40px;
  box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.08);
}
.cont-feature__imgl-01,
.cont-feature__imgl-03 {
  border-radius: 0 8px 8px 0;
  left: min(calc((100vw - 1200px) / 2 * -1), -4vw);
}
.cont-feature__imgl-02 {
  border-radius: 8px 0 0 8px;
  right: min(calc((100vw - 1220px) / 2 * -1), -4%);
}
.cont-feature__imgs {
  width: 26%;
  overflow: hidden;
  position: absolute;
  box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.08);
}
.cont-feature__imgs-01,
.cont-feature__imgs-03 {
  border-radius: 8px 0 0 8px;
  bottom: 40px;
  right: min(calc((100vw - 1220px) / 2 * -1), -4%);
}
.cont-feature__imgs-02-1 {
  border-radius: 0 8px 8px 0;
  bottom: 80px;
  left: min(calc((100vw - 1200px) / 2 * -1), -4vw);
}
.cont-feature__imgs-02-2 {
  border-radius: 8px;
  bottom: 0;
  left: 18%;
}
.cont-feature__bnr-list {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px 2%;
  margin: 120px auto 0;
}
.cont-feature__bnr-item {
  width: 49%;
  position: relative;
}
.cont-feature__bnr-item::after {
  content: "";
  width: 57%;
  height:43%;
  margin: auto;
  border-radius: 50%;
  background: #000000;
  box-shadow: 0 0 50px #000000;
  opacity: 16%;
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  right: 0;
}
.cont-news {
  margin: 176px 0 0;
  padding: 100px 0 92px;
  position: relative;
}
.cont-news::before {
  content: "";
  display: block;
  width: calc(100vw - 32px);
  height: 8px;
  background: var(--color-base);
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}
.cont-news-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0 80px;
}
.cont-news__block .btn-trans {
  margin: 24px 0 0 auto;
}
.cont-news__item {
  border-top: 1px solid var(--color-line);
}
.cont-news__item:last-child {
  border-bottom: 1px solid var(--color-line);
}
.cont-news__link {
  padding: 32px 24px;
  display: grid;
  gap: 12px;
}
@media (any-hover: hover) {
  .cont-news__link:hover {
    color: var(--color-main);
    box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.16);
    transition: box-shadow 0.25s ease-in-out;
  }
}
.cont-news__head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 4px 12px;
}
.cont-news__head-cat {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 4px 12px;
}
.cont-news__date {
  color: #949494;
  font-size: 18px;
}
.cont-news__label {
  display: inline-block;
  border-radius: 16px;
  border: 1px solid var(--color-main);
  color: var(--color-main);
  padding: 3px 20px;
  text-align: center;
  font-weight: 700;
}
.cont-news__label-caution {
  color: var(--color-caution2);
  border-color: var(--color-caution2);
}
.cont-news__label-event {
  color: var(--color-tab-event);
  border-color: var(--color-tab-event);
}
.cont-news__label-recruit {
  color: var(--color-tab-recruit);
  border-color: var(--color-tab-recruit);
}
.cont-info-inner {
  position: relative;
  padding: 0 0 100px;
}
.cont-info-inner::after {
  content: "";
  display: block;
  width: calc(100vw - 32px);
  height: calc(100% - 32px);
  margin: auto;
  background: var(--color-base);
  border-radius: 12px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.cont-info__ttl {
  display: grid;
  justify-items: center;
  padding: 0 0 40px;
}
.cont-info__ttl-txt {
  color: var(--color-main);
  font-size: 40px;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-align: center;
}
.cont-info__ttl-txt-en {
  color: var(--color-accent);
  font-size: 24px;
  letter-spacing: 0.1em;
  text-align: center;
}
.cont-info__column {
  display: grid;
  grid-template-columns: 67% 1fr;
  gap: 24px;
}
.cont-info__block {
  background: #ffffff;
  border-radius: 12px 100px 12px 12px;
  box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.04);
  padding: 40px;
}
.cont-info__block-ttl {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 24px;
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  position: relative;
  z-index: 1;
}
.cont-info__block-ttl::after {
  content: "";
  display: block;
  width: 80px;
  height: 80px;
  position: absolute;
  top: 50%;
  left: -60px;
  transform: translateY(-50%);
  z-index: -1;
}
.cont-info__block-ttl-time::after {
  background: url(../images/top_info_icon_time.svg) no-repeat center center / contain;
}
.cont-info__block-ttl-access::after {
  background: url(../images/top_info_icon_access.svg) no-repeat center center / contain;
}
.cont-info__block-inner {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 24px 40px;
}
.cont-info__table-txt {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
}
.table-ttl {
  min-height: 44px;
  margin: 0 0 12px;
  color: var(--color-main);
  font-size: 22px;
  font-weight: 700;
}
.table-ttl .btn-trans {
  margin: 0 0 0 8px;
}
.table-row {
  border-style: solid;
  border-color: var(--color-line);
  border-width: 1px 1px 0 1px;
  display: flex;
  gap: 0px;
  align-items: stretch;
  justify-content: flex-start;
}
.table-row:last-child {
  border-width: 1px;
}
.table-head {
  display: flex;
  align-items: center;
  justify-content: center;
  width: max(138px,36%);
  background: var(--color-base);
  border-right: 1px solid var(--color-line);
  padding: 10px 8px;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
}
.table-data {
  width: 75%;
  background: #ffffff;
  padding: 10px 24px;
  font-size: 16px;
  line-height: 170%;
  font-weight: 500;
}
.table-data.font-en {
  font-size: 18px;
}
.cont-info__table .table-data {
  font-size: 22px;
  text-align: center;
}
.table-txt-sup {
  display: block;
  padding: 8px 0 0 1em;
  text-indent: -1em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 0 0 auto;
}
.cont-info__btn {
  display: grid;
  gap: 4px;
  justify-items: center;
  text-align: center;
  margin: 20px 0 0;
  border-radius: 50px;
  border: 2px solid var(--color-main);
  padding: 12px 28px 12px 68px;
  box-shadow: var(
    --button-main-box-shadow,
    2px 2px 12px 0px rgba(0, 0, 0, 0.1)
  );
  line-height: 1.2;
  font-weight: 700;
  background: url(../images/icon_call_01.svg) no-repeat left 20px center / 40px, var(--color-base3);
  transition: 0.25s ease-in-out;
}
.cont-info__btn-num {
  text-align: center;
  font-size: 30px;
  line-height: 1;
  font-weight: 600;
}
@media (any-hover: hover) {
  .cont-info__btn:hover {
    background: url(../images/icon_call_02.svg) no-repeat left 20px center / 40px, var(--color-main);
    color: var(--color-base3);
    transition: 0.25s ease-in-out;
  }
}
.cont-info__map {
  max-width: 100%;
  aspect-ratio: 5/3;
}
.cont-info__map iframe {
  width: 100%;
  height: 100%;
}
.info__map-address {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 16px auto 0;
}
.info__map-link {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 8px 0 0 auto;
}
.info__map-btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 20px auto 0;
}
.cont-other {
  padding: 132px 0 0;
}
.cont-other__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px 2%;
}
.cont-other__item {
  display: block;
  width: 32%;
}
.cont-other__link {
  display: block;
  border-radius: 8px;
  border: 1px solid var(--color-line);
  overflow: hidden;
  position: relative;
}
.cont-other__link-icon {
  display: block;
  width: min(10%, 40px);
  margin: auto 16px auto auto;
  border-radius: 50%;
  box-shadow: var(--button-tertiary-shadow);
  position: absolute;
  inset: 0;
}
@media (any-hover: hover) {
  .cont-other__link:hover {
    opacity: 0.7;
    transition: opcity 0.25s ease-in-out;
  }
  .cont-other__link:hover .cont-other__link-icon {
    transform: scale(1.2);
    transition: transform 0.25s ease-in-out;
  }
}
.cont-other__recruit {
  display: grid;
  grid-template-columns: 40% 1fr;
  margin: 60px 0 0;
  border-radius: 12px;
  overflow: hidden;
}
.cont-other__recruit-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  background: var(--color-main);
  padding: 0 0 0 15%;
}
.cont-other__recruit-ttl .cont__ttl-txt,
.cont-other__recruit-ttl .cont__ttl-txt-en {
  color: var(--color-base3,#ffffff);
}
.cont-other__recruit-ttl .cont__ttl-mark::before {
  background: var(--color-base3,#ffffff);
}
.cont-other__recruit-txt {
  font-size: 20px;
  font-weight: 500;
  color: var(--color-base3,#ffffff);
}
.cont-other__recruit-btn {
  margin: 20px 0 0;
}
@media (any-hover: hover) {
  .cont-other__recruit-btn .btn-main:hover {
    border-color: var(--color-base3,#ffffff);
  }
}
.cont-other__recruit-slide {
  display: flex;
  height: 100%;
  overflow: hidden;
}
.cont-other__recruit-slide-img {
  -webkit-animation: scroll-left 80s infinite linear .5s both;
          animation: scroll-left 80s infinite linear .5s both;
  width: min(290vw,4200px);
}
@-webkit-keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.cont-other__recruit-slide-img img {
  height: 100%;
}
.cont-other__bnr-slide {
  margin: 190px 0 72px;
}
.cont-other__bnr {
  box-shadow: var(--button-tertiary-shadow);
}
.cont-other__bnr-slide .slick-slide {
  margin: 0 10px;
  transition: transform 0.3s ease-in-out;
  transform: scale(.82);
}
.cont-other__bnr-slide .slick-list {
  padding-top: 8px!important;
  padding-bottom: 8px!important;
}
.cont-other__bnr-slide .slick-center {
  transition: transform 0.3s ease-in-out;
  transform: scale(1);
}
.slick-arrow {
  width: 40px;
  cursor: pointer;
  margin: auto;
  box-shadow: var(--button-tertiary-shadow);
  border-radius: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
}
.prev-arrow {
  transform: rotate(180deg);
  left: 0;
  box-shadow: -2px -2px 8px 0px rgba(0, 0, 0, 0.2);
}
.next-arrow {
  right: 0;
}
.cont-other__bnr-slide .prev-arrow {
  left: 38%;
}
.cont-other__bnr-slide .next-arrow {
  right: 38%;
}

.modaal-content {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.modaal-content iframe {
  width: 100%;
  height: 100%;
}
.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
  background: var(--color-main);
}
.modaal-gallery-item img {
  max-width: 100vw;
  max-height: 85vh;
}

/* page */
/* common */
.page-mv-img {
  height: 320px;
  position: relative;
  overflow: hidden;
  background: url(../images/main_img_common.jpg) no-repeat center top / cover;
}
.page-mv-img::after {
  content: "";
  display: block;
  width: 100%;
  height: 120px;
  background: var(--color-base3);
  border-radius: 80px 0 0 0;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
}
.breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin: 0 0 80px;
  padding: 20px 0 0;
}
.breadcrumb__item:not(:last-child) {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.breadcrumb__item:not(:last-child)::after {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-bottom: 1px solid var(--color-text);
  border-right: 1px solid var(--color-text);
  transform: rotate(-45deg);
}
.breadcrumb__link {
  display: block;
  font-size: 14px;
  font-weight: 500;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .breadcrumb__link:hover {
    text-decoration: none;
  }
}
.breadcrumb__txt {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-main);
}
.page__main-ttl {
  color: var(--color-main);
  font-size: 44px;
  font-weight: 700;
}
.page-head {
  margin: -120px auto 0;
  padding: 0 0 90px;
  position: relative;
  z-index: 1;
}
.main:has(.page-mv + .inner-s) .page-head.inner {
  width: min(92%, 1000px);
}

.page-top__txt {
  margin: 0 0 60px;
  padding: 4px 0 4px 20px;
  font-weight: 500;
  line-height: 1.8;
  position: relative;
}
.page-top__txt::before {
  content: "";
  display: block;
  width: 3px;
  height: 100%;
  background: var(--color-main);
  border-radius: 2px;
  position: absolute;
  top: 0;
  left: 0;
}
.page-nav__list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 42px;
  padding: 0 0 100px;
}
.page-nav__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-line);
}
.page-nav__img {
  display: block;
  aspect-ratio: 3 / 2;
  overflow: hidden;
}
.page-nav__main {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 12px;
  position: relative;
}
.page-nav__txt {
  display: block;
  width: calc(100% - 40px);
  padding: 0 0 0 20px;
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.05em;
  font-weight: 700;
  line-height: 1.3;
}
.page-nav__main:not(:has(.page-nav__arr)) .page-nav__txt {
  width: 100%;
  padding: 0;
}
.page-nav__arr {
  display: block;
  width: 40px;
  height: 40px;
  margin: auto 12px auto auto;
  position: absolute;
  inset: 0;
  transition: transform 0.25s ease-in-out;
}
@media (any-hover: hover) {
  a.page-nav__main:hover .page-nav__txt {
    text-decoration: none;
  }
  a.page-nav__main:hover .page-nav__arr {
    transform: scale(1.1);
    transition: transform 0.25s ease-in-out;
  }
}
.page-nav__item:has(.page-nav__btn) .common-txt {
  padding: 0 24px 12px;
}
.page-nav__btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto auto 0;
  padding: 0 24px 16px;
}
.page-nav__item .page__slide .slick-list {
  border-radius: 8px 8px 0 0;
}
.page-nav__item .page__slide .next-arrow {
  right: 24px;
}
.page-nav__item .page__slide .prev-arrow {
  left: 24px;
}
.sub-nav__block {
  padding: 80px 0 100px;
  background: var(--color-base);
  border-radius: 0 120px 0 0;
}
.sub-nav__ttl {
  color: var(--color-main);
  font-size: 28px;
  font-weight: 700;
}
.sub-nav__list {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 0 40px;
  margin: 20px 0 0;
}

.page__container {
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  justify-content: space-between;
  grid-template-columns: 240px 1fr;
  gap: 32px 120px;
  min-height: 100vh;
  padding: 0 0 120px;
}
.sidebar-nav {
  width: 240px;
  padding: 16px 0 120px;
  position: -webkit-sticky;
  position: sticky;
  top: 120px;
}
.sidebar-nav__ttl {
  padding: 0 0 12px;
  color: var(--color-main);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
}
.sidebar-nav__btn {
  display: none;
  pointer-events: none;
}
.sidebar-nav__list {
  display: grid;
  gap: 4px;
  padding: 0 0 0 26px;
}
.sidebar-nav__link {

  display: grid;
  grid-template-columns: 1fr 24px;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  font-weight: 700;
}
.sidebar-nav__link::after {
  content: "";
  display: block;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--color-main);
  background: url(../images/icon_arr_down_02.svg) no-repeat center center / 20px;
}
@media (any-hover: hover) {
  .sidebar-nav__link:hover {
    color: var(--color-main);
  }
  .sidebar-nav__link:hover::after {
    color: var(--color-main);
    background: url(../images/icon_arr_down_01.svg) no-repeat center center / 20px, var(--color-main);
    transform: scale(1.2);
    transition: transform 0.25s ease-in-out;
  }
}
.sidebar-child__list {
  padding: 8px 0 0;
}
.sidebar-child__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 20px 0;
  font-size: 16px;
  font-weight: 700;
  border-top: 1px solid var(--color-line);
  transition: color 0.25s ease-in-out;
}
.sidebar-child__link::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(../images/icon_btn_arr_trans_02.svg) no-repeat center center / contain;
  transition: transform 0.25s ease-in-out;
}
@media (any-hover: hover) {
  .sidebar-child__link:hover {
    background: var(--color-base);
    transition: 0.25s ease-in-out;
  }
  .sidebar-child__link:hover::after {
    transform: scale(1.2);
    transition: transform 0.25s ease-in-out;
  }
}
.page__container .page__contents {
  width: calc(100% - 360px);
  padding: 0;
}
.page__contents {
  padding: 0 0 120px;
}
.page__block:not(:last-child) {
  margin: 0 0 80px;
}

.ttl-main,
.news__content h1 {
  padding: 0 0 20px;
  margin: 0 0 40px;
  color: var(--color-main);
  font-size: 34px;
  font-weight: 700;
  line-height: 1.3;
  position: relative;
}
.news__content h1:not(:first-child) {
  margin: 60px 0 40px;
}
.ttl-main::after,
.news__content h1::after {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-main) 0, var(--color-main) 64px, var(--color-titleline) 65px, var(--color-titleline) 100%);
  position: absolute;
  bottom: 0;
  left: 0;
}
.ttl-main-sub {
  font-size: 22px;
}

.ttl-sec,
.news__content h2 {
  margin: 28px 0 20px;
  padding: 8px 12px 8px 32px;
  background: var(--color-base);
  border-radius: 8px;
  color: var(--color-main);
  font-size: 24px;
  font-weight: 700;
  position: relative;
}
.ttl-sec::before,
.news__content h2::before {
  content: "";
  display: block;
  width: 3px;
  height: calc(100% - 28px);
  background: var(--color-main);
  border-radius: 2px;
  position: absolute;
  top: 14px;
  left: 12px;
}
.ttl-sec:has(.ttl-sec-num) {
  padding: 8px 12px;
}
.ttl-sec:has(.ttl-sec-num)::before {
  content: none;
}
.ttl-sec-num {
  font-size: 28px;
  font-weight: 500;
}
.ttl-sec + * {
  padding: 0 0 0 32px;
}
.ttl-sec:has(.ttl-sec-num) + * {
  padding: 0 0 0 40px;
}

.ttl-num {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
  color: var(--color-main);
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
}
.ttl-num-txt {
  background: var(--color-main);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: var(--color-base3);
  font-size: 24px;
  font-weight: 700;
}
.ttl-num + * {
  padding: 12px 0 0 52px;
}

.ttl-obi {
  margin: 0 0 32px;
  padding: 10px;
  background: var(--color-main);
  border-radius: 8px;
  color: var(--color-base3);
  font-size: 34px;
  font-weight: 700;
  text-align: center;
}

.ttl-obi-02 {
  padding: 10px 20px;
  background: var(--color-base2);
  border-radius: 8px;
  color: var(--color-text);
  font-size: 18px;
  font-weight: 700;
}

.ttl-deco {
  padding: 0 0 12px;
  color: var(--color-main);
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  position: relative;
}
.ttl-deco::after {
  content: "";
  display: block;
  width: 32px;
  height: 3px;
  margin: auto auto 0;
  background: var(--color-accent);
  border-radius: 2px;
  position: absolute;
  inset: 0;
}

.ttl-line {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 16px;
  margin: 16px 0 12px;
  color: var(--color-main);
  font-size: 22px;
  font-weight: 700;
}
.ttl-line::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: var(--color-line);
}

.ttl-nomal,
.news__content h3 {
  margin: 16px 0 12px;
  color: var(--color-main);
  font-size: 22px;
  font-weight: 700;
}

.intro {
  display: grid;
  gap: 28px;
  margin: 0 0 60px;
}
.intro__message {
  background: var(--color-base2);
  border-radius: 12px;
  padding: 24px 12px;
  text-align: center;
  font-size: 34px;
  font-weight: 500;
}
.intro__message.intro__message-s {
  font-size: 24px;
  line-height: 1.7;
}
.intro__message-subhead {
  display: block;
  margin: 0 0 12px;
  font-size: 20px;
  text-align: center;
  font-weight: 500;
  color: var(--color-text);
}
.intro__message-sub {
  display: block;
  padding: 8px 0 0;
  font-size: 16px;
}
.intro__txt {
  display: block;
  font-size: 16px;
  line-height: 1.8;
}

.base-block {
  background: var(--color-base);
  border-radius: 12px;
  padding: 20px 32px;
}
.base-block-2 {
  background: var(--color-base2);
  border-radius: 12px;
  padding: 24px 32px;
}
.base-block-ttl {
  display: block;
  width: fit-content;
  padding: 4px 16px;
  margin: 0 0 12px;
  background: var(--color-main);
  border-radius: 60px;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-base3);
  text-align: center;
}

.txt-common {
  font-size: 16px;
  line-height: 1.8;
}
.txt-em {
  color: var(--color-main);
}
.txt-medium {
  font-weight: 500;
}
.txt-bold {
  font-weight: 700;
}
.txt-note {
  color: var(--color-caution2);
}
.txt-line {
  text-decoration: underline;
}
.txt-indent {
  padding-left: 1em;
  text-indent: -1em;
}
.txt-para {
  padding-top: 1em;
}
.txt-center {
  text-align: center;
}
.txt-link {
  cursor: pointer;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .txt-link:hover {
    text-decoration: none;
  }
}
.font-en {
  font-family: "Jost", sans-serif;
  font-feature-settings: "palt";
}

/* form */
.form-label {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  width: fit-content;
  cursor: pointer;
}
.form-input[type="checkbox"] {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 1px solid var(--color-line);
  border-radius: 3px;
  position: relative;
}
.form-input[type="checkbox"]:checked::after {
  content: "";
  display: block;
  width: 18px;
  height: 10px;
  border-left: 3px solid var(--color-accent);
  border-bottom: 3px solid var(--color-accent);
  border-radius: 1px;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
.form-input[type="radio"] {
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid var(--color-line);
  position: relative;
}
.form-input[type="radio"]:checked::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-main);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}

.flow__box {
  background: var(--color-base);
  padding: 32px 40px;
  border-radius: 12px;
}
.flow__list > li:not(:first-child) {
  margin: 32px 0 0;
  position: relative;
}
.flow__list > li:not(:first-child)::before {
  content: "";
  display: block;
  width: 24px;
  height: 14px;
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
  background: var(--color-line);
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
}
.flow__other-list > li:not(:first-child) {
  margin: 32px 0 0;
}
.flow__box-inner {
  display: grid;
  grid-template-columns: auto 1fr;
}
.flow__num {
  display: block;
  margin: 0 40px 0 0;
  padding: 0 40px 0 0;
  border-right: 1px solid var(--color-line);
  font-size: 40px;
  font-weight: 500;
  color: var(--color-main);
  line-height: 1;
}
.flow__ttl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 4px 12px;
  margin: 0 0 16px;
  color: var(--color-main);
  font-size: 24px;
  line-height: 1.2;
  font-weight: 700;
}
.flow__ttl-label {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 4px 12px;
  border: 1px solid var(--color-main);
  border-radius: 4px;
  font-size: 16px;
  color: var(--color-main);
  font-weight: 700;
}
.flow__main .txt-common {
  margin: 16px 0 0;
}
.flow__main .btn-trans {
  margin: 16px 0 0;
}
.flow__main .cont__block-list {
  margin: 16px 0 0;
}
.flow__inner {
  display: grid;
  grid-template-columns: repeat(2,auto);
  gap: 20px 36px;
  align-items: flex-end;
  justify-content: center;
  margin: 16px 0 0;
  padding: 16px;
  background: var(--color-base3);
  border-radius: 12px;
}

.flow-time__list {
  margin: 0 0 60px;
  position: relative;
}
.flow-time__list::before {
  content: "";
  display: block;
  width: 4px;
  height: 100%;
  background: var(--color-line);
  border-radius: 2px;
  position: absolute;
  top: 0;
  left: 46px;
  z-index: -1;
}
.flow-time__item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 32px;
}
.flow-time__item:not(:first-child) {
  margin: 48px 0 0;
}
.flow-time__label {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--color-main);
  border-radius: 50%;
  width: 96px;
  height: 96px;
  color: var(--color-base3);
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.2;
}
.flow-time__label-interval {
  font-size: 16px;
  writing-mode: vertical-rl;
  line-height: 1.2;
}
.flow-img {
  display: block;
  height: fit-content;
  border-radius: 8px;
  overflow: hidden;
}

.flow__list {
  margin: 0 0 48px;
}
.flow__other-list {
  margin: 0 0 48px;
}
.flow__item:not(:first-child) {
  margin: 40px 0 0;
}
.flow__mark-list .cont__ttl-mark {
  margin: 12px 0 4px;
}
.flow__btn-block .ttl-line {
  font-size: 20px;
  margin: 24px 0 0;
}
.flow__btn-block .flow-time__btn {
  margin: 8px 0 0;
}
.figure__box {
  display: grid;
  grid-template-columns: 286px 1fr;
  gap: 16px 32px;
  border-radius: 12px;
  border: 1px solid var(--color-line);
  padding: 32px 40px;
  position: relative;
}
.flow-time__box {
  grid-template-columns: 240px 1fr;
  position: relative;
}
.flow-time__box::after {
  content: "";
  display: block;
  width: 16px;
  height: 20px;
  background: url(../images/flow_arr.png) no-repeat center center / contain;
  position: absolute;
  top: 50%;
  left: -16px;
  transform: translateY(-50%);
}
.flow-time__btn {
  display: grid;
  gap: 12px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 16px 0 0;
}
.flow-time__btn-bottom {
  margin: 32px 0 0;
}
.flow-time__btn .btn-icon {
  width: 100%;
  justify-content: flex-start;
}

.flow-box-list {
  display: grid;
  grid-template-columns: 100%;
  gap: 24px;
  position: relative;
}
.flow-box-list::before {
  content: "";
  display: block;
  width: 4px;
  height: 100%;
  background: var(--color-line);
  border-radius: 2px;
  position: absolute;
  top: 0;
  left: 56px;
  z-index: -1;
}

.base-box-list {
  display: grid;
  grid-template-columns: repeat(2,48%);
  gap: 16px 4%;
}
.base-box-item {
  padding: 20px 24px;
  background: var(--color-base);
  border-radius: 12px;
}
.base-box-item.base-box-border {
  background: var(--color-base3);
  border: 1px solid var(--color-line);
}
.base-box-list:has(.base-box-icon) {
  margin: 40px 0 0;
}
.base-box-item.base-box-icon {
  display: flex;
  flex-direction: column;
  margin: 36px 0 0;
  background: var(--color-base2);
  box-shadow: var(--button-main-shadow);
  position: relative;
}
.base-box-item.base-box-icon .base-box-ttl {
  color: var(--color-text);
}
.base-box-ttl {
  font-size: 22px;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
  margin: 0 0 12px;
  position: relative;
  z-index: 1;
}
.base-box-img {
  display: block;
  margin: 0 0 16px;
  border-radius: 8px;
  overflow: hidden;
}
.base-box-slide.page__slide.slick-dotted.slick-slider {
  margin: 0 0 60px;
}
.page__slide .base-box-img {
  margin: 0;
  border-radius: 0;
}
.page__slide .slick-list {
  border-radius: 8px;
  overflow: hidden;
}
.base-box-btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 12px auto 0;
}
.base-box-icon-img {
  width: 72px;
  height: fit-content;
  margin: 0 auto;
  padding: 16px;
  background: var(--color-base2);
  border-radius: 50%;
  position: absolute;
  inset: 0;
  top: -36px;
}
.base-box-label-list {
  display: grid;
  gap: 8px;
  margin: auto 0 0;
  padding: 16px 0 ;
  border-bottom: 1px dotted var(--color-line);
}
.base-box-label {
  display: block;
  width: fit-content;
  padding: 4px 16px;
  background: var(--color-base3);
  border-radius: 50px;
  text-align: center;
  font-weight: 700;
}

.movie-block {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.movie-block iframe {
  width: 100%;
  height: 100%;
}
video.movie-block {
  cursor: pointer;
}

.map-block {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.map-block iframe {
  width: 100%;
  height: 100%;
}

.cont-item:not(:first-child) {
  margin: 24px 0 0;
}
.cont-label {
  display: block;
  width: fit-content;
  background: var(--color-main);
  border-radius: 4px;
  padding: 2px 16px;
  color: var(--color-base3);
  text-align: center;
  font-weight: 700;
}
.cont-txt {
  padding: 8px 0 0;
}

.page__slide.slick-dotted.slick-slider {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin-bottom: 50px;
}
.page__slide .slick-arrow {
  top: auto;
  bottom: -48px;
}
.page__slide .next-arrow {
  right: 0;
}
.page__slide .prev-arrow {
  left: 0;
  transform: rotate(180deg);
  box-shadow: -2px -2px 8px 0px rgba(0, 0, 0, 0.2);
}
.page__slide .slick-dots {
  bottom: -38px;
}
.page__slide .slick-dots li button:before {
  content: '';
  width: 8px;
  height: 8px;
  margin: auto;
  border-radius: 50%;
  background: #d9d9d9;
  opacity: 1;
  position: absolute;
  inset: 0;
}
.page__slide .slick-dots li.slick-active button:before {
  background: #767676;
  opacity: 1;
}

.pdf__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 48px 90px;
}
.pdf__list .pdf__block {
  min-width: 30%;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.pdf__block {
  display: grid;
  justify-items: center;
  gap: 12px;
}
.pdf__block-txt {
  color: var(--color-main);
  text-align: center;
  font-size: 20px;
  font-weight: 700;
}
.pdf__block-link {
  display: grid;
  justify-items: center;
  gap: 12px;
}
.pdf__block-img {
  display: block;
  max-width: 160px;
  border: 1px solid var(--color-line);
}
.pdf__block-img.pdf__block-img-m {
  max-width: 400px;
  margin: auto;
}
@media (any-hover: hover) {
  .pdf__block-link:hover .pdf__block-img {
    opacity: 0.7;
    transition: opcity 0.25s ease-in-out;
  }
  .pdf__block-link:hover .btn-icon {
    background: var(--color-main);
    color: var(--color-base3);
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
  }
  .pdf__block-link:hover .btn-icon-pdf::after {
    background: url(../images/icon_btn_pdf_02.svg) no-repeat center center / contain;
  }
  .pdf__block-link:hover .btn-icon.btn-icon-line {
    background: #07b53b;
  }
}

.contact-box {
  max-width: 680px;
  margin: auto;
  border-radius: 12px;
  box-shadow: var(--button-main-shadow);
}
.contact-box:not(:first-child) {
  margin: 40px auto 0;
}
.contact-box__head {
  padding: 12px 0;
  background: var(--color-main);
  border-radius: 12px 12px 0 0;
  color: var(--color-base3);
  font-size: 24px;
  font-weight: 700;
  text-align: center;
}
.contact-box__body {
  display: grid;
  justify-items: center;
  gap: 24px 0;
  padding: 32px 16px;
  background: var(--color-base);
  border-radius: 0 0 12px 12px;
}
.contact-box__tel-link {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
}
@media (any-hover: hover) {
  a.contact-box__tel-link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.contact-box__tel-txt {
  display: block;
  color: var(--color-main);
  font-size: 48px;
  line-height: 1;
  font-weight: 700;
  padding: 0 0 0 48px;
  background: url(../images/icon_call_01.svg) no-repeat left center / 40px;
}
.contact-box__tel-txt.contact-box__fax-txt {
  background: url(../images/icon_fax.svg) no-repeat left center / 48px;
}
.contact-box__time {
  display: grid;
  grid-template-columns: repeat(3,auto);
  align-items: center;
  gap: 4px;
  text-align: center;
}
.contact-box__bubble {
  display: block;
  width: fit-content;
  margin: 0 auto 16px;
  padding: 4px 16px;
  border: solid 1px var(--color-main);
  border-radius: 50px;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-main);
  position: relative;
}
.contact-box__bubble:before {
  content: "";
  border: 4px solid transparent;
  border-top: 8px solid var(--color-base);
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
.contact-box__bubble:after {
  content: "";
  border: 5px solid transparent;
  border-top: 10px solid var(--color-main);
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.contact-box__body .btn-main::before {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  z-index: 2;
  background: url(../images/icon_mail_01.svg) no-repeat center center / contain;
  transition: transform 0.25s ease-in-out;
}
.contact-box__body .btn-main::after {
  background-image: url(../images/icon_btn_arr_trans_02.svg);
}
@media (any-hover: hover) {
  .contact-box__body .btn-main:hover::before {
    background-image: url(../images/icon_mail_02.svg);
  }
  .contact-box__body .btn-main:hover::after {
    background-image: url(../images/icon_btn_arr_trans_01.svg);
  }
}
.contact-box__btn-list {
  display: grid;
  gap: 20px;
}

.tab-list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}
.tab-list-top {
  align-items: flex-end;
  margin: 60px 0 32px;
  border-bottom: 3px solid var(--color-main);
}
.tab-list-bottom {
  align-items: flex-start;
  margin: 32px 0 0;
  border-top: 3px solid var(--color-main);
}
.tab-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 70px;
  background: var(--color-base);
  border-left: 1px solid var(--color-line);
  border-right: 1px solid var(--color-line);
  font-size: 18px;
  font-weight: 700;
  color: var(--color-main);
  line-height: 1.3;
  cursor: pointer;
}
.tab-button.tab-button--active {
  height: 78px;
  background: var(--color-main);
  border: none;
  font-size: 20px;
  color: var(--color-base3);
}
.tab-list-top .tab-button {
  border-radius: 8px 8px 0 0;
  border-top: 1px solid var(--color-line);
}
.tab-list-bottom .tab-button {
  border-radius: 0 0 8px 8px;
  border-bottom: 1px solid var(--color-line);
}
@media (any-hover: hover) {
  a.tab-button:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}

.page__bnr-block {
  display: grid;
  gap: 28px;
  max-width: 480px;
  margin: 80px auto 0;
}
.page__bnr {
  display: block;
  border: 1px solid var(--color-line);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.16);
  position: relative;
  overflow: hidden;
}
.page__bnr::after {
  content: "";
  width: 57%;
  height: 43%;
  margin: auto;
  border-radius: 50%;
  background: #000000;
  box-shadow: 0 0 50px #000000;
  opacity: 16%;
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  right: 0;
}
.page__bnr img,
.page__bnr source {
  transition: 0.25s ease-in-out;
  transition-property: transform, opacity;
}
@media (any-hover: hover) {
  .page__bnr:hover img,
  .page__bnr:hover source {
    transform: scale(1.04);
    transition: transform 0.25s ease-in-out;
  }
}
.page__bnr-icon {
  display: block;
  width: min(8%, 48px);
  border-radius: 50%;
  box-shadow: var(--button-tertiary-shadow);
  position: absolute;
  right: 12px;
  bottom: 12px;
}

.relation {
  background: var(--color-base);
  border-radius: 12px;
  margin: 100px 0 0;
  padding: 36px 48px 40px 48px;
}
.relation__head {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
  margin: 0 0 28px;
  padding: 0 0 12px;
  border-bottom: 2px solid var(--color-line);
  font-size: 28px;
  font-weight: 700;
}
.relation__head::before {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/icon_relation.svg) no-repeat center center / contain;
}
.relation__list {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
}
.relation__item .btn-main {
  min-width: initial;
  color: var(--color-text);
}
.relation__item .btn-main::after {
  background-image: url(../images/icon_btn_arr_trans_02.svg);
}
@media (any-hover: hover) {
  .relation__item .btn-main:hover::after {
    background-image: url(../images/icon_btn_arr_trans_01.svg);
  }
}

.note-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 24px;
  margin: 20px auto 0;
  padding: 32px 40px;
  background: var(--color-caution);
  border-radius: 12px;
}
.note-ttl {
  margin: 0 0 12px;
  color: var(--color-caution2);
  text-align: center;
  font-size: 20px;
  font-weight: 700;
}
.note-txt {
  display: block;
  width: 100%;
  line-height: 1.7;
}
.note-link-list {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 12px 20px;
}

.border-box {
  padding: 40px;
  border-radius: 12px;
  border: 1px solid var(--color-main);
}

.border-box-02 {
  display: grid;
  gap: 16px;
  padding: 32px 40px;
  border-radius: 12px;
  border: 5px solid var(--color-base2);
}

.border-box-03 {
  padding: 32px 36px;
  background: var(--color-base3);
  border-radius: 12px;
  border: 1px solid var(--color-titleline);
}

.figure-item:not(:first-child) {
  margin: 48px 0 0;
}
.figure-block {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 16px 32px;
}
.figure-img {
  display: block;
  height: fit-content;
  border-radius: 8px;
  overflow: hidden;
}
.figure-block-btn {
  margin: 16px 0 0;
}
.movie-thum-link {
  position: relative;
}
.movie-thum-link::after {
  content: "";
  display: block;
  width: 60px;
  height: 60px;
  background: url(../images/icon_btn_movie_02.svg) no-repeat center center / contain;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
@media (any-hover: hover) {
  .movie-thum-link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
  .movie-thum-link:hover::after {
    background: url(../images/icon_btn_movie_01svg) no-repeat center center / contain;
  }
}

.block-item:not(:first-child) {
  margin: 40px 0 0;
}
.block-item.base-block:not(:first-child) {
  margin: 32px 0 0;
}

.slide-loop-wrap {
  display: flex;
  overflow-x: hidden;
  min-height: 16.8vw;
  margin: 0 0 80px;
}
.slide-loop-list {
  animation: loop-img 50s infinite linear .5s both;
  display: flex;
  gap: 16px;
  align-items: center;
  margin: 0 0 0 16px;
}
@keyframes loop-img {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.slide-loop-item {
  width: calc(100vw / 5);
  box-shadow: var(--button-tertiary-shadow);
  border-radius: 12px;
  cursor: pointer;
  transition: width 0.25s ease-in-out;
}
.slide-loop-item img {
  border-radius: 12px;
  overflow: hidden;
}
@media (any-hover: hover) {
  .slide-loop-wrap:hover .slide-loop-list {
    animation-play-state: paused;
  }
  .slide-loop-item:hover {
    width: calc(100vw / 4);
  }
}

.head-nav {
  max-width: max-content;
  margin: 0 auto 40px;
  padding: 20px;
  background: var(--color-base);
  border-radius: 8px;
}
.head-nav .sidebar-nav__list {
  padding: 0 0 0 8px;
}

/* -----------------------------
hospitalization
----------------------------- */
.visit__link-list {
  margin: 32px 0 0;
}
.visit__pdf-block {
  margin: 20px 0 0;
}
.visit__box-item:not(:first-child) {
  margin: 36px 0 0;
}
.visit__btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 28px auto 0;
}
.visit__mail {
  display: grid;
  grid-template-columns: 60% 1fr;
  gap: 20px;
}

.price__cont:not(:last-child) {
  margin: 0 0 48px;
}
.price__box {
  padding: 16px 24px;
  margin: 16px 0 0;
}
.price__memo-list {
  padding: 0 0 0 32px;
}
.price__box-txt {
  padding: 16px 0 0;
}
.simulate__block {
  margin: 32px 0 0;
}
.simulate__ttl.ttl-obi {
  padding: 16px 10px;
  font-size: 28px;
  line-height: 1;
}
.simulate__ttl-sub {
  font-size: 16px;
}
.simulate__input-block {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(204px, 1fr));
  gap: 12px;
}
.simulate__input-block .form-label {
  width: 100%;
  padding: 12px 16px;
  background: var(--color-base3);
  border: 1px solid var(--color-main);
  border-radius: 8px;
  box-shadow: var(--button-tertiary-box-shadow, 2px 2px 8px 0px rgba(0, 0, 0, 0.2));
}
.simulate__input-block .form-input[type="radio"] {
  border-color: var(--color-main);
}
.simulate__input-block .form-label:has(.form-input[type="radio"]:checked) {
  background: var(--color-main);
  box-shadow: none;
}
.simulate__input-block .form-label:has(.form-input[type="radio"]:checked) .simulate__input-txt {
  color: var(--color-base3);
}
.simulate__input-block .form-input[type="radio"]:checked {
  border-color: var(--color-base3);
}
.simulate__input-block .form-input[type="radio"]:checked::after {
  width: 16px;
  height: 16px;
  background-color: var(--color-base3);
}
@media (any-hover: hover) {
  .simulate__input-block .form-label:not(:has(:checked)):hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.simulate__list .flow__num {
  display: grid;
  justify-items: center;
  align-content: flex-start;
  gap: 8px;
  min-width: 135px;
}
.simulate__head {
  padding: 4px 16px;
  border-radius: 30px;
  border: 1px solid var(--color-main);
  color: var(--color-main);
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
}
.simulate__cost {
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0 8px;
  margin: 28px 0 0;
  color: var(--color-main);
  font-size: 20px;
  font-weight: 700;
}
.simulate__cost-en {
  display: inline-block;
  font-size: 32px;
  font-weight: 500;
  padding: 0 4px 0 0;
}
.simulate__input-txt {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: flex-start;
  width: calc(100% - 28px);
  font-size: 20px;
  color: var(--color-main);
  font-weight: 700;
}
.simulate__input-txt-sub {
  font-size: 14px;
}
.simulate__btn.btn-main {
  justify-content: center;
  margin: auto;
  color: var(--color-text);
  cursor: pointer;
}
.simulate__btn.btn-main::after {
  background-image: url(../images/icon_btn_click_01.svg);
}
@media (any-hover: hover) {
  .simulate__btn.btn-main:hover::after {
    background-image: url(../images/icon_btn_click_02.svg);
  }
}
.simulate__result-head {
  padding: 12px 0;
  background: var(--color-main);
  border-radius: 12px 12px 0 0;
  color: var(--color-base3);
  font-size: 24px;
  font-weight: 700;
  text-align: center;
}
.simulate__result-body {
  display: grid;
  justify-items: center;
  gap: 16px 0;
  padding: 28px 16px 32px;
  background: var(--color-base);
  border-radius: 0 0 12px 12px;
}
.simulate__result-body .simulate__cost {
  margin: 0;
  border-bottom: 1px solid var(--color-main);
  font-size: 28px;
  line-height: 1;
}
.simulate__result-body .simulate__cost-en {
  font-size: 48px;
}
.simulate__error {
  font-weight: 700;
  color: var(--color-caution2);
}

.drive__box-list {
  margin: 40px 0 0;
}
.drive__graph {
  width: min(500px,80%);
  margin: 0 auto 40px;
}
.drive__btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 40px auto 0;
}

.data__wrap {
  margin: 90px 0 0;
  padding: 110px 0 160px;
  background: var(--color-base);
}
.data__block:not(:first-child) {
  margin: 80px 0 0;
}
.data__list {
  display: grid;
  gap: 32px;
}
.data__list-column2 {
  grid-template-columns: repeat(2,1fr);
}
.data__list-column3 {
  grid-template-columns: repeat(3,1fr);
}
.data__list-staff {
  grid-template-columns: repeat(2,1fr);
}
.data__item {
  display: grid;
  grid-row: span 3;
  grid-template-rows: subgrid;
  justify-items: center;
  gap: 12px;
  background: var(--color-base3);
  border-radius: 8px;
  padding: 32px;
}
.data__cont-center {
  display: grid;
  align-content: center;
}
.data__cont-space {
  display: grid;
  align-content: space-between;
}
.data__main {
  color: var(--color-main);
  font-size: 32px;
  font-weight: 700;
  text-align: center;
}
.data__main-num {
  display: inline-block;
  padding: 12px 0 0;
  font-size: 72px;
  font-weight: 700;
  line-height: 1;
}
.data__main {
  font-size: 20px;
}
.data__txt {
  padding: 12px 0 0;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
.data__icon {
  max-width: 120px;
}
.data__graph-area {
  display: grid;
  grid-template-columns: repeat(2,auto);
  justify-content: center;
  align-items: center;
  gap: 16px 40px;
}
.data__graph-img {
  width: min(320px,1fr);
}
.data__graph-detail {
  display: grid;
  gap: 24px;
}
.data__graph-data {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  align-items: center;
  font-size: 20px;
}
.data__graph-data::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
}
.data__graph-data-01::before {
  background: var(--color-accent);
}
.data__graph-data-02::before {
  background: #ffc573;
}
.data__graph-data-03::before {
  background: #fff9f2;
  border: 1px solid var(--color-line);
}
.data__staff-block {
  width: 100%;
  margin: 16px auto 0;
  padding: 24px 40px 16px;
  background: var(--color-base2);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 16px 40px;
  align-content: flex-start;
  align-self: stretch;
}
.data__staff-item {
  display: grid;
  justify-items: center;
  min-width: 96px;
}
.data__staff-job {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  min-height: 36px;
  padding: 4px 12px;
  background: var(--color-main);
  border-radius: 48px;
  color: var(--color-base3);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
.data__staff-job.font-en {
  font-size: 28px;
  font-weight: 500;
}
.data__staff-job-s {
  font-size: 14px;
  line-height: 1.5;
}
.data__staff-num {
  font-size: 20px;
  font-weight: 700;
}
.data__staff-num-en {
  font-size: 40px;
  font-weight: 700;
}


/* -----------------------------
about
----------------------------- */
.doctor__block {
  display: grid;
  grid-template-columns: 28% 1fr;
  gap: 16px 40px;
}
.director__img {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  border-radius: 8px;
  overflow: hidden;
}
.doctor__post {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-main);
}
.doctor__name-txt {
  display: flex;
  flex-direction: column;
  gap: 0 36px;
  padding: 16px 0 0;
  font-size: 36px;
  font-weight: 700;
}
.doctor__name-txt-director {
  padding: 8px 0 20px;
  flex-direction: row;
  align-items: center;
}
.doctor__name-en {
  font-size: 20px;
  font-weight: 500;
  color: var(--color-main);
}
.doctor__name-txt-director .doctor__name-en {
  font-size: 24px;
}
.doctor__table .table-head {
  align-items: flex-start;
  width: 24%;
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
  padding: 18px 8px;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-main);
}
.doctor__table .table-data {
  width: 76%;
  padding: 18px 24px;
  font-weight: 400;
}
.doctor__list {
  margin: 80px 0 0;
}
.doctor__item {
  display: grid;
  grid-template-columns: 26% 1fr;
  gap: 12px 40px;
  padding: 60px 0 60px 40px;
  border-top: 1px solid var(--color-line);
}
.doctor__item:last-child {
  border-bottom: 1px solid var(--color-line);
}

.floorroom__block:not(:first-child) {
  margin: 48px 0 0;
}
.floorroom__inner {
  display: grid;
  grid-template-columns: 59% 1fr;
  gap: 28px 24px;
}
.floorroom__img-slide,
.floorroom__thumbnail-slide {
  opacity: 0;
}
.floorroom__img-slide.slick-slider,
.floorroom__thumbnail-slide.slick-slider {
  opacity: 1;
}
.floorroom__img-slide,
.floorroom__thumbnail-slide .slick-slide img {
  overflow: hidden;
}
.floorroom__img-slide {
  border-radius: 8px;
  overflow: hidden;
}
.floorroom__thumbnail-slide {
  margin: 12px 0 0;
}
.floorroom__thumbnail-slide .slick-slide img {
  border-radius: 4px;
}
.floorroom__img-slide .slick-slide,
.floorroom__thumbnail-slide .slick-slide {
  position: relative;
  cursor: pointer;
}
.floorroom__thumbnail-slide .slick-list {
  width: 80%;
  margin: 0 auto;
}
.floorroom__thumbnail-slide .slick-slide {
  margin: 0 3px;
}
.floorroom__img-label {
  display: block;
  width: 100%;
  background: rgba(255,255,255,0.6);
  font-weight: 700;
  text-align: center;
  position: absolute;
  bottom: 0;
  left: 0;
}
.floorroom__img-slide .floorroom__img-label {
  padding: 8px 0;
}
.floorroom__thumbnail-slide .floorroom__img-label {
  padding: 2px 0;
}
.floorroom__thumbnail-slide .next-arrow {
  right: 0;
}
.floorroom__tab-list {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  align-items: flex-end;
  gap: 8px;
}
.floorroom__tab-list .tab-button {
  height: 36px;
  border-radius: 4px 4px 0 0;
  border-top: 1px solid var(--color-line);
  font-size: 14px;
  cursor: pointer;
}
.floorroom__tab-list .tab-button.tab-button--active {
  font-size: 16px;
}
.floorroom__plan {
  display: block;
  border: 1px solid var(--color-line);
}
.floorroom__detail-list {
  display: grid;
  gap: 8px;
  padding: 28px 0 0;
}
.floorroom__detail-item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  gap: 8px;
}
.floorroom__detail-label {
  padding: 2px 16px;
  background: var(--color-main);
  border-radius: 4px;
  color: var(--color-base3);
  text-align: center;
  font-weight: 700;
}
.floorroom__txt {
  margin: 20px 0 0;
  padding: 20px 0 0;
  background-image: repeating-linear-gradient(90deg, var(--color-line), var(--color-line) 2px, transparent 2px, transparent 4px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 100% 1px;
}
.floormap__btn-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 4px 2%;
  margin: 0 0 20px;
}
.floormap__btn-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 15%;
  height: 54px;
  padding: 0 0 8px;
}
.floormap__btn {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 4px;
  box-shadow: var(--button-tertiary-shadow);
  cursor: pointer;
  font-size: 24px;
  font-weight: 500;
  text-align: center;
}
.floormap__btn-item.floormap__btn-item--current .floormap__btn {
  background: var(--color-main);
  border: none;
  color: var(--color-base3);
  position: relative;
}
.floormap__btn-item.floormap__btn-item--current .floormap__btn::after {
  content: "";
  display: block;
  width: 10px;
  height: 8px;
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
  background: var(--color-main);
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
}
.floormap__slide {
  width: min(520px,90%);
  margin: auto;
}
.floormap__slide .next-arrow {
  right: -10%;
}
.floormap__slide .prev-arrow {
  left: -10%;
}

.sign__txt {
  display: block;
  width: fit-content;
  margin: 24px 0 0 auto;
}
.about__block-list {
  margin: 20px 0;
  gap: 20px;
}

.privacy__list {
  margin: 20px 0;
}

.medicalrecord__list {
  display: grid;
  gap: 4px;
  margin: 8px 0 0;
}
.medicalrecord__time-table {
  max-width: 320px;
}
.medicalrecord__price-table {
  max-width: 560px;
}
.medicalrecord__price-table .table-head {
  justify-content: flex-start;
  width: min(390px,70%);
  padding: 10px 24px;
  text-align: left;
}
.medicalrecord__price-table .table-data {
  width: min(170px,30%);
  text-align: right;
}
.medicalrecord__price-table .table-data .font-en {
  font-size: 20px;
}

.counselingcounter__time-table {
  max-width: 400px;
}
.counselingcounter__time-table .table-head {
  width: max(220px, 55%);
}
.counselingcounter__time-table .table-data {
  width: max(180px, 45%);
}
.about__block-box {
  margin: 24px 0 0;
}
.about__block-ttl {
  font-size: 22px;
  font-weight: 700;
  color: var(--color-main);
}
.assistance__table .table-head {
  align-items: flex-start;
  width: min(120px,20%);
}

.optout__block {
  margin-top: 40px;
}
.optout__list {
  margin: 20px 0;
}

.ethics__block .ttl-line {
  margin: 20px 0 4px
}

.guideline__list {
  display: grid;
  gap: 12px;
  margin: 20px 0 0;
}

.patient__txt {
  font-size: 20px;
}

.facility__pdf-list.pdf__list {
  justify-content: space-between;
  gap: 48px 5%;
}
.facility__pdf-list .pdf__block {
  width: 30%;
}
.facility__pdf-list .pdf__block-img {
  max-width: 280px;
}
.facility__table-01 {
  max-width: 360px;
  padding: 24px 0;
}
.facility__table-01 .table-head:nth-child(1),
.facility__table-01 .table-data:nth-child(1) {
  width: max(70%,170px);
}
.facility__table-01 .table-head:nth-child(2),
.facility__table-01 .table-data:nth-child(2) {
  width: max(30%,30px);
}
.facility__table-01 .table-head:last-child {
  border-right: none;
}
.facility__table-01 .table-data:not(:last-child) {
  border-right: 1px solid var(--color-line);
}
.facility__table-01 .table-data:nth-child(2) {
  text-align: right;
}
.facility__table-02 .table-head:nth-child(1) {
  width: 46%;
}
.facility__table-02 .table-head:not(:first-child),
.facility__table-02 .table-data {
  width: 18%;
}
.facility__table-02 .table-head:last-child {
  border-right: none;
}
.facility__table-02 .table-data:not(:last-child) {
  border-right: 1px solid var(--color-line);
}
.facility__table-02 .table-data {
  text-align: right;
}
.facility__table-03 .table-head:nth-child(1) {
  width: 58%;
}
.facility__table-03 .table-head:not(:nth-child(1)) {
  width: 14%;
}
.facility__table-03 .table-head:last-child {
  border-right: none;
}
.facility__table-03 .table-block {
  display: grid;
  grid-template-columns: 16% 1fr;
}
.facility__table-03 .table-block .table-head {
  width: 100%;
  grid-row: 1/7;
  border-right: none;
  border-left: 1px solid var(--color-line);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.facility__table-03 .table-block .table-row .table-data:nth-child(1) {
  width: 49.9%;
}
.facility__table-03 .table-data:not(:nth-child(1)){
  width: 16.7%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  text-align: right;
}
.facility__table-03 .table-block .table-row .table-data:not(:last-child) {
  border-right: 1px solid var(--color-line);
}
.facility__table-04 .table-head {
  width: max(calc(100% - 72px),20%);
  justify-content: flex-start;
  text-align: left;
}
.facility__table-04 .table-data {
  width: max(72px,20%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  text-align: right;
}
.facility__block-list {
  margin: 16px 0 0;
  padding: 20px 28px;
}
.facility__pdf {
  margin: 20px 0 0;
}

.outline__table-01 .table-head {
  justify-content: flex-start;
  padding: 10px 24px;
}
.outline__certificate-img {
  display: block;
  max-width: 480px;
  margin: 0 auto;
  border: 1px solid var(--color-line);
}
.outline__pride-block {
  align-items: center;
}
.outline__pride-img {
  display: block;
  border-radius: 0;
  border: 1px solid var(--color-line);
}
.outline__table-02 .table-head {
  display: flex;
  align-items: center;
  justify-content: center;
  width: max(110px, 20%);
  background: var(--color-base);
}
.outline__table-02 .table-data {
  width: 100%;
  padding: 0;
}
.outline__table-02 .table-data-item,
.outline__table-02 .table-head-item {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 10px 24px;
}
.outline__table-02 .table-data-item {
  justify-content: flex-start;
}
.outline__table-02 .table-head-item {
  justify-content: flex-end;
  background: var(--color-base);
  border-right: 1px solid var(--color-line);
}
.outline__table-02 .table-head-item:not(:first-child) {
  border-top: 1px solid var(--color-line);
}
.outline__table-02 .table-data-line {
  display: grid;
  grid-template-columns: min(86px,16%) 1fr;
}
.outline__table-02 .table-data-line:not(:first-child) {
  border-top: 1px solid var(--color-line);
}

.message__block {
  display: grid;
  grid-template-columns: 1fr 28%;
  gap: 20px 4%;
}
.message__img {
  display: block;
  border-radius: 8px;
  overflow: hidden;
}
.message__name {
  padding: 8px 0 0;
  text-align: right;
}
.message__name-m {
  font-size: 18px;
}

.accreditation__note-txt {
  display: block;
  font-weight: 700;
  line-height: 1.7;
  color: var(--color-main);
}
.accreditation__pdf-list {
  margin: 40px 0 0;
}
.accreditation__table {
  margin: 16px 0 0;
}
.accreditation__table .table-head:nth-child(1),
.accreditation__table .table-data:nth-child(1) {
  width: max(70px,15%);
}
.accreditation__table .table-head:nth-child(2),
.accreditation__table .table-data:nth-child(2) {
  width: 85%;
}
.accreditation__table .table-head:nth-child(2) {
  border-right: none;
}
.accreditation__table .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}

.performance__block {
  margin: 80px 0 0;
}
.performance__top-block {
  display: grid;
  grid-template-columns: 240px auto;
  gap: 20px 32px;
  align-items: center;
  width: fit-content;
  margin: 0 auto;
}
.performance__top-img {
  border: 1px solid var(--color-line);
}
.performance__top-txt {
  display: block;
  padding: 0 0 16px;
  font-size: 20px;
  font-weight: 700;
}
.performance__top-block .btn-icon {
  margin: auto;
}
.performance__list {
  margin: 48px 0 0;
}
.performance__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-main);
}
.performance__link::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(../images/icon_btn_pdf_01.svg) no-repeat center center / contain;
}
.performance__pdf-list.pdf__list {
  justify-content: flex-start;
  gap: 60px 5%;
}
.performance__pdf-list .pdf__block {
  gap: 8px;
}
.performance__pdf-list .pdf__block-img {
  max-width: 200px;
}

.philosophy__txt {
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.05em;
}

.harassment__pdf-block {
  margin: 40px auto 0;
}
.harassment__pdf-block .pdf__block-img {
  max-width: 480px;
}

/* -----------------------------
staff
----------------------------- */
.nutrition__pyramid-img {
  max-width: 480px;
  margin: auto;
}
.nutrition__table .table-head {
  background: var(--color-main);
  color: var(--color-base3);
}
.nutrition__table .table-data {
  padding: 0;
}
.nutrition__table .table-data-label {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-base);
}
.nutrition__table .table-data-label-2 {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.nutrition__table .table-data-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  padding: 10px 24px;
}
.nutrition__table .table-data-label-2 .table-data-item {
  justify-content: center;
  padding: 10px 8px;
  line-height: 1.3;
}
.nutrition__table .table-data-item:not(:first-child) {
  border-top: 1px solid var(--color-line);
}
.nutrition__table .table-row > :nth-child(1) {
  width: max(80px, 12%);
}
.nutrition__table .table-row > :nth-child(2) {
  flex-direction: column;
  width: max(132px, 18%);
}
.nutrition__table .table-row > :nth-child(3) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: max(132px, 76%);
  border-right: none;
  text-align: left;
}
.nutrition__table .table-row .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}
.nutrition__table .table-row .table-data:nth-child(2) {
  border-right: 1px solid var(--color-line);
}

.visual-img {
  display: block;
  max-width: 580px;
  margin: 0 auto;
}

.medical__block-btn {
  margin: 20px 0 0;
}

.msw__table {
  max-width: 500px;
}

.nurse__policy-list {
  display: grid;
  gap: 12px;
}
.nurse__policy {
  display: grid;
  grid-template-columns: 20px 1fr;
  align-items: baseline;
  gap: 12px;
  font-size: 20px;
  font-weight: 500;
}
.nurse__policy-num {
  font-size: 24px;
  font-weight: 500;
}

.license__table {
  max-width: 560px;
}
.license__table .table-head:nth-child(1),
.license__table .table-data:nth-child(1) {
  width: 75%;
}
.license__table .table-head:nth-child(2),
.license__table .table-data:nth-child(2) {
  width: 25%;
}
.license__table .table-head {
  background: var(--color-main);
  color: var(--color-base3);
}
.license__table .table-head:nth-child(2) {
  border-right: none;
}
.license__table .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}
.license__table .table-data:nth-child(2) {
  text-align: right;
}

.otstpt__table-txt {
  margin: 0 0 16px;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-main);
}

.recruit__bnr {
  margin: 80px 0 0;
}
.recruit__bnr-link {
  display: block;
}
@media (any-hover: hover) {
  .recruit__bnr-link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.recruit__rihabili-bnr {
  display: block;
  width: min(240px, 50%);
  margin: 0 0 24px;
}
.recruit__situation-table .table-data {
  text-align: center;
}
.recruit__situation-table .table-data:not(:last-child) {
  border-right: 1px solid var(--color-line);
}
.recruit__situation-table .table-head:nth-child(1),
.recruit__situation-table .table-head:nth-child(2),
.recruit__situation-table .table-data:nth-child(1),
.recruit__situation-table .table-data:nth-child(2) {
  width: 20%;
}
.recruit__situation-table .table-head:nth-child(3) {
  width: 60%;
  border-right: none;
}
.recruit__situation-table .table-data:nth-child(3),
.recruit__situation-table .table-data:nth-child(4) {
  width: 30%;
}

/* -----------------------------
rehabilitation
----------------------------- */
.rehabili-nav__list {
  display: grid;
  grid-template-columns: repeat(3, calc(96% / 3));
  gap: 24px;
}
.rehabili-nav__list .page-nav__main {
  padding: 24px;
}
.rehabili-nav__list .page-nav__txt {
  color: var(--color-main);
}
.rehabili-nav__list .page-nav__arr {
  margin: auto 24px auto auto;
}
.rehabili-nav__list .common-txt {
  padding: 0 24px 24px;
}
.rehabili-nav__list .page-nav__btn {
  display: grid;
  gap: 12px;
}
.rehabili-nav__list .page-nav__btn:has(.btn-icon-audio) {
  min-width: 250px;
}
.rehabili-nav__list .page-nav__btn:has(:nth-child(2)) .btn-icon-movie,
.rehabili-nav__list .page-nav__btn .btn-icon-audio {
  width: 100%;
  justify-content: flex-start;
}
.rehabili-nav__list .audio {
  max-width: 400px;
  margin: auto;
  padding: 0 24px 16px;
}

.caresupport__pdf-slide {
  max-width: 714px;
  margin: 36px auto 0;
}
.caresupport__pdf-slide:not(:has(.slick-arrow)) .slick-dots {
  display: none;
}
.caresupport__pdf-slide.page__slide .next-arrow {
  top: -18%;
  right: -8%;
}
.caresupport__pdf-slide.page__slide .prev-arrow {
  top: -18%;
  left: -8%;
}
.caresupport__btn {
  width: fit-content;
  margin: 28px auto 0;
}
.caresupport__join {
  height: 380px;
  max-height: 70vh;
  margin: 0 0 16px;
  padding: 24px 28px;
  border-radius: 8px;
  border: 1px solid var(--color-line);
  overflow-y: scroll;
}
.caresupport__join-list {
  display: grid;
  gap: 4px;
  padding: 8px 0 0 24px;
}
.caresupport__join-list:not(:last-child) {
  margin: 0 0 20px;
}
.caresupport__pdf-slide .pdf__block-img {
  max-height: 210px;
}
.caresupport__pdf-slide .pdf__block-img img {
  width: auto;
  height: 100%;
}
.caresupport__place {
  display: grid;
  gap: 16px;
  justify-content: center;
  justify-items: center;
  margin: 40px auto 0;
}
.caresupport__place-ttl {
  display: grid;
  grid-template-columns: repeat(2,auto);
  gap: 4px;
  align-items: center;
  justify-content: center;
  padding: 0 0 10px;
  background: url(../images/ttl_under_line.svg) no-repeat center bottom / contain;
  font-size: 20px;
  font-weight: 700;
}
.caresupport__place-ttl::before {
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  background: url(../images/icon_ttl_place.svg) no-repeat center center / contain;
}
.caresupport__box {
  margin: 60px 0 0;
}
.caresupport__box .ttl-deco {
  color: var(--color-text);
}

.seating__block {
  margin: 16px 0 0;
}
.seating__ex:not(:last-child) {
  margin: 0 0 60px;
}
.seating__img-block {
  display: grid;
  gap: 16px;
}
.seating__img-list {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
}
.seating__img-item {
  display: block;
  border-radius: 8px;
  overflow: hidden;
}
.seating__ba-wrap {
  display: grid;
  grid-template-columns: 32% auto;
  gap: 40px;
  margin: 32px auto 0;
}
.seating__ba-box {
  display: grid;
  justify-items: center;
  align-content: flex-start;
  gap: 16px;
  padding: 12px 16px 16px;
  border-radius: 8px;
}
.seating__ba-box.seating__ba-box-before {
  background: var(--color-bace4);
}
.seating__ba-box.seating__ba-box-after {
  background: var(--color-base2);
  position: relative;
}
.seating__ba-box-after::before {
  content: "";
  display: block;
  width: 16px;
  height: 24px;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: var(--color-line);
  position: absolute;
  top: 50%;
  left: -26px;
  transform: translateY(-50%);
}
.seating__ba-box-after:not(:has(.seating__ba-after-in)) {
  width: 51%;
}
.seating__ba-ttl {
  font-size: 20px;
  font-weight: 500;
}
.seating__ba-ttl::after {
  content: "";
  display: block;
  margin: 0 auto;
  width: 16px;
  height: 2px;
  border-radius: 2px;
  background: var(--color-main);
  inset: 0;
}
.seating__ba-box-after .seating__ba-ttl::after {
  background: var(--color-accent);
}
.seating__ba-img {
  display: block;
  margin: 0 auto 12px;
  max-width: 240px;
  border-radius: 4px;
  overflow: hidden;
}
.seating__ba-after-in {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px 16px;
}

.vevf__block {
  margin: 48px 0 0;
}

.sougu__top {
  margin: 0 0 60px;
}
.sougu__intro-list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px 40px;
  align-items: flex-end;
  margin: 32px 0 0;
}
.sougu__intro-ttl {
  display: block;
  margin: 0 0 12px;
  text-align: center;
  color: var(--color-main);
  line-height: 1.3;
}
.sougu__human-block {
  margin: 48px 0 0;
}
.sougu__intro-img {
  display: block;
  border-radius: 8px;
  border: 1px solid var(--color-line);
  overflow: hidden;
}
.sougu__human-column {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  align-items: center;
  gap: 32px;
}
.sougu__human-img {
  border-radius: 8px;
  overflow: hidden;
  height: fit-content;
}
.sougu__human-txt {
  grid-column: 2;
  grid-row: 1;
}
.sougu__team {
  display: grid;
  grid-template-columns: 35% 1fr;
  align-content: center;
  gap: 30px;
}
.sougu__team-item {
  max-width: 360px;
  margin: auto;
}
.sougu__flow-list {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 60px 40px;
}
.sougu__flow-list .sougu__flow-img {
  display: block;
  margin: 12px 0 0;
  padding: 0;
  border-radius: 8px;
  overflow: hidden;
}
.sougu__graph-block {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 24px 40px;
  margin: 60px 0 0;
}
.sougu__graph-img {
  display: block;
  max-width: 270px;
  margin: auto;
}
.sougu__table .table-head:nth-child(2) {
  border-right: none;
}
.sougu__table .table-data {
  text-align: center;
}
.sougu__table .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}
.sougu__table .table-head:nth-child(1),
.sougu__table .table-data:nth-child(1) {
  width: 60%;
}
.sougu__table .table-head:nth-child(2),
.sougu__table .table-data:nth-child(2) {
  width: 40%;
}
.sougu__bnr {
  margin: 48px 0 0;
}
.sougu__bnr-ttl {
  display: grid;
  grid-template-columns: repeat(3,auto);
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin: 0 auto 12px;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
}
.sougu__bnr-ttl::before,
.sougu__bnr-ttl::after {
  content: "";
  display: block;
  width: 2px;
  height: 20px;
  border-radius: 2px;
  background: var(--color-main);
}
.sougu__bnr-ttl::before {
  transform: rotate(-30deg);
}
.sougu__bnr-ttl::after {
  transform: rotate(30deg);
}
.sougu__bnr-link {
  display: block;
}
@media (any-hover: hover) {
  .sougu__bnr-link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.sougu__movie {
  margin: 60px 0 0;
}

/* -----------------------------
access
----------------------------- */
.access__note-txt {
  font-size: 20px;
  color: var(--color-caution2);
}
.access__map {
  margin: 40px 0 0;
}
.access__map-sup {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 12px 24px;
  margin: 12px 0 0;
}
.access__map-txt {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 8px 12px;
  font-size: 18px;
}
.access__map-label {
  display: inline-block;
  padding: 2px 16px;
  border-radius: 4px;
  border: 1px solid var(--color-main);
  color: var(--color-main);
  text-align: center;
  font-size: 16px;
  font-weight: 700;
}
.access__map-view {
  margin: 0 0 0 auto;
}
.access__bus-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0 32px;
  width: fit-content;
  margin: 0 auto 12px;
}
.access__bus-list .cont__ttl-mark-s {
  align-items: baseline;
}
.access__bus-txt {
  width: max-content;
}
.access__bus-note {
  color: var(--color-caution2);
}
.access__bus-note-num {
  font-size: 28px;
  font-weight: 500;
}
.access__table .table-head:first-child,
.access__table .table-data:first-child {
  width: 14%;
}
.access__table .table-head:not(:first-child),
.access__table .table-data:not(:first-child) {
  width: calc((100% - 14%) / 4 );
}
.access__table .table-head:last-child {
  border-right: none;
}
.access__table .table-data:not(:last-child) {
  border-right: 1px solid var(--color-line);
}
.access__table .table-data {
  text-align: center;
}
.access__table-txt {
  width: fit-content;
  margin: 0 0 0 auto;
  padding: 8px 0 0;
}
.access__map-btn {
  width: fit-content;
  margin: 20px auto 0;
}
.access__parking {
  width: fit-content;
  margin: 0 0 20px;
}
.access__parking-txt {
  width: max-content;
}

.intern__time-box.figure__box {
  grid-template-columns: 1fr;
  gap: 0;
}
.intern__note-box {
  margin: 80px 0 0;
}
.intern__img {
  display: block;
  max-width: 480px;
  margin: 16px auto 0;
}
.intern__ttl {
  margin: 24px 0 8px;
  font-size: 24px;
  font-weight: 700;
  color: var(--color-main);
}
.intern__box {
  margin: 8px 0 0;
  padding: 20px 28px;
}
.intern__box-ttl {
  margin: 0 0 12px;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-main);
}
.intern__check-item:not(:last-child) {
  margin: 0 0 12px;
}
.intern__items-note {
  display: grid;
  gap: 12px;
  margin: 16px 0 0;
}
.intern__table .table-head {
  justify-content: flex-start;
  padding: 10px 24px;
  background: var(--color-main);
  color: var(--color-base3);
}
.intern__table .table-head:nth-child(2) {
  border-right: none;
}
.intern__table .table-data {
  font-weight: 400;
}
.intern__table .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}
.intern__table .table-head:nth-child(1),
.intern__table .table-data:nth-child(1) {
  width: 37%;
}
.intern__table .table-head:nth-child(2),
.intern__table .table-data:nth-child(2) {
  width: 64%;
}
.intern__list {
  margin: 16px 0 0;
}
.intern__flow-block:not(:first-child) {
  margin: 24px 0 0;
}
.intern__note.note-box {
  align-items: flex-start;
}

.professtionals__btn {
  margin: 20px 0 0;
}


.smile__list {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  justify-content: space-between;
  gap: 120px 4%;
  max-width: 1086px;
  margin: 0 auto;
  padding: 0 0 180px;
  position: relative;
}
.smile__list::after {
  content: "";
  display: block;
  width: calc(100vw - 32px);
  height: calc(100% - 170px);
  background: var(--color-base);
  border-radius: 12px;
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.smile__item {
  max-width: 282px;
  margin: auto;
}
.smile__link {
  display: grid;
  justify-items: center;
  gap: 12px;
}
.smile__img {
  display: block;
  width: min(240px,86%);
  border: 1px solid var(--color-line);
  box-shadow: var(--button-main-shadow);
  overflow: hidden;
}
.smile__img img {
  transition: transform 0.15s ease-in-out;
}
.smile__ttl {
  display: grid;
  justify-items: center;
  font-size: 24px;
  font-weight: 700;
  color: var(--color-main);
}
.smile__ttl-date {
  font-size: 16px;
  line-height: 1;
}
@media (any-hover: hover) {
  .smile__link:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
  .smile__link:hover .smile__img img {
    transform: scale(1.05);
    transition: transform 0.15s ease-in-out;
  }
  .smile__link:hover .btn-icon {
    background: var(--color-main);
    color: var(--color-base3);
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
    transition: 0.15s ease-in-out;
  }
  .smile__link:hover .btn-icon-book::before {
    background: url(../images/icon_btn_book_02.svg) no-repeat center center / contain;
  }
}

.faq__item {
  border-radius: 8px;
  box-shadow: var(--accordion-box-shadow);
  background: var(--color-base);
}
.faq__item:not(:first-child) {
  margin: 24px 0 0;
}
.faq__q {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  gap: 16px;
  padding: 24px 58px 24px 32px;
  background: var(--color-base);
  font-size: 18px;
  font-weight: 700;
  position: relative;
}
.faq__q::before,
.faq__q::after {
  content: "";
  display: block;
  width: 18px;
  height: 2px;
  background: var(--color-main);
  border-radius: 1px;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  transition: transform 0.3s ease-in-out;
}
.faq__q::after {
  transform: translateY(-50%) rotate(90deg);
}
.accordion-btn--active.faq__q::after {
  transform: translateY(-50%) rotate(180deg);
}
.faq__q.accordion-btn {
  width: 100%;
}
.faq__q-en,
.faq__a-en {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 4px;
  font-size: 24px;
  font-weight: 500;
}
.faq__q-en {
  background: var(--color-main);
  color: var(--color-base3);
}
.faq__a-en {
  background: var(--color-base3);
  color: var(--color-main);
  border: 1px solid var(--color-main);
}
.faq__a {
  display: none;
}
.faq__a-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  gap: 16px;
  padding: 24px 58px 24px 32px;
  position: relative;
}
.faq__a-inner::before {
  content: "";
  display: block;
  width: calc(100% - 48px);
  height: 1px;
  background: var(--color-line);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.faq__table {
  margin: 16px 0 0;
}
.faq__table .table-head {
  background: var(--color-main);
  color: var(--color-base3);
}
.faq__table .table-data {
  font-weight: 400;
}
.faq__table .table-head:nth-child(2) {
  border-right: none;
}
.faq__table .table-data:nth-child(1) {
  border-right: 1px solid var(--color-line);
}
.faq__table .table-data:nth-child(2) {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.faq__table .table-head:nth-child(1),
.faq__table .table-data:nth-child(1) {
  width: 80%;
}
.faq__table .table-head:nth-child(2),
.faq__table .table-data:nth-child(2) {
  width: 20%;
}
.faq__bnr {
  display: block;
  max-width: 480px;
  margin: 16px auto 0;
  position: relative;
}
@media (any-hover: hover) {
  .faq__bnr:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.faq__a .cont__block-list {
  margin: 12px 0;
}
.faq__a .border-box {
  padding: 16px 20px;
}

.recruit__top-bnr {
  max-width: 720px;
  margin: 0 auto 80px;
}
.recruit__tab {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px 1%;
  margin: 0 0 60px;
}
.recruit__tab .tab-button {
  flex-direction: column;
  width: 15.5%;
  height: 60px;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 8px;
  box-shadow: var(--button-tertiary-shadow);
  text-align: center;
  position: relative;
}
.recruit__tab .tab-button.tab-button--active {
  background: var(--color-main);
  font-size: 18px;
}
.recruit__tab .tab-button.tab-button--active::after {
  content: "";
  display: block;
  width: 10px;
  height: 8px;
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background: var(--color-main);
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
}
.recruit__tab-txt-s {
  font-size: 14px;
}
.recruit__tab-sub {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 16px 1%;
  margin: 0 0 16px;
}
.recruit__tab-sub .tab-button {
  flex-direction: column;
  width: fit-content;
  height: 48px;
  padding: 0 32px;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 24px;
  text-align: center;
  position: relative;
}
.recruit__tab-sub .recruit__tab-click--active {
  background: var(--color-main);
  color: var(--color-base3);
}

.news__content pre {
  display: block;
  margin: 12px 0;
  font-size: 16px;
  line-height: 1.8;
  white-space: pre-wrap;
}
.news__content img {
  display: block;
  width: auto;
  max-width: 100%;
  margin: 16px 0;
}
.news__detail-head {
  margin: 0 0 24px;
}

.wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin: 60px 0 0;
}
.wp-pagenavi .current,
.wp-pagenavi .page {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 4px;
  font-size: 20px;
  font-weight: 500;
  font-family: "Jost", sans-serif;
}
.wp-pagenavi .current {
  background: var(--color-main);
  color: var(--color-base3);
}
.wp-pagenavi .page {
  background: var(--color-base3);
  border: 1px solid var(--color-main);
  color: var(--color-main);
}
.nextpostslink,
.previouspostslink {
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/icon_arr_link.svg) no-repeat center center / contain;
}
.nextpostslink {
  margin: 0 0 0 40px;
}
.previouspostslink {
  margin: 0 40px 0 0;
  transform: rotate(180deg);
}

.form__wrap {
  max-width: 840px;
  margin: 0 auto;
  padding: 32px 4% 72px;
  background: var(--color-base);
  border-radius: 12px;
}
.form__wrap .wpcf7-form .p {
  display: block;
  max-width: 600px;
  margin: auto;
}
.form__wrap .wpcf7-form .form__label {
  margin: 40px 0 8px;
  font-size: 18px;
  font-weight: 700;
}
.form__wrap .wpcf7-form .form__label::after {
  content: "必須";
  display: inline-block;
  margin: 0 0 0 12px;
  padding: 2px 8px;
  border-radius: 4px;
  color: var(--color-base3);
  background: var(--color-caution2);
  font-size: 16px;
}
.form__wrap .wpcf7-form .form__label-s {
  display: block;
  margin: 12px 0 4px;
  font-size: 16px;
}
.form__wrap .wpcf7-list-item {
  margin: 0;
}
.form__wrap .wpcf7-form-control {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 8px 36px;
}
.form__wrap .wpcf7-form .wpcf7-list-item label {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  cursor: pointer;;
}
.form-input[type="text"],
.form-input[type="email"],
.form-input[type="tel"],
textarea.form-input {
  width: 100%;
  padding: 8px 12px;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 4px;
}
.form__wrap .wpcf7-form input[type="checkbox"] {
  display: inline-block;
  width: 20px;
  height: 20px;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 3px;
  position: relative;
}
.form__wrap .wpcf7-form input[type="checkbox"]:checked::after {
  content: "";
  display: block;
  width: 18px;
  height: 10px;
  border-left: 3px solid var(--color-accent);
  border-bottom: 3px solid var(--color-accent);
  border-radius: 1px;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
.form__wrap .wpcf7-form input[type="radio"] {
  display: inline-block;
  width: 16px;
  height: 16px;
  background: var(--color-base3);
  border-radius: 50%;
  border: 1px solid var(--color-line);
  position: relative;
}
.form__wrap .wpcf7-form input[type="radio"]:checked::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-main);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
.form__wrap .wpcf7-form-control-wrap:has(input[type="checkbox"]) {
  display: block;
  padding: 4px 0 0;
}
.form__wrap .wpcf7-form .form__select {
  position: relative;
}
.form__wrap .wpcf7-form .form__select::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--color-text);
  border-bottom: 2px solid var(--color-text);
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%) rotate(45deg);
}
.form__wrap .wpcf7-form select {
  width: 100%;
  padding: 8px 12px;
  background: var(--color-base3);
  border: 1px solid var(--color-line);
  border-radius: 4px;
  cursor: pointer;
}
.form__wrap .wpcf7-form p:has(input[type="submit"]) {
  display: block;
  width: fit-content;
  margin: 48px auto 0;
  position: relative;
}
.form__wrap .wpcf7-form input[type="submit"] {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-width: 340px;
  min-height: 78px;
  border-radius: 100vw;
  background: var(--color-base3);
  border: 2px solid var(--color-main);
  padding: 0 36px 0 20px;
  box-shadow: var(--button-main-shadow);
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  line-height: 1.3;
  position: relative;
  cursor: pointer;
}
.form__wrap .wpcf7-form p:has(input[type="submit"]):after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  z-index: 2;
  background: url(../images/icon_btn_arr_trans_02.svg) no-repeat center center / contain;
  transition: transform 0.25s ease-in-out;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}
@media (any-hover: hover) {
  .form__wrap .wpcf7-form input[type="submit"]:hover {
    background: var(--color-main);
    color: var(--color-base3,#ffffff);
    transition: 0.25s ease-in-out;
  }
  .form__wrap .wpcf7-form input[type="submit"]:hover {
    color: var(--color-base3,#ffffff);
  }
  .form__wrap .wpcf7-form p:has(input[type="submit"]):hover::after {
    background-image: url(../images/icon_btn_arr_trans_01.svg);
    transform: translateY(-50%);
    transition: transform 0.25s ease-in-out;
  }
}
.wpcf7-spinner {
  display: none!important;
}
#autozip {
  display: none!important;
}
.form-thanks__txt {
  display: block;
  padding: 0 0 16px;
  font-size: 24px;
  text-align: center;
  font-weight: 700;
  color: var(--color-main);
}
.not-page__txt {
  display: block;
  padding: 0 0 16px;
  font-size: 24px;
  text-align: center;
  font-weight: 700;
  color: var(--color-main);
}

/* 1440 */


/* footer */
.sitemap__btn {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 4px 0;
  background: var(--color-main);
  color: var(--color-base3);
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  cursor: pointer;
}
.sitemap__btn::after {
  content: "";
  display: block;
  width: 48px;
  height: 48px;
  background: url(../images/icon_arr_down_01.svg) no-repeat center center / contain;
}
.accordion-btn {
  cursor: pointer;
}
.accordion-btn--active::after {
  transform: rotate(180deg);
}
.sitemap__cont {
  display: none;
  background: var(--color-base);
}
.sitemap__cont-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  padding: 44px 0 80px;
  border-bottom: 1px solid var(--color-line);
}
.sitemap__block {
  display: grid;
  gap: 16px;
  width: calc((100% - 120px) / 4);
}
.sitemap__link {
  border-bottom: 1px solid var(--color-main);
  padding: 16px 0px;
  display: flex;
  gap: 4px;
  align-items: center;
  justify-content: flex-start;
  align-self: stretch;
  color: var(--color-main);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.3;
}
.sitemap__link::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../images/icon_arr_link_nomal_01.svg) no-repeat center center / contain;
}
@media (any-hover: hover) {
  .sitemap__link:hover {
    background: #e2effb;
    transition: 0.25s ease-in-out;
  }
}
.sitemap__link-s {
  font-size: 16px;
}
.sitemap__list {
  padding: 16px 0 0 16px;
}
.footer {
  background: var(--color-base);
  padding: 80px 0 100px;
}
.fixed__btn-wrap {
  display: block;
  width: min(200px, 15%);
  opacity: 0;
  position: fixed;
  bottom: 40px;
  right: 2%;
  z-index: 2;
  transition: opacity 0.4s ease-in-out;
}
.fixed__btn {
  display: block;
  width: 100%;
  transition: transform 0.2s ease-in-out;
}
@media (any-hover: hover) {
  .fixed__btn:hover {
    transform: scale(1.1);
    transition: transform 0.2s ease-in-out;
  }
}
.fixed__btn-wrap.fixed__btn-wrap--view {
  opacity: 1;
  transition: opacity 0.4s ease-in-out;
}
.footer__inner {
  display: grid;
  grid-template-columns: repeat(2,auto);
  gap: 28px 4%;
  justify-content: space-between;
}
.footer__logo {
  display: block;
  max-width: 410px;
}
@media (any-hover: hover) {
  .footer__logo:hover {
    opacity: 0.7;
    transition: opacity 0.25s ease-in-out;
  }
}
.footer__info-block {
  display: grid;
  gap: 16px;
  padding: 42px 0 0;
  font-family: "jost", "Noto Sans JP",sans-serif;
}
.footer__info-tel {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0 32px;
}
.footer__info-time {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0 16px;
}
.footer__sns {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 16px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.footer__sns-icon {
  display: block;
  width: 36px;
}
@media (any-hover: hover) {
  .footer__sns-icon:hover {
    opacity: 0.7;
    transition: opacity 0.15s ease-in-out;
  }
}
.footer__link-block {
  display: grid;
  align-content: flex-start;
  gap: 44px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 12px 0 0;
}
.footer__link-list {
  display: grid;
  gap: 8px;
}
.footer__link-btn {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 240px;
  background: var(--color-base3);
  border-radius: 20px;
  border: 1px solid var(--color-main);
  padding: 2px 16px;
  box-shadow: var(--button-tertiary-shadow);
  color: var(--color-main);
  font-weight: 700;
}
.footer__link-btn::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../images/icon_arr_link_nomal_01.svg) no-repeat center center / contain;
}
.footer__link-btn.footer__link-btn-em {
  background: var(--color-main);
  color: var(--color-base3);
}
.footer__link-btn.footer__link-btn-em::before {
  background: url(../images/icon_arr_link_nomal_02.svg) no-repeat center center / contain;
}
@media (any-hover: hover) {
  .footer__link-btn:hover {
    box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.4);
    opacity: 0.7;
    transition: 0.15s ease-in-out;
    transition-property: box-shadow opacity;
  }
  .footer__link-btn:hover::before {
    transform: translateX(4px);
    transition: transform 0.25s ease-in-out;
  }
}
.footer__copyright {
  padding: 16px 0 0;
  font-size: 14px;
}

@media screen and (min-width: 1441px) {
  .cont-feature__imgl-01,
  .cont-feature__imgl-03 {
    left: -120px;
  }
  .cont-feature__imgl-02 {
    right: -120px;
  }
  .cont-feature__imgl {
    width: 50%;
    border-radius: 8px;
  }
  .cont-feature__imgs {
    border-radius: 8px;
  }
  .cont-feature__imgs-01,
  .cont-feature__imgs-03 {
    right: -4%;
  }
  .cont-feature__imgs-02-1 {
    left: -4%;
  }
}
@media screen and (max-width: 1199px) {
  .header {
    align-items: center;
    height: 60px;
    padding: 0 2%;
  }
  .header__logo {
    width: min(320px,78%);
    padding: 0;
  }
  .header__menu {
    display: block;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 4px 0;
    padding: 4px 0 0;
    cursor: pointer;
  }
  .header__menu-btn {
    position: relative;
    width: 32px;
    height: 20px;
  }
  .header__menu-btn-line {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--color-main);
    border-radius: 2px;
    position: absolute;
    left: 0;
    transition: 0.2s ease-in-out;
  }
  .header__menu-btn-line:nth-child(1) {
    top: 0;
  }
  .header__menu-btn-line:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
  }
  .header__menu-btn-line:nth-child(3) {
    bottom: 0;
  }
  .header__menu.header__menu--active .header__menu-btn-line:nth-child(1) {
    top: 50%;
    transform: rotate(45deg);
  }
  .header__menu.header__menu--active .header__menu-btn-line:nth-child(2) {
    opacity: 0;
  }
  .header__menu.header__menu--active .header__menu-btn-line:nth-child(3) {
    transform: rotate(-45deg);
    top: 50%;
  }
  .header__menu-btn-txt {
    display: block;
    font-size: 14px;
    font-weight: 700;
  }
  .nav {
    flex-direction: column;
    width: 100%;
    height: calc(100vh - 60px);
    background: var(--color-base3);
    border-top: 1px solid var(--color-line);
    padding: 24px 4% 60px;
    overflow-y: scroll;
    position: absolute;
    top: 60px;
    right: -100%;
    opacity: 0;
    pointer-events: none;
    transition: 0.25s ease-in-out;
    transition-property: right opacity;
  }
  .nav.nav--open {
    right: 0;
    opacity: 1;
    pointer-events: initial;
    transition: 0.4s ease-in-out;
    transition-property: right opacity;
  }
  .nav-main {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    width: 100%;
  }
  .nav-main__item {
    width: 100%;
  }
  .sp-nav-main__head {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
  }
  .nav-main__item:not(:first-child) .sp-nav-main__head {
    border-top: 1px solid var(--color-line);
  }
  .nav-main__link {
    width: calc(100% - 52px);
    padding: 24px 0 24px 12px;
    font-size: 18px;
    color: var(--color-main);
  }
  .nav-main__link.nav-main__link-pc {
    display: none;
  }
  .nav-main__link.nav-main__link-sp {
    display: block;
  }
  .nav-main__link::after {
    content: none;
  }
  .nav-main__link-btn {
    display: block;
    width: 52px;
    padding: 0 12px 0 0;
    cursor: pointer;
  }
  .nav-main__link-btn.nav-main__link-btn--active img {
    transform: rotate(180deg);
  }
  .nav-modal {
    opacity: 1;
    visibility: visible;
    pointer-events: initial;
    box-shadow: none;
    position: relative;
    top: auto;
    border: none;
    display: none;
  }
  .nav-modal__head {
    display: none;
  }
  .nav-modal__inner {
    width: 100%;
    padding: 0;
  }
  .nav-modal__list {
    grid-template-columns: 1fr;
    padding: 0 0 16px;
  }
  .nav-common__link {
    min-height: auto;
    padding: 12px 16px 12px 24px;
    font-size: 16px;
  }
  .nav-modal__list .nav-common__link {
    border: none;
  }
  .nav-modal__sub-block {
    padding: 0 24px;
  }
  .nav-modal__sub-list {
    grid-template-columns: 1fr;
  }
  .nav-modal__sub-ttl {
    font-size: 16px;
  }
  .nav-modal__sub-list {
    padding: 8px 32px 24px;
  }
  .nav-over {
    flex-direction: column;
    width: 100%;
    padding: 48px 0 0;
    border-top: 1px solid var(--color-line);
  }
  .nav-over__list {
    order: 1;
    flex-direction: column;
  }
  .nav-over__info-btn {
    width: 100%;
  }
  .nav-over__tel {
    order: 2;
  }
  .nav-over__sns {
    order: 3;
  }
  body::after {
    content: none;
  }

  /* common */
  .breadcrumb__list {
    margin: 0 0 48px;
  }
  .page__ttl-txt {
    font-size: 32px;
  }
  .cont__ttl-txt-en {
    font-size: 20px;
  }
  .cont__ttl-mark {
    gap: 4px;
  }
  .cont__ttl-mark::before {
    width: 14px;
    height: 14px;
  }
  .cont__ttl-mark-s::before {
    width: 8px;
    height: 8px;
    margin: 10px 0 0;
  }
  .btn-main {
    font-size: 18px;
  }
  .ttl-main,
  .news__content h1 {
    margin: 0 0 36px;
    font-size: 28px;
  }
  .news__content h1:not(:first-child) {
    margin: 48px 0 36px;
  }
  .ttl-main-sub {
    font-size: 20px;
  }

  .ttl-sec,
  .news__content h2 {
    margin: 24px 0 16px;
    font-size: 22px;
  }

  .ttl-num {
    gap: 8px;
    font-size: 22px;
  }
  .ttl-num-txt {
    width: 36px;
    height: 36px;
    font-size: 22px;
    font-weight: 500;
  }
  .ttl-num + * {
    padding: 8px 0 0 44px;
  }

  .ttl-obi {
    margin: 0 0 36px;
    font-size: 28px;
  }

  .ttl-deco {
    font-size: 22px;
  }

  .ttl-line {
    font-size: 20px;
  }

  .ttl-nomal,
  .news__content h3 {
    font-size: 20px;
  }

  /* style */
  .main {
    margin: 60px 0 0;
  }
  .mv-img {
    padding: 0 2%;
  }
  .cont-guide__list-main {
    gap: 20px 0;
  }
  .cont-guide__item-main {
    width: 49%;
  }
  .cont-guide__link {
    display: grid;
    grid-template-columns: 36% 1fr;
  }
  .cont-guide__link::after {
    content: none;
  }
  .cont-guide__img {
    border-radius: 8px 0 0 0;
  }
  .cont-guide__img::after {
    width: 16%;
    height: 100%;
    border-radius: 12px 0 0 0;
    left: auto;
    right: 0;
  }
  .cont-guide__box {
    justify-items: flex-start;
    align-content: center;
    gap: 4px 0;
    padding: 0 4% 0 0;
  }
  .cont-guide__head {
    display: grid;
    grid-template-columns: 16% 1fr;
    align-items: center;
    gap: 4%;
    width: 100%;
    margin: 0;
  }
  .cont-guide__icon {
    width: 100%;
    position: relative;
    top: auto;
    left: auto;
    transform: initial;
  }
  .cont-guide__ttl {
    font-size: 18px;
    text-align: left;
  }
  .cont-guide__txt {
    text-align: left;
  }
  .cont-guide__link-other.btn-main {
    min-width: auto;
  }
  .cont-feature__main-ttl {
    position: relative;
  }
  .cont__ttl--vertical {
    grid-template-columns: auto;
  }
  .cont__ttl--vertical .cont__ttl-txt {
    -webkit-writing-mode: initial;
        -ms-writing-mode: initial;
            writing-mode: initial;
  }
  .cont__ttl--vertical .cont__ttl-txt-en {
    transform: rotate(0) translateY(0);
  }
  .cont-feature {
    margin: 100px 0 0;
  }
  .cont-feature-inner {
    padding: 0;
  }
  .cont-feature__txtarea {
    width: 80%;
    padding: 12vw 12% 124px 12%;
  }
  .cont-feature__txtarea-01 {
    margin: 0 0 0 -4%;
    border-radius: 0 180px 12px 0;
  }
  .cont-feature__txtarea-02 {
    margin: 132px -4% 0 auto;
    border-radius: 180px 0 0 12px;
    padding: 14vw 12% 124px 12%;
  }
  .cont-feature__txtarea-03 {
    margin: 80px 0 0 -4%;
    border-radius: 0 180px 12px 0;
  }
  .cont-feature__imgl {
    width: 36%;
  }
  .cont-feature__imgl-01,
  .cont-feature__imgl-03 {
    border-radius: 8px 0 0 8px;
    bottom: 4%;
    left: auto;
    right: -4%;
  }
  .cont-feature__imgl-02 {
    border-radius: 0 8px 8px 0;
    bottom: 12%;
    right: auto;
    left: -4%;
  }
  .cont-feature__imgl img,
  .cont-feature__imgl source {
    -o-object-position: top;
       object-position: top;
  }
  .cont-feature__imgs {
    border-radius: 8px;
  }
  .cont-feature__imgs-01,
  .cont-feature__imgs-03 {
    bottom: -8%;
    right: 36%;
  }
  .cont-feature__imgs-02-1 {
    bottom: 0;
    left: 50%;
  }
  .cont-feature__imgs-02-2 {
    bottom: 12%;
    left: auto;
    right: 0;
  }
  .cont-news-inner {
    gap: 0 8%;
  }
  .cont-news__link {
    padding: 24px 16px;
  }
  .cont-info__column {
    grid-template-columns: 1fr;
    max-width: 840px;
    margin: auto;
  }
  .cont-info__ttl-txt {
    font-size: 32px;
  }
  .cont-info__ttl-txt-en {
    font-size: 20px;
  }
  .cont-other__recruit {
    grid-template-columns: auto 1fr;
  }
  .cont-other__recruit-block {
    padding: 40px 60px;
  }
  .cont-other__bnr-slide {
    margin: 160px 0 72px;
  }

  /* page */
  .page__container {
    gap: 32px 60px;
  }
  .page__container .page__contents {
    width: calc(100% - 260px);
  }
  .page__block:not(:last-child) {
    margin: 0 0 60px;
  }
  .sidebar-nav {
    width: 200px;
  }
  .sidebar-nav__list {
    padding: 0 0 0 18px;
  }

  .page-nav__list {
    gap: 16px;
  }
  .page-nav__main {
    padding: 16px 8px;
  }
  .page-nav__txt {
    font-size: 18px;
    padding: 0;
  }
  .page-nav__arr {
    margin: auto 8px auto auto;
  }
  .page-nav__item:has(.page-nav__btn) .common-txt {
    padding: 0 12px 12px;
  }
  .page-nav__btn {
    padding: 0 12px 16px;
  }
  .page-nav__item .page__slide .next-arrow {
    right: 12px;
  }
  .page-nav__item .page__slide .prev-arrow {
    left: 12px;
  }

  .sub-nav__list {
    gap: 16px;
  }

  .flow__ttl {
    font-size: 22px;
  }
  .contact-box__head {
    font-size: 22px;
  }
  .contact-box__tel-txt {
    font-size: 40px;
  }

  .relation {
    padding: 20px 24px;
  }
  .relation__list {
    gap: 12px;
  }
  .relation__head {
    margin: 0 0 16px;
    padding: 0 0 8px;
    font-size: 24px;
  }

  .border-box {
    padding: 20px 24px;
  }
  .border-box-02 {
    padding: 20px 24px;
  }
  .border-box-03 {
    padding: 20px 24px;
  }
  
  .intro {
    margin: 0 0 48px;
    gap: 16px;
  }
  .intro__message {
    font-size: 28px;
  }
  .intro__message-subhead {
    font-size: 16px;
  }

  .figure__box {
    gap: 16px 20px;
    padding: 24px;
  }

  .flow__box {
    padding: 24px 28px;
  }
  .flow__num {
    margin: 0 28px 0 0;
    padding: 0 28px 0 0;
  }
  .flow__item:not(:first-child) {
    margin: 28px 0 0;
  }
  .flow-time__list::before {
    width: 3px;
    left: 39px;
  }
  .flow-time__label {
    width: 80px;
    height: 80px;
    font-size: 18px;
  }

  .flow-box-list {
    gap: 20px;
  }
  .flow-box-list::before {
    left: 42px;
  }

  .base-box-item {
    padding: 16px;
    border-radius: 8px;
  }
  .base-box-ttl {
    margin: 0 0 8px;
    font-size: 20px;
  }
  .base-box-img {
    margin: 0 0 8px;
  }

  .visit__box-item:not(:first-child) {
    margin: 28px 0 0;
  }
  .visit__btn {
    margin: 20px auto 0;
  }
  .simulate__list .flow__num {
    min-width: 124px;
  }
  .simulate__input-txt {
    font-size: 18px;
  }
  .simulate__cost {
    font-size: 16px;
  }

  .drive__graph {
    margin: 0 auto 32px;
  }

  .data__list {
    gap: 20px;
  }
  .data__item {
    padding: 16px 20px;
  }
  .data__main {
    font-size: 18px;
  }
  .data__main-num {
    font-size: 56px;
  }
  .data__txt {
    font-size: 16px;
  }
  .data__staff-block {
    gap: 16px;
    padding: 16px 16px 12px;
  }

  .doctor__list {
    margin: 40px 0 0;
  }
  .doctor__item {
    padding: 32px 0 32px 20px;
  }
  .doctor__post {
    font-size: 16px;
  }
  .doctor__name-txt {
    gap: 0 20px;
    padding: 8px 0 0;
    font-size: 30px;
  }
  .doctor__name-en {
    font-size: 16px;
  }
  .doctor__name-txt-director {
    padding: 0 0 12px;
  }
  .doctor__name-txt-director .doctor__name-en {
    font-size: 20px;
  }

  .smile__list {
    grid-template-columns: repeat(2,1fr);
    gap: 80px 4%;
  }

  .floorroom__inner {
    grid-template-columns: 100%;
  }
  .floorroom__plan,
  .floorroom__detail-list,
  .floorroom__tab-list {
    width: min(480px,100%);
    margin: auto;
  }

  .caresupport__pdf-slide {
    max-width: 560px;
  }
  .caresupport__pdf-slide.page__slide .next-arrow {
    right: -3%;
  }
  .caresupport__pdf-slide.page__slide .prev-arrow {
    left: -3%;
  }

  /* 1199 */
  .base-box-list:has(.base-box-icon) {
    margin: 36px 0 0;
  }

  .rehabili-nav__list {
    gap: 16px;
  }
  .rehabili-nav__list .page-nav__main {
    padding: 20px 12px 16px;
  }
  .rehabili-nav__list .page-nav__arr {
    margin: auto 12px auto auto;
  }
  .rehabili-nav__list .common-txt {
    padding: 0 12px 16px;
  }
  .rehabili-nav__list .audio {
    padding: 0 12px 16px;
  }

  .slide-loop-wrap {
    min-height: 22.3vw;
  }
  .slide-loop-item {
    width: calc(100vw / 4);
  }
  @media (any-hover: hover) {
    .slide-loop-item:hover {
      width: calc(100vw / 3);
    }
  }

  .sitemap__cont-inner {
    padding: 24px 0 48px;
  }
  .sitemap__link {
    font-size: 18px;
  }
  .footer {
    padding: 32px 0 48px;
  }
  .footer__info-block {
    padding: 28px 0 0;
  }
}

@media screen and (max-width: 1024px) {
  .cont-other__bnr-slide .prev-arrow {
    left: 34%;
  }
  .cont-other__bnr-slide .next-arrow {
    right: 34%;
  }
  .figure__box {
    grid-template-columns: 200px 1fr;
  }
  .flow-time__list::before {
    content: none;
  }
  .flow-time__item {
    grid-template-columns: 1fr;
    position: relative;
  }
  .flow-time__box::after {
    content: none;
  }
  .flow-time__label {
    position: absolute;
    top: -24px;
    left: -24px;
    z-index: 1;
  }
  .figure-block {
    grid-template-columns: 100%;
  }
  .nutrition__pyramid-img {
    margin: 20px auto 0;
  }
  .sougu__intro-list {
    grid-template-columns: 1fr;
  }
  .sougu__human-column {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .sougu__human-txt {
    grid-column: auto;
    grid-row: auto;
  }
  .sougu__team {
    grid-template-columns: 1fr;
  }
  .sougu__flow-list {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .sougu__graph-block {
    grid-template-columns: 1fr;
  }
  .philosophy__logo-img {
    max-width: 320px;
    margin: auto;
  }
  .recruit__tab .tab-button {
    width: 32%;
  }

  .intern__time .figure__box {
    padding: 60px 16px 16px;
  }
}

@media screen and (max-width: 768px) {
  /* common */
  .cont__ttl {
    padding: 0 0 28px 0;
  }
  .page__ttl-txt {
    font-size: 28px;
  }
  .cont__ttl-txt-en {
    font-size: 16px;
  }
  .base-block,
  .base-block-2 {
    padding: 16px 20px;
  }
  .base-block-ttl {
    margin: 0 0 8px;
  }

  .btn-main {
    gap: 8px;
    min-width: 248px;
    min-height: 68px;
    padding: 0 16px 0 24px;
  }

  .btn-main.btn-main-sepatab::after {
    width: 28px;
    height: 28px;
  }

  .btn-trans {
    font-size: 16px;
  }

  .cont-item:not(:first-child) {
    margin: 16px 0 0;
  }
  .cont-txt {
    padding: 4px 0 0;
  }

  .header {
    padding: 0 4%;
  }

  .mv-img {
    padding: 0 4%;
    aspect-ratio: 1/1;
  }
  .mv__slide {
    border-radius: 8px;
  }
  .mv__slide.slick-slider,
  .mv__slide .slick-list,
  .mv__slide .slick-track {
    height: 100%;
  }
  .mv__slide-img {
    aspect-ratio: 1/1;
  }
  @-webkit-keyframes mv_slide {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50px);
    }
  }
  @keyframes mv_slide {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50px);
    }
  }
  .mv__copy {
    width: 74%;
    bottom: auto;
    top: 2%;
    left: 4%;
  }
  .mv__btn {
    width: 36%;
    bottom: 0;
    right: 4%;
  }
  .mv-news {
    margin: 20px auto 0;
    padding: 8px;
    border-radius: 8px;
  }
  .mv-news__link {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: 12px 2% 12px calc(4% + 24px);
    background-size: 24px;
    background-position-x: 2%;
  }
  @media (any-hover: hover) {
    .mv-news__link:hover {
      background-size: 24px;
      background-position-x: 2%;
    }
  }
  .mv-news__date {
    font-size: 14px;
    line-height: 1.2;
  }
  .cont-guide {
    margin: 40px 0 0;
    padding: 0 0 32px;
  }
  .cont-guide::after {
    border-radius: 90px 0px 0px 8px;
  }
  .cont-guide__list-main {
    gap: 12px 0;
  }
  .cont-guide__item-main {
    width: 100%;
  }
  .cont-guide__list-other {
    gap: 12px 2%;
    margin: 28px 0 0;
  }
  .cont-guide__item-other {
    width: 100%;
  }
  .cont-guide__hover-other::before,
  .cont-guide__hover-other::after {
    transition-duration: 0.45s;
  }
  @media (any-hover: hover) {
    .cont-guide__link:hover .cont-guide__hover-main::before,
    .cont-guide__link:hover .cont-guide__hover-main::after {
      width: 200vw;
      height: 200vw;
    }
    .cont-guide__link-other:hover .cont-guide__hover-other::before,
    .cont-guide__link-other:hover .cont-guide__hover-other::after {
      width: 200vw;
      height: 200vw;
    }
  }
  .cont-feature {
    margin: 48px 0 0;
  }
  .cont-feature__block-02 {
    padding: 0 0 30vw;
  }
  .cont-feature__ttl {
    font-size: 22px;
  }
  .cont-feature__deco {
    width: 100px;
    top: -40px;
  }
  .cont-feature__txtarea {
    width: 100%;
    gap: 8px;
  }
  .cont-feature__txtarea .btn-trans {
    margin: 8px 0 0;
  }
  .cont-feature__txtarea-01 {
    margin: 0 0 0 -4%;
    padding: 60px 8% 90px 8%;
    border-radius: 0 100px 8px 0;
  }
  .cont-feature__txtarea-02 {
    margin: min(220px,30vw) -4% 0 auto;
    padding: 60px 8% 90px 12%;
    border-radius: 100px 0 0 8px;
  }
  .cont-feature__txtarea-03 {
    margin: 80px 0 0 -4%;
    padding: 60px 8% 90px 8%;
    border-radius: 0 100px 8px 0;
  }
  .cont-feature__imgl {
    width: 45%;
    aspect-ratio: 4 / 3;
  }
  .cont-feature__imgl-01,
  .cont-feature__imgl-03 {
    border-radius: 4px 0 0 4px;
    bottom: -17vw
  }
  .cont-feature__imgs {
    width: 30%;
    border-radius: 4px;
  }
  .cont-feature__imgs-01,
  .cont-feature__imgs-03 {
    bottom: -22vw;
    right: 38%;
  }
  .cont-feature__imgl-02 {
    bottom: 50px;
  }
  .cont-feature__imgs-02-1 {
    left: 48%;
  }
  .cont-feature__imgs-02-2 {
    border-radius: 4px 0 0 4px;
    bottom: 40px;
    right: -4%;
  }
  .cont-feature__bnr-list {
    margin: 34vw auto 0;
  }
  .cont-feature__bnr-item {
    width: 100%;
    max-width: 480px;
  }
  .cont-news {
    margin: 60px 0 0;
    padding: 60px 0;
  }
  .cont-news-inner {
    grid-template-columns: 1fr;
  }
  .cont-news__link {
    padding: 16px 8px;
    gap: 4px;
  }
  .cont-news__date {
    font-size: 14px;
  }
  .cont-news__label {
    padding: 2px 16px;
    font-size: 14px;
  }
  .cont-news__block .btn-trans {
    margin: 16px 0 0 auto;
  }
  .cont-info-inner {
    padding: 0 0 40px;
  }
  .cont-info-inner::after {
    width: calc(100vw - 4vw);
    height: calc(100% - 24px);
    border-radius: 8px;
  }
  .cont-info__ttl {
    padding: 0 0 24px;
  }
  .cont-info__ttl-txt {
    font-size: 28px;
  }
  .cont-info__ttl-txt-en {
    font-size: 16px;
  }
  .cont-info__block {
    padding: 24px 4%;
    border-radius: 8px 90px 8px 8px;
  }
  .cont-info__block-ttl {
    margin: 0 auto 12px;
    font-size: 22px;
  }
  .cont-info__block-inner {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin: 0 auto;
  }
  .table-ttl {
    min-height: auto;
    margin: 0 0 8px;
    font-size: 18px;
  }
  .cont-info__block-ttl::after {
    width: 60px;
    height: 60px;
    left: -44px;
  }
  .table-head {
    font-size: 16px;
  }
  .table-data {
    padding: 10px;
  }
  .table-data:has(.font-en) {
    font-size: 18px;
  }
  .cont-info__btn {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 12px auto 0;
    font-size: 14px;
    background-size: 36px;
    background-position-x: 22px;
  }
  .cont-info__btn-num {
    font-size: 24px;
  }
  .info__map-address {
    margin: 4px auto 0;
  }
  .info__map-link {
    margin: 0 0 0 auto;
  }
  .info__map-btn {
    margin: 16px auto 0;
  }
  .cont-other {
    padding: 52px 0 0;
  }
  .cont-other__list {
    max-width: 480px;
    margin: auto;
  }
  .cont-other__item {
    width: 100%;
  }
  .cont-other__recruit-txt {
    font-size: 16px;
  }
  .cont-other__recruit {
    margin: 48px 0 0;
  }
  .cont-other__recruit-block {
    padding: 24px 32px;
  }
  .cont-other__bnr-slide {
    margin: 80px 0 48px;
  }
  .cont-other__bnr-slide .slick-list {
    padding-top: initial!important;
    padding-bottom: initial!important;
  }
  .cont-other__bnr-slide .slick-slide {
    transform: initial;
    margin: 0 12px;
    box-shadow: none
  }
  .cont-other__bnr-slide .slick-center {
    box-shadow: var(--button-tertiary-shadow);
  }
  .cont-other__bnr-slide .slick-arrow {
    width: 48px;
  }
  .cont-other__bnr-slide .next-arrow {
    right: 2%;
  }
  .cont-other__bnr-slide .prev-arrow {
    left: 2%;
  }
  .modaal-video-wrap {
    margin: auto;
  }
  .form-input[type="radio"] {
    width: 20px;
    height: 20px;
  }
  .form-input[type="radio"]:checked::after {
    width: 8px;
    height: 8px;
  }

  /* page */
  .page-mv-img {
    height: 240px;
  }
  .page-mv-img::after {
    border-radius: 60px 0 0 0;
  }
  .sub-nav__ttl {
    font-size: 22px;
  }
  .page-nav__list {
    grid-template-columns: repeat(2,1fr);
  }
  .sub-nav__list {
    grid-template-columns: 1fr;
  }

  .breadcrumb__list {
    gap: 4px 8px;
    padding: 8px 0 0 36px;
    margin: 0 0 48px;
  }
  .breadcrumb__item:not(:first-child) {
    gap: 8px;
  }
  .breadcrumb__txt,
  .breadcrumb__link {
    font-size: 12px;
  }
  .page-head {
    padding: 0 0 48px;
  }
  .page-nav__list {
    padding: 0 0 48px;
  }
  .sub-nav__block {
    border-radius: 0 60px 0 0;
    padding: 36px 0 48px;
  }

  .sidebar-nav {
    width: min(240px, 100%);
    margin: auto;
    padding: 0;
    border: 1px solid #cacfd4;
    border-radius: 8px;
    position: initial;
  }
  .sidebar-nav:not(:has(.sidebar-nav__list)) {
    display: none;
  }
  .sidebar-nav__ttl {
    display: none;
  }
  .sidebar-nav__btn {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 8px 8px 8px 16px;
    background: var(--color-main);
    border-radius: 8px;
    color: var(--color-base3);
    font-size: 18px;
    font-weight: 700;
    pointer-events: visible;
    cursor: pointer;
    transition: border-radius 0.25s ease-in-out;
  }
  .sidebar-nav__btn::after {
    content: "";
    display: block;
    width: 40px;
    height: 40px;
    background: url(../images/icon_arr_down_01.svg) no-repeat center center / contain;
  }
  .sidebar-nav__btn.accordion-btn--active {
    border-radius: 8px 8px 0 0;
  }
  .sidebar-nav__btn.sidebar-nav__btn--active::after {
    transform: rotate(180deg);
  }
  .sidebar-nav__list {
    display: none;
    padding: 12px 16px;
  }
  .sidebar-child__list {
    display: none;
  }

  .page__contents {
    padding: 0 0 80px;
  }
  .page__container .page__contents {
    width: 100%;
  }

  .pdf__block {
    gap: 8px;
  }
  .pdf__block-txt {
    font-size: 18px;
  }
  .pdf__block-img.pdf__block-img-m {
    width: 80%;
  }

  .page__bnr-block {
    margin: 48px auto 0;
  }

  .ttl-main,
  .news__content h1 {
    margin: 0 0 24px;
    padding: 0 0 16px;
    font-size: 26px;
  }
  .news__content h1:not(:first-child) {
    margin: 40px 0 24px;
  }
  .ttl-main-sub {
    font-size: 18px;
  }

  .ttl-sec,
  .news__content h2 {
    margin: 20px 0 12px;
    padding: 8px 12px 8px 24px;
    font-size: 20px;
  }
  .ttl-sec::before,
  .news__content h2::before {
    left: 10px;
  }
  .ttl-sec-num {
    font-size: 24px;
  }
  .ttl-sec + * {
    padding: 0 0 0 28px;
  }
  .ttl-sec:has(.ttl-sec-num) + * {
    padding: 0 0 0 34px;
  }

  .ttl-num {
    font-size: 20px;
  }
  .ttl-num-txt {
    width: 30px;
    height: 30px;
    font-size: 18px;
  }
  .ttl-num + * {
    padding: 4px 0 0 38px;
  }

  .ttl-obi {
    margin: 0 0 24px;
    font-size: 26px;
  }

  .ttl-line {
    font-size: 18px;
  }

  .ttl-nomal,
  .news__content h3 {
    font-size: 18px;
  }

  .figure__box {
    grid-template-columns: minmax(0, 1fr);
    padding: 16px;
  }

  .flow__box {
    padding: 16px;
    border-radius: 8px;
  }
  .flow__list > li:not(:first-child) {
    margin: 20px 0 0;
  }
  .flow__list > li:not(:first-child)::before {
    width: 16px;
    height: 8px;
    top: -14px;
  }
  .flow__other-list > li:not(:first-child) {
    margin: 20px 0 0;
  }
  .flow__num {
    margin: 0 12px 0 0;
    padding: 0 12px 0 0;
    font-size: 28px;
  }
  .flow__ttl {
    margin: 0 0 8px;
    font-size: 20px;
  }
  .flow__main .txt-common {
    margin: 8px 0 0;
  }
  .flow__inner {
    grid-template-columns: 1fr;
    border-radius: 8px;
  }
  .flow__list {
    margin: 0 0 32px;
  }
  .flow__other-list {
    margin: 0 0 32px;
  }
  .flow__btn-block .ttl-line {
    font-size: 18px;
  }
  .flow__btn-block .flow-time__btn,
  .flow-time__btn {
    margin-inline: auto;
  }
  .flow-time__list {
    margin: 48px 0 32px;
  }
  .flow-time__label {
    top: -32px;
    left: -2%;
  }
  .contact-box__body {
    gap: 12px 0;
    padding: 20px 16px;
  }
  .contact-box__head {
    padding: 8px 0;
    font-size: 18px;
  }
  .contact-box__tel-link {
    font-size: 16px;
  }
  .contact-box__tel-txt {
    padding: 0 0 0 36px;
    background-size: 32px;
    font-size: 32px;
  }
  .contact-box__tel-txt.contact-box__fax-txt {
    background-size: 36px;
  }
  .contact-box__time {
    gap: 0 4px;
  }

  .tab-list {
    gap: 8px;
  }
  .tab-list-top {
    margin: 40px 0 20px;
  }
  .tab-list-bottom {
    margin: 20px 0 0;
  }
  .tab-button {
    height: 56px;
    font-size: 14px;
    padding: 0 4px;
  }
  .tab-button.tab-button--active {
    height: 60px;
    font-size: 16px;
  }
  
  .relation {
    margin: 60px 0 0;
  }
  .relation__head {
    gap: 4px;
    padding: 0 0 4px;
    font-size: 22px;
  }
  .relation__head::before {
    width: 32px;
    height: 32px;
  }
  .relation__list {
    grid-template-columns: 1fr;
  }
  
  .note-box {
    gap: 12px;
    padding: 16px;
    border-radius: 8px;
  }

  .border-box {
    padding: 16px;
  }
  .border-box-02 {
    gap: 12px;
    padding: 16px;
  }
  .border-box-03 {
    padding: 16px;
  }

  .figure__box {
    border-radius: 8px;
  }

  .intro {
    gap: 12px;
  }
  .intro__message {
    padding: 16px 8px;
    border-radius: 8px;
    font-size: 22px;
  }
  .intro__message.intro__message-s {
    font-size: 18px;
  }
  .intro__txt {
    text-align: left;
  }

  .base-box-list {
    grid-template-columns: 100%;
  }

  .flow-box-list {
    gap: 16px;
  }
  .flow-box-list::before {
    width: 3px;
    left: 30px;
  }

  .visit__pdf-block .pdf__block-img {
    width: 80%;
  }
  .visit__box-item:not(:first-child) {
    margin: 16px 0 0;
  }
  .visit__btn {
    margin: 16px auto 0;
  }
  .visit__mail {
    grid-template-columns: 1fr;
  }
  .simulate__ttl.ttl-obi {
    font-size: 22px;
  }
  .simulate__ttl-sub {
    font-size: 14px;
  }
  .simulate__list .flow__box-inner {
    grid-template-columns: 1fr;
  }
  .simulate__list .flow__num {
    min-width: 80px;
    gap: 4px;
  }
  .simulate__list .flow__num {
    grid-template-columns: auto auto;
    justify-content: flex-start;
    border-right: none;
    border-bottom: 1px solid var(--color-line);
    padding: 0 0 8px;
    margin: 0 0 12px;
    min-width: initial;
  }
  .simulate__input-block {
    margin: 16px 0 0;
  }
  .simulate__head {
    padding: 2px 8px;
    font-size: 16px;
  }
  .simulate__input-block .form-label {
    padding: 12px;
  }
  .simulate__input-block .form-input[type="radio"]:checked::after {
    width: 12px;
    height: 12px;
    background-color: var(--color-base3);
  }
  .simulate__cost {
    margin: 20px 0 0;
  }
  .simulate__cost-en {
    font-size: 26px;
  }
  .simulate__result-head {
    font-size: 20px;
  }
  .simulate__result-body .simulate__cost {
    font-size: 18px;
  }
  .simulate__result-body .simulate__cost-en {
    font-size: 36px;
  }

  .drive__btn {
    margin: 28px auto 0;
  }

  .rehabili-nav__list {
    grid-template-columns: 100%;
  }
  .rehabili-nav__list .page-nav__btn:has(.btn-icon-audio) {
    max-width: 250px;
  }

  .data__wrap {
    margin: 40px 0 0;
    padding: 48px 0 72px;
  }
  .data__list-column2,
  .data__list-column3,
  .data__list-staff {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 520px;
    margin: 0 auto;
  }
  .data__main-num {
    padding: 8px 0 0;
    font-size: 48px;
  }
  .data__txt {
    padding: 4px 0 0;
  }
  .data__graph-area {
    grid-template-columns: 1fr;
    justify-items: center;
  }
  .data__graph-detail {
    gap: 8px;
  }
  .data__graph-data {
    font-size: 16px;
  }
  .data__staff-job.font-en {
    font-size: 24px;
  }

  .performance__top-block {
    grid-template-columns: 1fr;
  }
  .performance__top-img {
    max-width: 160px;
    margin: auto;
  }

  .doctor__block {
    grid-template-columns: 1fr;
  }
  .director__img {
    max-width: 240px;
    margin: 0 auto;
  }
  .doctor__item {
    grid-template-columns: 1fr;
    padding: 28px 0;
  }
  .doctor__name-txt {
    flex-direction: row;
    align-items: baseline;
    gap: 0 12px;
    padding: 0;
  }
  .doctor__name-txt-director {
    padding: 0 0 12px;
  }
  .doctor__table .table-row {
    flex-wrap: wrap;
  }
  .doctor__table .table-head,
  .doctor__table .table-data {
    width: 100%;
    padding: 8px 12px;
    font-size: 16px;
  }
  .doctor__table .table-head {
    justify-content: flex-start;
    border-right: none;
  }

  .smile__list {
    grid-template-columns: 1fr;
    padding: 0 0 120px;
  }
  .smile__link {
    gap: 8px;
  }
  .smile__ttl {
    padding: 0 0 8px;
    font-size: 20px;
  }
  .smile__ttl-date {
    font-size: 14px;
  }

  .floormap__slide .next-arrow {
    right: -6%;
  }
  .floormap__slide .prev-arrow {
    left: -6%;
  }
  .floorroom__detail-list {
    padding: 20px 0 0;
  }
  .floorroom__txt {
    margin: 12px 0 0;
    padding: 12px 0 0;
  }
  .floorroom__tab-list .tab-button {
    height: 36px;
  }
  .floormap__btn-item {
    width: 32%;
    height: 48px;
    padding: 0 0 6px;
  }
  .floormap__btn {
    font-size: 20px;
  }

  .about__block-list {
    gap: 16px;
  }
  .about__block-ttl {
    font-size: 20px;
  }
  .medicalrecord__price-table .table-head {
    width: 66%;
    padding: 10px;
  }
  .medicalrecord__price-table .table-data {
    min-width: 100px;
    font-size: 16px;
  }
  .outline__table-01 .table-head {
    padding: 10px;
  }
  .outline__table-02 .table-data-item,
  .outline__table-02 .table-head-item {
    padding: 10px;
  }

  .message__block {
    grid-template-columns: 1fr;
  }
  .message__img-block {
    grid-row: 1;
    max-width: 240px;
    margin: 0 auto;
  }
  .message__block .txt-common {
    grid-row: 2;
  }

  .performance__pdf-list.pdf__list {
    justify-content: center;
    gap: 48px 10%;
  }
  
  .cont__ttl-mark:has(.patient__txt) {
    align-items: baseline;
  }
  .patient__txt {
    font-size: 16px;
  }

  .nutrition__table-wrap {
    width: 100%;
    overflow-x: scroll;
  }
  .nutrition__table {
    width: 600px;
  }
  .nutrition__table .table-data {
    font-size: 16px;
  }
  .nutrition__table .table-data-label-2 .table-data-item {
    padding: 8px;
  }
  .nutrition__table .table-data-item {
    padding: 8px 12px;
  }

  .nurse__policy {
    grid-template-columns: 16px 1fr;
    font-size: 18px;
  }
  .nurse__policy-num {
    font-size: 22px;
  }

  .medical__block-btn .btn-trans {
    margin: auto;
  }

  .caresupport__join {
    padding: 12px;
  }
  .caresupport__pdf-slide {
    max-width: 360px;
  }
  .caresupport__pdf-slide.page__slide .next-arrow {
    right: 0;
  }
  .caresupport__pdf-slide.page__slide .prev-arrow {
    left: 0;
  }

  .seating__img-over {
    width: 100%;
    overflow-x: scroll;
  }
  .seating__img-list {
    grid-template-columns: repeat(4, 200px);
    width: 848px;
  }
  .seating__img-list:not(:has(:nth-child(4))) {
    grid-template-columns: repeat(3, 200px);
    width: 648px;
  }
  .seating__img-list:not(:has(:nth-child(3))) {
    grid-template-columns: repeat(2, 200px);
    width: 448px;
  }
  .seating__ba-wrap {
    grid-template-columns: 1fr;
    max-width: 360px;
  }
  .seating__ba-box-after:not(:has(.seating__ba-after-in)) {
    width: 100%;
  }
  .seating__ba-box-after::before {
    top: -30px;
    left: 50%;
    transform: translateX(-50%) rotate(90deg);
  }
  .seating__ba-after-in {
    grid-template-columns: 1fr;
  }
  .seating__ba-img {
    max-width: initial;
    margin: 0 auto 4px;
  }
  
  .access__contents .ttl-sec + * {
    padding: 0;
  }
  .access__map-view {
    margin: auto;
  }

  .sougu__intro-ttl {
    margin: 0 0 8px;
  }

  .intern__table.table {
    padding: 0;
  }
  .intern__table .table-head:nth-child(1),
  .intern__table .table-data:nth-child(1) {
    width: 60%;
  }
  .intern__table .table-head:nth-child(2),
  .intern__table .table-data:nth-child(2) {
    width: 40%;
  }
  .intern__table .table-head {
    padding: 10px;
  }

  .recruit__top-bnr {
    max-width: 480px;
    margin: 0 auto 40px;
  }
  .recruit__tab {
    gap: 12px 1%;
    margin: 0 0 32px;
  }
  .recruit__tab .tab-button {
    width: 48%;
    height: 52px;
  }
  .recruit__tab .tab-button.tab-button--active {
    font-size: 16px;
  }
  .recruit__tab-sub {
    margin: 0 0 8px;
  }

  .form__wrap {
    padding: 8px 4% 40px;
  }
  .form__wrap .wpcf7-form .form__label {
    margin: 24px 0 8px;
  }
  .form__wrap .wpcf7-form p:has(input[type="submit"]) {
    width: min(480px,100%);
    margin: 36px auto 0;
  }
  .form__wrap .wpcf7-form input[type="submit"] {
    min-width: initial;
    width: 100%;
    min-height: 68px;
  }


  /* 768 */
  .base-box-list:has(.base-box-icon) {
    margin: 24px 0 0;
  }

  .figure-item:not(:first-child) {
    margin: 36px 0 0;
  }

  .slide-loop-wrap {
    min-height: 44vw;
  }
  .slide-loop-item {
    width: calc(100vw / 2);
  }
  @media (any-hover: hover) {
    .slide-loop-item:hover {
      width: calc(100vw / 1.6);
    }
  }

  .head-nav {
    padding: 12px 20px;
  }
  .head-nav .sidebar-nav__list {
    display: block;
  }

  .sitemap__btn {
    padding: 0;
    font-size: 18px;
  }
  .sitemap__cont-inner {
    gap: 16px 0;
    padding: 20px 0 40px;
  }
  .sitemap__block {
    width: 47%;
  }
  .sitemap__link {
    padding: 12px 0;
  }
  .sitemap__list {
    padding: 8px 0 0 16px;
  }
  .fixed__btn-wrap {
    width: 36%;
  }
  .footer {
    padding: 36px 0 12px;
  }
  .footer__inner {
    grid-template-columns: 1fr;
    gap: 20px 4%;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: auto;
    padding: 0 4%;
  }
  .footer__info-block {
    padding: 24px 0 0;
    gap: 8px;
  }
  .footer__info-tel {
    flex-direction: column;
  }
  .footer__link-block {
    gap: 24px;
  }
  .footer__sns {
    justify-content: flex-start;
    grid-row: 2;
  }
  .footer__link-list {
    grid-row: 1;
  }
  .footer__copyright {
    padding: 40px 0 0;
  }
}

@media screen and (max-width: 428px) {
  .mv-img {
    aspect-ratio: 4/5;
  }
  .mv__slide-img {
    aspect-ratio: 4/5;
  }
  .cont-guide__link {
    grid-template-columns: 28% 1fr;
  }
  .cont-guide__box {
    padding: 8px 4% 8px 0;
  }
  .cont-guide__img img {
    aspect-ratio: 31/33;
  }
  .cont-feature__deco {
    width: 32%;
    top: -36px;
  }
  .cont-feature__block-02 {
    padding: 0 0 122px
  }
  .cont-feature__imgl-02 {
    bottom: 56px;
  }
  .cont-feature__imgs-02-2 {
    bottom: 42px;
  }
  .cont-feature__txtarea {
    width: 100%;
    padding: 48px 8% 28vw;
  }
  .cont-feature__txtarea-01,
  .cont-feature__txtarea-01 {
    border-radius: 0 90px 8px 0;
  }
  .cont-feature__txtarea-02 {
    border-radius: 90px 0 0 8px;
  }
  .cont-other__recruit {
    grid-template-columns: 100%;
  }
  .cont-other__recruit-slide {
    height: 32vw;
  }
  .cont-other__recruit-slide-img {
    width: 480vw;
  }

  /* page */
  .page-nav__list {
    grid-template-columns: 1fr;
  }

  .ttl-sec,
  .news__content h2 {
    padding: 8px 12px 8px 16px;
  }
  .ttl-sec::before,
  .news__content h2::before {
    left: 5px;
  }
  .ttl-sec + * {
    padding: 0 0 0 16px;
  }

  .btn-main {
    min-width: initial;
    width: 100%;
  }

  .note-link-item {
    width: 100%;
  }
  .note-link-item .btn-icon {
    width: 100%;
  }

  .tab-list {
    gap: 4px;
  }

  .simulate__result-body .simulate__cost {
    font-size: 16px;
  }
  .simulate__result-body .simulate__cost-en {
    font-size: 30px;
  }

  .facility__table-02 .table-head:nth-child(1) {
    width: 40%;
  }
  .facility__table-02 .table-head:not(:first-child),
  .facility__table-02 .table-data {
    width: 20%;
  }
  .facility__table-03-wrap {
    width: 100%;
    overflow-x: scroll;
  }
  .facility__table-03 {
    width: 500px;
  }

  .outline__table-02-wrap {
    width: 100%;
    overflow-x: scroll;
  }
  .outline__table-02 {
    width: 500px;
  }

  .contact-box__tel-txt {
    padding: 0 0 0 40px;
    font-size: 28px;
  }

  .sitemap__cont-inner {
    gap: 16px;
  }
  .sitemap__block {
    width: 100%;
  }
  .sitemap__list {
    padding: 12px 0 0 16px;
  }
  .sitemap__link {
    padding: 8px 0;
  }
  .footer__link-block {
    margin: auto;
  }
  .footer__sns {
    justify-content: center;
  }
  .footer__copyright {
    text-align: center;
  }
}
