/* main visual */

h2.main_tit{margin: 0; line-height: 42px; letter-spacing: -0.5px;}
.pc{display: block;}
.mo{display: none;}
#mainCont section{margin-top: 65px;}
#mainCont{padding-bottom: 80px;}

/* more 버튼 + 페이지네이션 공통 */
.btn_more{display: inline-block; height: 32px; line-height: 32px; padding: 0 12px; font-size: 14px; font-weight: 500; color: #7A45E5; border: 1px solid #7A45E5; border-radius: 99px;}
.pagination{display: flex; align-items: center; position: absolute;}
.pagination .swiper-pagination{position: static; width: auto; margin: 0 16px;}
.pagination .swiper-pagination .swiper-pagination-current{font-weight: 600; margin-right: 3px; display: inline-block; width: 10px;}
.pagination .swiper-pagination .swiper-pagination-total{font-weight: 300; margin-left: 3px;}
.pagination .swiper-button-next, .pagination .swiper-button-prev{position: static; margin: 0; text-indent: -9999px;}
.pagination .swiper-button-prev{width: 10px; height: 16px; background: url(../img/main/main_slide_prev.png) 0 0 / 100% 100% no-repeat;}
.pagination .swiper-button-next{width: 10px; height: 16px; background: url(../img/main/main_slide_next.png) 0 0 / 100% 100% no-repeat;}
.swiper-notification{display: inline-block; text-indent: -9999px;}

#mainCont .sec_visual{margin-top: 0;}
.main_visual{position: relative; height: 658px;}
.main_visual button:focus{outline: 2px solid red !important;}
.main_visual::after{content: ''; z-index: 5; position: absolute; bottom: -10px; left: 0; display: block; width: 100%; height: 123px; background: url(../img/main/bg_wave.png) 0 0 / 100% 100% no-repeat;}
.main_visual::before{content: ''; z-index: 1; position: absolute; top: -18px; left: 0; display: block; width: 100%; height: 20px; background: #fff;}
.main_visual .bg{position: relative; height: 100%; filter: blur(3px); -webkit-filter: blur(3px); transition: 0.3s; background-repeat: no-repeat; background-size: cover; background-position: 50% 50%;}
.main_visual .bg::after{content: ''; position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.6);}
.main_visual .visual_inner{width: 100%; height: 100%; max-width: 1320px; position: absolute; top: 0; left: 50%; transform: translateX(-50%); }
.main_visual .swiper-container{width: 100%; height: 100%; max-width: 1088px; overflow: hidden; margin: 0 auto;}
.main_visual .swiper-container .swiper-slide a{display: flex; gap: 100px; width: 100%; margin: 0 auto; position: relative;}
.main_visual .swiper-container .swiper-slide a:focus{outline: none;}
.main_visual .swiper-container .swiper-slide a:focus::after{content: ''; position: absolute; top: 3px; left: 0; display: block; width: 100%; height: 82%; border: 2px solid red; box-sizing: border-box; }
.main_visual .swiper-slide-container-box{margin-top: 110px; flex: 1; color: #fff;}
.main_visual .slide_title{position: relative; max-width: 928px;}
.main_visual .slide_title h2{font-size: 40px; font-weight: 800; color: #fff; word-break: keep-all; margin: 0;}
.main_visual .slide_title span{display: block; font-size: 18px; margin-bottom: 8px;}
.main_visual .slide_title .sort{margin-bottom: 20px; font-size: 16px; font-weight: 700; height: 36px; width: fit-content; display: flex; align-items: center; padding: 0 20px; background-color: #7A45E5; border-radius: 25px;}
.main_visual .slide_title .sort.theme{background-color: #E50A59;}
.main_visual .slide_title .location::before{content: ''; display: inline-block; width: 15px; height: 18px; margin-right: 8px; vertical-align: -2px; background: url(../img/main/icon_location.png) 0 0 / 100% 100% no-repeat;}
.main_visual .main_schedule{display: flex; justify-content: flex-start; align-items: center; margin-top: 24px; font-size: 18px;}
.main_visual .explain{margin-top: 20px; padding-top: 20px; font-weight: 500; border-top: 1px solid #80808a;}
.main_visual .explain li{margin-bottom: 5px;}
.main_visual .explain li::before{content: ''; display: inline-block; width: 5px; height: 1px; margin-right: 8px; vertical-align: 6px; background-color: #fff;}
.main_visual .pagination{z-index: 100; gap: 8px;top: 465px; left: calc(50% + 140px); transform: translateX(-50%);}
.main_visual .pagination .swiper-pagination{position: static; margin: 0; width: 65px; font-size: 14px; display: flex; align-items: center; justify-content: center; color: #fff; height: 30px; background: rgba(0, 0, 0, 0.5); border-radius: 99px;}
.main_visual .pagination .swiper-pagination .swiper-pagination-current{margin-right: 5px;}
.main_visual .pagination .swiper-pagination .swiper-pagination-total{margin-left: 5px;}
.main_visual .pagination .btn_autoStop{display: flex; flex-shrink: 0; border: none; text-indent: -9999px; width: 30px; height: 30px; background: rgba(0, 0, 0, 0.5) url(../img/main/slide_stop.png) 50% 50% / 8px 10px no-repeat; border-radius: 50%;}
.main_visual.active .pagination .btn_autoStop{background-image: url(../img/main/slide_play.png);}
.main_visual .swiper-button-next{right: 0; width: 64px; height: 64px; background-image: none;}
.main_visual .swiper-button-prev{left: 0; width: 64px; height: 64px; background-image: none;}

#mainCont .sec_keyword{position: relative; padding-bottom: 85px; margin-top: 0;}
.sec_keyword .main_keyword{position: absolute; z-index: 10; top: -20px;}
.main_keyword ul{display: flex; gap: 12px; margin-top: 27px;}
.main_keyword ul li{height: 36px; }
.main_keyword ul li a{color: #80808a; display: flex; align-items: center; justify-content: center; box-sizing: border-box; padding: 0 16px; height: 100%; border-radius: 99px; border: 1px solid #80808a;}
.main_keyword ul li a:hover, .main_keyword ul li a:focus{background: #7A45E5; color: #fff;}
.main_keyword ul li a:focus-visible {outline: none; position: relative;}
.main_keyword ul li a:focus-visible::after {content: ""; border: 2px solid #f00; width: 100%; height: 100%; position: absolute; top: -2px; left: -2px; border-radius: 99px;}


.main_rank{max-width: 1040px; padding-bottom: 105px; margin: 0 auto; background: url(../img/main/img_keyword.png) 0 bottom / 342px 284px no-repeat;}
.main_rank .inner{display: flex; justify-content: space-between; gap: 150px; align-items: start;}
.main_rank .ranktit{flex-shrink: 0;}
.main_rank h2 em{display: block;}
.main_rank .ranklist{display: flex; margin-top: 25px; width: calc(100% - 320px);}
.main_rank .ranklist ul{padding-right: 64px; box-sizing: border-box; width: 50%;}
.main_rank .ranklist ul + ul{position: relative; padding: 0 0 0 64px;}
.main_rank .ranklist ul + ul::before{content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); display: block; width: 1px; height: calc(100% - 32px); background: #f2f2f7;}
.main_rank .ranklist li{display: flex; gap: 11px; align-items: center; margin-top: 25px;}
.main_rank .ranklist .num{display: inline-block; border-radius: 50%; font-size: 14px; font-weight: 500; color: #666670; width: 22px; height: 22px; background: #f2f2f7; text-align: center; line-height: 22px;}
.main_rank .ranklist .type1{color: #9B530C; width: 20px; height: 27px; line-height: 20px; background: url(../img/main/rank_top.png) 0 0 / 100% auto no-repeat;}
.main_rank .ranklist .silver{color: #4E4E50; background-position: 0 -27px;}
.main_rank .ranklist .bronze{color: #763E1E; background-position: 0 -54px;}
.main_rank .ranklist a{font-size: 20px; font-weight: 500; color:#33333d; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;}

#mainCont .sec_festival{margin-top: 0; padding-top: 65px; background-image: linear-gradient(to bottom, #f2f2f7 400px, #fff 400px); position: relative;}
.sec_festival .festival_wrap{position: relative; overflow: hidden;}
.festivaltit{position: absolute; left: 50%; transform: translateX(-50%); top: 0; width: 928px; z-index: 100; }
.festivaltit .main_tit{margin-bottom: 30px;}
.festival_slide{width: calc(50% + 250px); float: right; overflow: hidden;}
.festival_slide .swiper-container{padding: 20px 0 20px 20px; font-size: 0;}
.festival_slide li:nth-child(2n+1){margin-top: 50px;}
.festival_slide li a{display: block; width: 100%; height: 100%; border-radius: 10px; overflow: hidden; box-sizing: border-box;}
.festival_slide .swiper-slide-active a{border: 4px solid #7A45E5; box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.25); }
.festival_slide li a img{width: 100%; height: 100%; object-fit: cover; object-position: center;}
.festival_wrap .pagination{left: 50%; transform: translateX(-50%); top: 220px; width: 928px; z-index: 100;}

.sec_tit{display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px;}
.sec_banner .swiper-container{overflow: hidden; font-size: 0;}
.sec_banner .pagination{width: auto; position: static; transform: translateX(0); justify-content: end; margin-bottom: 10px;}
.sec_banner .btn_autoStop{display: block; padding: 0; margin-right: 16px; border: none; text-indent: -9999px; width: 12px; height: 14px; background: url(../img/main/slide_stop_bk.png) center / 8px 10px no-repeat;}
.sec_banner.active .btn_autoStop{background-image: url(../img/main/slide_play_bk.png);}
.sec_banner li a{border-radius: 10px; overflow: hidden; display: block; position: relative;}
.sec_banner li a:focus{outline: none;}
.sec_banner li a:focus::after{content: ''; position: absolute; top: 0; left: 0; border: 2px solid #000; width: 100%; height: 100%; box-sizing: border-box; border-radius: 10px;}
.sec_banner li a img{width: 100%; height: 100%; object-fit: cover; object-position: center;}

.sec_theme .theme_wrap{display: flex; align-items: center; justify-content: space-between; gap: 32px;}
.theme_wrap a{border-radius: 10px; overflow: hidden; position: relative;}
.theme_wrap a:focus{outline: none;}
.theme_wrap a:focus::after{content: ''; position: absolute; top: 0; left: 0; border: 2px solid red; width: 100%; height: 100%; box-sizing: border-box; border-radius: 10px;}
.theme_wrap a img{width: 100%; height: 100%; object-fit: cover; object-position: center; vertical-align: top;}

.alio_wrap li a{display: block; width: 100%; position: relative;}
.alio_wrap li a .icon_alio{width: 50px; height: 50px; position: absolute; top: 0; right: 0; z-index: 5;}
.alio_wrap li a .img{display: block; width: 100%; height: 208px; border-radius: 50%; overflow: hidden;}
.alio_wrap li a .img img{width: 100%; height: 100%; object-fit: cover; object-position: center;}
.alio_wrap .txt_wrap{text-align: center; margin-top: 20px;}
.alio_wrap .txt_wrap strong{display: block; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; font-size: 20px; color: #000; font-weight: 500; margin-bottom: 6px;}
.alio_wrap .txt_wrap span{display: block; font-size: 14px; color: #4d4d57; margin-bottom: 5px;}

#closePopup {position: fixed; top: 0; left: 0; z-index: 999; width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; flex-wrap: wrap;}
#closePopup .pc{display: block;}
#closePopup .mo{display: none;}
#closePopup .dimmed { position: fixed; top: 0; left: 0; z-index: -1; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.6);}
#closePopup .layerpop{position: relative; max-width: 500px; width: 100%; border-radius: 8px; overflow: hidden;}
#closePopup a{position: absolute; z-index: 10; cursor: pointer; bottom: 81px; left: 50%; transform: translateX(-50%); width: calc(100% - 76px); height: 76px; text-indent: -9999px;}
#closePopup .viewNone,
#closePopup .viewNone button {color: #4D4D57; font-size: 16px; line-height: 20px; font-weight: 400;}
#closePopup .viewNone { position: relative; height: 48px; padding: 14px 24px; background: #F2F2F7; display: flex; justify-content: space-between;}
#closePopup .viewNone button {background: none; border: none; padding: 0; text-decoration: underline; text-underline-offset: 2px;}
#closePopup input[type="checkbox"] {position: absolute;width: 1px;height: 1px;padding: 0;margin: -1px;overflow: hidden;clip: rect(0, 0, 0, 0);border: 0; display: block;}
#closePopup input[type="checkbox"] + label {position: relative; padding-left: 26px; display: inline-block; vertical-align: middle; min-height: 20px;}
#closePopup input[type="checkbox"]:focus + label{outline: 2px solid #000; outline: -webkit-focus-ring-color auto 5px;}
#closePopup input[type="checkbox"] + label:before {content: ''; position: absolute; left: 0; top: 0; width: 20px; height: 20px; background: url(../img/main/icon_check_none.png) 0 0 / 100% 100% no-repeat;}
#closePopup input[type="checkbox"]:checked + label:after {content: ''; position: absolute; left: 0; top: 0; width: 20px; height: 20px; background: url(../img/main/icon_checked.png) 0 0 / 100% 100% no-repeat;}


@media all and (max-width:1008px){
    .pc{display: none;}
    .mo{display: block;}

    h2.main_tit{line-height: 30px; font-size: 22px; margin-left: 10px;}
    #mainCont section{margin-top: 50px;}

    .btn_more{height: 26px; line-height: 26px; padding: 0 10px; font-size: 12px;}
    .pagination{top: auto; bottom: 0; width: 100%; left: 0; transform: translateX(0); justify-content: center; font-size: 0;}
    .pagination .swiper-pagination{display: block;}
    .pagination .swiper-pagination .swiper-pagination-bullet{width: 10px !important; height: 10px !important; border: 1px solid #7A45E5; background: #fff !important;}
    .pagination .swiper-pagination .swiper-pagination-bullet-active{width: 24px !important; background: #7A45E5 !important; border-radius: 8px !important;}
    .pagination .swiper-button-next, .pagination .swiper-button-prev{display: none;}

    .sec_visual{min-height: auto;}
    .sec_visual .main_visual{height: 128.00vw;}
    .sec_visual .main_visual::after{background-image: url(../img/main/bg_wave_mo.png); height: 10.67vw; bottom: -1px;}
    .sec_visual .main_visual .bg{display: none;}
    .main_visual .slide_title h2{font-size: 30px;}
    .main_visual .swiper-container{width: 100%; transform: translate(0); left: 0;}
    .main_visual .swiper-container .swiper-slide a{gap: 0; height: 100%;}
    .main_visual .swiper-container .swiper-slide a::after{content: ''; position: absolute; bottom: 0; left: 0; display: block; width: 100%; height: 70%; background-image: linear-gradient(to bottom, transparent, rgba(0,0,0,.6));}
    .main_visual .swiper-container .swiper-slide a img{object-fit: cover; object-position: center; width: 100%; height: 100%;}
    .main_visual .swiper-slide-container-box{position: absolute; top: 61.33vw; z-index: 50; width: calc(100% - 60px); left: 50%; transform: translateX(-50%); margin-top: 0;}
    .main_visual .slide_title .sort{font-size: 14px; height: 30px; padding: 0 13px;}
    .main_visual .main_schedule{font-size: 14px; margin-top: 20px;}
    .main_visual .explain{display: none;}
    .main_visual .swiper-button-prev{display: none;}
    .main_visual .swiper-button-next{display: none;}
    .main_visual .pagination{top: 20px; right: 20px; bottom: auto; left: auto; transform: translateX(0); gap: 4px; justify-content: end;}

    #mainCont .sec_keyword{padding-bottom: 0;}
    .sec_keyword .main_keyword{position: static;}
    .main_keyword ul{flex-wrap: wrap; gap: 8px;}
    .main_keyword ul li{height: 32px;}
    .main_keyword ul li a{font-size: 14px;}

    #mainCont .sec_rank{margin-top: 0;}
    .main_rank{padding: 50px 0 0 0; max-width: 100%; background: url(../img/main/img_keyword_mo.png) calc(100% - 15px) top / 122px 97px no-repeat;}
    .main_rank .inner{flex-direction: column; gap: 16px; margin-top: 0;}
    .main_rank h2 em{display: inline-block;}
    .main_rank .ranklist{flex-direction: column; width: 100%; margin-top: 0; border: 1px solid #80808a; border-radius: 20px; padding: 0 20px 20px 20px;}
    .main_rank .ranklist ul{padding: 0; width: 100%;}
    .main_rank .ranklist ul + ul{padding: 0;}
    .main_rank .ranklist ul + ul::before{display: none;}
    .main_rank .ranklist li{margin-top: 18px;}
    .main_rank .ranklist a{font-size: 16px;}

    #mainCont .sec_festival{margin-top: 50px; padding-top: 40px; background-image: linear-gradient(to bottom, #f2f2f7 250px, #fff 250px);}
    .festivaltit{position: static; transform: translateX(0); display: flex; justify-content: space-between; width: 100%; padding: 0 20px;}
    .festivaltit .main_tit{margin-bottom: 40px;}
    .festival_slide{width: 100%; float: none; overflow: visible;}
    .festival_slide .swiper-container{padding: 30px 0 20px 0;}
    .festival_slide li{width: 60%; height: auto;}
    .festival_slide li:nth-child(2n+1){margin: 0;}
    .festival_slide .swiper-slide-active a{margin-top: -26px;}
    .festival_wrap .pagination{top: auto; bottom: 0; width: 100%; left: 0; transform: translateX(0); justify-content: center; font-size: 0;}

    .sec_tit{margin-bottom: 15px;}
    .sec_banner .inner{padding: 0;}
    .sec_banner li a{border-radius: 0;}
    .sec_banner .pagination{position: absolute; top: 20px; right: 20px; bottom: auto; z-index: 10;}
    .sec_banner .pagination .swiper-pagination{width: 65px; height: 30px; margin: 0 4px 0 0; border-radius: 99px; background: rgba(0, 0, 0, 0.5); color: #fff; font-size: 14px; display: flex; align-items: center; justify-content: center;}
    .sec_banner .btn_autoStop{width: 30px; height: 30px; margin: 0; border-radius: 50%; background: rgba(0, 0, 0, 0.5) url(../img/main/slide_stop.png) center / 8px 10px no-repeat;}
    .sec_banner.active .btn_autoStop{background-image: url(../img/main/slide_play.png);}

    .sec_theme .theme_wrap{flex-direction: column; gap: 10px;}
    .theme_wrap a{height: auto;}

    .alio_wrap .swiper-container{overflow: hidden; padding-bottom: 30px; font-size: 0;}
    .alio_wrap li a .img{position: relative; padding-bottom: 100%; height: auto;}
    .alio_wrap li a .img img{position: absolute; top: 0; left: 0;}
    .alio_wrap .txt_wrap{margin-top: 12px;}
    .alio_wrap .txt_wrap strong{font-size: 16px; margin-bottom: 3px;}
    .alio_wrap .txt_wrap span{font-size: 14px; margin-bottom: 2px;}

    #closePopup .pc{display: none;}
    #closePopup .mo{display: block; width: 100%; object-fit: cover;}
    #closePopup .layerpop {max-width: 90%;}
    #closePopup a{height: 15%; bottom: 16.5%; width: 82%;}
    #closePopup .viewNone,
    #closePopup .viewNone button {font-size: 15px;}
    #closePopup input[type="checkbox"] + label:before {width: 20px; height: 20px; background: url(../img/main/icon_check_none_mo.png) 0 0 / 100% 100% no-repeat;}
    #closePopup input[type="checkbox"]:checked + label:after {width: 20px; height: 20px; background: url(../img/main/icon_checked_mo.png) 0 0 / 100% 100% no-repeat;}


}