@charset "UTF-8";
.p-mv {
  height: 56.2vw;
  background: url(../../images/top/mv_bg.jpg) no-repeat right top;
  background-size: calc(100vw - 390px) 100%;
  display: flex;
  align-items: center;
}

.p-mv__visual__inner {
  margin-right: -390px;
}

.p-mv__visual__list .slick-list {
  overflow: visible;
  margin: 0 -1vw;
}
.p-mv__visual__list .slick-slide {
  margin: 0 1vw;
}

.p-mv__visual__item {
  filter: drop-shadow(0 0 20px rgba(0, 0, 0, 0.5));
  transform: translateZ(0);
}
.p-mv__visual__item img {
  width: 100%;
}

.p-mv__body {
  margin-top: 30px;
  padding-left: 390px;
}

.p-mv__catch__inner {
  height: 100%;
}

.p-mv__catch__text {
  font-size: 3rem;
  font-family: "A-OTF フォーク Pro", var(--font-base);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.05em;
  text-shadow: 0 0 10px #fff, 0 0 10px #fff, 0 0 10px #fff, 0 0 10px #fff, 0 0 10px #fff;
  text-align: center;
}
.p-mv__catch__text small {
  color: #000;
  font-size: 2.3rem;
  font-family: var(--font-base);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.1em;
  background: var(--color-white);
  box-shadow: 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white);
  padding: 0 20px;
  position: relative;
}
.p-mv__catch__text small::before, .p-mv__catch__text small::after {
  content: "";
  background: url(../../images/deco_16.svg);
  background-size: 100% 100%;
  position: absolute;
  top: -20px;
  width: 51px;
  height: 52px;
}
.p-mv__catch__text small::before {
  left: -40px;
}
.p-mv__catch__text small::after {
  right: -40px;
  transform: scale(-1, 1);
}
.p-mv__catch__text span {
  color: var(--color-white);
  font-size: 4.2rem;
}
.p-mv__catch__text span.p-mv__catch__text--pink {
  text-shadow: 0 0 10px #e01999, 0 0 10px #e01999, 0 0 10px #e01999, 0 0 10px #e01999, 0 0 10px #e01999;
}
.p-mv__catch__text span.p-mv__catch__text--blue {
  text-shadow: 0 0 10px #32a8cc, 0 0 10px #32a8cc, 0 0 10px #32a8cc, 0 0 10px #32a8cc, 0 0 10px #32a8cc;
}
.p-mv__catch__text strong {
  color: var(--color-white);
  font-size: 7rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  text-shadow: 0 0 20px #915593, 0 0 20px #915593, 0 0 20px #915593, 0 0 20px #915593, 0 0 20px #915593;
}

.p-mv__catch__image {
  display: block;
  max-width: 100%;
  max-height: 100%;
  margin-left: auto;
  object-fit: contain;
  object-position: top;
}

.p-mv__menu {
  --column-gap: 2.5em;
  margin-top: 2.5em;
  white-space: nowrap;
}

.p-mv__menu .l-menu {
  display: flex;
  flex-wrap: wrap;
  row-gap: 0.75em;
  column-gap: var(--column-gap);
  line-height: 1;
}

.p-mv__menu .l-menu__item {
  position: relative;
}

.p-mv__menu .l-menu__item:not(:last-of-type)::after {
  position: absolute;
  top: 55%;
  left: calc(100% + var(--column-gap) / 2);
  width: 1.5px;
  height: 0.9em;
  content: "";
  background-color: currentcolor;
  transform: translateX(-50%) translateY(-50%);
}

.p-mv__menu .l-menu__sub {
  display: none;
}

@media (max-width: 1024px) {
  .p-mv {
    height: 170vw;
    background: url(../../images/top/mv_bg.jpg) no-repeat center top;
    background-size: auto 100%;
    position: relative;
    margin-top: 60px;
  }
  .p-mv__visual__inner {
    margin-right: 0;
  }
  .p-mv__visual__list .slick-list {
    margin: 0 -2vw;
  }
  .p-mv__visual__list .slick-slide {
    margin: 0 2vw;
  }
  .p-mv__body {
    margin-top: 4vw;
    padding-left: 0;
  }
  .p-mv__catch__text {
    font-size: 4vw;
    text-shadow: 0 0 1.3vw #fff, 0 0 1.3vw #fff, 0 0 1.3vw #fff, 0 0 1.3vw #fff, 0 0 1.3vw #fff;
  }
  .p-mv__catch__text small {
    font-size: 3.4vw;
    box-shadow: 0 0 1.3vw var(--color-white), 0 0 1.3vw var(--color-white), 0 0 1.3vw var(--color-white), 0 0 1.3vw var(--color-white), 0 0 1.3vw var(--color-white);
    padding: 0 2.6vw;
  }
  .p-mv__catch__text small::before, .p-mv__catch__text small::after {
    top: -3vw;
    width: 7.6vw;
    height: 7.8vw;
  }
  .p-mv__catch__text small::before {
    left: -6vw;
  }
  .p-mv__catch__text small::after {
    right: -6vw;
  }
  .p-mv__catch__text span {
    font-size: 6.4vw;
  }
  .p-mv__catch__text span.p-mv__catch__text--pink {
    text-shadow: 0 0 1.3vw #e01999, 0 0 1.3vw #e01999, 0 0 1.3vw #e01999, 0 0 1.3vw #e01999, 0 0 1.3vw #e01999;
  }
  .p-mv__catch__text span.p-mv__catch__text--blue {
    text-shadow: 0 0 1.3vw #32a8cc, 0 0 1.3vw #32a8cc, 0 0 1.3vw #32a8cc, 0 0 1.3vw #32a8cc, 0 0 1.3vw #32a8cc;
  }
  .p-mv__catch__text strong {
    font-size: 10.4vw;
    text-shadow: 0 0 2.6vw #915593, 0 0 2.6vw #915593, 0 0 2.6vw #915593, 0 0 2.6vw #915593, 0 0 2.6vw #915593;
  }
  .p-mv__menu {
    display: none;
  }
}
.p-clinic-info {
  background: url(../../images/top/clinic_info_bg.jpg) left top;
  background-size: contain;
  padding-top: 60px;
  padding-bottom: 60px;
}

.p-clinic-info__inner {
  max-width: 984px;
}

.p-clinic-info__address {
  color: var(--color-white);
  margin-bottom: 20px;
}

.p-clinic-info__address__part {
  display: block;
}

@media (max-width: 525px) {
  .p-clinic-info {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .p-clinic-info__address {
    font-size: 1.2rem;
  }
}
.p-notice-section {
  background: #e7e2fc;
  padding: 100px 0;
}

.p-notice-section__inner {
  container-type: inline-size;
}

.p-notice-section__list {
  --column-count: 2;
  --column-gap: 40px;
  --row-gap: 40px;
  justify-content: center;
}

.p-notice {
  text-align: center;
  background: url(../../images/bg_01.jpg);
  background-size: 20px;
  border-radius: 10px;
  position: relative;
  z-index: 1;
}
.p-notice::before, .p-notice::after {
  content: "";
  position: absolute;
  z-index: -1;
}
.p-notice::before {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #0084a6 0%, #96979b 45%, #0084a6 100%);
  mix-blend-mode: saturation;
  border-radius: 10px;
  left: 0;
  top: 0;
}
.p-notice::after {
  width: calc(100% - 20px);
  height: calc(100% - 20px);
  background: var(--color-white);
  left: 10px;
  top: 10px;
}

.p-notice__deco img {
  position: absolute;
}

.p-notice--open .p-notice__deco img:nth-child(1) {
  left: -10px;
  top: -30px;
}
.p-notice--open .p-notice__deco img:nth-child(2) {
  right: -20px;
  top: -10px;
}

.p-notice--tour .p-notice__deco img:nth-child(1) {
  left: -25px;
  top: -40px;
}
.p-notice--tour .p-notice__deco img:nth-child(2) {
  right: -10px;
  top: -15px;
}

.p-notice__header {
  padding: 40px 40px 20px;
}

.p-notice__heading {
  color: var(--color-heading);
  font-size: 2rem;
  font-family: "A-OTF フォーク Pro", var(--font-base);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
}
.p-notice__heading span {
  border-bottom: 2px solid #9f95bb;
  padding-bottom: 5px;
}

.p-notice__body {
  padding: 0 40px 40px;
}

.p-notice__message {
  text-align: left;
}

.p-notice__open {
  font-family: "A-OTF フォーク Pro", var(--font-base);
  line-height: 1.4;
  margin-bottom: 20px;
}
.p-notice__open em {
  color: #f84580;
  font-size: 2.7rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0;
}
.p-notice__open em small {
  font-size: 1.8rem;
}
.p-notice__open strong {
  color: #010101;
  font-size: 4.5rem;
  font-weight: var(--font-weight-bold);
  display: block;
}

.p-notice__preview {
  font-family: "A-OTF フォーク Pro", var(--font-base);
  line-height: 1.4;
  margin-bottom: 20px;
}
.p-notice__preview strong {
  color: #010101;
  font-size: 2.5rem;
  display: block;
  margin-bottom: 10px;
}
.p-notice__preview em,
.p-notice__preview span {
  color: #f84580;
  letter-spacing: 0;
}
.p-notice__preview em small,
.p-notice__preview span small {
  font-size: 1.8rem;
}
.p-notice__preview em {
  font-size: 2.5rem;
}
.p-notice__preview em small {
  font-size: 1.8rem;
}
.p-notice__preview span {
  font-size: 1.6rem;
}
.p-notice__preview span small {
  font-size: 1.4rem;
}

@media (max-width: 768px) {
  .p-notice-section__list {
    flex-direction: column;
  }
  .p-notice {
    width: 100%;
  }
}
@media (max-width: 525px) {
  .p-notice-section {
    padding: 60px 0;
  }
  .p-notice__body {
    padding: 0 30px 30px;
  }
}
.p-info-section {
  background: url(../../images/top/info_bg.jpg) left top;
  background-size: cover;
  container-type: inline-size;
  position: relative;
  z-index: 0;
  padding: 100px 0;
}

.p-info-section__inner {
  position: relative;
}

.p-info-section__header {
  border-radius: 8px 8px 0 0;
  margin-bottom: 25px;
}

.p-info-section .p-info-panel {
  position: relative;
}

#info-panel-news .p-info-section__header {
  background: #ff5ab1;
}

#info-panel-blog .p-info-section__header {
  background: #2d6fe2;
}

.p-info-section__heading img {
  width: auto;
  max-height: 50px;
  position: relative;
  top: -20px;
  left: 20px;
}

.p-info-section__deco {
  position: absolute;
}

#info-panel-news .p-info-section__deco {
  right: 12px;
  top: -36px;
}
#info-panel-news .p-info-section__deco img {
  width: 91px;
}

#info-panel-blog .p-info-section__deco {
  right: 12px;
  top: -20px;
}
#info-panel-blog .p-info-section__deco img {
  width: 100px;
}

.p-info-section__body {
  container-type: inline-size;
  grid-area: body;
}

.p-info-section__panels {
  display: flex;
  flex-direction: column;
  gap: 60px;
  position: relative;
}

.p-info-section__panels:is(:not(.p-info-section__tabs + *)) {
  border-top-left-radius: var(--radius-md);
  border-top-right-radius: var(--radius-md);
}

.p-info-panel {
  background-color: var(--color-white);
  border-radius: 8px 8px 0 0;
  box-shadow: 5px 5px 10px rgba(120, 77, 142, 0.5);
}

.p-info-panel__inner {
  padding: 0 20px 30px;
}

.p-info-panel__main {
  --border: 1px solid currentcolor;
  --scrollbar-size: 10px;
  max-height: 332px;
  padding-right: 20px;
}

.p-info-panel__main .simplebar-track {
  --border-width: 10px;
}

.p-info-panel__main .simplebar-track::before {
  position: absolute;
  content: "";
  background-color: rgba(224, 25, 153, 0.8);
  opacity: 0.1;
}

.p-info-panel__main .simplebar-track.simplebar-vertical {
  width: var(--scrollbar-size);
}

.p-info-panel__main .simplebar-track.simplebar-vertical::before {
  top: calc(var(--scrollbar-size) / 2);
  bottom: calc(var(--scrollbar-size) / 2);
  left: 50%;
  width: var(--border-width);
  transform: translateX(-50%);
}

.p-info-panel__main .simplebar-track.simplebar-horizontal {
  height: var(--scrollbar-size);
}

.p-info-panel__main .simplebar-track.simplebar-horizontal::before {
  top: 50%;
  right: calc(var(--scrollbar-size) / 2);
  left: calc(var(--scrollbar-size) / 2);
  height: var(--border-width);
  transform: translateY(-50%);
}

.p-info-panel__main .simplebar-scrollbar::before {
  inset: 0;
  background-color: #e01999;
  border-radius: 0;
}

.p-info-panel__main .simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
}

.p-info-panel__list {
  display: grid;
  gap: 10px;
}
.p-info-panel__list .p-info {
  border-bottom: 1px dotted #5f4e8e;
  padding-bottom: 10px;
}

.p-info-panel__sub {
  display: flex;
  grid-area: sub;
  align-items: center;
  justify-content: center;
}

.p-info {
  container: info/inline-size;
}

.p-info__header {
  grid-area: header;
  min-width: 6em;
  opacity: 0.7;
  container: header/inline-size;
}

.p-info__date {
  color: var(--color-heading);
  font-size: 1.6rem;
  font-family: var(--font-english);
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.p-info__title {
  font-size: 1.8rem;
  font-weight: var(--font-weight-bold);
}

.p-info-panel__more-button {
  margin-top: 30px;
}

@media (max-width: 525px) {
  .p-info-section {
    padding: 60px 0;
  }
}
.p-apo-section {
  text-align: center;
  background: url(../../images/top/apo_bg.jpg) no-repeat center top;
  background-size: cover;
  position: relative;
  z-index: 0;
  padding: 100px 0;
}

.p-apo-section__inner {
  background: #e7e2fc;
  border-radius: 16px;
  border: 5px solid #fff;
  padding: 0 25px 40px;
}

.p-apo-section__heading {
  margin-bottom: 10px;
}
.p-apo-section__heading img {
  width: auto;
  max-height: 50px;
}

.p-apo-section__heading__text {
  color: var(--color-heading);
  font-size: 2.4rem;
  font-weight: var(--font-weight-bold);
  display: block;
  margin-top: 20px;
}

.p-apo-section__heading__icon {
  font-size: 1.5em;
  color: var(--color-primary);
}

.p-apo-section__body {
  display: flex;
  gap: 30px;
  margin-top: 30px;
}

.p-apo-section__item--tel {
  flex-grow: 2;
}

.p-apo-section__item--web {
  flex-grow: 2;
}

.p-apo {
  max-width: 700px;
  margin-inline: auto;
  container: item/inline-size;
}

.p-apo-section__header {
  margin: -25px 0 60px;
}

.p-apo__heading {
  color: var(--color-white);
  font-size: 1.6rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  background: var(--color-heading);
  position: relative;
  margin-bottom: 10px;
  padding: 4px 10px;
}

.p-apo-section__item .p-apo__heading img {
  position: absolute;
  left: 0;
  bottom: 0;
}

.p-apo-section__item--web .p-apo__heading img {
  left: 12px;
  bottom: 5px;
}

.p-apo__tel__num {
  color: #ff5c9a;
  font-size: 4rem;
  font-family: var(--font-english);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  display: block;
  position: relative;
  z-index: 1;
  margin-bottom: 10px;
}
.p-apo__tel__num::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  z-index: -1;
  -webkit-text-stroke: 8px #fff;
}

.p-apo__tel__note {
  text-align: left;
}

.p-apo__web {
  --button-align: center;
}

.p-apo__web__text {
  grid-area: text;
}

.p-apo__web__button {
  color: var(--color-white);
  line-height: 1.4;
  max-width: 330px;
  background: #12c255;
  border: 3px solid var(--color-white);
  display: flex;
  justify-content: center;
  gap: 25px;
  margin: 10px auto 0;
  padding: 10px 20px;
}
.p-apo__web__button .c-icon--web {
  width: 46px;
}
.p-apo__web__button .c-button__text span {
  font-size: 3.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
}
.p-apo__web__button .c-button__text small {
  font-size: 1.8rem;
  display: block;
}

@media (max-width: 1024px) {
  .p-apo-section__body {
    flex-direction: column;
    gap: 60px;
  }
}
@media (max-width: 525px) {
  .p-apo-section {
    padding: 60px 0;
  }
  .p-apo-section__inner {
    padding: 0 20px 30px;
  }
  .p-apo-section__header {
    margin: -21px 0 30px;
  }
  .p-apo__heading {
    font-size: 4vw;
    margin-bottom: 10px;
    padding: 4px 10px;
  }
  .p-apo-section__item .p-apo__heading img {
    width: 15vw;
    left: -5px;
  }
  .p-apo-section__item--web .p-apo__heading {
    text-align: right;
  }
  .p-apo-section__item--web .p-apo__heading img {
    width: 10vw;
    left: 10px;
    bottom: 10px;
  }
  .p-apo-section__body {
    gap: 30px;
  }
  .p-apo__web__button {
    max-width: 250px;
    padding: 5px 30px;
  }
  .p-apo__web__button .c-icon--web {
    width: 33px;
  }
  .p-apo__web__button .c-button__text span {
    font-size: 2.4rem;
  }
  .p-apo__web__button .c-button__text small {
    font-size: 1.2rem;
  }
}
@media (max-width: 400px) {
  .p-apo__tel__num {
    font-size: 9vw;
  }
  .p-apo__tel__num::before {
    -webkit-text-stroke: 6px #fff;
  }
}
.p-policy {
  position: relative;
  padding-top: 160px;
  padding-bottom: 160px;
}

.p-policy__inner {
  width: auto;
}

.p-policy__section-title {
  text-align: center;
  margin-bottom: 120px;
}
.p-policy__section-title img {
  width: auto;
  max-height: 104px;
}

.p-policy__grid {
  display: flex;
  justify-content: flex-end;
}

.p-policy__body {
  padding-left: 100px;
}

.p-policy__heading {
  color: var(--color-heading);
  font-size: 4.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.6;
  -webkit-text-stroke: 8px var(--color-white);
  paint-order: stroke;
  margin-bottom: 100px;
}

.p-policy__content {
  position: relative;
  z-index: 1;
}
.p-policy__content::before {
  content: "";
  width: 100vw;
  height: 100%;
  position: absolute;
  right: -200px;
  background-color: #e7e2fc;
  z-index: -1;
}
.p-policy__content p {
  font-size: 1.8rem;
  padding: 100px 100px 100px 0;
}

.p-policy__deco img {
  position: absolute;
}
.p-policy__deco img:nth-child(1) {
  width: 309px;
  left: -312px;
  top: -156px;
  display: none;
}
.p-policy__deco img:nth-child(2) {
  width: 355px;
  right: -336px;
  bottom: -79px;
}

.p-policy__image--01 {
  order: 2;
  z-index: 1;
  width: 46.3vw;
  position: relative;
}
.p-policy__image--01::before, .p-policy__image--01::after {
  content: "";
  background-size: 100% 100% !important;
  position: absolute;
  z-index: 1;
}
.p-policy__image--01::before {
  width: 112px;
  height: 128px;
  background: url(../../images/deco_09.png);
  right: 0;
  top: -120px;
}
.p-policy__image--01::after {
  width: 16vw;
  height: 14.9vw;
  background: url(../../images/deco_10.png);
  left: -13vw;
  top: 7vw;
}
.p-policy__image--01 img {
  width: 100%;
}

@media (max-width: 1460px) {
  .p-policy__inner {
    padding-right: 0;
    padding-left: 390px;
  }
}
@media (max-width: 1024px) {
  .p-policy__inner {
    padding-left: 20px;
  }
  .p-policy__section-title {
    margin-bottom: 10.6vw;
    padding-right: 20px;
    text-align: left;
  }
  .p-policy__grid {
    display: block;
  }
  .p-policy__body {
    padding-left: 0;
  }
  .p-policy__heading {
    font-size: 6.6vw;
    -webkit-text-stroke: 8px var(--color-white);
    margin: -90vw 0 30vw;
    position: relative;
    z-index: 2;
  }
  .p-policy__image--01 {
    width: 70.6vw;
    margin: 0 0 0 auto;
    padding-top: 13.3vw;
    z-index: 2;
  }
  .p-policy__image--01::before {
    width: 14vw;
    height: 16.5vw;
    left: auto;
    right: 2.5vw;
    top: -10vw;
  }
  .p-policy__image--01 img {
    aspect-ratio: 530/577;
    object-fit: cover;
    object-position: calc(50% + 20vw) top;
  }
  .p-policy__image--01::after {
    aspect-ratio: 688/639;
    width: 45.8vw;
    height: auto;
    background: url(../../images/deco_10.png);
    left: -36.6vw;
    bottom: -3.7vw;
    top: auto;
  }
  .p-policy__content {
    position: relative;
    z-index: 1;
  }
  .p-policy__content::before {
    width: calc(100vw - 20px);
    right: auto;
    left: -20px;
  }
  .p-policy__content p {
    padding: 29.3vw 60px 60px 0;
  }
  .p-policy__deco img:nth-child(1) {
    display: none;
  }
  .p-policy__deco img:nth-child(2) {
    width: 42vw;
    right: -14.2vw;
    bottom: -10.6vw;
  }
}
@media (max-width: 525px) {
  .p-policy {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .p-policy__section-title {
    text-align: center;
  }
  .p-policy__content p {
    font-size: 1.6rem;
    padding: 29.3vw 40px 20px 0;
  }
}
.p-greeting {
  position: relative;
  z-index: 0;
  background: url(../../images/top/greeting_bg.jpg) no-repeat center top;
  background-size: cover;
  padding-top: 160px;
  padding-bottom: 160px;
}

.p-greeting__inner {
  max-width: 1590px;
  position: relative;
}

.p-greeting__heading {
  text-align: center;
  margin-bottom: 120px;
}
.p-greeting__heading img {
  width: auto;
  max-height: 104px;
}

.p-greeting__grid {
  display: flex;
  justify-content: space-between;
  gap: 80px;
}

.p-greeting__main {
  width: 59.4vw;
  position: relative;
  z-index: 2;
}

.p-greeting__slogan {
  color: var(--color-heading);
  font-size: 4.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.6;
  margin-bottom: 20px;
  -webkit-text-stroke: 8px var(--color-white);
  paint-order: stroke;
}
.p-greeting__slogan span {
  color: #e01999;
  font-size: 2.8rem;
}

.p-greeting__content {
  color: #010101;
  line-height: 2;
  text-shadow: 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white), 0 0 10px var(--color-white);
}

.p-greeting__sign {
  color: var(--color-heading);
  -webkit-text-stroke: 4px var(--color-white);
  paint-order: stroke;
  justify-content: center;
  margin-top: 30px;
}
.p-greeting__sign .c-signature__position {
  font-size: 2.2rem;
  transform: translateY(-0.25em);
}
.p-greeting__sign .c-signature__name {
  font-size: 3.2rem;
}
.p-greeting__sign .c-signature__name ruby::before {
  font-size: 1.4rem;
  -webkit-text-stroke: 0 currentcolor;
  paint-order: normal;
}

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

.p-greeting__more-button {
  margin-top: 30px;
}

.p-greeting__portrait {
  max-width: 510px;
  position: relative;
  z-index: 1;
}

.p-greeting__image img {
  border: 10px solid var(--color-white);
  border-radius: 30px;
}

.p-greeting__deco img {
  position: absolute;
  z-index: -1;
}
.p-greeting__deco img:nth-child(1) {
  width: 263px;
  left: -100px;
  top: -56px;
}
.p-greeting__deco img:nth-child(2) {
  width: 201px;
  right: -94px;
  top: 407px;
}

@media (max-width: 1630px) {
  .p-greeting__inner {
    width: auto;
    padding-right: 20px;
    padding-left: 410px;
  }
}
@media (max-width: 1024px) {
  .p-greeting__inner {
    padding-left: 20px;
  }
  .p-greeting__grid {
    flex-direction: column;
  }
  .p-greeting__main {
    width: auto;
  }
  .p-greeting__portrait {
    margin: 0 auto;
  }
}
@media (max-width: 525px) {
  .p-greeting {
    padding: 60px 0;
  }
  .p-greeting::before {
    content: "";
    width: 16.9vw;
    height: 20.3vw;
    background: url(../../images/deco_12.png);
    background-size: 100% 100%;
    position: absolute;
    right: -1.3vw;
    top: 120px;
  }
  .p-greeting__heading {
    margin-bottom: 30px;
  }
  .p-greeting__grid {
    gap: 60px;
  }
  .p-greeting__slogan {
    font-size: 8vw;
    margin-bottom: 1em;
    -webkit-text-stroke: 8px var(--color-white);
  }
  .p-greeting__slogan span {
    font-size: 5.3vw;
  }
  .p-greeting__sign {
    justify-content: flex-start;
    margin: 20px 20px 0;
  }
  .p-greeting__sign .c-signature__position {
    font-size: 1.6rem;
  }
  .p-greeting__sign .c-signature__name {
    font-size: 2.7rem;
  }
  .p-greeting__sign .c-signature__name ruby::before {
    font-size: 1.2rem;
    -webkit-text-stroke: 0 currentcolor;
    paint-order: normal;
  }
  .p-greeting__image img {
    border: 5px solid var(--color-white);
    border-radius: 16px;
  }
  .p-greeting__sign {
    -webkit-text-stroke: 0 currentcolor;
    paint-order: normal;
    text-shadow: 3px 3px 0 var(--color-white), -3px -3px 0 var(--color-white), -3px 3px 0 var(--color-white), 3px -3px 0 var(--color-white), 0px 3px 0 var(--color-white), 0px -3px 0 var(--color-white), -3px 0px 0 var(--color-white), 3px 0px 0 var(--color-white);
  }
  .p-greeting__sign .c-signature__name ruby::before {
    text-shadow: none;
  }
  .p-greeting__deco img:nth-child(1) {
    width: 54.2vw;
    left: -35.6vw;
    top: -34.5vw;
  }
  .p-greeting__deco img:nth-child(2) {
    width: 41.4vw;
    right: -14.5vw;
    top: 63.6vw;
  }
}
.p-features-section {
  position: relative;
  z-index: 0;
  background: url(../../images/top/features_bg_pc.jpg) no-repeat center top;
  background-size: cover;
  padding: 160px 0;
}

.p-features-section__heading {
  text-align: center;
  background: var(--color-white);
  border-radius: 10px;
  margin-bottom: 60px;
  padding: 10px 40px;
}
.p-features-section__heading img {
  width: auto;
  max-height: 104px;
}

.p-features-section__main {
  container-type: inline-size;
}

.p-features-section__list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  counter-reset: features;
}

.p-feature {
  width: calc(50% - 10px);
  border-radius: 12px;
  border: 6px solid var(--color-white);
  background: #e7e2fc;
}

.p-feature__main {
  position: relative;
  z-index: 1;
  grid-area: main;
  margin: 0 20px 20px;
}

.p-feature__header {
  text-align: center;
  border-bottom: 2px dotted var(--color-heading);
  margin: -12px 0 10px;
  padding-bottom: 10px;
}

.p-feature__number {
  color: var(--color-white);
  font-size: 1.9rem;
  font-family: var(--font-english);
  letter-spacing: 0;
  counter-increment: features;
  width: 142px;
  height: 24px;
  line-height: 24px;
  background: url(../../images/top/feature_title_02.png);
  background-size: 100% 100%;
  border-radius: 5px;
  display: block;
  margin: 0 auto 10px;
}

.p-feature__number::before {
  content: "FEATURE";
}

.p-feature__number::after {
  content: counter(features, decimal-leading-zero);
}

.p-feature__heading {
  color: var(--color-heading);
  font-size: 1.8rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.6;
}

.p-feature__content {
  line-height: 2;
}

.p-feature__buttons {
  display: flex;
  flex-direction: column;
  gap: 1em;
  align-items: flex-end;
  margin-top: 2.5em;
}

.p-feature__image {
  width: 100%;
  position: relative;
  z-index: 0;
  grid-area: image;
  overflow: hidden;
}

@media (max-width: 768px) {
  .p-features-section {
    background: url(../../images/top/features_bg_sp.jpg) no-repeat center top;
    background-size: cover;
  }
  .p-features-section__list {
    flex-direction: column;
  }
  .p-feature {
    width: 100%;
  }
}
@media (max-width: 525px) {
  .p-features-section {
    padding: 60px 0;
  }
  .p-features-section__heading {
    margin-bottom: 30px;
  }
}
.p-services-section {
  text-align: center;
  padding-top: 160px;
  padding-bottom: 160px;
}
.p-services-section__inner {
  width: 100%;
  padding-right: 0;
}
@media (max-width: 1460px) {
  .p-services-section__inner {
    padding-left: 390px;
  }
}
@media (max-width: 1024px) {
  .p-services-section__inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}

.p-services-section__heading {
  margin-bottom: 60px;
  padding: 0 40px;
}
.p-services-section__heading img {
  width: auto;
  max-height: 104px;
}

.p-services-section__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}

.p-services-section__list__item:nth-child(-n+3) {
  width: calc(33.3% - 7px);
  margin-bottom: 10px;
}

.p-services-section__list__item:nth-child(n+4) {
  width: calc(25% - 8px);
}

.p-services-section__list__item:nth-child(4),
.p-services-section__list__item:nth-child(8) {
  width: calc(12.5% - 8px);
}

.p-service {
  color: var(--color-white);
  text-shadow: 0 0 10px #082da3, 0 0 10px #082da3, 0 0 10px #082da3;
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 12px;
}
.p-service::before {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(69, 36, 150, 0.5);
  border-radius: 12px;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

.p-service__list {
  max-width: 280px;
  width: 100%;
  margin: 10px auto 0;
}

.p-services-section__list__item:nth-child(-n+3) .p-service::before {
  background: rgba(69, 36, 150, 0.1);
}
.p-services-section__list__item:nth-child(-n+3) .p-service__list {
  position: relative;
  padding: 10px;
}
.p-services-section__list__item:nth-child(-n+3) .p-service__list::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #452496;
  mix-blend-mode: multiply;
  position: absolute;
  left: 0;
  top: 0;
}
.p-services-section__list__item:nth-child(-n+3) .p-service__list__item {
  position: relative;
}

.p-services-section__list__item:nth-child(n+4) .p-service__list__item {
  font-size: 1.6rem;
}

.p-service__name {
  font-size: 2.4rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  letter-spacing: 0.15em;
}

.p-services-section__list__item:nth-child(-n+3) .p-service__name {
  font-size: 3.4rem;
}

.p-service__image {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -3;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: ease 0.3s;
}

.p-service:hover .p-service__image {
  transform: scale(1.1);
}

.p-services-section__sub {
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-services__more-button {
  margin-top: 30px;
}

@media (max-width: 1460px) {
  .p-service__name {
    font-size: 1.6vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__name {
    font-size: 2.3vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__list__item {
    font-size: 1vw;
  }
  .p-services-section__list__item:nth-child(n+4) .p-service__list__item {
    font-size: 1vw;
  }
}
@media (max-width: 1024px) {
  .p-service__name {
    font-size: 2.4vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__name {
    font-size: 3.3vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__list__item {
    font-size: 1.6rem;
  }
  .p-services-section__list__item:nth-child(n+4) .p-service__list__item {
    font-size: 1.4rem;
  }
}
@media (max-width: 768px) {
  .p-service__name {
    font-size: 2.4rem;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__name {
    font-size: 3.4rem;
  }
  .p-services-section__list__item:nth-child(-n+3) {
    width: 100%;
    margin-bottom: 0;
  }
  .p-services-section__list__item:nth-child(3) {
    margin-bottom: 10px;
  }
  .p-services-section__list__item:nth-child(n+4) {
    width: calc(50% - 5px);
  }
  .p-services-section__list__item:nth-child(4),
  .p-services-section__list__item:nth-child(8) {
    display: none;
  }
}
@media (max-width: 525px) {
  .p-services-section {
    padding-top: 60px;
    padding-bottom: 100px;
  }
  .p-services-section__heading {
    margin-bottom: 30px;
  }
  .p-service__name {
    font-size: 4vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__list__item {
    font-size: 4.4vw;
  }
  .p-services-section__list__item:nth-child(-n+3) .p-service__name {
    font-size: 9.4vw;
  }
  .p-services-section__list__item:nth-child(n+4) .p-service__list__item {
    font-size: 3vw;
  }
}
.p-facilities {
  background: url(../../images/top/facilities_bg.jpg) no-repeat center top -30vw;
  background-size: cover;
  position: relative;
  z-index: 1;
  padding: 160px 0;
}
.p-facilities::before, .p-facilities::after {
  content: "";
  width: 100%;
  height: 99px;
  background: url(../../images/deco_15.png) repeat-x;
  background-size: auto 100%;
  position: absolute;
  left: 0;
  z-index: -1;
}
.p-facilities::before {
  top: -63px;
}
.p-facilities::after {
  bottom: -63px;
  transform: scale(-1, 1);
}

.p-facilities__inner {
  width: auto;
  position: relative;
}

.p-facilities__slogan {
  color: var(--color-heading);
  font-size: 4.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  -webkit-text-stroke: 8px var(--color-white);
  paint-order: stroke;
  display: grid;
  place-content: center;
  margin-bottom: 30px;
}

.p-facilities__slogan > span {
  color: #e01999;
  font-size: 2.8rem;
  display: block;
  margin-bottom: 20px;
}

.p-facilities__heading {
  text-align: center;
  margin-bottom: 60px;
  padding: 0 40px;
}
.p-facilities__heading img {
  width: auto;
  max-height: 104px;
}

.p-facilities__main {
  position: relative;
  z-index: -1;
  margin-inline: calc(50% - 50 * var(--vw));
}

.p-facilities__list {
  --slides-per-view: 3.75;
  --slide-gap: 20px;
}

.p-facilities__sub {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 30px;
}

@media (max-width: 768px) {
  .p-facilities__slogan {
    font-size: 2.2rem;
  }
  .p-facilities__slogan > span {
    font-size: 1.8rem;
  }
  .p-facilities__list {
    --slides-per-view: 2.75;
    --slide-gap: 18px;
  }
}
@media (max-width: 525px) {
  .p-facilities {
    background: url(../../images/top/facilities_bg.jpg) no-repeat center top;
    background-size: cover;
    padding: 60px 0;
  }
  .p-facilities__heading {
    margin-bottom: 30px;
  }
  .p-facilities__slogan {
    -webkit-text-stroke: 0 currentcolor;
    paint-order: normal;
    text-shadow: 3px 3px 0 var(--color-white), -3px -3px 0 var(--color-white), -3px 3px 0 var(--color-white), 3px -3px 0 var(--color-white), 0px 3px 0 var(--color-white), 0px -3px 0 var(--color-white), -3px 0px 0 var(--color-white), 3px 0px 0 var(--color-white);
  }
  .p-facilities__list {
    --slides-per-view: 1.1;
    --slide-gap: 10px;
  }
  .p-facilities__sub .p-facilities__more-button {
    min-width: 0;
    width: calc(50% - 10px);
  }
}
@media (max-width: 400px) {
  .p-facilities__slogan {
    font-size: 5.8vw;
    margin-bottom: 30px;
  }
  .p-facilities__slogan > span {
    font-size: 4.8vw;
  }
}
.p-facilities__list.swiper-wrapper {
  transition-timing-function: linear;
}

.p-facilities__item {
  width: calc(100 * var(--vw) / var(--slides-per-view));
  padding-inline: calc(var(--slide-gap) / 2);
}

.p-facilities__image {
  display: block;
  aspect-ratio: 630/685;
  pointer-events: none;
  object-fit: cover;
}

.p-facilities__buttons {
  display: flex;
  flex-wrap: wrap;
  grid-area: buttons;
  gap: 1.5em 3em;
  justify-content: center;
  margin-top: min(60px, 30 * var(--vw));
}

.p-calendar {
  margin-top: var(--section-gap);
}

.p-calendar__inner {
  container-type: inline-size;
}

.p-calendar__heading {
  margin-bottom: 1em;
  font-size: var(--font-size-xxl);
  font-weight: bold;
  color: var(--color-heading);
  text-align: center;
}

.p-calendar__list {
  --column-count: 2;
  --column-gap: 3cqw;
  --row-gap: max(5cqw, 32px);
  display: flex;
  flex-wrap: wrap;
  gap: var(--row-gap) var(--column-gap);
  justify-content: center;
}

@container (width < 760px) {
  .p-calendar__list {
    --column-count: 1;
  }
}
.p-calendar__item {
  position: relative;
  width: calc((100% - var(--column-gap) * (var(--column-count) - 1)) / var(--column-count));
  max-width: 700px;
  min-height: 420px;
  aspect-ratio: 1/0.78;
}

@container (width < 760px) {
  .p-calendar__item:nth-child(n+2) {
    display: none;
  }
}
.p-calendar__item > iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.p-calendar__button {
  margin-top: 3em;
  margin-right: auto;
  margin-left: auto;
}

.p-outline-section {
  background: url(../../images/top/outline_bg.jpg) no-repeat center top;
  background-size: cover;
  padding: 100px 0 60px;
}

.p-outline-section__main {
  background-color: var(--color-white);
  border-radius: 16px;
}

.p-outline-section__heading {
  color: var(--color-heading);
  font-size: 2.4rem;
  font-weight: var(--font-weight-bold);
  text-align: center;
  padding: 20px 20px 0;
}

.p-outline-section__body {
  padding: 20px;
}

.p-outline-section__sub {
  container-type: inline-size;
  display: grid;
  row-gap: min(50px, 10cqw);
  margin-top: var(--section-gap-md);
}

.p-outline-list > ul {
  --column-count: 3;
  --column-gap: 3cqw;
  --row-gap: max(3cqw, 16px);
  display: flex;
  flex-wrap: wrap;
  gap: var(--row-gap) var(--column-gap);
  justify-content: center;
}

@container (width < 900px) {
  .p-outline-list > ul {
    --column-count: 2;
  }
}
@container (width < 750px) {
  .p-outline-list > ul {
    --column-count: 1;
  }
}
.p-outline-list > ul > li {
  width: calc((100% - var(--column-gap) * (var(--column-count) - 1)) / var(--column-count));
  max-width: 500px;
}

.p-outline-list > ul > li:is(.p-outline-list--banner *) a {
  display: block;
}

.p-outline-list > ul > li:is(.p-outline-list--banner *) img {
  width: 100%;
}

.p-outline-list .l-outline-box__item {
  padding: 1.5em 2em;
  font-size: var(--font-size-sm);
  background-color: rgba(var(--color-primary-rgb), 15%);
  border-radius: var(--radius-md);
}

.p-outline-list .l-outline-box__heading {
  margin-bottom: 0.75em;
  font-size: var(--font-size-xl);
  font-weight: bold;
  color: var(--color-heading);
  text-align: center;
  letter-spacing: 0.15em;
}

.p-outline-list .l-sns__item--line {
  display: none;
}

.p-outline-list .l-sns__link {
  position: relative;
  z-index: 0;
  display: flex;
  gap: 1em;
  align-items: center;
  justify-content: center;
  min-height: 6.8rem;
  padding: 0.75em 3em;
  font-size: 2.1rem;
  line-height: 1.3;
  color: var(--color-text-contrast);
  text-align: center;
  background-color: var(--color-primary);
  border-radius: var(--radius-md);
}

.p-outline-list .l-sns__icon {
  flex-grow: 0;
  font-size: 1.45em;
}

.p-outline-list .l-sns__text {
  display: block;
  flex-grow: 1;
  letter-spacing: 0.15em;
}

@media (max-width: 525px) {
  .p-outline-section .c-term-list__item {
    display: block;
    margin-bottom: 1em;
    padding-bottom: 0;
    border: none;
  }
  .p-outline-section .c-term-list__term {
    text-align: left;
    margin-bottom: 0.5em;
    padding-bottom: 0.5em;
    border-bottom: 1px solid #5f4e8e;
  }
}/*# sourceMappingURL=top.css.map */