:root {
  --color-base: #111111;
  --color-body: #fff;
  --color-beige1: #ffeddf;
  --color-beige2: #FDF8E7;
  --color-brown1: #956134;
  --color-red1: #FF645F;
  --color-orange1: #F7792A;
  --color-gray1: #e7ded9;
  --color-gray2: #F0F5F7;
  --color-green1: #005F2F;
  --color-green2: #0C8F54;
  --color-green3: #B7D450;
  --color-green4: #0C8F2B;
  --color-blue1: #1C66A3;
  --color-white_op: rgb(from #fff r g b / 0.7);
}

/* ------------------------------------
// access
------------------------------------ */
#clinicinfo {
  background: var(--color-gray2);
  margin-top: calc(1.5 * clamp(2rem, 8.3vw, 12rem));
  padding-block: 0 10rem;
}
#clinicinfo hgroup {
  transform: translateY(calc(-0.5 * clamp(2rem, 8.3vw, 12rem)));
}
#clinicinfo .board {
  background: #FFF;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 30px;
  padding: clamp(2rem, 2.1vw, 3rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(2rem, 2.1vw, 3rem);
  align-items: end;
}
#clinicinfo .board p {
  margin-bottom: 2rem;
}
#clinicinfo .board .access li {
  background: var(--color-gray2);
  color: var(--color-green2);
  border-radius: 1rem;
  padding: 1.5rem 2rem;
}
#clinicinfo .board .access li.park {
  background: var(--color-green2);
  color: #FFF;
}
#clinicinfo .board .access li + li {
  margin-top: 1rem;
}
@media screen and (max-width: 768px) {
  #clinicinfo .board {
    display: grid;
    grid-template-columns: 1fr;
  }
}

#root {
  position: relative;
}
#root > * {
  position: relative;
  z-index: 2;
}
#root::before, #root:after {
  content: "";
  width: 25vw;
  aspect-ratio: 1;
  display: block;
  background: url(/lib/img/cmn/mori_01.webp) no-repeat 0 0/contain;
  position: absolute;
  top: 0;
  z-index: 0;
  opacity: 0.8;
}
#root::before {
  top: 10%;
  left: 0;
}
#root::after {
  right: 0rem;
  transform: scaleX(-1);
}
#root .root_container {
  width: min(1200px, 100% - 8rem);
  margin: 3rem auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: center;
  grid-template-areas: "title sp" "title card01" "card02 card01" "card02 card03" "card04 card03";
  align-items: center;
}
#root .root_container .card01 {
  grid-area: card01;
}
#root .root_container .card02 {
  grid-area: card02;
}
#root .root_container .card03 {
  grid-area: card03;
}
#root .root_container .card04 {
  grid-area: card04;
}
@media screen and (max-width: 768px) {
  #root .root_container {
    width: 100%;
  }
}
#root .root_container .title {
  grid-area: title;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 6rem;
}
#root .root_container .title h2 {
  white-space: nowrap;
  font-size: clamp(2.4rem, 4.2vw, 6rem);
  writing-mode: vertical-rl;
  color: var(--color-green1);
  position: relative;
}
#root .root_container .title h2::after {
  content: "";
  width: clamp(5rem, 14.6vw, 21rem);
  aspect-ratio: 211/104;
  display: block;
  background: url(/lib/img/access/ill_01.webp) no-repeat 0 0/contain;
  position: absolute;
  top: 0;
  left: calc(100% + 4rem);
  z-index: 0;
}
#root .root_container .title h2::before {
  content: "";
  width: clamp(5rem, 9vw, 13rem);
  aspect-ratio: 130/147;
  display: block;
  background: url(/lib/img/access/ill_02.webp) no-repeat 0 0/contain;
  position: absolute;
  bottom: -4rem;
  right: calc(100% + 2rem);
  z-index: 0;
}
#root .root_container .card {
  border: 1px solid var(--color-green1);
  border-radius: 20px;
  padding: clamp(2rem, 2.8vw, 4rem);
  position: relative;
}
#root .root_container .card .photo {
  margin-bottom: 3rem;
}
#root .root_container .card span {
  position: absolute;
  top: -2rem;
  left: -2rem;
  width: clamp(4rem, 9.7vw, 14rem);
  aspect-ratio: 1;
  border-radius: 50%;
  container-type: size;
  padding-bottom: 0.5em;
  display: grid;
  place-items: center;
  background: var(--color-green1);
  color: #FFF;
}
#root .root_container .card span i {
  font-style: normal;
  font-size: 60cqmin;
  line-height: 1;
  margin-block: calc((1cap - 1lh) / 2);
}
@media screen and (max-width: 768px) {
  #root .root_container .card {
    border-radius: 15px;
    padding: clamp(2rem, 2.8vw, 4rem) clamp(1rem, 2.8vw, 4rem);
  }
  #root .root_container .card p {
    font-size: 1.4rem;
  }
  #root .root_container .card .photo {
    margin-bottom: 1rem;
  }
}
#root .root_container .card01 {
  position: relative;
}
#root .root_container .card01 .card {
  margin-left: clamp(2rem, 2.8vw, 4rem);
}
#root .root_container .card01:before {
  position: absolute;
  content: "";
  width: clamp(4rem, 8.5vw, 12.2rem);
  aspect-ratio: 122/160;
  display: block;
  background: url(/lib/img/access/ill_03.webp) no-repeat top left/contain;
  bottom: 0;
  right: 0;
}
#root .root_container .card01:after {
  content: "";
  width: 80%;
  aspect-ratio: 452/224;
  display: block;
  background: url(/lib/img/access/rootline_01.webp) no-repeat top left/contain;
  left: calc(-1 * clamp(2rem, 2.8vw, 4rem));
  position: relative;
}
@media screen and (max-width: 768px) {
  #root .root_container .card01 .card {
    margin-left: 1rem;
  }
  #root .root_container .card01::after {
    left: -1rem;
  }
}
#root .root_container .card02 {
  padding-bottom: 5rem;
  position: relative;
}
#root .root_container .card02 .card {
  margin-right: clamp(2rem, 2.8vw, 4rem);
}
#root .root_container .card02:before {
  position: absolute;
  content: "";
  width: clamp(8rem, 19.9vw, 28.7rem);
  aspect-ratio: 287/171;
  display: block;
  background: url(/lib/img/access/ill_04.webp) no-repeat top left/contain;
  bottom: 4rem;
  left: 3rem;
}
#root .root_container .card02:after {
  content: "";
  width: 80%;
  aspect-ratio: 424/264;
  display: block;
  background: url(/lib/img/access/rootline_02.webp) no-repeat top left/contain;
  right: calc(-1 * clamp(2rem, 2.8vw, 4rem));
  position: relative;
  margin: 0 0 0 auto;
}
@media screen and (max-width: 768px) {
  #root .root_container .card02 .card {
    margin-right: 1rem;
  }
  #root .root_container .card02::after {
    right: -1rem;
  }
}
#root .root_container .card03 .card {
  margin-left: clamp(2rem, 2.8vw, 4rem);
}
#root .root_container .card03:after {
  content: "";
  width: 70%;
  aspect-ratio: 352/272;
  display: block;
  background: url(/lib/img/access/rootline_03.webp) no-repeat top left/contain;
  left: calc(-1 * clamp(2rem, 2.8vw, 4rem));
  position: relative;
}
@media screen and (max-width: 768px) {
  #root .root_container .card03 .card {
    margin-left: 1rem;
  }
  #root .root_container .card03::after {
    left: -1rem;
  }
}
#root .root_container .card04 .card {
  margin-right: clamp(2rem, 2.8vw, 4rem);
}
#root .root_container .card04:before {
  position: absolute;
  content: "";
  width: clamp(10rem, 28.1vw, 40.4rem);
  aspect-ratio: 404/263;
  display: block;
  background: url(/lib/img/access/ill_05.webp) no-repeat top left/contain;
  bottom: -3rem;
  right: 3rem;
}
@media screen and (max-width: 768px) {
  #root .root_container .card04 .card {
    margin-right: 1rem;
  }
  #root .root_container .card04::after {
    right: -1rem;
  }
}