@charset "utf-8";
/* pretendard */
@font-face{font-family:"Pretendard";src:local(Pretendard-Thin),url(../font/Pretendard-Thin.woff2) format('woff2'),url(../font/Pretendard-Thin.woff) format('woff');font-weight:100;}
@font-face{font-family:"Pretendard";src:local(Pretendard-Light),url(../font/Pretendard-Light.woff2) format('woff2'),url(../font/Pretendard-Light.woff) format('woff');font-weight:200;}
@font-face{font-family:"Pretendard";src:local(Pretendard-ExtraLight),url(../font/Pretendard-ExtraLight.woff2) format('woff2'),url(../font/Pretendard-ExtraLight.woff) format('woff');font-weight:300;}
@font-face{font-family:"Pretendard";src:local(Pretendard-Regular),url(../font/Pretendard-Regular.woff2) format('woff2'),url(../font/Pretendard-Regular.woff) format('woff');font-weight:400;}
@font-face{font-family:"Pretendard";src:local(Pretendard-Medium),url(../font/Pretendard-Medium.woff2) format('woff2'),url(../font/Pretendard-Medium.woff) format('woff');font-weight:500;}
@font-face{font-family:"Pretendard";src:local(Pretendard-SemiBold),url(../font/Pretendard-SemiBold.woff2) format('woff2'),url(../font/Pretendard-SemiBold.woff) format('woff');font-weight:600;}
@font-face{font-family:"Pretendard";src:local(Pretendard-Bold),url(../font/Pretendard-Bold.woff2) format('woff2'),url(../font/Pretendard-Bold.woff) format('woff');font-weight:700;}
@font-face{font-family:"Pretendard";src:local(Pretendard-ExtraBold),url(../font/Pretendard-ExtraBold.woff2) format('woff2'),url(../font/Pretendard-ExtraBold.woff) format('woff');font-weight:800;}
@font-face{font-family:"Pretendard";src:local(Pretendard-Black),url(../font/Pretendard-Black.woff2) format('woff2'),url(../font/Pretendard-Black.woff) format('woff');font-weight:900;}


html,body,h1,h2,h3,h4,h5,h6,div,p,blockquote,pre,code,address,ul,ol,li,menu,nav,section,article,aside,
dl,dt,dd,table,thead,tbody,tfoot,label,caption,th,td,form,fieldset,legend,hr,input,button,textarea,object,figure,figcaption,* {margin:0;padding:0;box-sizing : border-box;word-break: keep-all; line-height: 1.4;}
html, body{width:100%;font-weight: 400;position: relative;}
html{-webkit-tap-highlight-color:rgba(0, 0, 0, 0);-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;}
body{background:#fff; min-width:320px; -webkit-text-size-adjust:none;word-wrap:break-word;word-break:break-all;}
body,input,select,textarea,button,fieldset {box-sizing : border-box;border:none;font-family: "Pretendard", sans-serif !important; line-height: 1.4;color:  var(--grey-darken4);letter-spacing: -0.025em;word-break: keep-all;}
table {border-collapse: collapse;border-spacing: 0;}
caption {display: none;}
ul,ol,li{list-style:none;box-sizing: border-box;}
div,p,a {box-sizing: border-box;}
span, strong {line-height: inherit;}
a {text-decoration: none;color: var(--grey-darken4);display: inline-block; cursor: pointer;}
button {cursor: pointer; background-color: #fff;color:  var(--grey-darken4);}
img {max-width: 100%;}
form {display: block; width: 100%;}

.ellipsis{
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
} 
.ellipsis2{
    overflow: hidden;
    white-space: normal;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: keep-all;
}

.txtCenter{text-align: center !important;}
.txtLeft{text-align: left !important;}
.txtRight{text-align: right !important;}

.w100, .w100p{width: 100%;}

.anywhere{
    overflow-wrap: anywhere;
}

.swiper-wrapper{
    height: auto;
}

.skipNav{
	position: relative;
	z-index: 300;
}
.skipNav a{
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	background-color: #000;
	text-align: center;
	padding: 7px 0;
	font-size: 16px;
	color: #fff;
}
.skipNav a:focus{
	top: 0;
	z-index: 100;
}

.floating{
    position: fixed;
    bottom: 60px;
    right: 30px;
    z-index: 50;
}
.floatingBtn{
    width: 82px;
    height: 82px;
    border-radius: 50%;
    display: flex;
    gap: 4px 0;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.2;
    box-shadow: 0 4px 4px rgba(0, 0, 0, .25);
    transition: var(--transition);
}
.quickMenuBtn{
    background-color: var(--primary-base);
    color: #fff;
}
.floatingBtn.eventBtn{
    margin-bottom: 16px;
    background-image: url("../image/event-quick.png");
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}
.aiBtn{
    background-color: #fff;
    margin-bottom: 42px;
    position: relative;
}
.aiBtn .iconAi{
    width: 48px;
    height: 48px;
    background-image: url(../image/icon-ai.gif);
}
.aiBtn>span{
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    padding-top: 8px;
    width: 100%;
    text-align: center;
    transform: translateY(100%);
}
.quickMenuArea{
    position: relative;
}
.quickMenuW{
    position: absolute;
    right: 112px;
    top: 3px;
    display: flex;
    gap: 0 16px;
    z-index: -1;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
}
.quickMenu{
    display: block;
    height: 78px;
    width: 206px;
    background-color: #fff;
    padding: 12px 20px;
    border: 1px solid var(--border-color);
    transition: var(--transition);
}
.quickMenuArea.active .quickMenuW{
    z-index: 9999;
    opacity: 1;
    visibility: visible;
}
.quickMenu>p{
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    margin-top: 8px;
}
.iconQick1{
    background-image: url(../image/quick-icon1.svg);
}
.iconQick2{
    background-image: url(../image/quick-icon2.svg);
}
.iconQick3{
    background-image: url(../image/quick-icon3.svg);
}
.iconQick4{
    background-image: url(../image/quick-icon4.svg);
}
.quickMenuMoW{
    display: none;
}
@media screen and (min-width: 1201px){
    .quickMenuBtn:hover{
        background-color: var(--primary-darken2);
    }
    .aiBtn:hover{
        background-color: var(--grey-lighten4);
    }
    .floatingBtn.eventBtn:hover{
        filter: brightness(.8);
    }
    .quickMenu:hover{
        background-color: var(--primary-base);
        border-color: var(--primary-base);
        color: #fff;
    }
    .quickMenu:hover>.icon.iconQick1{
        background-image: url(../image/quick-icon1-active.svg);
    }
    .quickMenu:hover>.icon.iconQick2{
        background-image: url(../image/quick-icon2-active.svg);
    }
    .quickMenu:hover>.icon.iconQick3{
        background-image: url(../image/quick-icon3-active.svg);
    }
    .quickMenu:hover>.icon.iconQick4{
        background-image: url(../image/quick-icon4-active.svg);
    }
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
    :root{
        --bottom-navi: 78px;
    }
    .floating{
        right: unset;
        left: 0;
        bottom: 0;
        width: 100%;
        height: var(--bottom-navi);
        background-color: #fff;
        display: flex;
        padding: 0 var(--container-gutter);
        box-shadow: 0 -3px 10px rgba(0, 0, 0, .08);
    }
    .quickMenuArea{
        display: none;
    }
    .quickMenuMoW{
        display: flex;
        width: 75%;
    }
    .quickMenuMo{
        flex: 1 1 33.333%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        font-size: 14px;
        gap: 4px 0;
        font-weight: 600;
        line-height: 1.2;
    }
    .quickMenuMo>.icon{
        width: 32px;
        height: 32px;
        background-size: 28px auto;
        border-radius: 50%;
    }
    .iconQickMo1{
        background-image: url(../image/quick-icon1-mo.svg);
    }
    .iconQickMo2{
        background-image: url(../image/quick-icon2-mo.svg);
    }
    .iconQickMo3{
        background-image: url(../image/quick-icon3-mo.svg);
    }
    .quickMenuMo.active{
        color: var(--primary-base);
    }
    .quickMenuMo.active>.icon{
        background-color: var(--primary-base);
    }
    .quickMenuMo.active .iconQickMo1{
        background-image: url(../image/quick-icon1-mo-active.svg);
    }
    .quickMenuMo.active .iconQickMo2{
        background-image: url(../image/quick-icon2-mo-active.svg);
    }
    .quickMenuMo.active .iconQickMo3{
        background-image: url(../image/quick-icon3-mo-active.svg);
    }
    .aiBtn{
        margin-bottom: 0;
        width: 25%;
        height: 100%;
        border-radius: 0;
        box-shadow: none;
        font-size: 14px;
        gap: 4px 0;
    }
    .aiBtn .iconAi{
        width: 32px;
        height: 32px;
        background-size: 22px auto;
    }
    .aiBtn>span{
        position: static;
        transform: translateY(0);
        padding-top: 0;
        font-size: 14px;
    }
    .quickMenu{
        height: auto;
        padding: 12px 16px;
        max-width: calc((100vw - 136px) / 4);
    }
    .quickMenu>p{
        font-size: 14px;
    }
    .floatingBtn.eventBtn{
        position: fixed;
        bottom: calc(var(--bottom-navi) + 16px);
        right: 20px;
        width: 58px;
        height: 58px;
        margin-bottom: 0;
    }
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .quickMenuW{
        width: calc(100vw - 112px);
        flex-wrap: wrap;
        top: 50%;
        transform: translateY(-50%);
    }
    .quickMenu{
        width: calc(50% - 4px);
        max-width: calc(50% - 4px);
        padding: 12px;
    }
    .quickMenu>.icon{
        width: 20px;
        height: 20px;
    }
}
@media screen and (max-width: 500px){
    :root{
        --bottom-navi: 60px;
    }
    .floating{
        padding: 0;
    }
    .quickMenuMo{
        font-size: 12px;
        gap: 2px 0;
    }
    .quickMenuMo>.icon{
        width: 30px;
        height: 30px;
        background-size: 24px auto;
    }
    .aiBtn{
        font-size: 12px;
        gap: 2px 0;
    }
    .aiBtn>span{
        font-size: 12px;
    }
    .aiBtn .iconAi{
        width: 30px;
        height: 30px;
        background-size: 24px auto;
    }
}

.chatArea{
    display: block !important;
    position: fixed;
    padding: 30px 142px;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .4);
    z-index: -1;
    opacity: 0;
    visibility: hidden;
    transform: translate(0, 0);
    transition: all .25s ease-in-out, backgroundColor .01s ease-in-out, transform .15s ease-out;
}
html:has(.chatArea.active:not(.min)){
    height: 100vh;
    max-height: var(--view-height);
    overflow: hidden;
}
.chatArea.active{
    opacity: 1;
    visibility: visible;
    /*z-index: 999;*/
    z-index: 99999;
}
.chatArea:not(.min){
    transform: translate(0, 0) !important;
}
.floatingBtn.aiClose{
    position: fixed;
    bottom: 60px;
    right: 30px;
}
.chat{
    width: 100%;
    max-width: var(--container);
    height: 100%;
    overflow: hidden;
    margin: 0 auto;
}
.chatHead{
    width: 100%;
    height: 88px;
    padding: 0 40px;
    position: relative;
    box-shadow: 0 3px 10px rgba(0, 76, 174, .08);
    display: flex;
    gap: 0 18px;
    align-items: center;
    background-color: #fff;
    transition: var(--transition);
}
.chatArea .iconAi{
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background-size: 32px auto;
    background-color: var(--primary-lighten5);
    border: 1px solid var(--primary-lighten3);
}
.chatHeadTit{
    display: flex;
    align-items: center;
    gap: 0 8px;
}
.chatHeadTit>h2{
    font-size: 20px;
    font-weight: 600;
    line-height: 1;
}
.chatHeadTit>p{
    font-size: 14px;
    line-height: 1;
}
.chatHeadTitW>p{
    font-size: 14px;
    line-height: 1;
    margin-top: 8px;
}
.chatHeadTitW>p>br{
    display: none;
}
.chatHeadBtnW{
    margin-left: auto;
    display: flex;
    gap: 0 16px;
}
.chatHeadBtn{
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--grey-lighten5);
    transition: var(--transition);
}
.chatHeadBtn.primary{
    background-color: var(--primary-base);
}

.chatArea.min{
    padding: 0;
    bottom: 30px;
    right: 142px;
    width: 360px;
    height: calc(var(--view-height) - 60px - var(--header-height));
    box-shadow: 0 3px 20px rgba(0, 76, 174, .2);
    background-color: transparent;
}
.chatArea.min .floatingBtn.aiClose{
    opacity: 0;
    visibility: hidden;
}
.chatArea.min .chatHead{
    height: 80px;
    padding: 0 16px;
    gap: 0 8px;
    user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    cursor: move;
}
.chatArea.min .iconAi{
    width: 38px;
    min-width: 38px;
    height: 38px;
    background-size: 24px auto;
    /*margin-bottom: 44px;*/
}
.chatArea.min .chatHeadTit{
    display: block;
   /* margin-bottom: 44px;*/
}
.chatArea.min .chatHeadTit>h2{
    font-size: 16px;
}
.chatArea.min .chatHeadTit>p{
    font-size: 14px;
    margin-top: 4px;
}
.chatArea.min .chatHeadTitW>p{
    font-size: 14px;
    position: absolute;
    bottom: 13px;
    left: 16px;
    line-height: 18px;
}
.chatArea.min .chatHeadTitW>p>br{
    display: block;
}
.chatArea.min .chatHeadBtnW{
    gap: 0 8px;
    /*margin-bottom: 44px;*/
}
.chatArea.min .chatHeadBtn{
    width: 38px;
    height: 38px;
}

@media screen and (min-width: 1201px){
    .floatingBtn.aiClose:hover{
        background-color: var(--grey-lighten4);
    }
    .chatHeadBtn:hover{
        background-color: var(--grey-lighten3);
    }
    .chatHeadBtn.primary:hover{
        background-color: var(--primary-darken2);
    }
    .chatArea.hide:not(.min) .chatHead,
    .chatArea.hide:not(.min) .chatBody{
        opacity: 0;
        visibility: hidden;
    }
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
    html:has(.chatArea.min.active){
        height: 100vh;
        max-height: var(--view-height);
        overflow: hidden;
    }
    .chatArea.min {
        padding: var(--container-gutter);
        bottom: 0;
        right: 0;
        width: 100%;
        height: var(--view-height);
        box-shadow: none;
        background-color: rgba(0, 0, 0, .4);
    }
    .chatArea.min .chatHead{
        cursor: default;
    }
    .chatArea{
        transform: translate(0, 0) !important;
    }
    .aiScale,
    .chatArea>.aiClose{
        display: none;
    }
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .chatArea.min{
        padding: 0;
    }
}
@media screen and (max-width: 500px){
}
@media screen and (max-width: 374px){
}


.chatBody{
    height: calc(100% - 212px);
    max-height: calc(100% - 212px);
    padding: 40px 30px 40px 40px;
    font-size: 16px;
    background-color: var(--primary-lighten5);
    transition: var(--transition);
}
.chatBodyInner{
    padding-right: 10px;
    width: 100%;
    height: 100%;
    max-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
}
.chatBodyInner::-webkit-scrollbar {
    width: 5px;
}
.chatBodyInner::-webkit-scrollbar-track {
    background-color:var(--primary-lighten5);
    border-radius: 999px;
}
.chatBodyInner::-webkit-scrollbar-thumb {
    background-color: var(--primary-base);
    border-radius: 999px;
}
.chatBodyInner::-webkit-scrollbar-button {
    display: none;
}

.chatSpeechArea + .chatSpeechArea{
    margin-top: 30px;
}

.chatSpeechW{
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    gap: 0 16px;
}
.chatSpeechArea.que .chatSpeechW{
    flex-direction: row-reverse;
}
.chatSpeech{
    max-width: 58%;
}
.chatSpeechArea.ai .chatSpeech{
    background-color: #fff;
    padding: 30px;
    box-shadow: 0 4px 16px rgba(0, 76, 174, .08);
}
.chatSpeechArea.que .chatSpeech{
    position: relative;
    margin-right: 13px;
    padding: 24px 30px;
    background-color: var(--primary-lighten3);
    width: fit-content;
}
.chatSpeechArea.que .chatSpeech::before{
    content: "";
    display: block;
    position: absolute;
    width: 18px;
    height: 18px;
    background-image: url(../image/icon-chat-speech.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    top: 50%;
    right: -13px;
    transform: translateY(-50%);
}
.chatSpeechHead{
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 0 10px;
}
.chatSpeechHead .iconAi{
    background-color: #fff;
}
.chatSpeechHead>strong{
    display: block;
    font-size: 16px;
    line-height: 1;
    font-weight: 600;
    color: var(--primary-base);
}
.chatSpeech>p{
    font-size: 16px;
    font-weight: 500;
}
.chatSpeech>* + *{
    margin-top: 8px;
}
.btn.btnChatDown {
    flex-direction: column;
    align-items: flex-start;
    padding: 10px 56px 10px 10px;
    height: auto;
    position: relative;
    margin: 0 -10px;
    background-color: transparent;
}
.btn.btnChatDown::before {
    content: '';
    display: block;
    background-image: url(../image/my/icon-chat-down.svg);
    width: 36px;
    height: 36px;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}
.btn.btnChatDown>p {
    text-align: left;
    font-size: 16px;
}
.btn.btnChatDown .txt {
    color: #555;
    font-weight: 500;
}
.chatLink{
    color: var(--sky-base) !important;
    text-decoration: underline !important;
    transition: var(--transition);
}
.chatSpeech .btnBadge{
    height: 32px;
    padding: 0 16px;
    font-size: 16px;
}
.chatFile{
    max-width: 100%;
    display: flex;
    align-items: center;
    gap: 0 4px;
    font-size: 16px;
    font-weight: 500;
    color: var(--sky-base);
    text-decoration: underline;
    transition: var(--transition);
}
.chatFile>.icon{
    flex: 0 0 auto;
    min-width: 20px;
}
.chatFile>span{
    display: block;
    max-width: calc(100% - 24px);
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
}
.chatTime{
    line-height: 1;
    display: block;
    font-size: 15px;
    color: var(--grey-base);
}
.chatSpeechBottom{
    display: flex;
    gap: 0 16px;
    margin-top: 24px;
}
.thumbBtn{
    height: 36px;
    padding: 0 14px;
    background-color: #fff;
    border-radius: 999px;
    border: 1px solid var(--border-color-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0 6px;
    transition: var(--transition);
    font-size: 16px;
    font-weight: 500;
}
.thumbBtn.active{
    background-color: var(--primary-darken3);
    border-color: var(--primary-darken3);
    color: #fff;
}
.chatSpeechW.slide{
    position: relative;
}
.chatSpeechW.slide .chatSpeech{
    flex-basis: 0;
    flex-grow: 1;
    max-width: calc(100% - 13px);
}
.chatSpeechW.slide p + .chatSlide{
    margin-top: 24px;
}
.chatSpeechW.slide .chatTime{
    position: absolute;
    bottom: -16px;
    right: 13px;
    transform: translateY(100%);
}
.chatEduContents{
    margin-top: 16px;
    display: flex;
    align-items: center;
    gap: 0 16px;
}
.chatEduContents>.label{
    flex: 0 0 auto;
    min-width: 56px;
}
.chatEduContents>strong{
    flex-basis: 0;
    flex-grow: 1;
    max-width: calc(100% - 72px);
    display: block;
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
}


.chatSlide {
    position: relative;
    width: 100%;
    overflow: hidden;
}
.slideTrack {
    display: flex;
    transition: transform 0.45s ease;
    margin-right: -20px;
}
.slideItem {
    flex: 0 0 25%;
    width: 25%;
    min-width: 25%;
    flex-shrink: 0;
    box-sizing: border-box;
    padding-right: 20px;
}
.chatSlide::after{
    content: "";
    display: block;
    position: absolute;
    width: 120px;
    height: 100%;
    top: 0;
    right: 0;
    background-image: linear-gradient(to right, transparent, #fff);
    z-index: 3;
    transition: var(--transition);
}
.chatSlide .slideControl{
    position: absolute;
    height: calc(100% - 42px);
    top: 0;
    right: 0;
    z-index: 5;
    align-items: center;
    transition: var(--transition);
}
.chatSlide.disabled::after,
.chatSlide.disabled .slideControl{
    opacity: 0;
    visibility: hidden;
}
.chatSpeechW.edu .chatSpeech{
    width: 484px;
}
.chatEduW{
    padding: 20px 24px;
    border-radius: 4px;
    border: 1px solid var(--border-color);
    width: 100%;
}
.chatSpeech p + .chatEduW{
    margin-top: 24px;
}
.chatEdu{
    font-size: 13px;
    font-weight: 500;
}
.chatEduW>.chatEdu:nth-child(1){
    --primary-base: var(--secondary-darken1);
    --primary-lighten4: var(--secondary-lighten4);
}
.chatEduW>.chatEdu:nth-child(2){
    --primary-base: var(--orange-base);
    --primary-lighten4: var(--orange-lighten5);
}
.chatEduW>.chatEdu:nth-child(3){
    --primary-base: var(--grey-darken4);
    --primary-lighten4: var(--grey-lighten4);
}
.chatEdu + .chatEdu{
    margin-top: 28px;
}
.chatEduHead{
    display: flex;
    align-items: flex-start;
    gap: 0 6px;
    margin-bottom: 14px;
}
.chatEduHead>strong{
    font-size: 14px;
    font-weight: 600;
    display: block;
    margin-top: 3px;
    color: var(--primary-base);
}
.chatEdu>p + .progressArea{
    margin-top: 16px;
}
.progressW{
    display: flex;
    align-items: center;
    gap: 0 10px;
}
.progressW + .progressW{
    margin-top: 8px;
}
.chatEdu .progressW>p:first-child{
    min-width: 90px;
}
.progress{
    flex-basis: 0;
    flex-grow: 1;
    max-width: 160px;
    height: 6px;
    border-radius: 999px;
    background-color: var(--primary-lighten4);
    overflow: hidden;
    position: relative;
    margin-bottom: 0;
    box-shadow: none;
}
.progressInner{
    position: absolute;
    height: 100%;
    border-radius: 999px;
    background-color: var(--primary-base);
    top: 0;
    left: 0;
}
.chatArea.min .chatBody{
    height: calc(100% - 186px);
    max-height: calc(100% - 186px);
    padding: 20px 10px 20px 16px;
    font-size: 15px;
}
.chatArea.min .chatBodyInner{
    padding-right: 6px;
}

.chatArea.min .chatSpeechArea + .chatSpeechArea{
    margin-top: 20px;
}

.chatArea.min .chatSpeechW{
    display: block;
}
.chatArea.min .chatSpeech{
    max-width: calc(100% - 10px);
}
.chatArea.min .chatSpeechArea.ai .chatSpeech{
    padding: 16px 10px;
}
.chatArea.min .chatSpeechArea.que .chatSpeech{
    padding: 16px 10px;
    margin-right: 10px;
    margin-left: auto;
}
.chatArea.min .chatSpeechArea.que .chatSpeech::before{
    width: 14px;
    height: 14px;
    right: -10px;
}
.chatArea.min .chatSpeechHead{
    margin-bottom: 10px;
}
.chatArea.min .chatSpeechHead .iconAi{
    margin-bottom: 0;
}
.chatArea.min .chatSpeechHead>strong{
    font-size: 15px;
}
.chatArea.min .chatSpeech>p{
    font-size: 15px;
}
.chatSpeech .btnBadge{
    font-size: 15px;
}
.chatFile{
    font-size: 15px;
}
.chatArea.min .chatSpeech>* + *{
    margin-top: 4px;
}
.chatArea.min .chatTime{
    font-size: 14px;
    margin-top: 8px;
}
.chatArea.min .chatSpeechArea.que .chatTime{
    text-align: right;
    padding-right: 10px;
}
.chatArea.min .chatSpeechBottom{
    gap: 0 8px;
    margin-top: 16px;
}
.chatArea.min .thumbBtn{
    height: 32px;
    padding: 0 12px;
    gap: 0 4px;
    font-size: 14px;
}
.chatArea.min .chatSpeechW.slide .chatSpeech{
    max-width: calc(100% - 10px);
}
.chatArea.min .chatSpeechW.slide p + .chatSlide{
    margin-top: 16px;
}
.chatArea.min .chatSpeechW.slide .chatTime{
    position: static;
    transform: translateY(0);
}
.chatArea.min .chatEduContents{
    margin-top: 12px;
    gap: 0 8px;
}
.chatArea.min .chatEduContents>.label{
    font-size: 13px;
    min-width: 48px;
}
.chatArea.min .chatEduContents>strong{
    max-width: calc(100% - 56px);
    font-size: 15px;
}
.chatArea.min .chatSlide{
    padding-right: 80px;
}
.chatArea.min .chatSlide::after{
    width: 60px;
}
.chatArea.min .chatSlide .slideControl{
    height: calc(100% - 42px);
}
.chatArea.min .chatSpeechW.edu .chatSpeech{
    width: 100%
}
.chatArea.min .chatEduW{
    padding: 10px;
}
.chatArea.min .chatSpeech p + .chatEduW{
    margin-top: 10px;
}
.chatArea.min .chatEdu + .chatEdu{
    margin-top: 16px;
}
.chatArea.min .chatEduHead{
    margin-bottom: 10px;
}
.chatArea.min .chatEdu>p + .progressArea{
    margin-top: 10px;
}
.chatArea.min .progressW{
    gap: 0 8px;
    flex-wrap: wrap;
}
.chatArea.min .progressW + .progressW{
    margin-top: 4px;
}
.chatArea.min .progress{
    max-width: calc(100% - 98px);
}
.chatArea.min .progressW>p:last-child{
    flex: 1 1 100%;
    text-align: right;
}
.chatArea.min .btn.btnChatDown {
    margin: 0;
}
.chatArea.min .btn.btnChatDown {
    padding: 10px 30px 10px 0;
}
.chatArea.min .btn.btnChatDown::before {
    width: 28px;
    height: 28px;
    background-size: contain;
    background-repeat: no-repeat;
    right: 0;
}
.chatArea.min .slideItem{
    flex: 0 0 100%;
    width: 100%;
    min-width: 100%;
}

@media screen and (min-width: 1201px){
    .chatFile:hover,
    .chatLink:hover{
        color: var(--primary-base) !important;
    }
    .thumbBtn:hover{
        background-color: var(--primary-darken3);
        border-color: var(--primary-darken3);
        color: #fff;
    }
    .btn.btnChatDown:hover {
        background-color: var(--grey-lighten5);
    }
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
    .chatArea.min .chatSlide{
        padding-right: 0;
    }
    .chatArea.min .slideItem {
        flex: 0 0 33.3333%;
        width: 33.3333%;
        min-width: 33.3333%;
    }
}
@media screen and (max-width: 1023px){
    .chatArea.min .slideItem {
        flex: 0 0 50%;
        width: 50%;
        min-width: 50%;
    }
}
@media screen and (max-width: 767px){
    .chatArea.min .chatEduContents{
        display: block;
    }
    .chatArea.min .chatEduContents>strong{
        margin-top: 8px;
    }
    .chatArea.min .chatSlide{
        padding-right: 80px;
    }
    .chatArea.min .chatSlide .slideControl{
        height: calc(100% - 64px);
    }
    .chatArea.min .slideItem {
        flex: 0 0 100%;
        width: 100%;
        min-width: 100%;
    }
    .btn.btnChatDown {
        margin: 0;
    }
    .btn.btnChatDown {
        padding: 10px 30px 10px 0;
    }
    .btn.btnChatDown::before {
        width: 28px;
        height: 28px;
        background-size: contain;
        background-repeat: no-repeat;
        right: 0;
    }
}
@media screen and (max-width: 500px){
}
.chatFoot{
    --chat-btn: 54px;

    position: relative;
    height: 124px;
    background-color: #fff;
}
.chatQArea{
    position: absolute;
    z-index: 5;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(var(--view-height) - 332px);
    background-color: #fff;
    border-top: 1px solid var(--primary-lighten3);
    transform: translateY(0);
    opacity: 0;
    visibility: hidden;
    transition: 0.4s ease-in-out;
}
.chatFoot.active .chatQArea{
    transform: translateY(-100%);
    opacity: 1;
    visibility: visible;
}
.chatQW{
    position: relative;
    width: 100%;
    height: 100%;
    padding: 38px 20px 38px 38px;
}
button.aiQClose{
    position: absolute;
    width: var(--chat-btn);
    height: var(--chat-btn);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    top: 34px;
    right: 34px;
    background-color: transparent;
    transition: var(--transition);
}
.chatQList{
    width: 100%;
    height: 100%;
    max-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    padding-right: 74px;
}
.chatQList::-webkit-scrollbar {
    width: 5px;
}
.chatQList::-webkit-scrollbar-track {
    background-color:var(--primary-lighten5);
    border-radius: 999px;
}
.chatQList::-webkit-scrollbar-thumb {
    background-color: var(--primary-base);
    border-radius: 999px;
}
.chatQList::-webkit-scrollbar-button {
    display: none;
}
.chatQ + .chatQ{
    margin-top: 44px;
}
.chatQHead{
    display: flex;
    align-items: flex-start;
    gap: 0 12px;
    margin-bottom: 14px;
}
.chatQHead>.icon{
    width: 40px;
    min-width: 40px;
    height: 40px;
    flex: 0 0 auto;
}
.chatQHead>strong{
    display: block;
    flex-basis: 0;
    flex-grow: 1;
    font-size: 20px;
    font-weight: 600;
    margin-top: 6px;
}
.chatQBtnW{
    display: flex;
    flex-wrap: wrap;
}
.chatQBtn{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    height: 38px;
    font-size: 18px;
    transition: var(--transition);
}
.chatQLabel{
    gap: 16px;
}
.chatQBtnLabel{
    flex: 0 0 auto;
    padding: 0 14px;
    border-radius: 999px;
    background-color: var(--primary-lighten5);
    font-weight: 500;
    color: var(--primary-base);
}
.chatQTxt{
    padding: 30px;
    gap: 20px;
    background-color: var(--grey-lighten5);
}
.chatQBtnTxt{
    flex: 1 1 calc(50% - 10px);
    max-width: calc(50% - 10px);
    width: calc(50% - 10px);
    padding: 0 8px;
    color: var(--grey-base);
    font-weight: 600;
    text-align: left;
    background-color: transparent;
}
.chatFootInner{
    position: relative;
    z-index: 10;
    padding: 0 40px;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 0 20px;
    background-color: #fff;
    box-shadow: 0 -3px 10px rgba(0, 76, 174, .08);
}
.hamBtnBasic{
    flex: 0 0 auto;
    position: relative;
    width: var(--chat-btn);
    height: var(--chat-btn);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: transparent;
    transition: var(--transition);
}
.hamBtnBasicLine::before,
.hamBtnBasicLine::after,
.hamBtnBasicLine{
    display: block;
    width: 28px;
    height: 3px;
    border-radius: 999px;
    background-color: var(--grey-base);
}
.hamBtnBasicLine{
    position: relative;
    transition: var(--transition);
}
.hamBtnBasicLine::before,
.hamBtnBasicLine::after{
    content: "";
    position: absolute;
    left: 0;
}
.hamBtnBasicLine::before{
    top: -8px;
    transform: rotate(0);
    transition: .15s transform ease-out, .15s .15s top ease-out;
}
.hamBtnBasicLine::after{
    bottom: -8px;
    transition: .15s transform ease-out, .15s .15s bottom ease-out;
}
.hamBtnBasic.active .hamBtnBasicLine{
    background-color: transparent;
}
.hamBtnBasic.active .hamBtnBasicLine::before{
    top: 0;
    transform: rotate(45deg);
    transition: .15s top ease-out, .15s .15s transform ease-out;
}
.hamBtnBasic.active .hamBtnBasicLine::after{
    bottom: 0;
    transform: rotate(-45deg);
    transition: .15s bottom ease-out, .15s .15s transform ease-out;
}
.aiQ.hamBtnBasic{
    margin-bottom: 24px;
}
.chatFootCenter{
    flex-basis: 0;
    flex-grow: 1;
    position: relative;
}
.chatFootCenter::after{
    content: "";
    display: block;
    position: absolute;
    width: calc(100% + 40px);
    height: 74px;
    top: 27px;
    left: -20px;
    z-index: 9;
    background-color: #fff;
}
.chatFootCenter>p{
    position: relative;
    z-index: 10;
    margin-top: 10px;
    font-size: 14px;
    line-height: 1;
}
.chatFootCenter>p>br{
    display: none;
}
.chatInput{
    width: 100%;
    height: var(--chat-btn) !important;
    background-color: var(--primary-lighten5);
    border: 1px solid var(--primary-lighten3);
    border-radius: 999px;
    padding: 0 40px 0 56px;
    font-size: 18px;
    color: var(--grey-darken4);
    font-weight: 500;
    position: relative;
    z-index: 10;
}
.chatInput::placeholder{
    color: var(--grey-darken4);
}
button.chatHistoryBtn{
    position: absolute;
    top: 11px;
    left: 16px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    transition: var(--transition);
}
.chatHistoryArea{
    position: absolute;
    bottom: calc(var(--chat-btn) / 2);
    left: 0;
    z-index: 5;
    width: 100%;
    background-color: #fff;
    padding: 10px 30px 49px 40px;
    border-radius: 8px 8px 0 0;
    border: 1px solid var(--primary-lighten3);
    box-shadow: 0 4px 10px rgba(0, 76, 174, .08);
    opacity: 0;
    visibility: hidden;
    transform: translateY(100%);
    transition: 0.35s ease-in-out;
}
.chatHistoryArea.active{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.chatHistoryW{
    display: block;
    padding-right: 10px;
    max-height: 384px;
    overflow-x: hidden;
    overflow-y: auto;
}
.chatHistoryW::-webkit-scrollbar {
    width: 5px;
}
.chatHistoryW::-webkit-scrollbar-track {
    background-color:var(--primary-lighten5);
    border-radius: 999px;
}
.chatHistoryW::-webkit-scrollbar-thumb {
    background-color: var(--primary-base);
    border-radius: 999px;
}
.chatHistoryW::-webkit-scrollbar-button {
    display: none;
}
.chatHistoryW>li{
    display: flex;
    align-items: center;
    gap: 0 8px;
    height: 64px;
}
.chatHistoryW>li + li{
    border-top: 1px solid var(--border-color);
}
.chatSend{
    flex: 0 0 auto;
    width: var(--chat-btn);
    height: var(--chat-btn);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: var(--primary-base);
    margin-bottom: 24px;
    transition: var(--transition);
}
.chatHistory{
    flex-basis: 0;
    flex-grow: 1;
    text-align: left;
    padding: 8px 0 8px 42px;
    font-size: 16px;
    font-weight: 500;
    max-width: calc(100% - 32px);
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
    position: relative;
    background-color: transparent;
    transition: var(--transition);
}
.chatHistory::before{
    content: "";
    display: block;
    position: absolute;
    width: 24px;
    height: 24px;
    background-image: url(../image/icon-history-grey.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
button.chatHistoryClose{
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    transition: var(--transition);
}

.chatArea.min .chatFoot{
    --chat-btn: 38px;
    height: 106px;
}
.chatArea.min .chatQArea{
    height: calc(var(--view-height) - 320px - var(--header-height));
}
.chatArea.min .chatQW{
    padding: 20px 10px 20px 16px;
}
.chatArea.min button.aiQClose{
    width: 32px;
    height: 32px;
    top: 16px;
    right: 20px;
}
.chatArea.min button.aiQClose>.icon{
    width: 24px;
    height: 24px;
}
.chatArea.min .chatQList{
    padding-right: 10px;
}
.chatArea.min .chatQ + .chatQ{
    margin-top: 20px;
}
.chatArea.min .chatQHead{
    gap: 0 8px;
    margin-bottom: 10px;
}
.chatArea.min .chatQHead>.icon{
    width: 24px;
    min-width: 24px;
    height: 24px;
}
.chatArea.min .chatQHead>strong{
    font-size: 16px;
    margin-top: 2px;
}
.chatArea.min .chatQBtn{
    height: 32px;
    font-size: 15px;
}
.chatArea.min .chatQLabel{
    gap: 8px;
}
.chatArea.min .chatQBtnLabel{
    padding: 0 12px;
}
.chatArea.min .chatQTxt{
    gap: 2px 8px;
    padding: 10px 6px;
}
.chatArea.min .chatQBtnTxt{
    flex: 1 1 100%;
    max-width: 100%;
    width: 100%;
    min-height: 32px;
    padding: 4px 10px;
    height: auto;
}
.chatArea.min .chatFootInner{
    padding: 0 16px;
    gap: 0 6px;
}
.chatArea.min .hamBtnBasic{
    position: relative;
    z-index: 15;
    margin-bottom: 42px;
}
.chatArea.min .hamBtnBasicLine::before,
.chatArea.min .hamBtnBasicLine::after,
.chatArea.min .hamBtnBasicLine{
    width: 20px;
    height: 2px;
}
.chatArea.min .hamBtnBasicLine::before{
    top: -6px;
}
.chatArea.min .hamBtnBasicLine::after{
    bottom: -6px;
}
.chatArea.min .hamBtnBasic.active .hamBtnBasicLine::before{
    top: 0;
}
.chatArea.min .hamBtnBasic.active .hamBtnBasicLine::after{
    bottom: 0;
}
.chatArea.min .chatFootCenter{
    flex: 1 1 calc(100% - var(--chat-btn - 8px));
    min-width: calc(100% - var(--chat-btn - 8px));
}
.chatArea.min .chatFootCenter::after{
    top: 19px;
}
.chatArea.min .chatFootCenter>p{
    font-size: 14px;
    line-height: 18px;
    margin-top: 6px;
    width: calc(100% + (var(--chat-btn) * 2) + 12px);
    position: relative;
    left: calc((var(--chat-btn) + 6px) * -1);
}
.chatArea.min .chatFootCenter>p>br{
    display: block;
}
.chatArea.min .chatInput{
    padding: 0 16px 0 32px;
    font-size: 14px;
}
.chatArea.min button.chatHistoryBtn{
    width: 24px;
    height: 24px;
    top: 7px;
    left: 6px;
}
.chatArea.min button.chatHistoryBtn .icon{
    width: 20px;
    height: 20px;
}
.chatArea.min .chatHistoryArea{
    padding: 14px 10px 59px 16px;
}
.chatArea.min .chatHistoryW{
    padding-right: 6px;
    max-height: 240px;
}
.chatArea.min .chatHistoryW>li{
    gap: 0 6px;
    height: 40px;
}
.chatArea.min .chatHistory{
    padding: 4px 0 4px 26px;
    font-size: 14px;
}
.chatArea.min .chatHistory::before{
    width: 20px;
    height: 20px;
}
.chatArea.min .chatSend{
    position: relative;
    z-index: 15;
    margin-bottom: 42px;
}
@media screen and (min-width: 1201px){
    .hamBtnBasic:hover{
        background-color: var(--grey-lighten4);
    }
    .chatSend:hover{
        background-color: var(--primary-darken2);
    }
    button.chatHistoryBtn:hover{
        background-color: var(--primary-lighten4);
    }
    .chatHistory:hover{
        color: var(--primary-base);
    }
    button.chatHistoryClose:hover{
        background-color: var(--grey-lighten4);
    }
    button.aiQClose:hover{
        background-color: var(--grey-lighten4);
    }
    .chatQBtnLabel:hover{
        background-color: var(--primary-base);
        color: #fff;
    }
    .chatQBtnTxt:hover{
        color: var(--primary-base);
    }
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
}
@media screen and (max-width: 500px){
}

button:focus,
a:focus {
    outline: none;
}

button:focus-visible,
a:focus-visible {
    border: 2px solid var(--danger-base);
    z-index: 3;
}

.ir {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    border: 0;
}

.borderRight{border-right: 1px solid var(--border-color);}
.borderTop{border-top: 1px solid var(--border-color);}
.borderBottom{border-bottom: 1px solid var(--border-color);}
.borderLeft{border-left: 1px solid var(--border-color);}

.mo,.tb{display: none;}

@media screen and (max-width: 1023px){
    .tb{display: block;}
    .sp{display: none !important;}
}  
@media screen and (max-width: 767px){
    .mo{display: block;}
    .pc{display: none !important;}
}

.logo{
    width: var(--logo-width);
    height: var(--logo-height);
    background-image: url(../image/ci.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    transition: var(--transition);
}
.logo.vert{
    width: var(--logo-width-vert);
    height: var(--logo-height-vert);
    background-image: url(../image/ci-vert.png);
}
.logo>a{
    display: block;
    width: 100%;
    height: 100%;
}

html.overflowHidden{
    height: 100vh;
    max-height: var(--view-height);
    overflow: hidden;
}

/* pagination */
.paginationW{
    display: flex;
    justify-content: center;
    gap: 0 16px;
    margin-top: 30px;
}
.pagination{
    display: flex;
    gap: 0 5px;
    margin: 0 !important;
}
.paginationControl,
.paginationNum{
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    height: 36px;
    width: 36px;
    color: var(--grey-darken4);
    transition: var(--transition);
}
.paginationControl{
    background-color: var(--grey-lighten5);
}
.paginationControl:disabled{
    opacity: .4;
    cursor: default;
}
.paginationNum{
    justify-content: center;
    font-size: 16px;
    line-height: 1;
    font-weight: 600;
}
.paginationNum.active{
    background-color: var(--primary-base);
    color: #fff;
}

@media (min-width: 1201px){
    .paginationControl:not(:disabled):hover{
        background-color: var(--primary-lighten5);
    }
    .paginationNum:hover{
        background-color: var(--primary-base);
        color: #fff;
    }
}
@media (max-width: 1200px){
}
@media (max-width: 1023px){
}
@media (max-width: 767px){
    .paginationW{
        gap: 4px;
        margin-top: 20px;
    }
    .pagination{
        gap: 2px;
    }
    .paginationControl,
    .paginationNum{
        height: 28px;
        width: 28px;
    }
    .paginationControl .icon.lg{
        width: 20px;
        height: 20px;
    }
    .paginationNum{
        font-size: 14px;
    }
}
@media (max-width: 500px){
}
@media (max-width: 374px){
}

/*modal*/
.modal{
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999999;
    width: 100%;
    height: 100%;
    padding: var(--container-gutter);
    background-color: rgba(0, 0, 0, .4);
    justify-content: center;
    align-items: center;
    word-break: keep-all;
}
.modalInner{
    background-color: #fff;
    border-radius: 20px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, .15);
    max-width: 100%;
}
.modalHead{
    padding: 30px 30px 10px;
    position: relative;
}
.modalTit{
    display: block;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color-dark);
    padding-right: 44px;
}
.modalTit>a{
    color: var(--sky-base);
    transition: var(--transition);
}
.modalHead .modalCloseBtn{
    display: block;
    width: 34px;
    height: 34px;
    background-color: var(--primary-base);
    background-image: url(../image/icon-close-white.svg);
    background-size: 20px auto;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 50%;
    position: absolute;
    right: 30px;
    top: 24px;
    transition: var(--transition);
}
.closeLine{
    display: block;
    position: relative;
    height: 2px;
    width: 18px;
}
.closeLine::before,
.closeLine::after{
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #fff;
    border-radius: 999px;
    top: 0;
    left: 0;
}
.closeLine::before{
    transform: rotate(45deg);
}
.closeLine::after{
    transform: rotate(-45deg);
}
.modalBody{
    padding: 14px;
}
.modalBodyInner{
    padding: 0 16px;
    max-height: calc(var(--view-height) - 246px);
    overflow-x: hidden;
    overflow-y: auto;
}
.modal:not(:has(.modalFoot)) .modalBody{
    padding-bottom: 30px;
}

.modalBodyInner::-webkit-scrollbar {
    width: 5px;
}
.modalBodyInner::-webkit-scrollbar-track {
    background-color: var(--primary-lighten5);
    border-radius: 999px;
}
.modalBodyInner::-webkit-scrollbar-thumb { 
    background-color: var(--primary-base);
    border-radius: 999px;
}
.modalBodyInner::-webkit-scrollbar-button {
    display: none;
}
.modalFoot{
    padding: 16px 30px 30px;
}
.modalFootBtnW{
    display: flex;
    justify-content: flex-end;
    gap: 15px;
}
.modalFootBtn{
    height: 44px;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
    background-color: var(--primary-base);
    border-radius: 8px;
    transition: var(--transition);
}

.modalWindow .modalHead,
.modalWindow .modalBody,
.modalWindow .modalBodyInner{
    padding-left: 0;
    padding-right: 0;
}
.modalWindow .modalHead .modalCloseBtn{
    right: 0;
}

.modalWindow .modalBody{
    padding-bottom: 50px;
}

@media (min-width: 1201px){
    .modalHead .modalCloseBtn:hover{
        background-color: var(--primary-darken1);
    }
    .modalFootBtn:hover{
        background-color: var(--primary-darken1);
    }
    .modalTit>a:hover{
        color: var(--primary-base);
    }
}
@media (max-width: 1200px){
}
@media (max-width: 1023px){
}
@media (max-width: 767px){
    .modalHead{
        padding: 30px 20px 0;
    }
    .modalTit{
        padding-bottom: 12px;
        font-size: 18px;
    }
    .modalHead .modalCloseBtn{
        right: 16px;
        width: 32px;
        height: 32px;
        top: 16px;
        right: 20px;
    }
    .modalBody{
        padding: 20px 10px 20px;
    }
    .modalBodyInner{
        padding: 0 10px;
    }
    .modalAlert .modalBody{
        text-align: center;
    }
    .modalFoot{
        padding: 0 20px 30px;
    }
    .modalFootBtnW{
        gap: 8px;
    }
    .modalFootBtn{
        height: 40px;
        padding: 0 20px;
        font-size: 16px;
    }
}
@media (max-width: 500px){
}
@media (max-width: 374px){
    .modalFootBtnW>.btn{
        max-width: calc(50% - 4px);
        width: calc(50% - 4px);
        flex: 1 1 0;
        padding: 0 !important;
    }
}

/*layout*/
.container{
    width: 100%;
    max-width: calc(var(--container) + (var(--container-gutter) * 2));
    padding: 0 var(--container-gutter);
    margin: 0 auto;
}

/*wrap*/
.wrap{
    position: relative;
    width: 100%;
    min-height: var(--view-height);
    overflow-x: hidden;
    overflow-y: hidden;
    display: flex;
    flex-direction: column;
}
html:not(:has(header.header.dark)) .wrap{
    padding-top: var(--header-height);
}
main{
    width: 100%;
}
@media screen and (max-width: 1200px){
    html:has(header.header.dark) .wrap{
        padding-top: var(--header-height);
    }
}
@media screen and (max-width: 767px){
    html:has(header.header.dark) .wrap{
        padding-top: var(--header-height);
    }
}


/* divider */
.divider{
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--border-color);
}
.divider.vertical{
    width: 1px;
    height: 12px;
    background-color: var(--border-color);
}
.divider.dark{
    background-color: var(--border-color-dark);
}
.divider.white{
    background-color: #fff;
}

/* common */
.primaryTxt{
    color: var(--primary-base) !important;
}
.secondaryTxt{
    color: var(--secondary-base) !important;
}
.greyTxt{
    color: var(--grey-base) !important;
}
.dangerTxt{
    color: var(--danger-base) !important;
}
.infoTxt{
    color: var(--info-base) !important;
}
/* S:: 20250915 최유림 수정 */
.skyTxt{
    color: var(--sky-base) !important;
}

/* E:: 20250915 최유림 수정 */
.customSelectBtn{
    width: 100%;
    height: 38px;
    border-radius: 999px;
    padding: 0 42px 0 20px;
    color: var(--grey-darken4);
    display: flex;
    align-items: center;
    text-align: left;
    background-color: #fff;
    font-size: 16px;
    font-weight: 600;
    transition: var(--transition);
    position: relative;
}
.customSelectBtn>span{
    width: 100%;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
}
.customSelectBtn::after{
    content: "";
    display: block;
    position: absolute;
    width: 20px;
    height: 20px;
    background-image: url(../image/icon-circle-arrow-top-primary.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(-180deg);
    transition: var(--transition);
}
.customSelectW.active .customSelectBtn::after{
    transform: translateY(-50%);
}
.customSelectW{
    position: relative;
}
.customSelectScroll{
    padding: 12px 8px;
    position: absolute;
    left: 0;
    bottom: 6px;
    transform: translateY(100%);
    z-index: 10;
    border: 1px solid var(--border-color);
    background-color: var(--primary-lighten5);
    opacity: 0;
    visibility: hidden;
    width: 100%;
    transition: var(--transition);
}
.customSelect{
    display: block;
    width: 100%;
    max-height: 132px;
    overflow-x: hidden;
    overflow-y: auto;
}
.customSelect::-webkit-scrollbar {
    width: 8px;
}
.customSelect::-webkit-scrollbar-track {
    background-color: var(--primary-lighten5);
    border-radius: 999px;
}
.customSelect::-webkit-scrollbar-thumb { 
    background-color: var(--primary-base);
    border-radius: 999px;
}
.customSelect::-webkit-scrollbar-button {
    display: none;
}
.customSelectW.active .customSelectScroll{
    bottom: -6px;
    opacity: 1;
    visibility: visible;
}
.customSelectLi{
    width: 100%;
}
.customSelectLink{
    display: flex;
    align-items: center;
    text-align: left;
    word-break: keep-all;
    padding: 2px 12px;
    background-color: transparent;
    border-radius: 5px;
    color: var(--grey-darken4);
    width: 100%;
    font-size: 16px;
    transition: var(--transition);
}
.customSelectLink.active{
    text-decoration: underline;
}

.customSelectW.top .customSelectScroll{
    bottom: unset;
    top: 6px;
    transform: translateY(-100%);
}
.customSelectW.top.active .customSelectScroll{
    bottom: unset;
    top: -8px;
}
.customSelectW.top .customSelectBtn::after{
    transform: translateY(-50%);
}
.customSelectW.top.active .customSelectBtn::after{
    transform: translateY(-50%) rotate(-180deg);
}

@media screen and (min-width: 1201px){
    .customSelectBtn:hover{
        background-color: var(--primary-lighten4);
    }
    .customSelectLink:hover{
        background-color: var(--primary-lighten4);
    }    
    .customSelectBottomBtn:hover{
        background-color: var(--primary-lighten4);
    }
    
    .customSelectW.tbOnly .customSelectBtn{
        display: none;
    }
    .customSelectW.tbOnly .customSelectScroll{
        position: relative;
        left: 0;
        bottom: unset;
        transform: translateY(0);
        border-radius: 0;
        box-shadow:  0 0 0 rgba(0, 0, 0, 0);
        border: 0;
        padding: 0;
        background-color: transparent;
        z-index: 1;
        opacity: 1;
        visibility: visible;
    }
    .customSelectW.tbOnly .customSelect{
        max-height: unset;
        overflow: visible;
    }
    .customSelectW.tbOnly .customSelectLink {
        display: block;
        text-align: left;
        padding: 0;
        background-color: transparent;
        border-radius: 0;
        color: var(--grey-darken4);
    }
}
@media screen and (max-width: 767px){
    .customSelect::-webkit-scrollbar {
        width: 5px;
    }
}

/* filterPanel */

.filterPanelArea{
    position: relative;
}
.filterPanelBtn{
    max-width: 100%;
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
    display: flex;
    align-items: center;
    text-align: left;
    position: relative;
    transition: var(--transition);
}
.filterPanelBtn>span{
    width: 100%;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
}
.filterPanelInputArea{
    padding: 8px 24px 8px 8px;
}
.filterPanelInputW{
    width: 100%;
    position: relative;
}
input.filterPanelInput{
    width: 100%;
    height: 42px;
    padding: 0 56px 0 16px;
    color: var(--grey-darken4);
    border-radius: 8px;
    border: 1px solid var(--primary-base);
}
.filterPanelInputBtn{
    position: absolute;
    width: 34px;
    height: 34px;
    right: 11px;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 50%;
    background-color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
}
.filterPanelInput::placeholder{
    color: var(--grey-base);
}
.filterPanelW{
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 8px;
    transform: translateY(100%);
    z-index: 10;
    border-radius: var(--input-border-radius);
    border: 1px solid var(--border-color-dark);
    background-color: #fff;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
}
.filterPanel{
    display: block;
    width: 100%;
    padding: 0 8px 8px 8px;
}
.filterPanelInner{
    padding-right: 8px;
    max-height: 126px;
    overflow-x: hidden;
    overflow-y: auto;
}
.filterPanelInner::-webkit-scrollbar {
    width: 8px;
}
.filterPanelInner::-webkit-scrollbar-track {
    background-color: var(--primary-lighten4);
    border-radius: 2px;
}
.filterPanelInner::-webkit-scrollbar-thumb { 
    background-color: var(--primary-base);
    border-radius: 2px;
}
.filterPanelInner::-webkit-scrollbar-button {
    display: none;
}
.filterPanelArea.active .filterPanelW{
    bottom: 0;
    opacity: 1;
    visibility: visible;
}
.filterPanelLink{
    display: flex;
    align-items: center;
    text-align: left;
    word-break: keep-all;
    width: 100%;
    border-radius: 8px;
    padding: 8px;
    background-color: transparent;
    color: var(--grey-base);
    transition: var(--transition);
}
.filterPanelLink.active{
    color: var(--grey-darken4);
    background-color: var(--primary-lighten5);
}

@media screen and (min-width: 1201px){
    .filterPanelBtn:hover{
        background-color: var(--primary-lighten5);
    }

    .filterPanelLink:hover{
        background-color: var(--primary-lighten5);
    }

    .filterPanelInputBtn:hover{
        background-color: var(--primary-lighten5);
    }
}

/*tab*/
.tabContent{ position: relative; width: 100%; display: block;}
.tabContent>li { display: block; opacity: 0; visibility: hidden; z-index: 0; position: absolute; top: 0; left: 0; width: 100%;}
.tabContent>li.active { opacity: 1; visibility: visible; z-index: 1; height:auto; position:relative; animation: contentsActive ease-in-out .5s forwards; }
@-webkit-keyframes contentsActive { from { opacity: 0; } to { opacity: 1; } }
@keyframes contentsActive { from { opacity: 0; } to { opacity: 1; } }

/* Typography */
.black{
    font-weight: 900;
}
.extrabold{
    font-weight: 800;
}
.bold{
    font-weight: 700;
}
.semibold{
    font-weight: 600;
}
.medium{
    font-weight: 500;
}
.regular{
    font-weight: 400;
}

.indent{
    padding-left: 11px;
    text-indent: -11px;
}
.underline{
    text-decoration: underline;
}

@media (max-width: 1200px){
}
@media (max-width: 1023px){
}
@media (max-width: 767px){
    
}
@media (max-width: 500px){
}

.labelW{
    display: flex;
    flex-wrap: wrap;
    gap: 8px 5px;
}
.label{
    padding: 0 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 30px;
    width: fit-content;
    font-size: 16px;
    font-weight: 600;
    border-radius: 4px;
    background-color: var(--grey-lighten5);
    color: var(--grey-base);
}
.label.sm{
    height: 26px;
    font-size: 14px;
}
.label.xs{
    padding: 0 5px;
    height: 24px;
    font-size: 14px;
    font-weight: 500;
}
.label.pill{
    padding: 0 10px;
    border-radius: 999px;
}
.label.shadow{
    box-shadow: 0 3px 6px rgba(0, 0, 0, .16);
}
.label.orange{
    background-color: var(--orange-base);
    color: #fff;
}
.label.yellow{
    background-color: var(--yellow-base);
    color: #fff;
}
.label.sky{
    background-color: var(--sky-base);
    color: #fff;
}
.label.pink{
    background-color: var(--pink-base);
    color: #fff;
}
.label.lightPrimary{
    background-color: var(--primary-lighten5);
    color: var(--primary-base);
}
.label.lightGreen{
    background-color: var(--green-lighten5);
    color: var(--green-base);
}
.label.lightPurple{
    background-color: var(--purple-lighten5);
    color: var(--purple-base);
}
@media screen and (min-width: 1201px){
}
@media screen and (max-width: 1479px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .labelW{
        gap: 8px;
    }
    .label{
        height: 24px;
        font-size: 14px;
    }
}
@media screen and (max-width: 500px){
}

.boardFilterArea{
    border-radius: 8px;
    border: 1px solid var(--border-color-dark);
    padding: 20px;
    margin-bottom: 20px;
}
.boardFilterW .boardFilter + .boardFilter{
    margin-top: 12px;
}
.boardFilter{
    display: flex;
    align-items: flex-start;
}
.boardFilter>strong{
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    min-width: 85px;
    min-height: 54px;
    display: flex;
    align-items: center;
    flex: 0 0 auto;
}
.boardFilterContents{
    width: 100%;
    flex-basis: 0;
    flex-grow: 1;
    max-width: calc(100% - 85px);
    min-height: 54px;
    display: flex;
    align-items: center;
}
.boardFilterContents>input[type="text"]{
    max-width: 480px;
}

.boardFilter .radioW{
    gap: 0 10px;
}
.boardFilter .radioBtn input + label {
    width: 92px;
    height: 32px;
    border: 0;
    background-color: var(--grey-lighten5);
}
.boardFilter .radioBtn input + label p {
    font-size: 15px;
    color: var(--grey-base);
}
.boardFilter .radioBtn input:checked + label {
    background-color: var(--primary-base);
}
.boardFilter .radioBtn input:checked + label p {
    color: #fff;
}

.radioBtn.lightPrimary input + label {
    background-color: var(--primary-lighten5);
}
.radioBtn.lightPrimary input + label p {
    color: var(--primary-base);
}
.radioBtn.lightPrimary input:checked + label {
    background-color: var(--primary-base);
}
.radioBtn.lightPrimary input:checked + label p {
    color: #fff;
}
.radioBtn.lightGreen input + label {
    background-color: var(--green-lighten5);
}
.radioBtn.lightGreen input + label p {
    color: var(--green-base);
}
.radioBtn.lightGreen input:checked + label {
    background-color: var(--green-base);
}
.radioBtn.lightGreen input:checked + label p {
    color: #fff;
}
.radioBtn.lightPurple input + label {
    background-color: var(--purple-lighten5);
}
.radioBtn.lightPurple input + label p {
    color: var(--purple-base);
}
.radioBtn.lightPurple input:checked + label {
    background-color: var(--purple-base);
}
.radioBtn.lightPurple input:checked + label p {
    color: #fff;
}
.radioBtn.grey input + label {
    background-color: var(--grey-lighten5);
}
.radioBtn.grey input + label p {
    color: var(--grey-base);
}
.radioBtn.grey input:checked + label {
    background-color: var(--grey-base);
}
.radioBtn.grey input:checked + label p {
    color: #fff;
}

.period{
    display: flex;
    align-items: center;
    gap: 0 30px;
}
.period>.radioW{
    flex: 0 0 auto;
}
.inputPeriod{
    display: flex;
    align-items: center;
    gap: 0 8px;
    max-width: 100%;
}
.period>.inputPeriod{
    flex-basis: 0;
    flex-grow: 1;
    max-width: calc(100% - 326px); 
}
.inputPeriod>span{
    font-size: 14px;
    font-weight: 500;
}
.inputPeriod>input{
    flex-basis: 0;
    flex-grow: 1;
    max-width: calc((100% - 25px) / 2);
}

.boardFilterBottom{
    padding-top: 20px;
    margin-top: 20px;
    border-top: 1px solid var(--border-color-dark);
    display: flex;
    justify-content: center;
}
.boardFilterBtn{
    height: 40px;
    background-color: #747B8D;
    color: #fff;
    border-radius: 8px;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    font-weight: 600;
    transition: var(--transition);
}
@media screen and (min-width: 1201px){    
    .boardFilter .radioBtn:hover input + label {
        background-color: var(--primary-base);
    }
    .boardFilter .radioBtn:hover input + label p {
        color: #fff;
    }
    .radioBtn.lightPrimary:hover input + label {
        background-color: var(--primary-base);
    }
    .radioBtn.lightPrimary:hover input + label p {
        color: #fff;
    }
    .radioBtn.lightGreen:hover input + label {
        background-color: var(--green-base);
    }
    .radioBtn.lightGreen:hover input + label p {
        color: #fff;
    }
    .radioBtn.lightPurple:hover input + label {
        background-color: var(--purple-base);
    }
    .radioBtn.lightPurple:hover input + label p {
        color: #fff;
    }
    .boardFilterBtn:hover{
        background-color: var(--primary-base);
    }
}
@media screen and (max-width: 1439px){
    .boardFilter:not(.noWrap) .boardFilterContents>input[type="text"]{
        max-width: 100%;
    }
    .period{
        display: block;
    }
    .period>.inputPeriod{
        max-width: 100%;
    }
    .inputPeriod>input{
        max-width: 170px;
    }
    .period>.radioW{
        margin-top: 10px;
    }
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
    .boardFilter:not(.noWrap){
        display: block;
    }
    .boardFilter>strong{
        min-width: 0;
        min-height: 0;
        display: block;
        margin-bottom: 16px;
    }
    .boardFilterContents{
        max-width: 100%;
        min-height: 0;
        display: block;
    }
}
@media screen and (max-width: 767px){
    .boardFilterArea{
        padding: 20px 16px;
        margin-bottom: 20px;
    }
    .boardFilter>strong{
        font-size: 16px;
        margin-bottom: 12px;
    }
    .boardFilter .radioW{
        gap: 8px;
    }
    .boardFilter .radioBtn input + label {
        width: auto;
        padding: 0 16px;
        height: 30px;
    }
    .boardFilter .radioBtn input + label p {
        font-size: 14px;
    }
    .period{
        display: block;
    }
    .period>.radioW{
        margin-top: 8px;
    }   
    .inputPeriod>input{
        max-width: calc((100% - 25px) / 2);
    }
    .boardFilterBottom {
        padding-top: 16px;
        margin-top: 16px;
    }
    .boardFilterBtn{
        height: 38px;
        padding: 0 20px;
        font-size: 16px;
    }
}
@media screen and (max-width: 500px){ 
    .inputPeriod{
        flex-wrap: wrap;
        gap: 8px;
    }
    .inputPeriod>input:first-child{
        max-width: calc(100% - 17px);
        width: calc(100% - 17px);
    }
    .inputPeriod>input:last-child{
        max-width: 100%;
    }    
}
@media screen and (max-width: 374px){
}

/* S:: 20250915 최유림 수정 */
/*input*/
.inputPrimary{
    height: 54px;
    border-radius: var(--input-border-radius);
    padding: 0 var(--input-padding);
    border: 1px solid var(--border-color-dark);
    color: var(--grey-darken4);
    background-color: #fff;
    font-size: 16px;
    font-weight: 500;
    width: 100%;
    transition: var(--transition);
}
.inputPrimary.sm{
    font-weight: 400;
}
textarea.inputPrimary{
    resize: none;
    height: 300px;
    border-radius: 15px;
    padding: 20px var(--input-padding);
}
.inputPrimary:disabled {
    cursor: default;
    background-color: var(--grey-lighten5);
    color: var(--grey-darken4);
    border-color: var(--border-color);
}
.inputPrimary::placeholder{
    color: var(--grey-base);
}
.inputPrimary:focus{
    outline: none;
    border-color: var(--primary-base);
}
input[type='date']::-webkit-calendar-picker-indicator{
    width: 24px;
    height: 24px;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    position: absolute;
    z-index: 5;
    cursor: pointer;
    background-color: transparent;
    color: transparent;
    opacity: 0;
}
/* input[type='date']::-webkit-calendar-picker-indicator{
    display: none;
} */

input[type='date'] {
    position: relative;
    background: #fff url(../image/icon-date.svg) no-repeat right 12px center;
    background-size: 24px auto;
    padding-right: 42px;
}
/* E:: 20250915 최유림 수정 */
@media screen and (min-width: 1201px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}  
@media screen and (max-width: 767px){  
    .inputPrimary{
        height: 44px;
        font-size: 14px;
    } 
    textarea.inputPrimary{
        height: 240px;
    }
}
@media screen and (max-width: 500px){ 
}

.selectBg{
    position: relative;
}
.selectBg>select{
    width: 100%;
    height: var(--input-height);
    border-radius: var(--input-border-radius);
    padding: 0 42px 0 var(--input-padding);
    color: var(--grey-base);
    background-color: var(--grey-lighten4);
    font-size: 20px;
    font-weight: 600;
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
}
.selectBg::after{
    content: "";
    display: block;
    position: absolute;
    width: 20px;
    height: 20px;
    background-image: url(../image/select-bg-arrow.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center;
    top: 50%;
    right: 20px;
    z-index: 1;
    transform: translateY(-50%);
}
.selectBg.primary>select{
    background-color: var(--primary-lighten5);
    color: var(--primary-base);
}
.selectBg.primary::after{
    background-image: url(../image/select-bg-arrow-primary.svg);
}
@media screen and (min-width: 1201px){
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .selectBg>select{
        padding: 0 42px 0 var(--input-padding);
        font-size: 16px;
    }
    .selectBg::after{
        width: 16px;
        height: 16px;
        right: 16px;
    }
}
@media screen and (max-width: 500px){
}

.toggleSwitchW{
    display: flex;
    align-items: center;
    gap: 0 8px;
}
.toggleSwitchW>p{
    font-size: var(--control-label-font-size);
    color: var(--control-label-color);
    font-weight: 500;
}

.toggleSwitch {
    position: relative;
    display: block;
    width: 42px;
    height: 24px;
}

.toggleSwitch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.switchSlider {
    position: absolute;
    cursor: pointer;
    background-color: var(--grey-base);
    border-radius: 999px;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    transition: var(--transition);
}

.switchSlider::before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: #fff;
    transition: var(--transition);
    border-radius: 50%;
}

input:checked + .switchSlider {
    background-color: var(--primary-base);
}

input:checked + .switchSlider::before {
  transform: translateX(18px);
}
@media screen and (min-width: 1201px){
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .toggleSwitch {
        width: 36px;
        height: 20px;
    }
    .switchSlider::before {
        height: 16px;
        width: 16px;
        left: 2px;
        bottom: 2px;
    }
    input:checked + .switchSlider::before {
        transform: translateX(16px);
    }
}
@media screen and (max-width: 500px){
}

.radioW{
    display: flex;
    align-items: center;
    gap: 0 16px;
    flex-wrap: wrap;
}

.radioPrimary{
    width: fit-content;
}
.radioPrimary input[type="radio"]{
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

.radioPrimary{
    display: flex; 
    align-items: center; 
    justify-content: flex-start;
}
.radioPrimary input[type="radio"] + label{
    position: relative;
    min-width: var(--control-icon-size);
    min-height: var(--control-icon-size);
    width: fit-content;
    display: block;
    cursor: pointer;
}
.radioPrimary input[type="radio"] + label p{
    padding-left: calc(var(--control-icon-size) + var(--control-gap)); 
    font-size: var(--control-label-font-size); 
    color: var(--control-label-color);
}
.radioPrimary input[type="radio"] + label::after{
    content: ""; 
    width: var(--control-icon-size); 
    height: var(--control-icon-size); 
    /*background-image: url(../image/icon-radio.svg);*/
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute; 
    left: 0; 
    top: 50%; 
    transform: translateY(-50%);
}
.radioPrimary input[type="radio"]:checked + label::after{
    /*background-image: url(../image/icon-radio-active.svg);*/
}
.radioPrimary input[type="radio"] + label::before{
    content: "";
    position: absolute;
    display: block;
    width: calc(var(--control-icon-size) + calc(var(--control-gap) * 2));
    height: calc(var(--control-icon-size) + calc(var(--control-gap) * 2));
    top: 50%;
    left: 0;
    transform: translate(calc(var(--control-gap) / -1), -50%);
    border-radius: 50%;
    background-color: var(--primary-base);
    opacity: 0;
    transition: var(--transition);
}


.radioBtn{width: fit-content;}
.radioBtn input{
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}
.radioBtn input + label{
    position: relative;
    width: 100%;
    /*height: var(--btn-height);*/
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    border: 2px solid var(--primary-base);
    background-color: #ffffff;
    border-radius: 999px;
    transition: var(--transition);
}
.radioBtn input + label p{
    font-size: 16px;
    font-weight: 500;
    color: var(--primary-base);
    transition: var(--transition);
}
.radioBtn input:checked + label{
    /*border-color: var(--yinmn-base);*/
    /*background-color: var(--yinmn-base);*/
}
.radioBtn input:checked + label p{
    color: #fff;
}
.radioBtn.sm input + label{
    padding: 0 24px;
    border: 1px solid var(--border-color);
}
.radioBtn.sm  input + label p{
    font-weight: 600;
    color: var(--grey-lighten1);
}
.radioBtn.sm input:checked + label{
    border-color: var(--primary-lighten4);
    background-color: var(--primary-lighten5);
}
.radioBtn.sm input:checked + label p{
    /*color: var(--yinmn-base);*/
}

.checkW .checkPrimary + .checkPrimary{
    margin-top: 14px;
}
.checkW>.inputPrimary{
    margin-top: 14px;
}
.checkW .checkPrimary{
    width: 100%;
}
.checkPrimary{
    width: fit-content;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
}
.checkPrimary:has(.ir){
    width: var(--control-icon-size);
}
.checkPrimary input[type="checkbox"]{
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}
.checkPrimary input[type="checkbox"] + label{
    position: relative;
    min-width: var(--control-icon-size);
    min-height: var(--control-icon-size);
    width: fit-content;
    display: block; cursor: pointer;
}
.checkPrimary input[type="checkbox"] + label p{
    padding-left: calc(var(--control-icon-size) + var(--control-gap)); 
    font-size: var(--control-label-font-size); 
    color: var(--control-label-color);
    font-weight: 500;
    position: relative;
    top: 1px;
}
.checkPrimary input[type="checkbox"] + label::after{
    content: "";
    width: var(--control-icon-size);
    height: var(--control-icon-size);
    background-image: url(../image/icon-check.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.checkPrimary input[type="checkbox"]:checked + label::after{
    background-image: url(../image/icon-check-active.svg);
}

.radioPrimary input[type="radio"] + label::before,
.checkPrimary input[type="checkbox"] + label::before{
    content: "";
    position: absolute;
    display: block;
    width: calc(var(--control-icon-size) + calc(var(--control-gap) * 2));
    height: calc(var(--control-icon-size) + calc(var(--control-gap) * 2));
    top: 50%;left: 0;
    transform: translate(calc(var(--control-gap) / -1), -50%);
    border-radius: 50%;
    background-color: var(--primary-base);
    opacity: 0;
    transition: var(--transition);
}

@media (min-width: 1201px) {
    .radioPrimary:hover input[type="radio"] + label::before,
    .checkPrimary:hover input[type="checkbox"] + label::before{
        opacity: .08;
    }
    .radioPrimary:hover input[type="radio"] + label{
        border-color: var(--primary-base);
        color: var(--primary-base);
    }
    .radioBtn:hover label{
        /*border-color: var(--yinmn-base);*/
        /*background-color: var(--yinmn-base);*/
    }
    .radioBtn:hover label p{
        color: #fff;
    }
    .radioBtn.sm:hover input + label{
        border-color: var(--primary-lighten4);
        background-color: var(--primary-lighten5);
    }
    .radioBtn.sm:hover input + label p{
        /*color: var(--yinmn-base);*/
    }
}
@media (max-width: 1200px){
}
@media (max-width: 1023px){
}
@media (max-width: 767px){
    .checkW>.inputPrimary{
        margin-top: 10px;
    }
    .radioBtn.sm input + label{
        padding: 0 18px;
    }
}
@media (max-width: 500px){
}


/*thumb*/
.thumbW{
    position: relative;
    display: block;
    width: 100%;
}
.thumb{
    position: relative;
    height: 0;
    width: 100%;
    padding-top: calc((160 / 270) * 100%);
    overflow: hidden;
}
.thumbW:has(.thumb.rounded){
    border-radius: 20px;
}
.thumb.rounded{
    border-radius: 20px;
}
.thumbInner{
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    object-fit: cover;
    top: 0;
    left: 0;
    z-index: 1;
}
.thumbW.sm .thumb::after,
.thumbW:not(.sm)::after{
    content: "";
    display: block;
    position: absolute;
    height: 100%;
    width: 100%;
    border-radius: inherit;
    top: 0;
    left: 0;
    box-sizing: border-box;
    border: 2px solid var(--primary-base);
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
    z-index: 2;
}
@media screen and (min-width: 1201px){ 
    .thumbW.sm:hover .thumb::after,
    .thumbW:not(.sm):hover::after{
        opacity: 1;
        visibility: visible;
    }
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}  
@media screen and (max-width: 767px){ 
    .thumb.thumbVideo::before,
    .thumb.thumbVideo.lg::before{
        width: 58px;
        height: 58px;
    }
}
@media screen and (max-width: 500px){ 
}

.slideControl{
    display: flex;
}
.slideBtn{
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--primary-base);
    box-shadow: 0 4px 16px rgba(0, 76, 174, .08);
    transition: var(--transition);
}
.slideBtn:disabled,
.slideBtn.swiper-button-disabled{
    background-color: #fff;
    cursor: default;
    box-shadow: none;
}
.slideBtn:disabled .iconChevronLeftWhite,
.slideBtn.swiper-button-disabled .iconChevronLeftWhite{
    background-image: url(../image/icon-chevron-left.svg);
}
.slideBtn:disabled .iconChevronRightWhite,
.slideBtn.swiper-button-disabled .iconChevronRightWhite{
    background-image: url(../image/icon-chevron-right.svg);
}
@media screen and (min-width: 1201px){
    .slideBtn:not(.swiper-button-disabled, :disabled):hover{
        background-color: var(--primary-darken1);
    }
}
@media screen and (max-width: 1479px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .slideBtn{
        width: 34px;
        height: 34px;
    }
}
@media screen and (max-width: 500px){
}

/* tab */
.tabTxt{
    display: flex;
    gap: 0 24px;
}
.tabTxt>li{
    display: block;
    flex: 0 0 auto;
}
.tabTxt .tabBtn{
    padding: 0 8px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: transparent;
    color: var(--grey-lighten1);
    font-size: 20px;
    font-weight: 600;
    line-height: 1;
    transition: var(--transition);
}
.tabTxt .tabBtn>span{
    display: block;
    position: relative;
}
.tabTxt .tabBtn>span::before{    
    content: "";
    display: block;
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--primary-base);
    top: -5px;
    left: -6px;
    opacity: 0;
    visibility: hidden;
    transform: scale(0);
    transition: var(--transition);
}
.tabTxt .tabBtn.active{
    font-weight: 800;
    color: var(--primary-base);
}
.tabTxt .tabBtn.active>span::before{
    opacity: 1;
    visibility: visible;
    transform: scale(1);
}
@media screen and (min-width: 1201px){
    .tabTxt .tabBtn:hover{
        font-weight: 800;
        color: var(--primary-base);
    }
    .tabTxt .tabBtn:hover>span::before{
        opacity: 1;
        visibility: visible;
        transform: scale(1);
    }
}
@media screen and (max-width: 1479px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .tabTxt{
        flex-wrap: wrap;
        gap: 4px 8px;
    }
    .tabTxt .tabBtn{
        height: 28px;
        font-size: 18px;
    }
    .tabTxt .tabBtn>span::before{    
        width: 4px;
        height: 4px;
        top: -3px;
        left: -4px;
    }
}
@media screen and (max-width: 500px){
    .mainSectionHeadRight .tabTxt{
        left: -6px;
    }
    .tabTxt{
        gap: 4px;
    }
    .tabTxt .tabBtn{
        height: 24px;
        font-size: 14px;
        padding: 0 6px;
    }
    .tabTxt .tabBtn>span::before{    
        width: 3px;
        height: 3px;
        top: -2px;
        left: -2px;
    }
}


.tablePrimary{
    width: 100%;
    background-color: #fff;
    border-top: 2px solid var(--grey-darken4);
    table-layout: fixed;
}
.tablePrimary tr{
    border-bottom: 1px solid var(--border-color-dark);
}
.tablePrimary tr.active{
    background-color: var(--primary-lighten5);
}
.tableInner{
    max-width: 100%;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0 4px;
    padding: 8px;
}
.tableInner.left{
    justify-content: flex-start;
    text-align: left;
}
.tablePrimary td>.tableInner{
    font-size: 16px;
    font-weight: 500;
    min-height: 52px;
}
.tablePrimary th>.tableInner{
    font-size: 18px;
    font-weight: 600;
    min-height: 54px;
}
.tableBtn{
    display: block;
    width: 100%;
    text-align: center;
    color: var(--primary-base);
    text-decoration: underline;
    font-weight: 600;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    word-break: break-all;
    transition: var(--transition);
}
.tableBtn:has(.label){
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0 8px;
    text-decoration: none;
}
.tableBtn>.label{
    flex: 0 0 auto;
}
.tableBtn>span:not(.label){
    text-decoration: underline;
}
.tableBtn>.tableBtnTxt{
    flex-basis: 0;
    flex-grow: 1;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    text-decoration: underline;
}
@media (min-width: 1201px){
    .tableBtn:hover{
        color: var(--sky-base);
    }
}
@media (max-width: 1200px){
}
@media (max-width: 1023px){    
}
@media (max-width: 767px){
    .tableScroll{
        padding-bottom: 10px;
    }
    .tableInner{
        gap: 6px;
        padding: 8px 12px;
        min-height: 52px;
    }
    .tablePrimary td>.tableInner{
        font-size: 16px;
    }
    .tablePrimary th>.tableInner{
        font-size: 16px;
    }   
}
@media (max-width: 500px){
}

/* panel */
.panelList{
    width: 100%;
}
.panelItem{
    width: 100%;
}
.panelItemHead{
    position: relative;
    width: 100%;
    padding-right: 230px;
    transition: var(--transition);
}
.panelItemBtn{
    border: 1px solid var(--border-color-dark);
    padding: 0 16px;
    border-radius: 999px;
    position: absolute;
    width: 172px;
    height: 42px;
    top: 34px;
    right: 40px;
    transition: var(--transition);
}
.panelItemBtn>span{
    display: flex;
    align-items: center;
    font-size: 16px;
    font-weight: 500;
    color: var(--grey-base);
    width: 100%;
    height: 100%;
    position: relative;
}
.panelItemBtn>span::after{
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 13px;
    height: 13px;
    background-image: url(../image/select-bg-arrow-primary2.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: var(--transition);
}
.panelItem.active .panelItemBtn>span::after{
    transform: translateY(-50%) rotate(180deg);
}
.panelItemBody{
    overflow: hidden;
    height: 0;
    transition: 0.25s ease-out;
}
.panelItem.active .panelItemBody{
    margin-top: -20px;
}
@media screen and (min-width: 1201px){
    .panelItemBtn:hover{
        background-color: var(--primary-lighten5);
    }
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .panelItemBtn{
        position: static;
        width: 100%;
        font-size: 15px;
        height: 38px;
    }
    .panelItem.active .panelItemBody{
        margin-top: 0;
    }
}
@media screen and (max-width: 500px){
}

   

/* 20250915 최유림 추가 */
.modalSub {
    font-size: 16px;
    line-height: 22px;
    font-weight: 500;
}
.modalFoot:has(.btnBadge),
.badgeAddImg {
    text-align: center;
}

.badgeAddTit {
    padding-top: 8px;
    text-align: center;
    font-size: 20px;
    line-height: 1.8;
}

.badgeAddSub {
    line-height: 1.8;
    font-size: 17px;
    text-align: center;
}

.btnBadge {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    height: 44px;
    padding: 13px 23px;
    border-radius: 8px;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    transition: all var(--transition);
    background-color: var(--primary-base);
    color: #fff;
}


@media screen and (min-width: 1201px){
    .btnBadge:hover {
        background-color: var(--primary-darken2);
    }
}
@media screen and (max-width: 767px){
    .badgeAddImg {
        width: 160px;
        margin: 0 auto;
    }
    .badgeAddTit {
        font-size: 18px;
        line-height: 1.6;
    }
    .badgeAddSub {
        font-size: 15px;
        line-height: 1.6;
    }
    .btnBadge {
        font-size: 16px;
    }
}


.noData{
    min-height: 240px;
    background-color: #f5f5f5;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    margin-top: 20px;
}
@media screen and (min-width: 1201px){
}
@media screen and (max-width: 1439px){
}
@media screen and (max-width: 1200px){
}
@media screen and (max-width: 1023px){
}
@media screen and (max-width: 767px){
    .noData{
        font-size: 16px;
        min-height: 180px;
    }
}
@media screen and (max-width: 500px){
}