@font-face {
  font-family: "pretendard";
  font-weight: 400;
  font-display: swap;
  src: local("Pretendard-Regular"), url(/assets/fonts/Pretendard-Regular.woff) format("woff"), url(/assets/fonts/Pretendard-Regular.woff2) format("woff2");
}
@font-face {
  font-family: "pretendard";
  font-weight: 500;
  font-display: swap;
  src: local("Pretendard-Medium"), url(/assets/fonts/Pretendard-Medium.woff) format("woff"), url(/assets/fonts/Pretendard-Medium.woff2) format("woff2");
}
@font-face {
  font-family: "pretendard";
  font-weight: 700;
  font-display: swap;
  src: local("Pretendard-Bold"), url(/assets/fonts/Pretendard-Bold.woff) format("woff"), url(/assets/fonts/Pretendard-Bold.woff2) format("woff2");
}
@font-face {
  font-family: "samsungsharpsans";
  font-weight: 600;
  font-display: swap;
  src: local("samsungsharpsans-medium"), url(/assets/fonts/samsungsharpsans-medium.woff) format("woff"), url(/assets/fonts/samsungsharpsans-medium.woff2) format("woff2");
}
@font-face {
  font-family: "samsungsharpsans";
  font-weight: 700;
  font-display: swap;
  src: local("samsungsharpsans-bold"), url(/assets/fonts/samsungsharpsans-bold.woff) format("woff"), url(/assets/fonts/samsungsharpsans-bold.woff2) format("woff2");
}
.main-wrapper .container {
  max-width: none;
  padding: 80px 0 0;
}
.main-wrapper .contents {
  padding: 0;
}

.btn-view {
  display: flex;
  justify-content: flex-end;
}
.btn-view > a {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 18px;
  font-family: "samsungsharpsans";
  line-height: 18px;
}
.btn-view > a::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  background: url(/assets/images/icon_main_arrow.png) no-repeat 0 0/100% auto;
}

.main-section01 {
  text-align: center;
  background: #F7FAFF;
}
.main-section01 .visual-wrap {
  padding: 0 100px;
  max-width: 1800px;
  height: calc(100vh - 100px);
  margin: 0 auto;
}
.main-section01 .visual-wrap .visual-top-area {
  position: relative;
  display: flex;
  gap: 100px;
  text-align: left;
  align-items: flex-end;
}
.main-section01 .visual-wrap .visual-top-area .text-area-big {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}
.main-section01 .visual-wrap .visual-top-area .text-area-big p {
  color: #A2A4B3;
  font-size: 60px;
  font-weight: 700;
  font-family: "samsungsharpsans";
}
.main-section01 .visual-wrap .visual-top-area .text-area-big p span {
  font-size: 60px;
  font-weight: 700;
  font-family: "samsungsharpsans";
  transition: color 0.5s ease;
}
.main-section01 .visual-wrap .visual-top-area .text-area-big p.fade {
  opacity: 0;
  transition: opacity 0.7s ease;
}
.main-section01 .visual-wrap .visual-top-area .text-area-big p.fade.active {
  opacity: 1;
}
.main-section01 .visual-wrap .visual-top-area .img-motion01 {
  position: relative;
  width: 625px;
  height: 408px;
  flex-shrink: 0;
}
.main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 408px;
  height: 408px;
}
.main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.main-section01 .visual-wrap .visual-bottom-area {
  display: flex;
  margin-top: 54px;
  gap: 160px;
  align-items: flex-start;
}
.main-section01 .visual-wrap .visual-bottom-area .video-area {
  overflow: hidden;
  width: 247px;
  height: 247px;
  flex-shrink: 0;
  transform-origin: left center;
}
.main-section01 .visual-wrap .visual-bottom-area .video-area video {
  transform: translateX(-100%) rotate(0.0001deg);
  animation: expandVideo 1.5s both;
  animation-delay: 1.8s;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area {
  width: 100%;
  display: flex;
  gap: 60px;
  margin-bottom: 96px;
  justify-content: space-between;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .text {
  text-align: left;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .text p {
  font-size: 18px;
  line-height: 1.5;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .text .btn-round {
  margin-top: 32px;
  width: 172px;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 {
  position: relative;
  width: 381px;
  opacity: 0.85;
  flex-shrink: 0;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 381px;
}
.main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@keyframes expandVideo {
  to {
    transform: translateX(0);
  }
}
.main-section02 {
  max-width: 1800px;
  padding: 200px 120px;
  margin: 0 auto;
  background: #fff;
  box-sizing: border-box;
}
.main-section02 .inner .title-text {
  font-size: 36px;
  font-weight: 700;
  font-family: "samsungsharpsans";
  line-height: 56px;
  text-align: left;
  padding-left: 679px;
}
.main-section02 .inner .cont-area {
  display: flex;
  gap: 80px;
  margin-top: 100px;
  align-items: center;
}
.main-section02 .inner .cont-area figure {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  width: 512px;
  height: 364px;
}
.main-section02 .inner .cont-area figure img {
  position: relative;
  top: 50%;
  width: 100%;
  transform: translateY(-50%);
}
.main-section02 .inner .cont-area .text-area {
  width: 100%;
}
.main-section02 .inner .cont-area .text-area .main-about-title {
  display: block;
  font-size: 36px;
  line-height: 1.3;
  font-family: "samsungsharpsans";
}
.main-section02 .inner .cont-area .text-area .main-about-title br {
  display: none;
}
.main-section02 .inner .cont-area .text-area p {
  margin-top: 24px;
}
.main-section02 .inner .cont-area .text-area p span {
  display: block;
  margin-top: 24px;
  font-size: 24px;
  line-height: 1.66;
}
.main-section02 .inner .cont-area .text-area p span:first-child {
  margin-top: 0;
}

.main-section03 {
  padding: 200px 0;
  background: #F7FAFF;
}
.main-section03 .rolling-text-area {
  position: relative;
  max-width: 1800px;
  padding: 0 100px;
  z-index: 1;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 100px;
}
.main-section03 .rolling-text-area .title-text {
  font-size: 36px;
  font-weight: 700;
  font-family: "samsungsharpsans";
  line-height: 56px;
}
.main-section03 .rolling-text-area .item-inner {
  display: flex;
  justify-content: space-around;
  width: 100%;
}
.main-section03 .rolling-text-area .item-inner .item {
  display: flex;
  flex-direction: column;
  gap: 32px;
  flex: 1;
}
.main-section03 .rolling-text-area .item-inner .point-text-wrap {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.main-section03 .rolling-text-area .item-inner .point-text {
  display: inline-block;
  text-align: center;
  font-size: 100px;
  font-family: "samsungsharpsans";
  line-height: 120px;
  color: #1428a0;
}
.main-section03 .rolling-text-area .item-inner .sub-text {
  display: inline-block;
  text-align: center;
  font-size: 20px;
  line-height: 32px;
}

.main-section04 {
  max-width: 1800px;
  padding: 200px 100px;
  margin: 0 auto;
  text-align: center;
}
.main-section04 .inner {
  margin: 0 auto;
}
.main-section04 .inner .title-text {
  font-size: 36px;
  font-weight: 700;
  font-family: "samsungsharpsans";
  line-height: 56px;
}
.main-section04 .inner .item-wrap {
  display: grid;
  gap: 100px 80px;
  grid-template-columns: repeat(4, 1fr);
  align-items: start;
  margin: 100px 0 -80px;
}
.main-section04 .inner .item-wrap .item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}
.main-section04 .inner .item-wrap .item .tit {
  font-size: 28px;
  line-height: 40px;
  font-weight: 700;
  text-align: center;
  font-family: "samsungsharpsans";
}
.main-section04 .inner .item-wrap .item .txt {
  font-size: 20px;
  line-height: 1.6;
  text-align: center;
}

.main-section06 {
  max-width: 1800px;
  padding: 200px 100px;
  margin: 0 auto;
  text-align: center;
}
.main-section06 .inner {
  min-width: 1600px;
  margin: 0 auto;
  text-align: center;
}
.main-section06 .inner .title-text {
  font-size: 36px;
  font-weight: 700;
  font-family: "samsungsharpsans";
  line-height: 56px;
}
.main-section06 .inner .title-sub-text {
  display: block;
  margin-top: 20px;
  font-size: 24px;
  line-height: 1.5;
}
.main-section06 .inner .main-portfolio-list {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 100px -50px 0;
}
.main-section06 .inner .main-portfolio-list > li {
  display: flex;
  width: 100%;
  padding: 0 50px;
}
.main-section06 .inner .main-portfolio-list > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.main-section06 .inner .main-portfolio-list > li > a img {
  transition: 0.5s;
  width: 100%;
}
.main-section06 .inner .main-portfolio-list > li > a:hover img {
  transform: scale(1.15);
}
.main-section06 .inner .btn-round {
  margin-top: 80px;
  width: 172px;
}

.main-section05 {
  max-width: 1920px;
  padding: 200px 0;
  margin: 0 auto;
  text-align: center;
}
.main-section05 > .title-text {
  font-size: 36px;
  font-weight: 700;
  line-height: 56px;
  font-family: "samsungsharpsans";
  padding-bottom: 60px;
  text-align: center;
}
.main-section05 .inner {
  margin: 0 auto;
  text-align: center;
}
.main-section05 .inner .map-wrap {
  position: relative;
  overflow: hidden;
}
.main-section05 .inner .map-wrap .map-button {
  display: block;
  text-align: center;
  z-index: 10;
}
.main-section05 .inner .map-wrap .map-button > .btn {
  position: relative;
  display: inline-block;
  padding: 0 40px;
  text-align: center;
  height: 80px;
  color: #666;
  font-size: 24px;
  font-weight: 700;
  line-height: 80px;
  text-transform: uppercase;
  font-family: "samsungsharpsans";
  z-index: 10;
}
.main-section05 .inner .map-wrap .map-button > .btn[aria-selected=true] {
  color: #000;
}
.main-section05 .inner .map-wrap .map-button > .btn[aria-selected=true]:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 40px;
  right: 40px;
  height: 3px;
  background: #000;
}
.main-section05 .inner .map-wrap .map-inner {
  position: relative;
  background-color: #BDCFFF;
}
.main-section05 .inner .map-wrap .map-inner .img {
  height: 700px;
}
.main-section05 .inner .map-wrap .map-inner .img img {
  height: 100%;
}
.main-section05 .inner .map-wrap .map-inner #worldMapSvg {
  width: 100%;
  height: 700px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap {
  position: absolute;
  transform: translate(-50%, -100%);
  opacity: 0;
  margin-top: -20px;
  transition: opacity 0.5s ease-out !important;
}
.main-section05 .inner .map-wrap .btn-pin-wrap .pin-text {
  display: none;
  position: relative;
  z-index: 1;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.6);
  padding: 8px 18px;
  font-size: 18px;
  font-weight: 700;
  line-height: 26px;
  white-space: pre;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.is-text .pin-text {
  display: block;
  position: absolute;
  left: 44px;
  top: 5px;
  z-index: 1;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.is-active {
  z-index: 10;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.is-active::after {
  content: "";
  display: block;
  width: 91px;
  height: 90px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: url(/assets/images/icon_pin_circle.png) no-repeat 0 0/100% auto;
  animation: animation-pulse 2s linear infinite;
}
@keyframes animation-pulse {
  0% {
    width: 40px;
    height: 40px;
    opacity: 0.1;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0.9;
    width: 91px;
    height: 90px;
  }
}
.main-section05 .inner .map-wrap .btn-pin-wrap.seoul {
  top: 238px;
  left: 727px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.siliconvalley {
  top: 238px;
  left: 1246px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.boston {
  top: 204px;
  left: 1445px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.london {
  top: 155px;
  left: 153px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.telaviv {
  top: 270px;
  left: 318px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.beijing {
  top: 257px;
  left: 622px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.tokyo {
  top: 253px;
  left: 782px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.bangalore {
  top: 338px;
  left: 504px;
}
.main-section05 .inner .map-wrap .btn-pin-wrap.shanghai {
  top: 326px;
  left: 622px;
}
.main-section05 .inner .map-wrap .btn-pin {
  display: block;
  position: relative;
  z-index: 10;
  width: 32px;
  height: 42px;
  background: url(/assets/images/icon_pin.png) no-repeat 0 0/100% auto;
}
.main-section05 .inner .infor-text {
  max-width: 1800px;
  min-height: 40px;
  margin: 60px auto 0;
  padding: 0 100px 0;
  text-align: left;
}
.main-section05 .inner .infor-text .item {
  display: none;
}
.main-section05 .inner .infor-text .item.is-active {
  display: block;
}
.main-section05 .inner .infor-text .item.is-active a {
  display: flex;
}
.main-section05 .inner .infor-text .title-text {
  min-width: 271px;
  padding-bottom: 0;
  flex-shrink: 0;
  font-size: 28px;
  line-height: 40px;
}
.main-section05 .inner .infor-text .text {
  font-size: 24px;
  line-height: 40px;
}

@media only screen and (min-width: 1921px) {
  .main-section01 .visual-wrap .visual-top-area {
    gap: 72px;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    width: 788px;
    height: 516px;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
    width: 516px;
    height: 516px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    font-size: 60px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    font-size: 60px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    margin-top: 117px;
  }
}
@media only screen and (max-width: 1800px) {
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    font-size: 50px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    font-size: 50px;
  }
}
@media only screen and (max-width: 1600px) {
  .main-wrapper .container {
    padding: 80px 0 0;
  }
  img {
    width: 100%;
  }
  .main-section01 {
    padding: 0;
  }
  .main-section01 .visual-wrap {
    min-width: auto;
    padding: 0 60px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    font-size: 45px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    font-size: 45px;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    width: 580px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    gap: 100px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area {
    width: 230px;
    height: 230px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area {
    gap: 100px;
  }
  .btn-round {
    height: 40px;
    padding: 0 30px;
    line-height: 38px;
  }
  [class^=main-section] .inner .title-text, [class^=main-section] .rolling-text-area .title-text, [class^=main-section] .title-text {
    font-size: 2.25vw;
  }
  .main-section02, .main-section03, .main-section04, .main-section06 {
    padding: 100px 60px;
  }
  .main-section02 .inner {
    min-width: auto;
  }
  .main-section02 .inner .title-text {
    padding-left: calc(35% + 90px);
  }
  .main-section02 .inner .cont-area {
    gap: 90px;
  }
  .main-section02 .inner .cont-area figure {
    width: 32%;
    height: 260px;
  }
  .main-section02 .inner .cont-area figure img {
    width: 100%;
  }
  .main-section02 .inner .cont-area .text-area .main-about-title {
    font-size: 28px;
  }
  .main-section02 .inner .cont-area .text-area p span {
    margin-top: 18px;
    font-size: 18px;
  }
  .main-section03 {
    margin: 0 -24px;
  }
  .main-section03 .rolling-text-area {
    padding: 0 24px;
  }
  .main-section03 .rolling-text-area .item-inner .point-text {
    font-size: 52px;
    line-height: 80px;
  }
  .main-section03 .rolling-text-area .item-inner .sub-text {
    font-size: 20px;
  }
  .main-section04 .inner {
    min-width: auto;
  }
  .main-section04 .inner .item-wrap .item .txt {
    font-size: 18px;
  }
  .main-section04 .inner .item-wrap .item .txt br {
    display: none;
  }
  .main-section06 .inner {
    min-width: auto;
  }
  .main-section06 .inner .main-portfolio-list {
    margin: 25px -25px 0;
  }
  .main-section06 .inner .main-portfolio-list > li {
    padding: 0 25px;
  }
  .main-section06 .inner .main-portfolio-list > li img {
    width: 100%;
  }
  .main-section06 .inner .title-sub-text {
    font-size: 1.5vw;
  }
  .main-section05 {
    padding: 100px 60px;
  }
  .main-section05 .inner .map-wrap {
    height: auto;
  }
  .main-section05 .inner .map-wrap .map-button > .btn {
    font-size: 1.5vw;
  }
  .main-section05 .inner .map-wrap .map-inner .img {
    height: 550px;
  }
  .main-section05 .inner .map-wrap .map-inner .img #worldMapSvg {
    height: 550px;
  }
  .main-section05 .inner .infor-text {
    min-width: auto;
    margin-top: 12px;
    padding: 0 24px 0;
    min-height: 56px;
  }
  .main-section05 .inner .infor-text .title-text {
    font-size: 28px;
    line-height: 28px;
  }
  .main-section05 .inner .infor-text .text {
    font-size: 18px;
    line-height: 28px;
  }
}
/* Mobile Size */
@media only screen and (max-width: 1280px) {
  .main-section01 .visual-wrap {
    min-width: auto;
    padding: 0 24px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    font-size: 36px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    font-size: 36px;
  }
  .main-section01 .visual-wrap .visual-top-area {
    gap: 20px;
  }
  .main-section01 .visual-wrap .visual-top-area .video-area {
    width: 100px;
    height: 100px;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    width: 480px;
    height: 319px;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
    right: 50px;
    width: 319px;
    height: 319px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    gap: 30px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area {
    width: 120px;
    height: 120px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area video {
    animation-delay: 1.3s;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area {
    gap: 20px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p {
    font-size: 14px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 {
    width: 250px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img {
    height: 250px;
  }
  .btn-round {
    height: 40px;
    padding: 0 20px;
    line-height: 38px;
    font-size: 15px;
  }
  .main-section03 {
    padding: 120px 24px;
  }
  .main-section03 .rolling-text-area {
    gap: 60px;
  }
  .main-section03 .rolling-text-area .item-inner {
    flex-wrap: wrap;
    gap: 40px;
  }
  .main-section03 .rolling-text-area .item-inner .item {
    flex-basis: calc(50% - 20px);
    gap: 2px;
  }
  .main-section03 .rolling-text-area .item-inner .point-text {
    display: inline-block;
    text-align: center;
    font-size: 100px;
    font-family: "samsungsharpsans";
    line-height: 120px;
    color: #1428a0;
  }
  .main-section03 .rolling-text-area .item-inner .sub-text {
    display: inline-block;
    text-align: center;
    font-size: 24px;
    line-height: 36px;
  }
}
@media only screen and (max-width: 768px) {
  .main-wrapper .container {
    padding: 56px 0 0;
  }
  [class^=main-section] .inner .title-text, [class^=main-section] .rolling-text-area .title-text, [class^=main-section] .title-text {
    font-size: 28px;
    line-height: 1.5;
  }
  .main-section01 {
    margin: 0;
    height: calc(100dvh - 56px);
  }
  .main-section01 .visual-wrap .visual-top-area {
    display: block;
    padding-top: calc(100vw - 48px);
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
    width: 100%;
    height: calc(100vw - 112px);
    padding: 0 52px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    display: none;
    opacity: 0;
    font-size: 48px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p:first-child {
    display: block;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    display: block;
    font-size: 48px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    gap: 32px;
    margin-top: 60px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area {
    width: 104px;
    height: 104px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p br {
    display: none;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text .btn-round {
    margin-top: 20px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 {
    position: absolute;
    top: calc(100vw - 170px);
    right: 0;
    width: 160px;
    height: 160px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img {
    height: 160px;
  }
  .main-section02 {
    padding: 120px 24px;
  }
  .main-section02 .inner .title-text {
    text-align: center;
    padding-left: 0;
  }
  .main-section02 .inner .cont-area {
    margin-top: 60px;
    flex-direction: column;
    gap: 60px;
  }
  .main-section02 .inner .cont-area figure {
    width: 100%;
    height: auto;
  }
  .main-section02 .inner .cont-area figure img {
    top: 0;
    transform: none;
  }
  .main-section02 .inner .cont-area .text-area .main-about-title {
    font-size: 28px;
  }
  .main-section02 .inner .cont-area .text-area .main-about-title .mo_cont {
    display: block;
  }
  .main-section02 .inner .cont-area .text-area p span {
    font-size: 18px;
    line-height: 1.55;
  }
  .main-section03 {
    padding: 100px 24px;
  }
  .main-section03 .rolling-text-area .item-inner {
    gap: 60px 30px;
  }
  .main-section03 .rolling-text-area .item-inner .point-text {
    font-size: 60px;
    line-height: normal;
  }
  .main-section03 .rolling-text-area .item-inner .sub-text {
    margin-top: 16px;
    font-size: 16px;
    line-height: 24px;
    font-weight: 500;
  }
  .main-section04 {
    padding: 120px 24px;
  }
  .main-section04 .inner .item-wrap {
    gap: 48px 28px;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 60px;
  }
  .main-section04 .inner .item-wrap .item .tit {
    font-size: 20px;
    line-height: 28px;
  }
  .main-section04 .inner .item-wrap .item .txt {
    font-size: 14px;
  }
  .main-section06 {
    padding: 120px 24px;
  }
  .main-section06 .inner .title-sub-text {
    font-size: 16px;
  }
  .main-section06 .inner .main-portfolio-list {
    display: grid;
    gap: 20px 48px;
    grid-template-columns: repeat(2, 1fr);
    margin: 0;
  }
  .main-section06 .inner .main-portfolio-list > li:last-child {
    display: grid;
   }
  .main-section06 .inner .btn-round {
    margin-top: 40px;
  }
  .main-section05 {
    padding: 120px 0;
  }
  .main-section05 .inner {
    margin: 0 auto;
  }
  .main-section05 .inner .map-wrap .map-button > .btn {
    height: 54px;
    padding: 0 22px;
    font-size: 16px;
    line-height: 54px;
  }
  .main-section05 .inner .map-wrap .map-button > .btn[aria-selected=true]:after {
    left: 24px;
    right: 24px;
  }
  .main-section05 .inner .map-wrap .btn-pin-wrap {
    position: absolute;
  }
  .main-section05 .inner .map-wrap .btn-pin-wrap .pin-text {
    display: none;
    padding: 6px 16px;
    font-size: 14px;
    line-height: 22px;
  }
  .main-section05 .inner .map-wrap .btn-pin-wrap.is-text .pin-text {
    display: none;
    left: 32px;
    top: 2px;
  }
  .main-section05 .inner .map-wrap .btn-pin-wrap.is-active .pin-text {
    display: block;
  }
  .main-section05 .inner .map-wrap .btn-pin-wrap.boston .pin-text, .main-section05 .inner .map-wrap .btn-pin-wrap.telaviv .pin-text, .main-section05 .inner .map-wrap .btn-pin-wrap.tokyo .pin-text {
    left: auto;
    right: 32px;
  }
  @keyframes animation-pulse {
    0% {
      width: 28px;
      height: 28px;
    }
    50% {
      opacity: 1;
    }
    100% {
      opacity: 0.9;
      width: 56px;
      height: 56px;
    }
  }
  .main-section05 .inner .map-wrap .map-inner .img {
    height: 380px;
  }
  .main-section05 .inner .map-wrap .map-inner .img #worldMapSvg {
    height: 380px;
  }
  .main-section05 .inner .map-wrap .btn-pin {
    width: 22px;
    height: 30px;
  }
  .main-section05 .inner .infor-text {
    min-height: 92px;
    margin-top: 40px;
    padding: 0 24px;
  }
  .main-section05 .inner .infor-text .item a {
    flex-direction: column;
    gap: 12px;
  }
  .main-section05 .inner .infor-text .title-text {
    min-width: 100%;
    flex-shrink: 0;
    font-size: 20px;
    line-height: 32px;
  }
  .main-section05 .inner .infor-text .text {
    font-size: 16px;
    line-height: 24px;
  }
  .btn-round {
    padding: 0 24px !important;
    height: 32px !important;
    font-size: 12px !important;
    line-height: 30px !important;
  }
}
@media only screen and (max-width: 360px) {
  .main-section01 .visual-wrap {
    padding: 0 20px;
  }
  .main-section01 .visual-wrap .visual-top-area {
    display: block;
    padding-top: calc(100vw - 40px);
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
    width: 100%;
    padding: 0 40px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    display: none;
    font-size: 40px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p:first-child {
    display: block;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    display: block;
    font-size: 40px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    gap: 32px;
    margin-top: 48px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area {
    width: 80px;
    height: 80px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p {
    font-size: 12px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p br {
    display: none;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text .btn-round {
    margin-top: 20px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 {
    position: absolute;
    top: calc(100vw - 128px);
    right: 0;
    width: 132px;
    height: 132px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img {
    height: 132px;
  }
  .main-section02 {
    padding: 100px 20px;
  }
  .main-section02 .inner .cont-area {
    margin-top: 48px;
    gap: 48px;
  }
  .main-section02 .inner .cont-area .text-area .main-about-title {
    font-size: 24px;
    line-height: 1.33;
  }
  .main-section02 .inner .cont-area .text-area p {
    margin-top: 16px;
  }
  .main-section02 .inner .cont-area .text-area p span {
    font-size: 16px;
    line-height: 1.75;
  }
  .main-section03 {
    padding: 100px 20px;
  }
  .main-section03 .rolling-text-area .item-inner .point-text {
    font-size: 48px;
  }
  .main-section03 .rolling-text-area .item-inner .sub-text {
    font-size: 12px;
    line-height: 18px;
  }
  .main-section04 {
    padding: 100px 20px;
  }
  .main-section04 .inner .item-wrap {
    margin-top: 48px;
    gap: 40px 24px;
  }
  .main-section04 .inner .item-wrap .item .tit {
    font-size: 16px;
    line-height: 22px;
  }
  .main-section04 .inner .item-wrap .item .txt {
    font-size: 12px;
    line-height: 18px;
  }
  .main-section05 {
    padding: 100px 0;
  }
  .main-section05 .inner .map-wrap .map-button > .btn {
    font-size: 14px;
    padding: 0 16px;
  }
  .main-section05 .inner .map-wrap .map-button > .btn[aria-selected]:after {
    left: 16px;
    right: 16px;
  }
  .main-section05 .inner .infor-text {
    min-height: 88px;
    margin-top: 40px;
    padding: 0 20px;
  }
  .main-section05 .inner .infor-text .title-text {
    font-size: 16px;
  }
  .main-section05 .inner .infor-text .text {
    font-size: 14px;
    line-height: 22px;
  }
  .main-section06 {
    padding: 100px 20px;
  }
  .main-section06 .inner .title-sub-text {
    font-size: 14px;
    letter-spacing: -0.02em;
  }
}
@media only screen and (max-width: 320px) {
  .main-section01 .visual-wrap {
    padding: 0 16px;
  }
  .main-section01 .visual-wrap .visual-top-area {
    display: block;
    padding-top: calc(100vw - 32px);
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
  }
  .main-section01 .visual-wrap .visual-top-area .img-motion01 .motion-img {
    width: 100%;
    height: calc(100vw - 108px);
    padding: 0 38px;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p {
    display: none;
    font-size: 38px;
    letter-spacing: -0.01em;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p:first-child {
    display: block;
  }
  .main-section01 .visual-wrap .visual-top-area .text-area-big p span {
    display: block;
    font-size: 40px;
  }
  .main-section01 .visual-wrap .visual-bottom-area {
    gap: 20px;
    margin-top: 48px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .video-area {
    width: 80px;
    height: 80px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p {
    font-size: 12px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text p br {
    display: none;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .text .btn-round {
    margin-top: 20px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 {
    position: absolute;
    top: calc(100vw - 107px);
    right: 0;
    width: 116px;
    height: 116px;
  }
  .main-section01 .visual-wrap .visual-bottom-area .cont-area .img-motion02 .motion-img {
    height: 116px;
  }
  .main-section02 .inner .cont-area .text-area p span {
    line-height: 1.5;
  }
  .main-section02, .main-section03, .main-section04, .main-section06 {
    padding: 100px 16px;
  }
  .main-section04 {
    padding: 100px 20px;
  }
  .main-section04 .inner .item-wrap {
    gap: 40px 20px;
  }
  .main-section05 .inner .map-wrap .map-inner .img {
    height: 300px;
  }
  .main-section05 .inner .map-wrap .map-inner .img #worldMapSvg {
    height: 300px;
  }
  .main-section05 .inner .map-wrap .map-button > .btn {
    padding: 0 15px;
  }
}
/* main interection */
/* section1 */
.img-motion01 .motion-img {
  opacity: 0;
  z-index: 0;
  transition: opacity 1.5s ease-in-out;
}

.img-motion02 .motion-img {
  /* position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; */
  opacity: 0;
  z-index: 1;
  transition: opacity 1.5s ease-in-out;
}

.img-motion01 .motion-img.first {
  animation: doorOpen 0s ease-in-out both;
}

.img-motion02 .motion-img.first {
  animation: doorOpen 0s ease-in-out both;
}

.img-motion01 .motion-img.active {
  opacity: 1;
}

.img-motion02 .motion-img.active {
  opacity: 1;
  z-index: 1;
}

@keyframes doorOpen {
  0% {
    clip-path: inset(0 50% 0 50%);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    clip-path: inset(0 0% 0 0%);
    opacity: 1;
  }
}
/* section2 */
.scroll-up-animate {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease-out, transform 0.7s ease-out;
}

.scroll-up-animate.active {
  opacity: 1;
  transform: translateY(0);
}

.scroll-up-animate.delay {
  transition-delay: 0.5s;
}

@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* section4 */
.main-section04 .item .tit,
.main-section04 .item .txt {
  opacity: 0;
  transform: translateX(-30px);
}

.main-section04 .item.reverse .tit,
.main-section04 .item.reverse .txt {
  transform: translateX(30px);
}

.main-section04 .item:not(.reverse) .tit.animate-in,
.main-section04 .item:not(.reverse) .txt.animate-in {
  opacity: 1;
  transform: translateX(0);
  animation: slideInLeft 0.7s ease-out;
}

.main-section04 .item.reverse .tit.animate-in,
.main-section04 .item.reverse .txt.animate-in {
  opacity: 1;
  transform: translateX(0);
  animation: slideInRight 0.7s ease-out;
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
/* section6 */
.main-portfolio-list li img {
  opacity: 0;
}

.main-portfolio-list li img.fade-in {
  animation: fadeOnly 0.7s ease-out forwards;
}

@keyframes fadeOnly {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
:lang(en) .main-section01 .visual-wrap .visual-bottom-area .cont-area .text .btn-round {
  width: auto;
}