@charset "utf-8";

.mainBanner {position: relative; z-index: 1; height: 700px;}
.main-slide {height: 100%; background: #04050a;}
.banner-txt {width: 100%; height: 100%; background-position: 22% center; background-repeat: no-repeat; font-size: 20px; color: #fff; cursor:pointer;}
.banner-txt .container {display: flex; flex-direction: column; align-items: start; justify-content: center; width: 100%; height: 100%;}
.banner-txt h3 {margin-bottom: 5px; font-size: min(50px, 9vw); color: #fff;}
.banner-more {position: relative; min-width: 230px; margin-top: 43px; margin-bottom: 2rem; padding: 18px 40px; border-radius: 30px; background: #fff; font-size: 14px; color: #222; box-sizing: border-box; transition: all 0.2s;}
.banner-more:after {content:''; position: absolute; right: 40px; top: 50%; transform: translateY(-50%); width: 27px; height: 16px; background-image: url('/img/main/main_banner_arrow.png'); background-repeat: no-repeat; background-position: center; transition: all 0.2s;}
.banner-more:hover {background-color: rgba(255,255,255,0.7);}
.banner-more:hover:after {right: 30px;}

.main-slide .swiper-slide .view {position:absolute; top:0; left:0; width:100%; height:100%; background:no-repeat 50% 50%; background-size:cover; OVERFLOW:HIDDEN; cursor: pointer;}
.main-slide .swiper-slide video {position:absolute; top:52%; left:50%; width: 112%; min-width:100%; min-height:100%; transform: translateX(-50%) translateY(-51%);}
.main-slide .swiper-slide video[poster] {width:100%;}

.main-slide-controller {position: absolute; bottom: 90px; left: 0; right: 0; z-index: 10; max-width: 1920px; pointer-events: none;}
.main-slide-controller .container {display: flex; align-items: center; position: relative; padding: 0;}
.slide-timer {position: relative; width: 50px; height: 50px; margin-right: 30px; transition: left 0.5s;}
.btn-control {position: absolute; left: 0; top: 0; z-index: 1; width: 50px; height: 50px; border:0; text-indent: -9999px; transition: .4s ease; pointer-events: auto;}
.btn-control:after {content:''; position: absolute; top: 50%; left: 50%; width: 0; height: 16px; border-color: transparent transparent transparent #fff; border-style: double; border-width: 0 0 0 14px; transform: translate(-50%, -50%); transition: .17s linear;}
.btn-control.is-pause:after {height: 0; margin-left: 2px; border-style: solid; border-width: 9px 0 9px 14px;}
.slide-timer .progress {width: 50px; height: 50px; overflow: visible; transform: rotate(-90deg); transition: .4s ease;}
.slide-timer .progress .top {fill: transparent; stroke: #fff; stroke-width: 3; stroke-dashoffset: 201px; stroke-dasharray: 201px; stroke-linecap: round;}
.slide-timer .progress .bottom {fill: transparent; stroke: rgba(255, 255, 255, 0.5); stroke-width: 3; stroke-dasharray: 201px;}
.main-prev, .main-next {position: inherit; left: auto; right: auto; width: 50px; height: 50px; margin-top: 0; transition: left 0.5s; border: 2px solid #fff; border-radius: 100%; pointer-events: auto;}
.main-prev {background: url('/img/main/main_banner_prev.png') no-repeat center;}
.main-next {margin-left: 10px; background: url('/img/main/main_banner_next.png') no-repeat center;}
.main-slide-controller .fraction {margin-left: 15px; width: auto; color: rgba(255, 255, 255, 0.6);}
.main-slide-controller .fraction > * {padding: 0 3px;}
.main-slide-controller .fraction .current-num {color: #fff;}
.main-slide .swiper-slide video.w-100 {width: 100%;height:100%;}

/* 메인 퀵메뉴 */
.mainQuick {padding: 20px 0; border-bottom: 1px solid #dddddd;}
.mainQuick .container {display: flex; justify-content: center;}
.mQuick-list {display: flex; justify-content: space-evenly;}
.mQuick-list > li {width: 132px; padding-top: 10px;}
.mQuick-list > li > a {position: relative; z-index: 9; display: block; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center top; font-family: 'EsaManru'; font-weight: 300; font-size: 14px; text-align: center; transition: all 0.2s;}
.mQuick-list > li > a:hover {transform: translateY(-10px);}
.mQuick-list > li > a > span {display: block; padding-top: 52%;}
.bubble {display:block; position: absolute; z-index: 1; padding: 5px 12px 5px; border-radius: 17px; font-style: normal; font-weight: 300; font-size: 11px; color: #fff; -webkit-animation: blink2 1.2s infinite;}
.bubble:after {content:''; display: block; width: 0; height: 0; border-right: 16px solid transparent; position: absolute; z-index: -1;}
.bubble {right: -33px; top: -25px; background-color: #00e46b; text-align: center;}
.bubble:after {bottom: -6px; left: 12px; border-top: solid 8px #00e46b;}
.mQuick-list .bubble-vct {right: -15px; background-color: #0074e0;}
.mQuick-list .bubble-vct:after {border-top-color: #0074e0;}
.quick-call {display: flex; justify-content: center; flex-direction: column; position: relative; margin-left: 7px; padding-left: 50px; font-family: 'EsaManru'; font-weight: 300;}
.quick-call:before {content:''; position: absolute; top: 1px; bottom: 1px; left: 0; width: 1px; background: #efefef;}
.quick-call span {font-size: 12px;}
.quick-call p {font-size: 13px;}
.quick-call h2 {font-size: 40px;}

#rightQuick .bubble {right: -9px;top: -15px;background-color:#ea4410;}
#rightQuick .bubble:after {border-top: solid 8px #ea4410;}

@-webkit-keyframes blink2 {
    0% {opacity:1; }
	49% {opacity:1;}
	50% {opacity:0;}
	99% {opacity:0;}
	100% {opacity:1; }
}

.main-tit-wrap {display: flex; justify-content: space-between; align-items: end;}
.main-tit-wrap h2 {font-family: 'bau'; font-weight: 500; font-size: 54px; line-height: 1.2; text-transform: uppercase;}
.main-tit-wrap h3 {font-weight: 400; font-size: 28px;}
.main-tit-wrap p {font-size: 20px; color: #555555;}
.btn-more:after {content:''; display: inline-block; width: 19px; height: 16px; margin-left: 20px; background: url('/img/main/icon_more.png') no-repeat center; vertical-align: middle; transition: all 0.2s;}
.btn-more:hover:after {transform: translateX(5px);}

/* 인터뷰 */
.mainInterview {}
.mainItvBox {display: flex; margin: 0 -10px; padding-top: 25px;}
.mainItvBox > li {flex: 1; padding: 0 10px;}
.mainItvBox > li .txt-wrap em {display: block; margin: 25px 0 7px; font-size: 22px;}
.mainItvBox > li:hover p {text-decoration: underline;} 
.mainItvBox > li p {color: #999999;}
.mainItvBox > li .img-wrap {position: relative; height: 450px; overflow: hidden; border-radius: 12px;}
.mainItvBox > li .img-wrap em {display: block; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; transition: all .7s cubic-bezier(.17,.57,.43,.89);}
.mainItvBox > li:hover .img-wrap em {scale: 1.1;}
.mainItvBox .mItv-lg {flex: 2.2;}
.itv-category {display: inline-block; padding: 3px 20px; border-radius: 3px; background: #efefef; font-weight: 600; color: #777777;}

/* 포트폴리오 */
.mainGallery {padding-top: 130px; padding-bottom: 130px;}
.mainGallery .main-tit-wrap {align-items: center;}
.mainGallery .right-wrap {display: flex; align-items: center;}
.main-tab {display: flex; padding-left: 25px; margin: 0 -5px;}
.main-tab > li {padding: 0 5px;}
.main-tab > li a {padding: 12px 20px; border: 2px solid #222222; border-radius: 4px;}
.main-tab > li.on a {background: #222; color: #fff;}
.mGalleryWrap {margin-top: 25px;}
.mGalleryCont {display: none; -ms-overflow-style: none;/* IE and Edge */ scrollbar-width: none;/* Firefox */}
.mGalleryCont.on {display: flex;}
.main-gallery-list {display: flex; -webkit-animation-name: marquee-text-animation; animation-name: marquee-text-animation; -webkit-animation-timing-function: linear;  animation-timing-function: linear; -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; animation-duration: 80s; will-change: transform;}
#gallery02 .main-gallery-list {animation-duration: 40s;}
.mGalleryWrap:hover .main-gallery-list {-webkit-animation-play-state: paused; animation-play-state: paused;}

@-webkit-keyframes marquee-text-animation {
	0% {-webkit-transform:translateX(0);transform:translateX(0)}
	to {-webkit-transform:translateX(-100%);transform:translateX(-100%)}
}
@keyframes marquee-text-animation {
	0% {-webkit-transform:translateX(0);transform:translateX(0)}
	to {-webkit-transform:translateX(-100%);transform:translateX(-100%)}
}

.main-gallery-list::-webkit-scrollbar{display:none;}
.main-gallery-list > li {flex: none; position: relative; width: 280px; height: 501px; transition: all .3s ease; -webkit-transition: all .3s ease;}
.main-gallery-list > li:hover {width: 300px;}
.main-gallery-list > li a {position: absolute; left: 10px; right: 10px; top: 33px; bottom: 33px; border-radius: 17px; background-position: center; background-repeat: no-repeat; font-size: 14px; transition: all .3s ease; -webkit-transition: all .3s ease;}
.main-gallery-list > li:hover a {top: 0; bottom: 0; left: 0; right: 0; background-size: cover;}
.main-gallery-name {position: absolute; top: -28px; overflow:hidden; padding: 0 7px; text-overflow:ellipsis; white-space:nowrap;}
.main-gallery-tag {position: relative; display: inline-block; padding: 5px 10px; margin-right: 7px; font-size: 12px; color: #00a24c; letter-spacing: 0.01em;}
.main-gallery-tag:before {content:''; width: 100%; height: 80%; position: absolute; top: 7%; left: 0; background:linear-gradient(to right, rgba(228, 241, 44, 0.3) 0%, rgba(228, 241, 44, 0.4) 60%, rgba(228, 241, 44, 0.4) 60%, rgba(228, 241, 44, 0.6) 85%, rgba(228, 241, 44, 0.8) 100%); border-radius: 17px 0/100px 20px; z-index: -1; transition: 0.1s ease;}

/* 취업 */
.emp-slide {position: relative; overflow: hidden; margin-top: 33px; border-radius: 13px; background: #f8f9fa;}
.emp-slide .swiper-slide a {display: block; padding: 30px 30px; padding-left: 130px; font-size: 20px;}
.emp-slide .swiper-slide a em {position: absolute; left: 17px; top: 25px; width: 102px; height: 80px; border-radius: 5px; background-color: #fff; background-repeat: no-repeat; background-position: center; background-size: contain;}
.emp-slide .swiper-slide a h5 {position: relative; display: inline-block; padding: 0 20px; margin-bottom: 15px; font-weight: 350; color: #555;}
.emp-slide .swiper-slide a h5:before, .emp-slide .swiper-slide a h5:after {content:''; position: absolute; left: auto; right: auto; top: 0; bottom: 0; width: 16px; background-repeat: no-repeat; background-position: center;}
.emp-slide .swiper-slide a h5:before {left: 0; background-image: url('/img/main/mEmploy_left.png');}
.emp-slide .swiper-slide a h5:after {right: 0; background-image: url('/img/main/mEmploy_right.png');}
.emp-slide .swiper-slide a p {color: #666;}
.emp-slide-controller {position: absolute; bottom: 30px; right: 45px;}
.emp-prev, .emp-next {width: 25px; height: 25px;}
.emp-prev {left: -52px; right: auto; top: 0; border-radius: 13px 0 0 13px; background: #999 url('/img/main/emp_slide_prev.png') no-repeat center;}
.emp-next {position:relative; z-index: 1; left: 4px; border-radius: 0 13px 13px 0; background: #999 url('/img/main/emp_slide_next.png') no-repeat center;}
.emp-slide-controller .swiper-button-pause {display: inline-block; position: absolute; left: -24px; z-index: 1; width: 25px; height: 25px; background: #999; text-indent: -9999px;}
.emp-slide-controller .swiper-button-pause:before {content:''; position: absolute; left: 50%; top: 50%; width: 0; height: 12px; border-color: transparent transparent transparent #fff; border-style: double; border-width: 0 0 0 6px; transform: translate(-50%, -50%); transition: .17s linear;}
.emp-slide-controller .swiper-button-pause.is-pause:before {height: 0; border-style: solid; border-width: 5px 0 5px 9px}
.emp-frc {margin-top: 5px; color: #999999; letter-spacing: -0.12em}

.mainMou {display: flex; padding: 60px 0 122px;}
.mainMou h3 {margin-bottom: 10px; font-size: 28px;}
.mainMou .left-wrap {width: 460px;}
.mainMou .right-wrap {width: calc(100% - 460px);}
.mainMou .left-wrap p {font-size: 20px; color: #555;}
.mainMou .left-wrap .btn-more {display: inline-block; margin-top: 37px;}
.main-recruit-list {display: flex; flex-wrap: wrap;}
.main-recruit-list > li {width: 25%;}
.main-recruit-list > li:nth-child(n+5) {margin-top: 15px;}
.main-recruit-list > li .img-wrap {width: 200px; height: 80px; margin: 0 auto 5px; border: 1px solid #efefef; border-radius: 13px; background-repeat: no-repeat; background-position: center; transition: all 0.2s;}
.main-recruit-list > li:hover .img-wrap {border-color: #00e46b;}
.main-recruit-list > li p {font-size: 12px; color: #555555; text-align: center;}

/* 커리큘럼 */
.mainCurri {padding-bottom: 140px;}
.mainCurriList {display: flex; padding-top: 23px; margin: 0 -10px;}
.mainCurriList > li {width: 50%; height: 330px; padding: 0 10px;}
.mainCurriList > li > a {display: block; overflow: hidden; height: 100%; position: relative; padding-top: 107px; padding-left: 50px; border-radius: 13px; color: #fff;}
.mainCurriList > li em {position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: -1; background-position: center; background-repeat: no-repeat; transition: all .7s cubic-bezier(.17,.57,.43,.89);}
.mainCurriList > li:hover em {transform: scale(1.1);}
.mainCurriList h4 {margin-bottom: 8px; font-size: 25px;}
.mainCurriList p {font-size: 18px;}
.curri-more {display: inline-block; margin-top: 25px; padding-right: 40px; background: url('/img/main/icon_more_curri.png') no-repeat right center; font-size: 14px; line-height: 30px;}

.mainTeacher {padding-top: 50px; padding-bottom: 130px;}
.mTchList {display: flex; padding-top: 30px; margin: 0 -10px;}
.mTchList > li {flex: 1; height: 210px; padding: 0 10px;}
.mTchList > li a {position: relative; display: block; width: 100%; height: 100%; overflow:hidden; border-radius: 13px; }
.mTchList > li a .img-wrap {width: 100%; height: 100%; background-position: center; background-repeat: no-repeat; transition: all .7s cubic-bezier(.17,.57,.43,.89);}
.mTchList > li:hover a .img-wrap {transform: scale(1.1);}

.mTchList .swiper-slide {width: 315px; height: 210px; padding: 0 10px;}
.mTchList .swiper-slide a {position: relative; display: block; width: 100%; height: 100%; overflow:hidden; border-radius: 13px; }
.mTchList .swiper-slide a .img-wrap {width: 100%; height: 100%; background-position: center; background-repeat: no-repeat; transition: all .7s cubic-bezier(.17,.57,.43,.89);}
.mTchList .swiper-slide:hover a .img-wrap {transform: scale(1.1);}
.mTchList .mTchName {position: absolute; bottom: 0; left: 0; min-width: 120px; padding: 5px 20px; border-top-right-radius: 10px; background: #f6f6f6; color: #999;}

/* 세미나 */
.mainSeminar {padding-bottom: 80px;}
.mainSmnBox {display: flex; padding-top: 23px; margin: 0 -10px;}
.mainSmnBox > li {flex:1; height: 350px; padding: 0 10px;}
.mainSmnBox > li a {display: block; overflow: hidden; width: 100%; height: 100%; border-radius: 13px;}
.mainSmnBox > li a .img-wrap {width: 100%; height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; transition: all .7s cubic-bezier(.17,.57,.43,.89);}
.mainSmnBox > li:hover a .img-wrap {transform: scale(1.1);}

/*241107 카운트다운 배너 */
.countSlide{overflow:hidden;}
.countSlide .countdown{position:absolute;display: flex;align-items: center;bottom: 90px;left: calc(50% - 244.25px);}
.countSlide .countdown .countdown__item{margin-right: 25px;display: flex;align-items: center;}
.countSlide .countdown .countdown__label{font-size:26px;color:#fff;font-weight: 500;padding-left: 10px;text-shadow: 3px 3px 7px #000000f5;}
.countSlide .countdown .countdown__timer{font-size: 36px;color:#99bef6;width:64px;height:64px;line-height:64px;border-radius:8px;background:#0c0e29;text-align:center;font-weight: 600;box-shadow: 3px 3px 7px #00000057;}
.countSlide .snow {  position: absolute;  top: 0;  left: 0;  z-index: 5;  width: 100%;  height: 100%;  pointer-events: none;  animation: snow-direction cubic-bezier(0.445, 0, 0.55, 1) 4s both alternate infinite;}
@keyframes snow-direction {from { transform: translateX(0);  }  to {    transform: translateX(0);  }}
.countSlide .snow:before,.snow:after {content: '';  display: block;  position: absolute;  top: 0;  left: 0;  width: 8px;  height: 8px;  background-color: #fff;  border-radius: 50%;  filter: blur(0.5px);  animation: snow 20s linear infinite;  box-shadow:    -5vw 10vh #fff,    30vw 5vh #fff,    55vw 5vh #fff,    75vw 10vh #fff,    105vw 15vh #fff,    -10vw 30vh #fff,    40vw 25vh #fff,    60vw 20vh #fff,    90vw 25vh #fff,    20vw 40vh #fff,    5vw 45vh #fff,    65vw 45vh #fff,    105vw 40vh #fff,    50vw 50vh #fff,        30vw 50vh #fff,    10vw 55vh #fff,    20vw 60vh #fff,    40vw 65vh #fff,    60vw 60vh #fff,    80vw 65vh #fff,    5vw 70vh #fff,    30vw 75vh #fff,    55vw 85vh #fff,    75vw 80vh #fff,    105vw 75vh #fff,    20vw 90vh #fff,    -5vw 95vh #fff,    65vw 95vh #fff,    100vw 90vh #fff,        -5vw 110vh #fff,    30vw 105vh #fff,    55vw 105vh #fff,    75vw 110vh #fff,    105vw 115vh #fff,    -10vw 130vh #fff,    40vw 125vh #fff,    60vw 120vh #fff,    90vw 125vh #fff,    20vw 140vh #fff,    5vw 145vh #fff,    65vw 145vh #fff,    105vw 140vh #fff,    50vw 150vh #fff,        30vw 150vh #fff,    10vw 155vh #fff,    20vw 160vh #fff,    40vw 165vh #fff,    60vw 160vh #fff,    80vw 165vh #fff,    5vw 170vh #fff,    30vw 175vh #fff,    55vw 185vh #fff,    75vw 180vh #fff,    105vw 175vh #fff,    20vw 190vh #fff,    -5vw 195vh #fff,    65vw 195vh #fff,    100vw 190vh #fff;}
.countSlide .snow:after { left: 50px; top: 60px; animation-duration: 7s; width: 8px; height: 8px; opacity: 0.7; filter: blur(3px);}
@keyframes snow { from { transform: rotate(10deg) translateY(-100vh); } to { transform: rotate(10deg) translateY(0);}}
