@charset "utf-8";


/* font */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&display=swap');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");


/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit;}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after,
q:before, q:after { content: ''; content: none; }
table { border-collapse: collapse; border-spacing: 0; }

::selection{background-color: var(--p-color2); color: var(--n-white);}

/*
    default
    :: mobile first
*/

* { box-sizing: border-box;}
html {height: 100%; overflow-y: auto; scroll-behavior: smooth; overscroll-behavior: none;}
body {margin-top: 0; min-width: 320px; color: var(--n-subTitle); font-size: 16px; font-family: 'Noto Sans KR', sans-serif; word-wrap: break-word; word-break: keep-all; font-weight: 400; letter-spacing: -0.48px; background-color: #fff; color: var(--n-subTitle); position: relative; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; padding-top: 40px; overscroll-behavior: none; /* iOS bounce 방지 */}
body.fixed { position: fixed; top: 0; left: 0; right: 0; overflow: hidden; width: 100%; }
a{display: inline-block;}
a, a:visited{color: var(--n-subTitle); text-decoration: none; }
/* a:active, button:active{filter: brightness(0.7);} */
button{background-color: transparent; border: none; outline: 0; display: inline-block; color: var(--n-subTitle); padding: 0; margin: 0; font-family: 'Noto Sans KR', sans-serif; cursor: pointer; font-size: inherit; font-weight: inherit;}
strong{font-weight: bold;}
select { -webkit-appearance:none; /* for chrome */ -moz-appearance:none; /*for firefox*/ appearance:none; border: 1px solid var(--s-color1); border-radius: 8px; width: 100%; height: 40px; padding: 0 12px; background-color: transparent; outline: 0; color: var(--n-info); background-image: url('https://static.edmclass.com/common/membership/toggle-btn.svg'); background-repeat: no-repeat; background-size: 16px; background-position: right 12px center;}
select::-ms-expand{ display:none;/*for IE10,11*/}
select:focus-visible{outline: 1px solid #339DFF; border-color: transparent;}
.el-hide{position: absolute; width: 1px; height: 1px; margin: -1px; overflow: hidden; clip-path: polygon(0 0, 0 0, 0 0);}
.noto-sans{font-family: 'Noto Sans KR', sans-serif;}
img{display: inline-block; max-width: 100%;}
figure{max-width: 100%;}
picture {display: flex;}
picture img{display: block;}

b { font-weight: 800;}

/* 불필요시 삭제하기 */
/* IE의 경우 */
input::-ms-clear, input::-ms-reveal{ display:block; }
/* 크롬의 경우 */
input::-webkit-search-decoration, input::-webkit-search-cancel-button, input::-webkit-search-results-button, input::-webkit-search-results-decoration{ display:block; }

/* banner.timer */
.banner.timer.hide{display: none !important;}


/************************************
    input 공통
************************************/
input[type="text"], input[type="password"], input[type="tel"], input[type="email"], input[type="number"], select{width: 100%; height: 40px; border-radius: 8px; border: 1px solid var(--s-color1); padding: 0 8px; font-size: var(--f-body1); letter-spacing: -0.28px; outline: 0; font-family: inherit;}
textarea{border-radius: 8px; border: 1px solid var(--s-color1); padding: 9px; font-size: var(--f-body1); outline: 0; font-family: inherit;    white-space: pre-wrap;word-wrap: break-word;}
input[type="date"]{width: 100%; height: 40px; border-radius: 8px; border: none; outline: 0; font-size: var(--f-body1); letter-spacing: -0.28px; padding: 0 9px; font-family: inherit; position: relative; overflow: initial; font-family: inherit;}
input[type="date"]::-webkit-clear-button, input[type="date"]::-webkit-inner-spin-button {display: none;}
input[type="date"]::-webkit-calendar-picker-indicator {background: transparent; z-index: 1;}
input[type="date"]::before{content: ''; position: absolute; width: 32px; height: 100%; background-image: url('https://static.edmclass.com/common/membership/date-icon.svg'); background-repeat: no-repeat; background-position: right center; background-size: 24px; right: 0; top: 50%; transform: translateY(-50% ); background-color: var(--n-white);}
input[type="date"]::after{content: ''; position: absolute; width: calc(100% - 32px); height: calc(100% - 2px); border: 1px solid var(--s-color1); left: 0; top: 50%; transform: translateY(-50%); border-radius: 8px; }

[type="number"] {-moz-appearance: textfield;}
input::-webkit-inner-spin-button { -webkit-appearance: none; }
input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
textarea{resize: none; width: 100%;}

/* 검색 */
.searchWrap .search{width: 100%; position: relative;}
.searchWrap .search input[type="text"]{padding-right: 30px;}
.searchWrap .search input[type="text"]::placeholder{color: var(--n-info2);}
.searchWrap .search input[type="submit"].search-submit{background-image: url('https://static.edmclass.com/common/board/search-submit.svg'); background-repeat: no-repeat; background-size: 16px; background-position: center; text-indent: -999999%; background-color: transparent; border: none; outline: 0; position: absolute; top: 50%; transform: translateY(-50%); right: 0; cursor: pointer;}

input[type="text"]::placeholder, input[type="password"]::placeholder, input[type="tel"]::placeholder, input[type="email"]::placeholder, input[type="number"]::placeholder, textarea::placeholder{color: var(--n-info);}

input[type="text"]:focus-visible, input[type="password"]:focus-visible, input[type="tel"]:focus-visible, input[type="email"]:focus-visible, input[type="number"]:focus-visible, textarea:focus-visible {border-color: #339DFF;}

/* 입력이 불가능할 때 */
input:disabled{background-color: var(--b-color5) !important; color: var(--n-deactivate) !important; touch-action: none; pointer-events: none; border-color: var(--b-color5) !important;}
input:disabled::placeholder{color: var(--n-deactivate);}
a.disabled,
button:disabled {background-color: var(--b-color4) !important; color: var(--n-deactivate) !important; touch-action: none; pointer-events: none; border-color: var(--b-color4) !important;}
input[type="text"]:disabled,
input[type="password"]:disabled,
input[type="tel"]:disabled,
input[type="email"]:disabled,
input[type="number"]:disabled{border-color: var(--s-color1) !important;}

/* 값이 유효or 유효하지 않을 때 */
input.valid {border: 1px solid var(--p-color1) !important; background-image: url('https://static.edmclass.com/common/membership/valid.svg'); background-repeat: no-repeat; background-size: 16px; background-position: right 12px center;}
input.invalid,
input:user-invalid{border: 1px solid var(--waring-color) !important; outline: none !important; background-image: url('https://static.edmclass.com/common/membership/invalid.svg'); background-repeat: no-repeat; background-size: 16px; background-position: right 12px center;}
input.invalid + span::before,
input:user-invalid + span::before{border: 1px solid var(--waring-color) !important;}
input[type="date"]:in-range, input[type="date"]:user-valid{background-image: none !important;}

input[type="checkbox"], input[type="radio"]{width: 0; height: 0; opacity: 0; position: absolute;}
input[type="checkbox"] + span, input[type="radio"] + span{position: relative; padding-left: 22px; display: inline-block; cursor: pointer; }
input[type="checkbox"] + span::before, input[type="radio"] + span::before{content: ''; width: 14px; height: 14px; border: 1px solid var(--s-color1); position: absolute; left: 0; top: -2px; background-color: var(--n-white);}

input[type="checkbox"] + span::before{border-radius: 4px;}
input[type="checkbox"]:checked + span::before{background-color: var(--p-color2); border-color: var(--p-color2);}
input[type="checkbox"] + span::after{content: ''; background-image: url('https://static.edmclass.com/common/membership/checkIcon.svg'); background-repeat: no-repeat; background-size: 16px; background-position: center; width: 16px; height: 16px; position: absolute; left: 0; top: -2px; opacity: 0;}
input[type="checkbox"]:checked + span::after{opacity: 1;}
input[type="checkbox"]:disabled + span::before{background-color: var(--b-color5); border-color: var(--b-color5);}
input[type="checkbox"]:disabled + span{color: var(--n-deactivate); cursor: auto; }

input[type="radio"] + span::before{border-radius: 50%; top: -1px;}
input[type="radio"] + span::after{content: ''; position: absolute; width: 8px; height: 8px; border-radius: 50%; background-color: var(--n-white); top: 2.5px; left: 4px;}
input[type="radio"]:checked + span::before{background-color: var(--p-color2); border-color: var(--p-color2);}



[class *='mo-'] {display: block;}
[class *='tablet-'] {display: none;}
[class *='tab_pc-'] {display: none;}
[class *='mo_tab-'] {display: block;}
[class *='pc-'] {display: none;}

.noScroll{overflow: hidden !important; }
.hidden{position: absolute; width:0; height:0; overflow: hidden; clip:rect(0, 0, 0, 0);} /* 주로 페이지 내 h1 타이틀 명에 사용 */
.max-width{padding: 0 16px; width: 100%; ;} /* 영역의 가장 부모 다음에 추가 / padding-top, bottom 값은 부모 영역에 추가 */
.flex{display: flex; flex-wrap: wrap;}
.flex.sb{justify-content: space-between;}
.flex.align-c{align-items: center;}
.ellipsis_2{overflow: hidden; text-overflow: ellipsis; -webkit-box-orient: vertical; -moz-box-orient: vertical; line-clamp: 2; -webkit-line-clamp: 2; display: -moz-box; display: -webkit-box;}
.ellipsis_1{overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pretendard{font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif; }

/* scrollbar */
.scrollArea{padding: 0 16px;}
.scrollWidth{overflow: hidden;} /* scrollWidth 부모영역의 padding : 24px일 때 */
.scrollWrap{overflow-y: auto; width: 100%; height: 100%;} /* 박스에 스크롤이 필요할 때 사용 */
.scrollWrap::-webkit-scrollbar{display: block; width: 5px;}
.scrollWrap::-webkit-scrollbar-track{background: transparent;}
.scrollWrap::-webkit-scrollbar-thumb{background: var(--b-color2); border-radius: 8px;}

/* pagination */
#paginationWrap{display: none;}

/* messageBox */
.messageBox{padding: 12px 6px 12px 27px; border-radius: var(--b-radius0); background-color: var(--b-color5); font-size: var(--f-body3); position: relative; color: var(--n-info); margin-bottom: 16px; line-height: 16px; word-break: break-all;}
.messageBox em{display: block; color: #40404E;}
.messageBox em + p{margin-top: 2px;}
.messageBox figure{background-image: url('https://static.edmclass.com/common/membership/infoIcon-black.svg'); width: 16px; height: 16px; background-repeat: no-repeat; background-position: center; background-size: contain; position: absolute; left: 9px; top: 12px;}
.messageBox figure.red{background-image: url('https://static.edmclass.com/common/membership/infoIcon-red.svg');}
.messageBox.red{background-color: #FFF7F7;}
.messageBox.red em{color: var(--waring-color); }

body>.os-scrollbar{z-index: 99998;}
body>.os-scrollbar.click-notification{z-index: 99996;}
.os-scrollbar-vertical{padding: 8px 8px 8px 0; width: 14px;}
.os-scrollbar-handle{background: var(--b-color2); width: 5px !important;}

.scroll-x-active{overflow-x: auto; display: flex;}
.scroll-x-active::-webkit-scrollbar{display: none; height: 6px;}
.scroll-x-active::-webkit-scrollbar-track{background: transparent;}
.scroll-x-active::-webkit-scrollbar-thumb{background: var(--b-color2); border-radius: 8px;}

/* banner slide */
#eventBannerSlide{overflow: hidden;}
#eventBannerSlide .swiper-slide a{overflow: hidden; border-radius: var(--b-radius3);}
#eventBannerSlide .swiper-slide a img{display: block; width: 100%; max-width: 100%; image-rendering: auto; transform: translateZ(0); /* GPU 렌더 트리거 */ backface-visibility: hidden; }

/*
	page title
	pageTitleWrap -> page Title 이 없는 페이지에 디자인상 필요할 경우 클래스 바꿔서 사용함.
*/
.pageTitle,
.pageTitleWrap{text-align: center; font-size: var(--f-heading1); padding: 14px 0; font-weight: 700; letter-spacing: -0.4px; line-height: 28px; position: sticky; top: 40px; z-index: 10; color: var(--n-mainTitle); margin-bottom: 1px;}
.pageTitle.hidden { display: none;}
.pageTitle::after,
.pageTitleWrap::after{content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(255,255,255,0.9); backdrop-filter: blur(6px); z-index: -1;}
.pageTitle .backBtn{width: 24px; height: 24px; background-image: url('https://static.edmclass.com/common/board/back_btn.svg'); background-repeat: no-repeat; background-size: contain; background-position: center; position: absolute; left: 0; top: 50%; transform: translateY(-50%);}

/* background color gray */
.gray{background-color: var(--b-color5);}

/*
    bottom sheet
*/
/* default : 버튼으로 열리는 bottom sheet 디자인 */
.bottom-sheet{position: fixed; bottom: 0; left: 0; width: 100%; height: 0; z-index: 99999; transition: height 0.5s ease;}
.bottom-sheet .dragWrap{position: absolute; top: 0; left: 0; width: 100%; height: 30px; }
.bottom-sheet .slidingWrap{background-color: var(--n-white); padding: 16px; border-radius: var(--b-radius1) var(--b-radius1) 0 0; position: absolute; bottom: 0; left: 0; z-index: 1; width: 100%; height: calc(100% - 24px);}
.bottom-sheet .dim{position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.2); opacity: 0; transition: opacity 1s ease 0.5s;}
.bottom-sheet .closeBtn{width: 40px; height: 5px; background-color: var(--n-info2); margin: 0 auto; display: block; border-radius: 2.5px; z-index: 10; position: relative;}
.bottom-sheet .closeBtn span{display: inline-block; text-indent: -999999%; width: 100%;}
/* type2 : 일반적인 bottom sheet 디자인 */
.bottom-sheet.type2{height: 149px;}
.bottom-sheet.type2 .slidingWrap{padding-top: 0; box-shadow: var(--box-shadow4);}
.bottom-sheet.type2 .slidingWrap .topWrap{padding-top: 45px;}
.bottom-sheet.type2 .closeBtn{position: absolute; top: 16px; left: 50%; transform: translateX(-50%);}
/* active */
.bottom-sheet.active{height: calc(100vh - 56px); height: calc((var(--vh, 1vh) * 100) - 56px); z-index: 99999;}
.bottom-sheet.active .dim{opacity: 1;}
.bottom-sheet.type2.active{height: 100vh; height: calc(var(--vh, 1vh) * 100);}
.bottom-sheet.type2.active .closeBtn{z-index: 2;}

/* pc에서는 팝업형태 */
.bottom-sheet.type2.verChange{height: 100vh; height: calc(var(--vh, 1vh) * 100); touch-action: none; pointer-events: none; overflow: hidden; visibility: hidden;}
.bottom-sheet.type2.verChange .slidingWrap{height: calc(100% - 24px); overflow: hidden; transform: translateY(100%); transition: transform 0.5s ease; padding: 20px 0 0;}
.bottom-sheet.type2.verChange.active{touch-action: auto; pointer-events: visible; visibility: visible;}
.bottom-sheet.type2.verChange.active .slidingWrap{transform: translateY(0);}
.bottom-sheet.type2.verChange .buttonWrap{padding: 16px; background-color: var(--n-white);}
.bottom-sheet.type2.verChange .buttonWrap *{width: calc(50% - 4px); text-align: center; display: inline-block; height: 52px; line-height: 52px; background-color: var(--b-color4); border-radius: var(--b-radius0); font-size: var(--f-heading3); font-weight: 700; color: var(--n-info); outline: 0; border: none; cursor: pointer;}
.bottom-sheet.type2.verChange .buttonWrap *.submitBtn{background-color: var(--p-color2); color: var(--n-white); outline: 0; border:none; cursor: pointer;}

/*  */
.bottom-sheet.off .dim,
.bottom-sheet.off .dragWrap{top: 0 !important;}
.bottom-sheet.in .dim,
.bottom-sheet.in .dragWrap{top: auto;}


/* swiper slide pagination */
.swiper-pagination-bullets{text-align: center; margin-top: 26px; display: flex; justify-content: center; box-sizing: border-box;}
.swiper-pagination-bullets .swiper-pagination-bullet{width: 8px; height: 8px; background: var(--n-deactivate); opacity: 1; margin: 0 4px; transition: all 0.3s ease;}
.swiper-pagination-bullets .swiper-pagination-bullet-active{background: var(--n-mainTitle);}
.swiper-pagination-bullets.loop .swiper-pagination-bullet:last-child,
.swiper-pagination-bullets.loop .swiper-pagination-bullet.small{width: 6px; height: 6px;}
.swiper-pagination-bullets.loop .swiper-pagination-bullet:last-child.swiper-pagination-bullet-active{width: 8px; height: 8px;}
.swiper-pagination-lock{display: none !important;}

/* 페이지 경로 */
#breadcrumb {display: none;}


/* dropDownMenu - default 40 ver. */
.dropDownMenu{font-size: var(--f-body1); letter-spacing: -0.28px;}
.dropDownMenu .label{border: 1px solid var(--s-color1); border-radius: var(--b-radius0); width: 100%; height: 40px; padding: 0 28px 0 12px; color: var(--n-info); background-image: url('https://static.edmclass.com/common/new_selectArrow.svg'); background-repeat: no-repeat; background-size: 16px; background-position: right 12px center; text-align: left; background-color: var(--n-white); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.dropDownMenu .label.active{border-color: var(--n-info); color: var(--n-subTitle); background-image: url('https://static.edmclass.com/common/new_selectArrow-active.svg');}
.dropDownMenu .label.selected{color: var(--n-subTitle) !important;}
.dropDownMenu .label.invalid{border: 1px solid var(--waring-color) !important; outline: none !important; color: var(--n-subTitle);}
.dropDownMenu .selectBox { position: relative; }
.dropDownMenu .selectBox .optionListWrap { position: absolute; z-index: 15; top: 44px; left: 0; width: 100%; background: var(--n-white); color: var(--n-white); border-radius: var(--b-radius0); overflow: hidden; border: 1px solid var(--s-color1); padding: 8px; font-size: inherit; box-shadow: var(--box-shadow3); display: none;}
.dropDownMenu .selectBox .optionListWrap .scrollWidth{width: 100%;}
.dropDownMenu .selectBox .optionListWrap .scrollWrap{padding-right: 0;}
.dropDownMenu .selectBox .optionListWrap .optionList{ max-height: 200px; /*padding-right: 5px;*/}
.dropDownMenu .selectBox .optionListWrap .optionItem *{display: block; padding: 11px 10px; line-height: 1; color: var(--n-subTitle); width: 100%; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.dropDownMenu .selectBox .optionItem.selected { background: var(--b-color4); border-radius: var(--b-radius0);}
/* dropDownMenu - 24 ver. (pc: 40 ver.) */
.dropDownMenu.d-24{font-size: var(--f-body3); letter-spacing: -0.24px;}
.dropDownMenu.d-24 .label{height: 24px; padding: 0 22px 0 6px; border-radius: 4px; background-position: right 6px center;}
.dropDownMenu.d-24 .selectBox .optionListWrap{top: 28px; padding: 6px; border-radius: 4px;}
.dropDownMenu.d-24 .selectBox .optionListWrap .optionItem *{padding: 6px;}

/* floatingWrap 버튼 */
#floatingWrap{position: fixed; height: 104px; bottom: 72px; right: 16px; z-index: 99996; transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1); width: 48px; padding-top: 56px;}
#floatingWrap .kakaoTalk{width: 48px; height: 48px; box-shadow: var(--box-shadow2); border-radius: 150px; overflow: hidden; background: linear-gradient(180deg, #FFEC45 -14.29%, #FC0 101.79%); display: flex; align-items: center; justify-content: center; position: absolute; top: 0; right: 0; transition: width 0.3s ease;}
#floatingWrap .kakaoTalk figure{background-repeat: no-repeat; background-size: contain; background-position: center; width: 30px; height: 28px; position: absolute; left: 9px; top: 50%; transform: translateY(-50%); z-index: 2;}
#floatingWrap .kakaoTalk span{font-size: var(--f-body1); font-weight: 700; line-height: 20px; letter-spacing: -0.28px; opacity: 0; transition: opacity 0.3s ease; position: absolute; right: 9px; top: 50%; transform: translateY(-50%); color: #3C1D1E;}
/* #floatingWrap .kakaoTalk.top{width: 104px; border-radius: 28px;} */
/* #floatingWrap .kakaoTalk.top span{opacity: 1;} */
#go-top{width: 48px; height: 48px; border-radius: 50%; background-color: var(--n-white); position: relative; box-shadow: -15px -15px 15px 0px rgba(0, 0, 0, 0.04) inset, 0px 8px 20px 0px rgba(0, 0, 0, 0.04); transition: all 0.3s ease;}
#go-top svg{width: 24px; height: 24px; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);}

/* #floatingWrap.on{position: absolute; top: -92px;} */
/* #floatingWrap.active{opacity: 1; transform: translateY(0); touch-action: auto; pointer-events: visible;} */
/* bottom-fixed */
#floatingWrap.fix-type2{bottom: 140px;}

/* 수강신청 */
#floatingWrap.promotion{bottom: 68px;}


/* customLine - bottom (mobile : 100vw / tablet, pc : 100%) */
.customLine{position: relative;}
.customLine::after{content: '';  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: calc(100vw - 8px); height: 1px; background-color: var(--s-color1);}

/* slide pagination */
.slide .pagination{background-color: rgba(0, 0, 0, 0.20); margin-top: 10px; border-radius: 15px; padding: 8px 6px; display: inline-block; position: relative; }
.slide .pagination::after{content: ''; clear: both; display: block;}
.slide .pagination > li{float: left; }
.slide .pagination .btn{background: var(--n-subTitle); opacity: 0.3; width: 8px; height: 8px; border-radius: 50%; margin: 0 4px; display: block; transition: all 0.3s ease;}
.slide .pagination .btn.is-active{background: var(--n-white); opacity: 1;}


/* 하단 fixed 버튼 */
.bottom-fix-btn{text-align: center; position: sticky; bottom: 55px; left: 0; width: 100%; padding: 16px 0; background: var(--MO-Gradient, linear-gradient(180deg, rgba(255, 255, 255, 0.00) 0%, #FFF 13.99%, #FFF 100%)); z-index: 99996;}
.bottom-fix-btn a,
.bottom-fix-btn button,
.bottom-fix-btn input[type="submit"],
.bottom-fix-btn input[type="button"]{width: 100%; height: 52px; line-height: 52px; text-align: center; border-radius: 8px; font-size: var(--f-heading3); font-weight: 500; outline: 0; border: none; font-family: inherit; color: var(--n-white); background-color: var(--p-color2); cursor: pointer; max-width: 332px;}



/*
    media query
    :: 0px ~ mobile
    :: 576px ~ tablet
    :: 1200px ~ pc
*/


/* tablet */
@media screen and (min-width: 576px) {
    [class *='mo-'] {display: none;}
    [class *='tablet-'] {display: block;}
    [class *='tab_pc-'] {display: block;}


    input[type="checkbox"] + span::before{top: -1px;}
    input[type="checkbox"] + span::after{top: -1px; left: 0;}

    .max-width{padding: 0 32px;}
    .pageTitle,
	.pageTitleWrap{font-size: var(--f-display3); padding: 100px 0 40px; position: static;}
    .pageTitle::after,
	.pageTitleWrap::after{display: none;}

    /* type2 : 일반적인 bottom sheet 디자인 */
    .bottom-sheet.type2{height: 133px;}

    /* customLine - bottom (mobile : 100vw / tablet, pc : 100%) */
    .customLine::after{width: 100%; left: 0; transform: none;}

    /* slide pagination */
    .slide .pagination{margin-top: 18px; position: static;}

    /* 하단 fixed 버튼 */
    .bottom-fix-btn{position: static; padding: 0; margin-top: 16px; margin-bottom: 0;}

    /* messageBox */
    .messageBox em + p{margin-top: 6px;}
    .messageBox figure{width: 16px; height: 16px;}

}

/* pc */
@media screen and (min-width: 1200px) {
    [class *='tablet-'] {display: none;}
    [class *='pc-'] {display: block;}
    [class *='mo_tab-'] {display: none;}

    body{padding-top: 130px;}

    #header .topWrap > .mobile-btn{display: none !important;}

    input:out-of-range, input:user-invalid{background-size: 24px; background-position: right 16px center;}
    input:in-range, input:user-valid,input.invalid{background-size: 20px; background-position: right 16px center;}

    input[type="text"], input[type="password"], input[type="tel"], input[type="email"], select{padding: 0 16px; letter-spacing: -0.32px; height: 56px; border-radius: 12px; font-size: var(--f-heading3);}
    input[type="checkbox"] + span, input[type="radio"] + span{padding-left: 26px; line-height: normal; font-size: var(--f-body1)}
    input[type="checkbox"] + span::before{top: 0;}
    input[type="checkbox"] + span::before, input[type="radio"] + span::before{width: 18px; height: 18px;}
    input[type="checkbox"] + span::after{width: 20px; height: 20px; top: 0; left: 0; background-image: url('https://static.edmclass.com/common/membership/checkIcon-pc.svg'); background-size: 20px;}
    input[type="radio"] + span::before{top: 2px;}
    input[type="radio"] + span::after{width: 10px; height: 10px; left: 5px; top: 7px;}

    input:user-invalid{background-image: url('https://static.edmclass.com/common/membership/invalid-pc.svg'); background-size: 24px;}
    input.valid{background-image: url('https://static.edmclass.com/common/membership/valid-pc.svg'); background-size: 24px;}

    .scroll-x-active{overflow: hidden; padding-right: 0 !important; padding-left: 0 !important;}

    /* banner slide */
    #eventBannerSlide .swiper-slide a{border-radius: var(--b-radius1);}

    /* 검색 */
    .searchWrap .search{width: 384px;}
    .searchWrap .search input[type="text"]{height: 40px; font-size: var(--f-body1); border-radius: var(--b-radius0); padding-left: 8px;}


    /* 페이지 경로 */
    #breadcrumb {padding-top: 40px; display: block;}  /* header 크기만큼 padding 추가(header fixed) */
    #breadcrumb .pathWrap ul{align-items: center;}
    #breadcrumb .pathWrap ul .home{width:16px; height: 16px; background-image: url('https://static.edmclass.com/common/new_breadcrumb-home.svg'); background-repeat: no-repeat; background-size: contain; background-position: center;}
    #breadcrumb .pathWrap ul .home a { width: 100%; height: 100%;}
    #breadcrumb .pathWrap ul li { display: flex; align-items: center; font-size: var(--f-heading3); color: var(--n-deactivate);}
    #breadcrumb .pathWrap ul li a { color: var(--n-deactivate); }
    #breadcrumb .pathWrap ul li + li{position: relative; margin-left: 32px;}
    #breadcrumb .pathWrap ul li + li::before{content: ''; position: absolute; left: -24px; top: 50%; transform:  translateY(-50%); width: 16px; height: 16px; background-image: url('https://static.edmclass.com/common/new_breadcrumb-arrow.svg'); background-repeat: no-repeat; background-size: contain; background-position: center;}
    #breadcrumb .pathWrap ul li.current, #breadcrumb .pathWrap ul li.current a{color:var(--n-info);}

    /* scrollbar */
    .scrollArea{padding: 0 24px;}

    /* pagination */
    #paginationWrap{display: block; text-align: center; font-size: var(--f-body1); padding-top: 32px;}
    #paginationWrap .pagination{display: flex; align-items: center; justify-content: center;}
    #paginationWrap a{display: inline-block; width: 32px; height: 32px; border-radius: var(--b-radius0); background-color: var(--n-white); line-height: 32px; margin: 0 2px;}
    #paginationWrap a:active{background-color: var(--p-color2); filter: brightness(1);}
    #paginationWrap .number{display: flex;}
    #paginationWrap .page{background-repeat: no-repeat; background-size: contain; background-position: center;}
    #paginationWrap .page-first{background-image: url('https://static.edmclass.com/common/board/page-first.svg');}
    #paginationWrap .page-prev{background-image: url('https://static.edmclass.com/common/board/page-prev.svg');}
    #paginationWrap .page-next{background-image: url('https://static.edmclass.com/common/board/page-next.svg');}
    #paginationWrap .page-last{background-image: url('https://static.edmclass.com/common/board/page-last.svg');}
    #paginationWrap .page-first.disabled{background-image: url('https://static.edmclass.com/common/board/page-first-disabled.svg');}
    #paginationWrap .page-prev.disabled{background-image: url('https://static.edmclass.com/common/board/page-prev-disabled.svg');}
    #paginationWrap .page-next.disabled{background-image: url('https://static.edmclass.com/common/board/page-next-disabled.svg');}
    #paginationWrap .page-last.disabled{background-image: url('https://static.edmclass.com/common/board/page-last-disabled.svg');}
    #paginationWrap a.current{background-color: var(--p-color2); color: var(--n-white); font-weight: 500;}

    .messageBox{line-height: 22px; font-size: var(--f-heading3); padding: 16px 16px 16px 42px; margin-bottom: 24px;}
    .messageBox figure{width: 24px; height: 24px; top: 16px; left: 16px; background-image: url('https://static.edmclass.com/common/membership/infoIcon-black-pc.svg');}
    .messageBox em + p{font-size: var(--f-body1);}
    .messageBox figure.red{background-image: url('https://static.edmclass.com/common/membership/infoIcon-red-pc.svg');}

    /* dropDownMenu */
    /* dropDownMenu - 24 ver. (pc: 40 ver.) */
    .dropDownMenu.d-24{font-size: var(--f-body1); letter-spacing: -0.28px;}
    .dropDownMenu.d-24 .label{height: 40px; padding: 0 28px 0 12px; border-radius: var(--b-radius0);}
    .dropDownMenu.d-24 .selectBox .optionListWrap{top: 44px; padding: 8px;}
    .dropDownMenu.d-24 .selectBox .optionListWrap .optionItem *{padding: 11px 10px;}

    .max-width{max-width: 1200px; margin: 0 auto;}

    .pageTitle,
	.pageTitleWrap{font-size: var(--f-display2); letter-spacing: -0.56px; line-height: 38px; padding-top: 45px; position: static; margin-bottom: 0; }


    .bottom-sheet .dragWrap{display: none;}
    /* type2 : 일반적인 bottom sheet 디자인 */
    .bottom-sheet.type2{position: static; height: auto; width: auto;}
    .bottom-sheet.type2 .slidingWrap{position: static; height: auto; box-shadow: none; border-radius: 0; padding: 0;}
    .bottom-sheet.type2 .dim{display: none; transition-delay: 0s;}

    /* pc에서는 팝업형태 */
    .bottom-sheet.type2.verChange{position: fixed; top: 0; left: 0; width: 100%; height: 100vh; }
    .bottom-sheet.type2.verChange .slidingWrap{position: absolute; transform: translate(-50%,-50%); bottom: auto; left: 50%; top: calc(50% + 100px); width: 600px; max-height: 800px; height: auto; transition: top 0.5s ease; border-radius: var(--b-radius1); overflow: hidden; box-shadow: var(--box-shadow3);}
    .bottom-sheet.type2.verChange .closeBtn{background-image: url('https://static.edmclass.com/common/popupCloseBtn.svg'); background-repeat: no-repeat; width: 24px; height: 24px; background-size: contain; background-position: center; background-color: transparent; top: 16px; right: 16px; transform: none; left: auto;}
    .bottom-sheet.type2.verChange .buttonWrap{justify-content: center; padding: 32px 0;}
    .bottom-sheet.type2.verChange .buttonWrap *{font-size: var(--f-body2); width: 104px; height: 34px; line-height: 34px; margin: 0 4px; font-weight: 500; background-color: var(--n-white); border: 1px solid var(--s-color1);}
    .bottom-sheet.type2.verChange .buttonWrap *.submitBtn{border: 1px solid var(--p-color2); background-color: var(--n-white); color: var(--p-color2);}

    /* top 버튼 */
    #floatingWrap{width: 56px; right: 32px; bottom: 64px; padding-top: 72px; height: 128px;}
    #floatingWrap .kakaoTalk{width: 56px; height: 56px; transition: width 0.5s ease; border-radius: 28px; display: block;}
    #floatingWrap .kakaoTalk figure{width: 35px; height: 33px; left: 10.5px;}
    #floatingWrap .kakaoTalk span{font-size: var(--f-body1); right: 13px; line-height: 20px; letter-spacing: -0.28px;}
    /* #floatingWrap .kakaoTalk.top{width: 114px;} */
    #go-top{width: 56px; height: 56px; box-shadow: 0px 8px 20px 0px rgba(0, 0, 0, 0.08), -20px -20px 20px 0px rgba(0, 0, 0, 0.04) inset;}

    /* 수강신청 */
    #floatingWrap.promotion{bottom: 64px;}

    /* 하단 fixed 버튼 */
    .bottom-fix-btn{margin-top: 32px; margin-bottom: 0;}
    .bottom-fix-btn a,
    .bottom-fix-btn button,
    .bottom-fix-btn input[type="submit"],
    .bottom-fix-btn input[type="button"]{width: 236px; height: 56px; line-height: 3; font-size: var(--f-heading2); border-radius: 12px; color: var(--n-white); background-color: var(--p-color2); font-weight: 700; transition: background-color 0.3s ease, color 0.3s ease;}
    .bottom-fix-btn a:active,
    .bottom-fix-btn button:active,
    .bottom-fix-btn input[type="submit"]:active,
    .bottom-fix-btn input[type="button"]:active{background-color: var(--p-color2); color: var(--n-white); filter:brightness(1); font-weight: 600;}


    /*************************************************************
        hover effect
    *************************************************************/
    @media (hover: hover) and (pointer: fine) {
        #floatingWrap .kakaoTalk:hover{width: 114px;}
        #floatingWrap .kakaoTalk:hover span{opacity: 1;}

        .bottom-sheet.type2.verChange .buttonWrap *:hover{background-color: var(--b-color4); border-color: var(--b-color4);}
        .bottom-sheet.type2.verChange .buttonWrap *.submitBtn:hover{background-color: var(--p-color2); color: var(--n-white); border-color: var(--p-color2);}

        /* 하단 fixed 버튼 */
        .bottom-fix-btn a:hover,
        .bottom-fix-btn button:hover,
        .bottom-fix-btn input[type="submit"]:hover,
        .bottom-fix-btn input[type="button"]:hover{background-color: var(--n-subTitle); }

        .dropDownMenu.d-24 .selectBox .optionItem:hover{border-radius: var(--b-radius0);}
    }

}


@media screen and (min-width: 1264px) {
    .max-width{padding: 0;}
}

@media screen and (min-width: 1660px) {
    #floatingWrap{right: 82px;}
}



/*************************************************************
    hover effect
*************************************************************/
@media (hover: hover) and (pointer: fine) {
    .dropDownMenu .selectBox .optionItem:hover{ background: var(--b-color4); border-radius: var(--b-radius0);}
    .dropDownMenu.d-24 .selectBox .optionItem:hover{border-radius: 4px;}

    #go-top:hover{background-color: var(--b-color4);}

    #paginationWrap a:not(.current):hover{background-color: var(--b-color4); font-weight: 500;}
}



/*************************************************************
    loading spinner
*************************************************************/
#loading-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); z-index: 99999; display: flex; justify-content: center; align-items: center; }

.loading-spinner { background-color: white; padding: 30px; border-radius: 8px; text-align: center; box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); }
.loading-spinner i.ico-download { background-image: url(https://static.edmclass.com/ielts/my_class/ico_down_loading.svg); -webkit-animation: loading 2s infinite linear; animation: loading 2s infinite linear; }
.loading-spinner p { font-size: var(--f-body1); color: var(--n-subTitle); margin-top: 10px; }

@keyframes loading {
0% { transform: rotate(0deg); }
100% { transform: rotate(359deg); }
}





.flag { display: flex; position: relative; top: 1px; height: 20px; color: #ffffff; margin-right: 8px; font-size: 14px; align-items: center;}
.flag::before { content: ""; display: block; width: 3px; height: 20px; border-radius: 2px; background: linear-gradient(270deg, #FFAD84 0%, #FFCF7D 100%); }
.flag span { padding: 1px 3px;; height: 18px; border-radius: 0px 2px 2px 0px;font-size: 12px;display: flex;align-items: center; font-weight: 700; white-space: nowrap;}
.flag.orange span,
.flag.red span{ background: linear-gradient(90deg, #FF544A 0%, #FF4163 100%);}
.flag.green span,
.flag.skyblue span,
.flag.blue span{ background: linear-gradient(86deg, #10A9FF 1.8%, #5557FF 94.86%); }
.flag.pink span,
.flag.purple span{ background: linear-gradient(90deg, #D277E5 0.69%, #7531F9 99.88%); }


.debug {color: #ff6531; margin: 0 !important; padding: 0; list-style: none; display: flex; background-color: #fffbe1;}
.debug li {margin-right: 1rem;}
.debug label { font-weight: 700; color: #333; margin-right: 0.25rem;}
