.wrap{ width: 95%; margin: 0 auto; }
.wrap[max="1600"]{ max-width: 1600px; }
.wrap[max="1540"]{ max-width: 1540px; }

@media screen and (max-width: 820px){
    .wrap{ width: 90%; }
}


.snslist{ display: flex; align-items: center; }
.snslist li{ margin-right: 20px; }
.snslist li:last-of-type{ margin-right: 0; }
.snslist li > a{ display: block; }
.snslist li > a i{ font-size: 35px; background-clip: text; background-image: url(/asset/img/main/se02_titlecolor.jpg); background-position: 70% 10%; color: #fff; transition-duration: 0.2s; }

@media screen and (min-width: 821px){
    .snslist li > a:hover i{ color: transparent; }
}

@media screen and (max-width: 1280px){
    .snslist li{ margin-right: 10px; }
}

@media screen and (max-width: 820px){
    .snslist li{ margin-right: 15px; width: 25px; }
    .snslist li > a i{ font-size: 27px; }
}


/* header */
.header{ color: #fff; z-index: 995; position: fixed; top: 0; left: 0; width: 100%; padding-top: 40px; transition-duration: 0.4s; }
.header .wrap{ display: flex; justify-content: space-between; }
.header .wrap .logo{ flex-shrink: 0; }
.header .wrap .logo > a{ padding: 20px 0; display: block; transition-duration: 0.4s; }
.header .wrap nav{ width: 100%; display: flex; justify-content: flex-start; }
.header .wrap nav .menu{ display: flex; justify-content: flex-start; }
.header .wrap nav .menu li{ position: relative; }
.header .wrap nav .menu li.on > a{ color: #fff; }
.header .wrap nav .menu li > a{ font-size: 20px; font-family: 'Campton'; font-weight: 700; color: #767676; transition-duration: 0.2s; padding: 0 25px; height: 100%; display: flex; align-items: center; }
.header .wrap nav .menu li:first-of-type > a{ padding-left: 0; }

.header .wrap nav .menu li .submenu{ position: absolute; top: 100%; left: 0; display: flex; padding: 0 25px; background-color: rgba(0,0,0,0.8); height: 0; overflow: hidden; transition-duration: 0.2s; }
.header .wrap nav .menu li.sub .submenu{ height: 36px; }
.header .wrap nav .menu li .submenu li:first-of-type a{ padding-left: 0; }
.header .wrap nav .menu li .submenu li a{ font-size: 16px; display: flex; align-items: center; padding: 10px; height: auto; }
.header .wrap nav .menu li .submenu li a em{ display: block; width: 4px; height: 4px; background-color: #fff; margin-right: 10px; }
.header .wrap nav .menu li .submenu li a span{ color: #505654; transition-duration: 0.2s; }

.header .wrap .hamWrap{ width: 24px; display: flex; align-items: center; justify-content: center; cursor: pointer; display: none; }
.header .wrap .hamWrap .hambtn{ width: 30px; height: 9px;  margin-top: -5px; position: relative; }
.header .wrap .hamWrap .hambtn span{ width: 100%; height: 2px; background-color: #fff; position: absolute; left: 0; transition-duration: 0.4s; transform-origin: 50% 50%; }
.header .wrap .hamWrap .hambtn span:nth-of-type(1){ top: 0; }
.header .wrap .hamWrap .hambtn span:nth-of-type(2){ top: 100%; }

.header.scroll{ background-color: rgba(0,0,0,0.8); padding-top: 0; }
.header.ham .wrap .hamWrap .hambtn span:nth-of-type(1){ top: 50%; left: 0; transform: rotate(135deg); }
.header.ham .wrap .hamWrap .hambtn span:nth-of-type(2){ top: 50%; left: 0; transform: rotate(-135deg); }


@media screen and (min-width: 821px){
    .header .wrap nav .menu li > a:hover{ color: #fff; }
    .header .wrap nav .menu li .submenu li a:hover span{ color: #7bf1d2; }
}

@media screen and (max-width: 1280px){
    .header{ padding-top: 10px; }
    .header .wrap .logo > a{ padding: 15px 0; }
    .header .wrap .logo > a img{ width: 165px; }
    .header .wrap nav .menu li > a{ font-size: 16px; padding: 0 20px; }
    
}

@media screen and (max-width: 820px){
    .header .wrap .logo > a{ padding: 10px 0; }
    .header .wrap .logo > a img{ width: 120px; }
    .header .wrap nav{ display: none; }
    .header .wrap .hamWrap{ display: flex; }
}


.header.ham ~ .total{ transform: translateY(0); opacity: 1; }

/* mobile_menu */
.total{ width: 100%; transform: translateY(-100%); opacity: 0; height: 100vh; background-image: url(/asset/img/common/mobile_menu_bg.jpg); background-repeat: no-repeat; background-position: center; background-size: cover; display: flex; flex-direction: column; align-items: center; justify-content: center; display: none; position: fixed; top: 0; left: 0; z-index: 994; padding: 80px 0; box-sizing: border-box; transition-duration: 0.4s; }
.total .m_menu{ width: 100%; text-align: center; }
.total .m_menu > li{ width: 100%; padding: 25px 0; }
.total .m_menu > li > a{ display: inline-block; padding: 5px 0; font-size: 20px; font-family: 'Campton'; font-weight: 700; color: #fff; }
.total .m_menu > li .depth{ width: 100%; margin-top: 10px; }
.total .m_menu > li .depth li{ width: 100%; }
.total .m_menu > li .depth li > a{ display: inline-block; padding: 5px 0; font-size: 16px; color: #7bf1d2; position: relative; font-family: 'Campton'; font-weight: 700; }
.total .m_menu > li .depth li > a::after,
.total .m_menu > li .depth li > a::before{ content: ''; display: block; width: 5px; height: 5px; border-radius: 50%; position: absolute; top: 50%; transform: translateY(-50%); background-color: #fff; }

.total .m_menu > li .depth li > a::after{ left: -1em; }
.total .m_menu > li .depth li > a::before{ right: -1em; }

.total .regis{ width: 100%; display: flex; text-align: center; justify-content: center; margin-top: 5vh; }
.total .regis > a{ display: inline-flex; width: 180px; height: 45px; background-image: url(/asset/img/sub/agenda/download_bg.jpg); background-position: center; background-repeat: no-repeat; background-size: cover; color: #fff; font-weight: 700; font-size: 16px; align-items: center; justify-content: center; position: relative; border-radius: 5px; overflow: hidden; }
.total .regis > a .icon{ position: absolute; right: 15px; top: 50%; transform: translateY(-50%); font-size: 18px; }
.total .regis > a .icon i{ margin: 0 -0.45em; }

@media screen and (max-width: 820px){
    .total{ display: flex; }
}


/* footer */
.footer{ width: 100%; background-color: #000; color: #fff; }
.footer .wrap{ border-top: 1px solid #333333; box-sizing: border-box; padding: 105px 0; display: flex; }
.footer .wrap .logo{ flex-shrink: 0; padding-right: 80px; border-right: 1px solid #b6abcb; box-sizing: border-box; }

.footer .wrap .center{ padding: 5px 0; box-sizing: border-box; padding-left: 105px;  }
.footer .wrap .center .infor li{ font-size: 18px; letter-spacing: -0.025em; display: flex; align-items: flex-start; line-height: 1.3; margin-bottom: 12px; word-break: keep-all; }
.footer .wrap .center .infor li:last-of-type{ margin-bottom: 0; }
.footer .wrap .center .infor li span{ font-family: 'Campton'; font-weight: 700; flex-shrink: 0; display: block; width: 100px; padding-right: 5px; box-sizing: border-box; }
.footer .wrap .center .infor li p{ color: #b0b0b0; }
.footer .wrap .center > strong{ font-size: 18px; letter-spacing: -0.025em; font-family: 'Campton'; font-weight: 700; color: #b6abcb; margin-top: 30px; display: block; line-height: 1.3; }

.footer .wrap .right{ margin-left: auto; display: flex; justify-content: flex-end; flex-direction: column; align-items: flex-end; }
.footer .wrap .right .icons{ display: flex; align-items: center; justify-content: flex-end; }
.footer .wrap .right .icons .priv{ padding: 10px; margin-right: 20px; font-size: 18px; letter-spacing: -0.025em; cursor: pointer; }
.footer .wrap .right .family{ margin-top: 30px; position: relative; width: 275px; }
.footer .wrap .right .family > p{ width: 100%; padding: 15px 17px; box-sizing: border-box; border: 1px solid #b6abcb; display: flex; justify-content: space-between; align-items: center; font-size: 18px; font-weight: 700; font-family: 'Campton'; letter-spacing: -0.025em; cursor: pointer; }
.footer .wrap .right .family .site{ position: absolute; bottom: calc(100% + 10px); left: 0; width: 100%; border: 1px solid #b6abcb; box-sizing: border-box; background-color: #000; height: 0; overflow: hidden; padding: 0; transition-duration: 0.4s; opacity: 0; }
.footer .wrap .right .family.on .site{ height: 93px; padding: 10px 0; opacity: 1; }
.footer .wrap .right .family .site li{ width: 100%; }
.footer .wrap .right .family .site li > a{ display: block; padding: 10px 15px; box-sizing: border-box; font-size: 16px; letter-spacing: -0.025em; transition-duration: 0.2s; }

@media screen and (min-width: 821px){
    .footer .wrap .right .family .site li > a:hover{ background-color: rgba(255,255,255,0.1); }
}

@media screen and (max-width: 1280px){
    .footer .wrap .logo{ padding-right: 40px; }
    .footer .wrap .logo > a img{ width: 170px; }
    .footer .wrap .center{ padding-left: 20px; }
    .footer .wrap .center .infor li{ font-size: 14px; }
    .footer .wrap .center .infor li span{ width: 80px; }
    .footer .wrap .center > strong{ margin-top: 20px; font-size: 14px; }

    .footer .wrap .right .family{ width: 200px; }
    .footer .wrap .right .family > p{ font-size: 14px; padding: 10px 15px; }
    .footer .wrap .right .icons .priv{ padding: 5px; font-size: 14px; margin-right: 10px; }

    .footer .wrap .right .family .site li > a{ padding: 7px 15px; font-size: 14px; }
    .footer .wrap .right .family.on .site{ height: 80px; }
}

@media screen and (max-width: 820px){
    .footer .wrap{ display: block; padding: 60px 0; }
    .footer .wrap .logo{ padding-right: 0; border-right: 0; }
    .footer .wrap .logo > a img{ width: 120px; }

    .footer .wrap .center{ padding: 0; margin-top: 20px; }

    .footer .wrap .right .family{ margin-top: 20px; margin-left: auto; }
    .footer .wrap .right .family > p img{ transform: rotate(180deg); }
    .footer .wrap .right .icons{ justify-content: flex-end; flex-direction: row-reverse; margin-top: 20px; }
    .footer .wrap .right .icons .priv{ padding: 0; margin-right: 0; margin-left: 20px; }

    .footer .wrap .right .family .site{ display: block; top: auto; bottom: calc(100% + 5px);  }
    
}

@media screen and (max-width: 500px){
    .footer .wrap .center > strong{ text-align: center; margin-top: 30px; }
    .footer .wrap .right .family{ margin: 0 auto; margin-top: 20px; }
    .footer .wrap .right .icons{ flex-direction: column; align-items: center; justify-content: center; margin: 0 auto; margin-top: 20px; }
    .footer .wrap .right .icons .priv{ margin-left: 0; margin-bottom: 20px; }
    
}



/* 서브페이지 공통 */
._s{ width: 100%; position: relative; overflow: hidden; }
._s .subVisual{ width: 100%; position: relative; background-color: #000; overflow: hidden; padding-top: 200px; padding-bottom: 110px; color: #fff; }
._s .subVisual .obj{ position: absolute; top: -21%; right: calc(145 / 1920 * 100%); z-index: 0; animation: updown 2s infinite ease-in-out alternate; }
._s .subVisual .wrap{ position: relative; z-index: 2; }
._s .subVisual .subvis_t dt{ font-size: 24px; letter-spacing: -0.025em; color: #b320f1; font-weight: 500; }
._s .subVisual .subvis_t dd{ font-size: 40px; font-weight: 700; font-family: 'Campton'; margin-top: 15px; line-height: 1.3; }

._s._agenda .subVisual .obj{ right: calc(300 / 1920 * 100%); }
._s._event .subVisual .obj{ right: calc(205 / 1920 * 100%); }
._s._sponsor .subVisual .obj{ right: calc(320 / 1920 * 100%); }
._s._ondemand .subVisual .obj{ right: calc(170 / 1920 * 100%); top: 0; }

@media screen and (max-width: 1280px){
    ._s .subVisual .obj{ width: 40%; }
}

@media screen and (max-width: 820px){
    ._s .subVisual{ padding-top: 150px; padding-bottom: 70px; }
    ._s .subVisual .obj{ width: 35%; }
    ._s .subVisual .subvis_t dt{ font-size: 20px; }
    ._s .subVisual .subvis_t dd{ font-size: 32px; }
}

@media screen and (max-width: 500px){
    ._s .subVisual{ padding-top: 100px; padding-bottom: 60px; }
    ._s .subVisual .obj{ width: 45%; }
    ._s .subVisual .subvis_t dt{ font-size: 16px; }
    ._s .subVisual .subvis_t dd{ font-size: 26px; }
}


._s .cont_{ position: relative; overflow: hidden; padding-top: 130px; padding-bottom: 145px; }
._s .cont_ .sub_title dt{ font-size: 20px; font-weight: 500; word-break: keep-all; line-height: 1.3; }
._s .cont_ .sub_title dd{ font-family: 'Campton', 'Pretendard'; font-weight: 700; line-height: calc(80 / 70); margin-top: 25px; font-size: 70px;  word-break: keep-all; }

@media screen and (max-width: 1280px){
    ._s .cont_ .sub_title dt{ font-size: 16px; }
    ._s .cont_ .sub_title dd{ font-size: 60px; margin-top: 15px; }
}

@media screen and (max-width: 820px){
    ._s .cont_{ padding: 70px 0; }
    ._s .cont_ .sub_title dt{ font-size: 14px; }
    ._s .cont_ .sub_title dd{ font-size: 40px; margin-top: 10px; }
}

@media screen and (max-width: 500px){
    ._s .cont_ .sub_title dd{ font-size: 34px; }
}


.sideFix{ position: fixed; top: 50%; transform: translateY(-50%); right: 25px; z-index: 10; transition-duration: 0.2s; opacity: 0; pointer-events: none; }
.sideFix.show{ opacity: 1; pointer-events: unset; }
.sideFix .registration{ flex-shrink: 0; border-radius: 10px; overflow: hidden; }
.sideFix .registration > a{ width: 100%; height: 100%; padding: 25px 30px; box-sizing: border-box; position: relative; display: flex; flex-direction: column; justify-content: space-between; }
.sideFix .registration > a .bg{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; z-index: -1; transition-duration: 0.4s; }
.sideFix .registration > a strong{ display: block; font-family: 'Campton'; font-weight: 700; line-height: calc(60 / 50); writing-mode: vertical-rl; font-size: 30px; color: #fff; }
.sideFix .registration > a .regis{ display: flex; flex-direction: column; align-items: center; justify-content: center; margin-top: 70px; }
.sideFix .registration > a .regis span{ font-size: 18px; font-weight: 700; margin-top: 15px; color: #fff; }
.sideFix .registration > a .regis img{ transition-duration: 0.4s; width: 45px; }

.sideFix .totop{ width: 50px; height: 50px; border-radius: 50%; margin: 0 auto; background-color: #111111; color: #fff; font-size: 14px; font-family: 'Campton'; font-weight: 700; display: flex; justify-content: center; align-items: center; margin-top: 15px; cursor: pointer; }

@media screen and (min-width: 821px){
    .sideFix .registration:hover > a .bg{ transform: scale(1.2); }
    .sideFix .registration:hover > a .regis img{ transform: scaleX(-1); }
}

@media screen and (max-width: 1440px){
    .sideFix .registration > a{ padding: 15px 20px; }
    .sideFix .registration > a strong{ font-size: 24px; }
    .sideFix .registration > a .regis span{ font-size: 14px; }
    .sideFix .registration > a .regis img{ width: 30px; }
}

@media screen and (max-width: 820px){
    .sideFix{ top: auto; transform: translateY(0); bottom: 150px; right: 5%; }
    .sideFix .registration > a{ display: none; }
}





/*개인정보처리방침 팝업*/
.privPop{ position: fixed; top: 0; left: 0; width: 100%; height: 100vh; z-index: 99999;  transition: opacity .4s, visibility .4s; opacity: 0; visibility: hidden; }
.privPop .eleBg{ width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); }
.privPop .inn{ width: 95%; max-width: 1280px; height: 60vh; margin: 0 auto; background-color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); border-radius: 15px; box-sizing: border-box; padding: 20px; }
.privPop .inn .cont{ width: 100%; height: 100%; position: relative; }
.privPop .inn .cont .close{ position: absolute; bottom: calc(100% + 40px); left: 50%; transform: translateX(-50%); z-index: 99999; cursor: pointer; font-size: 30px; color: #fff; }
.privPop .inn .cont .p{ height: 100%; line-height: 1.3; overflow: auto; padding-right: 10px; }
.privPop .inn .cont .p::-webkit-scrollbar{ width: 5px; }
.privPop .inn .cont .p::-webkit-scrollbar-thumb{ width: 5px; border-radius: 5px; background-color: #333; }

.privPop.on { opacity: 1; visibility: visible; }

@media screen and (max-width: 450px){
    .privPop{ font-size: 14px; }
}



/* 행사등록,on-demand 팝업 */
.layerPopup{ position: fixed; top: 0; left: 0; width: 100%; height: 100vh; z-index: 99999;  transition: opacity .4s, visibility .4s; opacity: 0; visibility: hidden; text-align: center; word-break: keep-all; }
.layerPopup .bg{ width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); }
.layerPopup .inn{ width: 90%; max-width: 595px; margin: 0 auto; background-color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); box-sizing: border-box; padding: 20px; height: 490px; display: flex; flex-direction: column; align-items: center; justify-content: center; }

.layerPopup .inn dl{ padding-top: 50px; }
.layerPopup .inn dl dt{ font-size: 50px; font-family: 'Campton'; font-weight: 700; color: #b320f2; }
.layerPopup .inn dl dd{ font-size: 20px; line-height: calc(30 / 20); margin-top: 20px; }
.layerPopup.on { opacity: 1; visibility: visible; }
.layerPopup .inn .close{ margin-top: 45px; width: 120px; height: 46px; display: flex; align-items: center; justify-content: center; border: 1px solid #000; font-size: 20px; cursor: pointer; }
.layerPopup .inn .close span{ font-family: 'Campton'; font-weight: 700; margin-right: 10px; }

@media screen and (max-width: 1280px){
    .layerPopup .inn{ height: 410px; }
    .layerPopup .inn dl dt{ font-size: 40px; }
    .layerPopup .inn dl dd{ font-size: 18px; }
}

@media screen and (max-width: 820px){
    .layerPopup .inn{ height: 300px; max-width: 450px; }
    .layerPopup .inn dl{ padding-top: 30px; }
    .layerPopup .inn dl dt{ font-size: 30px; }
    .layerPopup .inn dl dd{ font-size: 14px; }
    .layerPopup .inn .close{ font-size: 14px; width: 90px; height: 30px; }
}