@charset "UTF-8";
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");
/* color */
/* variables */
/* sub variables */
/* shadow */
/* z-index */
/* media */
/* typo */
/* 라인 1줄 제한 */
/* 라인 2줄 제한 */
/*  */
/* 정사각형 */
/* 애니메이션 */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");
@keyframes checkbox_anim {
  0% {
    top: -4px;
    right: -4px;
    bottom: -4px;
    left: -4px;
  }
  50% {
    top: -8px;
    right: -8px;
    bottom: -8px;
    left: -8px;
  }
  100% {
    top: -4px;
    right: -4px;
    bottom: -4px;
    left: -4px;
  }
}
@keyframes sur_need_anim {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-50%, calc(-50% + 8px));
  }
  100% {
    transform: translate(-50%, -50%);
  }
}
@keyframes sur_need_m_anim {
  0% {
    transform: translate(-50px, -27%);
  }
  50% {
    transform: translate(-50px, calc(-27% + 8px));
  }
  100% {
    transform: translate(-50px, -27%);
  }
}
@keyframes tab_active_anim {
  to {
    width: 100%;
  }
}
@keyframes click_anim {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-50%, calc(-50% - 12px));
  }
  100% {
    transform: translate(-50%, -50%);
  }
}
/* 랜딩페이지 */
/* 타이포 > 랜딩페이지 */
/* 검색 버튼 */
/* 랜딩페이지 > 랜딩 */
/* 페이징 버튼 */
/* 목록 버튼 : 정보입력 */
/* 로그인 / 회원가입 버튼 */
/* 삭제 / 탈퇴 버튼 스타일 */
/* 중복확인 버튼 */
/* 학습창 버튼 */
/* 학습 종료 버튼 */
/* 공통 레이아웃 */
/* 약관 */
.terms {
  margin-top: 16px;
}

.editor ul {
  display: block;
  list-style-type: disc;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-inline-start: 40px;
}

.editor ol {
  display: block;
  list-style-type: decimal;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-inline-start: 40px;
}

.editor li {
  display: list-item;
  text-align: -webkit-match-parent;
  list-style-type: inherit;
}

.editor blockquote {
  position: relative;
  padding: 4px 0;
}

.editor blockquote::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 4px;
  background: #D9D9D9;
}

/* 공지사항 */
section#notice {
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: linear-gradient(90deg, #000920 0%, #052780 100%);
  font-size: 0;
}

section#notice > .inner {
  max-width: 1200px;
  margin: auto;
  display: flex;
  align-items: center;
  gap: 48px;
  padding: 9px 0;
}
@media screen and (max-width: 980px) {
  section#notice > .inner {
    padding-left: 24px;
    padding-right: 24px;
  }
}

section#notice .caption {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #FFFFFF;
  position: relative;
}
@media screen and (max-width: 980px) {
  section#notice .caption {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

section#notice .caption::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: calc(100% + 24px);
  transform: translate(0, -50%);
  width: 3px;
  height: 3px;
  background: #FFFFFF;
  border-radius: 1000px;
}

section#notice .nt-swiper-container {
  flex: 1;
  overflow: hidden;
}

section#notice .nt-swiper-container .nt-swiper-slide {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #FFFFFF;
  padding: 8px 0;
}
@media screen and (max-width: 980px) {
  section#notice .nt-swiper-container .nt-swiper-slide {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

section#notice .nt-swiper-container .nt-swiper-slide a {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
  display: inline-block;
  margin-top: 3px;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  section#notice .nt-swiper-container .nt-swiper-slide a {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

section#notice .nt-swiper-button {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

section#notice .nt-swiper-button > .button {
  cursor: pointer;
  opacity: 0.5;
  transition: all 0.3s;
}

section#notice .nt-swiper-button .nt-swiper-button-prev svg {
  transform: rotate(180deg);
}

section#notice .nt-swiper-button > .button:hover {
  opacity: 1;
}

section#notice .close {
  display: flex;
  gap: 8px;
  position: absolute;
  right: 24px;
}

section#notice .close p {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  section#notice .close p {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

/* 헤더 */
.sticky {
  position: sticky;
  top: 0;
  z-index: 75;
  margin-top: 63px;
  background: #FFFFFF;
}

.sticky.closed {
  margin-top: 0 !important;
}

section#header {
  background: #FFFFFF;
}

section#header > .inner {
  max-width: 1200px;
  margin: auto;
  display: flex;
  align-items: end;
  justify-content: space-between;
  padding-top: 24px;
}
@media screen and (max-width: 980px) {
  section#header > .inner {
    padding-left: 24px;
    padding-right: 24px;
  }
}

section#header > .inner .left {
  display: flex;
  align-items: end;
  gap: 24px;
}

section#header .search {
  width: 390px;
  background: #F4F4F4;
  border-radius: 1000px;
  position: relative;
}

section#header .search input {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #B1B1B1;
  width: 100%;
  height: 100%;
  border: none;
  outline: none;
  padding: 12px 24px;
  background: none;
}
@media screen and (max-width: 980px) {
  section#header .search input {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

section#header .search input:focus ~ .go-search svg path {
  fill: #446CF9;
}

section#header .search input::placeholder {
  color: #B1B1B1;
}

section#header .search .go-search {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
}

section#header .right {
  display: flex;
}

section#header .rbtn {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: flex;
  padding: 8px 12px;
  gap: 8px;
  align-items: center;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  section#header .rbtn {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

section#header .login::after {content:" "; margin-left:12px; height:18px; border-right:1px solid #e0e0e0;}

section#header .logout {
  padding-right: 0;
  color: #878787;
}

section#header .login:hover, section#header .logout:hover, section#header .signup:hover {
  color: #446cf9;
}

section#header .signup {color:#446cf9;}
 /*
section#header .signup {
  border: 1px solid #E3EEFF;
  background: #05267F;
  color: #E3EEFF;
  box-sizing: border-box;
  transition: all 0.3s;
}

section#header .signup:hover {
  border: 1px solid #446CF9;
  background: #446CF9;
  color: #F5F8FF;
}
*/

section#header .mypage {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  section#header .mypage {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

section#header .mypage:hover {
  color: #446CF9;
}

section#header .mypage:hover svg path {
  fill: #446CF9;
}

section#header .goStudy {
  background: #E3EEFF;
  color: #446CF9;
  transition: all 0.3s;
}

section#header .goStudy:hover {
  background: #446CF9;
  color: #FFFFFF;
}

/* 네비게이션 */
section#navbar {
  border-bottom: 1px solid #F8F8F8;
}

section#navbar > .inner {
  max-width: 1200px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 24px;
  padding-bottom: 16px;
}
@media screen and (max-width: 980px) {
  section#navbar > .inner {
    padding-left: 24px;
    padding-right: 24px;
  }
}

section#navbar > .inner .left {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 28px;
}
@media screen and (max-width: 980px) {
  section#navbar > .inner .left {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

section#navbar .menu-open {
  position: relative;
}

section#navbar .menu-open .btn_mn_open {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #446CF9;
  padding: 8px 24px;
  border-radius: 5px;
}

section#navbar .menu-open .btn_mn_open::before {
  content: "";
  display: block;
  position: absolute;
  left: -4px;
  top: -4px;
  right: -4px;
  bottom: -4px;
  background: rgba(68, 108, 249, 0.3);
  z-index: -1;
  border-radius: 7px;
}

section#navbar .menu-open .btn_mn_open::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  transform: translateY(100%);
  height: 48px;
  z-index: 10;
}

section#navbar .menu-open > .btn_mn_open {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  section#navbar .menu-open > .btn_mn_open {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

section#navbar .menu-open .chevron {
  width: 20px;
}

section#navbar .menu-open .sub-menu {
  display: flex;
  position: absolute;
  top: 48px;
  left: 0;
  z-index: 100;
  transform: translateY(24px);
  background: #FFFFFF;
  filter: drop-shadow(0 -8px 12px rgba(0, 0, 0, 0.05));
}

section#navbar .menu-open .sub-menu::after {
  content: "";
  position: absolute;
  top: 0;
  transform: translate(24px, -100%) rotate(180deg);
  width: 0;
  height: 0;
  border-left: 16px solid transparent;
  border-right: 16px solid transparent;
  border-top: 12px solid #FFFFFF; /* 말풍선 색상과 동일하게 */
}

section#navbar .menu-open .sub-menu .st {
  background: #FFFFFF;
  min-width: 240px;
  max-width: 240px;
  padding: 24px 0 24px 24px;
  box-sizing: border-box;
}

section#navbar .menu-open .sub-menu .st-2 {
  background: #ebf1ff;
  padding: 24px 0 24px 0;
}

section#navbar .menu-open .sub-menu .st-3 {
  background: #ebf1ff;
  padding: 24px;
  min-width: 720px;
  max-width: 720px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(7, 1fr);
  column-gap: 8px;
  align-items: flex-start;
  max-height: 527px;
  overflow: auto;
}

section#navbar .menu-open .sub-menu .item {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  padding: 8px 24px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  section#navbar .menu-open .sub-menu .item {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

section#navbar .menu-open .sub-menu .item .item-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 8px 0;
}

section#navbar .menu-open .sub-menu .item .item-inner .txt {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: #5A5A5A;
}

section#navbar .menu-open .sub-menu .item .item-inner .txt svg path {
  fill: #D9D9D9;
}

section#navbar .menu-open .sub-menu .item.active_mn .item-inner .txt svg path {
  fill: #446CF9;
}

section#navbar .menu-open .sub-menu .st-1 .item.active_mn {
  background: #F5F8FF;
  border-top-left-radius: 15px;
  border-bottom-left-radius: 15px;
}

section#navbar .menu-open .sub-menu .st-1 .item .chevron {
  display: none;
}

section#navbar .menu-open .sub-menu .st-1 .item.active_mn .chevron,
section#navbar .menu-open .sub-menu .st-1 .item:hover .chevron {
  display: block;
}

section#navbar .menu-grp {
  display: flex;
  gap: 24px;
}

section#navbar .menu-open .sub-menu .st-2 .item .item-inner {
  border-radius: 5px;
  transition: all 0.3s;
  border: 1px solid transparent;
}

section#navbar .menu-open .sub-menu .st-2 .item.active_mn .item-inner,
section#navbar .menu-open .sub-menu .st-2 .item:hover .item-inner {
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.05);
  border: 1px solid #CED8F4;
}

section#navbar .menu-open .sub-menu .st-2 .item .item-inner .txt {
  padding: 0 8px;
  color: #05267F;
}

section#navbar .menu-open .sub-menu .st-3 .item {
  padding: 8px;
  overflow: hidden;
}

section#navbar .menu-open .sub-menu .st-3 .item .item-inner {
  overflow: hidden;
  background: #FFFFFF;
  color: #7084B7;
  position: relative;
  padding: 8px 26px;
  border-radius: 5px;
}

section#navbar .menu-open .sub-menu .st-3 .item .item-inner .txt {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-left: 8px;
  display: block;
  width: 100%;
  text-align: left;
}

section#navbar .menu-open .sub-menu .st-3 .item:hover {
  background: #E3EEFF;
}

section#navbar .menu-open .sub-menu .st-3 .item .item-inner::after {
  content: "";
  display: block;
  position: absolute;
  left: 8px;
  width: 4px;
  height: 4px;
  background: #7084B7;
  border-radius: 1000px;
}

section#navbar .menu-grp .menu {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #5A5A5A;
  cursor: pointer;
  /* height: 30px;
  line-height: 30px;
  padding: 0 10px; */
  padding: 8px;
  /* line-height: 20px; */
}
@media screen and (max-width: 980px) {
  section#navbar .menu-grp .menu {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

section#navbar .menu-grp .menu:hover {
  color: #446CF9;
}

/* click 메뉴 */
section#navbar .menu-grp .menu1 {
  background: #2D2D2D;
  color: #FFFFFF;
  position: relative;
  border-radius: 5px;
  font-size: 14px !important;
  font-weight: 500 !important;
}
section#navbar .menu-grp .menu1:hover {
  color: #fff;
}

section#navbar .menu-grp .menu1 .click {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  position: absolute;
  top: 0;
  left: 50%;
  background: #F83D1E;
  color: #2D2D2D;
  transform: translate(-50%, -50%);
  padding: 1px 8px;
  border-radius: 1000px;
  animation: click_anim 3s linear infinite;
}
section#navbar .menu-grp .menu1 .click::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-width: 5px;
  border-style: solid;
  border-color: #F83D1E transparent transparent transparent;
  transform: translate(-50%, 100%);
}

section#navbar > .inner .right li {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #446CF9;
  padding:10px 16px; border-radius:5px; background:#E4F1FF;
  cursor: pointer;
}
@media screen and (max-width: 980px) {
  section#navbar > .inner .right li {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

section#navbar > .inner .right li:hover {
  background: #446CF9; color:#fff;
}


section#navbar .menu-grp .momenu {display:none;}
@media screen and (max-width: 980px) {
	section#navbar .menu-grp .momenu {display:block; color:#446cf9;}
}



/* 푸터 */
#footer > .inner {
  max-width: 1200px;
  margin: auto;
}
@media screen and (max-width: 980px) {
  #footer > .inner {
    padding-left: 24px;
    padding-right: 24px;
  }
}

.f_menu {
  position: relative;
  display: flex;
  margin-bottom: 32px;
}

.f_menu .menu {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  text-align: center;
  color: #7084B7;
  padding: 24px 24px;
  border-bottom: 3px solid #CED8F4;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .f_menu .menu {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.f_menu::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: #E3EEFF;
}

.f_menu .menu.per_info {
  color: #05267F;
  border-bottom: 3px solid #05267F;
  font-size: 17px;
}

.f_menu .menu:hover {
  background: #CED8F4;
}

.f_con {
  display: flex;
  justify-content: space-between;
  margin-bottom: 32px;
}

.f_con .left {
  flex: 1;
  display: flex;
  gap: 24px;
  align-items: end;
}

.f_con ul.info {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  column-gap: 24px;
  row-gap: 8px;
}

.f_con ul.info li {
  display: flex;
  gap: 24px;
  align-self: center;
}

.f_con ul.info li .label {
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
  color: #2A2A2A;
  position: relative;
}
@media screen and (max-width: 980px) {
  .f_con ul.info li .label {
    font-size: 13px;
    line-height: 17px;
    font-weight: 700;
  }
}

.f_con ul.info li p {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .f_con ul.info li p {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.f_con .utill_area {
  z-index: 10;
  position: relative;
}

.f_con .utill_area .utill_select_area2 {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  background: #FFFFFF;
  padding: 8px 24px;
  color: #446CF9;
  border-radius: 5px;
  align-self: center;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .f_con .utill_area .utill_select_area2 {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.f_con .utill_area .utill_select_area2:hover {
  background: rgba(68, 108, 249, 0.2);
}

.f_con .utill_area .utill_select_area2::before {
  content: "";
  display: block;
  position: absolute;
  left: -4px;
  top: -4px;
  right: -4px;
  bottom: -4px;
  background: rgba(68, 108, 249, 0.2);
  z-index: -1;
  border-radius: 7px;
}

.f_con .utill_area .utill_select_box2 {
  position: absolute;
  bottom: calc(100% + 24px);
  right: -4px;
  background: #FFFFFF;
  border: 1px solid #446CF9;
  width: 200%;
  border-radius: 15px;
  overflow: hidden;
}

.f_con .utill_area .utill_select_box2 ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.f_con .utill_area .utill_select_box2 li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  padding: 8px 24px;
  color: #6160F4;
  cursor: pointer;
}
@media screen and (max-width: 980px) {
  .f_con .utill_area .utill_select_box2 li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.f_con .utill_area .utill_select_box2 li:hover {
  background: #F5F8FF;
}

.copyright {
  display: flex;
  justify-content: center;
  padding: 24px 0;
  border-top: 1px solid #D9D9D9;
}

.copyright p {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  color: #B1B1B1;
}
@media screen and (max-width: 980px) {
  .copyright p {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

@media screen and (max-width: 980px) {
  /* 공통 */
  .sticky {
    margin-top: 40px;
  }
  section#notice.pc {
    display: none;
  }
  section#notice.mob {
    display: block !important;
  }
  section#header.pc {
    display: none;
  }
  section#header.mob {
    display: block !important;
  }
  section#quick, section#best, section#recommend, section#new, section#usage {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  #footer.pc {
    display: none;
  }
  #footer.mob {
    display: block !important;
  }
  /* 공지 */
  section#notice {
    position: absolute;
  }
  section#notice > .inner {
    padding: 3px 16px;
    max-width: 100%;
    gap: 0;
  }
  section#notice .caption {
    font-size: 14px !important;
    line-height: 18px !important;
    font-weight: 500 !important;
  }
  /* 헤더 */
  /* 서브 메뉴 */
  /* 퀵메뉴 */
  /* 푸터 */
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#notice .caption {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
@media screen and (max-width: 980px) {
  section#notice .caption::after {
    left: calc(100% + 8px);
  }
  section#notice .nt-swiper-container {
    padding-left: 24px;
  }
  section#notice .nt-swiper-container .nt-swiper-slide a {
    font-size: 14px !important;
    line-height: 18px !important;
    font-weight: 500 !important;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#notice .nt-swiper-container .nt-swiper-slide a {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
@media screen and (max-width: 980px) {
  section#notice .nt-swiper-button {
    gap: 2px;
  }
  .nt-btn-container {
    display: flex;
  }
  .nt-btn-container .nt-swiper-button {
    padding-right: 16px;
  }
  section#notice .nt-swiper-button > .button svg {
    width: 65%;
  }
  .nt-btn-container button {
    align-self: center;
    padding-left: 16px;
    border-left: 1px solid rgba(255, 255, 255, 0.1);
  }
  section#header > .inner {
    padding: 8px 16px;
  }
  section#header > .inner .left {
    justify-content: space-between;
    width: 100%;
  }
  section#header .right {
    gap: 8px;
  }
  section#header .btn {
    width: 24px;
    height: 24px;
  }
  section#header .btn svg {
    width: 75%;
    fill: #878787;
  }
  section#header .btn svg path {
    fill: #B1B1B1;
  }
  section#m_sub {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: #FFFFFF;
    z-index: 100;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
  }
  section#m_sub > .inner {
    height: 100vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }
  section#m_sub .row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 24px;
    border-bottom: 1px solid #F5F8FF;
  }
  section#m_sub .row1 .right {
    display: flex;
    gap: 24px;
  }
  section#m_sub .row1 .mypage a {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    color: #878787;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#m_sub .row1 .mypage a {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  section#m_sub .row1 .lec a {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 8px;
    background: #E3EEFF;
    border: 1px solid #CED8F4;
    border-radius: 4px;
    color: #7084B7;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#m_sub .row1 .lec a {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  section#m_sub .category-nm {
    font-size: 16px;
    line-height: 16px;
    font-weight: 700;
    color: #5A5A5A;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#m_sub .category-nm {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}
@media screen and (max-width: 980px) {
  section#m_sub .category-num {
    font-size: 14px !important;
    line-height: 18px !important;
    font-weight: 500 !important;
    color: #5A5A5A;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#m_sub .category-num {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
@media screen and (max-width: 980px) {
  section#m_sub .row3 {
    display: flex;
    flex: 1;
    overflow: hidden;
  }
  section#m_sub .row3 ul.st-1 {
    overflow-y: auto;
  }
  section#m_sub .row3 ul.st-2 {
    flex: 1;
    overflow-y: auto;
  }
  section#m_sub .row3 ul.st-1 li {
    padding: 16px;
    min-width: 123px;
    max-width: 123px;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  section#m_sub .row3 ul li.item {
    font-size: 18px;
    line-height: 18px;
    font-weight: 400;
    border-bottom: 1px solid #F8F8F8;
    color: #5A5A5A;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  section#m_sub .row3 ul li.item {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
  }
}
@media screen and (max-width: 980px) {
  section#m_sub .row3 ul li.item.active_mn {
    color: #446CF9;
    background: #e6edff;
  }
  section#m_sub .row3 ul li.item > svg path {
    fill: #D9D9D9;
  }
  section#m_sub .row3 ul li.item.active_mn > svg path {
    fill: #446CF9;
  }
  section#m_sub .row3 ul.st-2 li.item {
    display: flex;
    flex-direction: column;
    min-width: auto;
    max-width: inherit;
    background: #e6edff;
    box-sizing: border-box;
  }
  section#m_sub .row3 ul.st-2 li.item > div {
    color: #05267F;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 16px;
    box-sizing: border-box;
    border-bottom: 1px solid #E3EEFF;
  }
  section#m_sub .row3 ul.st-2 li.item:first-child > div {
    border-top: none;
  }
  section#m_sub .row3 ul.st-3 > li {
    padding: 16px;
    position: relative;
    color: #5A5A5A;
  }
  section#m_sub .row3 ul.st-3 > li::after {
    content: "";
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 1000px;
    background: #7084B7;
    top: 24px;
    position: absolute;
    transform: translateY(-50%);
  }
  section#m_sub .row3 ul.st-3 > li span {
    padding-left: 16px;
  }
  section#quick .conBox ul {
    gap: 8px;
  }
  .quick_m:hover > .icon svg {
    animation: none;
  }
  .quick_m:hover > .icon::before {
    display: none;
  }
  .quick_m .txt p {
    font-weight: 600;
  }
  .quick_m .txt p br {
    display: block;
  }
  #footer {
    padding: 0;
  }
  .f_con {
    flex-direction: column;
  }
  .f_con .top {
    display: flex;
    margin-bottom: 24px;
  }
  .f_con .top .d_logo {
    width: 28.3%;
  }
  .f_menu {
    margin-bottom: 24px;
  }
  .f_menu .menu {
    padding: 0;
    padding-top: 24px;
    padding-bottom: 24px;
    flex: 1;
  }
  .f_con .utill_area {
    flex: 1;
    display: flex;
    justify-content: end;
  }
  .f_con .utill_area .utill_select_box2 {
    width: 33vw;
  }
  .f_con ul.info {
    gap: 8px;
    flex-direction: column;
  }
  .f_con ul.info li {
    align-self: flex-start;
  }
  .f_con ul.info li .label {
    min-width: 52px;
  }
  .f_con ul.info li p {
    padding-top: 2px;
  }
  .f_menu .menu.per_info {
    font-size: 14px;
  }
}
/* 교육원 소개 */
.edu_intro {
  background: url("/img/sub/intro4.png") no-repeat 0 0/contain;
  width: 100%;
  height: 300px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px 0;
}

.edu_intro::before {
  content: "";
  display: inline-block;
  background: url("/img/sub/edu_icon1.png") no-repeat 0 0;
  width: 83px;
  height: 86px;
  position: absolute;
  top: -20px;
  left: 0;
}

.edu_intro::after {
  content: "";
  display: inline-block;
  background: url("/img/sub/edu_icon2.png") no-repeat 0 0;
  width: 83px;
  height: 86px;
  position: absolute;
  bottom: -29px;
  right: -19px;
}

.edu_intro h3 {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 980px) {
  .edu_intro h3 {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.edu_conBox0 {
  background: url("/img/sub/k-edu_bg.png") no-repeat 0 0;
  z-index: 0;
  position: relative;
  margin: 40px 0;
}

.edu_contitBox {
  text-align: center;
  margin-bottom: 16px;
}

.edu_titbox {
  text-align: right;
  word-break: auto-phrase;
}

.edu_contitBox h3 {
  font-size: 38px;
  line-height: 48px;
  font-weight: 800;
  margin-bottom: 24px;
}
@media screen and (max-width: 980px) {
  .edu_contitBox h3 {
    font-size: 24px;
    line-height: 29px;
    font-weight: 800;
  }
}

.edu_contitBox h3::before {
  content: "";
  display: inline-block;
  width: 3px;
  height: 34px;
  background: #446CF9;
  position: relative;
  left: -7px;
  top: 5px;
}

.edu_contitBox p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .edu_contitBox p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.edu_contitBox h3.edu_subtit1 span {
  color: #05267F;
}

.edu_contitBox p.edu_subtit2 {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #05267F;
  margin-bottom: 8px;
}
@media screen and (max-width: 980px) {
  .edu_contitBox p.edu_subtit2 {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.edu_contitBox p.edu_subcon {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .edu_contitBox p.edu_subcon {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.edu_conBox1 {
  margin-bottom: 40px;
}

.edu_conBox1 .edu_con ul {
  display: flex;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.05);
}

.edu_conBox1 .edu_con ul li {
  width: 33.333%;
  text-align: center;
  padding: 42px 0;
  position: relative;
}

.edu_conBox1 .edu_con ul li:nth-child(2) {
  background: #f7f7f7;
}

p.edu_contit {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  margin: 8px 0;
}
@media screen and (max-width: 980px) {
  p.edu_contit {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

p.edu_conin {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
}
@media screen and (max-width: 980px) {
  p.edu_conin {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

p.educontit2 {
  margin-top: 40px;
  position: relative;
}

p.educontit2::before {
  content: "";
  display: inline-block;
  width: 3px;
  height: 76px;
  background: #446CF9;
  position: absolute;
  margin: 0 0 0 32px;
  bottom: 40px;
}

.edu_conBox2 {
  margin: 40px 0;
}

.edu_conBox2 ul {
  display: flex;
  gap: 24px;
  text-align: center;
}

.edu_conBox2 ul li {
  width: 33.333%;
}

.edu_conBox2 ul li div.edu_img {
  width: 100%;
  overflow: hidden;
}

.edu_conBox2 ul li div.edu_img1 {
  border-radius: 30px 0 0 0;
}

.edu_conBox2 ul li div.edu_img3 {
  border-radius: 0 0 30px 0;
}

.edu_conBox2 ul li div.edu_img img {
  width: 100%;
}

/* 찾아오시는 길 */
#map {
  margin-top: 16px;
}

.location_img {margin-top:20px;}
.location_img img {width:100%;}
.in_con .in_con_inner .locationBox {
  width: 100%;
  overflow: hidden;
  background: #FFFFFF;
}

.in_con .in_con_inner .locationBox .address {
  box-sizing: border-box;
  margin-top: 24px;
  padding-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 2px solid #f8f8f8;
  overflow: hidden;
}

.in_con .in_con_inner .locationBox .address p.icon {
  position: relative;
  width: 24px;
  border: 1px solid #B1B1B1;
  background: #5A5A5A;
  text-align: center;
  color: #FFFFFF;
  border-radius: 1000px;
  font-size: 12px;
}
.in_con .in_con_inner .locationBox .address p.icon::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.in_con .in_con_inner .locationBox .address p.icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.in_con .in_con_inner .locationBox .address p.text {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .in_con .in_con_inner .locationBox .address p.text {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.in_con .in_con_inner .locationBox .transport {
  overflow: hidden;
  display: flex;
  gap: 24px;
  padding: 16px 0;
}

.in_con .in_con_inner .locationBox .transport div {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.in_con .in_con_inner .locationBox .transport div.bus {
  border-bottom: 0px;
  position: relative;
}

.in_con .in_con_inner .locationBox .transport div.bus::before {
  content: "";
  display: block;
  position: absolute;
  left: -12px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #D9D9D9;
}

.in_con .in_con_inner .locationBox .transport div.bus p.icon {
  border: 1px solid #446CF9;
  background: #6160F4;
}

.in_con .in_con_inner .locationBox .transport div p.icon {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  gap: 8px;
  padding: 4px 8px;
  border: 1px solid #AEF483;
  background: #39BF50;
  border-radius: 5px;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .in_con .in_con_inner .locationBox .transport div p.icon {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.in_con .in_con_inner .locationBox .transport p.text {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .in_con .in_con_inner .locationBox .transport p.text {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* hrd 안내 */
.hrd_wrap {
  margin: 24px 0;
}

.hrd_topBox {
  padding: 96px 24px;
  position: relative;
  border-radius: 15px;
  overflow: hidden;
}

.hrd_topBox::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 7px;
  background: #2A2A2A;
}

.hrd_topBox::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 7px;
  top: 8px;
  left: 8px;
  right: 8px;
  bottom: 8px;
  background: linear-gradient(45deg, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0.05) 50%);
}

.hrd_topBox .hrd_keyword,
.hrd_topBox .hrd_titBox {
  z-index: 10;
  position: relative;
}

.hrd_topBox .hrd_subStit {
  font-size: 22px;
  line-height: 22px;
  font-weight: 400;
  color: #D9D9D9;
  text-align: left;
  display: block;
  z-index: 10;
}
@media screen and (max-width: 980px) {
  .hrd_topBox .hrd_subStit {
    font-size: 17.6px;
    line-height: 17.6px;
    font-weight: 400;
  }
}

.hrd_topBox .hrd_subStit .strong {
  font-size: 38px;
  line-height: 48px;
  font-weight: 800;
  color: #FFFFFF;
  margin-top: 16px;
  display: inline-block;
}
@media screen and (max-width: 980px) {
  .hrd_topBox .hrd_subStit .strong {
    font-size: 24px;
    line-height: 29px;
    font-weight: 800;
  }
}

.hrd_topBox .hrd_card {
  overflow: hidden;
  z-index: 10;
  width: 290px;
  height: 163px;
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translate(-24px, -50%) rotate(0deg);
  background: linear-gradient(0deg, #878787 0%, #B1B1B1 100%);
  border-radius: 15px;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.8);
}

.hrd_topBox .hrd_card.tomorrow_card {
  background: linear-gradient(-45deg, #E3EEFF 0%, #446CF9 100%);
}

.hrd_topBox .hrd_card.kdc_card {
  background: linear-gradient(-45deg, #FF8E90 0%, #F94447 100%);
}

.hrd_topBox .hrd_card.nor_card {
  background: linear-gradient(-45deg, #446CF9 0%, #AEF483 100%);
}

.hrd_topBox .hrd_card::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.hrd_topBox .hrd_card .hrd_card_nm {
  font-size: 28.8px;
  line-height: 36px;
  font-weight: bold;
  font-size: 26px;
  color: #5A5A5A;
  display: flex;
  height: 100%;
  align-items: flex-end;
  padding: 24px;
  box-sizing: border-box;
  position: absolute;
  bottom: 0;
  text-shadow: 1px 1px 2px rgba(90, 90, 90, 0.2), -1px -1px 2px #d9d9d9; /* 위쪽 왼쪽 밝은 부분 */
}
@media screen and (max-width: 980px) {
  .hrd_topBox .hrd_card .hrd_card_nm {
    font-size: 21.6px;
    line-height: 26.4px;
    font-weight: bold;
  }
}

.hrd_topBox .hrd_card.tomorrow_card .hrd_card_nm {
  color: #05267F;
}

.hrd_topBox .hrd_card.kdc_card .hrd_card_nm {
  color: #bd0609;
}

.hrd_topBox .hrd_card.nor_card .hrd_card_nm {
  color: #031D61;
}

.hrd_topBox .d_square {
  position: absolute;
  right: -16px;
  top: -16px;
  width: 200px;
}
.hrd_topBox .d_square path {
  fill: #5A5A5A;
}

.hrd_keyword ul {
  display: flex;
  justify-content: start;
  gap: 8px;
  margin-bottom: 16px;
}

.hrd_keyword ul li {
  font-size: 15.4px !important;
  line-height: 21.6px !important;
  font-weight: 500 !important;
  border: 1px solid #FFFFFF;
  border-radius: 30px;
  color: #2A2A2A;
  padding: 4px 8px;
  background: linear-gradient(25deg, #F8F8F8 0%, #B1B1B1 100%);
}
@media screen and (max-width: 980px) {
  .hrd_keyword ul li {
    font-size: 14.3px !important;
    line-height: 15.6px !important;
    font-weight: 500 !important;
  }
}

.hrd_infoinner .tabBox {
  margin-top: 48px;
  margin-bottom: 48px;
}

.hrd_infoinner .tabBox .tabs {
  gap: 8px;
}

.hrd_infoinner .tabBox .hrd_tab {
  background: #F8F8F8;
  border-radius: 1000px;
  color: #878787;
  padding: 0;
  transition: all 0.3s;
}

.hrd_infoinner .tabBox .hrd_tab a {
  font-size: 15.4px !important;
  line-height: 21.6px !important;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 0;
  width: 100%;
}
@media screen and (max-width: 980px) {
  .hrd_infoinner .tabBox .hrd_tab a {
    font-size: 14.3px !important;
    line-height: 15.6px !important;
    font-weight: 500 !important;
  }
}

.hrd_infoinner .tabBox .hrd_tab:hover {
  background: #446CF9;
  color: #FFFFFF;
}

.hrd_infoinner .tabBox .hrd_tab.current::after {
  display: none;
}

.hrd_bigtab ul.hrd_tabul {
  display: flex;
  gap: 16px;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli {
  display: flex;
  align-items: center;
  justify-content: center;
  justify-content: space-between;
  gap: 16px;
  flex-direction: column;
  flex: 1;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  cursor: pointer;
  padding: 16px;
  transition: all 0.3s;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli:hover {
  border: 1px solid #446CF9;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli p.hrd_tabtit {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .hrd_bigtab ul.hrd_tabul li.hrd_tabli p.hrd_tabtit {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli img {
  object-fit: none;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli a {
  font-size: 15.4px !important;
  line-height: 21.6px !important;
  font-weight: 500 !important;
  box-sizing: border-box;
  width: 100%;
  display: flex;
  justify-content: space-between;
  padding: 16px 24px;
  background: #F8F8F8;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .hrd_bigtab ul.hrd_tabul li.hrd_tabli a {
    font-size: 14.3px !important;
    line-height: 15.6px !important;
    font-weight: 500 !important;
  }
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli:hover a {
  background: #446CF9;
  color: #FFFFFF;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli.hrd_active {
  border: 1px solid #446CF9;
}

.hrd_bigtab ul.hrd_tabul li.hrd_tabli.hrd_active a {
  background: #446CF9;
  color: #FFFFFF;
}

.hrdcon {
  scroll-margin-top: 140px;
}

.hrdcon + .hrdcon {
  margin-top: 64px !important;
}

.hrdcon.prod_section + .hrdcon {
  margin-top: 80px !important;
}

.hrd_infoBox {
  position: relative;
  display: flex;
  padding-right: 8px;
}

ul.hrd_info li .hrd_subtit {
  font-size: 22.5px !important;
  line-height: 30px !important;
  font-weight: 800 !important;
  font-weight: 800;
  color: #2A2A2A;
  display: inline-block;
  height: 100%;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 980px) {
  ul.hrd_info li .hrd_subtit {
    font-size: 20px !important;
    line-height: 30px !important;
    font-weight: 800 !important;
  }
}

ul.hrd_info li .hrd_sub_subtit {
  font-size: 19.2px;
  line-height: 25.6px;
  font-weight: 700;
  color: #5A5A5A;
  display: inline-block;
  height: 100%;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 980px) {
  ul.hrd_info li .hrd_sub_subtit {
    font-size: 16.8px;
    line-height: 28.8px;
    font-weight: 700;
  }
}

ul.hrd_info li .hrd_subtit .step_num {
  font-size: 15.4px !important;
  line-height: 21.6px !important;
  font-weight: 500 !important;
  display: inline-block;
  align-self: baseline;
  color: #446CF9;
  margin-bottom: 8px;
}
@media screen and (max-width: 980px) {
  ul.hrd_info li .hrd_subtit .step_num {
    font-size: 14.3px !important;
    line-height: 15.6px !important;
    font-weight: 500 !important;
  }
}

ul.hrd_info li p img {
  width: 100%;
}

ul.hrd_info li ul li {
  font-size: 17.6px;
  line-height: 27.6px;
  font-weight: 500;
  color: #5A5A5A;
  position: relative;
  padding-left: 16px;
}
@media screen and (max-width: 980px) {
  ul.hrd_info li ul li {
    font-size: 14.3px;
    line-height: 20.4px;
    font-weight: 500;
  }
}

ul.hrd_info li ul li::before {
  content: "";
  display: block;
  position: absolute;
  width: 4px;
  height: 4px;
  background: #446CF9;
  border-radius: 1000px;
  top: 0;
  left: 0;
  transform: translateY(11px);
}

/* hrd 안내 > 소개 */
.hrd_info_abt {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: calc(100% - 240px);
  border-top: 4px solid #D9D9D9;
  border-bottom: 4px solid #D9D9D9;
  margin-right: 32px;
}

.hrd_infoBox .hrd_imginfo {
  width: 240px;
  right: 0;
}

ul.hrd_info li .hrd_subtitBox {
  box-sizing: border-box;
  width: 100%;
  overflow: hidden;
  margin-bottom: 16px;
}

/* hrd 안내 > 지원대상 */
.hrd_info_target {
  width: 100%;
  background: #F8F8F8;
  padding: 24px;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
}

.hrd_info_target > li {
  position: relative;
  flex: 1;
  padding: 24px;
  border: 2px solid transparent;
  z-index: 10;
}

.hrd_info_target > li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: transparent;
  border-radius: 15px;
  z-index: -1;
}

.hrd_info_target > li.selected {
  border-radius: 15px;
  border: 2px solid transparent;
  overflow: hidden;
}

.hrd_info_target > li.selected::after {
  background: #39BF50;
}

.hrd_info_target > li.selected .hrd_sub_subtit {
  color: #FFFFFF;
}

.hrd_info_target > li.selected ul li {
  color: #FFFFFF;
}

.hrd_info_target > li.selected ul li::before {
  background: #FFFFFF;
}

.hrd_info_target > li.selected .hrd_subtit {
  color: #FFFFFF;
}

.hrd_info_target > li > ul {
  z-index: 10;
  position: relative;
}

.hrd_info_target > li > ul li + li {
  margin-top: 4px;
}

.hrd_info_target > li .symbol_box {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(calc(50% - 24px), calc(50% - 24px));
}

.hrd_info_target > li .symbol_box span {
  color: #D9D9D9;
  opacity: 0.2;
  font-size: 160px;
}

.hrd_info_target > li.selected .symbol_box span {
  color: #FFFFFF;
}

/* hrd 안내 > 진행 */
.hrd_info_process {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  position: relative;
  width: 100%;
}

.hrd_info_process::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -24px;
  left: 0;
  right: 0;
  height: 16px;
  background: linear-gradient(-90deg, rgba(57, 191, 80, 0.5) 0%, rgba(174, 244, 131, 0) 100%);
  border-radius: 30px;
}

.hrd_info_process::before {
  content: "";
  display: block;
  position: absolute;
  width: 8px;
  height: 8px;
  right: 0;
  bottom: -16px;
  background: #FFFFFF;
  z-index: 10;
  transform: translate(-4px, 50%);
  border-radius: 1000px;
}

.hrd_info_process > li {
  flex: 1;
  border: 1px solid #eeeeee;
  border-radius: 15px;
  padding: 16px;
  box-sizing: border-box;
  position: relative;
}

.hrd_info_process > li::after {
  display: block;
  content: "\f054"; /* Font Awesome user icon */
  font-family: "Font Awesome 6 Free"; /* Font Awesome 폰트 설정 */
  position: absolute;
  font-weight: 900; /* 아이콘 가중치 (일반적으로 900 사용) */
  right: 0;
  top: 26px;
  transform: translate(8px, -50%);
  width: 16px;
  height: 16px;
  font-size: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #E9FFDC;
  border-radius: 1000px;
  border: 1px solid #39BF50;
  z-index: 10;
  color: #39BF50;
}

.hrd_info_process > li:last-child:after {
  display: none;
}

.hrd_info_process > li.process_cover {
  font-size: 19.2px;
  line-height: 25.6px;
  font-weight: 700;
  background: #6160F4;
  color: #FFFFFF;
  overflow: hidden;
}
@media screen and (max-width: 980px) {
  .hrd_info_process > li.process_cover {
    font-size: 16.8px;
    line-height: 28.8px;
    font-weight: 700;
  }
}

.hrd_info_process > li.process_cover.kdc {
  background: #446CF9;
}

.hrd_info_process > li.process_cover.comp_info {
  background: #F94447;
}

.hrd_info_process > li.process_cover p {
  font-size: 15.4px !important;
  line-height: 21.6px !important;
  font-weight: 500 !important;
  margin-top: 16px;
}
@media screen and (max-width: 980px) {
  .hrd_info_process > li.process_cover p {
    font-size: 14.3px !important;
    line-height: 15.6px !important;
    font-weight: 500 !important;
  }
}

.hrd_info_process > li.process_cover p .process_cover_deco {
  position: absolute;
  top: 48px;
  transform: translate(40%, -50%);
  opacity: 0.2;
}

.hrd_info_process > li.process_cover p .wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  width: 100%;
}
.hrd_info_process > li.process_cover p .wave path {
  fill: #FFFFFF;
  opacity: 0.4;
}

.hrd_info_process > li.process_cover::after {
  display: none;
}

.hrd_info_process > li .pro_type {
  background: #E3EEFF;
  color: #05267F;
  min-width: 70.4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
}

.hrd_info_process > li .pro_type.offline {
  background: #ffc1c2;
  color: #f71316;
}

.hrd_info_process > li .pro_type {
  background: #E3EEFF;
  color: #05267F;
}

.hrd_info_process > li .spn_link {
  border-bottom: 1px solid #446CF9;
  padding: 0 2px;
  color: #446CF9;
}

.hrd_info_process > li .green {
  color: #39BF50;
}

.hrd_info_process > li .small {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .hrd_info_process > li .small {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.hrd_info_process > li .iconBox {
  position: relative;
  display: inline-block;
  width: 24px;
  font-size: 12px;
}
.hrd_info_process > li .iconBox::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.hrd_info_process > li .iconBox > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hrd_info_process > li .price_bar {
  display: flex;
  height: 8px;
  background: #F8F8F8;
  box-shadow: inset 0px 0px 2px rgba(90, 90, 90, 0.2);
  border-radius: 1000px;
  position: relative;
  margin-bottom: 16px;
}

@keyframes paid_anim {
  0% {
    right: 90%;
  }
  50% {
    right: 60%;
  }
  100% {
    right: 90%;
  }
}
.hrd_info_process > li .price_bar .paid {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: #AEF483;
  animation: paid_anim 5s infinite;
  border-radius: 1000px;
}

.hrd_info_process > li .price_bar.kdc .paid {
  right: 90%;
  animation: none;
}

.hrd_info_process > li .price_bar .paid::after {
  content: "";
  display: block;
  position: absolute;
  background: #AEF483;
  left: 0;
  right: 0;
  height: 2px;
  bottom: 0;
  transform: translateY(8px);
}

.hrd_info_process > li .price_bar .paid::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  position: absolute;
  top: 0;
  height: 8px;
  border-left: 1px solid #AEF483;
  border-right: 1px solid #AEF483;
  transform: translateY(11px);
}

.hrd_info_process li .hrd_subtitBox .hrd_subtit p {
  font-size: 19.2px;
  line-height: 25.6px;
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  .hrd_info_process li .hrd_subtitBox .hrd_subtit p {
    font-size: 16.8px;
    line-height: 28.8px;
    font-weight: 700;
  }
}

.hrd_info_process li ul {
  display: flex;
  flex-direction: column;
  min-height: 110.4px;
}

.hrd_info_process li ul li {
  font-size: 17.6px;
  line-height: 27.6px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .hrd_info_process li ul li {
    font-size: 14.3px;
    line-height: 20.4px;
    font-weight: 500;
  }
}

.hrd_info_process li ul li + li {
  margin-top: 16px;
}

/* hrd 안내 > 환급절차 */
.hrd_info_refund {
  width: 100%;
  background: #5A5A5A;
  padding: 24px;
  border-radius: 15px;
}

.hrd_info_refund li .hrd_subtit {
  color: #FFFFFF !important;
}

.hrd_info_refund li ul li {
  color: #F8F8F8;
}

.hrd_info_refund .refund_wrap {
  display: flex;
  gap: 24px;
}

.hrd_info_refund .refund_wrap > li {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 24px;
  flex-direction: column;
  background: #D9D9D9;
  border-radius: 15px;
  gap: 16px;
}

.hrd_info_refund .refund_wrap > li::after {
  content: "";
  display: block;
  position: absolute;
  background: url("/img/sub/process_arrow.svg") no-repeat;
}

.hrd_info_refund .refund_wrap > li::before {
  display: none;
}

.hrd_info_refund .refund_wrap > li .refund_idx {
  padding: 0 8px;
  width: 48px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #2A2A2A;
  border-radius: 5px;
  position: relative;
}

.hrd_info_refund .refund_wrap > li .refund_idx > span {
  font-size: 17.6px;
  line-height: 27.6px;
  font-weight: 500;
  position: absolute;
  color: #FFFFFF;
  position: relative;
}
@media screen and (max-width: 980px) {
  .hrd_info_refund .refund_wrap > li .refund_idx > span {
    font-size: 14.3px;
    line-height: 20.4px;
    font-weight: 500;
  }
}

.hrd_info_refund .refund_wrap > li .refund_idx > span::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  bottom: 0;
  background: #2A2A2A;
  opacity: 0.5;
}

.hrd_info_refund .refund_wrap > li .process_arw {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(calc(100% + 4px), -50%);
}

.hrd_info_refund .refund_wrap > li .process_arw > *:nth-child(1) {
  animation: process_anim 1s ease-in-out infinite;
  animation-delay: 0.3s;
}

.hrd_info_refund .refund_wrap > li .process_arw > *:nth-child(2) {
  animation: process_anim 1s ease-in-out infinite;
  animation-delay: 0.6s;
}

.hrd_info_refund .refund_wrap > li .process_arw > *:nth-child(3) {
  animation: process_anim 1s ease-in-out infinite;
  animation-delay: 0.9s;
}

.hrd_info_refund .hrd_note {
  margin-top: 24px;
}

.hrd_info_refund .hrd_note > ul {
  background: #FFFFFF;
  padding: 24px 16px;
  border-radius: 15px;
}

.hrd_info_refund .hrd_note .hrd_sub_subtit {
  color: #FFFFFF;
}

.hrd_info_refund .hrd_note > ul li {
  color: #5A5A5A;
}

.hrd_info_refund .hrd_note > ul li + li {
  margin-top: 16px;
}

/* hrd 안내 > 유의사항 */
.hrd_info_note {
  background: #F8F8F8;
  padding: 24px;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.hrd_info_note > li + li {
  margin-top: 48px;
}

.hrd_info_note .hrd_comp_table {
  border-radius: 15px;
  overflow: hidden;
  padding-left: 0;
}

.hrd_info_note .hrd_comp_table > ul {
  display: flex;
}

.hrd_info_note .hrd_comp_table > ul li {
  flex: 1;
  padding: 16px 8px;
  background: #FFFFFF;
  text-align: center;
  border-right: 1px solid #eeeeee;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.hrd_info_note .hrd_comp_table > ul li::before {
  display: none;
}

.hrd_info_note .hrd_comp_table > ul li:last-child {
  border-right: 1px solid transparent;
}

.hrd_info_note .hrd_comp_table > ul.head li {
  background: #446CF9;
  color: #FFFFFF !important;
}

.hrd_info_note .hrd_comp_table > ul li .outer {
  position: relative;
  width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  border: 1px solid #eeeeee;
  background: #05267F;
}
.hrd_info_note .hrd_comp_table > ul li .outer::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.hrd_info_note .hrd_comp_table > ul li .outer > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hrd_info_note .hrd_comp_table > ul li .outer i {
  font-size: 12px;
  color: #39BF50;
}

.hrd_info_note .hrd_comp_table > ul li .inner_circle {
  width: 16px;
  height: 16px;
  display: inline-block;
  border-radius: 50%;
  background: radial-gradient(closest-side, #05267F 50%, transparent 70%), conic-gradient(#39BF50 0% 80%, #FFFFFF 70% 100%);
  top: 2px;
  left: 2px;
}

.hrd_info_note .hrd_comp_table > ul li.note_cell {
  flex: 1.5;
  color: #F94447;
}

.hrd_info_note .hrd_comp_table > ul li.note_cell::before {
  display: none;
}

.hrd_info_note .note_normal > ul {
  padding: 24px 16px;
  background: #FFFFFF;
  border-radius: 15px;
}

.hrd_info_note .note_normal > ul li + li {
  margin-top: 16px;
}

.hrd_info_note .note_limit > ul {
  display: flex;
}

.hrd_info_note .note_limit > ul .schedule::before {
  display: none;
}

.hrd_info_note .note_limit > ul .schedule {
  flex: 1;
  justify-content: end;
  display: flex;
  margin-top: 0;
}

.hrd_info_note .note_limit > ul .schedule > div {
  display: flex;
  align-items: center;
  gap: 4px;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(1) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 0.3s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(2) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 0.6s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(3) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 0.9s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(4) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 1.2s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(5) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 1.5s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(6) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 1.8s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(7) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 2.1s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle:nth-child(8) {
  animation: schedule_circle_anim 1s ease-in-out infinite;
  animation-delay: 2.4s;
  animation-duration: 4.8s;
}

.hrd_info_note .note_limit > ul .schedule .circle {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 1px dashed #D9D9D9;
  border-radius: 1000px;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 20px;
}

.hrd_info_note .note_limit > ul .schedule .circle.filled {
  background: #39BF50;
  color: #FFFFFF;
  border: 1px dashed #39BF50;
}

.hrd_info_note .hrd_bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.hrd_info_note .hrd_bento > li {
  position: relative;
  background: #FFFFFF;
  border-radius: 15px;
  padding-left: 0;
}
.hrd_info_note .hrd_bento > li::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.hrd_info_note .hrd_bento > li > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hrd_info_note .hrd_bento > li::before {
  display: none;
}

.hrd_info_note .hrd_bento > li.span2 {
  grid-column: span 2;
  height: 290px;
}

.hrd_info_note .hrd_bento > li.span2::after {
  padding-bottom: 290px;
}

.hrd_info_note .hrd_bento > li > div {
  padding: 16px;
  box-sizing: border-box;
  flex-direction: column;
}

.hrd_info_note .hrd_bento > li .iconBox {
  position: relative;
  width: 32px;
  background: #E3EEFF;
  border-radius: 5px;
  margin-bottom: 8px;
  color: #446CF9;
}
.hrd_info_note .hrd_bento > li .iconBox::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.hrd_info_note .hrd_bento > li .iconBox > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hrd_info_note .hrd_bento > li .bento_mainTit {
  font-size: 19.2px;
  line-height: 25.6px;
  font-weight: 700;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .hrd_info_note .hrd_bento > li .bento_mainTit {
    font-size: 16.8px;
    line-height: 28.8px;
    font-weight: 700;
  }
}

.hrd_info_note .hrd_bento > li > div span {
  font-size: 17.6px;
  line-height: 27.6px;
  font-weight: 500;
  min-height: 86.4px;
  text-align: center;
}
@media screen and (max-width: 980px) {
  .hrd_info_note .hrd_bento > li > div span {
    font-size: 14.3px;
    line-height: 20.4px;
    font-weight: 500;
  }
}

.hrd_info_note .hrd_bento > li > div ul li {
  font-size: 17.6px;
  line-height: 27.6px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .hrd_info_note .hrd_bento > li > div ul li {
    font-size: 14.3px;
    line-height: 20.4px;
    font-weight: 500;
  }
}

/* hrd 안내 > 유의사항 > 모사 */
.hrd_info_note_mosa {
  background: #2A2A2A;
  display: flex;
  padding: 24px;
  padding-left: 120px;
  align-items: center;
  gap: 24px;
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
  position: relative;
}

.hrd_info_note_mosa > .mosa_coverimg {
  font-size: 0;
  position: relative;
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
}

.hrd_info_note_mosa > .mosa_coverimg svg {
  width: 50%;
  z-index: -1;
  opacity: 0.5;
}
.hrd_info_note_mosa > .mosa_coverimg svg path {
  fill: #B1B1B1;
}
.hrd_info_note_mosa > .mosa_coverimg svg path.frame {
  fill: #5A5A5A;
}
.hrd_info_note_mosa > .mosa_coverimg svg path.check {
  fill: #FFFFFF;
}

.hrd_info_note_mosa > li.mosa {
  background: #FFFFFF;
  padding: 24px;
  flex: 1;
  border-radius: 15px;
  z-index: 10;
}

.hrd_info_note_mosa > li.mosa ul + .hrd_subtitBox {
  margin-top: 16px;
}

.hrd_info_note_mosa > li.mosa ul li + li {
  margin-top: 16px;
}

@media screen and (max-width: 980px) {
  .edu_content {
    padding: 0 16px;
  }
  .edu_conBox0 {
    background-size: contain;
  }
  /* 교육원 소개 */
  .edu_intro {
    height: 138px;
    background-size: cover;
  }
  .edu_intro::after, .edu_intro::before {
    display: none;
  }
  .edu_contitBox h3::before {
    height: 25px;
  }
  .edu_titbox p br {
    display: none;
  }
  .edu_conBox1 .edu_con ul {
    flex-wrap: wrap;
  }
  .edu_conBox1 .edu_con ul li {
    width: 100%;
    padding: 24px 0;
  }
  .edu_conBox2 ul {
    flex-wrap: wrap;
  }
  .edu_conBox2 ul li {
    width: 100%;
  }
  /* 찾아오시는 길 */
  #map {
    height: 200px !important;
  }
  .in_con .in_con_inner .locationBox .transport {
    flex-direction: column;
  }
  /* 훈련 제도 */
  .hrdcon + .hrdcon {
    margin-top: 24px !important;
  }
  ul.hrd_info li .hrd_subtitBox {
    margin-bottom: 16px;
  }
  .hrd_topBox .hrd_card .hrd_card_nm {
    font-size: 5vw;
    padding: 2.5vw;
  }
  .hrd_tabul {
    flex-wrap: wrap;
    gap: 5px !important;
  }
  .hrd_tabul .hrd_tabli {
    flex: 1 !important;
  }
  .hrd_tabs {
    margin-bottom: 2px;
    flex-wrap: wrap;
  }
  .hrd_infoinner .tabBox .hrd_tab {
    flex: 23% !important;
    text-align: center;
    padding: 0 16px !important;
  }
  .hrd_infoinner .tabBox .hrd_tab:hover {
    background: #F8F8F8;
    color: #878787;
  }
  .hrd_infoinner .tabBox .hrd_tab::after {
    display: none;
  }
  .tabBox .tabs > li::after {
    right: 0;
    display: none;
  }
  .hrd_topBox {
    padding: 24px 16px;
    padding-bottom: 50%;
  }
  .hrd_topBox .hrd_subStit .strong {
    font-size: 11vw;
  }
  .hrd_topBox .hrd_card {
    width: 46vw;
    height: 26vw;
    border-radius: 5px;
    top: auto;
    right: 16px;
    bottom: 0;
    transform: translate(0px, -16px);
  }
  .hrd_topBox .hrd_card.tomorrow_card .hrd_card_nm {
    font-size: 4.5vw;
    line-height: 4.5vw;
    padding: 16px;
  }
  .hrd_keyword ul {
    flex-wrap: wrap;
  }
  .hrd_keyword ul li {
    width: auto;
    text-align: center;
  }
  .hrd_infoBox {
    flex-direction: column;
  }
  ul.hrd_info li ul li br {
    display: none;
  }
  ul.hrd_info li ul li::before {
    transform: translateY(7.2px);
  }
  /* 훈련 제도 > 탭 */
  .hrd_infoinner .tabBox {
    margin-top: 24px;
    margin-bottom: 24px;
  }
  /* hrd 안내 > 소개 */
  .hrd_info_abt {
    width: 100%;
    margin-top: 0;
    margin-right: 0;
  }
  ul.hrd_info_abt li {
    margin: 16px 0 8px;
  }
  .hrd_infoBox .hrd_imginfo {
    width: 80%;
    right: 0;
    margin: auto;
    margin-top: 16px;
  }
  /* hrd 안내 > 지원대상 */
  .hrd_info_target {
    flex-direction: column;
    box-sizing: border-box;
    padding: 16px;
  }
  .hrd_info_target > li .symbol_box span {
    font-size: 100px;
  }
  /* hrd 안내 > 진행 */
  .hrd_info_process {
    display: flex;
    flex-direction: column;
  }
  .hrd_info_process > li {
    padding: 16px 16px 24px;
  }
  .hrd_info_process > li.process_cover p .process_cover_deco {
    width: 35%;
    right: 0;
    top: 0;
    transform: translate(0, -50%);
  }
  .hrd_info_process > li .price {
    margin-top: 8px;
    margin-bottom: 4px;
  }
  .hrd_info_target > li {
    padding: 16px;
  }
  .hrd_info_process li ul {
    min-height: auto;
  }
  .hrd_info_process > li::after {
    left: 50%;
    top: auto;
    bottom: 0;
    transform: translate(-50%, 50%) rotate(90deg);
  }
  /* hrd 안내 > 환급절차 */
  .hrd_info_refund {
    box-sizing: border-box;
    padding: 16px;
  }
  .hrd_info_refund .hrd_note {
    margin-top: 16px;
  }
  .hrd_info_refund .hrd_note > ul {
    padding: 16px;
  }
  .hrd_info_refund .refund_wrap {
    flex-direction: column;
    width: 100%;
  }
  .hrd_info_refund .refund_wrap > li {
    padding: 16px;
  }
  .hrd_info_refund .refund_wrap > li .process_arw {
    bottom: 0;
    top: auto;
    left: 50%;
    transform: translate(-50%, calc(100% + 4px)) rotate(90deg);
  }
  /* hrd 안내 > 유의사항 */
  .hrd_info_note {
    padding: 16px;
  }
  .hrd_info_note > li + li {
    margin-top: 24px;
  }
  .hrd_info_note .note_normal > ul {
    padding: 16px;
  }
  .hrd_info_note .note_limit > ul {
    flex-direction: column;
  }
  .hrd_info_note .note_limit > ul .schedule {
    margin-top: 16px;
    padding-left: 0;
  }
  .hrd_info_note .hrd_bento {
    grid-template-columns: repeat(1, 1fr);
  }
  .hrd_info_note .hrd_bento > li::after {
    padding-bottom: 60%;
  }
  .hrd_info_note .hrd_bento > li > div {
    padding: 8px;
  }
  .hrd_info_note .hrd_bento > li > div span {
    min-height: auto;
  }
  .hrd_info_note .hrd_bento > li > div span br {
    display: block;
  }
  .hrd_info_note .hrd_comp_table > ul li {
    flex-direction: column;
  }
  .hrd_info_note .note_limit > ul .schedule > div {
    justify-content: center;
    width: 100%;
  }
  .hrd_info_note .note_limit > ul .schedule .circle {
    position: relative;
    font-size: 14px;
    width: 100%;
    height: auto;
  }
  .hrd_info_note .note_limit > ul .schedule .circle::after {
    content: "";
    display: block;
    padding-bottom: 100%;
  }
  .hrd_info_note .note_limit > ul .schedule .circle > * {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hrd_info_note .hrd_bento > li.span2 {
    grid-column: auto;
    height: auto;
  }
  .hrd_info_note_mosa > .mosa_coverimg {
    display: flex;
    align-items: center;
    justify-content: center;
    left: 50%;
    top: 8px;
    transform: translateX(-50%);
  }
  .hrd_info_note_mosa > .mosa_coverimg svg {
    width: 35%;
  }
  .hrd_info_note_mosa {
    padding-left: 16px;
    padding: 16px;
    padding-top: 64px;
  }
}
/* 하단 버튼 (목록, 수강신청) */
.buttonBox {
  padding: 24px 0;
  display: flex;
  justify-content: center;
  gap: 8px;
}

.buttonBox > button {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .buttonBox > button {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.buttonBox > button:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}

.buttonBox > button.application {
  border: 1px solid #FF8E90;
  background: #F94447;
  color: #FFFFFF;
}

.buttonBox > button.application:hover {
  background: #f71316;
}

/* 나의 강의실 검색 */
.usr_search {
  margin-top: 16px;
  margin-bottom: 16px;
}

.usr_search > div {
  width: 100%;
  overflow: hidden;
  border-radius: 5px;
  border: 1px solid #eeeeee;
  box-sizing: border-box;
}

.usr_search > div .table_row {
  width: 100%;
}

.usr_search > div .table_row form {
  display: flex;
  flex-direction: column;
}

.usr_search > div .table_row ul {
  display: flex;
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
  overflow: hidden;
}

.usr_search > div .table_row ul:last-child {
  border-bottom: 0px;
}

.usr_search > div .table_row ul li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  background: #F8F8F8;
  display: flex;
  flex: 1;
  box-sizing: border-box;
  align-items: center;
  padding: 0 8px;
  box-sizing: border-box;
}
@media screen and (max-width: 980px) {
  .usr_search > div .table_row ul li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.usr_search > div .table_row ul li.area2 {
  flex: 2;
}

.usr_search > div .table_row ul li.btnBox {
  flex: none;
  padding: 0 8px;
}

.usr_search > div .table_row ul .head {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  padding: 16px 0;
}
@media screen and (max-width: 980px) {
  .usr_search > div .table_row ul .head {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.usr_search > div .table_row ul .con {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
}

.usr_search > div .table_row ul .con input {
  width: 100%;
  padding: 12px;
  border-radius: 5px;
  background: #FFFFFF;
}

.usr_search > div .table_row ul .con input::placeholder {
  color: #B1B1B1;
}

.usr_search > div .table_row ul .con select {
  width: 100%;
  padding: 12px;
  border-radius: 5px;
  border: none;
  outline: none;
}

.usr_search > div .usr_search_btn {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  padding: 8px 24px;
  color: #446CF9;
  background: #E3EEFF;
  transition: all 0.3s;
  border: 1px solid #AFE1FD;
  box-shadow: 0 0 4px rgba(5, 38, 127, 0.1);
}
@media screen and (max-width: 980px) {
  .usr_search > div .usr_search_btn {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.usr_search > div .usr_search_btn:hover {
  background: #446CF9;
  border: 1px solid #D9D9D9;
  color: #E3EEFF;
}
@media screen and (max-width: 980px) {
  .usr_search > div .usr_search_btn {
    padding: 8px;
  }
}

/* 게시판 리스트 스타일 */
.table_list {
  width: 100%;
  overflow: hidden;
  border-radius: 5px;
}

.table_list_board {
  border: 1px solid #eeeeee;
  box-sizing: border-box;
}

.table_list > ul {
  width: 100%;
  overflow: hidden;
  height: auto;
  display: flex;
  align-items: center;
  border-top: 1px solid #E3EEFF;;
}

.table_list > ul.none {
  padding: 40px 0 !important;
}

.table_list.mypage_inter > ul.none {
  padding: 41px 0 !important;
}

.table_list ul:first-child {
  border-top: none;
}

.table_list ul > ul:last-child {
  border-bottom: 0px;
}

.table_list ul li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #5A5A5A;
  display: block;
  justify-content: center;
  text-align: center;
  vertical-align: middle;
  width: 100%;
  flex: 1 1 auto;
  transition: all 0.3s;
  box-sizing: border-box;
/*  padding: 16px;*/
}
@media screen and (max-width: 980px) {
  .table_list ul li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.table_list ul.head:hover li {
  color: #5A5A5A;
}

.table_list ul:hover li {
  color: #446CF9;
}

.title_custom {
  display: flex;
  align-items: center;
}

.title_custom h3 {
  flex: 1;
}

.title_custom span.essential {
  margin-right: 4px;
}

.table_custom {
  margin-top: 16px;
}

.table_custom ul li {
  justify-content: left;
  padding: 0;
  flex: auto;
  text-overflow: clip;
}

.table_custom ul:hover li {
  color: #5A5A5A;
}

.table_custom ul:first-of-type {
  border-top: 1px solid #E3EEFF;
}

.table_custom ul:last-of-type {
  margin-bottom: 16px;
  border-bottom: 1px solid #E3EEFF;
}

.table_custom ul:first-of-type li.head, .table_custom ul.ul_custom li.head {
  width: 5.5%;
}

.table_custom ul:first-of-type li.con, .table_custom ul.ul_custom li.con {
  width: 75%;
}

.table_custom ul li.head {
  padding: 16px;
  width: 40%;
  background-color: #F5F8FF;
  color: #7084B7;
  font-weight: bold;
}

.table_custom ul li.head label .essential {
  color: red;
  margin-left: 4px;
}

.table_custom ul li.con {
  padding: 0 16px;
  text-align: left;
}

.table_custom ul li input {
  padding: 5px;
  /* text-align: center; */
  width: 42%;
  font-weight: 500;
  padding: 8px 0;
  border-bottom: 1px solid #eeeeee;
  color: #5A5A5A;
}

.table_custom ul li.input_detail input {
  width: 26%;
}

.table_custom ul li input:focus {
  border-bottom: 1px solid #000;
}

.table_custom ul li.input_detail select#sel_mail {
  padding-right: 30px;
  margin-left: 16px;
}

.table_custom ul li.con select:focus {
  outline: none;
  border: 1px solid #000
}

.table_custom ul.ul_textarea li {
  display: flex;
  justify-content: center;
  align-items: center;
}

.table_custom ul.ul_textarea li.head {
  height: 182px;
}

.table_custom ul.ul_custom li textarea {
  width: 100%;
  height: 150px;
  padding: 5px;
  box-sizing: border-box;
  border: 1px solid #ddd;
}

.checkbox_grp {
  display: flex;
  align-items: center;
  gap: 8px;
}

.checkbox_grp input {
  display: none;
}

.checkbox_grp input[id=inp_04]:checked + .all_c_icon {
  background: #446CF9;
}

.checkbox_grp input[type=checkbox] + label {
  display: inline-block;
  position: relative;
}

.checkbox_grp label {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}

.checkbox_grp .all_c_icon {
  position: relative;
  width: 24px;
  height: 24px;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  cursor: pointer;
  color: #5A5A5A;
}

.checkbox_grp .all_c_icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.checkbox_grp .all_c_icon > span svg path {
  fill: #878787;
}

.checkbox_grp input[id=inp_04]:checked + .all_c_icon svg path {
  fill: #FFFFFF;
}

.table_list ul li p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .table_list ul li p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.table_list ul li.left {
  text-align: left;
  justify-content: start;
}

.table_list ul li.li_idx {
  flex: 1 1 14%;
}

.table_list ul li.li_tit {
  flex: 1 1 auto;
  flex-grow: 1;
}

.table_list ul li.li_uploader {
  flex: 1 1 14.6%;
}

.table_list ul li.li_file {
  flex: 1 1 18.6%;
}

.table_list ul li.li_date {
  flex: 1 1 23%;
}

.table_list ul li.li_cnt {
  flex: 1 1 14.6%;
}

.table_list ul li > a {
  padding: 25px 8px 21px;
  box-sizing: border-box;
  cursor: pointer;
  width: 100%;
  height: 100%;
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.table_list ul li > a .reply_ico {
  transform: rotate(180deg);
  color: #878787;
}

.table_list ul.head {
  background: #F8F8F8;
  border-bottom: 1px dashed #eeeeee;
}

.table_list ul.head li {
  box-sizing: border-box;
  padding: 16px 0;
  font-weight: bold;
}

.table_list ul.head li br {
  display: none;
}

.table_list.table_list_board ul.noti {
  background: #F5F8FF;
}

.table_list.table_list_board ul.noti li {
  font-weight: bold;
}

.table_list.table_list_board .none_result {
  margin-top: 0px !important;
}

.table_list.table_list_board .none_result li {
  box-sizing: border-box;
}

.none_result {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  box-sizing: border-box;
  padding: 40px;
  text-align: center;
  color: #5A5A5A;
  margin-top: 30px;
  cursor: default !important;
}
@media screen and (max-width: 980px) {
  .none_result {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 게시판 뷰 */
.table_view {
  width: 100%;
  padding: 16px 0;
  border-radius: 15px;
  box-sizing: border-box;
}

.table_view .titleBox {
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 16px;
  position: relative;
  padding: 16px;
  background: #fafafa;
}

.table_view .titleBox::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: #39BF50;
  width: 2px;
}

.table_view .titleBox h3.tit {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .table_view .titleBox h3.tit {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.table_view .titleBox ul.info {
  width: 100%;
  overflow: hidden;
  display: flex;
  gap: 24px;
}

.table_view .titleBox ul.info li {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #5A5A5A;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  display: flex;
  gap: 8px;
  align-items: center;
  white-space: nowrap;
  overflow: visible;
  text-overflow: ellipsis;
}
@media screen and (max-width: 980px) {
  .table_view .titleBox ul.info li {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.table_view .titleBox ul.info li::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #878787;
  z-index: 10;
}

.table_view .titleBox ul.info li p {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.table_view .titleBox ul.info li::after {
  content: "";
  display: block;
  position: absolute;
  right: -12px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #D9D9D9;
}

.table_view .titleBox ul.info li:last-child::after {
  background: none;
}

.table_view .titleBox ul.info li span {
  color: #5A5A5A;
  border-radius: 5px;
  font-weight: 700;
}

.table_view .fileBox {
  overflow: hidden;
  border-top: 1px solid #eeeeee;
  border-bottom: 1px solid #eeeeee;
  color: #5A5A5A;
  display: flex;
  align-items: center;
}

.table_view .fileBox p.lab {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: inline-block;
  box-sizing: border-box;
  padding: 16px 24px;
  position: relative;
}
@media screen and (max-width: 980px) {
  .table_view .fileBox p.lab {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.table_view .fileBox p.lab:after {
  position: absolute;
  content: "";
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 30%;
  background: #eeeeee;
}

.table_view .fileBox p.inp {
  display: inline-flex;
  align-items: flex-start;
  flex-direction: column;
  box-sizing: border-box;
  padding: 16px 24px;
  color: #5A5A5A;
  flex: 1;
}

.table_view .fileBox p.inp > span {
  flex: 1;
}

.table_view .fileBox p.inp > .curwrap {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
}

.table_view .fileBox p.inp > .curwrap a {
  margin-left: auto;
  width: 100%;
  display: inline-block;
  text-align: end;
}

.table_view .fileBox p.inp > .curwrap button:hover {
  color: #446CF9;
}

.table_view .fileBox p.inp a {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .table_view .fileBox p.inp a {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.table_view .view_con {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  overflow: hidden;
  box-sizing: border-box;
  padding: 0 16px;
}
@media screen and (max-width: 980px) {
  .table_view .view_con {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.table_view #board_in_frm .view_con {
  padding: 0;
  margin-bottom: 16px;
}

.table_view .view_con.view_con_inner {
  padding: 0 16px;
}

.table_view .view_con > p {
  padding: 0 24px;
}

.table_view .fileBox + .view_con {
  margin-top: 16px;
}

.table_view .view_con img {
  width: auto !important;
  max-width: 100% !important;
}

/* 게시판 뷰 > 편집 */
.table_view.table_input .titleBox h3.tit {
  display: flex;
  margin-bottom: 0;
  gap: 4px;
}

.table_view.table_input .titleBox h3.tit select {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  outline: none;
}
@media screen and (max-width: 980px) {
  .table_view.table_input .titleBox h3.tit select {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.table_view.table_input .titleBox h3.tit input {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #2A2A2A;
  width: 100%;
}
@media screen and (max-width: 980px) {
  .table_view.table_input .titleBox h3.tit input {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

/* 이전글 / 다음글, 목록 버튼 */
.buttonWrap {
  display: flex;
  justify-content: end;
  padding: 16px 0;
  gap: 16px;
}

button.list {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  button.list {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
button.list:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
@media screen and (max-width: 980px) {
  button.list {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.buttonWrap > div {
  display: flex;
  gap: 16px;
  margin-right: auto;
}

button.prev_li, button.next_li {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #5A5A5A;
  display: flex;
  align-items: center;
  gap: 4px;
}
button.prev_li > span, button.next_li > span {
  position: relative;
  display: inline-block;
  width: 32px;
  cursor: pointer;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
button.prev_li > span::after, button.next_li > span::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
button.prev_li > span > *, button.next_li > span > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
button.prev_li > span:hover, button.next_li > span:hover {
  background: #D9D9D9;
}
button.prev_li:hover > span, button.next_li:hover > span {
  background: #D9D9D9;
}
@media screen and (max-width: 980px) {
  button.prev_li, button.next_li {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
button.prev_li > span, button.next_li > span {
  margin-top: 2px;
}

button.in {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  button.in {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
button.in:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
button.in:hover {
  background: #05267F;
  color: #FFFFFF;
}

button.delete {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
  background: none;
  border: 1px solid #FF8E90;
  color: #F94447;
}
@media screen and (max-width: 980px) {
  button.delete {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
button.delete:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
button.delete:hover {
  background: #05267F;
  color: #FFFFFF;
}
button.delete:hover {
  background: rgba(255, 142, 144, 0.2);
  color: #F94447;
  border: 1px solid #FF8E90;
}

/* 자주 묻는 질문 */
.accordion {
  width: 100%;
  overflow: hidden;
}

.accordion ul {
  width: 100%;
  overflow: hidden;
}

.accordion ul li {
  width: 100%;
  cursor: pointer;
  border-bottom: 1px solid #F5F8FF;
  position: relative;
}

.accordion ul li:after {
  position: absolute;
  content: "";
  width: 0%;
  height: 1px;
  left: 0;
  bottom: 0;
  background: linear-gradient(to right, #CED8F4, #446CF9);
}

.accordion ul li:last-child {
  border-bottom: none;
}

.accordion ul li:hover:after {
  animation: width_ani 0.7s forwards;
}

.accordion ul li.on:after {
  display: none;
}

.accordion ul li.on:last-child {
  border-bottom: 1px solid #F5F8FF;
}

.accordion ul li > p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  box-sizing: border-box;
  padding: 24px 16px;
  position: relative;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 980px) {
  .accordion ul li > p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.accordion ul li > p:after {
  position: absolute;
  content: "\f13a";
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 20px;
  color: #D9D9D9;
  font-family: "FontAwesome";
}

.accordion ul li > p span.q {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 8px;
  background: #E9FFDC;
  color: #3fa900;
  border-radius: 1000px;
  width: 2.4vw;
}
.accordion ul li > p span.q::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.accordion ul li > p span.q > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.accordion ul li > p span.tit {
  display: inline-block;
  word-break: break-all;
}

.accordion ul li.on > p:after {
  content: "\f139";
  color: #2A2A2A;
}

.accordion ul li.on > p {
  color: #2A2A2A;
}

.accordion ul li.on div.answer {
  border-top: 1px solid #F8F8F8;
}

.accordion ul li.on div.answer img {
  width: 90% !important;
}

.accordion ul li div.answer {
  display: none;
  box-sizing: border-box;
  padding: 16px calc(24px + 2.4vw);
  background: #f8f8f8;
}

.accordion ul li div.answer.on {
  display: block;
}

.accordion ul li div.answer p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #878787;
  box-sizing: border-box;
}
@media screen and (max-width: 980px) {
  .accordion ul li div.answer p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.accordion ul li div.answer img {
  width: 100% !important;
}

/* 1:1 답변뷰 / 학습 Q&A */
.replyTitle {
  margin-top: 16px;
}

.replyTitle, .classInfo_reply {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  display: flex;
  gap: 8px;
  align-items: center;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .replyTitle, .classInfo_reply {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.classInfo_reply {
  justify-content: space-between;
  display: flex;
}

.classInfo_reply .info {
  display: none;
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #5A5A5A;
  padding: 4px;
  border: 1px solid #AFE1FD;
  align-self: end;
}
@media screen and (max-width: 980px) {
  .classInfo_reply .info {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

@media screen and (max-width: 980px) {
  /* 나의 강의실 검색 */
  .usr_search > div .table_row ul li {
    padding: 0 8px 0 0;
  }
  /* 게시판 리스트 스타일 */
  .table_list ul.head li br {
    display: block;
  }
  .table_list.table_list_board ul li.li_idx,
  .table_list.table_list_board ul li.li_file,
  .table_list.table_list_board ul li.li_cnt {
    display: none;
  }
  .usr_search > div .table_row ul .head {
    width: 64px;
  }
  .usr_search > div .table_row ul .con input {
    width: 100%;
  }
  .table_view .view_con {
    padding: 0;
  }
  /* 게시판 뷰 */
  .table_view .titleBox ul.info {
    flex-direction: column;
    gap: 8px;
  }
  .table_view .view_con.view_con_inner {
    padding: 0;
  }
  .table_view .fileBox p.lab {
    display: none;
  }
  .table_view .fileBox p.inp {
    padding: 8px;
    width: 100%;
  }
  .table_view .fileBox p.inp input {
    width: 100%;
  }
  /* 자주 묻는 질문 */
  .accordion {
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
  }
  .accordion ul li:hover:after {
    animation: none;
  }
  .accordion ul li > p {
    padding: 8px 0;
  }
  .accordion ul li > p span.q {
    width: 8vw;
  }
  .accordion ul li > p:after {
    font-size: 4vw;
  }
  .accordion ul li div.answer {
    padding: 16px calc(24px + 4vw);
  }
  /* 게시판 리스트 스타일 */
  .mypage_qna_custom > ul {
    position: relative;
  }
  .table_list > ul {
    flex-wrap: wrap;
    padding: 16px 0;
  }
  .table_custom > ul {
    padding: 0;
    border-top: none;
  }
  .table_custom ul li {
    justify-content: center;
  }
  .table_custom ul li.con {
    text-align: center;
    padding: 16px;
    border-bottom: 1px solid #E3EEFF;
  }
  .table_custom ul:first-of-type {
    flex-direction: column;
  }
  .table_custom ul:first-of-type li.head {
    border-top: 1px solid #E3EEFF;
  }
  .table_custom ul:first-of-type li.head, .table_custom ul.ul_custom li.head {
    display: flex;
    align-items: center;
    width: 100%;
  }
  .table_custom ul.ul_custom {
    border-bottom: 1px solid #E3EEFF;
    flex-direction: column;
  }
  .table_custom ul.ul_textarea li.head {
    height: auto;
  }
  .table_custom ul.ul_custom li.con {
    border-bottom: none;
  }
  .table_custom > ul.ul_custom:last-child {
    border-bottom: 1px solid #E3EEFF;
  }
  .table_custom ul:first-of-type li.con, .table_custom ul.ul_custom li.con {
    width: 100%;
  }
  .table_custom ul:first-of-type li.head, .table_custom ul:first-of-type li.con {
    width: 100%;
  }
  .table_list > ul:not(.head):first-child {
    border-top: none;
  }
  .table_list > ul:last-child {
    border-bottom: none;
  }
  .table_list > ul.head {
    display: none;
  }
  .table_list > ul.none {
    background: #F8F8F8;
    border-radius: 5px;
    border: 1px solid #eeeeee;
    box-sizing: border-box;
    color: #5A5A5A;
  }
  .table_list ul li {
    padding: 0 8px;
  }
  .table_list ul li > a {
    padding: 0;
  }
  .table_list ul.head li {
    padding: 16px 8px;
  }
  .table_list ul li.li_tit {
    padding: 0 8px;
    width: 100%;
    font-weight: bold;
    margin-bottom: 4px;
  }
  .table_list ul li.li_uploader {
    text-align: left;
    max-width: 75.2px;
    box-sizing: border-box;
    border-right: 1px solid #eeeeee;
  }
  .table_list ul li.li_file {
    text-align: left;
    max-width: 75.2px;
    box-sizing: border-box;
  }
  .table_list ul li.li_date {
    text-align: left;
    max-width: calc(100% - 80px);
    box-sizing: border-box;
  }
  .mypage_qna_custom li.li_file {
    position: absolute;
    top: 33px;
    left: 8px;
    padding: 0;
  }
  .mypage_qna_custom ul li.li_date_custom {
    text-align: right;
    position: absolute;
    top: 16px;
    right: 0px;
  }
  .mypage_qna_custom ul li.li_tit {
    margin-bottom: 0;
    text-align: left;
  }
  .mypage_qna_custom ul li > a {
    max-width: 230px;
  }
  /* 게시판 뷰 > 편집 */
  .table_view .titleBox ul.info li span {
    white-space: nowrap;
  }
}
/* 과정리스트 */
.listView {
  margin-top: 24px;
}

.listView .list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.lec_box {
  border: 1px solid #dfdfdf;
  cursor: pointer;
}

.lec_box > a {
  display: block;
}

.lec_box .box > .img {
  position: relative;
  padding-bottom: 56.25%;
  margin-bottom: 16px;
}

.lec_box .box > .img > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  object-fit: fill;
  height: 100%;
  width: 100%;
}

.lec_box .box .text {
  padding: 0 16px 16px;
}

.lec_box .box .text .title {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: #2A2A2A;
  min-height: 48px;
  max-height: 48px;
  border-bottom: 1px solid #F8F8F8;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .lec_box .box .text .title {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.lec_box .box .text .bottomBox {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px;
}

.lec_box .box .text .bottomBox .info {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.lec_box .box .text .bottomBox .info > div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.lec_box .box .text .bottomBox .info > div .label {
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
  display: flex;
  gap: 8px;
  align-items: center;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .lec_box .box .text .bottomBox .info > div .label {
    font-size: 13px;
    line-height: 17px;
    font-weight: 700;
  }
}

.lec_box .box .text .bottomBox .info > div .label .tit br {
  display: none;
}

.lec_box .box .text .bottomBox .info > div > span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .lec_box .box .text .bottomBox .info > div > span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.lec_box .box .text .bottomBox .tags > ul {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  max-height: 26px;
  overflow: hidden;
}

.lec_box .box .text .bottomBox .tags .tag {
  font-size: 12px !important;
  line-height: 12px !important;
  font-weight: 500 !important;
  padding: 6px;
  background: #eeeeee;
  color: #878787;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
   .lec_box .box .text .bottomBox .tags {display:none;}

  .lec_box .box .text .bottomBox .tags .tag {
    font-size: 12px !important;
    line-height: 12px !important;
    font-weight: 500 !important;
  }
}

/* 과정리스트 > 미리보기 */
.lec_box .box {
  transition: all 0.3s;
}

.lec_box .box:hover {
  box-shadow: 0 0 8px rgba(42, 42, 42, 0.2);
}

.lec_box .box .img .preview_btn {
  display: none;
  position: absolute;
  bottom: 8px;
  right: 8px;
}

.lec_box .box:hover .img .preview_btn {
  display: block;
}

.lec_box .box .img .preview_btn > a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 1000px;
  background: rgba(42, 42, 42, 0.5);
}

.lec_box .box .img .preview_btn > a img {
  margin-left: 3px;
}

/* 과정리스트 > 없을 경우 */
.list_none {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  box-sizing: border-box;
  padding: 40px;
  text-align: center;
  background: #F8F8F8;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  font-weight: 400;
  grid-column: 1/-1;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .list_none {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 과정 상세페이지 */
.details .topBox .conBox {
  display: flex;
  gap: 20px;
}

.details .topBox .conBox .img {
  width: 340px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.details .topBox .conBox .img .img_wrp {
  position: relative;
}

.details .topBox .conBox .img .img_wrp .preview_btn {
  position: absolute;
  right: 8px;
  bottom: 8px;
}

.details .topBox .conBox .img .img_wrp .preview_btn > a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 1000px;
  background: rgba(42, 42, 42, 0.5);
}

.details .topBox .conBox .img .img_wrp .preview_btn > a img {
  margin-left: 4px;
  width: 50%;
}

.details .topBox .conBox .img img {
  width: 100%;
}

.details .topBox .conBox .img .lec_btns {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.details .topBox .conBox .img .lec_btns li button {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 18px;
  font-weight: 400;
  transition: all 0.3s;
  padding: 16px 0;
  width: 100%;
  background: #F94447;
  border: 1px solid #FF8E90;
  color: #FFFFFF;
  box-sizing: border-box;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .details .topBox .conBox .img .lec_btns li button {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
  }
}

.details .topBox .conBox .img .lec_btns_online li button {
  margin-top: 16px;
}

.details .topBox .conBox .img .lec_btns li button:hover {
  background: #f71316;
}

.details .topBox .conBox .img .lec_btns li button.hrd_net {
  border: 1px solid #F94447;
  color: #F94447;
  background: #FFFFFF;
}

.details .topBox .conBox .img .lec_btns li button.hrd_net:hover {
  background: rgba(249, 68, 71, 0.2);
}

.details .topBox .conBox .infoBox {
  flex: 1;
}

.details .topBox .conBox .infoBox .info {
  box-sizing: border-box;
  padding: 24px;
  border: 1px solid #dfdfdf;
  border-radius: 15px;
  height: 100%;
}

.details .topBox .conBox .infoBox .info .d_list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.details .topBox .conBox .infoBox .info .d_list > li {
  display: flex;
  align-items: center;
}

.details .topBox .conBox .infoBox .info .d_list > li .title {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  min-height: 37px;
  font-weight: 600;
  color: #7084B7;
  max-width: 90px;
  min-width: 90px;
  position: relative;
  margin-right: 16px;
}
@media screen and (max-width: 980px) {
  .details .topBox .conBox .infoBox .info .d_list > li .title {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.details .topBox .conBox .infoBox .info .d_list > li .title::after {
  content: "";
  display: block;
  position: absolute;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #E3EEFF;
}

.details .topBox .conBox .infoBox .info .d_list > li .con {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  flex: 1;
}
@media screen and (max-width: 980px) {
  .details .topBox .conBox .infoBox .info .d_list > li .con {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.details .topBox .conBox .infoBox .info .d_list > li .con.money {
  color: #2A2A2A;
}

.details .topBox .conBox .infoBox .info .d_list > li .con.money #cls_dprice {
  display: flex;
}

.details .topBox .conBox .infoBox .info .d_list > li .con.money #cls_dprice > div {
  color: #39BF50;
}

/* 과정 상세페이지 > 과정명 */
.details {
  margin-top: 24px;
}

.details .topBox .titBox {
  align-items: center;
  margin-bottom: 8px;
}

.details .topBox .titBox::after {
  display: none;
}

.details .topBox .titBox .name {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
}
@media screen and (max-width: 980px) {
  .details .topBox .titBox .name {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.details .topBox .titBox .liked {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  padding-left: 16px;
  color: #2A2A2A;
  cursor: pointer;
}

.details .topBox .titBox .liked::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 1px;
  background: #D9D9D9;
}

.details .topBox .titBox .liked:hover i.fa-solid {
  opacity: 1;
}

.details .topBox .titBox .liked.on i.fa-solid {
  opacity: 1;
}

.details .topBox .titBox .liked i {
  color: #F94447;
}

.details .topBox .titBox .liked i.fa-solid {
  position: absolute;
  opacity: 0;
}

.details .topBox .titBox .liked span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .details .topBox .titBox .liked span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}



.details .topBox .tags ul {margin-bottom:20px;display:flex; flex-flow:row nowrap; gap:8px;}
.details .topBox .tags ul li {padding:6px; background:#eeeeee; color:#878787; font-size:12px; border-radius:5px;}






/* 과정 상세 > 과정 소개 */
.contentBox .tab-content .intro .icon {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #7084B7;
  display: flex;
  padding: 16px;
  background: #F5F8FF;
}
@media screen and (max-width: 980px) {
  .contentBox .tab-content .intro .icon {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.contentBox .tab-content .intro .txt {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #2A2A2A;
  padding: 24px 16px;
  line-height: initial;
}
@media screen and (max-width: 980px) {
  .contentBox .tab-content .intro .txt {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 과정 자료 */
.contentBox .tab-content {
  display: none;
}

.contentBox .tab-content.current {
  display: block;
}

.contentBox .tab-content .data {
  background: #F8F8F8;
  display: flex;
  gap: 16px;
  padding: 24px 16px;
}

.contentBox .tab-content .data > li {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  flex: 1;
  gap: 8px;
  padding: 24px;
  border-radius: 15px;
  box-shadow: 0 2px 8px rgba(42, 42, 42, 0.1);
  background: linear-gradient(0deg, #F5F8FF 25%, #FFFFFF 25%);
  overflow: auto;
}

.contentBox .tab-content .data > li .titBox {
  align-items: center;
  gap: 16px;
  display: flex;
  width: 100%;
  justify-content: flex-start;
}

.contentBox .tab-content .data > li .titBox .icon {
  font-size: 0;
  border: 1px solid #CED8F4;
  border-radius: 5px;
  box-shadow: 0 0 4px #ced8f4;
  position: relative;
}

.contentBox .tab-content .data > li .titBox .icon .marked {
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(50%, -50%);
}

.contentBox .tab-content .data > li .titBox .icon span {
  position: relative;
  display: inline-block;
  width: 32px;
  font-size: 15px;
  color: #7084B7;
}
.contentBox .tab-content .data > li .titBox .icon span::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.contentBox .tab-content .data > li .titBox .icon span > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contentBox .tab-content .data > li .titBox .title {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #7084B7;
}
@media screen and (max-width: 980px) {
  .contentBox .tab-content .data > li .titBox .title {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.contentBox .tab-content .data > li .con {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #7084B7;
  display: flex;
  width: 100%;
  justify-content: end;
}
@media screen and (max-width: 980px) {
  .contentBox .tab-content .data > li .con {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.contentBox .tab-content .data > li .con a {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 과정 상세 > 수강 기간 */
.infoBox .selectBox2 .optionBox li {
  display: flex;
}

.infoBox .selectBox2 .optionBox li:hover {
  background: #F8F8F8;
}

.infoBox .selectBox2 .optionBox li > span {
  display: block;
  flex: 1.35;
}

.infoBox .selectBox2 .optionBox li > span.date {
  color: #446CF9;
}

.infoBox .selectBox2 .optionBox li > span:first-child {
  flex: 2;
}

/* 과정 상세 > 수료 기준 */
.container {
  width: 100%;
  margin: 0 auto;
}

.table-container .table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 16px;
}

.table-container .table tr {
  border-bottom: 1px solid #E3EEFF;
}

.table-container .table tr:last-child {
  border-bottom: 2px solid #E3EEFF;
}

.table-container .table tr.tr_body {
  display: flex;
}

.table-container .table tr.tr_body td {
  flex: 1;
}

.table-container th, .table-container td {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  text-align: center;
  padding: 16px;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .table-container th, .table-container td {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.table-container th br, .table-container td br {
  display: none;
}

.table-container th {
  background-color: #F5F8FF;
  color: #7084B7;
  font-weight: bold;
}

.table-container .sub_titback {
  background: #FFFFFF;
  color: #5A5A5A;
  font-weight: bold;
}

.table-container .tr_body_head td {
  font-weight: bold;
}

.table-container td.bold {
  font-weight: bold;
}

.td_w {
  width: 50%;
}

/* 과정 상세 > 콘텐츠 차시 */
.con_table {
  display: flex;
  flex-direction: column;
  border-top: 1px solid #D9D9D9;
}

.con_table li {
  display: flex;
  box-sizing: border-box;
  width: 100%;
  border-bottom: 1px solid #E3EEFF;
  padding: 16px 0;
}

.con_table li:last-child {
  margin-bottom: 0px;
}

.con_table li span.num {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #7084B7;
  min-width: 70px;
  font-weight: bold;
}
@media screen and (max-width: 980px) {
  .con_table li span.num {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.con_table li span.name {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .con_table li span.name {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 수강 신청 > 결제 페이지 */
.view_list_m {
  display: none;
}

.view_list {
  border: 1px solid #eeeeee;
}

.view_list ul {
  display: flex;
}

.view_list ul li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  box-sizing: border-box;
  align-items: center;
  justify-content: center;
  border-right: 1px solid #eeeeee;
  padding: 16px;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .view_list ul li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.view_list ul li:last-child {
  border-right: none;
}

.view_list .head {
  background: #F8F8F8;
}

.view_list ul.head li {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #5A5A5A !important;
}
@media screen and (max-width: 980px) {
  .view_list ul.head li {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.view_list ul li.left {
  text-align: left;
  justify-content: flex-start;
}

.view_list ul .li_01 {
  flex: 4;
}

.view_list ul li.li_02 {
  flex: 1;
}

.view_list ul li.li_03 {
  flex: 2.5;
}

.view_list ul li.li_04 {
  flex: 1.5;
}

.view_list ul li.li_05 {
  flex: 1.5;
  color: #39BF50;
}

.view_list ul li > span {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.view_list ul li input {
  border: 1px solid #eeeeee;
  padding: 8px;
}

.view_list ul li > span.point {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .view_list ul li > span.point {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.view_list ul li {
  flex: 3;
  gap: 8px;
}

.view_list ul + ul {
  border-top: 1px solid #eeeeee;
}

.view_list ul li.head {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  flex: none;
  width: 140px;
  box-sizing: border-box;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .view_list ul li.head {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.all_price {
  overflow: hidden;
  text-align: center;
  box-sizing: border-box;
  padding: 24px 0;
  margin-top: 16px;
  border-top: 1px dashed #eeeeee;
  border-bottom: 1px solid #eeeeee;
  text-align: right;
}

.all_price p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .all_price p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.all_price p span.price_label {
  margin-right: 8px;
}

.all_price p span.price {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #39BF50;
}
@media screen and (max-width: 980px) {
  .all_price p span.price {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}



.agreeBox {
  margin-top: 16px;
  padding: 24px;
  border: 4px solid #eeeeee;
  border-radius: 5px;
}

.agreeBox h3 label {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .agreeBox h3 label {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.apply_wrap .now_tit {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #2A2A2A;
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 24px;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .apply_wrap .now_tit {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.apply_wrap .now_tit input[type=checkbox] {
  appearance: none; /* 기본 체크박스 스타일을 숨김 */
  -webkit-appearance: none; /* 웹킷 브라우저용 */
  -moz-appearance: none; /* 파이어폭스 브라우저용 */
  appearance: none; /* 기본 체크박스 스타일을 숨김 */
  width: 16px;
  height: 16px;
  background: #FFFFFF;
  border-radius: 1000px;
  position: relative;
  cursor: pointer;
}

.apply_wrap .now_tit input[type=checkbox]::after {
  content: "";
  display: block;
  position: absolute;
  top: -4px;
  right: -4px;
  bottom: -4px;
  left: -4px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  border-radius: 1000px;
  box-shadow: inset 0 4px 1px rgba(42, 42, 42, 0.1);
  z-index: -1;
}

.apply_wrap .now_tit input[type=checkbox]::before {
  content: "";
  display: block;
  position: absolute;
  top: -4px;
  right: -4px;
  bottom: -4px;
  left: -4px;
  background: #E3EEFF;
  border-radius: 1000px;
  z-index: -2;
  transition: all 0.3s;
  animation: checkbox_anim 1s linear infinite;
}

.apply_wrap .now_tit input[type=checkbox]:checked {
  background-color: #446CF9;
  border-color: #446CF9;
}

.apply_wrap .icon {
  width: 8px;
}

@media screen and (max-width: 980px) {
  /* 과정 리스트 */
  .listView .list {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .lec_box .box .text {
    padding: 0 8px 8px;
  }
  .lec_box .box .text .title {
    min-height: 48px;
    max-height: 48px;
  }
  .lec_box .box .text .bottomBox .info > div .label img {
    width: 18px;
  }
  .lec_box .box .text .bottomBox .info > div .label .tit br {
    display: block;
  }
  .lec_box .box .img .preview_btn {
    display: block;
  }
  .lec_box .box .img .preview_btn > a {
    width: 8vw;
    height: 8vw;
  }
  .lec_box .box .text .bottomBox .info > div .label .tit {
    min-width: 32.5px;
  }
  /* 상세페이지 */
  .details .topBox .conBox {
    flex-direction: column;
    gap: 16px;
  }
  .details .topBox .conBox .img {
    width: 100%;
  }
  .details .topBox .titBox .liked {
    order: 1;
    padding-left: 0;
    width: 100%;
    justify-content: start;
    margin-bottom: 8px;
  }
  .details .topBox .titBox .liked::after {
    display: none;
  }
  .details .topBox .titBox .liked i {
    font-size: 12px;
  }
  .details .topBox .titBox .name {
    width: 100%;
    order: 2;
  }
  .details .topBox .conBox .img .lec_btns {
    margin-top: 16px;
  }
  .details .topBox .conBox .infoBox .info {
    min-height: auto;
  }
  /* 과정 상세 > 과정 소개 */
  .contentBox .tab-content .intro .txt {
    line-height: initial;
  }
  /* 과정 상세 > 수강 기간 */
  .infoBox .selectBox2 .optionBox li {
    flex-direction: column;
  }
  /* 과정 상세 > 수료 기준 */
  .table-container th, .table-container td {
    margin: auto;
  }
  .table-container th br, .table-container td br {
    display: block;
  }
  /* 수강 신청 */
  .view_list {
    display: none;
  }
  .view_list_m {
    display: block;
  }
  .view_list_m ul {
    flex-direction: column;
  }
  .view_list ul + ul {
    flex-direction: column;
  }
  .view_list ul li {
    border-right: none;
  }
  .view_list ul li.head {
    flex: 1;
    width: auto;
  }
  .view_list_m ul li br {
    display: none;
  }
  .agreeBox {
    padding: 24px 16px;
  }
  .apply_wrap .now_tit {
    margin-top: 16px;
    margin-bottom: 16px;
  }
  .apply_wrap .now_tit input[type=checkbox] {
    width: 8px;
    height: 8px;
  }
}
.m_contentBox {
  display: none;
}


.m_pay_way {display:block;}
@media screen and (max-width: 980px){
	.m_pay_way ul {flex-direction:column;}
}




/* 탭 메뉴 */
.tab_menu {
  flex-direction: column;
  display: flex;
  gap: 16px;
  border-radius: 5px;
  margin-bottom: 16px;
}

.titBox + .tab_menu {
  margin-top: 16px;
}

.toggleSwitch_wrapper {
  display: flex;
  justify-content: end;
}

.toggleSwitch_wrapper .toggleSwitch {
  display: flex;
  padding: 4px;
  background: #F8F8F8;
  border-radius: 7px;
}

.toggleSwitch_wrapper .toggleSwitch .toggleButton {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  cursor: pointer;
  border-radius: 5px;
  color: #878787;
  display: flex;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .toggleSwitch_wrapper .toggleSwitch .toggleButton {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.toggleSwitch_wrapper .toggleSwitch .toggleButton.active {
  background: #FFFFFF;
  box-shadow: 0 0 4px rgba(42, 42, 42, 0.1);
  color: #446CF9;
}

.tab_menu > ul {
  display: flex;
  border-top: 1px solid #F5F8FF;
}

.tab_menu > ul li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  color: #5A5A5A;
  position: relative;
  cursor: pointer;
  padding: 16px 0px;
}
@media screen and (max-width: 980px) {
  .tab_menu > ul li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.tab_menu > ul li:has(a) {
  padding: 0;
}

.tab_menu > ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px 0px;
}

.tab_menu > ul li::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #F5F8FF;
}

.tab_menu > ul li:not(.current)::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 2px;
  background: #CED8F4;
  z-index: 10;
}

.tab_menu > ul li:hover::before {
  animation: tab_active_anim 1s forwards;
}

.tab_menu > ul li.current {
  background: #F5F8FF;
  color: #446CF9;
}

.tab_menu > ul li.current::after {
  background: #446CF9;
}

/* 탭 내용 */
.content .tab-content {
  display: none;
}

.content .tab-content.current {
  display: block;
}

/* 과정 목록 */
.conlist h3 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
  margin-top: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .conlist h3 {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.table_list ul li .progress {
  display: block;
  height: 4px;
  background: #AEF483;
  border-radius: 1000px;
  border: 4px solid #E9FFDC;
}

.table_list ul li .progress .progress-bar {
  background: #39BF50;
  height: 100%;
  position: relative;
  border-radius: 1000px;
}

.table_list ul li .progress .progress-bar::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 1000px;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  mix-blend-mode: overlay;
  opacity: 0.5;
  background: repeating-linear-gradient(45deg, #FFFFFF, #FFFFFF 10px, #39BF50 0, #39BF50 20px);
}

.table_list ul li .score_more {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  gap: 8px;
  font-weight: bold !important;
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: center;
  color: #446CF9;
}
@media screen and (max-width: 980px) {
  .table_list ul li .score_more {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

/* 마이페이지 테이블 */
.mypage_table {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .mypage_table {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.mypage_table ul li {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mypage_table ul li.li_01 {
  flex: 1 1 12.3%;
}

.mypage_table ul li.li_03 {
  flex: 1 1 35%;
}

.mypage_table ul li.li_04 {
  flex: 1 1 35%;
}

.mypage_table ul li.li_stat {
  flex: 1 1 20%;
}

.mypage_table ul li.li_06 {
  flex: 1 1 12.3%;
}

/* 마이페이지 테이블 > 수강 상태 */
li.li_stat > span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 4px 8px;
  border-radius: 1000px;
  align-self: center;
}
@media screen and (max-width: 980px) {
  li.li_stat > span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

li.li_stat .studying {
  background: #AEF483;
  color: #1c3f06;
}

li.li_stat .delete {
  background: #FF8E90;
  color: #5b0002;
}

li.li_stat .wait {
  background: #D9D9D9;
  color: #404040;
}

li.li_stat .study_cancle {
  color: #F94447;
  border: 1px solid #FF8E90;
  background: rgba(249, 68, 71, 0.1);
  border-radius: 5px;
  align-self: center;
  padding: 2px 4px;
}
li.li_stat .study_cancle:hover {
  background: rgba(249, 68, 71, 0.4);
  border: 1px solid #FF8E90;
  color: #F94447;
}

li.li_stat .completion {
  background: #AFE1FD;
  color: #034d77;
}

li.li_stat .un_completion {
  background: #7084B7;
  color: #F5F8FF;
}

.table_score {
  display: flex;
  flex-direction: column;
}

.table_score > .head {
  display: flex;
  border-top: 1px solid #B1B1B1 !important;
  border-bottom: 1px solid #D9D9D9 !important;
}

.table_score .score {
  width: 100%;
  display: flex;
  border-bottom: 1px solid #D9D9D9;
}

.table_score .score.score_calced li {
  font-weight: bold;
}

.table_score .score:last-child {
  border-bottom: none;
}

.table_score .score li.head.doc_head {
  background: #ebebeb;
  color: #5A5A5A;
}

.score_more_box {
  padding: 4px;
  background: #F8F8F8;
  border-top: 1px solid #eeeeee;
}

.mypage_table .dday {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #F94447;
  border: 1px solid #FF8E90;
  padding: 0 4px;
  display: flex;
  align-self: start;
}
@media screen and (max-width: 980px) {
  .mypage_table .dday {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.mypage_table .lect_name {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media screen and (max-width: 980px) {
  .mypage_table .lect_name {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.mypage_table .cateBox {
  font-size: 0;
  display: flex;
  align-items: center;
  gap: 4px;
  min-height: 24px;
}

.mypage_table .cateBox > span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 2px 4px;
  border: 1px solid #F8F8F8;
  background: #eeeeee;
  color: #878787;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .mypage_table .cateBox > span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.table_score ul > li {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 44%;
  background: #FFFFFF;
}

.table_score ul.head > li {
  background: #ebebeb;
  color: #5A5A5A;
}

.table_score ul > li .score1 {
  color: #39BF50;
}

.table_score ul > li .chk_ing {
  color: #5A5A5A;
}

.mypage_table ul.score > li.doc_head {
  background: #F8F8F8;
}

.table_score ul > li.doc_cri_wrp {
  flex: 1 1 auto;
  border-left: 1px solid #D9D9D9;
  flex-direction: row;
}

.table_score ul > li.doc_cri_wrp > div {
  flex: 1;
  padding: 16px 0;
}

.table_score ul > li.doc_cri_wrp > div:first-child {
  background: #ebebeb;
  color: #5A5A5A;
}

.mypage_table ul.sub_table {
  padding: 16px 0;
}

/* 마이페이지 상세 페이지 */
.my_topBox .infobox {
  background: #F8F8F8;
  border: 1px solid #eeeeee;
  padding: 16px;
}

.my_topBox .infobox h3 {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #05267F;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .my_topBox .infobox h3 {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.my_topBox .list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.my_topBox .list > li {
  display: flex;
  align-items: center;
}

.my_topBox .list > li .title {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  min-width: 115px;
  max-width: 115px;
}
@media screen and (max-width: 980px) {
  .my_topBox .list > li .title {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.my_topBox .list > li .con {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #2A2A2A;
  display: flex;
  align-items: center;
  gap: 4px;
  position: relative;
  overflow: visible;
}
@media screen and (max-width: 980px) {
  .my_topBox .list > li .con {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.my_topBox .list > li .con .score_num {
  color: #F94447;
  font-weight: bold;
}

.my_topBox .list > li .con .resource {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: inline-flex;
  padding: 4px 8px;
  background: #CED8F4;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .my_topBox .list > li .con .resource {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.my_topBox .list > li .con .resource:hover {
  background: #05267F;
  color: #FFFFFF;
}

.my_topBox .list > li .con .resource_no {
  background: #D9D9D9;
  color: #878787;
}

.my_topBox .list > li .con .resource_no:hover {
  background: #D9D9D9;
  color: #878787;
}

.my_topBox .list > li .con a.process {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
  cursor: pointer;
  border: 1px solid #446CF9;
  box-sizing: border-box;
  padding: 4px 16px;
  border-radius: 1000px;
  transition: all 0.3s;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .my_topBox .list > li .con a.process {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.my_topBox .list > li .con a.process:hover {
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .my_topBox .list > li .con a.process {
    padding: 4px 4px;
  }
}

.my_topBox .list > li .con .score_more {
  color: #446CF9;
}

/* 마이페이지 상세 페이지 > 수료 기준 자세히 보기 */
.score_view {
  display: none;
  position: absolute;
  top: 31px;
  left: 0;
  width: 40vw;
  background: #FFFFFF;
  padding: 8px;
  box-sizing: border-box;
  z-index: 30;
  background: #2A2A2A;
  border-radius: 15px;
}

.score_view::after {
  content: "";
  position: absolute;
  top: 0;
  left: 72px;
  transform: translateY(-100%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid #2A2A2A; /* 화살표 색상 */
}

.score_view .tableRow {
  display: flex;
  flex-direction: column;
}

.score_view .tableRow ul {
  display: flex;
  align-items: stretch;
}

.score_view .tableRow ul:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.score_view .tableRow ul li {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #FFFFFF;
  box-sizing: border-box;
  flex-grow: 1;
  padding: 0.8em 1.2em;
  overflow: hidden;
  list-style: none;
  border-right: 1px dotted #5A5A5A;
  border-bottom: 1px dotted #5A5A5A;
}
@media screen and (max-width: 980px) {
  .score_view .tableRow ul li {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.score_view .tableRow ul:last-child li {
  border-bottom: none;
}

.score_view .tableRow ul li:last-child {
  border-right: none;
}

.score_view .tableRow ul .head {
  display: flex;
  text-align: center;
  font-weight: bold;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.score_view .tableRow ul .con {
  display: flex;
  color: #FFFFFF;
  align-items: center;
  justify-content: center;
  flex: 2;
  background: #0e0e0e;
}

.score_view .tableRow ul:first-child .con:last-child {
  border-top-right-radius: 7px;
}

.score_view .tableRow ul:last-child .con:last-child {
  border-bottom-right-radius: 7px;
}

.score_view .tableRow ul .con.percent {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
}

.score_view .tableRow ul .con.percent p {
  display: flex;
  gap: 4px;
  justify-content: center;
}

.score_view .tableRow ul .con.three {
  flex-direction: column;
}

/* 마이페이지 상세 페이지 > 학습 box */
.my_topBox + .studyBox {
  margin-top: 16px;
}

.score_chk {
  cursor: pointer;
  color: #878787;
  display: flex;
  align-items: center;
  gap: 4px;
}

.score_chk .score2 {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .score_chk .score2 {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.score_chk .score1 {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #39BF50;
}
@media screen and (max-width: 980px) {
  .score_chk .score1 {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.score_chk button {
  position: relative;
  width: 24px;
  color: #446CF9;
}
.score_chk button::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.score_chk button > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.score_chk button i {
  font-size: 16px;
}

.score_chk button:hover i {
  color: #05267F;
}

.all_score .n_b b {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #F94447;
}
@media screen and (max-width: 980px) {
  .all_score .n_b b {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.all_score .score1 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #39BF50;
}
@media screen and (max-width: 980px) {
  .all_score .score1 {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.com_print {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  position: absolute;
  right: 24px;
  top: 24px;
  transform: translate(15%, -15%);
  color: #FFFFFF;
}
.com_print::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.com_print > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.com_print::before {
  content: "";
  display: block;
  position: absolute;
  animation: checkbox_anim 1s linear infinite;
  background: #CED8F4;
  z-index: -1;
  border-radius: 7px;
}

.com_print span {
  font-size: 10px;
  background: #FFFFFF;
  border: 1px soild #39BF50;
  border-radius: 5px;
  color: #05267F;
}

.com_print_prev {
  cursor: auto;
  background: #B1B1B1;
  color: #05267F;
}

/* 마이페이지 상세 페이지 > 학습 box > 진도율 & 학습하기 */
.my_progress {
  display: flex;
  border: 1px solid #eeeeee;
  padding: 16px;
  gap: 16px;
}

.my_progress + .bottomBox2 {
  margin-top: 16px;
}

.my_progress .tit {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .my_progress .tit {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.my_progress .progressBox {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 16px;
}

.my_progress .progressBox .progress {
  height: 8px;
  flex: 1;
  background: #AEF483;
  border-radius: 1000px;
}

.my_progress .progressBox .progress .progress-bar {
  background: #39BF50;
  height: 100%;
  border-radius: 1000px;
  position: relative;
  transition: all 0.3s;
}

.my_progress .progressBox .progress .progress-bar::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  mix-blend-mode: overlay;
  opacity: 0.5;
  background: repeating-linear-gradient(45deg, #FFFFFF, #FFFFFF 10px, #39BF50 0, #39BF50 20px);
}

.my_progress .score {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .my_progress .score {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.my_progress .score .percent {
  font-size: 18px;
  line-height: 18px;
  font-weight: 400;
  color: #39BF50;
}
@media screen and (max-width: 980px) {
  .my_progress .score .percent {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
  }
}

.my_progress .st_box {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .my_progress .st_box {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.my_progress .st_box button {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  box-sizing: border-box;
  padding: 8px 16px;
  color: #FFFFFF;
  position: relative;
  overflow: hidden;
  z-index: 10;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .my_progress .st_box button {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
.my_progress .st_box button::after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: 1px;
  border-radius: 1000px;
  background: #03174e;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
  transition: all 1s;
}
.my_progress .st_box button::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #05267F;
  border: 1px solid #05267F;
  z-index: -2;
}
.my_progress .st_box button:hover::after {
  transform: translate(-50%, -50%) scale(300);
}

.my_progress .progressBox + .st_box {
  margin-left: 16px;
  border-left: 1px solid #eeeeee;
}

/* 마이페이지 상세 페이지 > 학습 현황 */
.mypage_view_table ul {
  cursor: pointer;
  flex-wrap: nowrap;
  padding: 0;
}

.mypage_view_table ul.head {
  cursor: auto;
  display: flex;
}

.mypage_view_table ul li {
  padding: 16px 0;
  box-sizing: border-box;
}

.mypage_view_table ul li button.class_play {
  color: #446CF9;
  margin-bottom: 2px;
}

.mypage_view_table ul li.li_01 {
  flex: 1 1 20%;
}

.mypage_view_table ul li.li_04 {
  flex: 1 1 25%;
}

.mypage_view_table ul li.li_05 {
  flex: 1 1 25%;
}

.mypage_view_table ul li.li_06 {
  flex: 1 1 25%;
}

/* 마이페이지 상세 페이지 > 성적 박스 */
.studyBox + .bottomBox {
  margin-top: 16px;
}

.progress_ul {
  display: flex;
  gap: 8px;
}

.progress_ul li {
  position: relative;
  width: 100%;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 1px solid #eeeeee;
  border-radius: 15px;
  box-sizing: border-box;
}
.progress_ul li::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.progress_ul li > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.progress_ul li > .inner {
  flex-direction: column;
  box-sizing: border-box;
  padding: 24px;
}

.progress_ul li > .inner .tit {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #2A2A2A;
  width: 100%;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .tit {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.progress_ul li > .inner .tit .prog_check {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 1px solid #446CF9;
  border-radius: 1000px;
  position: relative;
}

.progress_ul li > .inner .tit .prog_check::after {
  content: "";
  display: block;
  position: absolute;
  left: 4px;
  top: 4px;
  bottom: 4px;
  right: 4px;
  background: #446CF9;
  border-radius: 1000px;
}

.progress_ul li > .inner .tit p {
  display: flex;
  align-items: center;
  gap: 8px;
}

.progress_ul li > .inner .tit span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: inline-block;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .tit span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.progress_ul li > .inner .tit p + span {
  margin-top: 8px;
}

.progress_ul li > .inner .show {
  flex: 1;
  width: 100%;
  display: flex;
  align-items: end;
  justify-content: end;
}

.progress_ul li > .inner .show .show_inner {
  font-size: 18px;
  line-height: 18px;
  font-weight: 400;
  color: #878787;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .show .show_inner {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
  }
}

.progress_ul li > .inner .show .show_inner .chk_ing {
  display: flex;
  align-items: center;
}

.progress_ul li > .inner .show .show_inner .chk_ing .dot_grp {
  display: flex;
  gap: 4px;
  margin-left: 4px;
}

.progress_ul li > .inner .show .show_inner .chk_ing .dot_grp .dot {
  display: inline-block;
  width: 4px;
  height: 4px;
  background: #446CF9;
  border-radius: 1000px;
}

.chk_ing .dot_grp .dot:nth-child(1) {
  animation: dot_anim 1.3s ease-in-out infinite;
  animation-delay: 0.3s;
}

.chk_ing .dot_grp .dot:nth-child(2) {
  animation: dot_anim 1.3s ease-in-out infinite;
  animation-delay: 0.6s;
}

.chk_ing .dot_grp .dot:nth-child(3) {
  animation: dot_anim 1.3s ease-in-out infinite;
  animation-delay: 0.9s;
}

.progress_ul li > .inner .show .show_inner .score {
  color: #446CF9;
}

.progress_ul li > .inner .show .show_inner .score.none {
  color: #878787;
}

.progress_ul li > .inner .show .show_inner .sur_need_wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  animation: sur_need_anim 4s linear infinite;
}

.progress_ul li > .inner .show .show_inner .sur_need_wrap .sur_need {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  background: #5A5A5A;
  color: #F8F8F8;
  padding: 8px 8px;
  border-radius: 5px;
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .show .show_inner .sur_need_wrap .sur_need {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.progress_ul li > .inner .show .show_inner .sur_need_wrap .sur_need::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 8px;
  transform: translateY(100%) rotate(180deg);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid #5A5A5A; /* 화살표 색상 */
}

.progress_ul li > .inner .show .show_inner .state {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 1000px;
  align-self: center;
  display: flex;
  flex-direction: column;
  align-items: end;
  gap: 8px;
  align-self: flex-end;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .show .show_inner .state {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.progress_ul li > .inner .show .show_inner .state .sur_need,
.progress_ul li > .inner .show .show_inner .state .sur_ok {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
  cursor: pointer;
  border: 1px solid #446CF9;
  box-sizing: border-box;
  padding: 4px 16px;
  border-radius: 1000px;
  transition: all 0.3s;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .show .show_inner .state .sur_need,
  .progress_ul li > .inner .show .show_inner .state .sur_ok {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.progress_ul li > .inner .show .show_inner .state .sur_need:hover,
.progress_ul li > .inner .show .show_inner .state .sur_ok:hover {
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .progress_ul li > .inner .show .show_inner .state .sur_need,
  .progress_ul li > .inner .show .show_inner .state .sur_ok {
    padding: 4px 4px;
  }
}

/* 수강 신청 현황 & 관심 과정 관리 */
.mypage_inter {
  border: 1px solid #eeeeee;
  box-sizing: border-box;
}

.mypage_inter ul {
  padding-bottom: 16px;
}

.mypage_inter ul:last-child {
  border-bottom: none;
  padding-bottom: 16px;
}

.mypage_inter ul + ul {
  padding-top: 16px;
}

.mypage_inter ul.head li {
  padding: 16px 0 0;
}

.mypage_inter ul.head li:first-child {
  padding-left: 16px;
}

.mypage_inter ul li {
  flex: 1 1 auto;
}

.mypage_inter ul li.li_thumb {
  display: flex;
}

.mypage_inter ul li.li_02 {
  flex: 1 1 42.5%;
}

.mypage_inter ul li.li_03 {
  flex: 1 1 34.5%;
}

.mypage_inter ul li.li_03 p {
  background: #D9D9D9;
  display: inline-block;
  border-radius: 16px;
  display: inline-flex;
  max-width: 100%;
  padding: 4px 8px;
  color: #5A5A5A;
}

.mypage_inter ul li.li_03.completion p {
  background: #39BF50;
  color: #FFFFFF;
}

.mypage_inter ul li.li_03 p .icon {
  display: inline-flex;
  width: 12px;
  height: 12px;
  background: #FFFFFF;
  margin: auto;
  border-radius: 1000px;
  color: #878787;
  margin-right: 4px;
  align-items: center;
  justify-content: center;
}
.mypage_inter ul li.li_03 p .icon i {
  margin-right: 1px;
}

.mypage_inter ul li.li_03.completion p .icon {
  color: #39BF50;
}

.mypage_inter ul li.li_03 p .tit {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media screen and (max-width: 980px) {
  .mypage_inter ul li.li_03 p .tit {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.mypage_inter ul li.li_03 .icon i {
  font-size: 10px;
}

.mypage_inter ul li.li_04 {
  flex: 1 1 17.5%;
}

.mypage_inter ul li.li_05 {
  flex: 1 1 30%;
}

.mypage_inter ul li.li_tit p {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-left: 16px;
}

.mypage_inter ul li.li_tit > img {
  width: 33.3%;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.mypage_inter ul li {
  align-items: center;
  gap: 8px;
  justify-content: center;
}

.mypage_inter ul li.left {
  padding-left: 16px;
}

.mypage_inter ul li.li_col {
  display: flex;
  flex-direction: column;
}

.mypage_inter ul li .deleteBtn {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
  cursor: pointer;
  border: 1px solid #446CF9;
  box-sizing: border-box;
  padding: 4px 16px;
  border-radius: 1000px;
  transition: all 0.3s;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .mypage_inter ul li .deleteBtn {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.mypage_inter ul li .deleteBtn:hover {
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .mypage_inter ul li .deleteBtn {
    padding: 4px 4px;
  }
}

/* 문의내역 */
.mypage_qna {
  border: 1px solid #eeeeee;
  box-sizing: border-box;
}

/* 설문조사 */
.surveyList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.surveyList .survey {
  flex: calc(50% - 32px);
  font-size: 0;
  box-sizing: border-box;
  border: 1px solid #eeeeee;
  border-radius: 15px;
  transition: all 0.3s;
}

.surveyList .survey:hover {
  border: 1px solid #D9D9D9;
}

.surveyList .survey a {
  display: flex;
  flex-direction: column;
  padding: 16px;
  gap: 16px;
  box-sizing: border-box;
}

.surveyList .survey .tit {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  min-height: 51px;
  max-height: 51px;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .surveyList .survey .tit {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.surveyList .survey .topBox {
  display: flex;
  gap: 16px;
  align-items: self-start;
}

.surveyList .survey .topBox .icon {
  width: 8px;
  margin-top: 5px;
}
.surveyList .survey .topBox .icon path {
  fill: #D9D9D9;
  transition: all 0.3s;
}

.surveyList .survey .tit {
  flex: 1;
}

.surveyList .survey:hover .topBox .icon circle {
  fill: #446CF9;
}

.surveyList .survey .bottomBox {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .surveyList .survey .bottomBox {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.surveyList .survey .bottomBox ul {
  display: flex;
  gap: 8px;
}

.surveyList .survey .bottomBox .left {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.surveyList .survey .bottomBox ul .head {
  color: #5A5A5A;
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  font-weight: bold;
  width: 80px;
  border-right: 1px solid #eeeeee;
}
@media screen and (max-width: 980px) {
  .surveyList .survey .bottomBox ul .head {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.surveyList .survey .bottomBox ul .con {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #878787;
  flex: 1;
}
@media screen and (max-width: 980px) {
  .surveyList .survey .bottomBox ul .con {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.surveyList .survey .bottomBox ul .con span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 3px 8px;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .surveyList .survey .bottomBox ul .con span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.surveyList .survey .bottomBox ul .con span.no_sur {
  background: #D9D9D9;
  color: #878787;
}

.surveyList .survey .bottomBox ul .con span.ok_sur {
  background: #446CF9;
  color: #F5F8FF;
}

/* 설문조사 팝업 */
.view_wrap {
  background: #f3f3f3;
  height: 100%;
}

.view_wrap .inner > .head {
  background: #F8F8F8;
  padding: 16px 24px;
}

.view_wrap .inner > .head h3 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .view_wrap .inner > .head h3 {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.view_wrap .view_button_wrap {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  padding: 0 0 16px;
}

.view_wrap .view_button_wrap .close {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .view_wrap .view_button_wrap .close {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.view_wrap .view_button_wrap .close:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}

.view_wrap .view_button_wrap .enter {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .view_wrap .view_button_wrap .enter {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.view_wrap .view_button_wrap .enter:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
.view_wrap .view_button_wrap .enter:hover {
  background: #05267F;
  color: #FFFFFF;
}

/* 설문조사 팝업 > 회원정보 */
.view_wrap .view_content > .tableRow {
  padding: 24px;
}

.view_wrap .view_content > .tableRow ul {
  display: flex;
}

.view_wrap .view_content > .tableRow ul li {
  flex: 1;
  display: flex;
  align-items: center;
}

.view_wrap .view_content > .tableRow ul.name {
  margin-bottom: 16px;
}

.view_wrap .view_content > .tableRow ul.name li {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .view_wrap .view_content > .tableRow ul.name li {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.view_wrap .view_content > .tableRow ul li > span {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
  border-radius: 1000px;
}

.view_wrap .view_content > .tableRow ul li .head {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  flex: 1;
  background: #05267F;
  color: #F8F8F8;
}
@media screen and (max-width: 980px) {
  .view_wrap .view_content > .tableRow ul li .head {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.view_wrap .view_content > .tableRow ul li .con {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  flex: 3;
  color: #05267F;
}
@media screen and (max-width: 980px) {
  .view_wrap .view_content > .tableRow ul li .con {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 설문조사 팝업 > 설문 */
.quizBox {
  padding: 0 24px;
}

.qiuzBoxinner {
  overflow-y: auto;
}

.quizBox .quiz {
  margin-bottom: 16px;
}

.quizBox .quiz:last-child {
  margin-bottom: 0;
}

.quizBox .quiz .top {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 16px;
}

.quizBox .quiz .top h3 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
  flex: 1;
  margin-top: 2px;
}
@media screen and (max-width: 980px) {
  .quizBox .quiz .top h3 {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.quizBox .quiz .top .num {
  position: relative;
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  width: 24px;
  display: inline-block;
  background: #05267F;
  color: #FFFFFF;
  border-radius: 5px;
  border: 1px solid #05267F;
}
.quizBox .quiz .top .num::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.quizBox .quiz .top .num > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 980px) {
  .quizBox .quiz .top .num {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.quizBox .quiz .top span.num.wrong {
  background: #F94447;
}

.quizBox .quiz .top span.num.answer {
  background: #39BF50;
}

.quizBox .quiz .top p.score {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  border: 1px solid #446CF9;
  color: #446CF9;
  padding: 4px 8px;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .quizBox .quiz .top p.score {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.quizBox .quiz .top .explanBox {
  box-sizing: border-box;
  background: #f5f5f5;
  border-radius: 5px;
  padding: 15px;
  margin: 25px 34px 0px;
  position: relative;
}

.quizBox .quiz .top .explanBox:after {
  content: "";
  position: absolute;
  top: 0;
  left: 100px;
  width: 0;
  height: 0;
  border: 20px solid transparent;
  border-bottom-color: #f5f5f5;
  border-top: 0;
  margin-left: -15px;
  margin-top: -15px;
}

.quizBox .quiz .check {
  width: 100%;
}

.quizBox .quiz .check ul {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.quizBox .quiz .check ul li {
  box-sizing: border-box;
  width: 100%;
  position: relative;
}

.quizBox .quiz .check ul li input {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  visibility: hidden;
}

.quizBox .quiz .check ul li img {
  width: 30% !important;
  margin-top: 5px;
  border: 1px solid #ddd;
}

.quizBox .quiz .check ul li.wrong {
  color: red;
  font-weight: bold;
  position: relative;
}

.quizBox .quiz .check ul li.wrong span.num {
  background: red;
  color: #fff;
}

.quizBox .quiz .check ul li.wrong:after {
  position: absolute;
  content: "오답";
  color: red;
  left: -30px;
  top: 50%;
  transform: translateY(-50%);
}

.quizBox .quiz .check ul li.answer {
  color: green;
  font-weight: bold;
  position: relative;
}

.quizBox .quiz .check ul li.answer span.num {
  background: green;
  color: #fff;
}

.quizBox .quiz .check ul li.answer:after {
  position: absolute;
  content: "정답";
  color: green;
  left: -30px;
  top: 50%;
  transform: translateY(-50%);
}

.quizBox .quiz .check ul li label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
}

.quizBox .quiz .check ul li div.num {
  position: relative;
  width: 24px;
  display: inline-block;
  border-radius: 5px;
  border: 1px solid silver;
  background: #D9D9D9;
  color: #878787;
  transition: all 0.3s;
}
.quizBox .quiz .check ul li div.num::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.quizBox .quiz .check ul li div.num > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.quizBox .quiz .check ul li:hover div.num {
  color: #446CF9;
  background: #FFFFFF;
  border-color: #446CF9;
}

.quizBox .quiz .check ul li input:checked + label .num {
  background: #446CF9;
  border: 1px solid #E3EEFF;
  color: #F5F8FF;
}

.quizBox .quiz .check ul li div.content {
  flex: 1;
  margin-top: 4px;
}

.quizBox .quiz .info {
  width: 100%;
  overflow: hidden;
  box-sizing: border-box;
  padding: 15px;
  background: #f7f7f7;
  border-radius: 10px;
  margin-top: 10px;
}

.quizBox .quiz .info p span {
  margin-right: 10px;
  font-weight: bold;
  box-sizing: border-box;
  padding: 3px 10px;
  border-radius: 10px;
  height: 100%;
  display: inline-block;
  float: left;
  margin-top: -4px;
}

.quizBox .quiz .info p img {
  width: 90% !important;
  margin-top: 10px;
}

.quizBox .quiz .info p.answer {
  margin-bottom: 15px;
}

.quizBox .quiz .info p.answer span {
  background: green;
  color: #fff;
}

.quizBox .quiz .info p.tip {
  margin-bottom: 15px;
}

.quizBox .quiz .info p.tip.feedback {
  display: flex;
}

.quizBox .quiz .info p.tip:last-child {
  margin-bottom: 0px;
}

.quizBox .quiz .info p.tip span.tit {
  background: #887BB0;
  color: #fff;
}

.quizBox .quiz .info p.tip span.score {
  float: inherit;
  margin-top: 0px;
  margin-right: 0px;
  padding: 0px;
}

.quizBox .quiz .info p.tip textarea {
  margin-top: 10px;
  height: 100px;
  resize: none;
  width: 100%;
  box-sizing: border-box;
  padding: 20px;
  border: 1px solid #ddd;
}

.quizBox .quiz .info span.feedback {
  margin-top: 0px;
  margin-right: 0px;
  padding: 0;
  width: 90%;
}

.quizBox .quiz .write {
  padding: 16px 0;
}

.quizBox .quiz .check p.tit {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .quizBox .quiz .check p.tit {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.quizBox .quiz .check p.tit .bubble {
  display: inline-flex;
  width: 16px;
  padding: 4px 4px;
  background: #2A2A2A;
  border-radius: 1000px;
}

.quizBox .quiz .check .answer {
  width: 100%;
  border: 1px solid #B1B1B1;
  box-sizing: border-box;
  font-size: 0;
  border-radius: 5px;
}

.quizBox .quiz .check .answer input {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  background: #D9D9D9;
  padding: 16px;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .quizBox .quiz .check .answer input {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.quizBox .quiz .check .answer input:focus {
  background: #F8F8F8;
}

.quizBox .quiz .check .answer textarea {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  box-sizing: border-box;
  border: none;
  resize: vertical;
  border-radius: 5px;
  padding: 16px;
  background: #D9D9D9;
}

.quizBox .quiz .check .answer textarea:focus {
  background: #F8F8F8;
  outline: none;
  border: none;
}

/* 내 정보 수정 */
.a_wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
}

.join_wrap .buttonWrap {
  padding: 16px;
}

.join_wrap .usredit_btn_area {justify-content:space-between; align-items:center;}
.join_wrap .usredit_btn_area .cancel {margin-left:auto;}


.join_wrap .buttonWrap button.cancel {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .join_wrap .buttonWrap button.cancel {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.join_wrap .buttonWrap button.cancel:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}

.join_wrap .buttonWrap button.edit {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .join_wrap .buttonWrap button.edit {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.join_wrap .buttonWrap button.edit:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
.join_wrap .buttonWrap button.edit:hover {
  background: #05267F;
  color: #FFFFFF;
}

.join_wrap .buttonWrap button.resign {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  color: #F94447;
  border: 1px solid #FF8E90;
  background: rgba(249, 68, 71, 0.1);
  border-radius: 5px;
  align-self: center;
}
@media screen and (max-width: 980px) {
  .join_wrap .buttonWrap button.resign {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.join_wrap .buttonWrap button.resign:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
.join_wrap .buttonWrap button.resign:hover {
  background: rgba(249, 68, 71, 0.4);
  border: 1px solid #FF8E90;
  color: #F94447;
}

@media screen and (max-width: 980px) {
  /* PC 게시판 가리기 */
  .pc_table_list {
    display: none;
  }
  /* 탭 메뉴 */
  /* 마이페이지 테이블 > 모바일 */
  .m_contentBox {
    display: flex;
    flex-direction: column;
  }
  .m_contentBox {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
  }
  .table_list.m_contentBox > ul.none {
    padding: 39px 0 !important;
  }
  .mypage_table {
    border: 1px solid #eeeeee;
    box-sizing: border-box;
  }
  .mypage_table + .mypage_table {
    margin-top: 16px;
  }
  .mypage_table ul.prod_con, .mypage_table ul.prod_con > .con {
    overflow: visible;
  }
  .mypage_table ul li {
    flex-direction: row;
    width: auto;
    flex: none;
  }
  .mypage_table ul li.head {
    min-width: 64px;
    justify-content: flex-start;
    padding: 0 0;
  }
  .mypage_table ul li.head:first-child {
    font-weight: bold;
  }
  .mypage_table ul li.head:nth-child(2) {
    font-weight: 500;
  }
  .mypage_table ul li.con {
    flex: 1;
    align-items: center;
    justify-content: flex-end;
  }
  .m_contentBox .mypage_table .myClass {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    background: #F8F8F8;
    padding: 16px;
  }
  .m_contentBox .mypage_table .myClass > div {
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: hidden;
  }
  .m_contentBox .mypage_table .myClass .cateBox {
    min-height: 13px;
  }
  .m_contentBox .mypage_table .myClass_ul {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .m_contentBox .mypage_table .myClass_ul > ul {
    display: flex;
    gap: 8px;
    border-bottom: none;
    align-items: center;
  }
  .m_contentBox .mypage_table .myClass_ul > ul .con br {
    display: none;
  }
  /* 마이페이지 상세 페이지 > 학습 box */
  .my_progress {
    gap: 0;
    flex-direction: column;
  }
  .my_progress .progressBox + .st_box {
    margin-left: 0;
    border-left: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .my_progress .progressBox + .st_box {
    margin-top: 8px;
  }
  .my_progress .progressBox + .st_box button {
    padding: 8px;
    background: #446CF9;
    color: #FFFFFF;
    border-radius: 5px;
    width: 100%;
  }
  /* 마이페이지  게시판 */
  .table_list ul li.li_idx {
    display: none;
  }
  .table_list ul li .progress {
    flex: 1;
  }
  .table_list ul li .progress .progress-bar {
    position: relative;
  }
  .table_list ul li .score {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    position: absolute;
    bottom: 0;
    right: 0;
    color: #FFFFFF;
    background: #2A2A2A;
    padding: 2px 4px;
    border-radius: 7px;
    transform: translate(50%, -6px);
    opacity: 0.5;
  }
  /* 성적 현황 */
  /* 마이페이지 상세 페이지 */
  /* 마이페이지 상세 페이지 > 성적 박스 */
  /* 마이페이지 학습현황 */
  /* 관심 과정 관리 & 수강 신청 현황 */
  /* 설문 조사 */
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .table_list ul li .score {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .table_list ul li .score:after {
    border-top: 2px solid #2A2A2A;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 0px solid transparent;
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 100%);
  }
  .table_list ul li .score1 {
    color: #39BF50;
  }
  ul li.listView_no {
    padding: 40px 0;
  }
  .score_view {
    position: absolute;
    transform: translateY(24px);
    top: 0;
    left: -100px;
    width: calc(100vw - 38.4px);
  }
  .score_more_box .table_score > ul {
    display: flex;
    box-sizing: border-box;
    border-bottom: 1px solid #D9D9D9;
  }
  .score_more_box .table_score > ul li.doc_head {
    background: #ebebeb;
    border-right: 1px solid #D9D9D9;
  }
  .score_more_box .table_score ul > li:first-child {
    min-width: 102.4px;
  }
  .score_more_box .table_score ul > li:nth-child(3) {
    font-weight: bold;
  }
  .score_more_box .table_score ul > :nth-child(n+2) {
    flex: 1;
  }
  .score_view::after {
    left: 93.5px;
    transform: translate(calc(100% + 54.5px), -100%);
  }
  .my_topBox .list {
    grid-template-columns: repeat(1, 1fr);
  }
  .my_topBox .list > li {
    align-items: baseline;
  }
  .my_topBox .list > li .title {
    min-width: 85px;
    max-width: 85px;
  }
  .my_topBox .list > li .con {
    align-items: center;
    flex: 4;
  }
  .score_view .tableRow ul .con.percent {
    grid-template-columns: repeat(1, 1fr);
  }
  .score_view .tableRow ul .head {
    font-size: 0.7rem;
  }
  .score_view .tableRow ul .con p {
    font-size: 0.7rem !important;
  }
  .progress_ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .progress_ul li > .inner {
    padding: 16px;
  }
  .progress_ul li.li_stat {
    grid-column: 1/-1;
    justify-self: center;
    width: 50%;
  }
  .progress_ul li.li_stat::after {
    padding-bottom: 100%;
  }
  .progress_ul li > .inner .show .show_inner .state {
    font-size: 16px !important;
    line-height: 21px !important;
  }
  .progress_ul li > .inner .show .show_inner .sur_need_wrap {
    left: auto;
    right: 0;
    transform: translate(-16px, -50%);
    animation: sur_need_m_anim 4s linear infinite;
  }
  .score_more_box .table_score ul > li {
    padding: 8px;
    box-sizing: border-box;
    justify-content: center;
  }
  .score_more_box .table_score ul > li.doc_cri_wrp ~ li.head {
    background: #E3EEFF;
  }
  .table_score ul > li.doc_cri_wrp {
    border-left: none;
  }
  .score_more_box .table_score ul > li.doc_cri_wrp {
    display: flex;
    flex-direction: column;
    padding: 0;
  }
  .table_score ul > li.doc_cri_wrp > div:first-child {
    padding: 8px 0;
  }
  .table_score ul > li.doc_cri_wrp .bold {
    font-weight: bold;
  }
  .table_score ul > li.doc_cri_wrp .doc_cri {
    width: 100%;
  }
  .score_more_box .table_score ul > li.doc_cri_wrp > span {
    font-size: 16px;
    line-height: 16px;
    font-weight: 700;
    display: block;
    width: 100%;
    padding: 8px;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .score_more_box .table_score ul > li.doc_cri_wrp > span {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}
@media screen and (max-width: 980px) {
  .mypage_view_table ul.head li {
    padding: 8px;
  }
  .mypage_view_table ul li {
    padding: 8px !important;
    margin-bottom: 0 !important;
  }
  .table_list.mypage_inter > ul.none {
    padding: 41px 0 !important;
    background: #FFFFFF;
    border: none;
  }
  .mypage_inter ul {
    flex-wrap: nowrap;
  }
  .mypage_inter ul:not(.head) {
    border-top: none;
  }
  .mypage_inter ul.head li {
    padding: 16px 8px 0 8px;
  }
  .mypage_inter ul.head li:first-child {
    padding-left: 8px;
  }
  .mypage_inter ul li.left {
    padding-left: 8px;
  }
  .mypage_inter ul li.li_thumb {
    padding-left: 8px;
  }
  .mypage_inter ul li.li_tit p {
    padding-left: 8px;
  }
  .mypage_inter ul li.li_04 {
    flex: 1 1 59.5%;
  }
  .mypage_inter ul li.li_03 p {
    padding: 4px;
  }
  .mypage_inter ul li.li_03 p .tit {
    display: none;
  }
  .mypage_inter ul li.li_03 p .icon {
    margin-right: 0;
    padding: 4px;
  }
  .mypage_inter ul li.li_03 p .icon i {
    margin-right: 0;
  }
  .mypage_inter ul li.li_stat {
    flex: 1 1 30%;
  }
  .mypage_inter ul li.li_date {
    flex: 1 1 60%;
  }
  .mypage_inter ul li.li_del {
    flex: 1 1 25%;
  }
  .mypage_inter ul li.li_lec_date {
    display: none;
  }
  .mypage_inter ul li .deleteBtn {
    margin: auto;
  }
  .mypage_inter ul li.li_tit p {
    margin-top: 0;
  }
  .surveyList {
    grid-template-columns: repeat(1, 1fr);
  }
  .surveyList .survey {
    flex: 100%;
  }
  .surveyList .survey .bottomBox ul .head {
    font-weight: bold;
  }
  .surveyList .survey .tit {
    min-height: 48px;
    max-height: 48px;
  }
}
/* 학습창: PC */
.learning_wrap {
  background: #FFFFFF;
  height: 100%;
  display: flex;
  align-items: center;
}

.learning_wrap .inner {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
  height: 100%;
}

.video_contentBox {
  width: 100%;
  height: 100%;
  flex-wrap: wrap;
  align-content: center;
  display: flex;
  justify-content: center;
}

.learning_wrap .inner .videoBox {
  display: inline-block;
  box-sizing: border-box;
  margin: 0px auto;
  width: auto;
  height: auto;
  overflow: auto;
  text-align: center;
  position: relative;
  font-size: 0;
  border: 1px solid #eeeeee;
}

.learning_wrap .inner .study_endBox {
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.learning_wrap .inner .study_endBox .txt {
  color: #5A5A5A;
}

.learning_wrap .inner .study_endBox button.end_btn {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  box-sizing: border-box;
  padding: 8px 16px;
  color: #FFFFFF;
  position: relative;
  overflow: hidden;
  z-index: 10;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .study_endBox button.end_btn {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
.learning_wrap .inner .study_endBox button.end_btn::after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: 1px;
  border-radius: 1000px;
  background: #03174e;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
  transition: all 1s;
}
.learning_wrap .inner .study_endBox button.end_btn::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #05267F;
  border: 1px solid #05267F;
  z-index: -2;
}
.learning_wrap .inner .study_endBox button.end_btn:hover::after {
  transform: translate(-50%, -50%) scale(300);
}

.learning_wrap .inner .videoBox iframe {
  border: 0px;
}

.learning_wrap .inner .boardBox {
  position: relative;
  right: 0;
  bottom: 0;
  width: 0%;
  height: 100%;
  transition: all 0.3s;
  transform: translateX(100%);
}

.learning_wrap .inner .boardBox.open {
  width: 27vw;
  transform: translateX(0%);
}

.learning_wrap .inner .boardBox button.openBtn {
  position: relative;
  left: 0;
  background: #5A5A5A;
  width: 2vw;
  position: absolute;
  bottom: 0;
  transition: all 0.3s;
  transform: translate(calc(-100% - 8px), -16px) rotate(90deg);
  border-radius: 1000px;
  box-shadow: 0 0 8px rgba(42, 42, 42, 0.2);
}
.learning_wrap .inner .boardBox button.openBtn::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.learning_wrap .inner .boardBox button.openBtn > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.learning_wrap .inner .boardBox.open button.openBtn {
  transform: translate(calc(-100% - 8px), -100%) rotate(-90deg);
}

.learning_wrap .inner .boardBox button.openBtn svg path {
  fill: #FFFFFF;
}

.learning_wrap .inner .board_inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  border-left: 1px solid #D9D9D9;
}

.learning_wrap .inner .boardBox .mainTit {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  white-space: normal;
  color: #FFFFFF;
  box-sizing: border-box;
  padding: 16px;
  background: #FFFFFF;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .mainTit {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.learning_wrap .inner .boardBox .bottomBox {
  flex: 1;
  background: #F8F8F8;
  white-space: normal;
  overflow: hidden;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.nameBox_m {
  display: none;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .nameBox {
  padding: 16px;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .nameBox p.sub_name {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: #5A5A5A;
  min-height: 46px;
  max-height: 46px;
  padding: 4px 0;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .nameBox p.sub_name {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

p.sub_name .step {
  background: #05267F;
  color: #FFFFFF;
  padding: 4px 8px;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning {
  width: 100%;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning ul {
  display: flex;
  border-top: 1px solid #D9D9D9;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning ul li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  padding: 8px 0;
  position: relative;
  background: #D9D9D9;
  transition: all 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning ul li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning ul li:hover {
  background: #eeeeee;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .tab_menu_lning ul li.current {
  background: #F8F8F8;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning {
  flex: 1;
  overflow-y: auto;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content {
  display: none;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content.current {
  height: 100%;
  width: 100%;
  display: block;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content p.no_list {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #878787;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #eeeeee;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content p.no_list {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content .content {
  display: none;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content .content.current {
  display: flex;
  position: relative;
  width: 100%;
  height: 100%;
  flex-direction: column;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content .content .boardList {
  overflow: auto;
  flex: 1;
  padding: 16px;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content .content .boardList .boardUl {
  height: 100%;
}

/* 학습창 > 보드 리스트 */
.boardUl {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.boardUl .list {
  display: flex;
  border-radius: 7px;
  position: relative;
  transition: all 0.3s;
}

.boardUl .list::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 4px;
}

.boardUl .list.list_noti::after {
  background: #446CF9;
}

.boardUl .list a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  background: #FFFFFF;
  padding: 16px;
  position: relative;
  gap: 16px;
  box-sizing: border-box;
  border: 1px solid #eeeeee;
  transition: all 0.3s;
}

.boardUl .list:hover a {
  border: 1px solid #CED8F4;
}

.boardUl .list a .textBox {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #2A2A2A;
  flex: 1;
  overflow-x: auto;
}
@media screen and (max-width: 980px) {
  .boardUl .list a .textBox {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.boardUl .list a .textBox .tit {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  margin-bottom: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}
@media screen and (max-width: 980px) {
  .boardUl .list a .textBox .tit {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.boardUl .list a .textBox .subInfo {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.boardUl .list a .textBox .subInfo > li {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #5A5A5A;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .boardUl .list a .textBox .subInfo > li {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.boardUl .list a .textBox .subInfo > li .icon {
  color: #878787;
  font-size: 12px;
}

.boardUl .list a .textBox .subInfo > li.file {
  position: relative;
  width: 24px;
  position: absolute;
  top: 8px;
  right: 8px;
  border: 1px solid #eeeeee;
  border-radius: 1000px;
  box-shadow: 0 4px 8px rgba(42, 42, 42, 0.1);
  color: #446CF9;
}
.boardUl .list a .textBox .subInfo > li.file::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.boardUl .list a .textBox .subInfo > li.file > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.boardUl .list a .arrow {
  height: 100%;
  display: flex;
  align-items: end;
  color: #878787;
}

.boardUl .list:hover a .arrow {
  visibility: visible;
}

.boardUl .list .state .stateTxt {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  min-width: 56px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .boardUl .list .state .stateTxt {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.boardUl .list .state .stateTxt img {
  width: 16px;
}

/* 보드 상세보기 */
.boardView {
  padding: 16px;
  flex: 1;
}

.boardView .view_inner {
  height: 100%;
}

.boardView .view_inner .mainContent {
  display: flex;
  flex-direction: column;
}

.boardView .view_inner > div + div {
  margin-top: 16px;
}

.boardView .view_inner .title {
  color: #5A5A5A;
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
}

.boardView .view_inner .title .tit {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  flex: 1;
  line-height: 1.4;
}
@media screen and (max-width: 980px) {
  .boardView .view_inner .title .tit {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.boardView .view_inner .title .tit .qa {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #D9D9D9;
  border-radius: 5px;
  display: inline-flex;
  width: 24px;
  height: 24px;
  color: #5A5A5A;
  box-shadow: 0 0 8px rgba(42, 42, 42, 0.1);
  margin-right: 4px;
}

.boardView .view_inner .state {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 4px 8px;
  align-self: baseline;
  border: 1px solid #6160F4;
  background: #05267F;
  color: #F8F8F8;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .boardView .view_inner .state {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.boardView .view_inner .state_no {
  border: 1px solid #D9D9D9;
  background: #eeeeee;
  color: #878787;
}

.boardView .view_inner .sub_info {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  margin-bottom: 16px;
  color: #5A5A5A;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-top: 1px solid #eeeeee;
}
@media screen and (max-width: 980px) {
  .boardView .view_inner .sub_info {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.boardView .view_inner .sub_info li:first-child {
  margin-top: 16px;
}

.boardView .view_inner .sub_info li.date {
  display: flex;
  align-self: baseline;
}

.boardView .view_inner .contentBox {
  height: 100%;
  padding: 16px;
  background: #FFFFFF;
  border-radius: 15px;
  box-sizing: border-box;
  box-shadow: 0 0 8px rgba(42, 42, 42, 0.1);
  min-height: 230px;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .board .content_lning .tab-content .content .boardList {
  overflow: inherit;
}

/* 보드 버튼 */
.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 {
  width: 100%;
  padding: 16px;
  box-sizing: border-box;
  display: flex;
  justify-content: end;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button {
    padding: 4px 8px;
  }
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.refreshBtn {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 41px;
  height: 41px;
  border: 1px solid #D9D9D9;
  border-radius: 1000px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.refreshBtn {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.refreshBtn {
    padding: 4px 8px;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.refreshBtn {
    width: 27px;
    height: 27px;
  }
}
.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.refreshBtn:hover {
  background: silver;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.inBtn,
.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.editBtn,
.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.writeBtn {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.inBtn,
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.editBtn,
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.writeBtn {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.inBtn,
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.editBtn,
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.writeBtn {
    padding: 4px 8px;
  }
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.deleteBtn {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
  background: #F8F8F8;
  color: #446CF9;
  border-color: #446CF9;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.deleteBtn {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.deleteBtn {
    padding: 4px 8px;
  }
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.backBtn {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 41px;
  height: 41px;
  border: 1px solid #D9D9D9;
  border-radius: 1000px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.backBtn {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.backBtn {
    padding: 4px 8px;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.backBtn {
    width: 27px;
    height: 27px;
  }
}
.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 button.backBtn:hover {
  background: silver;
}

.learning_wrap .inner .boardBox .bottomBox .bottom_inner .buttonBox2 > button.backBtn:first-child {
  margin-right: auto;
}

.buttonBox2 button.deleteBtn + button.editBtn {
  margin-left: 8px;
}

button.writeBtn + button.refreshBtn {
  margin-left: 8px;
}

/* Q&A 문의하기 */
.boardWrite {
  padding: 16px;
  height: 100%;
}

.boardWrite .titBox {
  margin-bottom: 16px;
}

.boardWrite .titBox input {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #5A5A5A;
  width: 100%;
  padding: 8px;
  border: 1px solid #D9D9D9;
}
@media screen and (max-width: 980px) {
  .boardWrite .titBox input {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

.boardWrite .fileBox {
  display: flex;
  margin-bottom: 16px;
  align-items: center;
  flex-direction: column;
  border: 1px solid #eeeeee;
  border-radius: 5px;
}

.boardWrite .fileBox > div {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  width: 100%;
  gap: 4px;
  padding: 8px 8px;
  box-sizing: border-box;
}
@media screen and (max-width: 980px) {
  .boardWrite .fileBox > div {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.boardWrite .fileBox > div:last-child {
  background: #eeeeee;
  color: #5A5A5A;
}

.boardWrite .fileBox > div:last-child .fa-paperclip {
  margin-right: 8px;
}

.boardWrite .fileBox > div:last-child button:hover i {
  color: #446CF9;
}

.boardWrite .fileBox > div a {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}

.boardWrite .fileBox label {
  display: block;
  margin-right: 8px;
}

.boardWrite .fileBox input {
  flex: 1;
}

.boardWrite .write_inner {
  height: 100%;
}

.boardWrite .write_inner form {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.boardWrite .write_inner form .writeBox {
  flex: 1;
}

.boardWrite .write_inner form .writeBox .cke_1 {
  height: 100%;
}

.boardWrite .write_inner form .writeBox .cke_contents {
  height: 100% !important;
}

.boardWrite .write_inner form .writeBox #cke_bd_cont {
  height: 100%;
}

.boardWrite .write_inner form .writeBox .cke_inner {
  height: 100%;
  overflow: hidden;
}

.buttonBox_m {
  display: none;
}

@media screen and (max-width: 980px) {
  /* 학습창 모바일 */
  .learning_wrap .inner .boardBox {
    position: fixed;
    top: 0;
    bottom: auto;
    left: 0;
    right: 0;
    width: 100%;
    height: 85%;
    transform: translateY(0%);
  }
  .learning_wrap .inner .boardBox.open {
    width: 100%;
    transform: translateY(-100%);
  }
  body.learning.mobile_class {
    background: #FFFFFF;
  }
  .learning_wrap .inner .board_inner {
    border-bottom: 1px solid #D9D9D9;
  }
  .mobile_class .learning_wrap .inner {
    box-sizing: border-box;
    display: block;
    overflow: auto;
    padding: 16px;
  }
  .mobile_class .learning_wrap .inner .video_contentBox > div {
    height: 100%;
    width: 100%;
  }
  .mobile_class .learning_wrap .inner .videoBox {
    width: 100%;
    height: 100%;
  }
  .mobile_class .learning_wrap .inner .videoBox iframe {
    position: static;
    transform: translate(0, 0);
  }
  .mobile_class .nameBox_m {
    width: 100%;
    display: block;
    box-sizing: border-box;
    padding: 16px 0;
  }
  .mobile_class .nameBox_m .class_name {
    font-size: 18px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
    overflow: hidden;
    word-break: break-word;
    margin-bottom: 16px;
  }
  /* 학습 게시판 */
  /* 버튼 */
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .mobile_class .nameBox_m .class_name {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}
@media screen and (max-width: 980px) {
  .mobile_class .nameBox_m .class_name i {
    margin-right: 8px;
  }
  .mobile_class .nameBox_m p.sub_name {
    font-size: 14px !important;
    line-height: 18px !important;
    font-weight: 500 !important;
    padding: 8px 0;
    word-break: break-word;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .mobile_class .nameBox_m p.sub_name {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
@media screen and (max-width: 980px) {
  p.sub_name .step {
    padding: 2px 8px;
  }
  .learning_wrap .inner .boardBox .bottomBox .bottom_inner .nameBox p.sub_name {
    min-height: 32px;
    max-height: 32px;
  }
  .boardWrite .titBox {
    padding-left: 0;
    padding-right: 0;
  }
  .boardWrite .fileBox input {
    width: 100%;
  }
  .learning_wrap .inner .boardBox button.openBtn {
    width: 12vw;
    right: 16px;
    left: auto;
    opacity: 0.5;
    transform: translate(0, calc(100% + 8px)) rotate(-180deg);
  }
  .learning_wrap .inner .boardBox.open button.openBtn {
    transform: translate(0, calc(100% + 8px)) rotate(0deg);
  }
  .boardUl .list a .textBox {
    overflow-x: visible;
  }
  .boardView .view_inner .sub_info {
    gap: 8px;
  }
  .mobile_class .buttonBox_m {
    width: 100%;
    overflow: hidden;
    display: block;
    text-align: center;
    margin: 16px 0 0;
  }
  .mobile_class .buttonBox_m button {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    box-sizing: border-box;
    padding: 8px 16px;
    color: #FFFFFF;
    position: relative;
    overflow: hidden;
    z-index: 10;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .mobile_class .buttonBox_m button {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .mobile_class .buttonBox_m button::after {
    content: "";
    display: block;
    position: absolute;
    width: 1px;
    height: 1px;
    border-radius: 1000px;
    background: #03174e;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    transition: all 1s;
  }
  .mobile_class .buttonBox_m button::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #05267F;
    border: 1px solid #05267F;
    z-index: -2;
  }
  .mobile_class .buttonBox_m button:hover::after {
    transform: translate(-50%, -50%) scale(300);
  }
  .mobile_class .buttonBox_m p.txt {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    color: #2A2A2A;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 980px) and (max-width: 980px) {
  .mobile_class .buttonBox_m p.txt {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}
@media screen and (max-width: 980px) {
  .learning_wrap .inner .study_endBox {
    display: none;
  }
}
/* 애니메이션 */
@keyframes width_ani {
  0% {
    width: 0%;
  }
  100% {
    width: 100%;
  }
}
@keyframes top_to_bottom_ani {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-2px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes dot_anim {
  0% {
    transform: translateY(0);
    opacity: 0.5;
  }
  40% {
    transform: translateY(-4px);
    opacity: 1;
  }
  60% {
    transform: translateY(0);
    opacity: 0.5;
  }
  100% {
    transform: translateY(0);
    opacity: 0.5;
  }
}
@keyframes process_anim {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes schedule_circle_anim {
  100% {
    background: #39BF50;
    color: #FFFFFF;
    border: 1px dashed #39BF50;
  }
}
/* 공통 */
.flex_column {
  flex-direction: column;
}

.wrap {
  width: 100%;
  min-height: 100%;
  max-height: max-content;
  display: flex;
  flex-direction: column;
}

.max_width1200 {
  flex: 1;
}
.max_width1200 .sub_content {
  max-width: 1200px;
  margin: auto;
}
.max_width1200 .sub_content_inner {
  display: flex;
  padding-top: 24px;
  padding-bottom: 24px;
  gap: 50px;
}
.max_width1200 .contentBox {
  max-width: 1200px;
  margin: auto;
}

/* 공통 */
/* 결과 없음 */
.listView_no {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 40px;
  border: 1px solid #eeeeee;
  background: #FFFFFF;
  color: #5A5A5A;
  border-radius: 5px;
}
@media screen and (max-width: 980px) {
  .listView_no {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.survey_wrapper .listView_no {
  padding: 40px 40px;
}

.tab_menu_search .listView_no {
  background: #F8F8F8;
  padding: 39px;
}

ul li.listView_no {
  border-radius: 0;
  border: none;
}

/* 새 글 */
img.noti_n {
  width: 12px !important;
  height: 12px !important;
  margin-bottom: 2px;
}

.sub_con .main_con {
  flex: 1;
  overflow: hidden;
}

/* 셀렉트 박스 */
.selectBox2 {
  position: relative;
  width: 100%;
  box-sizing: border-box;
}

.selectBox2 .select {
  border: 1px solid #446CF9;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 16px;
  border-radius: 5px;
}

.selectBox2 .select a {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  flex: 1;
}
@media screen and (max-width: 980px) {
  .selectBox2 .select a {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.selectBox2 .select a .date {
  margin-right: 8px;
  color: #446CF9;
}

.selectBox2 .select a .default_txt {
  color: #B1B1B1;
}

.selectBox2 .optionBox {
  position: absolute;
  bottom: -4px;
  width: 100%;
  background: #fff;
  border: 1px solid #CED8F4;
  transform: translateY(100%);
  border-radius: 5px;
}

.selectBox2 .optionBox li {
  padding: 8px 16px;
  cursor: pointer;
}

.selectBox2 .optionBox li.default {
  color: #B1B1B1;
}

.selectBox2 .optionBox li span {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .selectBox2 .optionBox li span {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

/* 레프트메뉴 */
.leftMenu {
  width: 190px;
  display: flex;
  flex-direction: column;
}

.leftMenu .mainTit {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 8px;
}

.leftMenu .mainTit h3 {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  .leftMenu .mainTit h3 {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.leftMenu .mainMenu {
  display: flex;
  flex-direction: column;
}

.leftMenu .mainMenu > li {
  position: relative;
  color: #B1B1B1;
}

.leftMenu .mainMenu > li::after {
  content: "";
  display: block;
  position: absolute;
  left: 7px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #D9D9D9;
}

.leftMenu .mainMenu > li a {
  width: calc(100% - 40px);
  display: inline-block;
  padding: 12px 28px;
}

.leftMenu .mainMenu > li.on a {
  color: #446CF9;
}

.leftMenu .mainMenu > li.on::before {
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 0;
  right: 0;
  bottom: 0;
  background: #f3f3f3;
  z-index: -1;
  border-radius: 5px;
}

.leftMenu .mainMenu > li.on::after {
  background: #446CF9;
}

.leftMenu .mainMenu > li .subMenu {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .leftMenu .mainMenu > li .subMenu {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.leftMenu .mainMenu > li .subMenu .son_li a {
  color: #5A5A5A;
}

.leftMenu .mainMenu > li .subMenu .son_li.on a {
  color: #446CF9;
}

/* 브레드크럼 */
.titBox {
  position: relative;
  display: flex;
  justify-content: space-between;
}

.titBox_my {
  display: flex;
  flex-direction: column;
}

.titBox::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: #F8F8F8;
  z-index: -1;
}

.titBox > .nameBox {
  display: flex;
  align-items: center;
  gap: 8px;
}

.titBox > .nameBox .txt {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .titBox > .nameBox .txt {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.titBox_my h3 {
  display: flex;
  gap: 8px;
  align-items: center;
}

.titBox_my h3 .numTit {
  display: flex;
  gap: 4px;
}

.total_num {
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
  display: flex;
  align-items: center;
  padding: 2px 8px;
  border: 1px solid #CED8F4;
  border-radius: 5px;
  box-sizing: border-box;
  color: #6160F4;
}
@media screen and (max-width: 980px) {
  .total_num {
    font-size: 13px;
    line-height: 17px;
    font-weight: 700;
  }
}

.titBox .naviBox {
  flex: 1;
  display: flex;
  justify-content: end;
}

.titBox .naviBox > ul {
  display: flex;
  cursor: pointer;
}

.titBox .naviBox > ul li {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 16px;
  padding: 8px;
}

.titBox .naviBox > ul li span {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .titBox .naviBox > ul li span {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.titBox .naviBox > ul li.now span {
  color: #446CF9;
  position: relative;
}

.titBox .naviBox > ul li.now::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: #446CF9;
}

.titBox .naviBox > ul li.now .chev {
  display: none;
}

/* 페이징 */
.pasing {
  display: flex;
  justify-content: center;
  padding: 64px 0;
}

.pasing ul {
  display: flex;
  gap: 8px;
}

.pasing ul > li {
  position: relative;
  display: inline-block;
  width: 32px;
  cursor: pointer;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
.pasing ul > li::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.pasing ul > li > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pasing ul > li:hover {
  background: #D9D9D9;
}

.pasing ul > li.now {
  background: #2A2A2A;
  color: #FFFFFF;
}

/* 탭 박스 */
.tabBox {
  margin-top: 24px;
}

.tabBox .tabs {
  display: flex;
}

.tabBox .tabs > li {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  padding: 16px 0;
  position: relative;
  color: #878787;
  cursor: pointer;
}
@media screen and (max-width: 980px) {
  .tabBox .tabs > li {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.tabBox .tabs > li:hover {
  color: #212121;
}

.tabBox .tabs > li.current {
  color: #7084B7;
}

.tabBox .tabs > li::after {
  content: "";
  display: block;
  position: absolute;
  transition: all 0.3s;
  left: 0;
  bottom: 0;
  height: 2px;
  background: #F8F8F8;
}

.tabBox .tabs > li.current::after {
  right: 0;
  background: #CED8F4;
}

/* auth > 아이콘 */
.a_icon {
  position: relative;
  width: 48px;
  background: linear-gradient(180deg, #446CF9, #6160F4);
  border-radius: 5px;
  margin-bottom: 16px;
  border: 1px solid #6160F4;
}
.a_icon::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.a_icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.a_icon svg {
  width: 24px;
  overflow: visible;
}
.a_icon svg path {
  fill: #FFFFFF;
}
.a_icon svg path.search {
  fill: #CED8F4;
}
.a_icon svg path.key {
  fill: #E3EEFF;
}
.a_icon svg path.person {
  fill: #FFFFFF;
}
.a_icon svg path.spk {
  animation: top_to_bottom_ani 2s linear infinite;
}

/* 탭 */
.sol_tab > ul {
  display: flex;
}

.sol_tab > ul > li {
  flex: 1;
  display: flex;
  justify-content: center;
  padding: 16px;
}

/* 로그인 */
.l_input + .l_input {
  margin-top: 16px;
}

.l_input {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 16px;
  border: 1px solid #eeeeee;
  border-radius: 5px;
}

.l_input .icon {
  position: relative;
  width: 24px;
  color: #B1B1B1;
}
.l_input .icon::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.l_input .icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.l_input > input {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  border: 1px solid transparent;
}

.l_input .icon + input {
  padding-left: 56px;
}

.l_input > input:focus {
  border: 1px solid #446CF9;
}

.l_input > input::placeholder {
  color: #B1B1B1;
}

.login_wrap {
  padding: 24px 0;
}

.login_box {
  width: 100%;
}

.login_box .login_box_inner .auth_box_inner_inner {
  display: flex;
  align-items: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
  margin: auto;
  width: calc(40% - 32px);
  border: 1px solid #eeeeee;
  padding: 16px;
  box-sizing: border-box;
}
@media screen and (max-width: 980px) {
  .login_box .login_box_inner .auth_box_inner_inner {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
  }
}

.login_box h3.title {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  margin-bottom: 24px;
}
@media screen and (max-width: 980px) {
  .login_box h3.title {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.login_box .login_box_inner .input_box {
  width: 100%;
}

.login_box .login_box_inner button.login {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  padding: 8px 16px;
  border-radius: 5px;
  width: 100%;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .login_box .login_box_inner button.login {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.login_box .login_box_inner .idpw_s {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  width: 100%;
  text-align: right;
  padding: 16px 0;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .login_box .login_box_inner .idpw_s {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.login_box .login_box_inner .id_save {
  margin: 15px 0 15px 8%;
}

.login_box .login_box_inner .id_save label {
  font-size: 13px;
}

.login_box .login_box_inner .login_search {
  box-sizing: border-box;
  width: calc(40% - 32px);
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 8px;
  margin-top: 16px;
  font-size: 0;
}

.login_box .login_box_inner .login_search .join_que {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .login_box .login_box_inner .login_search .join_que {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.login_box .login_box_inner .login_search ul li.join a {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
}
@media screen and (max-width: 980px) {
  .login_box .login_box_inner .login_search ul li.join a {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

/* 회원가입 - 아이디 or 비번 찾기 */
.idpw_wrap {
  width: 100%;
  box-sizing: border-box;
  position: relative;
}

.idpw_wrap .icon_wrp {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 16px;
  box-sizing: border-box;
}

.idpw_wrap .idpw {
  display: flex;
  flex-direction: column;
  margin: auto;
  width: calc(40% - 32px);
  border: 1px solid #eeeeee;
}
@media screen and (max-width: 980px) {
  .idpw_wrap .idpw {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
  }
}

.idpw_wrap .idpw > div.id_f,
.idpw_wrap .idpw > div.pw_f {
  width: 100%;
  box-sizing: border-box;
}

.idpw_wrap .idpw > h3.title {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  text-align: center;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .idpw_wrap .idpw > h3.title {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.idpw_wrap .idpw > div .form {
  overflow: hidden;
  display: inline-block;
  box-sizing: border-box;
  width: 100%;
  padding-left: 16px;
  padding-right: 16px;
}

.idpw_wrap .idpw > div ul {
  width: 100%;
}

.idpw_wrap .idpw > div ul li {
  flex: 1;
}

.idpw_wrap .idpw .id_f .form {
  box-sizing: border-box;
}

.idpw_wrap .idpw .buttonWrap button.search {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
  cursor: pointer;
  border: 1px solid #446CF9;
  box-sizing: border-box;
  padding: 4px 16px;
  border-radius: 1000px;
  transition: all 0.3s;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .idpw_wrap .idpw .buttonWrap button.search {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.idpw_wrap .idpw .buttonWrap button.search:hover {
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .idpw_wrap .idpw .buttonWrap button.search {
    padding: 4px 4px;
  }
}

/* 회원가입 - 아이디 or 비번 찾기 결과 */
.id_res {
  display: flex;
  align-items: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
  margin: auto;
  width: calc(40% - 32px);
  border: 1px solid #eeeeee;
  padding: 16px;
  box-sizing: border-box;
}
@media screen and (max-width: 980px) {
  .id_res {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
  }
}

.id_res .notfnd_wrp {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}

.id_res .notfnd {
  width: 24%;
}

.id_res .title {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .id_res .title {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.id_res .titBox {
  margin-bottom: 16px;
}

.id_res .res_box p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  text-align: center;
  margin-bottom: 16px;
}
@media screen and (max-width: 980px) {
  .id_res .res_box p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.id_res .buttonWrap button.re {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .id_res .buttonWrap button.re {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.id_res .buttonWrap button.re:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}

.id_res .buttonWrap button.login {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .id_res .buttonWrap button.login {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.id_res .buttonWrap button.login:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
.id_res .buttonWrap button.login:hover {
  background: #05267F;
  color: #FFFFFF;
}

/* 회원가입 - 단계별 */
.step_wrap {
  margin-bottom: 16px;
}

.step_wrap ul {
  display: flex;
  width: 100%;
  padding: 0 0 16px;
}

.step_wrap ul .step {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  padding-top: 16px;
}

.step_wrap ul .step.passed {
  background: #F5F8FF;
}

.step_wrap ul .step .progress {
  width: 100%;
  height: 2px;
  background: #E3EEFF;
}

.step_wrap ul .step.current .progress {
  background: #446CF9;
}

.step_wrap ul .step .txt {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  display: inline-block;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .step_wrap ul .step .txt {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.step_wrap ul .step.current .txt {
  color: #446CF9;
}

/* 회원가입 - 약관 동의 */
.joinBox {
  width: 100%;
  box-sizing: border-box;
}

.join_wrap {
  margin: 0 auto;
  width: 840px;
  border: 1px solid #eeeeee;
  box-sizing: border-box;
}

.joinBox .join_wrap .title {
  overflow: hidden;
  text-align: center;
  margin-bottom: 16px;
}

.joinBox .join_wrap .title h3 {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #2A2A2A;
}
@media screen and (max-width: 980px) {
  .joinBox .join_wrap .title h3 {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.joinBox .join_wrap .title p {
  color: #878787;
}

.joinBox .join_wrap .title p span {
  color: #F94447;
}

.joinBox .join_wrap .join-con-wrap {
  width: 100%;
  padding: 16px;
  box-sizing: border-box;
}

.joinBox .join_wrap .join-con-wrap .all {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  display: flex;
  align-items: center;
  gap: 8px;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 980px) {
  .joinBox .join_wrap .join-con-wrap .all {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.joinBox .join_wrap .join-con-wrap input[type=checkbox] {
  display: none;
}

.joinBox .join_wrap .join-con-wrap input[type=checkbox] + label {
  display: inline-block;
  position: relative;
}

.joinBox .join_wrap .join-con-wrap .all_c_icon {
  position: relative;
  width: 24px;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  cursor: pointer;
  color: #5A5A5A;
}
.joinBox .join_wrap .join-con-wrap .all_c_icon::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.joinBox .join_wrap .join-con-wrap .all_c_icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.joinBox .join_wrap .join-con-wrap .all_c_icon > span svg path {
  fill: #878787;
}

.joinBox .join_wrap .join-con-wrap input[id=all_c]:checked + .all_c_icon,
.joinBox .join_wrap .join-con-wrap input[id=inp_02]:checked + .all_c_icon,
.joinBox .join_wrap .join-con-wrap input[id=inp_03]:checked + .all_c_icon,
.joinBox .join_wrap .join-con-wrap input[id=inp_04]:checked + .all_c_icon {
  background: #446CF9;
}
.joinBox .join_wrap .join-con-wrap input[id=all_c]:checked + .all_c_icon svg path,
.joinBox .join_wrap .join-con-wrap input[id=inp_02]:checked + .all_c_icon svg path,
.joinBox .join_wrap .join-con-wrap input[id=inp_03]:checked + .all_c_icon svg path,
.joinBox .join_wrap .join-con-wrap input[id=inp_04]:checked + .all_c_icon svg path {
  fill: #FFFFFF;
}

.joinBox .join_wrap .join-con-wrap .text_area {
  width: 100%;
  overflow: hidden;
  box-sizing: border-box;
}

.joinBox .join_wrap .join-con-wrap .text_area > div {
  width: 100%;
  overflow: hidden;
  margin-bottom: 24px;
}

.joinBox .join_wrap .join-con-wrap .text_area > div > div.tit {
  font-weight: bold;
  color: #446CF9;
  padding: 16px 0;
}

.joinBox .join_wrap .join-con-wrap .text_area > div .checkbox_grp {
  display: flex;
  align-items: center;
  gap: 8px;
}

.joinBox .join_wrap .join-con-wrap .text_area > div .checkbox_grp label {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
}
@media screen and (max-width: 980px) {
  .joinBox .join_wrap .join-con-wrap .text_area > div .checkbox_grp label {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.joinBox .join_wrap .join-con-wrap .text_area > div .text {
  resize: none;
  height: 300px;
  border: 1px solid #eeeeee;
  overflow-y: auto;
  margin-bottom: 16px;
  box-sizing: border-box;
  padding: 16px;
}

.joinBox .join_wrap .join-con-wrap .text_area > div textarea:focus {
  outline: none;
}

.joinBox .join_wrap .join-con-wrap .text_area > div input[type=checkbox] {
  display: none;
}

.joinBox .join_wrap .join-con-wrap .all {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  display: flex;
  align-items: center;
  gap: 8px;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 980px) {
  .joinBox .join_wrap .join-con-wrap .all {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

/* 회원가입 - 인증 버튼 */
.certified {
  display: flex;
  width: 100%; height:200px;
  overflow: hidden;
  box-sizing: border-box;
  text-align: center;
  border-top: 1px solid #eeeeee;
  justify-content: space-evenly;
  padding-top: 16px;
  padding-bottom: 16px;
}

.certified .cell-certified {
  position: relative;
  width: calc((100% - 48px) / 2);
  box-sizing: border-box;
  border: 1px solid #eeeeee;
  border-radius: 5px;
  background: #FFFFFF;
  transition: all 0.3s;
}
.certified .cell-certified::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.certified .cell-certified > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.certified .cell-certified > div {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  font-size: 0;
  padding: 24px;
  box-sizing: border-box;
}

.certified .cell-certified > div .icon_wrp {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0;
  width: 100%;
}

.certified .cell-certified > div .icon_wrp .icon {
  position: relative;
  width: 48px;
  box-shadow: 0 4px 8px rgba(42, 42, 42, 0.1);
  border-radius: 5px;
  background: #FFFFFF;
}
.certified .cell-certified > div .icon_wrp .icon::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.certified .cell-certified > div .icon_wrp .icon > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.certified .cell-certified > div .icon_wrp .icon i {
  font-size: 24px;
  color: #878787;
}

.certified .cell-certified > div p {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .certified .cell-certified > div p {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.certified .cell-certified:hover {
  border: 1px solid #446CF9;
  background: #F5F8FF;
}

.certified .cell-certified:hover > div .icon_wrp .icon i {
  color: #446CF9;
}

/* 회원가입 - 정보 입력 */
.info_in {
  width: 100%;
  box-sizing: border-box;
}

.info_in ul {
  width: 100%;
}

/* 라벨 & 인풋창 분리 형식 */
.info_in ul li {
  padding: 8px 0;
  box-sizing: border-box;
}

.info_in ul li:last-child {
  padding-bottom: 0px;
  margin-bottom: 0px;
  border-bottom: none;
}

.info_in ul li p.tit {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  margin-bottom: 8px;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .info_in ul li p.tit {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

.info_in ul li p.tit span {
  color: #F94447;
}

.info_in ul li > div {
  display: flex;
  align-items: center;
  gap: 4px;
  width: 100%;
  clear: both;
}

.info_in ul li > div.column {
  flex-direction: column;
}

.info_in ul li > div.column > .line {
  width: 100%;
  display: flex;
  gap: 8px;
}

.info_in ul li > div button {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
  cursor: pointer;
  border: 1px solid #446CF9;
  box-sizing: border-box;
  padding: 4px 16px;
  border-radius: 1000px;
  transition: all 0.3s;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .info_in ul li > div button {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.info_in ul li > div button:hover {
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .info_in ul li > div button {
    padding: 4px 4px;
  }
}

.info_in ul li > div input {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  flex-direction: column;
  width: inherit;
  flex: 1;
  padding: 8px 0;
  border-bottom: 1px solid #eeeeee;
  color: #5A5A5A;
}




@media screen and (max-width: 980px) {
  .info_in ul li > div input {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.info_in ul li > div input::placeholder {
  color: #D9D9D9;
}

.info_in ul li > div input.id_inp {
  width: 50%;
}

ul li > div label {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #2A2A2A;
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 16px;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 980px) {
  ul li > div label {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

ul li > div label .background {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border: 1px solid #eeeeee;
  border-radius: 5px;
}

ul li > div label input[type=radio] {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  visibility: hidden;
}

ul li > div label .check_wrp {
  display: flex;
  justify-content: end;
}

ul li > div label .check_wrp .check {
  position: relative;
  display: block;
  width: 16px;
  border: 1px solid #D9D9D9;
  border-radius: 1000px;
}
ul li > div label .check_wrp .check::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
ul li > div label .check_wrp .check > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

ul li > div label .check_wrp .check::before {
  content: "";
  display: block;
  position: absolute;
  border-radius: 1000px;
  background: #446CF9;
  top: 4px;
  left: 4px;
  right: 4px;
  bottom: 4px;
  display: none;
}

ul li > div label input[type=radio]:checked ~ .background {
  z-index: -1;
  border: 2px solid #446CF9;
}

ul li > div label input[type=radio]:checked ~ .check_wrp .check {
  border: 1px solid #446CF9;
}

ul li > div label input[type=radio]:checked ~ .check_wrp .check::before {
  display: block;
}

.jinbutton_wrap {
  padding: 16px;
  display: flex;
  justify-content: end;
  gap: 8px;
}

.jinbutton_wrap > button {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
}
@media screen and (max-width: 980px) {
  .jinbutton_wrap > button {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.jinbutton_wrap > button:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}

.jinbutton_wrap > button.next {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 8px 16px;
  border: 1px solid #D9D9D9;
  background: #FFFFFF;
  color: #878787;
  border-radius: 5px;
  transition: all 0.3s;
  background: #446CF9;
  color: #FFFFFF;
}
@media screen and (max-width: 980px) {
  .jinbutton_wrap > button.next {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}
.jinbutton_wrap > button.next:hover {
  border: 1px solid #446CF9;
  color: #446CF9;
}
.jinbutton_wrap > button.next:hover {
  background: #05267F;
  color: #FFFFFF;
}

/* 검색 페이지 */
.allsearchBox {
  padding-top: 16px;
  background: #F5F8FF;
}

.allsearchBox > .inner {
  max-width: 1200px;
  margin: auto;
}

.tab_menu_search .tab-content {
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-bottom: 24px;
}

/* 검색 페이지 > 검색 갯수 */
.allsearchBox .search_total {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 16px;
}

.allsearchBox .search_total h2 {
  font-size: 24px;
  line-height: 30px;
  font-weight: bold;
  color: #2A2A2A;
  position: relative;
}
@media screen and (max-width: 980px) {
  .allsearchBox .search_total h2 {
    font-size: 18px;
    line-height: 22px;
    font-weight: bold;
  }
}

.allsearchBox .search_total h2::after {
  content: "";
  display: block;
  position: absolute;
  right: -8px;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: #D9D9D9;
}

.search_total .resultTxt {
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  color: #5A5A5A;
}
@media screen and (max-width: 980px) {
  .search_total .resultTxt {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
  }
}

/* 검색 페이지 > 인풋 */
.allsearchBox .search_Box .search {
  position: relative;
}

.allsearchBox .search_Box .search form {
  display: flex;
  width: 100%;
  position: relative;
}

.allsearchBox .search_Box .search input {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  width: 100%;
  display: flex;
  padding: 16px 24px;
  background: #FFFFFF;
  border-radius: 5px;
  box-shadow: 0 0 8px rgba(42, 42, 42, 0.05);
}
@media screen and (max-width: 980px) {
  .allsearchBox .search_Box .search input {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.allsearchBox .search_Box .search button {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
}

.allsearchBox .search_Box .search button > span {
  position: relative;
  display: block;
  width: 24px;
  background: #446CF9;
  color: #FFFFFF;
  padding: 4px;
  border-radius: 5px;
  transition: all 0.3s;
}
.allsearchBox .search_Box .search button > span::after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.allsearchBox .search_Box .search button > span > * {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.allsearchBox .search_Box .search button:hover > span {
  background: #1345f7;
}

/* 검색 페이지 > 탭 */
.tabBox .tabs > li {
  gap: 8px;
  color: #5A5A5A;
}

.tabBox .tabs > li .num {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  padding: 4px 10px;
  background: #FFFFFF;
  color: #446CF9;
  border-radius: 1000px;
  box-shadow: 0 0 4px rgba(90, 90, 90, 0.1);
}
@media screen and (max-width: 980px) {
  .tabBox .tabs > li .num {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

/* 검색 페이지 > 검색 결과 */
.tab_menu_search .titBox {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 0 0 16px;
}

.tab_menu_search .titBox h3 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
  display: flex;
  gap: 8px;
}
@media screen and (max-width: 980px) {
  .tab_menu_search .titBox h3 {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
  }
}

.tab_menu_search .titBox p {
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #446CF9;
}
@media screen and (max-width: 980px) {
  .tab_menu_search .titBox p {
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }
}

/* 검색 페이지 > 검색 결과 리스트 */
.tab_menu_search .content {
  margin-top: 64px;
}

.tab_menu_search .content .board {
  display:flex; flex-flow:column nowrap; gap:16px;
}

.tab_menu_search .content .board > li {
  position: relative;
  width: 100%;
  background: #FFFFFF;
  transition: all 0.3s;
}


.tab_menu_search .content .board > li:hover a h3 {
  color: #446CF9;
}

.tab_menu_search .content .board > li a {
  width:100%; display: flex; flex-flow:row nowrap; align-items:center; box-sizing: border-box; padding:0 16px 16px; border-bottom:1px solid #f7f7f7;
}

.tab_menu_search .content .board > li a .tit {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 800 !important;
  color: #2A2A2A;
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
white-space:nowrap; margin-right:16px;
}
@media screen and (max-width: 980px) {

  .tab_menu_search .content .board > li a .tit {
    font-size: 16px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
	width:100%;
  }
}

.tab_menu_search .content .board > li a p.txt_con {
  font-size: 16px;
  line-height: 23px;
  font-weight: 500;
  color: #5A5A5A;
  min-height: 115px;
  max-height: 115px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 5;
  width: 100%;
}
@media screen and (max-width: 980px) {
  .tab_menu_search .content .board > li a p.txt_con {
    font-size: 13px;
    line-height: 17px;
    font-weight: 500;
  }
}

.tab_menu_search .content .board > li a p.txt_con img {
  width: 100% !important;
  height: auto !important;
}

.tit + p.txt_con {
  margin-top: 16px;
}

.tab_menu_search .content .board > li .datebox {
  display: flex; margin-left:auto; gap:16px; font-size:14px; color:#777; align-items:center;
}

.tab_menu_search .content .board > li .datebox li {width:60px;}


.tab_menu_search .content .board > li .datebox .date {
	width:110px;
  font-size: 14px !important;
  line-height: 18px !important;
  font-weight: 500 !important;
  color: #878787;
}
@media screen and (max-width: 980px) {
  .tab_menu_search .content .board > li .datebox .date {
	width:100px;
    font-size: 13px !important;
    line-height: 13px !important;
    font-weight: 500 !important;
  }

	.listView {margin-top:0;}
	.tab_menu_search .content .board > li a {flex-flow:column wrap; align-items:flex-start;}
	.tab_menu_search .content .board > li .datebox {margin-left:0;}
}


.tab_menu_search .content .board > li .datebox .date .date_icon {
  margin-right: 4px;
}

@media screen and (max-width: 980px) {
  .leftMenu {
    display: none;
  }
  .max_width1200 {
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }
  .max_width1200 .sub_content {
    max-width: 100%;
  }
  .max_width1200 .contentBox {
    max-width: 100%;
  }
  .titBox {
    flex-direction: column;
  }
  .titBox .naviBox > ul {
    justify-content: end;
  }
  .titBox_my::after {
    display: none;
  }
  /* 셀렉트 박스 */
  .selectBox2 {
    width: 100%;
  }
  .selectBox2 .select {
    box-sizing: border-box;
  }
  .selectBox2 .select a {
    white-space: nowrap;
    display: inline-grid;
    text-overflow: ellipsis;
    width: 100%;
  }
  .selectBox2 .select a span {
    overflow: hidden;
    text-overflow: ellipsis;
  }
  /* 과정 자료 */
  .contentBox .tab-content .data {
    flex-direction: column;
  }
  .contentBox .tab-content .data > li .titBox {
    flex-direction: row;
  }
  /* 로그인 */
  .login_box .login_box_inner .login_box_inner_inner .a_icon {
    width: 10vw;
  }
  .login_box .login_box_inner .login_box_inner_inner .a_icon svg {
    width: 6vw;
  }
  .login_box .login_box_inner .login_box_inner_inner {
    width: 100%;
  }
  .login_box .login_box_inner .login_search {
    width: 100%;
  }
  /* 회원가입 - 약관 동의 */
  .join_wrap {
    width: 100%;
  }
  /* 회원가입 - 인증 버튼 */
  .certified button.cell-certified > div {
    padding: 16px;
  }
  .certified button.cell-certified > div .icon_wrp .icon {
    width: 10vw;
  }
  .certified button.cell-certified > div .icon_wrp .icon i {
    font-size: 5vw;
  }
  /* 검색 페이지 > 검색 갯수 */
  .allsearchBox > .inner .top {
    padding: 0 16px;
  }
  .allsearchBox .search_Box .search button {
    right: 8px;
  }
  /* 검색 페이지 > 검색 결과 리스트 */
  .tab_menu_search .content {
    margin-top: 40px;
  }
  .tab_menu_search .content .board {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
  .tab_menu_search .titBox {
    flex-direction: row;
  }
  .tab_menu_search .content .board > li a {
    padding: 16px;
  }
  .tit + p.txt_con {
    margin-top: 0;
  }
  .tab_menu_search .content .board > li a .tit {
    max-height: 48px;
  }
  .tab_menu_search .content .board > li a p.txt_con {
    min-height: 34px;
    max-height: 34px;
    -webkit-line-clamp: 2;
  }
  .tab_menu_search .content .board > li .datebox {
    padding-top: 16px;
  }
}

/*# sourceMappingURL=sub.new.css.map */
