@charset "utf-8";

.mo {display: none;}

/* 공통 */
.section-header {margin-bottom: 70px;}
.section-header h3 {font-size: 58px; font-weight: 600; color: #fff; text-align: center;}
.section-header p {font-size: 22px; line-height: 1.8; color: rgba(255,255,255, .8); text-align: center; margin-top: 40px;}


.btn-box {display: flex; gap: 15px; width: 100%;}
.btn-box > a {position: relative; display: block; flex: 1 1 auto; border-radius: 30px; border: 1px solid #fff; line-height: 54px; padding: 0 30px; font-size: 18px; color: #fff; font-weight: 500; transition: all .2s linear;}
.btn-box > a:hover {background-color: #177ae0; border-color: #177ae0;}
.btn-box > a::after {position: absolute; content: ''; width: 45px; height: 19px; background: url(../images/main/ico_arrow.png) 50% 50% no-repeat; background-size: auto; top: 50%; right: 30px; transform: translateY(-50%);}


/* m-visual */
.m-visual {padding: 0;}
.m-visual .visual {width: 100%; height: 970px; position: relative;}
.m-visual .visual .swiper-wrapper {transition-timing-function: linear;}
.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); background-color: #444;}
.m-visual .visual .swiper-wrapper .slide03 .backdrop {background-image: url(../images/main/m-visual03.jpg); background-color: #444;} 
.m-visual .visual .swiper-wrapper .slide04 .backdrop {background-image: url(../images/main/m-visual04.jpg); background-color: #444;} 
.m-visual .visual .swiper-wrapper .slide05 .backdrop {background-image: url(../images/main/m-visual05.jpg); background-color: #444;} 
/* .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 .img {position: absolute; top: 290px; left: 15px; opacity: 0; transition: all 1.2s ease .1s;}
.m-visual .visual .swiper-wrapper .swiper-slide .container .img img {max-width: 100%;}
.m-visual .visual .swiper-wrapper .swiper-slide .container p {position: absolute; top: 395px; left: 15px; font-size: 24px; line-height: 1.75; color: #fff; font-weight: 400; width: 100%; opacity: 0; transition: all 1.2s ease .5s;}
.m-visual .visual .swiper-wrapper .swiper-slide .container .btn-box {position: absolute; left: 15px; top: 550px; opacity: 0; transition: all 1.2s ease .9s; max-width: 704px;}
.m-visual .visual .swiper-wrapper .swiper-slide .container span {display: block; position: absolute; left: 15px; bottom: 235px; font-size: 20px; color: #fff; opacity: 0; transition: all 1.2s ease 1.3s;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container .img {top: 330px; opacity: 1;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container p {top: 435px; opacity: .8;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container .btn-box {top: 590px; opacity: 1;}
.m-visual .visual .swiper-wrapper .swiper-slide-active .container span {bottom: 200px; opacity: .8;}

.controls {position: absolute; bottom: 80px; left: 0; width: 100%; z-index: 2;}
.controls .btn-area {position: relative; width: 670px;}
.controls .btn-area .visual-pagination {width: 100%; gap: 30px; display: flex;}
.swiper-pagination-bullet {margin: 0 !important; position: relative; background-color: transparent !important; opacity: 1 !important; transition: all .3s linear; height: 16px !important; width: auto !important;}
.swiper-pagination-bullet span {position: relative; display: block; font-size: 16px; color: #fff; opacity: .3; padding-left: 18px; font-weight: 600; transition: all .3s linear;}
.swiper-pagination-bullet span::before {position: absolute; content: ''; width: 6px; height: 6px; background-color: #fff; border-radius: 50%; top: 50%; left: 0; transform: translateY(-50%); transition: all .3s linear;}
.swiper-pagination-bullet-active {padding-right: 150px;}
.swiper-pagination-bullet-active span {opacity: 1;}
.swiper-pagination-bullet-active span::before {background-color: #177ae0;}
.controls .btn-area .progress-bar {position: absolute; width: 130px; height: 3px; background-color: transparent; top: 50%; transform: translateY(-50%); transition: all .15s linear;}
.controls .btn-area .progress-bar svg {position: absolute; --progress: 0; top: 1px; left: 0; width: 100%; stroke-width: 3px; stroke: #fff; fill: none; stroke-dashoffset: calc(100 * (1 - var(--progress))); stroke-dasharray: 100;}
.controls.s1 .btn-area .progress-bar {left: 103px;}
.controls.s2 .btn-area .progress-bar {left: 205px;}
.controls.s3 .btn-area .progress-bar {left: 338px;}
.controls.s4 .btn-area .progress-bar {left: 427px;}
.controls.s5 .btn-area .progress-bar {left: 540px;}

.scroll {position: absolute; z-index: 1; bottom: 80px; left: 93px; width: 10px; height: 100px; 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%; padding: 125px 0; background: url(../images/main/bg_sec2.jpg) 50% 50% no-repeat; background-size: cover;}
.sec2 .btn-box {max-width: 464px; margin: 0 auto;}

/* sec3 */
.sec3 {width: 100%; padding: 175px 0 160px; background: url(../images/main/bg_sec3.jpg) 50% 50% no-repeat; background-size: cover;}
.sec3 .section-header ~ .section-header {margin-top: 220px;}
.sec3 .section-header h3 {text-align: left; line-height: 1.241;}
.sec3 .section-header h3 > span {color: rgba(255,255,255, .3);}
.sec3 .section-header.sh2 {width: 100%; display: flex; align-items: flex-start; margin-bottom: 0;}
.sec3 .section-header .img {max-width: 745px; width: 100%;}
.sec3 .section-header .img img {max-width: 100%; display: block;}
.sec3 .section-header h4 {font-size: 48px; color: #fff; font-weight: 600; font-family: 'Poppins'; margin-top: 40px;}
.sec3 .section-header .txt {width: 1%; flex: 1 1 auto;}
.sec3 .section-header p {text-align: left; margin-top: 0; margin-bottom: 70px; letter-spacing: -.6px;}
.sec3 .btn-box {max-width: 225px;}
