/* CSS Document */
.spmask {
  display: inline-block;
}

.spmask-inline {
  display: inline;
}

.sponly {
  display: none;
}

@media (max-width: 767px) {
  .spmask {
    display: none;
  }
  .spmask-inline {
    display: none;
  }
  .sponly {
    display: block;
  }
}
/*------------------------------*/
.sectionHd {
  display: flex;
  align-items: flex-end;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
}
@media screen and (max-width: 767px) {
  .sectionHd {
    flex-direction: column;
    align-items: flex-start;
  }
}
.sectionHd p.en {
  font-size: 16rem;
  font-family: "Oswald";
  line-height: 1;
  margin-block: -0.05em;
}
.sectionHd p.en::first-letter {
  color: var(--main);
}
@media screen and (max-width: 767px) {
  .sectionHd p.en {
    font-size: 8rem;
  }
}
.sectionHd h2.ja {
  font-size: 1.8rem;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .sectionHd h2.ja {
    margin-top: 2rem;
    font-size: 1.6rem;
  }
}

/*------------------------------*/
.mv {
  position: relative;
  width: 100%;
  height: calc(100lvh + 16rem);
  max-height: calc(820px + 16rem);
  min-height: calc(620px + 16rem);
  padding-bottom: 16rem;
  overflow: hidden;
  --w: 16;
  --x: 16;
  --y: 8.2;
}
@media screen and (max-width: 767px) {
  .mv {
    height: 100svh;
    max-height: none;
    min-height: none;
    padding-block: 0 8rem;
    --w: 7;
  }
}
.mv .copy {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  max-width: 88rem;
  height: 100%;
  padding-top: 8rem;
  margin-inline: auto;
  row-gap: 3rem;
}
@media screen and (max-width: 767px) {
  .mv .copy {
    padding-top: 0;
    padding-bottom: 10rem;
    row-gap: 1.5rem;
  }
}
.mv .copy p {
  display: inline-block;
}
.mv .copy p:first-child {
  align-self: flex-start;
}
@media screen and (max-width: 767px) {
  .mv .copy p:first-child {
    margin-left: 1rem;
  }
  .mv .copy p:first-child span {
    padding-left: 0.6rem;
  }
}
.mv .copy p:last-child {
  align-self: flex-end;
}
@media screen and (max-width: 767px) {
  .mv .copy p:last-child {
    margin-right: 1rem;
  }
}
.mv .copy p span {
  font-size: clamp(6.8rem, 68vw / var(--w), 68px);
  font-weight: 600;
  font-style: italic;
  font-family: "Noto sans JP";
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
  padding: 1.4rem 1.2rem 1.6rem;
  background-color: #fff;
  line-height: 1;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .mv .copy p span {
    font-size: 3.8rem;
    white-space: nowrap;
    padding: 1rem 1rem 1.4rem;
    letter-spacing: 0.05em;
    font-weight: 700;
  }
}
.mv .container {
  position: absolute;
  z-index: 1;
  inset: 4rem 0 16rem 0;
}
@media screen and (max-width: 767px) {
  .mv .container {
    inset: 7rem 0 2rem;
  }
}
.mv .container .item {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .mv .container .item {
    z-index: 1;
  }
}
.mv .container .item img {
  pointer-events: none;
}
.mv .container .item.en {
  overflow: hidden;
}
.mv .container .item.en p {
  font-size: min(260vw / var(--w), 260px);
  color: #272a33;
  font-family: "Oswald";
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .mv .container .item.en p {
    font-weight: 500;
  }
}
.mv .container .item.en.en01 {
  right: 2rem;
  bottom: 0;
  margin-right: -0.05em;
}
@media screen and (max-width: 767px) {
  .mv .container .item.en.en01 {
    right: 1rem;
    left: 1rem;
    bottom: 10%;
  }
  .mv .container .item.en.en01 p {
    font-size: 7.4rem;
    font-weight: 500;
    letter-spacing: -0.02em;
  }
}
.mv .container .item.en.en02 {
  left: 2rem;
  top: calc(46% / var(--y));
  margin-left: -0.05em;
}
@media screen and (max-width: 767px) {
  .mv .container .item.en.en02 {
    left: 1rem;
    right: 1rem;
    top: auto;
    bottom: calc(10% + 7rem);
    z-index: 10;
  }
  .mv .container .item.en.en02 p {
    font-size: 8.3rem;
    letter-spacing: 0.018em;
  }
}
.mv .container .item.cloud.cloud01 {
  width: calc(508% / var(--w));
  left: calc(1191% / var(--x));
  top: calc(580% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.cloud.cloud01 {
    top: 60%;
    left: -5%;
    width: 50%;
  }
}
.mv .container .item.cloud.cloud02 {
  width: calc(430% / var(--w));
  left: calc(116% / var(--x) * -1);
  bottom: calc(70% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.cloud.cloud02 {
    width: 50%;
    left: -20%;
    bottom: 65%;
  }
}
.mv .container .item.cloud.cloud03 {
  width: calc(310% / var(--w));
  left: calc(114% / var(--x));
  top: calc(194% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.cloud.cloud03 {
    left: 45%;
    top: 8%;
    width: 33%;
  }
}
.mv .container .item.cloud.cloud04 {
  width: calc(235% / var(--w));
  left: calc(1443% / var(--x));
  top: calc(60% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.cloud.cloud04 {
    display: none;
  }
}
.mv .container .item.image.image01 {
  width: calc(550% / var(--w));
  left: calc(1000% / var(--x));
  top: calc(460% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.image.image01 {
    width: 60%;
    left: 50%;
    right: 1rem;
    top: 56%;
  }
}
.mv .container .item.image.image02 {
  width: calc(480% / var(--w));
  left: calc(126% / var(--x));
  top: calc(384% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.image.image02 {
    width: 44%;
    left: 0;
    top: 10%;
  }
}
.mv .container .item.image.image02 .paraElement {
  background-color: #fff;
  border-radius: 50%;
}
.mv .container .item.image.image03 {
  width: min(500% / var(--w), 400px);
  left: calc(1139% / var(--x));
  top: 0;
}
@media screen and (max-width: 767px) {
  .mv .container .item.image.image03 {
    width: min(66%, 220px);
    left: 60%;
    top: 22%;
  }
}
.mv .container .item.image.image04 {
  width: calc(1091% / var(--w));
  left: calc(552% / var(--x) * -1);
  top: calc(94% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.image.image04 {
    width: 75%;
    left: -44%;
    top: 0;
  }
}
.mv .container .item.image.image05 {
  width: calc(519% / var(--w));
  left: calc(738% / var(--x));
  top: calc(-53% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.image.image05 {
    width: 39%;
    left: 66%;
    top: 2%;
  }
}
.mv .container .item.dots.dots01 {
  width: calc(514% / var(--w));
  left: calc(881% / var(--x));
  top: calc(371% / var(--y));
  mix-blend-mode: multiply;
}
@media screen and (max-width: 767px) {
  .mv .container .item.dots.dots01 {
    display: none;
  }
}
.mv .container .item.dots.dots02 {
  width: calc(543% / var(--w));
  left: calc(669% / var(--x));
  top: calc(33% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.dots.dots02 {
    left: 58%;
    width: 53%;
    top: 2%;
  }
}
.mv .container .item.dots.dots03 {
  width: calc(709% / var(--w));
  left: calc(64% / var(--x));
  top: calc(135% / var(--y));
  mix-blend-mode: multiply;
}
@media screen and (max-width: 767px) {
  .mv .container .item.dots.dots03 {
    width: 79%;
    left: -15%;
    top: 24%;
    rotate: 90deg;
    z-index: 0;
  }
}
.mv .container .item.shape {
  width: calc(825% / var(--w));
  left: calc(288% / var(--x));
  top: calc(374% / var(--y));
}
@media screen and (max-width: 767px) {
  .mv .container .item.shape {
    left: 1rem;
    top: 25%;
    width: 85%;
    rotate: -144deg;
  }
}
.mv .bg {
  position: absolute;
  inset: 12rem 4rem 26rem;
  background-color: var(--gray);
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .mv .bg {
    inset: 10rem 2rem 12rem;
  }
}

/*------------------------------*/
.lead {
  position: relative;
  overflow: hidden;
  background-color: #000;
}
.lead .inner {
  position: relative;
  z-index: 1;
  padding-block: 10rem;
}
.lead .inner p.readText {
  font-weight: 500;
  color: #fff;
  opacity: 0;
  transform: translateY(2rem);
  transition: opacity 0.8s, transform 0.8s;
}
.lead .inner p.readText + p {
  margin-top: 1lh;
}
.lead .inner p.readText.view {
  opacity: 1;
  transform: translateY(0);
}
.lead .inner p.readText.view:nth-of-type(1) {
  transition: opacity 1s 0.2s, transform 1s 0.2s;
}
.lead .inner p.readText.view:nth-of-type(2) {
  transition: opacity 1s 0.7s, transform 1s 0.7s;
}
.lead .inner p.readText.view:nth-of-type(3) {
  transition: opacity 1s 1.2s, transform 1s 1.2s;
}
@media screen and (max-width: 767px) {
  .lead .inner p.readText.alignCenter {
    text-align: justify;
  }
}
.lead .image {
  position: absolute;
  --paraTop: -6%;
  --paraBottom: -6%;
  top: var(--paraTop);
  bottom: var(--paraBottom);
  left: 0;
  right: 0;
  z-index: 0;
  transition: opacity 1s, filter 1.5s;
}
.lead .image.blur {
  filter: blur(5px);
  opacity: 40%;
}
.lead .image img {
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
}

/*------------------------------*/
.about {
  padding-block: 14rem 13rem;
  background-color: var(--gray);
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .about {
    padding-block: 6rem;
  }
}
.about .inner {
  position: relative;
  z-index: 1;
}
.about p.readText {
  font-size: 2.4rem;
  font-weight: 500;
  margin-top: 6rem;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .about p.readText {
    font-size: 1.8rem;
    line-height: 2;
    margin-top: 4rem;
  }
}
.about .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-row: auto;
  gap: 6rem;
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .about .container {
    margin-top: 3rem;
    gap: 3rem;
    grid-template-columns: 1fr;
    grid-template-rows: 20rem 20rem 20rem;
  }
}
.about .container a {
  position: relative;
  overflow: hidden;
  background-color: var(--sub);
}
@media (hover: hover) and (pointer: fine) {
  .about .container a:hover .title {
    color: var(--sub);
  }
}
@media screen and (max-width: 767px) {
  .about .container a .image {
    position: absolute;
    inset: 0;
  }
  .about .container a .image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    -o-object-position: center;
       object-position: center;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.about .container a .title {
  position: absolute;
  z-index: 1;
  inset: 0;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 2rem;
  transition: color 0.4s ease;
}
@media screen and (max-width: 767px) {
  .about .container a .title {
    row-gap: 1rem;
    align-items: flex-start;
    padding-left: 2rem;
  }
}
.about .container a .title p.en {
  font-size: 2.8rem;
  font-family: "Oswald";
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .about .container a .title p.en {
    font-size: 1.6rem;
  }
}
.about .container a .title h3.ja {
  font-size: 3.2rem;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .about .container a .title h3.ja {
    font-size: 2.4rem;
  }
}
.about .container a .blockBtn {
  position: absolute;
  z-index: 1;
  color: var(--sub);
  right: 0;
  bottom: 0;
  width: 18rem;
  height: 5rem;
}
.about .container a .blockBtn::before, .about .container a .blockBtn::after {
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .about .container a .blockBtn {
    width: 16rem;
  }
}
.about .container a.item01 {
  grid-column: span 2;
}
@media screen and (max-width: 767px) {
  .about .container a.item01 {
    grid-column: span 1;
  }
}
.about .container a.item01 .title {
  align-items: flex-start;
  padding-left: 3rem;
}
.about .container a.item01 .title h3.ja {
  font-size: 4rem;
}
@media screen and (max-width: 767px) {
  .about .container a.item01 .title h3.ja {
    font-size: 2.4rem;
  }
}
.about .container a.item01 img {
  opacity: 0.6;
}
.about .container a.item02 .title {
  row-gap: 1.6rem;
}
@media screen and (max-width: 767px) {
  .about .container a.item02 .title {
    row-gap: 1rem;
  }
}
.about .container a.item02 img {
  opacity: 0.5;
}
.about .container a.item03 .title {
  row-gap: 1.6rem;
}
@media screen and (max-width: 767px) {
  .about .container a.item03 .title {
    row-gap: 1rem;
  }
}
.about .container a.item03 img {
  opacity: 0.4;
}
.about .bg {
  position: absolute;
  z-index: 0;
  right: 4.1875%;
  top: 9rem;
  width: 42.9375%;
  max-width: 687px;
}
@media screen and (max-width: 767px) {
  .about .bg {
    max-width: none;
    right: -54%;
    width: 100%;
    top: 4rem;
  }
}

/*------------------------------*/
.interview {
  padding-block: 10rem 16rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .interview {
    padding-block: 6rem;
  }
}
.interview .inner {
  position: relative;
  z-index: 1;
}
.interview .sectionHd {
  flex-direction: column;
  align-items: flex-start;
}
.interview .sectionHd h2.ja {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .interview .sectionHd h2.ja {
    margin-top: 2rem;
  }
}
.interview .wrap {
  margin-top: 8rem;
  width: 50%;
}
@media screen and (max-width: 767px) {
  .interview .wrap {
    margin-top: 4rem;
    width: 100%;
  }
}
.interview .wrap p.readText {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .interview .wrap p.readText {
    font-size: 1.8rem;
    line-height: 2;
  }
}
.interview .wrap .blockBtn {
  margin-top: 5rem;
  margin-inline: auto 0;
  width: 18rem;
  height: 5rem;
  color: var(--sub);
}
.interview .wrap .blockBtn::before, .interview .wrap .blockBtn::after {
  background-color: #6f727f;
}
@media screen and (max-width: 767px) {
  .interview .wrap .blockBtn {
    margin-top: 3rem;
  }
}
.interview .image {
  position: absolute;
  left: calc(50% + 14rem);
  right: 0;
  top: 10.5rem;
  max-width: 660px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .interview .image {
    position: relative;
    left: 0;
    top: 0;
    max-width: none;
    padding-inline: 2rem;
    margin-top: 3rem;
  }
}
.interview .image img {
  transition: scale 0.6s;
}
.interview:has(.blockBtn:hover) .image img {
  scale: 1.03;
}
.interview .bg {
  position: absolute;
  z-index: 0;
  right: 55.5%;
  top: 27rem;
  width: 42.9375%;
  max-width: 687px;
}
@media screen and (max-width: 767px) {
  .interview .bg {
    max-width: none;
    right: auto;
    left: -54%;
    width: 100%;
    top: 4rem;
  }
}

/*------------------------------*/
.how {
  padding-block: 0 15rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .how {
    padding-block: 0 12rem;
  }
}
.how .inner {
  position: relative;
  z-index: 1;
}
.how .sectionHd {
  flex-direction: column;
  align-items: center;
}
.how .sectionHd p.en {
  font-size: 12rem;
}
@media screen and (max-width: 767px) {
  .how .sectionHd p.en {
    font-size: 7.2rem;
  }
}
.how .sectionHd h2.ja {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .how .sectionHd h2.ja {
    margin-top: 2.5rem;
  }
}
.how .wrap {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .how .wrap {
    margin-top: 4rem;
  }
}
.how .wrap p.readText {
  font-size: 2.1rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .how .wrap p.readText {
    font-size: 1.8rem;
  }
}
.how .wrap .blockBtn {
  margin-top: 6rem;
  margin-inline: auto;
  width: 18rem;
  height: 5rem;
  color: var(--sub);
}
.how .wrap .blockBtn::before, .how .wrap .blockBtn::after {
  background-color: #6f727f;
}
@media screen and (max-width: 767px) {
  .how .wrap .blockBtn {
    margin-top: 3rem;
  }
}
.how .image {
  position: absolute;
  bottom: -0.3rem;
  z-index: 0;
}
.how .image.imageLeft {
  left: 0;
  width: 39.0625%;
  max-width: 625px;
  transform-origin: left bottom;
}
@media screen and (max-width: 767px) {
  .how .image.imageLeft {
    width: 45%;
  }
}
.how .image.imageRight {
  right: 0;
  width: 37.6875%;
  max-width: 603px;
  transform-origin: right bottom;
}
@media screen and (max-width: 767px) {
  .how .image.imageRight {
    width: 45%;
  }
}

/*------------------------------*/
.entry .panelBtn {
  padding-block: 15rem 14rem;
  position: relative;
  width: 100%;
  display: grid;
  place-content: center;
  overflow: hidden;
  background-color: var(--sub);
}
@media screen and (max-width: 767px) {
  .entry .panelBtn {
    padding-block: 4rem 3.5rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .entry .panelBtn:hover .blockBtn p.en, .entry .panelBtn:hover .blockBtn h2.ja {
    color: var(--main);
  }
}
.entry .panelBtn .blockBtn {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  color: var(--main);
  padding-block: 6rem 4.5rem;
  width: 68rem;
  margin-inline: auto;
  row-gap: 0.8rem;
}
@media screen and (max-width: 767px) {
  .entry .panelBtn .blockBtn {
    padding: 0;
    width: 30rem;
    height: 12rem;
    row-gap: 0.5rem;
  }
}
.entry .panelBtn .blockBtn p.en {
  color: #fff;
  font-family: "Lato";
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  transition: color 0.2s;
}
@media screen and (max-width: 767px) {
  .entry .panelBtn .blockBtn p.en {
    font-size: 3.2rem;
  }
}
.entry .panelBtn .blockBtn h2.ja {
  color: #fff;
  font-weight: 600;
  transition: color 0.2s;
}
@media screen and (max-width: 767px) {
  .entry .panelBtn .blockBtn h2.ja {
    font-size: 1.4rem;
  }
}
.entry .panelBtn .image {
  position: absolute;
  z-index: 0;
  inset: 0;
}
.entry .panelBtn .image img {
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
  opacity: 0.7;
}
/*# sourceMappingURL=style.css.map */