@charset "utf-8"; 
@import "contents.css";
@import "board.css";
@import "quick.css";

:root { 
	--navy: hsl(208, 100%, 34%); 
	--bluegreen: hsl(174, 100%, 34%); 
	--red: hsl(11, 92%, 45%); 
	--dark: hsla(210deg, 8%, 29%, 1); 
	--gray8: hsla(0deg, 0%, 80%, 1); 
	--gray9: hsla(0deg, 0%, 95%, 1); 
	--gray7: hsla(0deg, 0%, 70%, 1); 
	--gray6: hsla(0deg, 0%, 60%, 1); 
	--gray4: hsla(0deg, 0%, 40%, 1); 
}

/* 서브 레이아웃 */
body { height: 100%; }
#wrap {}
.footer { margin-top: auto; }
aside.right {top:18rem; transform: none; right: calc(50% - (1280px / 2) - 12rem);}
@media(max-width: 1550px){
	aside.right {right:1rem;}
}
@media(max-width: 1440px){
	aside.right {display: none;}
}

.subMenu .content .tabs li { background: var(--darkPrimary, hsl(145, 68%, 26%) ); }
.tbl .btn ~ .btn { margin-left: 0; }

/* 여백 */
.pt0 { padding-top: 0!important; }
.pt5 { padding-top: .5rem!important; }
.pt10 { padding-top: 1rem!important; }
.pt20 { padding-top: 2rem!important; }
.pb0 { padding-bottom: 0rem!important; }
.pb4 { padding-bottom: .4rem!important; }
.pb8 { padding-bottom: .8rem!important; }
.pl0 { padding-left: 0rem!important; }
.pl4 { padding-left: .4rem!important; }
.pl8 { padding-left: .8rem!important; }
.pr0 { padding-right: 0rem!important; }
.pr4 { padding-right: .4rem!important; }
.pr8 { padding-right: .8rem!important; }
.pr12 { padding-right: 1.2rem!important; }
/**/
.box.wrap { flex-wrap: wrap; }
/* tbl 부트스트랩 버전 테이블 스타일 추가_221018 */
/* tbl_테이블 태그 안에 버튼이 들어가는 경우_추가_221018 */
.tbl .btn { padding: 0.4rem 1rem; font-size: 1.4rem; border-radius: 0.4rem; margin: 2px; }
.tbl .btn ~ .btn { margin-left: 0; }
/* button */
button.disabled { opacity: 0.45 !important; pointer-events: none !important; }

/* 크기 */
.lg { font-size: 110%; }

.mh40 { max-height: 40rem !important; }

/* 색상 */
[class~="red"] { color: var(--red, hsl(11, 92%, 45%, 1)) }
[class~="blue"] { color: var(--blue, hsla(198, 100%, 41%, 1)) }
[class~="bluegreen"] { color: var(--bluegreen, hsl(174, 100%, 34%)) }
[class~="gray6"] { color: var( --gray6, hsla(0deg, 0%, 60%, 1) ) }

/* 코너 형태 */
.rect { border-radius: 0 !important; }

/* 버튼 스타일 추가*/
/* solid 배경깔릴때 사용, 색상 클래스가 추가작성돼있지 않거나 solid가 없고 btn 클래스만 있는 경우 기본 바탕색은 흰색 */
[class="solid"] { color: #333 !important; background-color: #fff; border-color: currentColor; }
[class~="solid"] { color: var(--white, #f5f5f5) !important; background-color: hsla(198, 100%, 41%, 1); border-color: currentColor; }
[class~="solid"]:hover { border-color: currentColor; filter: contrast(110%) brightness(90%); color: var(--white, #fff); }
.solid.blue, .solid.fcBlue { background-color: var(--blue,hsla(198, 100%, 41%, 1) ); border-color: var(--blue, hsla(198, 100%, 41%, 1) ); }
.solid.bluegreen, .solid.fcGreen { background-color: var(--bluegreen, hsl(174, 100%, 34%) ); border-color: var(--bluegreen, hsl(174, 100%, 34%) ); }
.solid.gray, .solid.fcGray { background-color: var( --dark3 , hsla(0deg, 0%, 80%, 1) ); border-color: var(--dark3 , hsla(0deg, 0%, 80%, 1) ); color: #333 !important }
.solid.dark { background-color: var( --dark , hsla(210deg, 8%, 29%, 1) ); border-color: var(--dark , hsla(210deg, 8%, 29%, 1) ); color: #fff !important }
.btn[data-mobile-icon="true"] {}
.btn[data-mobile-icon="true"] i { display: block; }
.btn[data-mobile-icon="true"]:not(i) { display: none; }
@media(min-width:1024px) {
	.btn[data-mobile-icon="true"] i { display: none; }
	.btn[data-mobile-icon="true"]:not(i) { display: initial; }
}

/* 상태 라벨 추가 */
.label { display: inline-block; padding: 4px 12px; line-height: normal; font-size: 1.5rem; border-radius: .4rem; color: var(--dark3); border: 1px solid currentColor; }
.label.basic { display: inline-block; padding: 0.4rem 0.6rem; line-height: normal; font-size: 1.3rem; border-radius: .4rem; color: var(--dark3); border: none; }
.label.basic.bcRed { color: #da4727; }
.label.basic.bcTeal { color: #12949C; }
.label.basic.bcBlue { color: #0090D0; }
.label.basic.bcPurple { color: #772AC4; }
.label.basic.bcGray { color: #666666; }
.label.support {font-size: 1.3rem; color: #fff; font-weight: 500; padding: 0.4rem 0.6rem; background-color: #00C471;}

/* */
.infoTag { padding: 3rem; border-radius: 1rem; border: 1px solid #dddddd; }
.infoTag .box { border: 0; padding: 1rem; border-radius: 0; }
.infoTag .box ~ .box { padding-top: 3rem; margin-top: 2rem; border-top: 1px dashed #ddd }
.infoTag .btn { display: inline-block; font-size: 90%; background-color: var(--gray9, hsla(0deg, 0%, 95%, 1) ); border-radius: 10em; border: 0; padding: .3em 1em; margin: 4px }
.infoTag .btn.on { background-color: var(--bluegreen, hsl(182, 58%, 40%)); color: #fff }
.infoTag .box .title { flex-basis: 100%; }

/* video */
.video {}
.video .thumbnail { position: relative; display: inline-block; padding-top: 56.25% !important; width: calc( 100% - 1em); border: 0; background-color: transparent !important; cursor: pointer; }
.video .thumbnail::after { content: "\ea3f"; position: absolute; display: inline-block; line-height: 1; font-family: xeicon !important; font-style: normal; font-weight: 400; font-variant: normal; text-transform: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-size: 2em; left: 50%; top: 50%; transform: translate(-50%,-50%); color: #fff; z-index: 2; }
.video .thumbnail::before { content: ""; position: absolute; display: block; width: 100%; height: 100%; background-color: hsla(0deg, 0%, 0%, .4); left: 0; top: 0; z-index: 1; }
.video .thumbnail img { position: absolute; width: 100%; height: 100%; object-fit: contain; object-position: center; left: 0; top: 0; z-index: 0; }
@media(max-width:1280px) {
	.video[data-mobile-icon="true"] { position: relative; display: block; padding: .4rem 1rem !important; width: auto; margin-left: unset !important; margin-right: unset !important; border: 1px solid #ddd; color: #fff; border-color: var(--navy, hsl(208, 100%, 34%)); background-color: var(--navy, hsl(208, 100%, 34%)) !important; }
	.video[data-mobile-icon="true"]::after { display: none; }
	.video[data-mobile-icon="true"]::before { display: none; }
}
/* 콘텐츠가 없는 경우_221216 */
.no-list { display: flex ; align-items: center; flex-direction: column; gap: 1rem; color: var(--text-color6); justify-content: center; border-radius: 1.6rem; min-height: 30rem; margin-top: 3rem; background-color:#fff;  border: 1px solid #e1e6eb; }
.no-list::before { content: ''; display: block; width: 50px; height: 60px; background: url(../img/common/logo-emblem-gray.png) center no-repeat; background-size: contain; }


.like-table { width: 100%; display: table; margin-top: 1rem; }
.like-table .thead { display: table-header-group; }
.like-table .thead .th { display: table-cell; text-align: center; position: relative; vertical-align: middle; background-color: #f7f7f7; padding: 13px 0; color: #222; font-weight: 500; border-top: 1px solid #e0e0e0; line-height: 1.5rem; word-break: keep-all; }
.like-table .thead .th .txt-small { font-size: 1.3rem; }
.like-table .thead .th + .th:before { content: ''; position: absolute; left: 0; top: 50%; background-color: #d9d9d9; width: 1px; height: 14px; margin-top: -7px; }
.like-table .tbody { display: table-row-group; padding: 0; }
.like-table .tbody .tr { display: table-row; }
.like-table .tbody .tr .td { display: table-cell; text-align: center; margin-bottom: 0; padding: 12px 8px; border-bottom: 1px solid #e1e1e1; background: #fff; vertical-align: middle; }
/* .like-table .tbody .tr:last-child .td { border-bottom: 1px solid #e1e1e1; } */
.like-table .tbody .tr .td.txt-left dd { padding-left: 1rem; }
.like-table .tbody .tr .td dt { display: none; }
.like-table .tbody .tr .td .btn, .like-table .tbody .tr .td .btn3 { padding: .4rem 1rem; font-size: 1.4rem; border-radius: .4rem; margin: 2px; }
/**/
.like-table .tbody .tr .td input[type="checkbox"] { width: 1.125em; height: 1.125em; }
.like-table .tbody.main { min-height: 20rem; display: coltable; }
.like-table + .no-list { position: relative; padding: 1em 0; text-align: center; /* border: 1px solid #e1e1e1; */
}
@media screen and (max-width:1280px) {
	.like-table { display: block; }
	.like-table .thead { display: none; }
	.like-table .tbody { display: block; }
	.like-table .tbody .tr { position: relative; display: flex; flex-wrap: wrap; background-color: #fff; margin: 0 5px; padding: 0; }
	/* border-top: 1px solid #999; */
	.like-table .tbody .tr:first-child { border-top: 1px solid #999; }
	.like-table .tbody .tr::after { content: ""; clear: both; position: absolute; display: block; width: 100%; height: 1px; bottom: 0; left: 0; background-color: #999; }
	.like-table .tbody .tr .td { display: flex; align-items: flex-start; float: left; width: 50%; }
	/* .like-table .tbody .tr:last-child .td { border-bottom: 0; } */
}
@media screen and (max-width:1280px) and (max-width:768px) {
	.like-table .tbody .tr .td { width: 100%; }
}
@media screen and (max-width:1280px) {
	.like-table .tbody .tr .td dt { display: inline-block; text-align: left; width: 30%; position: relative; padding-left: 12px; padding-right: 8px; vertical-align: top; color: #222; font-weight: 500; }
	.like-table .tbody .tr .td dt .txt-small { font-size: 1.4rem; }
	.like-table .tbody .tr .td dt:before { content: ''; width: 3px; height: 3px; top: .8em; margin-top: -1px; left: 0; position: absolute; background-color: #000; }
	.like-table .tbody .tr .td dd { display: inline-block; width: 70%; height: 100%; border-left: 1px solid #e7e7e7; text-align: left !important; padding-left: 10px; padding-right: 10px; }
	.like-table .tbody .tr .td.dt-hidden { clear: both; display: block; width: 100%; }
	.like-table .tbody .tr .td.dt-hidden dt { display: none; }
	.like-table .tbody .tr .td.dt-hidden dd { width: 100%; border-left: 0 none; }
}
@media screen and (max-width:786px) {
	.like-table { margin-top: 1rem; }
	.like-table .tbody .tr { border: 1px solid #f0f1f2; margin: 0 0 10px; /* @include display-flex; */ flex-wrap: wrap; padding: 7px 15px 7px 15px; position: relative; font-size: 13px }
	.like-table .tbody .tr:first-child { border-top: 1px solid #f0f1f2; }
	.like-table .tbody .tr:last-child { border-bottom: 1px solid #f0f1f2; }
	.like-table .tbody .tr::after { background-color: transparent; }
	.like-table .tbody .tr .td { padding: 5px 0; }
	.like-table .tbody .tr .td:last-child { border-bottom: 0 }
	/* .like-table .tbody .tr .td:nth-child(2) { border-top: 1px solid #e1e1e1; } */
	.like-table .tbody .tr .td dt:before { width: 2px; height: 2px; background-color: #9ea4a6; }
	.like-table .tbody .tr .td dd { text-align: left !important; padding-left: 10px; }
}
.like-table .tbody .tr.alert {margin: 4em 0 2em; display: flex; }
.like-table .tbody .tr.alert::after { bottom: -2em; }
.like-table .tbody .tr.alert .cnt { position: absolute; display: block; width: calc(100% - 1em); padding: 1em; margin-top: -3em; background-color: hsla(208, 100%, 34%, .1); margin-left: .5em; text-align: center; }
.like-table .tbody .tr.alert dt { display: block !important; }
.like-table .tbody .tr.alert dd { padding: 1em }
@media screen and (max-width:1280px) {
	.like-table .tbody .tr.alert { border: 0 }
	.like-table .tbody .tr.alert .cnt { position: relative; }
}
@media screen and (max-width:786px) {
	.like-table .tbody .tr.alert { padding: 0 4px; }
	.like-table .tbody .tr.alert .cnt { width: 100%; margin-left: 0; }
	.like-table .tbody .tr.alert .cnt span { display: block; }
}
/* .table with table atg */
.table.st2 { display: block; }
.table.st2 tbody { display: block; }
.table.st2 tr { display: block; }
.table.st2 tr > * { display: block; text-align: left; padding: 8px }
.table.st2 tr > th { background-color: #f4f4f4; background-image: none; }
@media(min-width:1024px) {
	.table.st2 { display: table; }
	.table.st2 tbody { display: table-row-group; }
	.table.st2 tr { display: table-row; border: 1px solid #ddd; border-left: 0; border-right: 0; }
	.table.st2 tr > * { display: table-cell; }
}

/* 표 */
.table2 { background-color: #fff; border-top: 0; border-left: 0; }
.table2>.row { display: flex; flex-direction: row; flex-wrap: wrap; align-items: stretch; margin-right: 0; margin-left: 0; }
.table2>.row:last-of-type { border-bottom: 1px solid #ddd; }
.table2>.row .col { flex: 1; display: flex; flex-wrap: wrap; min-width: 15em; /*gap: 1em; */
	border-top: 1px solid #ddd; }
.table2>.row .col .title { display: inline-flex; justify-content: left; align-items: center; width: 100%; min-width: 5em; max-width: 7em; height: 100%; padding: 1em 8px; background-color: #f4f4f4; /* */
}
.table2 > .row .col:first-of-type .title { border-left: 0; }
@media(min-width:1024px) {
	.table.st2>.row .col label, .table.st2>.row .col .title { width: 10em; }
}
.table2>.row .col>:not(.title) { flex: 1; margin: auto 1em; padding: .75em 0; }
.table2>.row input, .table.st2>.row textarea { margin: 4px 0; border-radius: 2px; }
.table2>.row textarea { min-height: 10em; }
.table2>.row .btn { padding: 0.4rem 1rem; font-size: 1.4rem; border-radius: 2px; min-height: 3.7rem; }
table .alert { margin: 4em 0; border-right: 0 !important; }
table .alert .cnt { display: block; width: calc(100% - 2em); padding: 1em; background-color: hsla(208, 100%, 34%, .1); margin-left: 1em; text-align: center; }
table .alert dt { display: block !important; }
table .alert dd { padding: 1em }
.table-scroll { display: flex; border: 0; background: transparent; border-radius: 0; overflow: auto; }
.table-scroll .tbl-left td, .table-scroll .tbl-main-wrap { flex: 1; position: relative; min-width: 0; }
.table-scroll .tbl-left, .table-scroll .tbl-right { background: #fff; }
.table-scroll .tbl-left td, .table-scroll .tbl-right td { padding: 8px 20px; }
.table-scroll .tbl-left .ui.checkbox label, .ui.checkbox + label, .table-scroll .tbl-right .ui.checkbox label, .ui.checkbox + label { padding: 0 }
.table-scroll .tbl-main { width: 100%; }
.table-scroll .tbl-main td { min-width: 140px; }
/* white-space: nowrap; */
.table-scroll .tbl-main th {}
.table-scroll table { width: auto; margin: 0; }
.table-scroll table thead th { padding: 15px 8px; }
.table-scroll table td { padding: 8px; text-align: center; }
@media(max-width:1024px) {
	.table-scroll .tbl-main { cursor: move; }
}

/* 디바이스 사이즈별 화면 show-hidden */
.mobile-elem { display: none !important; }
@media all and (max-width:1280px) {
	.mobile-elem { display: initial !important; }
	.desktop-elem { display: none !important; }
}

.tbl { position: relative; overflow: hidden; }
.tbl:before { content: ''; position: absolute; display: block; width: 1px; height: 100%; background-color: #fbfbfb; z-index: 555555; top: 0; left: 0px; }
.tbl:after { content: ''; position: absolute; display: block; width: 1px; height: 100%; background-color: #fbfbfb; z-index: 555555; top: 0; right: 0px; }

/* 이미지 슬라이드 */
.slider { position: relative; /* */width: 100%; height: 300px; background-color: #f9f9f9; }
.slider > button { position: absolute; display: block; width: 3em; height: 3em; top: calc(50% - 1.5em); z-index: 3; overflow: hidden; color: transparent; background-color: rgba(255,255,255,.9); }
.slider > button::before { content: ''; position: absolute; display: block; width: 40%; height: 40%; border-top: 2px solid; border-left: 2px solid; border-color: #333; transform-origin: center; top: 30%; }
.slider > button.slick-next { right: 0px }
.slider > button.slick-prev { left: 0px; }
.slider > button.slick-next::before { right: calc(50% - 8px); transform: rotate(135deg); }
.slider > button.slick-prev::before { left: calc(50% - 8px); transform: rotate(-45deg); }
.slider .slideitem { width: 100%; height: 300px; }
/* .slider .slick-list { height: 100%; } */
/* .slider .slick-list .slick-track { height: 100%; } */
.slider img { margin: unset; /* display: block; */
	width: 100%; height: 100%; object-fit: cover; object-position: center; }

/* role 사용한 ui 스타일 추가_230201 */
[role="tablist"] { position: relative; display: flex; z-index: 1; }
[role="tablist"]::before { content: ''; position: absolute; display: block; width: 100%; height: 2px; background-color: var(--dark3); top: calc(100% - 1px); left: 0; z-index: 2; }
[role="tablist"] [role="tab"] { flex: 1; position: relative; max-width: 20%; color: var(--dark2); padding: 8px 1em; border-bottom: 2px solid transparent; background-color: #fff; z-index: 1; }
[role="tablist"] [role="tab"]:hover { background-color: hsla(205, 100%, 40%, .1); }
[role="tablist"] [role="tab"][aria-selected="true"] { font-weight: bold; color: var(--brandcolor); border-bottom-color: var(--brandcolor); z-index: 3; }
[role="tabpanel"] { display: none; }
[role="tabpanel"].on { display: block; }
.ui.horizontal.divider { margin-top: 35px; margin-bottom: 30px; display: table; white-space: nowrap; height: auto; line-height: 1; text-align: center; }
.ui.horizontal.divider:before, .ui.horizontal.divider:after { content: ''; display: table-cell; position: relative; top: 50%; width: 50%; background-repeat: no-repeat; }
.ui.horizontal.divider:before { background-position: right 1em top 50%; }
.ui.horizontal.divider:after { background-position: left 1em top 50%; }
.ui.horizontal.divider:before, .ui.horizontal.divider:after { background-image: url(../img/common/divider_line.png); }


/* No Content */
.no_content .no_text { display: flex; flex-direction: column; justify-content: center; text-align: center; color:var(--text-color4); width: 100%; }
.no_content .no_text i { width: 100%; display: inline-block; font-size: 3.5rem; color:var(--text-color6); margin-bottom: 1rem; }
.no_content { padding: 5rem 0 6rem; position: relative; display: flex; width: 100%; min-height: 32rem; margin-bottom: 3rem; align-items: center; justify-content: center; border-radius: 2rem; background-color: #f3f5f9; }
.no_text .ico.icon-cont-none:before { -webkit-mask-image: url('../img/common/icon-cont-none.svg'); mask-image: url('../img/common/icon-cont-none.svg'); }
.no_text .ico { display: inline-block; width: 2em; height: 2em; color: currentColor; }
.no_text .ico:before { content: ''; display: block; width: 100%; height: 100%; background-position: center; background-repeat: no-repeat; color: currentColor; background-color: currentColor; }
.no_text .ico[class*="icon-"]:before { -webkit-mask-size: contain; -webkit-mask-position-x: 50%; -webkit-mask-position-y: calc(50% - 0px); -webkit-mask-repeat: no-repeat; mask-size: contain; mask-position-x: 50%; mask-position-y: 50%; mask-repeat: no-repeat; }


/* =======================================================================================
sub - member
======================================================================================= */
.member .flex-container { padding: 5rem 0 6rem; position: relative; display: flex; flex-direction: column; width: 100%; height: 100%; min-height:50rem ; align-items: center; justify-content: center; border-radius: 2rem; background-color: #f3f5f9; }
.member .flex-container .con { width: 32rem; margin-left: auto; margin-right: auto; }
.member .tit-header { padding: 0rem 0 2rem 0; }
.member .tit-header .title { margin: 0px; font-size: 2.8rem; font-weight: 800; line-height: 1.4; margin-bottom: 1rem; text-align: center; }
.member .tit-header .desc { font-size: 1.6rem; text-align: center; }
.member .flex-container .entry_btn button { padding: 1.5rem 2rem; background: linear-gradient(145deg, #24ad5d 15%, #1E7F46 100%); box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.13); width: 100%; font-size: 1.8rem; font-weight: 500; color: #fff; border-radius: .6rem; display: block; }
.member .flex-container .btns-join { display: flex; flex-direction: column; }
.member .flex-container .btns-join .btn { padding: 1.2rem 2rem; width: 100%; font-size: 1.6rem; font-weight: 500; color: #fff; border: none; border-radius: .6rem; text-align: center; }
.member .flex-container .btns-join .btn ~ .btn { margin-top: 1rem; margin-left: 0rem; }
.member .flex-container .btns-join .btn.kakao { color: #333; background: #fae100 url(../img/common/sns_kakao.png) no-repeat 15px 12px; background-size: 22px; }
.member .flex-container .btns-join .btn.naver { background: #00C73C url(../img/common/sns_naver.png) no-repeat 15px 13px; background-size: 22px; }
@media (max-width:1023.98px) {
	.member { margin-top: 3rem; }
}

/* =======================================================================================
sub - myClass 
======================================================================================= */
h5.subtitle { font-size: 2.2rem; margin-bottom: 1.3rem; }
.box.terms.txt_small { padding: 2rem; font-size: 1.4rem; word-break: keep-all; }
.btn.list { margin-left: 2rem; }

/* 3개씩 출력 */
.myCourseList .list_ul { display: flex; flex-wrap: wrap; margin: 0 -1.2rem; }
.myCourseList .list_ul .list_li { display: flex; padding: 0 1.2rem 3rem 1.2rem; position: relative; }
.myCourseList .list_ul .list_li .item { display: flex; width: 100%; flex-direction: column; position: relative; border-radius: 1.4rem; background: #fff; box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.13); }
.myCourseList .list_ul .list_li .thumb_img { overflow: hidden; position: relative; border-radius: 1.2rem; width: calc(100% - 3rem); margin: 1.5rem 1.5rem 0 1.5rem; padding-top: 52%; }
.myCourseList .list_ul .list_li .thumb { position: absolute !important; top: 0; left: 0; width: 100%; height: 100%; }
.myCourseList .list_ul .list_li .thumb img { position: absolute; top: 0; left: 0; max-width: 100%; background-size: cover; -webkit-transition: all .5s; -o-transition: all .5s; transition: all .5s; -webkit-transform: scale(1) translateZ(0); transform: scale(1) translateZ(0); image-rendering: optimize-contrast; -webkit-backface-visibility: hidden; backface-visibility: hidden; opacity: 1 !important; object-fit: cover; width: 100%; height: 100%;}
.myCourseList .list_ul .list_li .thumb_img:hover img { -webkit-transform: scale(1.03) translateZ(0); transform: scale(1.03) translateZ(0); }
.myCourseList .list_ul .list_li .card_label { margin-bottom: 0.4rem; }
.myCourseList .list_ul .list_li .title { display: inline-block; font-size: 1.8rem; line-height: 2.2rem; word-break: keep-all; font-weight: 700; display: block; width: 100%; transition: all .4s; }
.myCourseList .list_ul .list_li .date, .myCourseList .list_ul .list_li2 .s_num { display: inline-block; font-size: 1.4rem; margin: .6rem 0 0 0; color: #80848A; }
.myCourseList .list_ul .list_li .date b, .myCourseList .list_ul .list_li2 .s_num b { font-weight: normal; color: #000; display: inline-block; margin-right: .4rem; }
.myCourseList .list_ul .list_li .desc { display: block; display: -webkit-box; -webkit-line-clamp: 2; max-height: 4.8rem; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; white-space: normal; word-wrap: break-word; word-break: keep-all; margin-bottom: 2rem; }
.myCourseList .list_ul .list_li .date { position: relative; padding-left: 0.6rem; margin-left: 0.6rem; }
.myCourseList .list_ul .list_li .date::before { content: ''; display: block; background-color: #ddd; width: 1px; height: 1.4rem; position: absolute; transform: translate(0, -50%); left: -2px; top: 50%; }
.myCourseList.col3 > .list_ul .list_li { flex: 0 0 33.333333%; max-width: 33.333333%; }
.myCourseList.col4 > .list_ul .list_li { flex: 0 0 25%; max-width: 25%; }
.myCourseList .list_ul .list_li .thumb:hover { opacity: .9; background-size: ; transform: scale(1) translateZ(0); transition: all .5s; }
.myCourseList .list_ul .list_li:hover img, .myCourseList .list_ul .list_li2:focus img { opacity: 1; transform: scale(1) translateZ(0); transition: all .5s; }
.myCourseList .list_ul .list_li .item_txt { flex-grow: 1; padding: 2rem 2.5rem; }
.my_prog_rate .progress { margin-top: 1.8rem; height: 1.25rem; border-radius: 5rem; background: #D2D6DA; flex: 1; overflow: hidden; }
.my_prog_rate .progress .bar { float: left; height: 100%; border-radius: 5rem; }
.my_prog_rate .progress .bar.red_type { background: linear-gradient(90deg, #f58982 0%, #da6860 100%); }
.my_prog_rate .progress .bar.rainbow_type { background: linear-gradient(90deg, rgb(220, 76, 44) 0%, rgb(221, 115, 58) 20%, rgba(207, 194, 13, 0.884) 45%, rgb(84, 182, 19) 65%, rgb(71, 132, 190) 85%); }
.my_prog_rate .prog_num { font-size: 1.4rem; margin-right: 1rem; color: #80848A; }
.my_prog_rate .meta { font-size: 1.4rem; font-weight: 700; }
.myCourseList .bottom_button { display: flex; flex-direction: row; flex-grow: initial; padding: 0 !important; border-top: 1px solid rgba(34, 36, 38, 0.1); }
.myCourseList .bottom_button .go { display: block; padding: 0.75em 1em; font-size: 1.7rem; font-weight: 600; flex: 1; flex-basis: auto; color: var(--primary); text-align: center; transition: all .4s; border-radius: 0 0 1.4rem 1.4rem; }
.myCourseList .bottom_button .go:hover { background-color: #F3FAF7; }

.myCourseList .grade_info { display: flex; flex-direction: column; margin-top: 1.5rem; }
.myCourseList .grade_info li { display: flex; padding: 0.15rem 0 0.15rem 0.8rem; font-weight: 500; font-size: 1.5rem; }
.myCourseList .grade_info li span { width: 60px; font-weight: 400; flex: 0 0 auto; margin-right: 1.5rem; color: #80848A; }
.myCourseList .grade_info li.total {margin-top: 1rem; color: var(--blue); padding-top: .5rem; padding-bottom: .5rem; background-color:#F0F4FF; border-radius: 1rem;}
.myCourseList .grade_info li.total span {color: var(--blue); font-weight: 600;}
.myCourseList .grade_info li.cer_info {font-weight: 600 !important; margin-top: 1rem; padding-top: .5rem; padding-bottom: .5rem; background-color:#f7f7f7; border-radius: 1rem;}
.myCourseList .bottom_button { flex-grow:initial;}
.myCourseList .bottom_button .go.disabled {color: #c0c0c0;}
.myCourseList.finish .bottom_button {background-color: #373F57; border-radius: .8rem; margin: 1rem;}
.myCourseList.finish .bottom_button .go {font-size: 1.6rem; color:#57ddff; padding: 0.75em 1em 0.85em;}
.myCourseList.finish .bottom_button .go.disabled {opacity: 0.35 !important;}
.myCourseList.finish .bottom_button .go::before { content: ""; display: inline-block; position: relative; top: 2px; width: 16px; height: 16px; margin-right: 3px; background: url(../img/common/icon_certificate.svg) center center no-repeat;}
.myCourseList.finish .bottom_button .go:hover { background-color: #2a3144; }
.myCourseList.finish.col4 > .list_ul .list_li .item_txt {padding-bottom: 0;}
.myCourseList.finish.col4 > .list_ul .list_li {display: inline-flex;}
.myCourseList.finish.col4 .list_ul .list_li .item {display: flex; width: 100%; flex-direction: column;}
.myCourseList.finish.col4 .list_ul .list_li .item_txt {flex-grow: 1;}
.myCourseList.finish .finish_label {position: absolute; right: 1.5rem; top: 2rem; display: flex; align-items: center; justify-content: center; width: 59px; height: 60px; background:  url(../img/common/bg_grade_result.svg) center no-repeat;}
.myCourseList.finish .finish_label span {font-size: 1.4rem; color: #fff; font-weight: 600;}


.table_list {color: #666; border-top: 2px solid #222;}
.table_list ul.list {display: flex; border-bottom: 1px solid #e8e8e8;}
.table_list ul.list > li {display: flex; align-items: center; padding: 2rem 1.5rem; border-right: 1px solid #e8e8e8;}
.table_list ul.list > li.head {width: 20%;}
.table_list ul.list > li label {font-weight: 500; color: #111;}
.table_list ul.list > li:nth-child(odd) {background: #f7f7f7;}
.table_list ul.list > li:nth-child(even) {flex: 1;}
.table_list ul.list > li:last-child {border-right: 0;}
.table_list ul.list > li .btn-line {flex: none;}
.table_list ul.list > li ul.add_file {flex: 1;}

.survey_area {padding: 3rem 4rem 4rem 4rem; display: block; border-radius: 1rem; border: 1px solid #dddddd;}
.survey_list {display: flex; flex-direction: column;}
.survey_list + .survey_list {margin-top: 2.8rem; padding-top: 2.8rem; border-top: 1px solid #e8e8e8;}
.survey_list .title {margin-bottom: 1rem; font-size: 2rem; font-weight: 700;}
.survey_list .title small {display: inline-block; margin-left: 1rem; font-size: 1.5rem; font-weight: 400; color: #666;}
.survey_list ol {display: flex; padding: 1rem; border-radius: 1rem; background: #f7f7f7;}
.survey_list ol li {flex: 1; text-align: center;}


/* =======================================================================================
sub - 수강신청
======================================================================================= */
.course_list ul.courseList { border-top: 2px solid #555; }
.course_list ul.courseList > li { border-bottom: 1px solid #e5e5e5; }
.course_list .course_con { display: flex; position: relative; justify-content: space-between; align-items: center; padding: 2rem; background-color: #fff; }
.course_list .course_con .course_img { flex: 0 0 22rem; max-width: 22rem; margin: 0 3.8rem 0 0; }
.course_list .course_con .course_img img { border-radius: 1.5rem; }
.course_list .course_con .course_info { display: flex; flex-direction: column; gap: .5rem; margin: 0 0 0 .8rem; }
.course_list .course_con .course_info { display: flex; margin-right: auto; }
.course_list .course_con .course_info .card_label .label.cate {font-size: 1.3rem; color: #fff; font-weight: 500; padding: 0.4rem 0.6rem; background-color: #E84646;}
.course_list .course_con .course_info .card_label .label.support {font-size: 1.3rem; color: #fff; font-weight: 500; padding: 0.4rem 0.6rem; background-color: #00C471;}
.course_list .course_con .course_info .item { display: flex; flex-direction: column; flex: 1; }
.course_list .course_con .course_info .item h2 {color: #222; font-size: 1.9rem; transition: all .5s; }
.course_list .course_con .course_info .item h2:hover {text-decoration: underline;}
.course_list .course_con .course_info .item h2 .label { font-size: 1.3rem; color: #fff; font-weight: 500; padding: 3px 5px; background-color: #E84646;}
.course_list .course_con .course_info .item ul { display: flex; flex-direction: column; margin-top: 1rem; }
.course_list .course_con .course_info .item ul li { display: flex; margin-top: .25rem; font-weight: 400; font-size: 1.5rem; color: #80848A;}
.course_list .course_con .course_info .item ul li span { width: 120px; font-weight: 400; flex: 0 0 auto; margin-right: 1.5rem; color: #80848A; }
.course_list .course_con .course_info .item ul li strong { color: #DC065B; font-weight: 800; }
.course_list .course_con .course_info .item ul li .price { display: flex ; gap: .6rem; font-weight: 600; font-size: 1.6rem; margin-bottom: 1rem; -webkit-box-align: center; align-items: center; }
.course_list .course_con .course_info .item ul li .price p.txt01 { color: #DC065B; }
.course_list .course_con .course_info .item ul li .price p.txt02 { color: #19181B; }
.course_list .course_con .course_info .item ul li .price p.txt03 { font-size: 1.2rem; color: #9DA7AE; text-decoration: line-through; }
.course_list .course_con .btn_apply {display: flex; flex-direction: column; gap: 1rem; }
.course_list .course_con .btn_apply .btn { padding: 1.2rem 2.5rem; border-radius: .8rem; font-size: 1.5rem;}
.course_list .course_con .btn_apply .btn {}
.course_list .course_con .btn_apply .btn + .btn {margin-left: 0;}

.course_header { padding: 32px; background-color: #25262b; }
.course_header .course_detail_info { max-width: 1280px; }

.course_pay {display: flex; flex-direction: column; position: relative; padding: 3rem; background-color: #fff; border-radius: 2.5rem; border: 1px solid #E9EBF2;}
.course_pay h4.seg_title {padding-bottom: 1.3rem;}
.course_pay .terms { overflow-y:auto; line-height: 1.6; }
.course_pay .terms_agree { margin: 1.5rem 0 2rem; }
.course_pay .agree_course .terms.box { padding: 0 1.5rem 0 0; border: none; flex-wrap: wrap; max-height: 35rem !important;}
.course_pay .agree_course .terms.box .table.st2 { margin-top: 0; }
.course_pay .agree_course .terms.box .table_list {width: 100%;}
.course_pay .agree_pay {margin-top: 3rem; margin-bottom: 3rem;}
.course_pay .agree_pay .terms { overflow-y:auto; line-height: 1.6; }
.course_pay .agree_pay .terms.box { padding: 2rem 1.5rem 2rem 2rem; color: #666; flex-wrap: wrap; border-radius: 2rem; max-height: 25rem !important;}
.total_price {display: flex; justify-content: flex-end; margin-top: 2rem;}
.total_price .price { width: 25%; text-align: center; font-size: 1.8rem; background-color: #fff; border-radius: 1rem; box-shadow: 0px 0px 10px 0px rgba(73, 171, 201, 0.5); margin: 1rem; padding: 1.5rem 2.5rem 1.5rem 1.5rem;}

/* =======================================================================================
sub - 장바구니 수정  25-03-10
======================================================================================= */
.cartWrap { display: flex; gap: 3rem; padding-bottom: 3rem; justify-content: space-between; }
.cartWrap .left_con { flex: 1; width: 100%; }
.cartWrap .right_con {  width: 32rem; }
.cart_list ul.cartList { border-top: 2px solid #555; }
.cart_list ul.cartList > li { border-bottom: 1px solid #e5e5e5; opacity: .5;}
.cart_list ul.cartList > li.active {opacity: 1;}
.cart_list .course_con { display: flex; position: relative; gap: 2rem; justify-content: space-between; align-items: center; padding: 2rem; background-color: #fff; }
.cart_list .course_con .course_img { flex: 0 0 18rem; max-width: 18rem; margin: 0 ; }
.cart_list .course_con .course_img img { border-radius: 1.5rem; }
.cart_list .course_con .course_info { display: flex; flex-direction: column; margin: 0 0 0 .8rem; }
.cart_list .course_con .course_info { display: flex; margin-right: auto; }
.cart_list .course_con .course_info .card_label .label.cate {font-size: 1.3rem; color: #fff; font-weight: 500; padding: 3px 5px; background-color: #E84646;}
.cart_list .course_con .course_info .card_label .label.support {font-size: 1.3rem; color: #fff; font-weight: 500; padding: 3px 5px; background-color: #00C471;}
.cart_list .course_con .course_info .item { display: flex; flex-direction: column; flex: 1; }
.cart_list .course_con .course_info .item h2 {color: #222; font-size: 1.7rem; transition: all .5s; }
.cart_list .course_con .course_info .item h2:hover {text-decoration: underline;}
.cart_list .course_con .course_info .item h2 .label { font-size: 1.3rem; color: #fff; font-weight: 500; padding: 3px 5px; background-color: #E84646;}
.cart_list .course_con .course_info .item ul { display: flex; flex-direction: column; margin-top: 1rem; }
.cart_list .course_con .course_info .item ul li { display: flex; margin-top: .25rem; font-weight: 400; font-size: 1.4rem; color: #80848A;}
.cart_list .course_con .course_info .item ul li span { width: 80px; font-weight: 400; flex: 0 0 auto; margin-right: 1rem; color: #80848A; }
.cart_list .course_con .course_info .item ul li strong { color: #DC065B; font-weight: 800; }
.cart_list .course_con .course_btn {margin-right: 1rem;}
.cart_list .course_con .course_btn a {padding: .6rem .6rem .4rem; font-size: 1.4rem; border-radius: 6px; border: 1px solid #E8E8E8; line-height: 1; transition: 0.2s; }
.cart_list .course_con .course_btn a:hover {background-color: #E8E8E8;}
.cart_list .course_con .price { display: flex; flex-direction: column; width:15rem ; font-weight: 500; font-size: 1.4rem; }
.cart_list .course_con .price .price_end {display: flex; gap: 1rem; font-size: 1.7rem; font-weight: 600;}
.cart_list .course_con .price p.txt01 { color: #DC065B; }
.cart_list .course_con .price p.txt02 { color: #19181B; }
.cart_list .course_con .price p.txt03 { font-size: 1.2rem; color: #9DA7AE; text-decoration: line-through;}
.cart_price { display: flex; flex-direction: column; gap: 1rem; padding: 2rem; border-radius: 12px; background-color: #fff; box-shadow: rgba(0, 0, 0, 0.08) 0px 8px 24px 0px, rgba(0, 0, 0, 0.12) 0px 0px 4px 0px; }
.cart_price .title { display: flex; align-items: center; gap:1.5rem; font-weight: 700; font-size: 1.6rem; }
.cart_price .title .title_caution {display: flex; align-items: center; font-size: 1.3rem; color: var(--primary); }
.cart_price .title .title_caution i {font-size: 1.5rem; margin-right: .6rem;}

.cart_price .cart_total_price { background: #f8f9fa; padding:2.5rem 2rem;}
.cart_price .cart_total_price dl {display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; font-size:1.5rem; margin:0 0 5px;}
.cart_price .cart_total_price dl dt {letter-spacing: -0.045rem; color:rgba(34,34,34,0.7);}
.cart_price .cart_total_price dl dd {font-weight: 500; letter-spacing: -0.045rem;}
.cart_price .cart_total_price dl dd.red {color:#DC065B;}
.cart_price .cart_total_price dl.last_total {margin-top:1.5rem; margin-bottom:0;}
.cart_price .cart_total_price dl.last_total dd {font-weight: 700; font-size:2.2rem; }
.cart_price .btn_full {display: flex; flex-direction: column;}
.cart_price .btn_full a { padding: 1.4rem; font-weight: 500; text-align: center; color: #fff; background-color:#D9635A; border-color:#D9635A; border-radius: 8px; transition: 0.2s;}
.cart_price .btn_full a:hover {background-color:#cc4f47;}
.cart_price .btn_full a span {font-weight: 300; letter-spacing: 1px;}
.cart_price .btn_full .samll_txt {margin-top: .5rem; text-align: center; font-size: 1.3rem; color: var(--text-color6); word-break: keep-all;}
.cartWrap .cart_mss {display: flex; gap: .5rem; margin-bottom:1rem; padding: 2rem; border-radius: 12px; background-color:#fff; box-shadow: rgba(0, 0, 0, 0.08) 0px 8px 24px 0px, rgba(0, 0, 0, 0.12) 0px 0px 4px 0px;}
.cartWrap .cart_mss i {font-size: 1.7rem;}
.cartWrap .cart_mss span {font-size: 1.4rem;}
.cartWrap .cart_mss strong {color:#DC065B;}
.cartWrap .cart_mss em {font-style: normal;}
.cart_price .btn_half {display: flex; gap: .6rem;}
.cart_price .btn_half a {width: 50%; display: flex; flex-direction: column; align-items: center; gap: .5rem; line-height: 1.4; font-weight: 600; font-size: 1.4rem; padding: 1.4rem .5rem 1.4rem .5rem; border-radius: 8px; transition: 0.2s;}
.cart_price .btn_half a img {width: auto; max-width: 75%; height: 1.5rem; object-fit: contain;}
.cart_price .btn_half a.active {color: var(--primary); border-color:var(--primary); background-color: #F3FAF7;}
.cart_price .btn_half .btn ~ .btn {margin-left: 0;}


/* 수강신청 - 확인동의 */
.cartWrap .course-agree {margin-bottom: 5rem;}
.agree_course_list { border: 1px solid #DEE2E6; margin: 0 0 15px 0; border-radius: 8px; }
.agree_course_list li .title-wrap { display: block; background-color: #F8F9FA; position: relative; border-radius: 8px; padding: 18px 25px; }
.agree_course_list li .title-wrap .title { color: #333; font-weight: 600; font-size: 17px; }
.agree_course_list li .title-wrap .title img { margin-left: 5px;}
.agree_course_list li .title-wrap .course_arrow {position: absolute; bottom: 16px; right: 20px; display: flex; align-items: center; gap: 1rem;}
.agree_course_list li .title-wrap .course_arrow span {font-size: 1.5rem;}
.agree_course_list li .title-wrap .course_arrow b {font-weight: 400;}
.agree_course_list li .title-wrap .arrow { color: #333;  font-size: 18px; padding: 6px; transition: all .25s ease; }
.agree_course_list li > .cont { opacity: 0; visibility: hidden; max-height: 0; overflow: hidden;  }
.agree_course_list li.active .title-wrap {border-radius: 8px 8px 0 0; border-bottom: 1px solid #DEE2E6;}
.agree_course_list li.active .cont { opacity: 1; visibility: visible; max-height: 1000px; padding:0; transition: all .3s ease; }
.agree_course_list li.active .arrow { transform: rotate(180deg); }
.agree_course_list li .cont_scorllbox { overflow-y: auto; max-height: 20rem; padding: 2rem 2.5rem; font-size: 90%;}
.agree_course_list li .cont_scorllbox .btn_plandown {margin-bottom: 1rem; }  
.agree_course_list li .cont_scorllbox .btn-line {font-size: 1.4rem; padding: .4rem 2.7rem .4rem 1rem; border-radius: .4rem;}
.agree_course_list li .cont_scorllbox .course-detail {padding-top: 0;}
.agree_course_list li .course_sub_title { font-size: 22px; color: #333; font-weight: 700; margin-bottom: 15px; margin-top: 0px; }
.agree_course_list li .course_sub_desc { line-height: 28px; letter-spacing: 0; margin-bottom: 40px; }
.agree_course_list li .title-wrap .course_con { display: flex; position: relative; justify-content: space-between; align-items: center; }
.agree_course_list li .title-wrap .course_con .course_img { flex: 0 0 13rem; max-width: 13rem; margin: 0 2.8rem 0 0; }
.agree_course_list li .title-wrap .course_con .course_img img { border-radius: 1.2rem; }
.agree_course_list li .title-wrap .course_con .course_info { display: flex; flex-direction: column; gap: .3rem; margin: 0 0 0 .8rem; margin-right: auto; }
.agree_course_list li .title-wrap .course_con .course_info .card_label .label {font-size: 1.2rem;}
.agree_course_list li .title-wrap .course_con .course_info .card_label .label.cate {font-size: 1.2rem; color: #fff; font-weight: 500; padding: 0.4rem 0.6rem; background-color: #E84646;}
.agree_course_list li .title-wrap .course_con .course_info .card_label .label.support {font-size: 1.2rem; color: #fff; font-weight: 500; padding: 0.4rem 0.6rem; background-color: #00C471;}
.agree_course_list li .title-wrap .course_con .course_info .item { display: flex; flex-direction: column; flex: 1; }
.agree_course_list li .title-wrap .course_con .course_info .item h2 {color: #222; font-size: 1.8rem;}
.agree_course_list li .title-wrap .course_con .course_info .item h2 .label { font-size: 1.3rem; color: #fff; font-weight: 500; padding: 3px 5px; background-color: #E84646;}
.agree_course_list li .title-wrap .course_con .course_info .item ul { display: flex; flex-direction: column; margin-top: 0rem; }
.agree_course_list li .title-wrap .course_con .course_info .item ul li { display: flex; align-items: center; margin-top: .25rem; font-weight: 400; font-size: 1.5rem; color: #80848A;}
.agree_course_list li .title-wrap .course_con .course_info .item ul li span { width: 60px; font-weight: 400; flex: 0 0 auto; margin-right: 1.5rem; color: #80848A; }
.agree_course_list li .title-wrap .course_con .course_info .item ul li .price { display: flex ; gap: .6rem; font-weight: 600; font-size: 1.6rem; -webkit-box-align: center; align-items: center; }
.agree_course_list li .title-wrap .course_con .course_info .item ul li .price p.txt01 { color: #DC065B; }
.agree_course_list li .title-wrap .course_con .course_info .item ul li .price p.txt02 { color: #19181B; }
.agree_course_list li .title-wrap .course_con .course_info .item ul li .price p.txt03 { font-size: 1.2rem; color: #9DA7AE; text-decoration: line-through; }
.agree_course_list li .terms_agree { border-top: 1px solid #e8e8e8; background: #DDE2EE ; color: #222; letter-spacing: 0; padding: 1.4rem 2.2rem; border-radius: 0 0 8px 8px; word-break: keep-all; display: flex ; align-items: center; box-shadow: rgba(0, 0, 0, 0.12) 0px 0px 14px 0px; }
.bottom_message { position: fixed; z-index: 24; max-width: 50rem; width: 100%; left: 50%; transform: translateX(-50%); bottom: 18px; max-height: min(530px, -134px + 100dvh); z-index: 400; }
.bottom_message .bottom_txt { display: flex; justify-content: center; align-items: center; font-weight: 600; color: #fff; border-radius: 2rem; padding: 2rem 3rem; gap: 1rem; background-color: rgb(0, 0, 0, .7 ); box-shadow: rgba(0, 0, 0, 0.25) 0px 20px 24px 0px; backdrop-filter: blur(8px);  }
.bottom_message .bottom_txt i.xi-error-o { font-size: 2.2rem; color: #ff4891; }

.cartWrap .agree_pay h4.seg_title { padding-bottom: 1.3rem; }
.cartWrap .agree_pay .terms_area {padding: 2rem; background-color: #f7f7f7; border-radius:1rem;}
.cartWrap .agree_pay .terms { line-height: 1.6; padding: 2rem 1.5rem 2rem 2rem;}
.cartWrap .agree_pay .terms.box { color: var(--text-color6); font-size: 1.5rem; background-color: #fff; flex-wrap: wrap; overflow-y: auto; max-height: 18rem !important;}
.cartWrap .agree_pay .terms_agree { margin: 1.5rem 0 0rem; }

.alert_area {display: flex; flex-direction: column; align-items: center; gap: 1.5rem; margin: 1rem 0 2rem 0;}
.alert_area .con_img {max-width: 50%; width: 16rem; object-fit: contain;}
.alert_area .col_txt {display: flex; flex-direction: column; gap: 1.5rem;}
.alert_area .col_txt .title { font-size: 2.2rem; color: #222; line-height: 1.2; text-align: center; }
.alert_area .col_txt .title strong {color: #12949C;}
.alert_area .col_txt .desc {font-size: 1.7rem; text-align: center;} 
.modal_cont .alert_area .xi-warning {position: relative; top: 3px; display: inline; font-size: 2.6rem; margin-bottom: 0; margin-right: .6rem;}
@media (max-width:380px) {
	.alert_area {margin-bottom: 0;}
	.alert_area .col_txt .title { font-size: 1.8rem;}
	.alert_area .col_txt .desc {font-size: 1.6rem;}
	.alert_area .col_txt .desc br {display: none;}
}

/* =======================================================================================
sub - 마이페이지
======================================================================================= */
/* 장바구니 */
/* .basket-total-price { position: relative; display: table; width: 100%; overflow: hidden; background-color: #fff; border: 2px solid #cecdcd; border-radius: 1rem;  margin-top: 4rem; }
.basket-total-price > div { display: table-cell; padding: 2rem 3rem; }
.basket-total-price > div:before { content: ''; display: block; position: absolute; top: 50%; margin: -15px -15px 0 0; width: 30px; height: 30px; border-radius: 50% 50%; }
.basket-total-price > div:after { content: ''; display: block; position: absolute; top: 50%; margin: -4px -7px 0 0; width: 13px; height: 9px; background-position: 50% 50%; background-repeat: no-repeat; }
.basket-total-price .order_price_area { width: 33.333333%; border-right: 1px solid #ebe8e8; box-sizing: border-box; }
.basket-total-price .order_price_area:before, .basket-total-price .order_price_area:after { display: none; }
.basket-total-price .estimated_price_area { width: 33.333333%; border-right: 1px solid #ebe8e8; box-sizing: border-box; }
.basket-total-price .estimated_price_area:before { right: 66.666666%; background-color: #616161; }
.basket-total-price .estimated_price_area:after { right: 66.666666%;}
.basket-total-price .total_price_area { width: 33.333333%; background-color: #fafafa; box-sizing: border-box; }
.basket-total-price .total_price_area:before { right: 33.333333%; background: linear-gradient(145deg, rgb(241, 111, 207) 0%, rgb(241, 74, 214) 100%);} 
.basket-total-price .total_price_area:after { right: 33.333333%;  }
.basket-total-price .total_price_area:after { content: ''; display: block; position: absolute; top: 50%; margin: -15px -15px 0 0; line-height: 32px; text-align: center; width: 30px; height: 30px; color: #fff; font-size: 2.4rem; font-family: xeicon; content: "\e960"; }
.basket-total-price .estimated_price_area:after { content: ''; display: block; position: absolute; top: 50%; margin: -15px -15px 0 0; line-height: 32px; text-align: center; width: 30px; height: 30px; color: #fff; font-size: 2rem; font-family: xeicon; content: "\e91a"; }
.basket-total-price .tit_area { position: relative; padding-bottom: 6px; font-size: 1em; color: #222; }
.basket-total-price .price_area { font-size: 2.4rem; font-weight: 600;} */
 
.btn_pay {margin-top: .8rem;}
.btn_pay .btn { padding: 0.4rem 1rem; font-size: 1.4rem; border-radius: 0.4rem; margin: 2px; }
.btn_pay .btn ~ .btn { margin-left: 0; }

/* 환불안내 */
.list-dot { line-height: 1.6; }
.list-dot li { padding: 4px 12px; }
.list-dot li:before { content: '·'; font-weight: bold; font-size: 1.8rem; margin-right: 4px; margin-left: -8px; }
.btn.pad-sm {padding: 0.4rem 1rem; margin: 2px;}

@media (max-width:1280px) {
	.cartWrap .right_con { width: 29rem; }
	.cart_list .course_con { gap: 1rem; }
	.cart_list .course_con .course_img { flex: 0 0 16rem; max-width: 16rem; }
	.cart_list .course_con .price { width: 14rem; }
	.cart_price .btn_half a {font-size: 1.3rem;}
}

@media (max-width:980px) {
	.course_detail .detail_top .course_img { flex: 0 0 28rem; max-width: 28rem; }
	.myCourseList.col4 .list_ul { margin: 0 -0.8rem; }
	.myCourseList.col4 .list_ul .list_li { flex: 0 0 33.333333%; max-width: 33.333333%; padding: 0 1rem 3rem 1rem; }
	.total_price .price { width: 100%; margin: .7rem;}
	.cartWrap .right_con { position: fixed; top: auto; left: 0; bottom: 0; margin-top: 0; transform: none; width: 100%; min-width: 100%; height: auto; z-index: 100; }
	.cart_price {flex-direction: row; align-items: center; border-radius: 0; padding:1.5rem 2rem;}
	.cart_price .cart_total_price {display: flex; gap: 2rem; padding: 1rem 2rem; border: 1px solid #e5e5e5; background-color: #fff; border-radius: 8px;}
	.cart_price .cart_total_price dl {flex-direction: column; align-items:flex-start; margin: 0;}
	.cart_price .cart_total_price dl + dl { border-left: 1px solid #e5e5e5; padding-left: 1rem;}
	.cart_price .cart_total_price dl dt {font-size: 1.4rem;}
	.cart_price .cart_total_price dl dd {font-size: 1.8rem;}
	.cart_price .cart_total_price dl dd.black { color: #9DA7AE; }
	.cart_price .cart_total_price dl.last_total { margin-top: 0; }
	.cart_price .cart_total_price dl.last_total dd { font-size: 1.8rem; }
	.cart_price .btn_full { margin-left: auto; }
	.cart_price .btn_full a {padding:1.4rem 3rem;}
	.cartWrap .cart_mss {margin-bottom: 0; border-radius: 0;     padding: 2rem 1.8rem 0 1.8rem;}
	.cartWrap .cart_mss + .cart_price {box-shadow: none; padding-top: .5rem;}
	.cart_price .btn_full .samll_txt {display: none;}
	.bottom_message { max-width: 80%; bottom: 105px; }
	.bottom_message .bottom_txt { padding: 1.2rem 2rem; }
	.right_con.KDT .cart_price .title  {display: none;}
}

@media (max-width:767.98px) {
	.myCourseList.col3 .list_ul .list_li { flex: 0 0 50%; max-width: 50%; padding: 0 1rem 3rem 1rem; }
	.course_list .course_con .course_img {flex: 0 0 18rem; max-width: 18rem; margin-right: 2rem; }
	.course_list .course_con .course_info .item ul {margin-top: 1rem; }
	.course_list .course_con .course_info .item ul li span { width: 70px;}
	.course_detail .detail_top .course_img { flex: 0 0 24rem; max-width: 24rem; }
	.course_detail .detail_top .course_info .item ul li span { width: 80px; }
	.content .course_pay .tabs li {flex-basis: calc(33.333333% - 0.8rem); max-width: calc(33.333333% - 0.8rem);}
	.survey_area {padding:2rem;}
	.survey_list ol { flex-wrap: wrap; }
	.survey_list ol li {flex: 50%; text-align: left;}
	.cartWrap .board_info {display:flex;}
	.cartWrap .board_info .page_info {margin-top: 0;}
	.cartWrap .cart_mss em {display: none;}
	.agree_course_list li .title-wrap {padding: 1.5rem 1.5rem;}
	.agree_course_list li .title-wrap .course_con .course_info .item ul {margin-top: 0;}
	.agree_course_list li .title-wrap .course_con .course_img { flex: 0 0 13rem; max-width: 13rem; margin-right: 1.5rem; }
	.agree_course_list li .title-wrap .course_arrow {gap: 0; bottom: 1rem; right: 1rem;}
	.agree_course_list li .title-wrap .course_arrow span {font-size: 1.5rem;}
	.agree_course_list li .cont_scorllbox { max-height: 20rem; padding: 1.5rem;}
	.right_con.KDT .cart_price .cart_total_price dl dt {display: none;}
	.right_con.KDT .cart_price .cart_total_price {padding: 1rem 1.5rem;}
	.right_con.KDT .cart_price .cart_total_price dl dt {line-height: 1;}
	.right_con.KDT .cart_price .cart_total_price dl dd {font-size: 1.5rem;}
	.right_con.KDT .cart_price .cart_total_price dl dd.black { text-decoration: line-through; }
	.right_con.KDT .cart_price .cart_total_price dl.last_total dd {font-size: 1.6rem;}	
	.right_con.KDT .cart_price .btn_half a {justify-content: center; padding: 1.2rem .5rem 1.2rem .5rem;}
	.right_con.KDT .cart_price .btn_half a img {display: none;}
}

@media (max-width:670px) {
	.myCourseList.col4 .list_ul { margin: 0 -0.8rem; }
	.myCourseList.col4 .list_ul .list_li { flex: 0 0 50%; max-width: 50%; padding: 0 1rem 3rem 1rem; }
	.course_list .course_con .btn_apply { margin-left: 21rem; margin-top: 1rem; flex-direction: row;}
	.course_list .course_con .btn_apply .btn { padding: .8rem 1.8rem; }
	.course_list .course_con {flex-wrap: wrap;}
	.course_detail .detail_top { flex-direction: column; }
	.course_detail .detail_top .course_img { margin: 2rem 0 0 0; flex: auto; }
	.course_detail .detail_top .course_info { margin: 2rem; }
	.course_detail .detail_con { padding: 2rem; }
	.cart_list .course_con {justify-content: flex-start; flex-wrap: wrap;     align-items:flex-start; padding: 2rem 1rem;}
	.cart_list .course_con .course_img { flex: 0 0 11rem; max-width: 11rem; }
	.cart_list .course_con .course_img img { border-radius: .8rem; }
	.cart_list .course_con .course_btn {position: absolute; top: 2.4rem; right: .5rem; margin-right: 0;}
	.cart_list .course_con .course_info {width: calc(100% - 185px);}
	.cart_list .course_con .course_info .item ul li span {width: 60px;}
	.cart_list .course_con .price {margin-left: auto; width: calc(100% - 145px); }
	.cart_price { padding: 1.5rem 1.5rem; }
	.cart_price .cart_total_price { padding: 1rem 1rem; }
	.cart_price .cart_total_price dl dd { font-size: 1.6rem; }
	.cart_price .btn_full a { padding: 1.4rem 1.5rem; }
	.agree_course_list li .title-wrap .course_arrow b {display: none;}
	.right_con.KDT .cart_price .cart_total_price {padding: 1rem 1rem; gap: 1rem;}
	.right_con.KDT .cart_price .btn_half a { max-width: 72px; padding: .5rem 1.2rem .5rem 1.2rem; }	
}


@media (max-width:550px) {
	.course_list .course_con {flex-direction: column; justify-content: center;}
	.course_list .course_con .course_img {flex:auto; max-width: 26rem; margin-bottom: 1rem;}
	.course_list .course_con .course_info {margin-right: inherit; }
	.course_list .course_con .btn_apply {margin-left: inherit; width: 100%;}
	.course_list .course_con .btn_apply .btn {width: 100%;}
	.basket-total-price > div {padding: 2rem;}
	.basket-total-price > div:before {width: 20px; height: 20px; margin: -10px -10px 0 0;}
	.basket-total-price .estimated_price_area:after,
	.basket-total-price .total_price_area:after {width: 20px; height: 20px; margin: -10px -10px 0 0; line-height: 20px;}
	.basket-total-price .price_area {font-size: 2rem;}
	.content .course_pay .tabs li {align-items: stretch; flex-basis: calc(50% - 0.8rem);}
	.cart_price {flex-direction:column;}
	.cart_price .title {display:none;}
	.cart_price .cart_total_price {width: 100%; padding: 1rem 1.5rem;}
	.cart_price .cart_total_price dl dt {line-height: 1;}
	.cart_price .cart_total_price dl dd {font-size: 1.5rem;}
	.cart_price .cart_total_price dl.last_total dd {font-size: 1.6rem;}
	.cart_price .btn_full {width: 100%;}
	.bottom_message {bottom: 160px;}
	.agree_course_list li .terms_agree {font-size: 1.5rem; padding-right: 1rem;}
	.agree_course_list li .terms_agree .custom-input input + label {margin-right: 0;}
	.agree_course_list li .title-wrap .course_con { justify-content: flex-start; flex-wrap: wrap; align-items: flex-start; }
	.agree_course_list li .title-wrap .course_con .course_info { width: calc(100% - 130px); }
	.agree_course_list li .title-wrap .course_arrow span { display: none; }
	.agree_course_list li .title-wrap .course_con .course_img { flex: 0 0 11rem; max-width: 11rem; margin-right: 1rem; }
	.agree_course_list li .title-wrap .course_con .course_info .item h2 { font-size: 1.7rem; }
	.agree_course_list li .title-wrap .course_con .course_info .item ul li span { display: none; }
	.right_con.KDT .cart_price { gap: .5rem; }
	.right_con.KDT .cart_price .btn_half { width: 100%; }
	.right_con.KDT .cart_price .btn_half a { max-width: 100%; padding: 1rem .5rem 1rem .5rem; }
	.right_con.KDT .cart_price .btn_full a { padding: 1rem 1rem; } 
	.right_con.KDT .cart_price .cart_total_price {border: none; padding-top: 0; padding-bottom: .5rem;}
}

@media (max-width:480px) {
	.course_list .course_con {justify-content: center;}
	.myCourseList .list_ul .list_li .item_txt { padding: 2rem 1.5rem; }
	.table_list ul.list {flex-direction: column; border-bottom: 0;}
    .table_list ul.list li.head {width: 100%;}
    .table_list ul.list li {padding: .75rem; border-right: 0; border-bottom: 1px solid #e8e8e8;}
	.course_pay {padding: 1.5rem;}
	.content .course_pay .tabs li {max-width: calc(50% - 0.8rem);}
	.cart_list .course_con {gap: .8rem; padding: 2rem 0rem;}
	.cart_list .course_con .course_img { flex: 0 0 9rem; max-width: 9rem; }
	.cart_list .course_con .course_info { width: calc(100% - 150px);}
	.cart_list .course_con .price {width: calc(100% - 123px);}
	.cart_list .course_con .course_btn {position: absolute; top: 2.4rem; right: 0rem;}
	.agree_course_list li .title-wrap .course_con .course_img { flex: 0 0 9rem; max-width: 9rem; }
	.bottom_message {max-width: 90%;}
}

@media (max-width:400px) {
	.myCourseList.col3 .list_ul .list_li,
	.myCourseList.col4 .list_ul .list_li { flex: 0 0 100%; max-width: 100%; }
	.myCourseList .list_ul .list_li .thumb_img { padding-top: 0%; padding: 1.5rem 1rem 0rem 1rem; }
	.myCourseList .list_ul .list_li .thumb { position: relative !important; display: flex; justify-content: center; }
	.myCourseList .list_ul .list_li .thumb img { position: relative; object-fit: contain; width: auto; border-radius: 1rem; max-height: 16rem; }
	.basket-total-price {padding: 1.5rem 2rem;}
	.basket-total-price .order_price_area,
	.basket-total-price .estimated_price_area,
	.basket-total-price .total_price_area {width: 100%; display: flex; justify-content: space-between;}
	.basket-total-price .order_price_area,
	.basket-total-price .estimated_price_area {border-right: none; border-bottom: 1px solid #ebe8e8;}
	.basket-total-price .estimated_price_area:before, 
	.basket-total-price .estimated_price_area:after,
	.basket-total-price .total_price_area:before,
	.basket-total-price .total_price_area::after {display: none;}
	.basket-total-price > div {padding: 1rem;}
	.basket-total-price .price_area {font-size: 1.8rem;}	
	.right_con.KDT .cart_mss span {line-height: 1;}
	.right_con.KDT .cart_mss span i {position: relative; top: -2px; }
	.agree_course_list li .cont_scorllbox .btn-line {max-width: 100%;}
}

.modal__btn {width: 100%; padding: 1.5rem 1rem; color: #fff; border-top: 1px solid #ccc; background: #222;}


/* =======================================================================================
sub - NEW 과정상세
======================================================================================= */
.courseWrap {min-height: 25rem; background: linear-gradient(0deg, #505150 15%, #1c1e1d 100%); }
.courseWrap .detail_top {display: flex; max-width: 81rem; width: 100%; min-height: 29rem;}
.courseWrap .detail_top .mobile_image {display: none;}
.courseWrap .detail_top .des { display: flex; gap: .5rem; flex-direction: column; padding: 4.5rem 1.5rem 4.5rem 1.5rem; letter-spacing: 0;}
.courseWrap .detail_top .cate_label { display: flex; gap: .5rem;}
.courseWrap .detail_top .cate_label span { color: #fff; font-size: 1.5rem; line-height: 1; padding: 0.7rem 1.3rem; border-radius: var(--border-radius-100); background: #E84646; }
.courseWrap .detail_top .cate_label span.label.support {background-color: #00C471; border: none;}
.courseWrap .detail_top .des p { word-break: keep-all; }
.courseWrap .detail_top .des .des1 { color:#fff; font-weight: 700; font-size: 3.6rem; margin-bottom: 1rem; line-height: 1.4;}
.courseWrap .detail_top .des .des2 { font-weight: 400; color: #D3D3D3; font-size: 1.9rem; margin-bottom: 1rem; }
.courseWrap .detail_top .card_labels { display: flex; align-items: center; gap: 1rem; }
.courseWrap .detail_top .card_labels span { color: hsl(0, 0%, 100%, .8); font-size: 1.3rem; line-height: 1; padding: 0.6rem 0.6rem; border-radius: 0.4rem; background: hsl(0, 0%, 0%, .3); }

.courseWrap + #contentWrap {padding-top: 1.5rem;}
.detailWrap {max-width: 81rem; width: 100%;}
.course-detail {padding-top:7rem;}
#course-info.course-detail {padding-top:0rem;}

/* 강의소개 */
/* .course_info_box1 { text-align: center; padding: 30px; color: #fff; font-size: 16px; background-color: #16151C; border-radius: 10px; margin-bottom: 25px;}
.course_info_box1 .point {color:#8DFFA0; font-weight: 600; font-size: 20px; margin-bottom: 8px;}
.course_info_box2 {margin-bottom: 25px;}
.course_info_box2 img {border: 1px solid #E5E5EA; border-radius: 10px;}
.course_info_title {font-size: 22px; color: #333; font-weight: 700; margin-bottom: 15px; margin-top: 40px;}
.small_title {font-size: 20px; color: #333; font-weight: 700; margin-bottom: 15px; }
.box_area_half {display: flex; flex-wrap: wrap; gap: 16px;}
.box_area_half .txt_box {width: calc(50% -  8px); text-align: center; font-weight: 500; padding: 25px 10px; border: 1px solid #DEE2E6; border-radius: 8px;}
.box_area_full {padding: 25px 30px; background-color: #F6F6F8; border: 1px solid #DEE2E6; border-radius: 8px;}
.box_area_full p + p {margin-top: 10px;}
.box_area_full .icon_mr5 {margin-right: 5px;}
.course_info_desc {line-height: 28px; letter-spacing: 0; margin-bottom: 40px;}
.point_color {color:#3F79EE;}
.full_img {text-align: center;} */


/* 커리큘럼 아코디언 */
/* .curri_list { border: 1px solid #DEE2E6; margin: 15px 0; border-radius: 8px;}
.curri_list li .title-wrap { display: block; background-color: #F8F9FA; position: relative; border-radius: 8px; padding: 18px 25px; }
.curri_list li .title-wrap .title { color: #333; font-weight: 600; font-size: 17px; }
.curri_list li .title-wrap .title img { margin-left: 5px;}
.curri_list li .title-wrap .arrow { color: #333; position: absolute; top: 16px; right: 20px; font-size: 18px; padding: 6px; transition: all .25s ease; }
.curri_list li > .cont { opacity: 0; visibility: hidden; max-height: 0; overflow: hidden; padding: 0 30px; }
.curri_list li.active .title-wrap {border-radius: 8px 8px 0 0; border-bottom: 1px solid #DEE2E6;}
.curri_list li.active .cont { opacity: 1; visibility: visible; max-height: 2000px; padding:12px 30px; transition: all .3s ease; }
.curri_list li.active .arrow { transform: rotate(180deg); }
.curri_list .total_section_info {display: flex; align-items: center; gap: 25px; padding: 8px 0; }
.curri_list .total_section_info .total_section {display: flex; align-items: center; }
.curri_list .total_section_info .total_time {display: flex; align-items: center; }
.curri_list .total_section_info .total_section img {margin-right: 5px;}
.curri_list .total_section_info .total_time img {margin-right: 5px;} 
.curri_list .total_section_info a { margin-left: auto; text-align: center; padding: 5px 12px; display: block; font-size: 14px; border: 1px solid #E8E8E8; border-radius: 100em; transition: 0.2s; }
.curri_list .total_section_info a:hover { color: #2466EB; border-color: #2466EB; }
.curri_list .timeline {display: flex; padding: 13px 0; border-top: 1px solid #E9EBF2; font-weight: 500; letter-spacing: 0;}
.curri_list .timeline .stitle {font-size: 15px; display: flex; align-items: center; }
.curri_list .timeline .stitle::before { display: inline-block; content: ''; width: 4px; height: 4px; background-color: #D9D9D9; border-radius: 50%; margin-right: 10px; }
.curri_list .timeline .time {color: #80848A; font-size: 14px; margin-left: auto;}

.curri_list li .title-wrap-live { display: flex; background-color: #F8F9FA; position: relative; border-radius: 8px; padding: 18px 25px; }
.curri_list li .title-wrap-live .title { color: #333; font-weight: 600; font-size: 17px; }
.curri_list li .title-wrap-live .title img { margin-left: 5px;}
.curri_list li .title-wrap-live .live_date { color: #333; font-weight: 600; font-size: 15px; margin-left: auto; } */


/* 과정상세 강사소개  */
.tutor_box { display: flex; gap: 4rem;  align-items: center; background-color: #fff; border-radius: 2.5rem; padding: 3.5rem; box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1); }
.tutor_box .photo { width: 14.8rem; height: 14.8rem; }
.tutor_box .photo img { border-radius: 100%; }
.tutor_box .tutor_info {display: flex; flex-direction: column; gap: 1.5rem;}
.tutor_box .tutor_info .name {font-size: 2.2rem; font-weight: 600; color: var(--text-basic);}
.tutor_box .tutor_info .txt {color: var(--text-color6); display: flex; flex-direction: column;} 

/* 과정상세 후기  */
#course-review h5 {display: flex; align-items: center; }
.total_review {margin-left: auto; font-size: 1.6rem; color: var(--text-color6); font-weight: 400;}
.total_review .score {font-weight: 700; color: #333;}
.total_review strong {font-weight: 600; color: #333;}
.review_list {}
.review_list dl:first-child {border-top:1px solid #E9EBF2; }
.review_list dl {padding: 3rem 0rem; border-bottom:1px solid #E9EBF2; box-sizing:border-box;}
.review_list dl dt {display:flex; flex-direction: column; gap: .5rem; margin-bottom: 1.5rem;}
.review_list dl dt .name {color: var(--text-color2); font-weight: 600;} 
.review_list dl dt .date {color: var(--text-color6); font-weight: 300; font-size: 1.5rem; letter-spacing: 0;}
.review_list .review_user {display: flex; gap: 1.5rem;}
.review_list .review_star {display: flex; gap: 1rem;}
.review_list .review_star i {margin-left: -2px;}
.review_list dl dt .score {font-weight: 700; font-size: 1.7rem;}
.review_list dl dd .stxt {letter-spacing: -0.04rem; color:rgba(34,34,34,0.7);}
.review_list .more {display: flex; font-weight: 600; color: #333; padding: 1.2rem; justify-content:center; border: 1px solid #E5E5EA; border-radius: 8px; margin-top: 2rem; transition: .2s;}
.review_list .more:hover {background-color: #f3f3f3; }

/* 과정상세 FAQ  */
#course-FAQ .listFaq {border: none;}
#course-FAQ .listFaq::after {display: none;}
#course-FAQ .listFaq ul li { margin: 10px 0; border-bottom: none;}
#course-FAQ .listFaq ul li a {border: 1px solid #DEE2E6; border-radius: 8px;}
#course-FAQ .listFaq ul li .category {color: var(--primary); font-weight: 700; font-size: 1.9rem; background: none;}
#course-FAQ .listFaq ul li .question {padding: 1.5rem 4rem 1.5rem 6rem;}
#course-FAQ .listFaq ul li .question .title {font-weight: 600;}
#course-FAQ .listFaq ul li .answer {border-top: none; background-color: #fff; }
#course-FAQ .listFaq ul li .answer .answer_box {padding-left: 6rem; font-size: 1.5rem; line-height: 1.8; border-radius:0 0 8px 8px ; border: 1px solid #DEE2E6; border-top: none; color: var(--text-color6); transition: all .3s ease; }
#course-FAQ .listFaq ul li .answer::before {display: none;}
#course-FAQ .listFaq ul li.active a {border-radius: 8px 8px 0 0;}
#course-FAQ .listFaq ul li .question::after {content:"\e941"; font-size: 18px; top: 1.5rem;}

/* 과정상세 오른쪽  */
aside.right_con { gap: 1rem; width: 39rem; min-width: 39rem; height: 100%; position: sticky; top: 190px; margin-top: -160px;  z-index: 10; transform: translateY(-100px);}
aside.right_con .card_item { display: flex ; flex-direction: column; justify-content: flex-start; border-radius: 16px; box-shadow: rgba(0, 0, 0, 0.08) 0px 8px 24px 0px, rgba(0, 0, 0, 0.12) 0px 0px 4px 0px; }
aside.right_con .card_item .image_area {}
aside.right_con .card_item .image_area .img_area { position: relative; display: block; padding-top: 54%; overflow: hidden; border-radius: 16px 16px 0 0; background-color: #333; background-image: url(../img/common/logo_gray.svg); background-size: 50%; background-repeat: no-repeat; background-position: center; }
aside.right_con .card_item .image_area .img_area img { position: absolute; display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; top: 0; left: 0; border-radius: 1rem 1rem 0 0; }
aside.right_con .card_item .card_con {background-color: #fff; padding: 2rem 3rem; border-radius:0 0 16px 16px; }
aside.right_con .card_item .price { display: flex; flex-direction: column; font-weight: 500; font-size: 1.4rem; margin-bottom: 1rem; }
aside.right_con .card_item .price .price_end {display: flex; gap: 1rem; font-size: 2rem; font-weight: 600;}
aside.right_con .card_item .price p.txt01 { color: #DC065B; }
aside.right_con .card_item .price p.txt02 { color: #19181B; }
aside.right_con .card_item .price p.txt03 { font-size: 1.2rem; color: #9DA7AE; text-decoration: line-through;}
aside.right_con .card_item .btn ~ .btn { margin-left: 0rem; }
aside.right_con .card_item .btn_half {display: flex; gap: 1rem; margin-bottom: 1rem;}
aside.right_con .card_item .btn_half a {width: 50%; display: flex; align-items: center; gap: 1rem; line-height: 1.4; font-weight: 600; font-size: 1.4rem; padding: 1.4rem 1.2rem 1.4rem 2.2rem; border-radius: 8px; transition: 0.2s;}
aside.right_con .card_item .btn_half a i {font-size: 2.2rem;}
aside.right_con .card_item .btn_half a.active {color: var(--primary); border-color:var(--primary); background-color: #F3F8FF;}
aside.right_con .card_item .btn_half em {font-style: normal;}
aside.right_con .card_item .btn_full {display: flex; flex-direction: column; gap: 1rem;}
aside.right_con .card_item .btn_full a {padding: 1.4rem; font-weight: 500; text-align: center; border: 1px solid #E5E5EA; border-radius: 8px; transition: 0.2s;}
aside.right_con .card_item .btn_full a:hover {background-color: #F5F5F5;}
aside.right_con .card_item .btn_full a.bgcolor {color: #fff; background-color:var(--lightPrimary); border-color: var(--lightPrimary); }
aside.right_con .card_item .btn_full a.bgcolor:hover {background-color:var(--darkPrimary);}
aside.right_con .card_item .btn_full a.btn.gray2:hover { background: #343434; color: #fff; border: 1px solid #343434; }
aside.right_con .card_item .btn_full span {margin-right: 5px;}
aside.right_con .card_item .info_box {padding: 1.6rem 2rem; background-color: hsl(205, 29%, 92%, .4); border-radius: 8px; margin-top: 1rem;}
aside.right_con .card_item .info_box .title {display: flex; align-items: center; gap: .5rem; font-weight: 700; font-size: 1.5rem;}
aside.right_con .card_item .info_box .title i {font-size: 2rem;}
aside.right_con .card_item .info_box ul { display: flex; flex-direction: column; margin-top: .5rem; }
aside.right_con .card_item .info_box ul li { display: flex; margin-top: .25rem; font-weight: 500; font-size: 1.4rem; }
aside.right_con .card_item .info_box ul li span { width: 6rem; font-weight: 400; flex: 0 0 auto; margin-right: 1.5rem; color: #80848A; }
aside.right_con .card_item .countdown { display: flex; align-items: center; color: #fff; border-radius: .8rem; padding: 1.5rem 2rem; gap: 1rem; margin-bottom: 1rem; background-color: var(--darkPrimary); }
aside.right_con .card_item .countdown strong { font-weight: 700; }
aside.right_con .card_item .countdown em {font-style: normal;}
aside.right_con .card_item .countdown .time_area {display: flex; align-items: center; gap: .6rem;}
aside.right_con .card_item .countdown i { font-size: 2rem; }
aside.right_con .card_item .countdown .time { padding: 0.3rem .7rem 0.2rem .7rem; color: #E84646; font-size: 1.6rem; font-weight: 700; border-radius: 0.5rem; background-color: #fff; }


/* 과정상세 하단 플로팅 */
.bottom_floating {display: none;}
.bottom_floating { position: fixed; z-index: 24; max-width: 84rem; width: 100%; left: 50%; transform: translateX(-50%); bottom: 18px; max-height: min(530px, -134px + 100dvh); }
.bottom_floating .countdown { position: relative; }
.bottom_floating .countdown { display: flex; align-items: center; color: #fff; border-radius: 2rem; padding: 2rem 3.2rem; gap: 1rem; background-color: var(--darkPrimary); box-shadow: rgba(0, 0, 0, 0.25) 0px 20px 24px 0px; backdrop-filter: blur(8px); }
.bottom_floating .countdown strong { font-weight: 700; }
.bottom_floating .countdown em {font-style: normal;}
.bottom_floating .countdown .info { margin-right: 2rem; }
.bottom_floating .countdown .time_area {display: flex; align-items: center; gap: .6rem;}
.bottom_floating .countdown i { font-size: 2rem; }
.bottom_floating .countdown .time { padding: 0.3rem .7rem 0.2rem .7rem; color: #E84646; font-size: 1.6rem; font-weight: 700; border-radius: 0.5rem; background-color: #fff; }
.bottom_floating .countdown .right_btn {margin-left: auto;}
.bottom_floating .countdown .right_btn a {color: #fff; font-size: 1.5rem; padding: 0.7rem 1.5rem; border-radius: 0.5rem; background-color: #E84646; box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.1); transition: 0.2s;}
.bottom_floating .countdown .right_btn a:hover {background-color: #ca3737; }

/* 과정상세 하단 메세지 */
.bottom_message.typeA { position: fixed; z-index: 24; max-width: 54rem; width: 100%; left: 50%; transform: translateX(-50%); bottom: 18px; max-height: min(530px, -134px + 100dvh); z-index: 400; }
.bottom_message.typeA .bottom_txt { display: flex; justify-content: center; font-weight: 600; color: #fff; border-radius: 2rem; padding: 2rem 3rem; gap: 1rem; background-color: rgb(0, 0, 0, .7 ); box-shadow: rgba(0, 0, 0, 0.25) 0px 20px 24px 0px; backdrop-filter: blur(8px); }
.bottom_message.typeA .bottom_txt .info {display: flex; justify-content: center; align-items: center; gap: 1rem;}
.bottom_message.typeA .bottom_txt i.xi-check-circle-o { font-size: 2rem; line-height: 1; color: #00C471;}
.bottom_message.typeA .bottom_txt .right_btn {margin-left: auto; display: flex; gap: 1.5rem; align-items: center;}
.bottom_message.typeA .bottom_txt .right_btn a {color: #fff; font-size: 1.5rem; padding: 0.5rem 1.5rem; border-radius: 0.5rem; background-color: #00C471; box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.1); transition: 0.2s;}
.bottom_message.typeA .bottom_txt .right_btn a:hover {background-color: #00C471; }
.bottom_message.typeA .bottom_txt .right_btn a.close_btn {padding: 0; background: none;}

@media (max-width:1280px) {
	.courseWrap .detail_top {width: calc(100% - 3rem - 39rem);}
	.detailWrap {width: calc(100% - 3rem); }
}
@media (max-width:1200px) {
	.courseWrap .detail_top {width: calc(100% - 3rem - 28rem);}
	aside.right_con { width: 28rem; min-width: 28rem; }
	aside.right_con .card_item .card_con { padding: 2rem 2rem; }
	aside.right_con .card_item .btn_half { flex-direction: column; gap: .6rem; }
	aside.right_con .card_item .btn_half a { width: 100%; padding: 1.2rem 1.2rem 1.2rem 2.2rem; }
	aside.right_con .card_item .btn_half a br { display: none; }
	aside.right_con .card_item .btn_full a { padding: 1.2rem; }
	aside.right_con .card_item .btn_full { gap: .6rem; }
	aside.right_con .card_item .info_box ul li { font-size: 1.3rem; }
	aside.right_con .card_item .info_box ul li span { width: 4.4rem; }
	aside.right_con .card_item .countdown {flex-direction: column; align-items: flex-start; gap: .5rem; font-size: 1.5rem; padding: 1.2rem 2rem 1.5rem 2rem;}
	aside.right_con .card_item .countdown .info {font-size: 1.4rem;}
}

@media (max-width:1024px) {	
	.bottom_floating {max-width:100%; bottom: 0;}
	.bottom_floating .countdown {border-radius: 0; padding: 2rem 2.2rem;}
	.bottom_floating .countdown .right_btn a { padding: 0.7rem 2.5rem;}
}

@media (max-width:850px) {
	.courseWrap .detail_top {width: 100%; max-width: 100%; flex-direction: column; gap: 1rem; padding: 3rem 0 2rem 0;}
	.courseWrap .detail_top .mobile_image {display: block;}
	.courseWrap .detail_top .mobile_image .image_area {max-width: 35rem; margin: 0 auto;} 
	.courseWrap .detail_top .mobile_image .image_area img {border-radius: 10px;}
	.courseWrap .detail_top .des {padding: 1.5rem .5rem 1.5rem .5rem;}
	.courseWrap .detail_top .des .des1 {font-size: 3rem;}
	.courseWrap .detail_top .des .des2 {font-size: 1.6rem;}
	.courseWrap .detail_top .cate_label span {font-size: 1.5rem;}
	.detailWrap {width: 100%; max-width: 100%;}
	aside.right_con { position: fixed; top: auto; left: 0; bottom: 0; margin-top: 0; transform: none; width: 100%; min-width: 100%; height: auto; }
	aside.right_con .card_item { flex-direction: row; gap: 2rem; background-color: #fff; padding: 1.5rem 1.5rem; border-radius: 0; border-top: 1px solid #DEE2E6; }
	aside.right_con .card_item .card_con { display: flex; padding: 0rem; width: 100%; gap: .6rem; }
	aside.right_con .card_item .price { margin-bottom: 0; }
	aside.right_con .card_item .btn_half { flex-direction: row; gap: .6rem; margin-left: auto; margin-bottom: 0; }
	aside.right_con .card_item .btn_half a { width: 50%; min-width: 88px; justify-content: center; border-radius: 5px; line-height: 1.1; text-align: center; padding: .2rem .2rem .2rem .2rem; }
	aside.right_con .card_item .btn_half a br { display: block; }
	aside.right_con .card_item .btn_half a i { display: none; }
	aside.right_con .card_item .image_area { display: none ; }
	aside.right_con .card_item .info_box { display: none; }
	aside.right_con .card_item .btn_full { flex-direction: row; }
	aside.right_con .card_item .btn_full a { padding: .4rem .6rem; display: flex; align-items: center; border-radius: 5px; }
	.bottom_floating .countdown { height: 62px; padding: 2rem 1.5rem; }
	.bottom_message.typeA { max-width: 90%; bottom: 135px;}
	.bottom_message.typeA .bottom_txt {padding: 1.2rem 2rem;}
	#course-info.course-detail {padding-top: 0;}
	aside.right_con .card_item .countdown { position: fixed; border-radius: 0; left: 0; bottom: 60px; min-width: 100%; width: 100%; flex-direction: row; align-items: center; justify-content: center; }
	
}

@media (max-width:580px) {
	.bottom_floating .countdown .info {margin-right: 0;}
	.bottom_floating .countdown em {display: none;}
	.bottom_floating .countdown .time_area .txt {display: none;}
	aside.right_con .card_item .btn_full a {min-width: 40px; justify-content: center; line-height: 1.2;}
	aside.right_con .card_item .btn_full span {display: none; }
	aside.right_con .card_item .btn_half a {width: auto; min-width: 60px;}
	aside.right_con .card_item .btn_half em {display: none;}	
}

@media (max-width:480px) {
	.courseWrap .detail_top .des .des1 {font-size: 2.6rem;}
	.bottom_floating .countdown .info { width: 58%; }
	.bottom_floating .countdown .time_area { gap: 0; width: 95px; border-radius: 0.5rem; background-color: #fff; }
	.bottom_floating .countdown .time { line-height: 1.2; font-size: 1.5rem; min-width: 34px; }
	.bottom_floating .countdown .time + .time { margin-left: -4px; }
	.bottom_floating .countdown .right_btn a { padding: .9rem; display: block; width: 62px; }
	aside.right_con .card_item { padding: 1rem 1.5rem 1.5rem 1.5rem; }
	aside.right_con .card_item .card_con { display: block; width: calc(100% - 5px ); }
	aside.right_con .card_item .price { width: 100%; display: block; }
	aside.right_con .card_item .price p.txt03 { display: none; }
	aside.right_con .card_item .btn_half { margin-bottom: 6px; }
	aside.right_con .card_item .btn_half a { width: 50%; min-width: 50%; padding: .7rem .2rem .7rem .2rem; }
	aside.right_con .card_item .btn_full a { width: 50%; min-width: 50%; }
	.tutor_box { gap: 2rem;   padding: 2.5rem 2rem 2.5rem 2.5rem;}
	.tutor_box .photo {width: 12rem; height: 12rem;}
	.tutor_box .tutor_info .txt {font-size: 1.5rem; word-break: keep-all;}
	.bottom_message.typeA { max-width: 95%;}
	.bottom_message.typeA .bottom_txt .info {line-height: 1.4; font-size: 1.5rem;}
	.bottom_message.typeA .bottom_txt .right_btn {gap: 1rem;}
	.bottom_message.typeA .bottom_txt .right_btn a { font-size: 1.4rem; padding: 0.5rem 1rem; }
	aside.right_con .card_item .countdown {bottom:95px ; padding: 1rem 2rem;}
}