@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@100;300;400;500;700;800;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200");
@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100..700;1,100..700&display=swap");
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanjp.css");
.main-visual-top {
  width: 100%;
  height: calc(100vh - 56px);
  overflow-x: auto;
}
@media screen and (min-width: 768px) {
  .main-visual-top {
    height: auto !important;
    overflow-x: hidden;
  }
}
.main-visual-top-messagebox {
  justify-content: flex-end;
  align-items: flex-start;
  padding: 20px;
  box-sizing: border-box;
}
.main-visual-top-messagebox::after {
  content: none;
}
.main-visual-top__container {
  position: relative;
  z-index: 0;
  width: calc((100vh - 56px) * 1.5605493134);
  height: 100%;
}
@media screen and (min-width: 768px) {
  .main-visual-top__container {
    width: 100vw;
    height: 64.08vw;
  }
}
.main-visual-top__imagebox {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.main-visual-top__imagebox .point > * {
  position: absolute;
  z-index: 10;
  cursor: pointer;
}
.main-visual-top__imagebox .point__01 {
  top: 38.5%;
  left: 83%;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__01 {
    top: 38.5%;
    top: calc(40.5% - 27px);
    left: 83%;
  }
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__01 .point__text {
    top: 70px;
  }
}
.main-visual-top__imagebox .point__01 .point__fukidashi {
  width: 10vw;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__01 .point__fukidashi {
    width: 100%;
    max-width: 140px;
    line-height: 1;
  }
}
.main-visual-top__imagebox .point__02 {
  top: 37%;
  left: 72%;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__02 {
    top: 38%;
    top: calc(48% - 95px);
    left: calc(76% - 55px);
  }
}
.main-visual-top__imagebox .point__03 {
  top: 48%;
  left: 58.5%;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__03 {
    top: 48%;
    top: calc(58% - 95px);
    left: calc(62.5% - 55px);
  }
}
.main-visual-top__imagebox .point__04 {
  top: 37%;
  left: 40.5%;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__04 {
    top: 48%;
    top: calc(33% - 95px);
    left: calc(43.5% - 55px);
  }
}
.main-visual-top__imagebox .point__04 .point__text {
  opacity: 1;
}
.main-visual-top__imagebox .point__05 {
  top: 8.5%;
  left: 22.2%;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__05 {
    top: 8.5%;
    top: calc(19.5% - 95px);
    left: calc(26.5% - 55px);
  }
}
.main-visual-top__imagebox .point__fukidashi {
  width: 8vw;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__fukidashi {
    width: 100%;
    max-width: 110px;
  }
}
.main-visual-top__imagebox .point__fukidashi img {
  width: 100%;
}
.main-visual-top__imagebox .point__text {
  position: absolute;
  top: 120%;
  left: 50%; /* 横方向の中央に揃えるためにleftを50%に設定 */
  transform: translateX(-50%);
  padding: 0 1vw;
  background-color: #fff;
  box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
  white-space: nowrap;
  font-size: 1.5vw;
  transition: 0.3s;
  opacity: 0;
}
@media screen and (min-width: 1160px) {
  .main-visual-top__imagebox .point__text {
    top: 110px;
    font-size: 18px;
  }
}
.main-visual-top__imagebox .point__text.show {
  opacity: 1;
}
.main-visual-top__imagebox .before_base,
.main-visual-top__imagebox .after_base {
  transition: 0.7s;
}
.main-visual-top__imagebox .point,
.main-visual-top__imagebox #sync,
.main-visual-top__imagebox .plumb-parts,
.main-visual-top__imagebox .before_base {
  opacity: 0;
}
.main-visual-top__imagebox .plumb-parts {
  transition: 0.6s;
}

/*# sourceMappingURL=style.css.map */
