@charset "UTF-8";
html {
  scroll-behavior: smooth;
  font-size: min(1.3333333333vw, 16px);
}
@media (max-width: 768px) {
  html {
    font-size: min(3.7209302326vw, 16px);
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #24243C;
  background-color: #fdfdfd;
  line-height: 2;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.box {
  width: min(96.6666666667vw, 1160px);
  margin: 0 auto;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media (max-width: 768px) {
  .box {
    width: min(86.0465116279vw, 370px);
  }
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: normal;
      -ms-flex-align: normal;
          align-items: normal;
}

.grid {
  display: grid;
}

.pc {
  display: inherit;
}

.sp {
  display: none;
}

@media (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: inherit;
  }
}
.btn {
  width: min(25vw, 300px);
  height: min(5vw, 60px);
  font-size: min(1.6666666667vw, 20px);
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.btn:hover {
  opacity: 0.8;
}
@media (max-width: 768px) {
  .btn {
    width: min(43.023255814vw, 185px);
    height: min(13.9534883721vw, 60px);
    font-size: min(3.7209302326vw, 16px);
  }
}
.btn.download {
  background-color: #D9E021;
  color: #24243C;
}
.btn.contact {
  background-color: #24243C;
  color: #fdfdfd;
}
.btn.download_white {
  background-color: #fdfdfd;
  color: #24243C;
}

.heading {
  display: inline-block;
}
.heading h2 {
  font-size: min(3.3333333333vw, 40px);
  font-weight: bold;
  border-left: 2px solid #25BFE3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  line-height: 1;
  padding-left: min(2.5vw, 30px);
}
@media (max-width: 768px) {
  .heading h2 {
    font-size: min(6.511627907vw, 28px);
    padding-left: min(4.6511627907vw, 20px);
    line-height: 1.5;
  }
}
.heading h2 span {
  font-size: min(1.5vw, 18px);
  font-weight: 700;
  margin-top: min(1.6666666667vw, 20px);
  letter-spacing: 0.1em;
}
@media (max-width: 768px) {
  .heading h2 span {
    font-size: min(3.7209302326vw, 16px);
    margin-top: min(1.1627906977vw, 5px);
  }
}
.heading.effect {
  position: relative;
}
.heading.effect::before {
  content: "";
  position: absolute;
  display: inline-block;
  top: 0;
  left: 0;
  background-color: #25BFE3;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.heading.effect.is-visible .mask {
  opacity: 1;
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.heading.effect.is-visible::before {
  -webkit-animation: 0.6s both scroll-effect-before 0s cubic-bezier(0.36, 0, 1, 0.29);
          animation: 0.6s both scroll-effect-before 0s cubic-bezier(0.36, 0, 1, 0.29);
}
.heading.effect .mask {
  opacity: 0;
}

.fadein {
  -webkit-transform: translateY(8%);
  transform: translateY(8%);
  opacity: 0;
  -webkit-transition-duration: 1s;
          transition-duration: 1s;
  transition-property: opacity, -webkit-transform;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-timing-function: cubic-bezier(0.17, 0.84, 0.45, 0.99);
          transition-timing-function: cubic-bezier(0.17, 0.84, 0.45, 0.99);
  will-change: transition;
}
.fadein.is-visible {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

.noto {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.roboto-cond {
  font-family: "Roboto Condensed", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

a {
  color: #25BFE3;
  text-decoration: none;
}

#plans, #spec {
  scroll-margin-top: 80px;
}

#about {
  scroll-margin-top: -60px;
}

@-webkit-keyframes scroll-effect-mask {
  0% {
    opacity: 1;
    clip-path: inset(0% 100% 0% 0%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0% 0% 0% 0%);
  }
}

@keyframes scroll-effect-mask {
  0% {
    opacity: 1;
    clip-path: inset(0% 100% 0% 0%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0% 0% 0% 0%);
  }
}
@-webkit-keyframes scroll-effect-before {
  0% {
    opacity: 1;
    clip-path: inset(0% 100% 0% 0%);
  }
  49% {
    clip-path: inset(0% 0% 0% 0%);
  }
  50% {
    clip-path: inset(0% 0% 0% 0%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0% 0% 0% 100%);
  }
}
@keyframes scroll-effect-before {
  0% {
    opacity: 1;
    clip-path: inset(0% 100% 0% 0%);
  }
  49% {
    clip-path: inset(0% 0% 0% 0%);
  }
  50% {
    clip-path: inset(0% 0% 0% 0%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0% 0% 0% 100%);
  }
}
@-webkit-keyframes endLoadingLogoAnimation {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes endLoadingLogoAnimation {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes venn1stCircleAnimation {
  0% {
    opacity: 0;
    top: -100px;
  }
  100% {
    opacity: 1;
  }
}
@keyframes venn1stCircleAnimation {
  0% {
    opacity: 0;
    top: -100px;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes venn2ndCircleAnimation {
  0% {
    opacity: 0;
    left: -100px;
  }
  100% {
    opacity: 1;
  }
}
@keyframes venn2ndCircleAnimation {
  0% {
    opacity: 0;
    left: -100px;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes venn3rdCircleAnimation {
  0% {
    opacity: 0;
    right: -100px;
  }
  100% {
    opacity: 1;
  }
}
@keyframes venn3rdCircleAnimation {
  0% {
    opacity: 0;
    right: -100px;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes drawCircle {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes drawCircle {
  to {
    stroke-dashoffset: 0;
  }
}
@-webkit-keyframes drawCircleReverse {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes drawCircleReverse {
  to {
    stroke-dashoffset: 0;
  }
}
@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@-webkit-keyframes toRight {
  0% {
    opacity: 1;
    right: 0%;
  }
  1% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    right: 0%;
  }
}
@keyframes toRight {
  0% {
    opacity: 1;
    right: 0%;
  }
  1% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    right: 0%;
  }
}
@-webkit-keyframes toLeft {
  0% {
    opacity: 1;
    left: 0%;
  }
  1% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    left: 0%;
  }
}
@keyframes toLeft {
  0% {
    opacity: 1;
    left: 0%;
  }
  1% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    left: 0%;
  }
}
@-webkit-keyframes toLeftSp02 {
  0% {
    opacity: 1;
    left: 0%;
    top: 82%;
  }
  100% {
    opacity: 1;
    left: 0%;
    top: 82%;
  }
}
@keyframes toLeftSp02 {
  0% {
    opacity: 1;
    left: 0%;
    top: 82%;
  }
  100% {
    opacity: 1;
    left: 0%;
    top: 82%;
  }
}
@-webkit-keyframes toLeftSp03 {
  0% {
    opacity: 1;
    left: -7%;
    top: 5%;
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
  }
  100% {
    opacity: 1;
    left: -7%;
    top: 5%;
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
  }
}
@keyframes toLeftSp03 {
  0% {
    opacity: 1;
    left: -7%;
    top: 5%;
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
  }
  100% {
    opacity: 1;
    left: -7%;
    top: 5%;
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
  }
}
#splash {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100svh;
  z-index: 9999;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#splash::before {
  content: "";
  display: inline-block;
  width: 100vw;
  height: 100svh;
  background-color: #fdfdfd;
  position: absolute;
}
#splash::before {
  top: 0;
  left: 0;
  -webkit-transition: 1s cubic-bezier(0.85, 0, 0.15, 1);
  transition: 1s cubic-bezier(0.85, 0, 0.15, 1);
}
#splash .logo-fadeout {
  -webkit-animation: endLoadingLogoAnimation 1.5s cubic-bezier(0.85, 0, 0.15, 1) forwards;
          animation: endLoadingLogoAnimation 1.5s cubic-bezier(0.85, 0, 0.15, 1) forwards;
  opacity: 0;
}
#splash #loading-logo {
  position: fixed;
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  text-align: center;
}
#splash #loading-logo img {
  width: 70%;
}

.finished #splash {
  visibility: hidden;
}
.finished #splash::before {
  top: -100svh;
  left: 0;
}

.st-Logo {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-decoration: none;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: auto;
}

.st-Logo_Main {
  width: 159px;
  min-width: 159px;
  margin: 0 50px 0 0;
}

.st-GlobalHeader_StatementImage.st-GlobalHeader_StatementImage {
  width: 190px;
  height: auto;
}

.st-GlobalHeader {
  position: relative;
  border-bottom: 2px solid #e6e6e6;
  border-bottom: 0px solid #e6e6e6;
}

.st-GlobalHeader_link a {
  font-size: 14px;
  color: #000;
  text-decoration: none;
  font-weight: 600;
  position: relative;
  display: inline-block;
}

.st-GlobalHeader_link a::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-top: #df0523 1px solid;
  border-left: #df0523 1px solid;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  margin: -1px 0 0 60px;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  top: calc(50% - 4px);
  left: -78px;
}

.st-GlobalHeader_link a:hover {
  color: #df0523;
}

.st-Logo_Main img {
  width: 159px;
  height: 34px;
}

.st-GlobalHeader, .st-GlobalFooter {
  background-color: #fff;
}

.st-GlobalHeader_Inner {
  max-width: 1200px;
  margin: auto;
}

/*----------------
	st-GlobalNav
-----------------*/
.st-GlobalNav_Area {
  padding-bottom: 0;
  top: 64px;
}

.st-GlobalNav-categoryFirst .st-GlobalNav_Area {
  background-color: #fdfdfd;
}

.st-GlobalSiteNav_Item {
  position: relative;
}

.st-GlobalSiteNav_Item a {
  -webkit-animation: nav_animation 1s both 0.5s;
          animation: nav_animation 1s both 0.5s;
}

.st-GlobalSiteNav_Item::after {
  content: "";
  display: inline-block;
  background-color: #24243C;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-animation: nav_animation 1s both 0.5s;
          animation: nav_animation 1s both 0.5s;
}

.st-GlobalSiteNav_Item:nth-of-type(6):after,
.st-GlobalSiteNav_Item:nth-of-type(7):after {
  content: none;
}

@-webkit-keyframes nav_animation {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes nav_animation {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.st-GlobalSiteNav_Link {
  border-bottom: none;
  background-color: #fdfdfd;
  color: #25BFE3;
}

#st-GlobalNav {
  position: fixed;
  left: 23px;
  bottom: 75vh;
  z-index: 110;
  background: transparent;
  width: auto;
  mix-blend-mode: difference;
}

#st-GlobalNav a {
  color: #fff;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  text-align: left;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 75vh;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a {
  font-size: 1.125rem;
  font-weight: 700;
  padding: 0;
  position: relative;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover {
  color: #e7803b;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .mark {
  font-size: 1.25rem;
  position: absolute;
  left: -33px;
  top: 9px;
  color: transparent;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover .mark {
  color: #e7803b;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active .mark {
  color: #e7803b;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active {
  color: #e7803b;
}

#st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .jp {
  font-size: 0.875rem;
  font-family: 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: normal;
}

@media screen and (min-width: 769px) {
  .st-GlobalHeader_Logo {
    width: 100%;
    padding: 0px 20px;
    float: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    line-height: 1;
    height: 60px;
  }
}
@media print, screen and (max-width: 1440px) {
  #st-GlobalNav {
    bottom: 72vh;
    left: 16px;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List {
    height: calc(100svh - 64px);
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a {
    font-size: 0.9rem;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .mark {
    left: -26px;
    top: 5px;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .jp {
    font-size: 0.75rem;
    line-height: 1.4;
  }
}
@media print, screen and (max-width: 768px) {
  .st-Logo_Main img {
    width: 118px;
    height: 40px;
  }
  .st-GlobalHeader {
    position: fixed;
    width: 100%;
    z-index: 100;
    -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  }
  #st-GlobalNav {
    mix-blend-mode: normal;
  }
  #st-GlobalNav .st-GlobalSiteNav {
    background-color: #fdfdfd;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #st-GlobalNav a {
    color: #24243C;
  }
  #st-GlobalNav .st-GlobalSiteNav_Item.download .st-GlobalSiteNav_Link {
    background-color: #D9E021;
  }
  #st-GlobalNav .st-GlobalSiteNav_Item.contact .st-GlobalSiteNav_Link {
    background-color: #24243C;
    color: #fdfdfd;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a {
    font-size: 3.5vw;
    font-weight: 500;
    padding: 4vw 8vw;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover {
    color: #25BFE3;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover .mark {
    color: #25BFE3;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active {
    color: #25BFE3;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .jp {
    font-size: 3vw;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .download a,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .contact a {
    text-align: center;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .download a .jp,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .contact a .jp {
    margin-right: 0;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .pc_only {
    display: none;
  }
  /* ハンバーガー閉じる */
  #st-GlobalNav .st-GlobalNav_Area.close {
    height: 0 !important;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
  }
  #st-GlobalNav .close {
    padding-bottom: 0;
  }
}
@media print, screen and (max-width: 768px) {
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a {
    font-size: min(2.6666666667vw, 32px);
    font-weight: bold;
    text-align: center;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a .jp {
    font-size: min(4vw, 48px);
    font-weight: bold;
  }
  .st-GlobalHeader_Buttons {
    width: 64px;
    height: 64px;
    /* FF3.6-15 */
    /* Chrome10-25,Safari5.1-6 */
    background: -webkit-gradient(linear, left top, left bottom, from(rgb(60, 60, 60)), to(rgb(1, 1, 1)));
    background: linear-gradient(to bottom, rgb(60, 60, 60) 0%, rgb(1, 1, 1) 100%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#3c3c3c", endColorstr="#010101", GradientType=0);
    /* IE6-9 */
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .st-ToggleButton_Icon:before {
    color: #FFF;
    font-size: 34px;
  }
}
#mv {
  background-color: #25BFE3;
  color: #fdfdfd;
  padding-top: min(5vw, 60px);
  overflow-x: hidden;
}
#mv::-webkit-scrollbar {
  display: none;
}
@media (max-width: 768px) {
  #mv {
    padding-top: 0;
    background-color: transparent;
    position: relative;
  }
  #mv::after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 100vw;
    height: 100svh;
    top: 0;
    left: 0;
    background-color: #25BFE3;
    z-index: -1;
  }
}
#mv .flex.box {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: min(0.8333333333vw, 10px);
  position: relative;
}
@media (max-width: 768px) {
  #mv .flex.box {
    position: static;
  }
}
@media (max-width: 768px) {
  #mv .flex.box .mv_content {
    width: 100%;
  }
}
#mv .flex.box .logo_vimeo {
  width: min(50vw, 600px);
  margin-top: min(12.5vw, 150px);
}
@media (max-width: 768px) {
  #mv .flex.box .logo_vimeo {
    width: min(79.0697674419vw, 340px);
    margin-top: min(34.8837209302vw, 150px);
  }
}
#mv .flex.box .catch-copy {
  font-size: min(2.5vw, 30px);
  font-weight: 700;
  margin-top: min(4.1666666667vw, 50px);
}
@media (max-width: 768px) {
  #mv .flex.box .catch-copy {
    font-size: min(5.5813953488vw, 24px);
    margin-top: min(11.6279069767vw, 50px);
    line-height: 1.6;
  }
}
#mv .flex.box .sub-copy {
  margin-top: min(0.8333333333vw, 10px);
}
@media (max-width: 768px) {
  #mv .flex.box .sub-copy {
    margin-top: min(4.6511627907vw, 20px);
  }
}
#mv .flex.box .btn_wrap {
  margin-top: min(9.1666666667vw, 110px);
  gap: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #mv .flex.box .btn_wrap {
    margin-top: min(18.6046511628vw, 80px);
    width: 100%;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media (max-width: 768px) {
  #mv .flex.box .btn_wrap .btn {
    width: 50%;
  }
}
#mv .flex.box .video-container {
  position: relative;
  width: min(35.6666666667vw, 428px);
  aspect-ratio: 9/16;
}
@media (max-width: 768px) {
  #mv .flex.box .video-container {
    width: min(86.0465116279vw, 370px);
    margin-top: min(4.6511627907vw, 20px);
  }
}
#mv .flex.box video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: opacity 0.8s ease;
  transition: opacity 0.8s ease;
  display: block;
  opacity: 0;
  z-index: 0;
  pointer-events: none;
}
#mv .flex.box video.active {
  opacity: 1;
  z-index: 1;
}
#mv .flex.box .scroll {
  font-size: min(1.1666666667vw, 14px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: absolute;
  right: -40px;
  bottom: 150px;
}
@media (max-width: 768px) {
  #mv .flex.box .scroll {
    font-size: min(2.7906976744vw, 12px);
    top: 85svh;
    right: min(1.1627906977vw, 5px);
    bottom: auto;
  }
}
#mv .flex.box .scroll p {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
#mv .flex.box .scroll .scroll-arrow {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: min(0.8333333333vw, 10px);
}
#mv .flex.box .scroll .scroll-arrow img {
  width: min(1.1666666667vw, 14px);
  margin-top: min(0.1666666667vw, 2px);
}
@media (max-width: 768px) {
  #mv .flex.box .scroll .scroll-arrow img {
    width: min(2.7906976744vw, 12px);
    margin-top: min(0.4651162791vw, 2px);
  }
}
#mv .flex.box .scroll .scroll-arrow img:nth-of-type(1) {
  -webkit-animation: mv-arrow 3s 1s infinite;
          animation: mv-arrow 3s 1s infinite;
}
#mv .flex.box .scroll .scroll-arrow img:nth-of-type(2) {
  -webkit-animation: mv-arrow 3s 1.1s infinite;
          animation: mv-arrow 3s 1.1s infinite;
}
#mv .flex.box .scroll .scroll-arrow img:nth-of-type(3) {
  -webkit-animation: mv-arrow 3s 1.2s infinite;
          animation: mv-arrow 3s 1.2s infinite;
}
#mv .flex.box .scroll .scroll-arrow img:nth-of-type(4) {
  -webkit-animation: mv-arrow 3s 1.3s infinite;
          animation: mv-arrow 3s 1.3s infinite;
}
#mv .flex.box .scroll .scroll-arrow img:nth-of-type(5) {
  -webkit-animation: mv-arrow 3s 1.4s infinite;
          animation: mv-arrow 3s 1.4s infinite;
}

@-webkit-keyframes mv-arrow {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  15% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes mv-arrow {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  15% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
#about {
  background-color: #fdfdfd;
  color: #24243C;
  margin-top: max(-11.6666666667vw, -140px);
  padding-top: min(5vw, 60px);
  padding-bottom: min(10vw, 120px);
}
@media (max-width: 768px) {
  #about {
    padding: min(37.2093023256vw, 160px) 0 min(20.9302325581vw, 90px);
  }
}
#about h2 {
  border-color: #25BFE3;
}
#about .about_content {
  margin-top: min(5vw, 60px);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (max-width: 768px) {
  #about .about_content {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: min(9.3023255814vw, 40px);
  }
}
#about .about_content .venn {
  width: min(32.3333333333vw, 388px);
  height: min(29.6666666667vw, 356px);
  position: relative;
  margin-left: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #about .about_content .venn {
    width: min(65.1162790698vw, 280px);
    height: min(59.3023255814vw, 255px);
    margin-left: min(0vw, 0px);
  }
}
#about .about_content .venn .circle-wrap {
  width: min(17.5vw, 210px);
  height: min(17.5vw, 210px);
  position: absolute;
}
@media (max-width: 768px) {
  #about .about_content .venn .circle-wrap {
    width: min(34.8837209302vw, 150px);
    height: min(34.8837209302vw, 150px);
  }
}
#about .about_content .venn .circle-wrap .circle-svg {
  width: 100%;
  height: 100%;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg); /* アニメーション開始位置調整 */
}
#about .about_content .venn .circle-wrap .circle-svg .circle-stroke {
  fill: none;
  stroke: #24243C;
  stroke-width: 1;
  stroke-dasharray: 565.48;
  stroke-dashoffset: 565.48;
}
#about .about_content .venn .circle-wrap.venn1st {
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#about .about_content .venn .circle-wrap.venn2nd {
  bottom: 0;
  left: 0;
}
#about .about_content .venn .circle-wrap.venn3rd {
  bottom: 0;
  right: 0;
}
#about .about_content .venn .circle-text {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -40%);
          transform: translate(-50%, -40%);
  text-align: center;
  opacity: 0;
  font-size: min(1.6666666667vw, 20px);
  line-height: 1;
  font-weight: 400;
}
@media (max-width: 768px) {
  #about .about_content .venn .circle-text {
    font-size: min(4.1860465116vw, 18px);
  }
}
#about .about_content .venn .circle-text .noto {
  font-size: min(1.6666666667vw, 20px);
  font-weight: 400;
  margin-top: min(0.8333333333vw, 10px);
  line-height: 1;
}
@media (max-width: 768px) {
  #about .about_content .venn .circle-text .noto {
    font-size: min(3.7209302326vw, 16px);
    margin-top: min(2.3255813953vw, 10px);
  }
}
#about .about_content .venn .circle-text span {
  font-weight: bold;
}
#about .about_content .about_content-text {
  color: #24243C;
  margin-left: min(6.6666666667vw, 80px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text {
    margin-top: min(6.976744186vw, 30px);
    margin-left: min(0vw, 0px);
  }
}
#about .about_content .about_content-text p {
  font-weight: 600;
}
#about .about_content .about_content-text .sub-copy {
  font-size: min(2vw, 24px);
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .sub-copy {
    font-size: 24px;
  }
}
#about .about_content .about_content-text .about_content_image {
  position: relative;
  font-size: min(1.1666666667vw, 14px);
  line-height: 1.5;
  text-align: center;
  margin-top: min(3.3333333333vw, 40px);
}
#about .about_content .about_content-text .about_content_image img {
  width: min(51.9166666667vw, 623px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image img {
    width: 100%;
  }
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image {
    font-size: min(2.7906976744vw, 12px);
  }
}
#about .about_content .about_content-text .about_content_image .object {
  position: absolute;
}
#about .about_content .about_content-text .about_content_image .about_content_image_01 {
  width: min(15.3333333333vw, 184px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_01 {
    width: min(33.2558139535vw, 143px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_01 p {
  color: #fdfdfd;
  position: absolute;
  top: max(-6.25vw, -75px);
  left: min(1.4166666667vw, 17px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_01 p {
    width: min(33.2558139535vw, 143px);
    top: max(-35.5813953488vw, -153px);
    left: max(-2.7906976744vw, -12px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_02 .about_content_image_02-1 {
  position: absolute;
  width: min(7.0833333333vw, 85px);
  top: min(0.8333333333vw, 10px);
  right: min(4.1666666667vw, 50px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_02 .about_content_image_02-1 {
    width: min(9.7674418605vw, 42px);
    right: min(16.2790697674vw, 70px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_02 .about_content_image_02-2 {
  position: absolute;
  width: min(6.1666666667vw, 74px);
  top: min(5vw, 60px);
  right: min(0vw, 0px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_02 .about_content_image_02-2 {
    width: min(13.488372093vw, 58px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_02 p {
  position: absolute;
  top: min(11.25vw, 135px);
  right: min(0vw, 0px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_02 p {
    top: min(24.4186046512vw, 105px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_03 {
  width: min(7.25vw, 87px);
  top: min(11.25vw, 135px);
  left: min(25vw, 300px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_image_03 {
    width: min(20.9302325581vw, 90px);
    top: min(52.3255813953vw, 225px);
    left: min(39.5348837209vw, 170px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_image_03 p {
  text-align: left;
  margin: min(0.8333333333vw, 10px) 0 0 min(0.4166666667vw, 5px);
}
#about .about_content .about_content-text .about_content_image .about_content_line {
  width: 100%;
  height: 100%;
}
#about .about_content .about_content-text .about_content_image .about_content_line_01 {
  width: min(22.5vw, 270px);
  top: min(0.4166666667vw, 5px);
  left: min(16.6666666667vw, 200px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_line_01 {
    width: min(17.2093023256vw, 74px);
    top: min(1.1627906977vw, 5px);
    left: min(37.2093023256vw, 160px);
  }
}
#about .about_content .about_content-text .about_content_image .about_content_line_02 {
  width: min(10vw, 120px);
  top: min(9.4166666667vw, 113px);
  left: min(31.6666666667vw, 380px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_line_02 {
    width: min(18.8372093023vw, 81px);
    top: min(53.7209302326vw, 231px);
    left: min(59.3023255814vw, 255px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #about .about_content .about_content-text .about_content_image .about_content_line_02 .about_content_line {
    width: min(18.6046511628vw, 80px);
    height: min(13.9534883721vw, 60px);
  }
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_line_02 p {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
#about .about_content .about_content-text .about_content_image .about_content_line_03 {
  width: min(10vw, 120px);
  top: min(9.4166666667vw, 113px);
  left: min(13.3333333333vw, 160px);
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_line_03 {
    width: min(18.8372093023vw, 81px);
    top: min(53.7209302326vw, 231px);
    left: min(13.9534883721vw, 60px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #about .about_content .about_content-text .about_content_image .about_content_line_03 .about_content_line {
    width: min(18.6046511628vw, 80px);
    height: min(13.9534883721vw, 60px);
  }
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image .about_content_line_03 p {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
#about .about_content .about_content-text .about_content_image path {
  width: 100%;
  fill: none;
  stroke: #24243C;
  stroke-width: 16;
  stroke-dasharray: 300;
  stroke-dashoffset: 300;
}
@media (max-width: 768px) {
  #about .about_content .about_content-text .about_content_image path {
    stroke-width: 4;
  }
}

.finished #about .effect.is-visible .circle-stroke {
  -webkit-animation: drawCircle 0.6s cubic-bezier(0, 0.36, 0.19, 0.99) forwards;
          animation: drawCircle 0.6s cubic-bezier(0, 0.36, 0.19, 0.99) forwards;
}
.finished #about .effect.is-visible .circle-text {
  -webkit-animation: fadeInUp 0.6s ease-out 1s forwards;
          animation: fadeInUp 0.6s ease-out 1s forwards;
}
.finished #about .effect.is-visible .venn1st .circle-text {
  -webkit-animation-delay: 1.6s;
          animation-delay: 1.6s;
}
.finished #about .effect.is-visible .venn2nd .circle-text {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}
.finished #about .effect.is-visible .venn3rd .circle-text {
  -webkit-animation-delay: 2.4s;
          animation-delay: 2.4s;
}
.finished #about .effect.is-visible .circle-delay1 {
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}
.finished #about .effect.is-visible .circle-delay2 {
  -webkit-animation-delay: 1.6s;
          animation-delay: 1.6s;
}
.finished #about .effect.is-visible .circle-delay3 {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}
.finished #about .effect.is-visible .line_wrap {
  position: relative;
}
.finished #about .effect.is-visible .line_wrap::before {
  content: "";
  display: inline-block;
  width: min(2vw, 24px);
  height: min(1vw, 12px);
  background-color: #fdfdfd;
  position: absolute;
  top: min(0.5833333333vw, 7px);
  right: 0%;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .line_wrap::before {
    width: min(4.6511627907vw, 20px);
    height: min(2.3255813953vw, 10px);
  }
}
.finished #about .effect.is-visible .line_wrap::after {
  content: "";
  display: inline-block;
  width: min(2vw, 24px);
  height: min(1vw, 12px);
  background-color: #24243C;
  position: absolute;
  top: min(0.5833333333vw, 7px);
  clip-path: polygon(0 0, 100% 50%, 0% 100%);
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .line_wrap::after {
    width: min(4.6511627907vw, 20px);
    height: min(2.3255813953vw, 10px);
  }
}
.finished #about .effect.is-visible .about_content_line_01 .line_wrap::after {
  -webkit-animation: toRight 0s linear forwards 0s;
          animation: toRight 0s linear forwards 0s;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_01 .line_wrap::after {
    stroke-width: 6;
    -webkit-animation: toRight 0s linear forwards 0s;
            animation: toRight 0s linear forwards 0s;
  }
}
.finished #about .effect.is-visible .about_content_line_01 .line_wrap .about_content_line {
  padding-top: min(0.8333333333vw, 10px);
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_01 .line_wrap .about_content_line {
    padding-top: min(1.3953488372vw, 6px);
  }
}
.finished #about .effect.is-visible .about_content_line_01 .line_wrap .about_content_line .about_content_line_01-path {
  -webkit-animation: drawCircle 0s linear forwards 0s;
          animation: drawCircle 0s linear forwards 0s;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_01 .line_wrap .about_content_line .about_content_line_01-path {
    stroke-width: 6;
    -webkit-animation: drawCircle 0s linear forwards 0s;
            animation: drawCircle 0s linear forwards 0s;
  }
}
.finished #about .effect.is-visible .about_content_line_02 .line_wrap::after {
  -webkit-animation: toLeft 0s linear forwards 0s;
          animation: toLeft 0s linear forwards 0s;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_02 .line_wrap::after {
    -webkit-animation: toLeftSp02 0s linear forwards 0s;
            animation: toLeftSp02 0s linear forwards 0s;
  }
}
.finished #about .effect.is-visible .about_content_line_02 .line_wrap::before {
  left: 0%;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_02 .line_wrap::before {
    top: auto;
    bottom: 0%;
  }
}
.finished #about .effect.is-visible .about_content_line_02 .line_wrap .about_content_line_02-path {
  -webkit-animation: drawCircle 0s linear forwards 0s;
          animation: drawCircle 0s linear forwards 0s;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_02 .line_wrap .about_content_line_02-path {
    -webkit-animation: drawCircle 0s linear forwards 0s;
            animation: drawCircle 0s linear forwards 0s;
  }
}
.finished #about .effect.is-visible .about_content_line_03 .line_wrap::after {
  -webkit-animation: toLeft 0s linear forwards 0s;
          animation: toLeft 0s linear forwards 0s;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_03 .line_wrap::after {
    -webkit-animation: toLeftSp03 0s linear forwards 0s;
            animation: toLeftSp03 0s linear forwards 0s;
  }
}
.finished #about .effect.is-visible .about_content_line_03 .line_wrap::before {
  left: 0%;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_03 .line_wrap::before {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    left: -5%;
  }
}
.finished #about .effect.is-visible .about_content_line_03 .line_wrap .about_content_line_03-path {
  -webkit-animation: drawCircle 0s linear forwards 0s;
          animation: drawCircle 0s linear forwards 0s;
}
@media (max-width: 768px) {
  .finished #about .effect.is-visible .about_content_line_03 .line_wrap .about_content_line_03-path {
    -webkit-animation: drawCircle 0s linear forwards 0s;
            animation: drawCircle 0s linear forwards 0s;
  }
}

.nav {
  font-size: min(1.1666666667vw, 14px);
  position: sticky;
  top: 0;
  margin-top: min(2.5vw, 30px);
  z-index: 999;
  will-change: transform;
}
.nav .flex.box {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  background-color: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(3px);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.nav .flex.box a {
  color: #24243C;
  text-align: center;
  padding: min(1.25vw, 15px);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.nav .flex.box a:hover {
  opacity: 0.8;
}
.nav .flex.box a.download {
  background-color: #D9E021;
  width: min(16.6666666667vw, 200px);
  font-weight: bold;
}
.nav .flex.box a.contact {
  background-color: #24243C;
  color: #fdfdfd;
  width: min(16.6666666667vw, 200px);
  font-weight: bold;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.nav .flex.box .anchor {
  width: calc(100% - min(33.3333333333vw, 400px));
}
.nav .flex.box .anchor a {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  font-weight: 700;
}
.nav .flex.box .anchor a:not(:first-of-type)::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 1px;
  top: min(0.8333333333vw, 10px);
  left: 0;
  bottom: min(0.8333333333vw, 10px);
  background-color: #24243C;
}
.nav.inversion .flex.box {
  background-color: rgba(37, 37, 61, 0.9);
}
.nav.inversion .flex.box a {
  color: #fdfdfd;
}
.nav.inversion .flex.box .download {
  color: #24243C;
}
.nav.inversion .flex.box .contact {
  background-color: rgba(255, 255, 255, 0.9);
  color: #24243C;
}
.nav.inversion .flex.box .anchor a:not(:first-of-type)::after {
  background-color: rgba(255, 255, 255, 0.3);
}

#value {
  background-image: url(../img/bg_lattice.svg);
  background-color: rgba(37, 191, 227, 0.1);
  background-repeat: repeat;
  background-position: center top;
  background-size: min(2.4833333333vw, 29.8px);
  padding: min(15.8333333333vw, 190px) 0 min(13.3333333333vw, 160px);
  margin-top: max(-7.5vw, -90px);
}
@media (max-width: 768px) {
  #value {
    padding: min(18.6046511628vw, 80px) 0;
    margin-top: max(0vw, 0px);
  }
}
#value .value_content {
  position: relative;
}
#value .value_content .mask {
  height: min(27.3083333333vw, 327.7px);
  padding: 0 min(6.6666666667vw, 80px);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: min(2.4833333333vw, 29.8px);
  background-color: #fdfdfd;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  #value .value_content .mask {
    height: auto;
    padding: min(4.6511627907vw, 20px) min(4.6511627907vw, 20px) min(6.976744186vw, 30px);
    margin-top: min(9.3023255814vw, 40px);
  }
}
#value .value_content .mask .value_image {
  width: min(29.5833333333vw, 355px);
  grid-row: 1/3;
  grid-column: 1/2;
}
@media (max-width: 768px) {
  #value .value_content .mask .value_image {
    width: 100%;
    grid-row: 2/3;
    grid-column: 1/2;
  }
}
#value .value_content .mask .value_issue {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1.5;
  border-bottom: 1px solid #24243C;
  margin-bottom: min(1.6666666667vw, 20px);
  padding-bottom: min(1.6666666667vw, 20px);
  grid-row: 1/2;
  grid-column: 2/3;
  align-self: end;
  width: min(41.6666666667vw, 500px);
}
@media (max-width: 768px) {
  #value .value_content .mask .value_issue {
    width: 100%;
    margin-bottom: min(4.6511627907vw, 20px);
    padding-bottom: min(4.6511627907vw, 20px);
    grid-row: 1/2;
    grid-column: 1/2;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
  }
}
#value .value_content .mask .value_issue p {
  font-weight: 700;
}
#value .value_content .mask .value_issue .value_issue-number {
  font-size: min(3.3333333333vw, 40px);
  margin-right: min(1.6666666667vw, 20px);
  font-weight: 600;
}
@media (max-width: 768px) {
  #value .value_content .mask .value_issue .value_issue-number {
    font-size: min(7.9069767442vw, 34px);
    margin-right: min(0vw, 0px);
  }
}
#value .value_content .mask .value_text {
  grid-row: 2/3;
  grid-column: 2/3;
  align-self: start;
  width: min(41.6666666667vw, 500px);
}
@media (max-width: 768px) {
  #value .value_content .mask .value_text {
    width: 100%;
    grid-row: 3/4;
    grid-column: 1/2;
    margin-top: min(6.976744186vw, 30px);
  }
}
#value .value_content .mask .value_text p {
  font-weight: 600;
}
#value .value_content .mask .value_text .value_text-title {
  font-size: min(2.3333333333vw, 28px);
  font-weight: bold;
  color: #24243C;
}
@media (max-width: 768px) {
  #value .value_content .mask .value_text .value_text-title {
    font-size: min(5.5813953488vw, 24px);
    margin-bottom: min(2.3255813953vw, 10px);
    text-align: center;
    line-height: 1.5;
  }
}

#case {
  background-color: #24243C;
  padding: min(8.3333333333vw, 100px) 0;
}
#case h2 {
  color: #fdfdfd;
}
#case .slider {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#case .swiper-container {
  position: relative;
  padding: min(4.1666666667vw, 50px) 0;
  overflow: hidden;
  background-color: #24243C;
  width: min(98.3333333333vw, 1180px);
}
#case .swiper-slide {
  background: #ffffff;
  color: #fff;
  line-height: 1.5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 70%;
  max-width: calc(min(133.3333333333vw, 1600px) / 2);
}
#case .swiper-slide.soon {
  background-color: #5a5a69;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  font-size: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #case .swiper-slide.soon {
    font-size: min(4.6511627907vw, 20px);
  }
}
#case .swiper-slide .slide_image {
  width: 40%;
}
#case .swiper-slide .slide_image img {
  width: 100%;
  aspect-ratio: 1;
}
#case .swiper-slide img {
  -o-object-fit: cover;
     object-fit: cover;
}
#case .swiper-slide .slide_info {
  width: 60%;
  height: 100%;
  color: #24243C;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: min(2.5vw, 30px) min(3.3333333333vw, 40px);
}
#case .swiper-slide .slide_info .slide_top_text .company {
  font-size: min(1.25vw, 15px);
  font-weight: 600;
  margin-bottom: min(0.4166666667vw, 5px);
}
#case .swiper-slide .slide_info .slide_top_text .scene {
  font-size: min(1.8333333333vw, 22px);
  font-weight: 600;
}
#case .swiper-slide .slide_info .tag {
  border-top: 1px solid #24243C;
  padding: min(1.6666666667vw, 20px) 0 min(0.8333333333vw, 10px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: min(0.6666666667vw, 8px);
}
#case .swiper-slide .slide_info .tag span {
  font-size: min(1vw, 12px);
  text-align: center;
  border-radius: 20px;
  padding: min(0.4166666667vw, 5px) 0;
  color: #fff;
  background-color: #24243C;
  min-width: min(10.6666666667vw, 128px);
}
#case .swiper-slide .slide_info .example {
  font-size: min(1.5vw, 18px);
  font-weight: 600;
}
#case .swiper-button-prev,
#case .swiper-button-next {
  color: #fff;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 30px;
  height: 30px;
  margin: 0;
  z-index: 1;
}
#case .swiper-button-prev::after,
#case .swiper-button-next::after {
  font-size: 26px;
}
#case .swiper-button-prev {
  left: calc(50% - min(133.3333333333vw, 1600px) / 4 - min(6vw, 45px));
}
#case .swiper-button-next {
  right: calc(50% - min(133.3333333333vw, 1600px) / 4 - min(6vw, 45px));
}
#case .swiper-pagination {
  bottom: 0;
}
#case .swiper-pagination-bullet {
  background: #ffffff;
  width: min(1.1666666667vw, 14px);
  height: min(1.1666666667vw, 14px);
  margin: 0 min(0.8333333333vw, 10px);
  opacity: 1;
}
#case .swiper-pagination-bullet-active {
  background: #25BFE3;
  opacity: 1;
}
#case .swiper-fade-left,
#case .swiper-fade-right {
  position: absolute;
  top: 0;
  width: 30px;
  height: 100%;
  z-index: 10;
  pointer-events: none;
}
#case .swiper-fade-left {
  left: 0;
  background: -webkit-gradient(linear, left top, right top, from(#24243C), to(transparent));
  background: linear-gradient(to right, #24243C, transparent);
}
#case .swiper-fade-right {
  right: 0;
  background: -webkit-gradient(linear, right top, left top, from(#24243C), to(transparent));
  background: linear-gradient(to left, #24243C, transparent);
}
#case .case_material p {
  color: #fdfdfd;
  font-weight: 700;
  text-align: center;
  margin-top: min(1.6666666667vw, 20px);
  margin-bottom: min(0.8333333333vw, 10px);
}
#case .btn_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#case .btn_wrap .btn {
  width: min(29.1666666667vw, 350px);
}
@media (max-width: 768px) {
  #case .btn_wrap .btn {
    width: 50%;
  }
}

@media (max-width: 768px) {
  #case {
    padding: min(23.2558139535vw, 100px) min(6.976744186vw, 30px);
  }
  #case .swiper-container {
    position: relative;
    padding: min(11.6279069767vw, 50px) min(9.3023255814vw, 40px) min(13.9534883721vw, 60px);
    overflow: hidden;
    background-color: #24243C;
    max-width: 100%;
  }
  #case .swiper-slide {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-orient: inherit;
    -webkit-box-direction: inherit;
        -ms-flex-direction: inherit;
            flex-direction: inherit;
    width: 100%;
    max-width: 100%;
  }
  #case .swiper-slide .slide_image {
    width: 100%;
  }
  #case .swiper-slide .slide_image img {
    width: 100%;
    height: 100%;
    aspect-ratio: inherit;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #case .swiper-slide .slide_info {
    height: auto;
    width: 100%;
    padding: min(6.976744186vw, 30px) min(6.976744186vw, 30px);
    gap: min(4.6511627907vw, 20px);
  }
  #case .swiper-slide .slide_info .slide_top_text .company {
    font-size: min(3.7209302326vw, 16px);
  }
  #case .swiper-slide .slide_info .slide_top_text .scene {
    font-size: min(4.6511627907vw, 20px);
  }
  #case .swiper-slide .slide_info .tag {
    padding: min(4.6511627907vw, 20px) 0 min(2.3255813953vw, 10px);
  }
  #case .swiper-slide .slide_info .tag span {
    font-size: min(2.7906976744vw, 12px);
    padding: min(1.1627906977vw, 5px) 0;
    min-width: min(23.2558139535vw, 100px);
  }
  #case .swiper-slide .slide_info .example {
    font-size: min(3.7209302326vw, 16px);
  }
  #case .swiper-button-prev {
    left: 0;
  }
  #case .swiper-button-next {
    right: 0;
  }
  #case .swiper-pagination {
    margin-top: min(4.6511627907vw, 20px);
    bottom: 0;
  }
  #case .swiper-pagination .swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    margin: 10px;
    z-index: 1;
  }
  #case .swiper-fade-left,
  #case .swiper-fade-right {
    display: none;
  }
}
#feature {
  background-color: #E9E9EB;
  padding: min(10vw, 120px) 0 0;
}
@media (max-width: 768px) {
  #feature {
    padding: min(18.6046511628vw, 80px) 0;
  }
}
#feature .feature_main_title {
  position: sticky;
  top: min(0.8333333333vw, 10px);
  padding-bottom: min(53.0833333333vw, 637px);
}
@media (max-width: 768px) {
  #feature .feature_main_title {
    position: static;
    padding-bottom: min(46.511627907vw, 200px);
  }
}
#feature ol {
  width: 100%;
}
#feature ol .feature_content {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
#feature ol .feature_content .feature_text {
  width: 100%;
  position: sticky;
  top: min(5vw, 60px);
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: 1rem 0;
}
@media (max-width: 768px) {
  #feature ol .feature_content .feature_text {
    width: 100%;
    position: static;
  }
}
#feature ol .feature_content .feature_text .feature_title {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid #24243C;
  margin-bottom: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #feature ol .feature_content .feature_text .feature_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: min(4.6511627907vw, 20px);
    padding-bottom: min(2.3255813953vw, 10px);
  }
}
#feature ol .feature_content .feature_text .feature_title .feature_title-number {
  font-size: min(3.3333333333vw, 40px);
  font-weight: 600;
  margin-right: min(2.5vw, 30px);
}
@media (max-width: 768px) {
  #feature ol .feature_content .feature_text .feature_title .feature_title-number {
    font-size: min(7.9069767442vw, 34px);
  }
}
#feature ol .feature_content .feature_text .feature_title p {
  font-size: min(2vw, 24px);
  font-weight: bold;
}
@media (max-width: 768px) {
  #feature ol .feature_content .feature_text .feature_title p {
    font-size: min(5.5813953488vw, 24px);
  }
}
#feature ol .feature_content .feature_text .feature_title + ul {
  margin-left: min(7.5vw, 90px);
}
@media (max-width: 768px) {
  #feature ol .feature_content .feature_text .feature_title + ul {
    margin-left: min(4.6511627907vw, 20px);
  }
}
#feature ol .feature_content .feature_text .feature_title + ul li {
  font-weight: 700;
  list-style-type: disc;
}
#feature ol .feature_image {
  width: 50%;
  position: relative;
  top: max(-9.3333333333vw, -112px);
}
@media (max-width: 768px) {
  #feature ol .feature_image {
    width: 100%;
    margin-top: min(4.6511627907vw, 20px);
    top: 0;
  }
}
#feature ol .feature_image .feature_image-content {
  position: sticky;
}
@media (max-width: 768px) {
  #feature ol .feature_image .feature_image-content {
    position: relative;
  }
}
#feature ol .feature_image .feature_image-content:not(:first-of-type) {
  margin-top: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #feature ol .feature_image .feature_image-content:not(:first-of-type) {
    margin-top: min(4.6511627907vw, 20px);
  }
}
#feature ol .feature_image .feature_image-content p {
  position: absolute;
  top: 0;
  right: 0;
  background-color: #24243C;
  color: #fdfdfd;
  padding: min(0.4166666667vw, 5px);
  width: min(10.8333333333vw, 130px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: min(1.1666666667vw, 14px);
  font-weight: bold;
}
@media (max-width: 768px) {
  #feature ol .feature_image .feature_image-content p {
    font-size: min(2.7906976744vw, 12px);
    padding: 0 min(1.1627906977vw, 5px);
    width: min(23.2558139535vw, 100px);
  }
}

#feature ol .feature_content.flex {
  position: sticky;
  padding-bottom: min(37.5vw, 450px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex {
    position: static;
  }
}
#feature ol .feature_content.flex:nth-of-type(1) {
  top: max(-56.75vw, -681px);
  z-index: 1;
  padding-bottom: min(35.5vw, 426px);
  margin-top: max(-49.1666666667vw, -590px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(1) {
    padding-bottom: 0;
    margin-top: max(-41.8604651163vw, -180px);
  }
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_text {
  top: min(5.8333333333vw, 70px);
  z-index: 1;
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image {
  margin-bottom: max(-29.1666666667vw, -350px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(1) .feature_image {
    top: 0;
    margin-bottom: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content {
  top: min(15.5833333333vw, 187px);
  z-index: 2;
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content {
    top: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content:nth-of-type(2) {
  z-index: 3;
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content:nth-of-type(3) {
  z-index: 4;
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content:nth-of-type(4) {
  z-index: 5;
}
#feature ol .feature_content.flex:nth-of-type(1) .feature_image .feature_image-content:nth-of-type(5) {
  z-index: 6;
}
#feature ol .feature_content.flex:nth-of-type(2) {
  top: max(-46vw, -552px);
  z-index: 2;
  background-color: #E9E9EB;
  padding-bottom: min(30.6666666667vw, 368px);
  margin-top: max(-8.3333333333vw, -100px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(2) {
    padding-bottom: 0;
    margin-top: min(11.6279069767vw, 50px);
  }
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_text {
  top: min(13.3333333333vw, 160px) !important;
  z-index: 20;
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image {
  top: max(-6.6666666667vw, -80px);
  margin-bottom: max(-16.6666666667vw, -200px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(2) .feature_image {
    top: 0;
    margin-bottom: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content {
  top: min(23.0833333333vw, 277px);
  z-index: 21;
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content {
    top: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content:nth-of-type(2) {
  z-index: 22;
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content:nth-of-type(3) {
  z-index: 23;
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content:nth-of-type(4) {
  z-index: 24;
}
#feature ol .feature_content.flex:nth-of-type(2) .feature_image .feature_image-content:nth-of-type(5) {
  z-index: 25;
}
#feature ol .feature_content.flex:nth-of-type(3) {
  top: max(-38.3333333333vw, -460px);
  z-index: 3;
  background-color: #E9E9EB;
  padding-bottom: min(20.8333333333vw, 250px);
  margin-top: max(-14.1666666667vw, -170px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(3) {
    margin-top: min(11.6279069767vw, 50px);
    padding-bottom: min(6.976744186vw, 30px);
  }
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_text {
  top: min(20.8333333333vw, 250px) !important;
  z-index: 30;
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_image {
  top: max(-9.3333333333vw, -112px);
  margin-bottom: max(-16.6666666667vw, -200px);
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(3) .feature_image {
    top: 0;
    margin-bottom: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_image .feature_image-content {
  top: min(30.5vw, 366px);
  z-index: 31;
}
@media (max-width: 768px) {
  #feature ol .feature_content.flex:nth-of-type(3) .feature_image .feature_image-content {
    top: 0;
  }
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_image .feature_image-content:nth-of-type(2) {
  z-index: 32;
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_image .feature_image-content:nth-of-type(3) {
  z-index: 33;
}
#feature ol .feature_content.flex:nth-of-type(3) .feature_image .feature_image-content:nth-of-type(4) {
  z-index: 34;
}

@-webkit-keyframes bubble-stroke {
  0% {
    opacity: 0;
  }
  1% {
    opacity: 1;
  }
  100% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
}

@keyframes bubble-stroke {
  0% {
    opacity: 0;
  }
  1% {
    opacity: 1;
  }
  100% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
}
@-webkit-keyframes system_line-01-dotted-move {
  0% {
    opacity: 0;
    left: 0;
  }
  1% {
    opacity: 1;
    left: 0;
  }
  9% {
    opacity: 1;
    left: 100%;
  }
  10% {
    opacity: 0;
    left: 100%;
  }
  50% {
    opacity: 0;
    left: 100%;
  }
  51% {
    opacity: 1;
    left: 100%;
  }
  59% {
    opacity: 1;
    left: 0%;
  }
  60% {
    opacity: 0;
    left: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
  }
}
@keyframes system_line-01-dotted-move {
  0% {
    opacity: 0;
    left: 0;
  }
  1% {
    opacity: 1;
    left: 0;
  }
  9% {
    opacity: 1;
    left: 100%;
  }
  10% {
    opacity: 0;
    left: 100%;
  }
  50% {
    opacity: 0;
    left: 100%;
  }
  51% {
    opacity: 1;
    left: 100%;
  }
  59% {
    opacity: 1;
    left: 0%;
  }
  60% {
    opacity: 0;
    left: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
  }
}
@-webkit-keyframes system_line-02-solid-move {
  0% {
    opacity: 0;
    left: 0;
  }
  10% {
    opacity: 0;
    left: 0;
  }
  11% {
    opacity: 1;
    left: 0;
  }
  19% {
    opacity: 1;
    left: 100%;
  }
  20% {
    opacity: 0;
    left: 100%;
  }
  40% {
    opacity: 0;
    left: 100%;
  }
  41% {
    opacity: 1;
    left: 100%;
  }
  49% {
    opacity: 1;
    left: 0%;
  }
  50% {
    opacity: 0;
    left: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
  }
}
@keyframes system_line-02-solid-move {
  0% {
    opacity: 0;
    left: 0;
  }
  10% {
    opacity: 0;
    left: 0;
  }
  11% {
    opacity: 1;
    left: 0;
  }
  19% {
    opacity: 1;
    left: 100%;
  }
  20% {
    opacity: 0;
    left: 100%;
  }
  40% {
    opacity: 0;
    left: 100%;
  }
  41% {
    opacity: 1;
    left: 100%;
  }
  49% {
    opacity: 1;
    left: 0%;
  }
  50% {
    opacity: 0;
    left: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
  }
}
@-webkit-keyframes system_line-01-dotted-move-sp {
  0% {
    opacity: 0;
    left: 0;
  }
  1% {
    opacity: 1;
    left: 0;
    top: 0;
  }
  6% {
    top: 105%;
    left: 0;
  }
  9% {
    opacity: 1;
    left: 100%;
    top: 105%;
  }
  10% {
    opacity: 0;
    left: 100%;
    top: 105%;
  }
  50% {
    opacity: 0;
    left: 100%;
    top: 105%;
  }
  51% {
    opacity: 1;
    left: 100%;
    top: 105%;
  }
  54% {
    opacity: 1;
    left: 0%;
    top: 105%;
  }
  59% {
    opacity: 1;
    left: 0%;
    top: 0%;
  }
  60% {
    opacity: 0;
    left: 0%;
    top: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
    top: 0%;
  }
}
@keyframes system_line-01-dotted-move-sp {
  0% {
    opacity: 0;
    left: 0;
  }
  1% {
    opacity: 1;
    left: 0;
    top: 0;
  }
  6% {
    top: 105%;
    left: 0;
  }
  9% {
    opacity: 1;
    left: 100%;
    top: 105%;
  }
  10% {
    opacity: 0;
    left: 100%;
    top: 105%;
  }
  50% {
    opacity: 0;
    left: 100%;
    top: 105%;
  }
  51% {
    opacity: 1;
    left: 100%;
    top: 105%;
  }
  54% {
    opacity: 1;
    left: 0%;
    top: 105%;
  }
  59% {
    opacity: 1;
    left: 0%;
    top: 0%;
  }
  60% {
    opacity: 0;
    left: 0%;
    top: 0%;
  }
  100% {
    opacity: 0;
    left: 0%;
    top: 0%;
  }
}
@-webkit-keyframes system_line-02-solid-move-sp {
  0% {
    opacity: 0;
    left: 0;
    top: 90%;
  }
  10% {
    opacity: 0;
    left: 0;
    top: 90%;
  }
  11% {
    opacity: 1;
    left: 0;
    top: 90%;
  }
  14% {
    opacity: 1;
    left: 95%;
    top: 90%;
  }
  19% {
    opacity: 1;
    left: 95%;
    top: 0%;
  }
  20% {
    opacity: 0;
    left: 95%;
    top: 0%;
  }
  40% {
    opacity: 0;
    left: 95%;
    top: 0%;
  }
  41% {
    opacity: 1;
    left: 95%;
    top: 0%;
  }
  46% {
    opacity: 1;
    left: 95%;
    top: 90%;
  }
  49% {
    opacity: 1;
    left: 0%;
    top: 90%;
  }
  50% {
    opacity: 0;
    left: 0%;
    top: 90%;
  }
  100% {
    opacity: 0;
    left: 0%;
    top: 90%;
  }
}
@keyframes system_line-02-solid-move-sp {
  0% {
    opacity: 0;
    left: 0;
    top: 90%;
  }
  10% {
    opacity: 0;
    left: 0;
    top: 90%;
  }
  11% {
    opacity: 1;
    left: 0;
    top: 90%;
  }
  14% {
    opacity: 1;
    left: 95%;
    top: 90%;
  }
  19% {
    opacity: 1;
    left: 95%;
    top: 0%;
  }
  20% {
    opacity: 0;
    left: 95%;
    top: 0%;
  }
  40% {
    opacity: 0;
    left: 95%;
    top: 0%;
  }
  41% {
    opacity: 1;
    left: 95%;
    top: 0%;
  }
  46% {
    opacity: 1;
    left: 95%;
    top: 90%;
  }
  49% {
    opacity: 1;
    left: 0%;
    top: 90%;
  }
  50% {
    opacity: 0;
    left: 0%;
    top: 90%;
  }
  100% {
    opacity: 0;
    left: 0%;
    top: 90%;
  }
}
main.is-visible #system .illustration .system_illust-01-bubble_wrap .system_illust-01-bubble-path {
  opacity: 0;
}
main.is-visible #system .illustration .system_illust-01-bubble_wrap p {
  opacity: 0;
}
main.is-visible #system .illustration .system_line-01-dotted {
  position: relative;
}
@media (max-width: 768px) {
  main.is-visible #system .illustration .system_line-01-dotted {
    height: min(20vw, 86px);
  }
}
main.is-visible #system .illustration .system_line-01-dotted::before {
  left: 0;
  top: 10px;
}
main.is-visible #system .illustration .system_line-02-solid {
  position: relative;
}
main.is-visible #system .illustration .system_line-02-solid::before {
  left: 0;
  top: 10px;
}
main.is-visible #system .illustration .system_line-02-dotted {
  position: relative;
}
main.is-visible #system .illustration .system_line-02-dotted::before {
  left: 0;
  top: 10px;
}
main.is-visible #system .illustration.is-visible .system_illust-01-bubble_wrap .system_illust-01-bubble-path {
  -webkit-animation: bubble-stroke 0s both 0s;
          animation: bubble-stroke 0s both 0s;
  stroke-dasharray: 940;
  stroke-dashoffset: 940;
}
main.is-visible #system .illustration.is-visible .system_illust-01-bubble_wrap p {
  opacity: 1;
}

#system {
  margin-top: min(13.3333333333vw, 160px);
}
@media (max-width: 768px) {
  #system {
    margin-top: min(18.6046511628vw, 80px);
  }
}
#system .heading + p {
  font-weight: 700;
  margin-top: min(5vw, 60px);
}
#system .illustration {
  margin-top: min(4.1666666667vw, 50px);
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  line-height: 1.5;
  text-align: center;
  position: relative;
  font-weight: 600;
}
@media (max-width: 768px) {
  #system .illustration p {
    position: absolute;
  }
}
@media (max-width: 768px) {
  #system .illustration {
    -webkit-box-pack: unset;
        -ms-flex-pack: unset;
            justify-content: unset;
    margin-top: min(9.3023255814vw, 40px);
    position: relative;
    height: min(93.023255814vw, 400px);
    font-size: min(2.7906976744vw, 12px);
  }
}
@media (max-width: 768px) {
  #system .illustration .system_illust {
    position: absolute;
  }
}
#system .illustration .system_illust.system_illust-01 .about_system_image {
  width: min(96.6666666667vw, 1160px);
}
#system .illustration .system_illust.system_illust-01 .system_illust-01-bubble_wrap {
  width: min(20.8333333333vw, 250px);
  text-align: center;
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-01 .system_illust-01-bubble_wrap {
    width: min(38.3720930233vw, 165px);
    left: min(0vw, 0px);
  }
}
#system .illustration .system_illust.system_illust-01 .system_illust-01-bubble_wrap .system_illust-01-bubble {
  width: min(20.8333333333vw, 250px);
  fill: transparent;
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-01 .system_illust-01-bubble_wrap .system_illust-01-bubble {
    width: min(38.3720930233vw, 165px);
  }
}
#system .illustration .system_illust.system_illust-01 .system_illust-01-bubble_wrap p {
  position: absolute;
  top: min(2.0833333333vw, 25px);
  left: min(1.6666666667vw, 20px);
}
#system .illustration .system_illust.system_illust-01 .system_illust-tool {
  width: min(28.0833333333vw, 337px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-01 .system_illust-tool {
    width: min(40.9302325581vw, 176px);
    margin-top: min(16.2790697674vw, 70px);
    margin-left: min(2.3255813953vw, 10px);
  }
}
#system .illustration .system_illust.system_illust-02 {
  position: absolute;
  top: min(22.5vw, 270px);
  left: min(50vw, 600px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-02 {
    margin-top: min(0vw, 0px);
    top: min(79.0697674419vw, 340px);
    left: min(34.8837209302vw, 150px);
  }
}
#system .illustration .system_illust.system_illust-02 .system_illust-router {
  width: min(12.5vw, 150px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-02 .system_illust-router {
    width: min(18.6046511628vw, 80px);
  }
}
#system .illustration .system_illust.system_illust-02 p {
  margin-top: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-02 p {
    width: min(27.9069767442vw, 120px);
    left: min(-4.6511627907vw, -20px);
  }
}
#system .illustration .system_illust.system_illust-03 {
  position: absolute;
  top: min(24.1666666667vw, 290px);
  left: min(83.3333333333vw, 1000px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-03 {
    margin-top: min(0vw, 0px);
    top: min(44.1860465116vw, 190px);
    left: min(54.6511627907vw, 235px);
  }
}
#system .illustration .system_illust.system_illust-03 .system_illust-pc {
  width: min(11.4166666667vw, 137px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-03 .system_illust-pc {
    width: min(16.7441860465vw, 72px);
  }
}
#system .illustration .system_illust.system_illust-03 p {
  margin-top: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #system .illustration .system_illust.system_illust-03 p {
    width: min(27.9069767442vw, 120px);
  }
}
#system .illustration .system_line {
  width: min(12.5vw, 150px);
}
@media (max-width: 768px) {
  #system .illustration .system_line {
    margin-top: min(0vw, 0px);
  }
}
#system .illustration .system_line.system_line-01 {
  position: absolute;
  top: min(17.5vw, 210px);
  left: min(34.1666666667vw, 410px);
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-01 {
    top: min(62.7906976744vw, 270px);
    left: min(9.3023255814vw, 40px);
  }
}
#system .illustration .system_line.system_line-01 .system_line-01-dotted::before {
  content: "";
  display: inline-block;
  border-bottom: 5px dashed #24243C;
  width: 100%;
  position: absolute;
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-01 .system_line-01-dotted::before {
    width: min(15.5813953488vw, 67px);
    height: min(20vw, 86px);
    border-left: 5px dashed #24243C;
    border-bottom: 5px dashed #24243C;
  }
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 {
    top: min(58.1395348837vw, 250px);
    left: min(58.1395348837vw, 250px);
  }
}
#system .illustration .system_line.system_line-02 p:nth-of-type(1) {
  position: absolute;
  top: min(16.6666666667vw, 200px);
  left: min(71.6666666667vw, 860px);
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 p:nth-of-type(1) {
    top: min(62.7906976744vw, 270px);
    left: min(60.4651162791vw, 260px);
  }
}
#system .illustration .system_line.system_line-02 p:nth-of-type(2) {
  position: absolute;
  top: min(22.5vw, 270px);
  left: min(71.6666666667vw, 860px);
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 p:nth-of-type(2) {
    top: min(62.7906976744vw, 270px);
    left: min(74.4186046512vw, 320px);
    width: min(6.976744186vw, 30px);
  }
}
#system .illustration .system_line.system_line-02 .system_line_border {
  line-height: 1;
  position: relative;
}
#system .illustration .system_line.system_line-02 .system_line_border::before {
  content: "";
  display: inline-block;
  border-bottom: 5px solid #24243C;
  width: 100%;
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 .system_line_border::before {
    width: min(12.7906976744vw, 55px);
    height: min(17.4418604651vw, 75px);
    border-right: 5px solid #24243C;
    border-bottom: 5px solid #24243C;
  }
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 .system_line-02-dotted {
    position: absolute;
    top: min(0vw, 0px);
    left: min(0vw, 0px);
  }
}
#system .illustration .system_line.system_line-02 .system_line-02-dotted::before {
  border-bottom: 5px dotted #24243C;
}
@media (max-width: 768px) {
  #system .illustration .system_line.system_line-02 .system_line-02-dotted::before {
    width: min(15.1162790698vw, 65px);
    height: min(19.7674418605vw, 85px);
    border-right: 5px dotted #24243C;
    border-bottom: 5px dotted #24243C;
  }
}
#system .illustration .system_line.system_line-02 .system_line-02-dotted + p {
  margin-top: min(0.8333333333vw, 10px);
}

#plans {
  margin-top: min(13.3333333333vw, 160px);
}
#plans .plan_wrap {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#plans .plan_wrap .plan {
  width: min(46.6666666667vw, 560px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan {
    width: 100%;
    margin-top: min(9.3023255814vw, 40px);
  }
}
#plans .plan_wrap .plan .plan_content_sensing img {
  width: min(10vw, 120px);
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content_sensing img {
    width: min(19.5348837209vw, 84px);
  }
}
#plans .plan_wrap .plan .plan_content_ai img {
  width: min(10vw, 120px);
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content_ai img {
    width: min(19.5348837209vw, 84px);
  }
}
#plans .plan_wrap .plan .face {
  width: min(16.6666666667vw, 200px);
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .face {
    width: min(32.5581395349vw, 140px);
  }
}
#plans .plan_wrap .plan .plan_target {
  font-size: min(2.3333333333vw, 28px);
  font-weight: bold;
  color: #24243C;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_target {
    font-size: min(5.5813953488vw, 24px);
  }
}
#plans .plan_wrap .plan .comment {
  font-weight: 700;
}
#plans .plan_wrap .plan .plan_content {
  margin-top: min(0.8333333333vw, 10px);
  border: 1px solid #25BFE3;
  width: 100%;
  position: relative;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content {
    margin-top: min(2.3255813953vw, 10px);
  }
}
#plans .plan_wrap .plan .plan_content .plan_content-title {
  font-size: min(2.3333333333vw, 28px);
  color: #fdfdfd;
  background-color: #25BFE3;
  padding: min(0.4166666667vw, 5px) 0;
  text-align: center;
  font-weight: bold;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content .plan_content-title {
    font-size: min(5.5813953488vw, 24px);
  }
}
#plans .plan_wrap .plan .plan_content .flex {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: min(15.8333333333vw, 190px);
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content .flex {
    height: 150px;
    padding: min(6.976744186vw, 30px) 0;
  }
}
#plans .plan_wrap .plan .plan_content .flex .plan_img_inner {
  width: 40%;
  margin-left: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content .flex .plan_img_inner {
    margin-left: 0;
  }
}
#plans .plan_wrap .plan .plan_content .flex p {
  width: 60%;
  font-size: min(1.8333333333vw, 22px);
  font-weight: bold;
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content .flex p {
    font-size: min(3.7209302326vw, 16px);
  }
}
#plans .plan_wrap .plan .plan_content .soon {
  position: absolute;
  top: min(1.6666666667vw, 20px);
  right: min(0.8333333333vw, 10px);
  text-align: center;
  width: min(8.3333333333vw, 100px);
  height: min(8.3333333333vw, 100px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1.2;
  font-weight: 500;
  background-color: #D9E021;
  border-radius: 50%;
  font-size: min(1.5vw, 18px);
}
@media (max-width: 768px) {
  #plans .plan_wrap .plan .plan_content .soon {
    font-size: min(2.7906976744vw, 12px);
    width: min(13.9534883721vw, 60px);
    height: min(13.9534883721vw, 60px);
  }
}
#plans .heading {
  margin-bottom: 40px;
}
@media (max-width: 768px) {
  #plans .heading {
    margin-bottom: 0;
  }
}

@-webkit-keyframes flow_animation {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  1% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
    opacity: 1;
  }
  100% {
    opacity: 1;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

@keyframes flow_animation {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  1% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
    opacity: 1;
  }
  100% {
    opacity: 1;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}
@-webkit-keyframes flow_animation_01 {
  0% {
    clip-path: polygon(0 0, 0% 0, 0% 50%, 0% 100%, 0 100%, 0% 50%);
    opacity: 0;
  }
  100% {
    clip-path: polygon(0 0, 95% 0, 100% 50%, 95% 100%, 0 100%, 0% 50%);
    opacity: 1;
  }
}
@keyframes flow_animation_01 {
  0% {
    clip-path: polygon(0 0, 0% 0, 0% 50%, 0% 100%, 0 100%, 0% 50%);
    opacity: 0;
  }
  100% {
    clip-path: polygon(0 0, 95% 0, 100% 50%, 95% 100%, 0 100%, 0% 50%);
    opacity: 1;
  }
}
#flow {
  margin-top: min(13.3333333333vw, 160px);
}
@media (max-width: 768px) {
  #flow {
    margin-top: min(18.6046511628vw, 80px);
  }
}
#flow .flow-chart {
  margin-top: min(5vw, 60px);
}
@media (max-width: 768px) {
  #flow .flow-chart {
    margin-top: min(9.3023255814vw, 40px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#flow .flow-chart .chart {
  width: min(19.3333333333vw, 232px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  clip-path: polygon(0 0, 95% 0, 100% 50%, 95% 100%, 0 100%, 5% 50%);
  padding: min(2.5vw, 30px) 0 min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    width: 100%;
    clip-path: polygon(0 0, 50% 20%, 100% 0, 100% 80%, 50% 100%, 0 80%);
    padding: min(6.976744186vw, 30px) min(4.6511627907vw, 20px);
  }
}
@media (max-width: 768px) {
  #flow .flow-chart .chart:not(:first-of-type) {
    margin-top: max(-3.488372093vw, -15px);
    padding-top: min(9.3023255814vw, 40px);
  }
}
#flow .flow-chart .chart::before {
  content: "";
  display: inline-block;
  width: min(7.5vw, 90px);
  height: min(6vw, 72px);
  background-repeat: no-repeat;
  background-position: center center;
}
@media (max-width: 768px) {
  #flow .flow-chart .chart::before {
    width: min(13.9534883721vw, 60px);
    height: min(11.1627906977vw, 48px);
    margin-left: min(11.6279069767vw, 50px);
  }
}
#flow .flow-chart .chart.chart01 {
  background-color: #E9F9FC;
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart01 {
    width: 100%;
    clip-path: polygon(0 0, 50% 0%, 100% 0, 100% 80%, 50% 100%, 0 80%);
  }
}
#flow .flow-chart .chart.chart01::before {
  background-image: url(../../assets/img/icn_chart_01.svg);
  background-size: min(4.9166666667vw, 59px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart01::before {
    background-size: min(9.0697674419vw, 39px);
  }
}
#flow .flow-chart .chart.chart02 {
  background-color: #C8EFF8;
}
#flow .flow-chart .chart.chart02::before {
  background-image: url(../../assets/img/icn_chart_02.svg);
  background-size: min(5.8333333333vw, 70px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart02::before {
    background-size: min(10.6976744186vw, 46px);
  }
}
#flow .flow-chart .chart.chart03 {
  background-color: #92DFF1;
}
#flow .flow-chart .chart.chart03::before {
  background-image: url(../../assets/img/icn_chart_03.svg);
  background-size: min(5.5vw, 66px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart03::before {
    background-size: min(10.4651162791vw, 45px);
  }
}
#flow .flow-chart .chart.chart04 {
  background-color: #5CCFEA;
}
#flow .flow-chart .chart.chart04::before {
  background-image: url(../../assets/img/icn_chart_04.svg);
  background-size: min(7.5vw, 90px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart04::before {
    background-size: min(13.9534883721vw, 60px);
  }
}
#flow .flow-chart .chart.chart05 {
  background-color: #25BFE3;
}
#flow .flow-chart .chart.chart05::before {
  background-image: url(../../assets/img/icn_chart_05.svg);
  background-size: min(5.8333333333vw, 70px);
}
@media (max-width: 768px) {
  #flow .flow-chart .chart.chart05::before {
    background-size: min(11.1627906977vw, 48px);
  }
}
#flow .flow-chart .chart p {
  font-weight: bold;
  line-height: 1.5;
  margin-top: min(1.6666666667vw, 20px);
  height: min(4.1666666667vw, 50px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  #flow .flow-chart .chart p {
    margin-top: min(0vw, 0px);
    margin-left: min(4.6511627907vw, 20px);
  }
}
#flow .price {
  margin-top: min(5vw, 60px);
}
@media (max-width: 768px) {
  #flow .price {
    margin-top: min(6.976744186vw, 30px);
  }
}
#flow .price .price_wrap {
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (max-width: 768px) {
  #flow .price .price_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: min(12.5581395349vw, 54px);
  }
}
#flow .price .price_wrap .price_inner .price-title {
  color: #24243C;
  width: min(20.8333333333vw, 250px);
  border-top: 1px solid #24243C;
  border-bottom: 1px solid #24243C;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
}
@media (max-width: 768px) {
  #flow .price .price_wrap .price_inner .price-title {
    width: 100%;
    padding: min(2.3255813953vw, 10px) 0;
  }
}
#flow .price .price_wrap .price_inner .price_plan {
  width: min(24.1666666667vw, 290px);
  border-top: 1px solid #24243C;
  border-bottom: 1px solid #24243C;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  font-weight: bold;
  padding: min(0.4166666667vw, 5px) 0;
  position: relative;
}
#flow .price .price_wrap .price_inner .price_plan::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 1px;
  top: min(0.8333333333vw, 10px);
  left: 0;
  bottom: min(0.8333333333vw, 10px);
  background-color: #24243C;
}
@media (max-width: 768px) {
  #flow .price .price_wrap .price_inner .price_plan::before {
    display: none;
  }
}
@media (max-width: 768px) {
  #flow .price .price_wrap .price_inner .price_plan {
    width: 100%;
    padding: min(2.3255813953vw, 10px) 0;
    border-top: none;
  }
}
#flow .price .price_wrap .price_inner .price_plan p {
  font-size: min(2vw, 24px);
}
@media (max-width: 768px) {
  #flow .price .price_wrap .price_inner .price_plan p {
    font-size: min(5.5813953488vw, 24px);
  }
}
#flow .price .price_wrap .price_inner .price_plan .day {
  font-size: min(1.3333333333vw, 16px);
}
@media (max-width: 768px) {
  #flow .price .price_wrap .price_inner .price_plan .day {
    font-size: min(3.7209302326vw, 16px);
  }
}
#flow .price .apply {
  position: relative;
}
#flow .price .apply .btn {
  width: min(23.75vw, 285px);
}
@media (max-width: 768px) {
  #flow .price .apply .btn {
    width: 100%;
  }
}
#flow .price .apply p {
  position: absolute;
  bottom: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-size: min(1.3333333333vw, 16px);
  color: #24243C;
  white-space: nowrap;
  font-weight: 600;
}
@media (max-width: 768px) {
  #flow .price .apply p {
    font-size: min(3.7209302326vw, 16px);
    bottom: 120%;
  }
}

#spec {
  margin-top: min(13.3333333333vw, 160px);
}
@media (max-width: 768px) {
  #spec {
    margin-top: min(18.6046511628vw, 80px);
  }
}
#spec .spec_content {
  margin-top: min(1.6666666667vw, 20px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  #spec .spec_content {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
#spec .spec_content img {
  width: min(37vw, 444px);
}
@media (max-width: 768px) {
  #spec .spec_content img {
    width: min(63.9534883721vw, 275px);
    margin: 0 auto;
  }
}
#spec .spec_content dl {
  font-weight: 700;
  margin-left: min(6.6666666667vw, 80px);
}
@media (max-width: 768px) {
  #spec .spec_content dl {
    margin-top: min(4.6511627907vw, 20px);
    margin-left: min(0vw, 0px);
    width: 100%;
  }
}
#spec .spec_content dl dt {
  font-size: min(2vw, 24px);
  font-weight: bold;
  margin-bottom: min(1.6666666667vw, 20px);
}
@media (max-width: 768px) {
  #spec .spec_content dl dt {
    font-size: min(5.5813953488vw, 24px);
    margin-bottom: min(4.6511627907vw, 20px);
  }
}
#spec .spec_content dl dd {
  font-size: min(1.1666666667vw, 14px);
  display: grid;
  grid-template-columns: 1fr 2fr;
}
@media (max-width: 768px) {
  #spec .spec_content dl dd {
    font-size: min(3.2558139535vw, 14px);
    gap: min(4.6511627907vw, 20px);
  }
}
#spec .spec_content dl dd .spec_heading {
  font-weight: 700;
}
#spec .spec_content dl dd:not(:first-of-type) {
  border-top: 1px solid #24243C;
}
#spec .spec_content dl .annotation {
  font-size: min(1.1666666667vw, 14px);
  margin-top: min(0.6666666667vw, 8px);
}

#conversion {
  background-color: #24243C;
  margin-top: min(8.3333333333vw, 100px);
  padding: min(8.3333333333vw, 100px) 0 min(11.6666666667vw, 140px);
}
@media (max-width: 768px) {
  #conversion {
    margin-top: min(18.6046511628vw, 80px);
  }
}
#conversion p {
  font-weight: bold;
  font-size: min(3.3333333333vw, 40px);
  color: #fdfdfd;
  text-align: center;
}
@media (max-width: 768px) {
  #conversion p {
    font-size: min(8.3720930233vw, 36px);
    line-height: 1.5;
  }
}
#conversion .btn_wrap {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: min(1.6666666667vw, 20px);
  margin-top: min(3.3333333333vw, 40px);
}
#conversion .btn_wrap .btn {
  width: calc(33.3333333333% - min(1.6666666667vw, 20px));
}
@media (max-width: 768px) {
  #conversion .btn_wrap .btn {
    width: 100%;
  }
}
#conversion .btn_wrap .contact {
  background-color: #fdfdfd;
  color: #24243C;
}

@media (max-width: 768px) {
  .container {
    padding: 0 2rem;
  }
}
#floating {
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 90;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
#floating .btn_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#floating .btn_wrap .btn {
  width: 50%;
}
#floating.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.btn_wrap .btn {
  width: calc(50% - min(1.6666666667vw, 20px) / 2);
}
@media (max-width: 768px) {
  .btn_wrap .btn {
    width: 50%;
  }
}

/*----------------
	SNS
-----------------*/
#sns {
  padding: 45px 0 55px;
  background: #fff;
}
#sns a {
  color: #24243C;
}
#sns .sns_title {
  font-size: 36px;
  font-weight: bold;
  line-height: 1;
  color: #24243C;
  text-align: center;
  margin-bottom: 25px;
}
#sns ul {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#sns ul li {
  width: 32%;
  background: #fff;
  border-radius: 10px;
  padding: 15px 15px 12px;
  -webkit-box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
}
#sns ul li .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#sns ul li .icon {
  width: 22%;
  padding-right: 10px;
}
#sns ul li .description {
  width: 78%;
}
#sns ul li .description .title {
  font-size: 16px;
  margin-bottom: 8px;
  margin-top: 5px;
}
#sns ul li .description .detail {
  font-size: 13.6px;
  line-height: 1.5;
}

@media print, screen and (max-width: 1440px) {
  #sns {
    padding: 45px 0 30px;
  }
  #sns .sns_title {
    margin-bottom: 35px;
  }
  #sns ul {
    display: block;
  }
  #sns ul li {
    width: 60%;
    margin: 0 auto 25px;
    padding: 25px 25px 20px;
  }
  #sns ul li .icon {
    padding-right: 20px;
  }
}
@media print, screen and (max-width: 960px) {
  #sns {
    padding: 6vw 0 3vw;
  }
  #sns .sns_title {
    font-size: 4vw;
    margin-bottom: 4vw;
  }
  #sns ul li {
    width: 80%;
    margin: 0 auto 3vw;
    padding: 3vw;
  }
  #sns ul li .icon {
    width: 16%;
    padding-right: 2vw;
  }
  #sns ul li .description {
    width: 84%;
  }
  #sns ul li .description .title {
    font-size: 2.2vw;
    margin-bottom: 1vw;
    margin-top: 0.5vw;
  }
  #sns ul li .description .detail {
    font-size: 1.9vw;
  }
}
@media print, screen and (max-width: 640px) {
  #sns {
    padding: 18vw 0 12vw;
  }
  #sns .sns_title {
    font-size: 6vw;
    margin-bottom: 8vw;
  }
  #sns ul li {
    width: 100%;
    padding: 4vw 4vw 3.5vw;
    margin-bottom: 5vw;
  }
  #sns ul li .flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  #sns ul li .icon {
    width: 22%;
    padding-right: 3vw;
  }
  #sns ul li .description {
    width: 78%;
  }
  #sns ul li .description .title {
    font-size: 4vw;
    margin-bottom: 2vw;
    margin-top: 1.5vw;
  }
  #sns ul li .description .detail {
    font-size: 3.5vw;
  }
}
@media print, screen and (min-width: 961px) {
  #st-GlobalNav {
    mix-blend-mode: initial;
  }
  #st-GlobalNav a {
    color: #000;
    -webkit-transition: 0s;
    transition: 0s;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active1 {
    color: #fff;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a:hover .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active {
    color: var(--color-blue);
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active2 {
    color: #fff;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a.active2:hover,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a.active2:hover .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active.active2 .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active.active2 .mark,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List .active.active2 {
    color: #fff;
  }
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a.active2:hover,
  #st-GlobalNav .st-GlobalSiteNav .st-GlobalSiteNav_List a.active2:hover .mark {
    opacity: 0.7;
  }
}
.st-Icon-Internal:before {
  font-size: 1.25rem;
  line-height: 0;
  padding-left: 5px;
}

@media print, screen and (max-width: 460px) {
  .st-Icon-Internal:before {
    font-size: 4.5vw;
    line-height: 0;
    padding-left: 5px;
  }
}
.highlight {
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.5em; /* 線の太さ */
  text-decoration-color: #D9E021; /* 線の色 */
  text-underline-offset: -0.3em; /* 線の位置。テキストに重なるようにやや上部にする */
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}

.opacity-zero {
  opacity: 0;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
}

.transparent-bg {
  background-color: transparent !important;
}

.st-GlobalFooter_PageTop {
  z-index: 100;
}/*# sourceMappingURL=style.css.map */