/*
**  Bg
*/

.navigation__pages,
.for-first-time {
  position: relative;
}

.navigation__pages::before,
.navigation__pages::after,
.for-first-time::before,
.for-first-time::after {
  content: '';
  position: absolute;
  display: block;
  background-size: contain;
}

.navigation__pages::before,
.for-first-time::before {
  z-index: -1;
  width: 6rem;
  height: 3rem;
  background-image: url(../image/common/illust_flower.png);
  background-position: center;
  background-repeat: no-repeat;
}

.navigation__pages::after,
.for-first-time::after {
  z-index: -2;
  background-image:
    linear-gradient(transparent 50%, #fff),
    url(../image/clinic/bg_pattern.jpg);
  background-repeat: repeat;
  mask-repeat: no-repeat;
  mask-position: top center;
  mask-size: 100%;
}


/*
**  .navigation
*/

.navigation__inner {
  display: grid;
  grid-template-columns: 100%;
  grid-auto-rows: max-content;
  grid-row-gap: 4.5rem;
}

/* .navigation__pages */

.navigation__pages::before {
  top: -1rem;
  right: 1rem;
}

.navigation__pages::after {
  top: 0;
  left: 0;
  width: 100%;
  height: 85vw;
  mask-image: url(../image/common/bg_section-mask_wave@sm.svg);
}

.navigation__pages-inner {
  padding-top: 4.5rem;
}

.navigation__pages-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(auto, 14.5rem));
  grid-auto-rows: max-content;
  grid-gap: 2rem;
  justify-content: center;
}

.navigation__pages-item {
  display: grid;
  grid-template-columns: 100%;
  grid-auto-rows: max-content;
  grid-row-gap: 0.9rem;
}

.navigation__pages-icon path {
  fill: var(--main);
}

.navigation__pages-contents img,
.navigation__pages-contents svg {
  transition: var(--transition);
}

.navigation__pages-link {
  font-size: 1.5rem;
  text-align: center;
  transition: var(--transition);
}

@media (hover: hover) and (pointer: fine) {

  .navigation__pages-item a:hover img,
  .navigation__pages-item a:hover svg {
    opacity: 0.5;
  }

  .navigation__pages-item a:hover .navigation__pages-link {
    color: var(--link);
  }

}


/*
**  .for-first-time
*/

.for-first-time::before {
  top: -4.5rem;
  right: 0.5rem;
}

.for-first-time::after {
  top: -4.5rem;
  right: 0;
  width: 33.3%;
  height: 53.3vw;
  mask-image: url(../image/common/bg_section-mask_r@sm.svg);
}

.for-first-time__inner {
  border-top: 0.1rem solid var(--main);
  border-bottom: 0.1rem solid var(--main);
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.for-first-time__contents {
  display: grid;
  grid-template-columns: 100%;
  grid-auto-rows: max-content;
  grid-row-gap: 2rem;
}

.for-first-time__summary {
  display: grid;
  grid-template-columns: 100%;
  grid-auto-rows: max-content;
  grid-row-gap: 2rem;
}

.for-first-time__headline {
  text-align: center;
  padding-left: 19.6%;
  padding-right: 19.6%;
}

.for-first-time__headline img {
  max-width: 35rem;
}

.for-first-time__summary-headline {
  font-size: 2rem;
  font-weight: 500;
  color: var(--main);
  line-height: 1.5;
  margin-bottom: 1rem;
}

.for-first-time__summary-text > * + * {
  margin-top: 1rem;
}

.for-first-time__summary-text-list {
  grid-row-gap: 0.5rem;
}

.for-first-time__summary-text-item {
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--main);
  line-height: 1.25;
}

.for-first-time__reservation-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(25rem, 1fr));
  grid-auto-rows: max-content;
  grid-gap: 1.5rem 3rem;
}

.for-first-time__reservation-item a {
  width: 100%;
}

.for-first-time__reservation-item--web a {
  border: 0.1rem solid var(--main);
  background-color: #fff;
  transition: var(--transition);
}

@media (hover: hover) and (pointer: fine) {

  .for-first-time__reservation-item--web a:hover {
    background-color: var(--main);
  }

  .for-first-time__reservation-item--web a:hover .for-first-time__reservation-item-button path.st0,
  .for-first-time__reservation-item--web a:hover .for-first-time__reservation-item-button path.st2 {
    fill: #fff;
  }

}

.for-first-time__guidance-headline {
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--main);
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.for-first-time__guidance-text + .for-first-time__guidance-headline {
  margin-top: 2rem;
}

.for-first-time__guidance-text a {
  color: var(--link);
  text-decoration: underline;
}


/*
**  .button__float
*/

.button__float {
  position: fixed;
  bottom: 6.5rem;
  right: 1rem;
  z-index: var(--z-index--mid);
  width: 12.5rem;
  height: 12.5rem;
}

@media (hover: hover) and (pointer: fine) {
  .button__float a:hover {
    transform: translateY(0.5rem);
  }
}