@charset "UTF-8";
.main_image {
  position: relative;
  height: 646px;
  padding-top: 0;
  box-sizing: border-box;
  background: url(/images/medical/medical_key.webp) center top/cover no-repeat;
  overflow: hidden;
}
.main_image .inner {
  width: 1025px;
  max-width: 100%;
  padding: 0 20px;
  margin: 0 auto;
  box-sizing: border-box;
}
.main_image .text {
  position: relative;
  z-index: 5;
  padding-top: 300px;
  padding-left: 0;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 36px;
  letter-spacing: 0.2em;
  color: #fff;
  text-shadow: 0 0 5px rgba(155, 152, 152, 0.71);
}
.main_image .text:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: -105px;
  top: 50%;
  transform: translateY(-50%);
  width: 221px;
  height: 221px;
  background: url(/images/common/key_logo.webp) center/contain no-repeat;
}
@media screen and (max-width: 767px) {
  .main_image {
    position: relative;
    height: 80vw;
    padding-top: 45.3vw;
    box-sizing: border-box;
    background: url(/images/medical/medical_key.webp) center top/cover no-repeat;
    overflow: hidden;
  }
  .main_image .inner {
    padding: 0 2.7vw;
  }
  .main_image .text {
    padding-top: 0;
    padding-left: 0;
    font-size: 5.8vw;
    text-align: center;
  }
  .main_image .text:before {
    left: 0;
    top: 4.3vw;
    width: 21.3vw;
    height: 21.3vw;
    background: url(/images/common/key_logo.webp) center/contain no-repeat;
  }
}

.menu {
  box-sizing: border-box;
  width: 1280px;
  max-width: 100%;
  padding: 30px 20px 0;
  margin: 0 auto;
  margin-bottom: 100px;
}
.menu .gridbox {
  width: 1005px;
  max-width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  gap: 15px 0px;
  grid-template-columns: repeat(4, 1fr);
}
.menu .gridbox .item {
  width: 236px;
  height: 123px;
  box-sizing: border-box;
  border: 1.1px solid #808080;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 19px;
  text-align: center;
  position: relative;
  font-feature-settings: "palt";
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  padding-top: 20px;
  line-height: 1.1;
}
.menu .gridbox .item::after {
  content: "";
  position: absolute;
  right: 45%;
  top: 80%;
  transform: translateY(-50%);
  width: 21px;
  height: 10px;
  background: url(/images/medical/menu_icon.webp) center/contain no-repeat;
}
.menu .gridbox .caries::before {
  content: "";
  position: absolute;
  right: 43%;
  top: 25%;
  transform: translateY(-50%);
  width: 30px;
  height: 38px;
  background: url(/images/medical/caries.webp) center/contain no-repeat;
}
.menu .gridbox .perio::before {
  content: "";
  position: absolute;
  right: 43%;
  top: 25%;
  transform: translateY(-50%);
  width: 26px;
  height: 33px;
  background: url(/images/medical/perio.webp) center/contain no-repeat;
}
.menu .gridbox .blueradical::before {
  content: "";
  position: absolute;
  right: 43%;
  top: 25%;
  transform: translateY(-50%);
  width: 48px;
  height: 35px;
  background: url(/images/medical/blueradical.webp) center/contain no-repeat;
}
.menu .gridbox .child::before {
  content: "";
  position: absolute;
  right: 38%;
  top: 25%;
  transform: translateY(-50%);
  width: 56px;
  height: 32px;
  background: url(/images/medical/child.webp) center/contain no-repeat;
}
.menu .gridbox .inlay-crown::before {
  content: "";
  position: absolute;
  right: 45%;
  top: 25%;
  transform: translateY(-50%);
  width: 23px;
  height: 32px;
  background: url(/images/medical/inlay-crown.webp) center/contain no-repeat;
}
.menu .gridbox .tsutsu-wellness::before {
  content: "";
  position: absolute;
  right: 42%;
  top: 25%;
  transform: translateY(-50%);
  width: 35px;
  height: 35px;
  background: url(/images/medical/tsutsu-wellness.webp) center/contain no-repeat;
}
.menu .gridbox .tsutsu-wellness-jr::before {
  content: "";
  position: absolute;
  right: 41%;
  top: 25%;
  transform: translateY(-50%);
  width: 37px;
  height: 33px;
  background: url(/images/medical/tsutsu-wellness-jr.webp) center/contain no-repeat;
}
.menu .gridbox .tsutsu-kids::before {
  content: "";
  position: absolute;
  right: 40%;
  top: 25%;
  transform: translateY(-50%);
  width: 49px;
  height: 30px;
  background: url(/images/medical/tsutsu-kids.webp) center/contain no-repeat;
}
.menu .gridbox .child-ortho::before {
  content: "";
  position: absolute;
  right: 38%;
  top: 25%;
  transform: translateY(-50%);
  width: 57px;
  height: 28px;
  background: url(/images/medical/child_ortho.webp) center/contain no-repeat;
}
.menu .gridbox .denture::before {
  content: "";
  position: absolute;
  right: 41%;
  top: 25%;
  transform: translateY(-50%);
  width: 38px;
  height: 34px;
  background: url(/images/medical/denture.webp) center/contain no-repeat;
}
.menu .gridbox .bridge::before {
  content: "";
  position: absolute;
  right: 38%;
  top: 25%;
  transform: translateY(-50%);
  width: 57px;
  height: 35px;
  background: url(/images/medical/bridge.webp) center/contain no-repeat;
}
.menu .gridbox .implant::before {
  content: "";
  position: absolute;
  right: 43%;
  top: 25%;
  transform: translateY(-50%);
  width: 31px;
  height: 46px;
  background: url(/images/medical/implant.webp) center/contain no-repeat;
}
.menu .gridbox .ortho::before {
  content: "";
  position: absolute;
  right: 37%;
  top: 25%;
  transform: translateY(-50%);
  width: 66px;
  height: 23px;
  background: url(/images/medical/ortho.webp) center/contain no-repeat;
}
.menu .gridbox .whitening::before {
  content: "";
  position: absolute;
  right: 44%;
  top: 25%;
  transform: translateY(-50%);
  width: 30px;
  height: 35px;
  background: url(/images/medical/whitening.webp) center/contain no-repeat;
}
.menu .gridbox .treatment::before {
  content: "";
  position: absolute;
  right: 38%;
  top: 25%;
  transform: translateY(-50%);
  width: 58px;
  height: 45px;
  background: url(/images/medical/treatment.webp) center/contain no-repeat;
}
@media screen and (max-width: 1099px) and (min-width: 768px) {
  .menu .gridbox {
    width: 750px;
    gap: 15px;
    grid-template-columns: repeat(3, 1fr);
  }
  .menu .gridbox .item {
    width: 216px;
  }
}

.sec01 {
  margin-bottom: 100px;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
}
.sec01 .item {
  display: flex;
  box-sizing: border-box;
  flex-direction: row-reverse;
  margin-bottom: 115px;
}
.sec01 .item_pic {
  width: 586px;
  min-width: 54%;
  max-width: 34%;
  margin-left: 50px;
}
.sec01 .item_pic img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sec01 .title_text {
  margin-bottom: 35px;
}
.sec01 .item_title {
  font-size: 20px;
}
.sec01 .flexbox {
  display: flex;
  justify-content: left;
  margin-top: 45px;
}

.sec02 {
  margin-bottom: 100px;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
}
.sec02 .item {
  display: flex;
  box-sizing: border-box;
  flex-direction: row-reverse;
  margin-bottom: 115px;
}
.sec02 .item_pic {
  width: 586px;
  min-width: 54%;
  max-width: 34%;
  margin-left: 50px;
}
.sec02 .item_pic img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sec02 .title_text {
  margin-bottom: 35px;
}
.sec02 .item_title {
  font-size: 20px;
}
.sec02 .item_title .small {
  font-size: 17px;
}
.sec02 .flexbox {
  display: flex;
  justify-content: left;
  margin-top: 45px;
}

.sec03 {
  margin-bottom: 100px;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
}
.sec03 .item {
  display: flex;
  box-sizing: border-box;
  flex-direction: row-reverse;
  margin-bottom: 115px;
}
.sec03 .item_pic {
  width: 586px;
  min-width: 54%;
  max-width: 34%;
  margin-left: 50px;
}
.sec03 .item_pic img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sec03 .title_text {
  margin-bottom: 35px;
}
.sec03 .item_title {
  font-size: 20px;
}
.sec03 .flexbox {
  display: flex;
  justify-content: left;
  margin-top: 45px;
}

.sec04 {
  margin-bottom: 100px;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
}
.sec04 .item {
  display: flex;
  box-sizing: border-box;
  flex-direction: row-reverse;
  margin-bottom: 115px;
}
.sec04 .item_pic {
  width: 586px;
  min-width: 54%;
  max-width: 34%;
  margin-left: 50px;
}
.sec04 .item_pic img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sec04 .title_text {
  margin-bottom: 35px;
}
.sec04 .item_title {
  font-size: 20px;
}
.sec04 .item_title .small {
  font-size: 17px;
}
.sec04 .flexbox {
  display: flex;
  justify-content: left;
  margin-top: 45px;
}

@media screen and (max-width: 767px) {
  .menu {
    padding: 5.5vw 5.5vw 0;
    margin-bottom: 13.8vw;
  }
  .menu .gridbox {
    width: 100%;
    gap: 3vw;
    grid-template-columns: repeat(2, 1fr);
  }
  .menu .gridbox .item {
    width: 100%;
    height: 36vw;
    font-size: 4.2vw;
    line-height: 1.6;
    padding-top: 8vw;
  }
  .menu .gridbox .item::after {
    width: 5.7vw;
    height: 2.6vw;
    right: 43%;
    top: 87%;
  }
  .menu .gridbox .caries::before {
    content: "";
    position: absolute;
    right: 41%;
    top: 25%;
    transform: translateY(-50%);
    width: 8vw;
    height: 10vw;
    background: url(/images/medical/caries.webp) center/contain no-repeat;
  }
  .menu .gridbox .perio::before {
    content: "";
    position: absolute;
    right: 43%;
    top: 25%;
    transform: translateY(-50%);
    width: 7vw;
    height: 9vw;
    background: url(/images/medical/perio.webp) center/contain no-repeat;
  }
  .menu .gridbox .child::before {
    content: "";
    position: absolute;
    right: 33%;
    top: 25%;
    transform: translateY(-50%);
    width: 15vw;
    height: 9vw;
    background: url(/images/medical/child.webp) center/contain no-repeat;
  }
  .menu .gridbox .inlay-crown::before {
    content: "";
    position: absolute;
    right: 43%;
    top: 25%;
    transform: translateY(-50%);
    width: 6.2vw;
    height: 8.5vw;
    background: url(/images/medical/inlay-crown.webp) center/contain no-repeat;
  }
  .menu .gridbox .tsutsu-wellness::before {
    content: "";
    position: absolute;
    right: 39%;
    top: 25%;
    transform: translateY(-50%);
    width: 9.5vw;
    height: 9.5vw;
    background: url(/images/medical/tsutsu-wellness.webp) center/contain no-repeat;
  }
  .menu .gridbox .tsutsu-wellness-jr::before {
    content: "";
    position: absolute;
    right: 38%;
    top: 25%;
    transform: translateY(-50%);
    width: 10vw;
    height: 9.5vw;
    background: url(/images/medical/tsutsu-wellness-jr.webp) center/contain no-repeat;
  }
  .menu .gridbox .tsutsu-kids::before {
    content: "";
    position: absolute;
    right: 35%;
    top: 25%;
    transform: translateY(-50%);
    width: 13.2vw;
    height: 8vw;
    background: url(/images/medical/tsutsu-kids.webp) center/contain no-repeat;
  }
  .menu .gridbox .child-ortho::before {
    content: "";
    position: absolute;
    right: 33%;
    top: 25%;
    transform: translateY(-50%);
    width: 15.5vw;
    height: 7.2vw;
    background: url(/images/medical/child_ortho.webp) center/contain no-repeat;
  }
  .menu .gridbox .denture::before {
    content: "";
    position: absolute;
    right: 38%;
    top: 25%;
    transform: translateY(-50%);
    width: 10.2vw;
    height: 9.2vw;
    background: url(/images/medical/denture.webp) center/contain no-repeat;
  }
  .menu .gridbox .bridge::before {
    content: "";
    position: absolute;
    right: 33%;
    top: 25%;
    transform: translateY(-50%);
    width: 15.2vw;
    height: 9.5vw;
    background: url(/images/medical/bridge.webp) center/contain no-repeat;
  }
  .menu .gridbox .implant::before {
    content: "";
    position: absolute;
    right: 41%;
    top: 25%;
    transform: translateY(-50%);
    width: 8.3vw;
    height: 12.5vw;
    background: url(/images/medical/implant.webp) center/contain no-repeat;
  }
  .menu .gridbox .ortho::before {
    content: "";
    position: absolute;
    right: 30%;
    top: 25%;
    transform: translateY(-50%);
    width: 17.6vw;
    height: 6.2vw;
    background: url(/images/medical/ortho.webp) center/contain no-repeat;
  }
  .menu .gridbox .whitening::before {
    content: "";
    position: absolute;
    right: 42%;
    top: 25%;
    transform: translateY(-50%);
    width: 8vw;
    height: 9.5vw;
    background: url(/images/medical/whitening.webp) center/contain no-repeat;
  }
  .menu .gridbox .treatment::before {
    content: "";
    position: absolute;
    right: 33%;
    top: 25%;
    transform: translateY(-50%);
    width: 15.5vw;
    height: 12vw;
    background: url(/images/medical/treatment.webp) center/contain no-repeat;
  }
  .sec01, .sec02, .sec03, .sec04 {
    margin-bottom: 13.8vw;
  }
  .sec01 .item, .sec02 .item, .sec03 .item, .sec04 .item {
    display: block;
    margin-bottom: 15vw;
  }
  .sec01 .item_title, .sec02 .item_title, .sec03 .item_title, .sec04 .item_title {
    font-size: 5vw;
    text-align: center;
  }
  .sec01 .item_title .small, .sec02 .item_title .small, .sec03 .item_title .small, .sec04 .item_title .small {
    font-size: 4.2vw;
  }
  .sec01 .title_text, .sec02 .title_text, .sec03 .title_text, .sec04 .title_text {
    margin-bottom: 3vw;
  }
  .sec01 .item_pic, .sec02 .item_pic, .sec03 .item_pic, .sec04 .item_pic {
    margin-left: initial;
    min-width: 100%;
    margin-bottom: 3vw;
  }
  .sec01 .flexbox, .sec02 .flexbox, .sec03 .flexbox, .sec04 .flexbox {
    justify-content: center;
    margin-top: 5vw;
  }
  .sec01 .flexbox .palt, .sec02 .flexbox .palt, .sec03 .flexbox .palt, .sec04 .flexbox .palt {
    font-feature-settings: "palt";
  }
}/*# sourceMappingURL=medical_1.css.map */