@charset "utf-8";
/*@import "../../_css/sub_layout.css"; */
@import "contents.css";
/*@import "../../_css/board.css"; */
@import "board.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);
	--sab: env(safe-area-inset-bottom, 0px);
}
/* 서브 레이아웃 */
body {
	height: 100%;
}
#wrap {
	/* display: flex; 
flex-direction: column; 
height: 100%; */
}
.footer {
	margin-top: auto;
}
.subMenu .content .tabs li {
	background: var(--darkblue, hsl(208, 100%, 34%));
}
.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;
	}
}
/* 상태 라벨 추가_221222 */
.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;
	/* 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, #4372E7 15%, #1553CE 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;
	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, rgba(245, 171, 225, 1) 0%, rgba(239, 105, 217, 1) 100%);
}
.my_prog_rate .progress .bar.rainbow_type {
	background: linear-gradient(90deg, rgb(218, 70, 37) 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: #edfaff;
}
.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: var(--lightblue);
	border-color: var(--lightblue);
	border-radius: 8px;
	transition: 0.2s;
}
.cart_price .btn_full a:hover {
	background-color: var(--darkblue);
}
.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: #F3F8FF;
}
.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, #262D8C 15%, #1F2662 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: 2rem;
}
/* 강의소개 */
/* .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(--lightblue);
	border-color: var(--lightblue);
}
aside.right_con .card_item .btn_full a.bgcolor:hover {
	background-color: var(--darkblue);
}
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(--darkblue);
}
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: calc(100vh - 134px); /* dvh 미지원 브라우저 fallback */
	max-height: min(530px, calc(100vh - 134px)); /* dvh 미지원 브라우저 fallback */
	max-height: min(530px, -134px + 100dvh); /* Chrome 108+, Safari 15.4+ */
}
.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(--darkblue);
	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;
		padding-bottom: constant(safe-area-inset-bottom, 0px); /* 구 iOS 11 */
		padding-bottom: env(safe-area-inset-bottom, 0px);       /* Chrome/Safari 최신 */
	}
	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; /* JS(adjustCountdownBottom)가 동적으로 덮어씀 */
		min-width: 100%;
		width: 100%;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		padding-bottom: constant(safe-area-inset-bottom, 0px); /* 구 iOS 11 */
		padding-bottom: env(safe-area-inset-bottom, 0px);       /* Chrome/Safari 최신 */
	}
}
@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;
	}
}
/* =============================================
인사말
=============================================== */
.greetings-wrap {
	position: relative;
	vertical-align: bottom;
}
.greetings-wrap img {
	width: 100%;
}
.greetings-wrap .frame {
	display: flex;
	justify-content: space-between;
}
.greetings-wrap .left {
	position: relative;
	display: block;
	width: 35%;
	padding-top: 6.8rem;
	z-index: 1;
}
.greetings-wrap .right {
	position: relative;
	width: calc(100% - 35% - 6rem);
	margin-left: 6rem;
}
.greetings-wrap .img-box img {
	border-radius: 15px 15px 15px 35px;
}
.greetings-wrap .greeting {
	position: relative;
	padding: 6.5rem 0 5.5rem 0;
}
.greetings-wrap .greeting::before {
	position: absolute;
	width: calc(100% + 33.5rem);
	height: 100%;
	background: #f3f5f9 url(../img/common/logo-emblem-gray.svg) right 3rem bottom -1.6rem no-repeat;
	background-size: 30%;
	border-radius: 1rem;
	content: '';
	right: 0;
	top: 0;
}
.greetings-wrap .greeting.txt em {
	position: relative;
	display: block;
	margin-bottom: .6rem;
	font-size: 2rem;
	color: #222;
}
.greetings-wrap .greeting.txt strong {
	position: relative;
	display: block;
	font-size: 2.4rem;
	color: #1d1d1d;
	line-height: 3.5rem;
}
.greetings-wrap .greeting.txt strong span {
	color: var(--primary);
}
.greetings-wrap .text-box {
	position: relative;
	padding-top: 5.5rem;
	font-size: 1.8rem;
	line-height: 2.8rem;
}
.greetings-wrap .text-box i {
	display: block;
	margin: 2.8rem 0;
}
.greetings-wrap .sign {
	display: flex;
	margin-top: 4.5rem;
	font-size: 2rem;
}
.greetings-wrap .sign em {
	display: inline-block;
	margin-left: 2rem;
	font-size: 3.4rem;
	color: #1D1D1D;
	line-height: 2.8rem;
}
@media screen and (max-width:1280px) {
	.greetings-wrap .greeting {
		padding: 5.5rem 0 4.5rem 0;
	}
	.greetings-wrap .right {
		width: calc(100% - 35% - 5rem);
		margin-left: 5rem;
	}
	.greetings-wrap .text-box {
		padding-top: 4rem;
	}
}
@media screen and (max-width:1024px) {
	.greetings-wrap .frame {
		flex-direction: column;
	}
	.greetings-wrap .left {
		width: 40%;
		margin: 0 auto;
		text-align: center;
		padding-top: 0;
	}
	.greetings-wrap .right {
		width: 100%;
		margin: 0;
	}
	.greetings-wrap .greeting {
		padding: 8rem 0 3rem 0rem;
		margin: -4rem 0rem 0 0rem;
	}
	.greetings-wrap .text-box {
		padding: 2rem 0 4rem 4rem;
		font-size: 1.7rem;
	}
	.greetings-wrap .greeting {
		padding: 5.5rem 0 5.5rem 4rem;
	}
	.greetings-wrap .greeting::before {
		width: 100%;
		top: -2rem
	}
	.greetings-wrap .greeting.txt em {
		margin-bottom: 0;
		margin-top: 1rem;
	}
}
@media screen and (max-width:768px) {
	.greetings-wrap .greeting {
		padding: 5.5rem 0 4.5rem 3rem;
	}
	.greetings-wrap .greeting::before {
		background-position: right 3rem bottom -1rem;
	}
	.greetings-wrap .greeting.txt em {
		font-size: 1.8rem;
	}
	.greetings-wrap .greeting.txt strong span {
		font-size: 2.6rem;
	}
	.greetings-wrap .text-box {
		padding: 2rem 0 4rem 2rem;
	}
}
@media screen and (max-width:590px) {
	.greetings-wrap .greeting.txt em {
		font-size: 1.7rem;
	}
	.greetings-wrap .greeting::before {
		background-image: none;
	}
	.greetings-wrap .greeting.txt strong {
		margin-bottom: 0;
	}
	.greetings-wrap .text-box {
		font-size: 1.6rem;
		padding: 2rem 2rem 4rem 2rem;
		word-break: keep-all;
	}
	.greetings-wrap .text-box span br {
		display: none;
	}
}
@media screen and (max-width:480px) {
	.greetings-wrap .left {
		width: 80%;
	}
	.greetings-wrap .greeting {
		padding: 5.5rem 3rem 4.5rem 3rem;
		word-break: keep-all;
	}
	.greetings-wrap .greeting.txt em {
		font-size: 1.6rem;
		margin-bottom: 1rem;
	}
	.greetings-wrap .greeting.txt strong,
	.greetings-wrap .greeting.txt strong span {
		font-size: 2.4rem;
		line-height: 2.8rem;
	}
	.greetings-wrap .text-box {
		font-size: 1.5rem;
		line-height: 1.5;
		padding-top: 2rem;
	}
	.greetings-wrap .sign {
		font-size: 1.8rem;
	}
	.greetings-wrap .sign em {
		font-size: 2.8rem;
	}
}
/* =============================================
history
=============================================== */
.history_page .history {
	margin-top: 7rem;
	margin-bottom: 3rem;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.history_page .history .left {
	position: sticky;
	top: 10rem;
	width: 50rem;
	margin-right: 10rem;
	padding-bottom: 45rem;
	background: url(../img/contents/history_img.png) left bottom no-repeat;
	background-size: contain;
}
.history_page .history .left p {
	font-size: 5.4rem;
	font-weight: 700;
	line-height: 1.2;
}
.history_page .history .left p span {
	font-size: 3.6rem;
}
.history_page .history .left p span.year {
	font-size: 5rem;
}
.history_page .history .info {
	position: relative;
	width: 100%;
}
.history_page .history .info .line {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	height: 99% !important;
	background-color: #e0e0e0;
}
.history_page .history .info .line .bg {
	position: absolute;
	left: 50%;
	top: 0;
	width: 2px;
	height: 0%;
	transform: translateX(-50%);
	background-color: var(--primary);
	max-height: 100%;
}
.history_page .history .info li {
	position: relative;
	display: flex;
	align-items: flex-start;
	line-height: 1.5em;
}
.history_page .history .info li:last-child:before {
	content: "";
	position: absolute;
	width: 12px;
	height: 100%;
	left: 0%;
	top: 1rem;
	transform: translateX(-50%);
	background-color: #fff;
}
.history_page .history .info li+li {
	margin-top: 8rem;
}
.history_page .history .info li .num {
	font-size: 3.4rem;
	font-weight: 700;
	position: relative;
	padding-left: 10rem;
	z-index: 3;
}
.history_page .history .info li .num:before {
	content: "";
	position: absolute;
	left: 0.5px;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: #BDBDBD;
}
.history_page .history .info li .txt {
	margin-left: 3.8rem;
}
.history_page .history .info li .txt p {
	position: relative;
	font-weight: 400;
	padding-left: 1.2rem;
}
.history_page .history .info li .txt p::before {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #c6c7cb;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 1rem;
}
.history_page .history .info li .txt p+p {
	margin-top: 1.2rem;
}
.history_page .history .info li:nth-child(1) .num:before,
.history_page .history .info li.active .num:before {
	background-color: var(--primary);
	box-shadow: 0 0 0px 8px var(--blue-alpha20);
}
@media (max-width:1280px) {
	.history_page .history .left {
		width: 40rem;
		margin-right: 8rem;
	}
	.history_page .history .left p span.year {
		font-size: 4.4rem;
	}
	.history_page .history .info li .num {
		padding-left: 7rem;
	}
}
@media (max-width:1023.98px) {
	.history_page .history {
		margin-top: 5rem;
	}
	.history_page .history .left {
		display: none;
	}
	.history_page .history .info {
		margin-left: 3rem;
	}
	.history_page .history .info li+li {
		margin-top: 6rem;
	}
}
@media (max-width:767.98px) {
	.history_page .history {
		margin-top: 3rem;
	}
	.history_page .history .info {
		margin-left: 2rem;
	}
	.history_page .history .info li .num {
		padding-left: 3.5rem;
		font-size: 2.6rem;
	}
	.history_page .history .info li .txt {
		margin-left: 2.5rem;
	}
}
@media (max-width:480px) {
	.history_page .history .info {
		margin-left: 1rem;
	}
	.history_page .history .info li .num {
		padding-left: 2rem;
		font-size: 2.2rem;
	}
	.history_page .history .info li .num:before {
		width: 8px;
		height: 8px;
	}
	.history_page .history .info li .txt {
		margin-left: 1.5rem;
	}
	.history_page .history .info li+li {
		margin-top: 4rem;
	}
	.history_page .history .info li:nth-child(1) .num:before,
	.history_page .history .info li.active .num:before {
		box-shadow: 0 0 0px 6px rgb(192, 185, 244, 0.5);
	}
}
/* =============================================
조직도
=============================================== */
.org-chart {
	font-size: 1.6rem;
	padding: 6rem 0;
	width: 100%;
}
.oc-tree {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
}
.oc-box {
	background-color: #f1f2f5;
	border: 1px solid #d0d1d6;
	padding: 1.5rem 2rem;
	text-align: center;
	color: #333;
	min-width: 18rem;
	position: relative;
	z-index: 2;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	min-height: 5.6rem;
	box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.03);
	word-break: keep-all;
	line-height: 1.3;
	border-radius: .4rem;
}
.oc-box.cap {
	background-color: var(--darkblue);
	color: #fff;
	font-size: 1.8rem;
}
.oc-node.center {
	position: relative;
	padding-bottom: 3rem;
}
.oc-node.center::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: 3rem;
	background-color: #dcdcdc;
	z-index: 1;
}
.oc-middle {
	display: flex;
	width: 100%;
	max-width: 80rem;
	position: relative;
	padding: 3rem 0;
}
.oc-center-line {
	position: absolute;
	top: 0;
	bottom: 0px;
	left: 50%;
	width: 1px;
	background-color: #dcdcdc;
	transform: translateX(-50%);
	z-index: 1;
}
.oc-side-left, .oc-side-right {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
}
.oc-side-left {
	align-items: flex-end;
	padding-right: 5rem;
	gap: 2rem;
}
.oc-side-right {
	align-items: flex-start;
	padding-left: 5rem;
}
.oc-branch {
	position: relative;
}
.oc-side-left .oc-branch::after {
	content: '';
	position: absolute;
	top: 50%;
	right: -5rem;
	width: 5rem;
	height: 1px;
	background-color: #dcdcdc;
	z-index: 1;
}
.oc-side-right .oc-branch::after {
	content: '';
	position: absolute;
	top: 50%;
	left: -5rem;
	width: 5rem;
	height: 1px;
	background-color: #dcdcdc;
	z-index: 1;
}
.oc-bottom {
	position: relative;
	width: 100%;
}
.oc-dot-center {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 1.2rem;
	height: 1.2rem;
	border: 2px solid var(--blue);
	border-radius: 50%;
	background-color: #fff;
	z-index: 10;
}
.oc-leaves {
	display: flex;
	justify-content: space-between;
	width: 100%;
	padding-top: 0;
	margin: 0;
}
.oc-leaves>li {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0 2px;
}
.oc-leaves>li::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #dcdcdc;
	z-index: 1;
}
.oc-leaves>li:first-child::after {
	left: 50%;
	width: 50%;
}
.oc-leaves>li:last-child::after {
	left: 0;
	width: 50%;
}
.oc-leaves>li::before {
	content: '';
	position: absolute;
	top: 0px;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: 3rem;
	background-color: #dcdcdc;
	z-index: 1;
}
.oc-leaf-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	z-index: 2;
	position: relative;
	width: 100%;
	padding-top: 2.7rem;
}
.oc-dot {
	width: 0.8rem;
	height: 0.8rem;
	background-color: var(--blue);
	border-radius: 50%;
	margin-bottom: 0.8rem;
}
.oc-leaves .oc-box.white {
	background-color: #fff;
	min-width: unset;
	width: 100%;
	font-size: 1.5rem;
	padding: 1.5rem 0.5rem;
	min-height: 8rem;
}
@media (max-width: 1024px) {
	.oc-bottom {
		padding-top: 2rem;
	}
	.oc-leaves>li::before, .oc-leaves>li::after {
		display: none;
	}
	.oc-dot-center {
		display: none;
	}
	.oc-bottom::before {
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: 1px;
		background-color: #dcdcdc;
		z-index: 0;
	}
	.oc-leaves {
		flex-direction: column;
		align-items: center;
		gap: 2rem;
		padding-top: 3rem;
	}
	.oc-leaves>li {
		width: 100%;
		max-width: 32rem;
		flex: unset;
		padding: 0;
	}
	.oc-leaf-content {
		flex-direction: row;
		padding-top: 0;
		background: #fff;
		border: 1px solid #dcdcdc;
		border-radius: 0.5rem;
		padding: 1rem 2rem;
		gap: 1.5rem;
	}
	.oc-leaf-content .oc-dot {
		margin-bottom: 0;
	}
	.oc-leaves .oc-box.white {
		border: none;
		box-shadow: none;
		padding: 0;
		min-height: unset;
		text-align: left;
		justify-content: flex-start;
	}
}
@media (max-width: 768px) {
	.oc-middle {
		flex-direction: column;
		padding: 0;
		gap: 3rem;
	}
	.oc-side-left, .oc-side-right {
		padding: 0;
		gap: 3rem;
		align-items: center;
	}
	.oc-side-left .oc-branch::after,
	.oc-side-right .oc-branch::after {
		display: none;
	}
	.oc-leaves {
		padding-top: 0;
	}
	.oc-bottom::before {
		top: -3rem;
	}
}
/* .oc-leaves .oc-box.white br {
	display: none;
}
@media (min-width: 1025px) {
	.oc-leaves .oc-box.white br {
		display: block;
	}
} */
/* .oc-leaves>li:nth-child(n+3) .oc-box.white br {
	display: none;
} */
/* =============================================
KDT 안내 (course_info_tab01)
=============================================== */
.kdt_info_wrap {
	padding: 2rem 0;
}
.kdt_sec {
	margin-bottom: 4rem;
}
.kdt_sec .kdt_tit {
	font-size: 2.2rem;
	font-weight: 700;
	color: #222;
	margin-bottom: 1rem;
}
.kdt_sec .kdt_txt {
	font-size: 1.6rem;
	color: #444;
	line-height: 1.6;
	margin-bottom: 1rem;
	word-break: keep-all;
}
.kdt_note {
	font-size: 1.5rem;
	color: #666;
	line-height: 1.5;
	margin-top: 1rem;
	word-break: keep-all;
}
.kdt_list_num {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.kdt_list_num>li {
	display: flex;
	align-items: baseline;
	gap: 1rem;
	font-size: 1.7rem;
	line-height: 1.6;
	color: #444;
}
.kdt_list_num>li .num {
	font-weight: normal;
	color: #222;
	font-size: 1.8rem;
	line-height: 1.8rem;
	min-width: 1.4rem;
}
.kdt_list_gap {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.kdt_list_gap>li {
	display: flex;
	align-items: baseline;
	gap: 0.4rem;
}
.kdt_table {
	width: 100%;
	min-width: 60rem;
	border-top: 2px solid #222;
	border-collapse: collapse;
}
.kdt_table th, .kdt_table td {
	border: 1px solid #ddd;
	padding: 1.2rem 1rem;
	text-align: center;
	font-size: 1.5rem;
	line-height: 1.5;
	word-break: keep-all;
}
.kdt_table th {
	background-color: #f7f3e8;
	font-weight: 700;
	color: #222;
}
.kdt_table th.bd_l {
	border-left: 1px solid #ddd;
}
.kdt_table td {
	color: #444;
}
.kdt_table tbody tr:first-child th {
	border-top: none;
}
.kdt_table td.ta_l {
	text-align: left;
}
.kdt_table td.ta_c {
	text-align: center;
}
.kdt_table td.fw_b {
	font-weight: 700;
	color: #222;
}
/* 참여절차 프로세스 */
.kdt_process {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 1.5rem;
	margin-top: 2rem;
}
.kdt_process .step {
	flex: 1;
	border: 1px solid #222;
	display: flex;
	flex-direction: column;
}
.kdt_process .step_tit {
	background-color: #f7f3e8;
	border-bottom: 1px solid #222;
	padding: 1.5rem;
	text-align: center;
	font-weight: 700;
	font-size: 1.6rem;
	color: #222;
}
.kdt_process .step_con {
	padding: 2rem 1.5rem;
	font-size: 1.5rem;
	line-height: 1.6;
	color: #444;
	word-break: keep-all;
	flex: 1;
	display: flex;
}
.kdt_process .arr {
	display: flex;
	align-items: center;
	font-size: 2.4rem;
	color: #666;
}
@media (max-width: 1024px) {
	.kdt_table.res_table th, .kdt_table.res_table td {
		font-size: 1.3rem;
		padding: 1rem 0.5rem;
	}
}
@media (max-width: 768px) {
	.table_wrap {
		overflow-x: auto;
	}
	.kdt_process {
		flex-direction: column;
		align-items: center;
	}
	.kdt_process .step {
		width: 100%;
	}
	.kdt_process .arr {
		transform: rotate(90deg);
		margin: 1rem 0;
	}
}