@font-face {
  font-family: "Noto Sans";
  src: url("/company/efforts/next21/assets/fonts/noto-subset.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap
}
@font-face {
  font-family: "Roboto";
  src: url("/company/efforts/next21/assets/fonts/roboto-subset.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap
}
@font-face {
  font-family: "Roboto italic";
  src: url("/company/efforts/next21/assets/fonts/roboto-italic-subset.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap
}
.sec-heading {
  display: grid;
  grid-template-columns: 5rem 1fr;
  align-items: center;
  gap: 1.2rem
}
.sec-heading .heading-ttl .ttl-sub {
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.3
}
.sec-heading .heading-ttl .ttl-main {
  font-weight: bold;
  font-size: 2.6rem;
  line-height: 1.4
}
.sec-heading .heading-ttl .ttl-main .main-s {
  font-size: 2.2rem
}
@media screen and (min-width: 769px) {
  .sec-heading {
    grid-template-columns: 6.5rem 1fr;
    gap: 1.4rem
  }
  .sec-heading .heading-ttl .ttl-sub {
    font-size: 1.6rem
  }
  .sec-heading .heading-ttl .ttl-main {
    font-size: 3rem
  }
  .sec-heading .heading-ttl .ttl-main .main-s {
    font-size: 2.5rem
  }
}
.mv {
  background: #ebf7ff
}
.mv .item-img {
  border-radius: 0 0 2rem 2rem;
  overflow: hidden
}
@media screen and (min-width: 769px) {
  .mv .item-img {
    border-radius: 0 0 5rem 5rem
  }
}
.news {
  position: relative;
  padding-top: 7rem;
  margin-bottom: 5rem
}
.news::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 390/662;
  max-height: 66.2rem;
  background: linear-gradient(to bottom, #EBF7FF, #F4FBFF 75%, #FFF 100%);
  pointer-events: none;
  content: "";
  z-index: -1;
}
.news .inner {
  position: relative;
  z-index: 2
}
.news .news-wrap {
  position: relative;
  display: grid;
  gap: 2rem 5.5rem;
  padding: 4rem 2.5rem 2.5rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 0 .6rem rgba(0, 0, 0, .16);
  box-sizing: border-box
}
.news .news-wrap::before {
  position: absolute;
  bottom: -3.8rem;
  left: 0;
  width: 100%;
  aspect-ratio: 350/481;
  background: url("/company/efforts/next21/assets/img/home/news-deso-sp.svg") center/cover no-repeat;
  pointer-events: none;
  content: ""
}
.news .news-wrap .news-ttl {
  color: #0066b5;
  font-weight: bold;
  font-size: 2.6rem;
  line-height: 1.5;
  text-align: center
}
.news .news-wrap .news-cont .news-list {
  display: grid;
  gap: 1.5rem
}
.news .news-wrap .news-cont .news-list .news-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem .8rem;
  padding-bottom: 1.2rem;
  border-bottom: .1rem solid #7aaed8
}
.news .news-wrap .news-cont .news-list .news-item .news-date {
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: .06em;
  line-height: 1.5
}
.news .news-wrap .news-cont .news-list .news-item .news-tag.new {
  display: inline-block;
  padding: .4rem .8rem;
  background: #0066b5;
  border-radius: .2rem;
  color: #fff;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 1.1rem;
  letter-spacing: .06em;
  line-height: 1
}
.news .news-wrap .news-cont .news-list .news-item .news-ttl {
  color: #000;
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 1.75;
  text-align: left
}
.news .news-wrap .news-cont .news-btn {
  display: block;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin: 2rem 0 0 auto;
  padding-right: 1.9rem;
  color: #0066b5;
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1.5
}
.news .news-wrap .news-cont .news-btn::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: .8rem;
  aspect-ratio: 1;
  border-top: .1rem solid #0066b5;
  border-right: .1rem solid #0066b5;
  transform: translate(-25%, -50%) rotate(45deg);
  content: ""
}
@media screen and (min-width: 961px) {
  .news {
    padding-top: 10rem;
    margin-bottom: 8rem
  }
  .news::before {
    aspect-ratio: 1366/600;
    max-height: calc(100% + 5rem);
  }
  .news .news-wrap {
    grid-template-columns: 155fr 704fr;
    gap: 2rem;
    padding: 4rem 6rem 2.5rem;
    border-radius: 2rem
  }
  .news .news-wrap::before {
    bottom: auto;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: 115%;
    aspect-ratio: 1200/302;
    background: url("/company/efforts/next21/assets/img/home/news-deso-pc.svg") center/cover no-repeat
  }
  .news .news-wrap .news-ttl {
    font-size: 3rem
  }
  .news .news-wrap .news-cont .news-list {
    gap: 1.8rem
  }
  .news .news-wrap .news-cont .news-list .news-item {
    display: grid;
    grid-template-columns: 70fr 55fr 540fr;
    gap: 1.5rem;
    padding-bottom: 1.8rem
  }
  .news .news-wrap .news-cont .news-list .news-item .news-date {
    padding-right: 1rem;
    font-size: 1.4rem
  }
  .news .news-wrap .news-cont .news-list .news-item .news-tag.new {
    padding: .4rem 1.4rem;
    font-size: 1.2rem
  }
  .news .news-wrap .news-cont .news-list .news-item .news-ttl {
    font-size: 1.4rem
  }
  .news .news-wrap .news-cont .news-btn {
    font-size: 1.5rem;
    border-bottom: .1rem solid #fff;
    transition: .3s
  }
  .news .news-wrap .news-cont .news-btn::before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: .1rem;
    background: #0066b5;
    transition: .3s;
    content: ""
  }
  .news .news-wrap .news-cont .news-btn::after {
    width: .8rem
  }
  .news .news-wrap .news-cont .news-btn:hover::before {
    width: 100%
  }
}
@media screen and (min-width: 1261px) {
  .news .news-wrap::before {
    width: 120%
  }
}
.special {
  margin: 5rem 0 6.5rem
}
.special .special-ttl {
  padding: 1.5rem;
  background: #0066b5;
  box-sizing: border-box;
  clip-path: polygon(100% 0, calc(100% - 1rem) 50%, 100% 100%, 0 100%, 1rem 50%, 0 0);
  color: #fff;
  font-weight: bold;
  font-size: 2rem;
  line-height: 1.5;
  text-align: center
}
.special .special-txt {
  position: relative;
  margin: 2rem 0;
  font-size: 1.2rem;
  line-height: 1.83
}
.special .special-txt b {
  font-weight: bold
}
.special .special-txt a {
  display: inline;
  color: #0066b5;
  text-decoration: underline
}
.special .special-img {
	max-width: 800px;
	margin: 0 auto 5rem;
}
@media screen and (min-width: 769px) {
  .special {
    margin: 8rem 0 10rem
  }
  .special .special-ttl {
    max-width: 90rem;
    margin-left: auto;
    margin-right: auto;
    padding: 1.2rem;
    font-size: 2.2rem;
    clip-path: polygon(100% 0, calc(100% - 2rem) 50%, 100% 100%, 0 100%, 2rem 50%, 0 0)
  }
  .special .special-txt {
    max-width: 88rem;
    margin: 3rem auto 2.5rem;
    font-size: 1.4rem;
    line-height: 1.85
  }
}
.topic {
  position: relative;
  margin-top: 15rem;
  padding-bottom: 9rem;
  background: #F9FAFB;
}
.topic + .phase {
  position: relative;
  z-index: 1;
  margin-top: -2rem;
}
.topic::before {
  position: absolute;
  top: -8.5rem;
  left: 50%;
  transform: translate(-50%,0);
  width: 150vw;
  height: 23.8rem;
  border-radius: 50%;
  background: #F9FAFB;
  content: '';
}
.topic .inner {
  position: relative
}
.topic .topic-heading .heading-ttl {
  width: 29.5rem;
  margin: 0 auto
}
.topic .topic-heading .heading-txt {
  margin-top: 1.5rem;
  color: #0066b5;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.5;
  text-align: center
}
.topic .topic-slider {
  margin-top: 2.4rem;
  overflow: visible
}
.topic .topic-slider .topic-img{
  display: block;
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: 1rem;
  box-shadow: 0 0 .6rem rgba(0,0,0,.16);
  overflow: hidden;
}
.topic .topic-slider .topic-img img{
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.topic .topic-slider .topic-detail {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  margin-top: 1.5rem
}
.topic .topic-slider .topic-detail .topic-date {
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: .06em;
  line-height: 1.5
}
.topic .topic-slider .topic-detail .topic-tag {
  display: block;
  background: #0066b5;
  padding: .5rem 1.5rem;
  border-radius: 5rem;
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: .05em;
  line-height: 1
}
.topic .topic-slider .topic-ttl {
  margin-top: .5rem;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.625
}
.topic .topic-slider .topic-arrow {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: 2;
  width: 100vw;
  aspect-ratio: 390/175;
  pointer-events: none
}
.topic .topic-slider .topic-arrow .topic-next, .topic .topic-slider .topic-arrow .topic-prev {
  position: absolute;
  top: 50%;
  width: 4rem;
  z-index: 3;
  cursor: pointer;
  pointer-events: auto
}
.topic .topic-slider .topic-arrow .topic-prev {
  left: 4%;
  transform: translate(0, -50%) scale(-1, 1)
}
.topic .topic-slider .topic-arrow .topic-next {
  right: 4%;
  transform: translate(0, -50%)
}
.topic .topic-slider .topic-pagination {
  margin: 2rem auto 2.5rem;
  display: flex;
  justify-content: center
}
.topic .topic-slider .topic-pagination .swiper-pagination-bullet {
  background: #e8e8e8;
  opacity: 1;
  margin: 0 .5rem
}
.topic .topic-slider .topic-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #0066b5
}
@media screen and (min-width: 769px) {
  .topic {
    margin-top: 20rem;
    padding-bottom: 12rem;
  }
  .topic + .phase{
    margin-top: -4rem;
  }
  .topic::before {
    top: -12.5rem;
    width: 110vw;
    height: 38.8rem;
  }
  .topic .topic-heading .heading-ttl {
    width: 44rem
  }
  .topic .topic-heading .heading-txt {
    font-size: 1.6rem
  }
  .topic .topic-slider {
    margin-top: 2.6rem
  }
  .topic .topic-slider .topic-img{
    border-radius: 2rem;
  }
  .topic .topic-slider .topic-detail {
    margin-top: 1.8rem
  }
  .topic .topic-slider .topic-detail .topic-date {
    font-size: 1.6rem
  }
  .topic .topic-slider .topic-detail .topic-tag {
    padding: .5rem 2rem;
    font-size: 1.2rem
  }
  .topic .topic-slider .topic-ttl {
    margin-top: .8rem;
    font-size: 1.8rem;
    line-height: 1.44
  }
  .topic .topic-slider .topic-arrow {
    aspect-ratio: 1366/243
  }
  .topic .topic-slider .topic-arrow .topic-next, .topic .topic-slider .topic-arrow .topic-prev {
    width: 5.2rem
  }
  .topic .topic-slider .topic-arrow .topic-prev {
    left: 9.5rem
  }
  .topic .topic-slider .topic-arrow .topic-next {
    right: 9.5rem
  }
  .topic .topic-slider .topic-pagination {
    margin: 3rem auto
  }
}
@media screen and (min-width: 1261px) {
  .topic .inner::before {
    right: -8.5rem
  }
}
.phase {
  padding: 6rem 0 7.5rem;
  background: #ebf7ff;
  border-radius: 2rem 2rem 0 0
}
.phase .phase-wrap {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 2rem;
  background: #fff;
  padding: 3.5rem 2rem 3rem;
  box-sizing: border-box;
  border-radius: 1.5rem;
  box-shadow: 0 0 1rem rgba(0, 0, 0, .16)
}
.phase .phase-wrap::before {
  position: absolute;
  top: -8.4rem;
  left: 1rem;
  width: 34rem;
  aspect-ratio: 340/1103;
  background: url("/company/efforts/next21/assets/img/home/phase-deco-sp.svg") center/cover no-repeat;
  content: ""
}
.phase .phase-wrap .wrap-img {
  width: 60%;
  margin: 0 auto
}
.phase .phase-wrap .wrap-cont .cont-tag {
  display: inline-block;
  padding: .5rem .8rem;
  background: #0066b5;
  color: #fff;
  font-weight: bold;
  font-size: 1.1rem;
  line-height: 1
}
.phase .phase-wrap .wrap-cont .cont-ttl {
  margin-top: .5rem;
  color: #0066b5;
  font-weight: bold;
  font-size: 2.2rem;
  line-height: 1.4
}
.phase .phase-wrap .wrap-cont .cont-txt {
  margin-top: .5rem;
  font-weight: bold;
  font-size: 1.2rem;
  line-height: 1.83
}
.phase .phase-wrap .phase-txt {
  margin-top: 1.5rem;
  padding: 2.5rem 2rem;
  background: #ebf7ff;
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.83;
  border-radius: 2rem
}
@media screen and (min-width: 769px) {
  .phase {
    padding: 8rem 0 12rem;
    border-radius: 4rem 4rem 0 0
  }
  .phase .phase-wrap {
    grid-template-columns: 354fr 486fr;
    gap: 4rem;
    padding: 5rem 6rem 8rem;
    border-radius: 2rem
  }
  .phase .phase-wrap::before {
    top: -14rem;
    left: -2.7rem;
    width: 111.2rem;
    aspect-ratio: 1112/915;
    background: url("/company/efforts/next21/assets/img/home/phase-deco-pc.svg") center/cover no-repeat
  }
  .phase .phase-wrap .wrap-img {
    width: 100%
  }
  .phase .phase-wrap .wrap-cont .cont-tag {
    padding: .6rem 1.2rem;
    font-size: 1.3rem

  }
  .phase .phase-wrap .wrap-cont .cont-ttl {
    margin-top: 1.2rem;
    font-size: 2.8rem
  }
  .phase .phase-wrap .wrap-cont .cont-txt {
    margin-top: .8rem;
    font-size: 1.4rem
  }
  .phase .phase-wrap .phase-txt {
    margin-top: 1.5rem;
    padding: 3rem;
    font-size: 1.4rem;
    line-height: 1.7
  }
}
.bnr {
  padding-top: 7rem;
  border-radius: 2rem 2rem 0 0;
  background: #fff;
  margin-top: -2rem
}
.bnr .inner {
  padding-bottom: 4rem;
  margin-bottom: 6rem;
  border-bottom: 1px solid #e8e8e8
}
.bnr .bnr-wrap {
  display: grid;
  gap: 1rem 2rem
}
.bnr .house-bnr {
  display: block;
  width: 30rem;
  margin: 2rem auto 0
}
@media screen and (min-width: 769px) {
  .bnr {
    border-radius: 4rem 4rem 0 0;
    margin-top: -4rem
  }
  .bnr .bnr-wrap {
    grid-template-columns: 1fr 1fr
  }
  .bnr .house-bnr {
    max-width: 335px;
    margin-top: 2.5rem
  }
}
.about {
  margin: 6.5rem 0 7.5rem
}
.about .about-wrap {
  display: grid;
  gap: 3rem 8rem;
  width: 94.87%
}
.about .about-wrap .wrap-cont {
  padding-left: 2rem
}
.about .about-wrap .wrap-cont .cont-heading {
  color: #0066b5
}
.about .about-wrap .wrap-cont .cont-txt {
  margin-top: 1.5rem;
  font-size: 1.2rem;
  line-height: 1.83
}
.about .about-wrap .wrap-cont .cont-btn {
  margin-top: 3rem
}
@media screen and (min-width: 769px) {
  .about {
    margin: 10rem 0
  }
  .about .about-wrap {
    grid-template-columns: 47fr 45fr;
    align-items: center;
    width: 89.75%;
    max-width: 1000px;
    margin: 0 auto
  }
  .about .about-wrap .wrap-cont {
    padding-left: 0
  }
  .about .about-wrap .wrap-cont .cont-txt {
    margin-top: 1.8rem;
    font-size: 1.4rem;
    line-height: 2
  }
  .about .about-wrap .wrap-cont .cont-btn {
    max-width: 26rem;
    margin-left: 0
  }
}
.house {
  position: relative;
  background: #ebf7ff;
  border-radius: 2rem 2rem 0 0;
  padding: 5rem 0 6rem
}
.house .house-wrap {
  display: grid;
  gap: 4rem 6.7rem
}
.house .house-wrap .wrap-cont .cont-heading {
  color: #0066b5
}
.house .house-wrap .wrap-cont .cont-txt {
  margin-top: 1.5rem;
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 1.83
}
.house .house-wrap .wrap-cont .cont-btn {
  margin-top: 3rem
}
.house .house-experiment {
  display: grid;
  gap: 2.5rem;
  margin-top: 5.5rem;
  padding: 4rem 2rem 5rem;
  border-radius: 2rem;
  background: #0066b5;
  box-sizing: border-box
}
.house .house-experiment .experiment-img {
  width: 73.5%;
  margin: 0 auto
}
.house .house-experiment .experiment-cont {
  color: #fff
}
.house .house-experiment .experiment-cont .cont-txt {
  margin-top: 1.5rem;
  font-size: 1.2rem;
  line-height: 1.83
}
.house .house-experiment .experiment-cont .cont-btn {
  width: 77.4%;
  margin-top: 3rem
}
.house .house-bnr {
  display: block;
  margin-top: 3rem
}
@media screen and (min-width: 769px) {
  .house {
    border-radius: 4rem 4rem 0 0;
    padding: 8rem 0
  }
  .house .house-wrap {
    grid-template-columns: 500fr 433fr
  }
  .house .house-wrap .wrap-img {
    order: 2;
    padding-top: 1.2rem
  }
  .house .house-wrap .wrap-cont .cont-txt {
    margin-top: 2rem;
    font-size: 1.4rem;
    line-height: 2
  }
  .house .house-wrap .wrap-cont .cont-btn {
    max-width: 26rem;
    margin-left: 0
  }
  .house .house-experiment {
    grid-template-columns: 340fr 480fr;
    gap: 6rem;
    margin-top: 6.5rem;
    padding: 6rem
  }
  .house .house-experiment .experiment-img {
    width: 100%
  }
  .house .house-experiment .experiment-cont .cont-txt {
    margin-top: 1.8rem;
    font-size: 1.4rem;
    line-height: 1.85
  }
  .house .house-experiment .experiment-cont .cont-btn {
    width: 100%;
    max-width: 26rem;
    margin-left: 0
  }
  .house .house-bnr {
    max-width: 62rem;
    margin: 5rem auto 0
  }
}