@charset "euc-kr";

@import url('https://webfontworld.github.io/NanumSquareNeo/NanumSquareNeo.css');

#wrapper {
    width: auto;
    min-width: 1100px;
    margin-top: 0;
}

.mask {
    width: 1200px;
    position: relative;
    margin: 0 auto;
    overflow: hidden;
}

.mask .thumb {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}

#wrapper .swiper-button-prev, #wrapper .swiper-button-next{text-indent:-9999px;}

/* click text default */
#wrapper .btn {
    display: inline-block;
    text-indent: -9999px;
}


/* visual */
.visual {
    background: #272936 url(img/visual.png) no-repeat center;
    overflow: hidden;
}

.visual .mask {
    width: 1328px;
}

.visual .circle_box {
    position: absolute;
    right: 50px;
    top: 50px;
}

.visual .circle_box::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 180px;
	height: 180px;
	background: url(img/roller_typo.png) no-repeat center center;
	animation: spin 30s infinite linear;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.visual .circle_box .arrow {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    padding-top: 32px;
}

.visual .circle_box .arrow li {
}

.visual .circle_box .arrow li img {
}

.visual .circle_box .arrow li {
    animation: arrow 1.7s cubic-bezier(0.3, 0.01, 0.4, 1) infinite;
}

.visual .circle_box .arrow li:nth-child(1) {
    animation-delay: -0.4s;
}

.visual .circle_box .arrow li:nth-child(2) {
    animation-delay: -0.2s;
}

.visual .circle_box .arrow li:nth-child(3) {
    animation-delay: 0s;
}

@keyframes arrow {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.4;
    }
}

.visual .circle_box .bg {
}

.visual .rolling {
    position: absolute;
    right: 135px;
    top: 0;
    overflow: hidden;
    height: 100%;
}

.visual .rolling:before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 300px;
    height: 69px;
    background: url(img/visual_roll_gradient.png) 0 0 no-repeat;
    z-index: 10;
}

.visual .rolling .roller.original {
    animation: 100s linear 0s infinite normal forwards running rollingTop1;
}

.visual .rolling .roller.clone {
    animation: 100s linear 0s infinite normal none running rollingTop2;
}

.visual .rolling .roller img {
    margin: 10px 0;
}

.visual .btn {
	left: 64px;
	bottom: 100px;
	width: 400px;
	height: 120px;
	position: absolute;
}

.visual .btn::before {
    content: '';
    width: 79px;
    height: 88px;
    position: absolute;
    top: 92px;
    right: -25px;
    background: url(img/click_01.png) no-repeat;
    animation: blinker 1s infinite;
}

@keyframes rollingTop1 {
    0% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-100%);
    }
    50.01% {
        transform: translateY(100%);
    }
    100% {
        transform: translateY(0);
    }
}

@keyframes rollingTop2 {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-200%);
    }
}


.spin2 {
    -webkit-animation: spin2 3s linear 0s infinite normal;
    animation: spin2 3s linear 0s infinite normal;
}

@keyframes spin2 {
    to {
        transform: rotate(360deg);
    }
}

@keyframes blinker {
    50% {
        opacity: 0;
    }
}


/* cont1 */
.cont1 {
    padding: 100px 0 40px;
    background: #edfbed;
}

.cont1 .mask {
    width: 1200px;
    padding: 0 50px;
}

/*.cont1_2 .tab01 ul li a {cursor: default;}*/


/* cont2 */
.cont2 {
	background: #edfbed;
    padding-bottom: 139px;
}

.cont2 .cont1_1 {
    margin-bottom: 60px;
}

.cont2 .tabArea {
}

.cont2 .tabArea > ul {
    width: 1100px;
    margin: 0 auto;
    display: flex;
    height: 94px;
    background: #2c2e45;
}

.cont2 .tabArea li {
    width: 100%;
}

.cont2 .tabArea li a {
    background: #2c2e45;
    color: #a7b3c1;
    font-size: 28px;
    text-align: center;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "NanumSquareNeo";
    font-weight: 800;
}

.cont2 .tabArea li.on a {
    background: #f2f2f2;
    font-weight: 900;
    color: #2c2e45;
}

.cont2 .cont1_1 .tab_contents {
    position: relative; /* margin-top: 70px; */
    background-color: #fff;
    border-radius: 15px;
    overflow: hidden;
}

.cont2 .cont1_1 .tab_contents a {
    position: absolute;
    bottom: 85px;
    right: 115px;
    width: 380px;
    height: 80px;
}

.cont2 .cont1_1 .tab_contents a::before {
    content: '';
    width: 43px;
    height: 47px;
    position: absolute;
    top: 50px;
    right: 5px;
    background: url(img/click_02.png) no-repeat;
    animation: blinker 1s step-start infinite;
}

.cont2 .cont1_2 {
    padding: 50px 94px 20px;
    background-color: #fff;
    text-align: center;
    border-radius: 15px;
    overflow: hidden;
}

.cont2 .cont1_2 > .tab,
.cont2 .cont1_2 > .tab * {
    -webkit-box-sizing: initial;
    -moz-box-sizing: initial;
    box-sizing: initial;
}

.cont2 .cont1_2 > .tab {
    width: 850px;
    margin: 0 auto;
}

.cont2 .cont1_2 > .tab:after {
    content: "";
    display: block;
    clear: both;
}

.cont2 .cont1_2 > .tab li {
    float: left;
    position: relative;
    background: #fafbfc;
    z-index: 1;
    width: 9.2%;
    height: 46px;
    border: 1px solid #d7d7d9;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    border-bottom: 2px solid #4e4e4e;
    text-align: center;
    font-weight: bold;
    line-height: 1.2;
    padding: 9px 0 0;
    margin: 0 0 0 -1px;
}

.cont2 .cont1_2 > .tab li a {
    width: 100%;
    height: 100%;
    display: block;
    color: #777;
}

.cont2 .cont1_2 > .tab li.on {
    border: 2px solid #4e4e4e;
    color: #4e4e4e;
    background: #fff;
    z-index: 2;
    border-bottom: none;
    padding: 8px 0 0;
}

.cont2 .cont1_2 > .tab li.on a {
    color: #4e4e4e;
}

.cont2 .cont1_2 .btn_area {
    position: relative;
}

.cont2 .cont1_2 .btn_area a {
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    width: 583px;
    height: 100px;
}

.report_slide {
}

.report_slide .swiper-pagination {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    height: 87px;
}

.report_slide > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    background: 0;
}

.report_slide .btn {
    position: absolute;
    bottom: 78px;
    right: 127px;
    width: 365px;
    height: 91px;
}

.report_slide .btn::before {
    content: '';
    width: 43px;
    height: 47px;
    position: absolute;
    top: 65px;
    right: 17px;
    background: url(img/click_02.png) no-repeat;
    animation: blinker 1s infinite;
}

.cont2 .notice_wrap .con {
    background-color: #ddf1dd;
}


/*notice_wrap*/
.notice_wrap {
    z-index: 1;
    position: relative;
    margin-top: 40px;
}

.notice_wrap > .tit {
    text-align: center;
    display: block;
    height: 70px;
    background-color: #111111;
    border-radius: 40px;
    font-family: "GmarketSansBold";
    font-size: 28px;
    color: #fff;
    line-height: 74px;
}

.notice_wrap > .tit span {
    position: relative;
    padding-right: 30px;
}

.notice_wrap > .tit span:before {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    right: 0;
    width: 20px;
    height: 13px;
    background: url(img/notice_arr.png) 0 0 no-repeat;
    transition: transform .5s;
}

.notice_wrap > .tit.on span:before {
    transform: rotate(180deg);
}

.notice_wrap .con {
    display: none;
    padding: 47px 56px;
    background-color: #f6f6f6;
    border-radius: 40px;
    text-align: left;
    letter-spacing: -1px;
}

.notice_wrap .con .tit {
    margin-bottom: 10px;
    font-weight: 900;
    font-size: 20px;
    color: #333;
}

.notice_wrap .con ul + p {
    margin-top: 25px;
}

.notice_wrap .con ul li {
    position: relative;
    padding-left: 7px;
    font-weight: 500;
    font-size: 16px;
    color: #777;
    word-break: keep-all;
}

/* .notice_wrap .con ul li:before{content:""; display:block; position:absolute; top:12px; left:0; width:5px; height:1px; background-color:#777;} */
.notice_wrap .con ul li:not(:first-child) {
    margin-top: 4px;
}


/* event2 */
.event2 {
    position: relative;
    padding: 100px 0 96px;
    align-content: center;
}

.event2 button.thumb {
    margin-top: 50px;
}

.event2 .attention_box {
    margin-top: 60px;
    margin-bottom: 0;
}

/* book */
.con_book {
    background: #edfbed;
    padding-bottom: 99px;
    position: relative;
    z-index: 2;
}


.book_top {
    position: relative;
    display: flex;
    justify-content: center;
    overflow: hidden;
}

.book_top::after {
    content: '';
    top: 0;
    left: 0;
    right: 0;
    height: 271px;
    background: #0E1310;
    display: block;
    position: absolute;
}

.book_top img {
    z-index: 1;
    position: relative;
}

.book_tit {
    margin: 58px auto 44px;
    display: block;
}

.con_book .tab_wrap {
    position: relative;
}

.con_book .tab_btn {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
}

.con_book .tab_btn button {
    height: 70px;
    width: 280px;
    opacity: 0;
}

.con_book .tab_con {
}

.book_rolling {
    position: absolute;
    bottom: 182px;
    left: 34px;
    right: 34px;
    overflow: hidden;
}

.book_list {
    position: relative;
    font-size: 0;
    -webkit-backface-visibility: hidden;
    animation-name: book_rolling;
    animation-duration: 15s;
    animation-fill-mode: both;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    white-space: nowrap;
    display: flex;
    width: 2214px;
}

.book_list li {
    height: 100%;
    width: auto;
    white-space: nowrap;
    padding-right: 19px;
}

@keyframes book_rolling {
    0% {
        left: 0;
    }
    100% {
        left: -1107px;
    }
}

.txt_rolling {
    display: flex;
    position: absolute;
    top: 498px;
    left: 80px;
    overflow: hidden;
    width: 1040px;
    border-radius: 0 0 33px 33px;
}

.txt_rolling img {
    margin: 0 12px;
}

.txt_rolling .roller.original {
    margin-right: 12px;
    animation: 100s linear 0s infinite normal forwards running rollingLeft1;
}

.txt_rolling .roller.clone {
    animation: 100s linear 0s infinite normal none running rollingLeft2;
}

@keyframes rollingLeft1 {
    0% {
        transform: translateX(0);
    }
    50% {
        transform: translateX(100%);
    }
    50.01% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(0);
    }
}

@keyframes rollingLeft2 {
    0% {
        transform: translateX(-200%);
    }
    100% {
        transform: translateX(0);
    }
}

.con_book .tab_con a {
    position: absolute;
    bottom: 55px;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 222px;
    height: 65px;
    border-radius: 45px;
    opacity: 0;
}


/* lineup */
.lineup {
    background:#252525/*  url(img/lineup_bg.png) center bottom no-repeat */;
}

.lineup .mask{
	overflow:visible;
	padding:106px 0 265px;
}

.lineup .badge {
	position: absolute;
	top: 270px;
	right: -32px;
	/* transform: translate(200px, 0); */
	left: auto;
}

.lineup .slider {
    margin-bottom:-50px;
    width: 1200px;
    overflow: hidden;
}

.lineup .slider .swiper-container {
    position: relative;
    width: 1200px;
    margin: 0 auto;
    overflow: visible;
}

.lineup .slider .swiper-slide {
    opacity: 0 !important;
    transition: opacity ease .5s;
}

.lineup .slider .swiper-slide-active {
    opacity: 1 !important;
}

.lineup .slider .swiper-button-next {
    top: 50%;
    right: 0;
    left: auto;
    width: 30px;
    height: 49px;
}

.lineup .slider .swiper-button-prev {
    top: 50%;
    left: 0;
    right: auto;
    width: 30px;
    height: 49px;
}

.lineup .slider .swiper-button-next a {
    display: block;
    width: 100%;
    height: 100%;
    background: url(/promotion/event/2023/1221_11780/img/slide_next_arr.png) 0 0 no-repeat;
}

.lineup .slider .swiper-button-prev a {
    display: block;
    width: 100%;
    height: 100%;
    background: url(/promotion/event/2023/1221_11780/img/slide_prev_arr.png) 0 0 no-repeat;
}

.lineup .slider .swiper-button-next::after,
.lineup .slider .swiper-button-prev::after {
    display: none;
}

.lineup .mask > a {
    width: 239px;
    display: block;
    height: 86px;
    font-size: 0;
    position: absolute;
    bottom: 100px;
    left: 0;
    right: 0;
    margin: 0 auto;
	background:url(img/lineup_btn.png) 0 0 no-repeat;
}


/* con_step */
.con_step {
    display: flex;
    justify-content: center;
    background: linear-gradient(to bottom, #fafffa 0%, #f7fff6 36%, #cfffcd 67%);

}

.con_step .mask {
    width: 2560px;
}

.con_step .step {
    display: flex;
    justify-content: space-between;
    position: absolute;
    top: 340px;
    left: 0;
    width: 1200px;
    background: 0;
    right: 0;
    margin: 0 auto;
}

.con_step .step li {
    position: relative;
}

.con_step .step li:not(:last-child):before {
    content: "";
    display: block;
    position: absolute;
    top: 230px;
    right: -51px;
    width: 53px;
    height: 83px;
    background: url(img/system_step_arr.png) 0 0 no-repeat;
    z-index: 10;
}

.con_step .step li:nth-of-type(1) {
    z-index: 3;
}

.con_step .step li:nth-of-type(2) {
    z-index: 2;
}

.con_step .step li:nth-of-type(3) {
    z-index: 1;
}

.con_step .step li .puzzle.v1 {
    position: absolute;
    top: 183px;
    left: 0;
    width: 100%;
    height: 280px;
}

.con_step .step li .puzzle.v2 {
    position: absolute;
    top: 184px;
    left: 0;
    width: 100%;
    height: 277px;
}

.con_step .step li .puzzle img {
    position: absolute;
}

.con_step .step li .puzzle.v1 img {
    animation: blinker 1s step-end infinite
}

.con_step .step li .puzzle.v1 img:nth-child(1) {
    top: -1px;
    right: 99px;
}

.con_step .step li .puzzle.v1 img:nth-child(2) {
    top: 49px;
    left: 49px;
}

.con_step .step li .puzzle.v1 img:nth-child(3) {
    bottom: 1px;
    right: 48px;
}

.con_step .step li .puzzle.v2 img {
    position: absolute;
    opacity: 0;
    transition: all .5s;
}

.con_step .step li .puzzle.v2 img:nth-child(1) {
    top: 0;
    right: 102px;
    transition-delay: 1.2s;
}

.con_step .step li .puzzle.v2 img:nth-child(2) {
    top: 49px;
    left: 51px;
    transition-delay: 1.5s;
}

.con_step .step li .puzzle.v2 img:nth-child(3) {
    bottom: 69px;
    left: 120px;
    transition-delay: 1.8s;
}

.con_step .step li .puzzle.v2 img:nth-child(4) {
    bottom: 0;
    right: 51px;
    transition-delay: 2.1s;
}

.con_step .step li .puzzle.v2 span {
    position: absolute;
    width: 71px;
    height: 71px;
    box-shadow: 0 0 10px 3px #0400ee;
    opacity: 0;
    transition: all ease .6s;
    transition-delay: 2.4s;
}

.con_step .step li .puzzle.v2 span:nth-of-type(1) {
    top: 1px;
    right: 120px;
}

.con_step .step li .puzzle.v2 span:nth-of-type(2) {
    top: 68px;
    left: 51px;
}

.con_step .step li .puzzle.v2 span:nth-of-type(3) {
    bottom: 69px;
    left: 120px;
}

.con_step .step li .puzzle.v2 span:nth-of-type(4) {
    bottom: 1px;
    right: 52px;
}

.con_step .step li.aos-animate .puzzle.v2 img {
    opacity: 1;
}

.con_step .step li.aos-animate .puzzle.v2 span {
    opacity: 1;
}

.con_step .mask a {
    width: 239px;
    display: block;
    height: 86px;
    font-size: 0;
    position: absolute;
    bottom: 94px;
    left: 0;
    right: 0;
    margin: 0 auto;
}


/* banner */
.banner {
    display: flex;
    justify-content: center;
    background: #0E1310;
}

.banner .mask {
    width: 2560px;
}


/* benefit */
.benefit_experience2 {
    text-align: center;
}


/* noticeBox */
.noticeBox {
    position: relative;
    background: #3f3f3f;
}

.noticeBox .mask {
    width: 1200px;
    padding: 70px 50px;
}

.noticeBox .tit {
    position: relative;
    margin-bottom: 12px;
    font-family: "NanumSquareNeo";
    font-weight: 900;
    color: #fff;
    font-size: 28px;
}

.noticeBox ol {
    margin: 5px 0 0;
    letter-spacing: -1px;
}

.noticeBox li {
    position: relative;
    font-family: 'Noto Sans KR';
    font-weight: 400;
    font-size: 18px;
    color: #aaa;
    line-height: 23px;
    text-indent: -18px;
    padding: 0 0 0 18px;
    letter-spacing: -1px;
}

.noticeBox li:not(:first-child) {
    margin-top: 8px;
}

#only1_rnb_sky_banner {
    display: none;
}

#ch-plugin {
    display: none !important;
}

/* ¾ó·µ ÆË¾÷ */
.popup{position:relative; width:470px; background-color:#fff; text-align:center;}
.popup *{font-family:"pretendard";}
.popup .inner{padding:20px 25px 34px;}
.popup .inner .txt1{margin-top:10px; font-weight:700; font-size:21px; line-height:27px; color:#2C2C2C; white-space: pre-wrap;}
.popup .inner .txt2{margin-top:5px; font-size:18px; color:#666;}
.popup .inner .btn_area{display:flex; justify-content:center; gap:10px; margin-top:15px;}
.popup .inner .btn_area button{width:155px; height:56px; background-color:#1154CF; border:none; border-radius:15px; font-weight:600; font-size:24px; color:#fff;}
.popup .inner .close{position:absolute; top:15px; right:15px;}