.main-mv {
    position: relative;
    height: 100vh;
}

.main-mv_slide {
    width: 100vw;
    height: 100%;
}

.main-mv_slide .slick-list,
.main-mv_slide .slick-track {
    height: 100%;
}

.main-mv_slide .item {
    height: 100%;
    position: relative;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.main-mv_slide .item .inner {
    width: 100%;
    padding-bottom: 144px;
}

.main-mv_slide .item.slick-current .main-mv_bg img {
    -webkit-transform: scale(1);
    transform: scale(1);
}

.main-mv_slide .slick-nav {
    position: absolute;
    bottom: 25%;
    left: 0%;
    right: 0;
    overflow: hidden;
    max-width: 1400px;
    margin: auto;
}

.main-mv_slide .slick-nav__dots {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 10px;
}

.main-mv_slide .slick-nav__btns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: 20px;
    gap: 20px;
}

.main-mv_slide .slick-nav__btns button {
    overflow: hidden;
    color: transparent;
    width: 9px;
    height: 14px;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
}

.main-mv_slide .slick-nav__btns button.slick-nav__pause {
    width: 15px;
    height: 15px;
}

.main-mv_slide .slick-nav__pause {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    background-image: url("/image/common/pause.svg");
}

.main-mv_slide .slick-nav__pause.paused {
    background-image: url("/image/common/play.svg");
}

.main-mv_slide .slick-nav__prev {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    background-image: url("/image/common/prev.svg");
}

.main-mv_slide .slick-nav__next {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    background-image: url("/image/common/next.svg");
}

.main-mv_slide .circle_fill circle {
    stroke: #fff !important;
    stroke-width: 2px;
}

.main-mv_slide .circle_dot {
    width: 8px !important;
    height: 8px !important;
    background-color: #fff !important;
}

.main-mv_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
}

.main-mv_bg img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    -webkit-transition: -webkit-transform 4.5s ease;
    transition: -webkit-transform 4.5s ease;
    transition: transform 4.5s ease;
    transition: transform 4.5s ease, -webkit-transform 4.5s ease;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
}

.main-mv_txt span {
    font-family: var(--outfit);
    color: #FFF;
    font-size: 80px;
    font-weight: 500;
    line-height: 1;
}

.main-mv_desc {
    color: #FFF;
    font-size: 24px;
    font-weight: 400;
    margin-top: 40px;
    opacity: 0;
    transform: translateY(50px);
}

.main-mv_slide .slick-active .splitting .char {
    opacity: 1;
    -webkit-animation: text-active-animation 1s calc(0.05s * var(--char-index)) cubic-bezier(0.4, 0, 0.2, 1) both;
    animation: text-active-animation 1s calc(0.05s * var(--char-index)) cubic-bezier(0.4, 0, 0.2, 1) both;
}

.main-mv_slide .slick-active .main-mv_desc {
    opacity: 1;
    transform: translateY(0);
    transition: all 1.5s 1.2s;
}

.splitting {
    overflow: hidden;
    display: block;
}

.splitting .char {
    display: inline-block;
    opacity: 0;
    line-height: 1.2em;
    overflow: hidden;
}

.splitting .word {
    line-height: 0;
    overflow: hidden;
    display: inline-block;
}

@-webkit-keyframes text-active-animation {
    from {
        opacity: 0;
        filter: Alpha(opacity=0);
        -webkit-transform: translateY(50px);
        transform: translateY(50px);
    }
    to {
        opacity: 1;
        filter: Alpha(opacity=100);
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

@keyframes text-active-animation {
    from {
        opacity: 0;
        filter: Alpha(opacity=0);
        -webkit-transform: translateY(50px);
        transform: translateY(50px);
    }
    to {
        opacity: 1;
        filter: Alpha(opacity=100);
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

@-webkit-keyframes text-fade-out {
    from {
        opacity: 1;
        filter: Alpha(opacity=100);
    }
    to {
        opacity: 0;
        filter: Alpha(opacity=0);
    }
}

@keyframes text-fade-out {
    from {
        opacity: 1;
        filter: Alpha(opacity=100);
    }
    to {
        opacity: 0;
        filter: Alpha(opacity=0);
    }
}

.mainPage > section {
    padding: 120px 0;
}

.main-tit span {
    color: var(--keyColor);
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 5px;
    display: block;
}

.main-tit h2 {
    font-size: 60px;
    font-weight: 500;
    line-height: 1.3em;
}

.main-data .data-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 40px;
    margin-top: 60px;
}

.main-data .data-list li {
    width: 100%;
}

.main-data .data-list li .iconBox {
    border-radius: 20px;
    background: var(--bgColor);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    flex-direction: column;
    gap: 20px;
    overflow: hidden;
    height: 240px;
    margin-bottom: 10px;
}

.main-data .data-list li .iconBox p {
    text-align: center;
    font-size: 22px;
    font-weight: 500;
    line-height: 100%; /* 22px */
}

.main-data .data-list li .textBox {
    border-radius: 20px;
    border: 1px solid #DDD;
    padding: 23px 25px;
    display: flex;
    align-items: center;
    min-height: 150px;
}

.main-data .data-list .dotList {
    gap: 3px;
}

.main-data .data-list .dotList > li {
    color: #666;
}

.main-addition .addition-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 40px;
    margin-top: 60px;
    flex-wrap: wrap;
}

.main-addition .addition-list > li {
    width: calc(50% - 20px);
    display: flex;
    align-items: center;
}

.main-addition .addition-list > li .iconBox {
    border-radius: 20px;
    background: var(--bgColor);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: hidden;
    height: 200px;
    width: 200px;
    margin-right: 10px;
}

.main-addition .addition-list > li .textBox {
    border-radius: 20px;
    border: 1px solid #DDD;
    padding: 20px 40px;
    min-height: 200px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.main-addition .addition-list > li .textBox h6 {
    font-size: 24px;
    font-weight: 500;
    margin-bottom: 15px;
}

.main-addition .addition-list .dotList {
    gap: 3px;
}

.main-addition .addition-list .dotList > li {
    color: #666;
    font-size: 18px;
}

.main-addition .addition-list .dotList > li em {
    font-weight: 400;
}

.main-technology .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.main-technology .technology-left {
    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;
}

.main-technology .technology-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 80px;
}

.main-technology .technology-list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 60px;
}

.main-technology .technology-list li > div {
    flex: 1;
}

.main-technology .technology-list h6 {
    color: var(--keyColor);
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 15px;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
}

.main-technology .technology-list p {
    font-size: 16px;
    font-weight: 400;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
}

.main-service {
    padding: 0;
}

.main-service .carousel-wrap {
    font-size: 120px;
    font-weight: 500;
    white-space: nowrap;
}

.main-service > .inner-L {
    border-radius: 20px;
    background: var(--bgColor);
    margin-top: 20px;
    padding: 90px 4%;
}

.main-service .service-tit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.main-service .service-tit h3 {
    font-size: 28px;
    font-weight: 400;
}

.main-service .service-tit h3 strong {
    font-weight: 500;
}

.main-service .service-tit .commonBtn {
    margin-top: 40px;
}

.main-service .service-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 20px;
    margin-top: 80px;
}

.main-service .service-list > li {
    width: 100%;
    height: 520px;
    border-radius: 20px;
    border: 1px solid #ddd;
    position: relative;
}

.main-service .service-list > li:hover .service-list_bg {
    opacity: 1;
    left: -21px;
    right: -21px;
    top: -29px;
    bottom: -29px;
}

.main-service .service-list > li:hover .service-list_bg img {
    -webkit-transform: scale(1);
    transform: scale(1);
}

.main-service .service-list > li:hover .service-txt h6 {
    -webkit-animation: service-txt-animation 0.7s cubic-bezier(0.4, 0, 0.2, 1) both;
    animation: service-txt-animation 0.7s cubic-bezier(0.4, 0, 0.2, 1) both;
    color: #FFF;
}

.main-service .service-list > li:hover .service-txt .dotList li {
    -webkit-animation: service-txt-animation 0.7s 0.1s cubic-bezier(0.4, 0, 0.2, 1) both;
    animation: service-txt-animation 0.7s 0.1s cubic-bezier(0.4, 0, 0.2, 1) both;
    color: #FFF;
}

.main-service .service-list > li:hover .service-txt .commonBtn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-animation: service-txt-animation 0.7s 0.2s cubic-bezier(0.4, 0, 0.2, 1) both;
    animation: service-txt-animation 0.7s 0.2s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.main-service .service-list .service-list_bg {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    overflow: hidden;
    border-radius: 20px;
    opacity: 0;
    -webkit-transition: all 0.3s 0.1s, opacity 0.5s 0s;
    transition: all 0.3s 0.1s, opacity 0.5s 0s;
}

.main-service .service-list .service-list_bg img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-transform: scale(1.17);
    transform: scale(1.17);
    -webkit-transition: -webkit-transform 0.3s 0.1s;
    transition: -webkit-transform 0.3s 0.1s;
    transition: transform 0.3s 0.1s;
    transition: transform 0.3s 0.1s, -webkit-transform 0.3s 0.1s;
}

.main-service .service-list .service-list_grayBg {
    padding: 20px 25px;
}

.main-service .service-list .service-txt {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px 25px;
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
    min-height: 232px;
}

.main-service .service-list .service-txt h6 {
    font-size: 26px;
    font-weight: 600;
    margin-bottom: 5px;
    -webkit-transition: color 0.3s;
    transition: color 0.3s;
}

.main-service .service-list .service-txt .dotList {
    gap: 0;
}

.main-service .service-list .service-txt .dotList li {
    font-size: 17px;
    font-weight: 400;
    color: var(--textGray);
    -webkit-transition: color 0.3s;
    transition: color 0.3s;
}

.main-service .service-list .service-txt .commonBtn {
    margin-top: 10px;
    display: none;
}

.main-about .about-cards {
    margin-top: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 55px;
}

.main-about .about-cards > li {
    width: 100%;
    height: 530px;
}

.main-about .about-cards .card {
    display: block;
    border-radius: 20px;
    border: 1px solid #DDD;
    padding: 40px;
    height: 100%;
    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-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
}

.main-about .about-cards .card h3 {
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 10px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.main-about .about-cards .card p {
    color: var(--textGray);
    font-size: 16px;
    font-weight: 400;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.main-about .about-cards .card img {
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
    -webkit-transition: -webkit-filter 0.3s;
    transition: -webkit-filter 0.3s;
    transition: filter 0.3s;
    transition: filter 0.3s, -webkit-filter 0.3s;
}

.main-about .about-cards .card.on h3,
.main-about .about-cards .card:hover h3 {
    color: var(--keyColor);
}

.main-about .about-cards .card.on img,
.main-about .about-cards .card:hover img {
    -webkit-filter: grayscale(0);
    filter: grayscale(0);
}

.main-about .about-cards .col-1 .card {
    position: relative;
}

.main-about .about-cards .col-1 .card img {
    position: absolute;
    right: 40px;
    bottom: 40px;
}

.main-about .about-cards .col-2 .card {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    overflow: hidden;
    position: relative;
}

.main-about .about-cards .col-2 .card img {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    max-width: none;
}

.main-about .about-cards .col-2 .card h3 {
    opacity: 0.8;
    z-index: 1;
    color: #fff;
}

.main-about .about-cards .col-2 .card p {
    color: #fff;
    opacity: 0.6;
    z-index: 1;
}

.main-about .about-cards .col-2 .card:hover h3, .main-about .about-cards .col-2 .card:hover p {
    opacity: 1;
}

.main-about .about-cards .col-3 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 55px;
}

.main-about .about-cards .col-3 .card {
    padding: 33px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.main-about .about-cards .col-3 .card img {
    margin-bottom: 20px;
}

.main-rnd {
    background-color: var(--bgColor);
}

.main-rnd .rnd-cards {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 55px;
    margin-top: 100px;
}

.main-rnd .rnd-cards .card {
    width: 100%;
    height: 530px;
    border-radius: 20px;
    background: #FFF;
    padding: 40px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    position: relative;
}

.main-rnd .rnd-cards .card img {
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.main-rnd .rnd-cards .card .count {
    color: var(--textGray);
    font-size: 100px;
    font-weight: 500;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.main-rnd .rnd-cards .card p {
    color: var(--textGray);
    font-size: 18px;
    font-weight: 400;
    min-height: 90px;
    position: absolute;
    left: 40px;
    right: 40px;
    bottom: 40px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.main-rnd .rnd-cards .card:hover {
    -webkit-transform: translateY(-50px);
    transform: translateY(-50px);
    -webkit-box-shadow: 0px 0px 30px 5px rgba(113, 97, 239, 0.05);
    box-shadow: 0px 0px 30px 5px rgba(113, 97, 239, 0.05);
}

.main-rnd .rnd-cards .card:hover img {
    -webkit-filter: grayscale(0);
    filter: grayscale(0);
}

.main-rnd .rnd-cards .card:hover .count {
    color: var(--keyColor);
}

.main-rnd .rnd-cards .card:hover p {
    color: var(--textBlack);
}

.partnerWrap .item {
    margin: auto 30px;
}

.partnerWrap .item img {
    margin: auto;
}

.parallaxWrap {
    margin-bottom: 60px;
}

.parallaxWrap .inner-L {
    height: 360px;
    background-image: url(/image/main/main-parallax.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    border-radius: 20px;
}

.parallaxWrap .inner {
    height: 100%;
    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: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.parallaxWrap .inner p {
    color: #FFF;
    font-size: 60px;
    font-weight: 500;
    line-height: 1.3em;
    margin-bottom: 40px;
}

@-webkit-keyframes service-txt-animation {
    from {
        opacity: 0;
        filter: Alpha(opacity=0);
        -webkit-transform: translate(-30px, 100px);
        transform: translate(-30px, 100px);
    }
    to {
        opacity: 1;
        filter: Alpha(opacity=100);
        -webkit-transform: translate(-30px, 30px);
        transform: translate(-30px, 30px);
    }
}

@keyframes service-txt-animation {
    from {
        opacity: 0;
        filter: Alpha(opacity=0);
        -webkit-transform: translate(-30px, 100px);
        transform: translate(-30px, 100px);
    }
    to {
        opacity: 1;
        filter: Alpha(opacity=100);
        -webkit-transform: translate(-30px, 30px);
        transform: translate(-30px, 30px);
    }
}