@charset "utf-8";

.pl {font-family: 'Play';}
.mo {display: none;}

@keyframes text-top {
    0% {
        transform: translateY(70px); opacity: 0;
    }
    100% {
        transform: translateY(0px);
        opacity: 1;
    }
}


@keyframes text-right {
    0% {
        transform: translateX(-50px); opacity: 0;
    }
    100% {
        transform: translateX(0px);
        opacity: 1;
    }
}

@keyframes text-left {
    0% {
        transform: translateX(50px); opacity: 0;
    }
    100% {
        transform: translateX(0px);
        opacity: 1;
    }
}

/* fullpage nav */
#fp-nav {position: fixed; top: 50%; right: 60px; transform: translateY(-50%); margin-top: 0 !important;}
#fp-nav li {margin-bottom: 22px;} 
#fp-nav li a {position: relative; display: block; width: 8px; height: 8px; background: transparent; transition: all 0.4s; border: 1px solid #fff;}
#fp-nav li a.active {background: #fff;}
/* #fp-nav li:last-child {display: none;} */
.fp-viewing-FOOTER #fp-nav {display: none;}


/* m-visual */
.m-visual {padding: 0;}
.m-visual .visual {width: 100%; height: 970px; position: relative; }
.m-visual .visual .swiper-wrapper .swiper-slide .backdrop {width: 100%; height: 100%; background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; transition: all 2s ease;}
.m-visual .visual .swiper-wrapper .slide01 .backdrop {background-image: url(../images/main/m-visual01.jpg);}
.m-visual .visual .swiper-wrapper .slide02 .backdrop {background-image: url(../images/main/m-visual02.jpg);}
.m-visual .visual .swiper-wrapper .slide03 .backdrop {background-image: url(../images/main/m-visual03.jpg);} 
.m-visual .visual .swiper-wrapper .swiper-slide-active .backdrop {transform: scale(1.1);}
.m-visual .visual .swiper-wrapper .swiper-slide .container {width: 100%; height: 100%; position: absolute; top: 0; left: 50%; transform: translateX(-50%);}
.m-visual .visual .swiper-wrapper .swiper-slide .container h3 {position: absolute; top: 290px; left: 15px; font-size: 70px; line-height: 1.214; color: #fff; font-weight: 700;  width: 100%; opacity: 0; transition: all 1.2s ease .15s;}
.m-visual .visual .swiper-wrapper .swiper-slide .container p {position: absolute; top: 490px; left: 15px; font-size: 26px; line-height: 35px; color: #fff; font-weight: 400; width: 100%; opacity: 0; transition: all 1.2s ease .5s;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container h3 {top: 330px; opacity: 1;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container p {top: 530px; opacity: 1;}

.controls {position: absolute; top: 620px; left: 0; width: 100%; z-index: 5;}
.controls .btn-area {position: relative; width: 270px; height: 100%; display: flex; align-items: center; justify-content: space-between;}
.controls .btn-area .visual-pagination {width: 175px; gap: 30px; display: flex;}
.swiper-pagination-bullet {margin: 0 !important; position: relative; background-color: transparent !important; opacity: 1 !important; height: 14px !important; width: 15px !important; transition: all .3s linear;}
.swiper-pagination-bullet-active {width: 95px !important;}
.swiper-pagination-bullet::before {position: absolute; content: ''; font-size: 14px; font-weight: 700; font-family: 'Play'; opacity: .5; color: #fff; top: 0; left: 0;}
.swiper-pagination-bullet:nth-of-type(1)::before {content: '01';}
.swiper-pagination-bullet:nth-of-type(2)::before {content: '02';}
.swiper-pagination-bullet:nth-of-type(3)::before {content: '03';}
.swiper-pagination-bullet-active::before {opacity: 1;}
.controls .btn-area .progress-bar {position: absolute; width: 60px; height: 1px; background-color: transparent; left: 125px; top: 50%; transform: translateY(-50%); transition: all .15s linear;}
.controls .btn-area .progress-bar svg {position: absolute; --progress: 0; top: 0; left: 0; width: 100%; stroke-width: 4px; stroke: #fff; fill: none; stroke-dashoffset: calc(100 * (1 - var(--progress))); stroke-dasharray: 100;}
.controls.s1 .btn-area .progress-bar {left: 125px;}
.controls.s2 .btn-area .progress-bar {left: 170px;}
.controls.s3 .btn-area .progress-bar {left: 215px;}


.controls .btn-area .btn-controls {width: 60px; height: 60px; background: url(../images/main/ico_pause.png) 50% 50% no-repeat; background-size: auto; border: 1px solid #fff;}
.controls .btn-area .btn-controls.play {background-image: url(../images/main/ico_play.png);}

.scroll {position: absolute; z-index: 1; bottom: 80px; left: 50%; transform: translateX(-50%); width: 24px; height: 32px; background: url(../images/main/scroll.png) 50% 50% no-repeat;background-size: auto; animation: bounce 1.3s ease infinite;}
@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
      transform: translateY(0);
    }
  
    40% {
      transform: translateY(-10px);
    }
  
    60% {
      transform: translateY(-5px);
    }
}

/* sec2 */
.sec2 {width: 100%;}
.product {width: 100%; height: 100%; display: flex;}
.product li {width: 33.3333%;}
.product li a {position:relative; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: 100%; background: url() 50% 50% no-repeat; background-size: cover;}
.product li a::after {position: absolute; content: ''; width: 100%; height: 0%; bottom: 0; left: 0; background-color: #112952; opacity: .9; z-index: 0; transition: all .3s linear;}
.product li:nth-of-type(1) a {background-image: url(../images/main/img_sec201.jpg);}
.product li:nth-of-type(2) a {background-image: url(../images/main/img_sec202.jpg);}
.product li:nth-of-type(3) a {background-image: url(../images/main/img_sec203.jpg);}
.product li a small {display: block; width: 100%; text-align: center; font-size: 22px; font-weight: 400; color: rgba(255,255,255, .5); position: relative; z-index: 1; transition: all .2s linear;}
.product li a h5 {font-size: 50px; font-weight: 700; color: #fff; text-align: center; padding-top: 30px; line-height: 55px; position: relative; z-index: 1; transition: all .2s linear;}
.product li a .txt {padding-top: 80px; text-align: center; position: relative; z-index: 1; height: 0; opacity: 0; transition: all .5s linear;}
.product li a .txt::before {position: absolute; content: ''; width: 1px; height: 40px; background-color: #fff; top: 20px; left: 50%; transform: translateX(-50% + 0.5px); opacity: 1;}
.product li a .txt p {font-size: 20px; color: rgba(255,255,255, .6); line-height: 1.7;}
.product li a .txt span {position: relative; display: block; max-width: 180px; width: 100%; font-size: 20px; font-weight: 400; color: #fff; margin: 30px auto 0; line-height: 64px; padding: 0 30px; background: url(../images/main/ico_arrow.png) calc(100% - 30px) calc(50% + 3px) no-repeat; background-size: auto; text-align: left; transition: all .3s linear;}
.product li a .txt span::after {position: absolute; content: ''; width: 100%; height: 100%; top: 0; left: 0; background: url(../images/main/bg_btn.png) 50% 50% no-repeat; background-size: auto; transition: all .3s linear;}
.product li a:hover::after {height: 100%;}
.product li a:hover small {animation: opacity .5s linear;}
.product li a:hover h5 {animation: opacity .5s linear;}
.product li a .txt span:hover {color: #112952; background-image:url(../images/main/ico_arrow_on.png); font-weight: 500;}
.product li a .txt span:hover::after {background-image:url(../images/main/bg_btn_on.png); z-index: -1;}
.product li a:hover .txt {height: auto; opacity: 1;}
@keyframes opacity {
  0% {opacity: 0;}
  20% {opacity: 0;}
  100% {opacity: 1;}
}

.sec2.on .product li:nth-of-type(1) a {animation: text-top 1.5s both .3s;}
.sec2.on .product li:nth-of-type(2) a {animation: text-top 1.5s both .5s;}
.sec2.on .product li:nth-of-type(3) a {animation: text-top 1.5s both .7s;}


/* sec3 */
.sec3 {width: 100%; background: url() 50% 50% no-repeat; background-size: cover; transition: all .3s linear; display: flex; flex-direction: column; align-items: center; justify-content: center; transition: all .3s linear;}
.sec3.on1 {background-image: url(../images/main/bg_sec301.jpg);}
.sec3.on2 {background-image: url(../images/main/bg_sec302.jpg);}
.sec3.on3 {background-image: url(../images/main/bg_sec303.jpg);}
.sec3.on4 {background-image: url(../images/main/bg_sec304.jpg);}
.section-header span {display: block; font-size: 22px; color: #fff;}
.section-header h3 {font-size: 48px; font-weight: 700; color: #fff; line-height: 1.4; margin-top: 35px;}
.sec3 .about {margin-top: 85px; width: 100%;}
.sec3 .about ul {width: 100%; display: flex;}
.sec3 .about ul li {width: 25%; min-height: 287px; position: relative;}
.sec3 .about ul li:not(:last-child)::after {position: absolute; content: ''; width: 1px; height: calc(100% - 7px); top: 7px; right: 0; background-color: rgba(255,255,255, .6);}
.sec3 .about ul li a {width: 100%; display: block; height: 100%; opacity: .6; text-align: center; transition: all .2s linear; position: relative;}
.sec3 .about ul li a dl dt {max-width: 130px; width: 100%; margin: 0 auto;}
.sec3 .about ul li a dl dt img {max-width: 100%; display: block; margin: 0 auto;}
.sec3 .about ul li a dl dd {margin-top: 40px; font-size: 32px; font-weight: 600; color: #fff; text-align: center;}
.sec3 .about ul li a span {position: relative; display: block; max-width: 180px; width: 100%; font-size: 20px; font-weight: 400; color: #fff; margin: 30px auto 0; line-height: 64px; padding: 0 30px; opacity: 0; transition: all .2s linear; z-index: 2;background: url(../images/main/bg_btn2.png) 50% 50% no-repeat; background-size: auto;}
.sec3 .about ul li a span > i {display: inline-block; margin-left: 15px;}
.sec3 .about ul li a span > i img {display: block;}
.sec3 .about ul li a:hover {opacity: 1;}
.sec3 .about ul li a:hover span {opacity: 1;}

.sec3.on .section-header span {animation: text-right 1.5s both .3s;}
.sec3.on .section-header h3 {animation: text-right 1.5s both .6s;}
.sec3.on .about ul {animation: text-top 1.5s both .9s;}

/* sec4 */
.sec4 .inner {width: 100%; height: 551px; background: url(../images/main/bg_sec4.jpg) 50% 50% no-repeat; background-size: cover;}
.sec4 .inner > .container {width: 100%; display: flex; align-items: flex-end; justify-content: space-between;}
.sec4 .section-header {padding-top: 195px;}
.sec4 .section-header span {font-size: 20px; font-weight: 700; color: #112952;}
.sec4 .section-header h3 {font-size: 48px; font-weight: 700; color: #000; line-height: 1.4; margin-top: 35px;}
.sec4 .box {display: block; width: 160px; margin-right: 130px; height: 160px;}
.sec4 .more {position: relative; display: block; width: 100%; height: 100%; background: url(../images/main/bg_btn3.png) 50% 50% no-repeat; background-size: cover; padding: 20px;  transition: all .2s linear;}
/* .sec4 .box:hover .more {height: 60px; margin-top: 100px;} */
.sec4 .box:hover .more > i {top: 25px; right: 25px}
.sec4 .more > i {position: absolute; top: 20px; right: 20px; transition: all .2s linear;}
.sec4 .more > i img {display: block;}
.sec4 .more > span {font-size: 20px; color: #fff; position: absolute; bottom: 20px; left: 20px; transition: all .2s linear; line-height: 1;}

.sec4.on .section-header span {animation: text-right 1.5s both .3s;}
.sec4.on .section-header h3 {animation: text-right 1.5s both .6s;}
.sec4.on .more {animation: text-left 1.5s both .6s;}