@charset "UTF-8";
.link_btn {
  border-radius: 10px;
  padding: 24px 5.8em 24px 2.8em;
  position: relative;
}
.link_btn::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: initial;
  right: 23px;
  background: url(/images/clinic02/btn_arrow.webp) center center/contain no-repeat;
  width: 47px;
  height: 47px;
}
@media screen and (max-width: 767px) {
  .link_btn {
    border-radius: 2.66vw;
    position: relative;
  }
  .link_btn::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: initial;
    right: 6.13vw;
    background: url(/images/clinic02/btn_arrow.webp) center center/contain no-repeat;
    width: 9.06vw;
    height: 9.06vw;
  }
}

.key {
  position: relative;
  height: 550px;
  background: url(/images/clinic02/clinic_key.webp) center top/cover no-repeat;
}
.key:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 50%;
  height: 3.9vw;
  background: url(../images/common/key_bg.webp) center/cover no-repeat;
}
.key:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -1px;
  width: 50%;
  height: 3.9vw;
  transform: rotateY(180deg);
  background: url(../images/common/key_bg.webp) center/cover no-repeat;
}
.key .inner {
  width: 1280px;
  margin: 0 auto;
}
.key .key_text {
  position: relative;
  padding-top: 300px;
  padding-left: 20px;
  font-size: 30px;
  color: rgba(255, 255, 255, 0.9);
  letter-spacing: 0.07em;
}
.key .key_text:before {
  content: "CLINIC";
  position: absolute;
  top: 200px;
  left: 0;
  font-size: 70px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .key {
    position: relative;
    height: 97.2vw;
    background: url(/images/clinic02/clinic_key.webp) center top/cover no-repeat;
  }
  .key:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 50%;
    height: 3.9vw;
    background: url(../images/common/key_bg.webp) center/cover no-repeat;
  }
  .key:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -1px;
    width: 50%;
    height: 3.9vw;
    transform: rotateY(180deg);
    background: url(../images/common/key_bg.webp) center/cover no-repeat;
  }
  .key .inner {
    width: 100%;
    margin: 0 auto;
  }
  .key .key_text {
    position: relative;
    padding-top: 55.5vw;
    padding-left: 5.5vw;
    font-size: 8.3vw;
    color: rgba(255, 255, 255, 0.9);
    letter-spacing: 0.07em;
  }
  .key .key_text:before {
    content: "CLINIC";
    position: absolute;
    top: 33.3vw;
    left: 5.5vw;
    width: 90%;
    font-size: 13.8vw;
    letter-spacing: 0.05em;
  }
}

.sec01 {
  margin-bottom: 100px;
}
.sec01 .sec_title {
  margin-top: 155px;
  margin-bottom: 90px;
  letter-spacing: 0.1em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 35px;
  font-weight: 500;
  text-align: center;
}
.sec01 .sec_text {
  width: 1022px;
  max-width: 100%;
  margin: 0 auto 100px;
  text-align: justify;
}
.sec01 .flexbox {
  width: 635px;
  max-width: 100%;
  margin: 0 auto 70px;
}
.sec01 .flexbox .link_btn:nth-of-type(1) {
  margin-right: 65px;
}
@media screen and (max-width: 767px) {
  .sec01 {
    margin-bottom: 13.8vw;
    padding: 0 5.5vw;
  }
  .sec01 .sec_title {
    margin-top: 13.8vw;
    margin-bottom: 90px;
    letter-spacing: 0.1em;
    font-size: 6.9vw;
    font-weight: 600;
  }
  .sec01 .sec_text {
    margin: 0 auto 13.8vw;
    font-size: 4.4vw;
  }
  .sec01 .flexbox {
    max-width: 100%;
    margin: 0 auto 70px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .sec01 .flexbox .link_btn {
    width: 78.13vw;
    text-align: center;
  }
  .sec01 .flexbox .link_btn:nth-of-type(1) {
    margin-right: initial;
    margin-bottom: 4.2vw;
  }
}

.sec02 {
  background-color: #F8F8F8;
  padding-bottom: clamp(160px, 12.5vw, 180px);
  position: relative;
}
.sec02::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  background: url(/images/clinic02/sec02_bg_image01.webp) center center/contain no-repeat;
  width: clamp(537px, 70vw, 1008px);
  height: clamp(307px, 40.069vw, 577px);
}
.sec02::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  background: url(/images/clinic02/sec02_bg_image02.webp) center center/contain no-repeat;
  width: clamp(736px, 57.569vw, 829px);
  height: clamp(454px, 35.486vw, 511px);
}
.sec02 .sec_title {
  margin-left: clamp(98px, 7.708vw, 111px);
  margin-right: auto;
  padding-top: clamp(195px, 15.277vw, 220px);
  margin-bottom: 90px;
  letter-spacing: 0.15em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 36px;
  font-weight: 600;
  position: relative;
}
.sec02 .sec_title::before {
  content: "Welcome";
  position: absolute;
  top: clamp(75px, 5.902vw, 85px);
  left: clamp(-23px, -1.597vw, -20px);
  letter-spacing: 0.2em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: clamp(72px, 5.625vw, 81px);
  font-weight: 600;
  color: rgba(235, 144, 156, 0.3);
}
.sec02 .slick_box {
  box-sizing: border-box;
  width: clamp(720px, 56.25vw, 810px);
  height: clamp(480px, 37.5vw, 540px);
  margin: 0 auto clamp(133px, 17.361vw, 250px);
}
.sec02 .slick_box .clinic_slick01 .slick-list .slick-track li {
  margin: 0 50px 30px;
  position: relative;
}
.sec02 .slick_box .clinic_slick01 .slick-list .slick-track li .circle {
  position: absolute;
  z-index: 10;
  bottom: -28px;
  right: -41px;
  width: 285px;
  height: 285px;
}
.sec02 .slick_box .clinic_slick01 .slick-list .slick-track li .circle img {
  width: clamp(378px, 49.305vw, 710px);
  height: clamp(252px, 32.847vw, 473px);
  -o-object-fit: contain;
     object-fit: contain;
}
.sec02 .slick_box .prev {
  z-index: 10;
  position: absolute;
  top: 50%;
  left: -80px;
  transform: translateY(-50%);
  width: 23px;
  height: 77px;
}
.sec02 .slick_box .prev:hover {
  cursor: pointer;
}
.sec02 .slick_box .next {
  z-index: 10;
  position: absolute;
  top: 50%;
  right: -80px;
  transform: translateY(-50%);
  width: 23px;
  height: 77px;
}
.sec02 .slick_box .slick-dots {
  text-align: right;
  padding-right: 60px;
  box-sizing: border-box;
}
.sec02 .slick_box .slick-dots li {
  margin: 0 12px;
}
.sec02 .slick_box .slick-dots li button:before {
  content: "";
  width: 40px;
  height: 5px;
  border-radius: 50%;
  background: #D9D9D9;
  opacity: 1;
  width: 14px;
  height: 14px;
}
.sec02 .slick_box .slick-dots li.slick-active button:before {
  background: #EB909C;
}
.sec02 .cont {
  box-sizing: border-box;
  margin-bottom: clamp(97px, 7.638vw, 110px);
}
.sec02 .cont .subtitle {
  padding-left: 60px;
  margin-bottom: 11px;
  letter-spacing: 0.15em;
  line-height: 1.5;
  font-size: 20px;
  font-weight: 500;
  color: #EB909C;
}
.sec02 .cont .title {
  padding-left: 60px;
  margin-bottom: 33px;
  letter-spacing: 0.1em;
  line-height: 1.06;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 32px;
  font-weight: 500;
  text-align: left;
}
.sec02 .cont .text {
  padding-left: 60px;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: justify;
}
.sec02 .cont01 {
  margin-bottom: clamp(280px, 21.875vw, 315px);
}
.sec02 .cont01 .textbox {
  margin-right: clamp(66px, 5.208vw, 75px);
  position: relative;
}
.sec02 .cont01 .textbox::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: clamp(-185px, -14.513vw, -209px);
  left: 0;
  background: url(/images/clinic02/sec02_cont01_bg_image.webp) center center/contain no-repeat;
  width: clamp(716px, 55.972vw, 806px);
  height: clamp(477px, 37.291vw, 537px);
}
.sec02 .cont01 .textbox .subtitle,
.sec02 .cont01 .textbox .title,
.sec02 .cont01 .textbox .text {
  position: relative;
  z-index: 3;
}
.sec02 .cont01 .textbox .image_list {
  position: absolute;
  z-index: 5;
  top: clamp(358px, 27.986vw, 403px);
  left: clamp(58px, 4.583vw, 66px);
  width: clamp(1159px, 90.555vw, 1304px);
  height: clamp(256px, 20vw, 288px);
  max-height: 288px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.sec02 .cont01 .textbox .image_list .image01 {
  margin-right: clamp(69px, 5.416vw, 78px);
  width: clamp(378px, 29.583vw, 426px);
  height: clamp(238px, 18.611vw, 268px);
}
.sec02 .cont01 .textbox .image_list .image02 {
  margin-right: clamp(237px, 18.541vw, 267px);
  width: clamp(274px, 21.458vw, 309px);
  height: clamp(238px, 18.611vw, 268px);
}
.sec02 .cont01 .textbox .image_list .image03 {
  margin-top: clamp(85px, 6.666vw, 96px);
  width: clamp(199px, 15.555vw, 224px);
  height: clamp(170px, 13.333vw, 192px);
}
.sec02 .cont01 .imagebox .cont_image {
  position: relative;
  z-index: 3;
}
.sec02 .cont02 .textbox {
  margin-right: clamp(66px, 5.208vw, 75px);
}
.sec02 .cont02 .textbox .image_list {
  position: absolute;
  z-index: 5;
  top: clamp(295px, 23.055vw, 332px);
  left: clamp(58px, 4.583vw, 66px);
  width: clamp(528px, 41.25vw, 594px);
  height: clamp(153px, 12.013vw, 173px);
  max-height: 173px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.sec02 .cont02 .textbox .image_list .cont02_kazari01 {
  margin-right: clamp(162px, 12.708vw, 183px);
  width: clamp(161px, 12.638vw, 182px);
  height: clamp(127px, 9.93vw, 143px);
}
.sec02 .cont02 .textbox .image_list .cont02_kazari02 {
  width: clamp(203px, 15.902vw, 229px);
  height: clamp(127px, 9.93vw, 143px);
}
.sec02 .box .sub_title {
  margin-bottom: 11px;
  letter-spacing: 0.15em;
  line-height: 1.5;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  color: #EB909C;
}
.sec02 .box .title {
  margin-bottom: clamp(88px, 6.944vw, 100px);
  letter-spacing: 0.1em;
  line-height: 1.06;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 32px;
  font-weight: 600;
  text-align: center;
}
.sec02 .box .shinsatsu_box {
  width: 1270px;
  max-width: 100%;
  margin: 0 auto clamp(142px, 11.111vw, 160px);
  -moz-column-gap: clamp(60px, 4.722vw, 68px);
       column-gap: clamp(60px, 4.722vw, 68px);
  grid-template-columns: repeat(2, 1fr);
}
.sec02 .box .shinsatsu_box .item {
  box-sizing: border-box;
}
.sec02 .box .shinsatsu_box .item .item_image {
  margin-bottom: 20px;
}
.sec02 .box .shinsatsu_box .item .item_title {
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  line-height: 1;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 30px;
  font-weight: 500;
  text-align: center;
}
.sec02 .box .shinsatsu_box .item .text {
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: justify;
  color: #695446;
}
.sec02 .box .others_box {
  width: 1125px;
  max-width: 100%;
  margin: 0 auto clamp(142px, 11.111vw, 160px);
  -moz-column-gap: clamp(60px, 4.722vw, 68px);
       column-gap: clamp(60px, 4.722vw, 68px);
  row-gap: clamp(88px, 6.944vw, 100px);
  grid-template-columns: repeat(3, 1fr);
}
.sec02 .box .others_box .item {
  box-sizing: border-box;
}
.sec02 .box .others_box .item .item_image {
  margin-bottom: 20px;
}
.sec02 .box .others_box .item .item_title {
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  line-height: 1.2;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 25px;
  font-weight: 500;
  text-align: center;
  text-wrap: nowrap;
}
.sec02 .box .others_box .item .item_text {
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: justify;
  color: #695446;
}
@media screen and (max-width: 767px) {
  .sec02 {
    overflow-x: hidden;
    padding-bottom: 13.8vw;
    position: relative;
  }
  .sec02::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background: url(/images/clinic02/sec02_bg_image01_sp.webp) center center/contain no-repeat;
    width: 100vw;
    height: 75.2vw;
  }
  .sec02::after {
    content: "";
    position: absolute;
    z-index: 0;
    bottom: 0;
    right: 0;
    background: url(/images/clinic02/sec02_bg_image02_sp.webp) center center/contain no-repeat;
    width: 100vw;
    height: 61.641vw;
  }
  .sec02 .sec_title {
    width: 100%;
    margin-left: initial;
    margin-right: initial;
    padding-top: 23vw;
    margin-bottom: 8vw;
    font-size: 6.9vw;
    text-align: center;
    position: relative;
  }
  .sec02 .sec_title::before {
    top: 8.8vw;
    left: -12vw;
    font-size: 10.93vw;
    width: 100%;
  }
  .sec02 .slick_box {
    box-sizing: border-box;
    width: 95.33vw;
    height: 56.8vw;
    margin: 0 auto 20.7vw;
  }
  .sec02 .slick_box .clinic_slick01 .slick-list .slick-track li {
    margin: 0 5vw;
    position: relative;
  }
  .sec02 .slick_box .clinic_slick01 .slick-list .slick-track li .circle {
    position: absolute;
    z-index: 10;
    bottom: -25.33vw;
    right: -4.26vw;
    width: 46.66vw;
    height: 46.66vw;
  }
  .sec02 .slick_box .clinic_slick01 .slick-list .slick-track li .circle img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
  .sec02 .slick_box .prev {
    z-index: 10;
    position: absolute;
    top: 43%;
    left: -2vw;
    transform: translateY(-50%);
    width: 6.6vw;
    height: 5.33vw;
  }
  .sec02 .slick_box .prev:hover {
    cursor: pointer;
  }
  .sec02 .slick_box .next {
    z-index: 10;
    position: absolute;
    top: 43%;
    right: -2vw;
    transform: translateY(-50%);
    width: 6.6vw;
    height: 5.33vw;
  }
  .sec02 .slick_box .slick-dots {
    text-align: right;
    bottom: -8.47vw;
    z-index: 0;
    padding-right: 2vw;
  }
  .sec02 .slick_box .slick-dots li button:before {
    content: "";
    width: 40px;
    height: 5px;
    border-radius: 50%;
    opacity: 1;
    width: 3.73vw;
    height: 3.73vw;
  }
  .sec02 .cont {
    box-sizing: border-box;
    background-color: #F8F8F8;
    margin-bottom: 13.8vw;
    padding: 0 5.5vw;
  }
  .sec02 .cont .subtitle {
    box-sizing: border-box;
    padding-left: 0;
    margin-bottom: 2.93vw;
    font-size: 4.8vw;
  }
  .sec02 .cont .title {
    box-sizing: border-box;
    padding-left: 0;
    margin-bottom: 4.2vw;
    font-size: 6.9vw;
    font-weight: 500;
  }
  .sec02 .cont .text {
    box-sizing: border-box;
    padding-left: initial;
    font-size: 4.4vw;
    text-align: justify;
  }
  .sec02 .cont .imagebox {
    width: 100%;
    max-width: 100%;
    min-width: 100%;
  }
  .sec02 .cont01 {
    margin-bottom: initial;
    padding-bottom: 58vw;
  }
  .sec02 .cont01 .textbox {
    margin-right: initial;
    position: relative;
  }
  .sec02 .cont01 .textbox::before {
    display: none;
    content: "";
    position: absolute;
    z-index: 0;
    top: -21vw;
    left: -5.5vw;
    background: url(/images/clinic02/sec02_cont01_bg_image_sp.webp) center center/contain no-repeat;
    width: 100vw;
    height: 66.625vw;
  }
  .sec02 .cont01 .textbox .subtitle,
  .sec02 .cont01 .textbox .title,
  .sec02 .cont01 .textbox .text {
    position: relative;
    z-index: 3;
  }
  .sec02 .cont01 .textbox .image_list {
    display: none;
    position: absolute;
    z-index: 5;
    top: 143vw;
    left: 0;
    width: 100vw;
    height: 50vw;
    max-height: initial;
    display: block;
  }
  .sec02 .cont01 .textbox .image_list .image01 {
    margin-right: initial;
    position: absolute;
    left: -5vw;
    top: 14.66vw;
    width: 44vw;
    height: 27.73vw;
  }
  .sec02 .cont01 .textbox .image_list .image02 {
    margin-right: initial;
    position: absolute;
    left: 23.266vw;
    top: 0;
    width: 37.6vw;
    height: 32.26vw;
  }
  .sec02 .cont01 .textbox .image_list .image03 {
    margin-top: initial;
    position: absolute;
    left: 56.9vw;
    top: 18.9vw;
    width: 36.08vw;
    height: 30.93vw;
  }
  .sec02 .cont01 .textbox .imagebox {
    margin-bottom: 4.2vw;
    position: relative;
  }
  .sec02 .cont01 .imagebox {
    width: 100%;
    max-width: 100%;
    min-width: 100%;
  }
  .sec02 .cont01 .imagebox .cont_image {
    position: relative;
    z-index: 3;
  }
  .sec02 .cont02 {
    box-sizing: border-box;
    padding-bottom: 31vw;
  }
  .sec02 .cont02 .textbox {
    margin-right: initial;
  }
  .sec02 .cont02 .textbox .image_list {
    position: absolute;
    top: 143vw;
    left: 0;
    width: 100vw;
    height: 50vw;
    max-height: initial;
    display: block;
  }
  .sec02 .cont02 .textbox .image_list .cont02_kazari01 {
    margin-right: initial;
    position: absolute;
    top: 20vw;
    left: 5.02vw;
    width: 29.86vw;
    height: 25.76vw;
  }
  .sec02 .cont02 .textbox .image_list .cont02_kazari02 {
    position: absolute;
    top: 20vw;
    left: 57.27vw;
    width: 40.26vw;
    height: 25.14vw;
  }
  .sec02 .cont02 .textbox .imagebox {
    margin-bottom: 4.2vw;
  }
  .sec02 .cont02 .imagebox {
    width: 100%;
    max-width: 100%;
    min-width: 100%;
  }
  .sec02 .box {
    box-sizing: border-box;
    padding: 0 5.5vw 30.4vw;
  }
  .sec02 .box .sub_title {
    margin-bottom: 2.93vw;
    font-size: 4.8vw;
  }
  .sec02 .box .title {
    margin-bottom: 8vw;
    font-size: 6.9vw;
  }
  .sec02 .box .shinsatsu_box {
    width: 1270px;
    max-width: 100%;
    margin: 0 auto 13.8vw;
    -moz-column-gap: initial;
         column-gap: initial;
    row-gap: 13.8vw;
    grid-template-columns: repeat(1, 1fr);
  }
  .sec02 .box .shinsatsu_box .item {
    box-sizing: border-box;
  }
  .sec02 .box .shinsatsu_box .item .item_image {
    margin-bottom: 4.2vw;
  }
  .sec02 .box .shinsatsu_box .item .item_image img {
    width: 100%;
  }
  .sec02 .box .shinsatsu_box .item .item_title {
    margin-bottom: 4.2vw;
    font-size: 5.8vw;
  }
  .sec02 .box .shinsatsu_box .item .text {
    font-size: 4.4vw;
  }
  .sec02 .box .others_box {
    width: 1125px;
    max-width: 100%;
    margin: 0 auto 0;
    -moz-column-gap: initial;
         column-gap: initial;
    row-gap: 13.8vw;
    grid-template-columns: repeat(1, 1fr);
  }
  .sec02 .box .others_box .item {
    box-sizing: border-box;
  }
  .sec02 .box .others_box .item .item_image {
    margin-bottom: 4.2vw;
  }
  .sec02 .box .others_box .item .item_image img {
    width: 100%;
  }
  .sec02 .box .others_box .item .item_title {
    margin-bottom: 4.2vw;
    font-size: 5.8vw;
    font-weight: 600;
    text-wrap: nowrap;
  }
  .sec02 .box .others_box .item .item_text {
    font-size: 4.4vw;
    position: relative;
    z-index: 3;
  }
}

.sec03 {
  background-color: #E6F0F4;
  margin-bottom: 100px;
  padding-bottom: clamp(142px, 11.111vw, 160px);
}
.sec03 .sub_title {
  padding-top: clamp(184px, 14.375vw, 207px);
  margin-bottom: 10px;
  letter-spacing: 0.1em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 21px;
  font-weight: 500;
  text-align: center;
  position: relative;
}
.sec03 .sub_title::before {
  content: "Devices";
  position: absolute;
  top: clamp(80px, 6.25vw, 90px);
  left: 50%;
  transform: translateX(-50%);
  letter-spacing: 0.15em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: clamp(72px, 5.625vw, 81px);
  font-weight: 600;
  color: rgba(140, 190, 214, 0.7);
}
.sec03 .sec_title {
  box-sizing: border-box;
  margin-bottom: clamp(133px, 10.416vw, 150px);
  letter-spacing: 0.1em;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 36px;
  font-weight: 600;
  text-align: center;
}
.sec03 .cont {
  width: 1180px;
  max-width: 100%;
  margin: 0 auto 57px;
}
.sec03 .imagebox {
  width: 42.37%;
  max-width: 42.37%;
  min-width: 42.37%;
}
.sec03 .textbox {
  width: 57.67%;
  margin-left: clamp(56px, 4.375vw, 63px);
}
.sec03 .cont_title {
  margin-bottom: 29px;
  padding-top: clamp(34px, 2.708vw, 39px);
  padding-left: 0;
  font-size: 32px;
  font-weight: 500;
  line-height: 1;
  text-align: justify;
}
.sec03 .cont_text {
  padding-left: 0;
  line-height: 2;
}
.sec03 .clean_safty_box {
  width: clamp(1048px, 81.944vw, 1180px);
  max-width: 100%;
  margin: clamp(124px, 9.722vw, 140px) auto 0;
  position: relative;
  z-index: 1;
}
.sec03 .clean_safty_box::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: -38px;
  left: 0;
  background: url(/images/clinic02/setsubi_box_bg.webp) center center/contain no-repeat;
  width: clamp(1080px, 84.375vw, 1215px);
  height: clamp(323px, 25.277vw, 364px);
}
.sec03 .clean_safty_box .title_box {
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  margin-left: clamp(83px, 6.527vw, 94px);
  margin-right: auto;
  margin-bottom: clamp(62px, 4.861vw, 70px);
  padding-top: 40px;
  position: relative;
  z-index: 3;
}
.sec03 .clean_safty_box .title_box .subtitle {
  letter-spacing: 0.15em;
  line-height: 1.5;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 41px;
  font-weight: 600;
  color: #fff;
  text-align: center;
}
.sec03 .clean_safty_box .title_box .title {
  letter-spacing: 0.1em;
  line-height: 1.15;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}
.sec03 .clean_safty_box .setsubi_box {
  width: clamp(967px, 75.555vw, 1088px);
  max-width: 100%;
  margin: 0 auto;
  position: relative;
  z-index: 3;
  -moz-column-gap: clamp(41px, 3.263vw, 47px);
       column-gap: clamp(41px, 3.263vw, 47px);
  grid-template-columns: repeat(3, 1fr);
}
.sec03 .clean_safty_box .setsubi_box .item {
  box-sizing: border-box;
}
.sec03 .clean_safty_box .setsubi_box .item .item_image {
  margin-bottom: 20px;
  width: clamp(293px, 22.916vw, 330px);
  height: clamp(195px, 15.277vw, 220px);
}
.sec03 .clean_safty_box .setsubi_box .item .item_title {
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  line-height: 1.2;
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "noto serif jp", serif;
  font-size: 26px;
  font-weight: 500;
  text-align: center;
}
.sec03 .clean_safty_box .setsubi_box .item .text {
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: justify;
  color: #695446;
}
@media screen and (max-width: 767px) {
  .sec03 {
    margin-bottom: 13.8vw;
    padding-bottom: 13.8vw;
  }
  .sec03 .sub_title {
    padding-top: 39.25vw;
    margin-bottom: 3.93vw;
    font-size: 4.8vw;
    position: relative;
  }
  .sec03 .sub_title::before {
    top: 18.26vw;
    left: 50%;
    transform: translateX(-50%);
    font-size: 15.36vw;
    width: 100%;
  }
  .sec03 .sec_title {
    box-sizing: border-box;
    margin-bottom: 13.8vw;
    font-size: 6.9vw;
  }
  .sec03 .cont {
    width: 1180px;
    max-width: 100%;
    margin: 0 auto 57px;
    padding: 0 5.5vw;
  }
  .sec03 .imagebox {
    width: 100%;
    max-width: initial;
    min-width: initial;
  }
  .sec03 .textbox {
    width: 100%;
    margin-left: initial;
  }
  .sec03 .cont_title {
    margin-bottom: 4.2vw;
    padding-top: 0;
    font-size: 5.5vw;
  }
  .sec03 .cont_text {
    font-size: 4.4vw;
  }
  .sec03 .clean_safty_box {
    width: 89.8vw;
    max-width: 100%;
    margin: 27.6vw auto 0;
    position: relative;
    z-index: 1;
  }
  .sec03 .clean_safty_box::before {
    content: "";
    position: absolute;
    z-index: 0;
    top: -38px;
    left: 0;
    background: url(/images/clinic02/setsubi_box_bg_sp.webp) center center/contain no-repeat;
    width: 95.2vw;
    height: 62.4vw;
  }
  .sec03 .clean_safty_box .title_box {
    width: 100%;
    max-width: 100%;
    margin-left: initial;
    margin-right: initial;
    margin-bottom: initial;
    margin: 0 auto 8vw;
    padding-top: 10.66vw;
    position: relative;
    z-index: 3;
  }
  .sec03 .clean_safty_box .title_box .subtitle {
    font-size: 8.53vw;
  }
  .sec03 .clean_safty_box .title_box .title {
    font-size: 6.13vw;
  }
  .sec03 .clean_safty_box .setsubi_box {
    box-sizing: border-box;
    width: initial;
    padding: 0 5.5vw;
    position: relative;
    z-index: 3;
    -moz-column-gap: initial;
         column-gap: initial;
    row-gap: 13.8vw;
    grid-template-columns: repeat(1, 1fr);
  }
  .sec03 .clean_safty_box .setsubi_box .item {
    box-sizing: border-box;
    width: 78.66vw;
  }
  .sec03 .clean_safty_box .setsubi_box .item .item_image {
    text-align: center;
    margin-bottom: 4.2vw;
    width: initial;
    height: initial;
  }
  .sec03 .clean_safty_box .setsubi_box .item .item_image img {
    width: 100%;
  }
  .sec03 .clean_safty_box .setsubi_box .item .item_title {
    margin-bottom: 4.2vw;
    font-size: 5.5vw;
  }
  .sec03 .clean_safty_box .setsubi_box .item .text {
    font-size: 4.4vw;
  }
}/*# sourceMappingURL=clinic.css.map */