@charset "UTF-8";
html{
	overflow-x: hidden;
}
#main {
	min-height: 100vh;
	background-color: #FDF9FF;
}

/* 메인 비주얼   */
#main_visual {
	position: relative;
	background-image: url(/images/main/intro-46dd5e620b8030992ad0eb6276373626.svg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center bottom;
	height: 720px;
	text-align: center;
	overflow: hidden;
	cursor: url('images/main/mouse_icon.png'), auto;
}

#main_visual .banner_title,
#main_visual .sub_title {
    opacity: 0;
    transform: translateY(30px);
}


#main_visual .banner_title {
	padding-top: 80px;
	padding-bottom: 20px;
	font-size: 63px;
	font-weight: 700;
	line-height: 130%;
	letter-spacing: -1%;
	color: var(--Color-Grey-900);
}

#main_visual .banner_title .point_color{
	color:var(--Color-Primary-600);
}

#main_visual .sub_title {
	color: var(--Color-Grey-800);
}

#main_visual .btn_big svg {
	width: 20px;
	height: 20px;
}

#main_visual img {
	position: absolute;
}

#main_visual img.student01 {
	width: 350px;
	left: 9.5%;
	bottom: 6%;
	z-index: 10;
}

#main_visual img.student02 {
	width: 280px;
	left: 41.2%;
	bottom: 12%;
	z-index: 10;
}

#main_visual img.student03 {
	width: 350px;
	left: 70%;
	bottom: 6%;
	z-index: 10;
}

#main_visual img.student04 {
	width: 230px;
	left: 29%;
	bottom: 20%;
}

#main_visual img.student05 {
	width: 230px;
	left: 56%;
	bottom: 20%;
}

#main_visual a.btn_big:hover {
	cursor: url('images/main/mouse_icon.png'), auto;
}

/* 메인 내용 */
#main_container {
	width: 100%;
	max-width: 1800px;
	border-radius: 40px 40px 0 0;
	margin: -80px auto 0;
	background-color: var(--Color-Grey-100);
	position: relative;
	z-index: 20;
	box-shadow: 0px 20px 24px 0px rgba(0, 0, 0, 0.11);
}

#main_container .banner_group {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

#main_container .banner_group.full_width {
	max-width: none;
	background-image: url(/images/main/full_sub_bg_1-c25255756afb0bb33dcb52eddbd73735.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	height: 410px;
}

#main_container .banner_group.full_width .inner_wrap {
	width: 100%;
	max-width: 1000px;
	padding-top: 100px;
	padding-left: 40px;
	margin: 0 auto;
}

#main_container .banner_group.full_width .inner_wrap a {
	margin-top: 40px;
}

#main_container .group1-1 {
	display: flex;
	gap:20px;
	justify-content: space-between;
	padding-top:30px;
}
#main_container .group1-2{
	padding-bottom: 50px;
	margin-top:20px;
}

#main_container .basic_box {
	padding: 40px;
	height: 320px;
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-content: space-between;
}
#main_container .basic_box img{
	 transition: transform 0.3s ease;
}
#main_container .basic_box:hover img{
	 transform: scale(1.08);
}
#main_container .basic_box .banner_title {
	width: 100%;
}

#main_container .basic_box img {
	position: absolute;
	right: 0;
	bottom: 0;
}

#main_container .group1-1 .banner_1,
#main_container .group1-1 .banner_2 {
	width: 490px;
}

#main_container .group1-1 .banner_1 img {
	right: 20px;
	bottom: 20px;
}

#main_container .group1-2 .banner_3 {
	width: 100%;
	overflow: hidden;
}
#main_container .group1-2 .banner_3 video{
	position: absolute;
	right: 70px;
	width:65%;
	right: 50px;
	top:40px;
	border-radius: 15px;
}
#main_container .group1-2 .banner_3 a{
	z-index: 20;
}
#main_container .group1-2 .banner_3 img {
	right: 0;
}

#main_container .group2 {
	padding: 50px 0;
	display: flex;
	gap: 20px;
}

#main_container .group2 .basic_box {
	width: 49%;
	max-width: 490px;
	height: 600px;
	transition: transform 0.3s ease;
	will-change: transform;
}
#main_container .group2 .basic_box.banner_4{
	transform-origin: right bottom; 
}
#main_container .group2 .basic_box.banner_5{
	transform-origin: left bottom; 
}

.banner_group.group2 .basic_box:hover {
  transform: scale(1.05); 
  z-index: 1;
}
#main_container .group2 .basic_box .banner_title svg {
	margin-bottom: 7px;
}

#main_container .group2 .basic_box img {
	position: static;
}

.accordion_list_wrap {
	padding: 50px 0;
	background-color: #F8F8F8;
}

.accordion_list_wrap .inner_group {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}

.accordion_list_wrap .inner_group .accordion_list {
	width: 410px;
}

.accordion_list>li {
	padding: 40px 0;
	position: relative;
}

.accordion_list>li+li {
	border-top: 1px solid #C2C2C2;
}

.accordion_list>li>.title {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
} 
.accordion_list> li >.title > div{
	width:70%;
}
.accordion_list> li.active >.title > div{
	width:80%;
	font-size:32px;
	font-weight:700;
	color:var(--Color-Grey-800);
	word-break: keep-all;
}

.accordion_list>li>.content {
	display: none;
	color:var(--Color-Grey-700);
}
.accordion_list>li>.content .desc{
	padding:20px 0 40px;
}

.image_viewer {
	width: 490px;
	position: relative;
}

.image_viewer>li {
	display: none;
}

.image_viewer>li.active {
	display: block;
}

.accordion_list>li>.title svg {
	transition: transform 0.3s ease;
}

.accordion_list>li .progress_bar {
	position: absolute;
	left: 0;
	top: 0;
	height: 2px;
	width: 100%;
	background-color: #ccc;
	transform-origin: left;
	transform: scaleX(1);
	opacity: 0;
	pointer-events: none;
	z-index: 10;
	transition: opacity 0.3s ease;
}

.accordion_list>li.active .progress_bar {
	opacity: 1;
}

.last_banner {
	margin-top:50px;
	height: 334px;
	display: flex;
	align-items: center;
	background-image: url(/images/main/full_sub_bg_2-34fb552620b91bd737018e1bbc141d2a.svg);
	background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.last_banner .inner_group {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.last_banner .inner_group .banner_title {
	color: var(--Color-Grey-100);
	font-size: 48px;
	font-weight: 700;
}

.last_banner .inner_group a.btn_teritary {
	background-color: var(--Color-Grey-100);
}

/* 푸터 */
#main_footer {
	width: 100%;
	background-color: var(--Color-Grey-700);
}

.footer_menu_wrap {
	border-bottom: 1px solid var(--Color-Grey-600);
	padding: 24px 0;
	display: flex;
	justify-content: center;
}

.footer_menu_wrap .inner_group {
	display: flex;
	width: 1000px;
	margin: 0 auto;
	justify-content: space-between;
}

.footer_menu_wrap .inner_group .menu_wrap {
	display: flex;
	gap: 60px;
	align-items: center;
}

.footer_menu_wrap .inner_group .footer_menu {
	display: flex;
	gap: 32px;
}

.footer_menu_wrap .inner_group .footer_menu a {
	color: var(--Color-Grey-300);
}

.footer_menu_wrap .inner_group .footer_menu a.privacy {
	font-weight: 600;
}

.input-wrapper.family_site {
	width: auto;
}

.input-wrapper.family_site select {
	width: 225px;
	border-radius: 22px;
	background-color: var(--Color-Grey-600);
	border: none;
	color: var(--Color-Grey-200);
	background-image: url(/images/main/ic_open-c57a55009fb8fb45a32cdd3d7733525c.svg);
}

.site_info_wrap {
	padding: 40px 0 80px;
}

.site_info_wrap .inner_group {
	width: 100%;
	max-width:1000px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	color: var(--Color-Grey-400);
}
.site_info_wrap .inner_group .info_wrap{
	width:70%;
}
.site_info_wrap .inner_group .customer_service{
	width:30%;
}

.info_wrap .inner_row.hosting {
	margin: 12px 0 24px;
}

.site_info_wrap a.footer_email {
	color: var(--Color-Grey-400);
	text-decoration: underline;
}

.site_info_wrap a.business_info_btn {
	background-color: #D7D7D7;
	color: #212121;
	font-size: 12px;
	font-weight: 600;
	border-radius: 16px;
	padding: 4px 8px;
}

.site_info_wrap .customer_service .inner_row.cs_title {
	color: var(--Color-Grey-200);
	font-size: 14px;
}

.site_info_wrap .customer_service .inner_row.tell {
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 12px;
}

.site_info_wrap .customer_service .sns_link_wrap {
	margin-top: 26px;
}

.site_info_wrap .customer_service .sns_link_wrap .sns_link_list {
	display: flex;
	gap: 20px;
	align-items: center;
}


/* 이용약관 */
.purple_body {
	background-color: #FDF9FF;
}

.policy_title {
	margin-bottom: 80px;
	text-align: center;
	color: var(--Color-Grey-800);
}

.policy_details {
	word-break: keep-all;
}

.policy_group+.policy_group {
	margin-top: 80px;
}

.policy_content {
	padding: 100px 0;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.policy_group_title {
	margin-bottom: 20px;
	color: var(--Color-Grey-800);
}

.policy_group_detail {
	color: var(--Color-Grey-700);
}

.list_box+.list_box {
	margin-top: 20px;
}

span.strong {
	color: var(--Color-Grey-900);
}

/* 리스트스타일 없음 */
.not_style {
	list-style: none;
	padding-left: 0;
}

/* 숫자 */
.list_type1 {
	list-style: decimal;
	padding-left: 20px;
}

/* 괄호 숫자*/
.list_type2 {
  list-style: none;
  counter-reset: item;
  padding-left: 0;
}

.list_type2 > li {
  position: relative;
  padding-left: 20px; 
}

.list_type2 > li::before {
  counter-increment: item;
  content: counter(item) ") ";
  position: absolute;
  left: 0;
  width: 20px;
  display: inline-block;
}

/* 원 숫자*/
.list_type3 {
	list-style: none;
	padding-left: 0;
	margin: 0;
}

.list_type3>li {
	position: relative;
	padding-left: 20px;
}

.list_type3 > li:nth-child(1)::before { content: "① "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(2)::before { content: "② "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(3)::before { content: "③ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(4)::before { content: "④ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(5)::before { content: "⑤ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(6)::before { content: "⑥ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(7)::before { content: "⑦ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(8)::before { content: "⑧ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(9)::before { content: "⑨ "; position: absolute; left: 0; top: 0; }
.list_type3 > li:nth-child(10)::before { content: "⑩ "; position: absolute; left: 0; top: 0; }

/* '-' 스타일 */
.list_type4{
	padding-left: 20px;
}
.list_type4 > li::marker {
	content: "- ";
}

/* '※' 스타일 */
.list_type5{
	padding-left:20px;
}
.list_type5 >li::marker {
	content: "※ ";
}

/* 기본 숫자 스타일 */
.list_type6{
	list-style: decimal;
	padding-left:20px;
}

/* 점 스타일 */
.list_type7{
	padding-left:20px;
}
.list_type7 > li::marker{
	content: '·  ';
}

/* 테이블 스타일 */
table.policy_tb{
	width:100%;
	margin:20px 0;
}
table.policy_tb thead th{
	background-color: var(--Color-Grey-200);
	padding:10px;
	text-align: center;
	border: 1px solid var(--Color-Grey-300);
}
table.policy_tb thead th:first-of-type,
table.policy_tb tbody td:first-of-type{
	border-left:none;
}
table.policy_tb thead th:last-of-type,
table.policy_tb tbody td:last-of-type{
	border-right:none;
}
table.policy_tb tbody td{
	border:1px solid var(--Color-Grey-300);
	padding:20px;
	text-align: center;
}
.main_notice_wrap{
	width:100%;
	max-width:1000px;
	margin:0 auto;
	padding:30px 0 0; 
}
.main_notice_list_wrap .notice_list{
	display: flex;
	gap:14px;
	margin-top:12px;
}

.main_notice_list_wrap .notice_list li{
	width:100%;
	height:110px;
	border:1px solid var(--Color-Grey-200);
	border-radius: 20px;
	padding:16px 20px;
}
.main_notice_list_wrap .notice_list li .notice_date {
  color:var(--Color-Grey-400);
}
.main_notice_list_wrap .notice_list li .notice_title {
  color:var(--Color-Grey-700);
}

.notice_row {
    cursor: pointer;
}

.ellipsis-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4em;
  max-height: 2.8em;
}

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

.main_notice_title_wrap a.notice_more{
	display: flex;
	align-items: center;
	color:var(--Color-Grey-400);
}

/*퀵메뉴*/
#quickMenu{
	position: fixed;
	right:50px;
	bottom:50px;
	z-index: 9999;
}
#quickMenu .quickMenu_list{
	display: flex;
	flex-direction: column;
	gap:15px;
	justify-content: flex-end;
    align-items: flex-end;
}
#quickMenu a{
	display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    width: clamp(48px, 4.1vw, 60px);
    height: clamp(48px, 4.1vw, 60px);
    padding: 0 clamp(8px, .96vw, 14px);
    border-radius: 999px;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, .24);
    background-color: #fff;
    transition: all .1s ease-in;
}
#quickMenu a span{
    width: 0;
    opacity: 0;
    color: var(--Color-Grey-800);
    font-size: clamp(16px, 1.25vw, 18px);
    font-weight: 400;
    line-height: 100%;
    font-weight: 600;
}

#quickMenu a svg {
    width: clamp(28px, 2.2vw, 32px);
    height: auto;
    color: var(--Color-Grey-800);
}


#quickMenu a:hover {
    width: fit-content;
}

#quickMenu a:hover span{
    width: fit-content;
    opacity: 1;
    padding: 0 8px
}

#quickMenu a:focus,
#quickMenu a:active {
  box-shadow: 2px 2px 10px rgba(0, 0, 0, .24) !important;
  outline: none;
}

/* 미디어 쿼리 */
@media all and (max-width: 1440px) {
	#main_visual img.student01 {
		width: 400px;
		height: 310px;
		left: 7%;
		bottom: 4%;
	}
	#main_visual img.student02 {
		width: 320px;
		height: 300px;
		left: 39%;
		bottom: 10%;
	}
	#main_visual img.student03 {
		width: 370px;
		height: 350px;
		left: 65%;
		bottom: 4%;
	}
	#main_visual img.student04 {
		width: 200px;
		height: 230px;
		left: 28%;
		bottom: 22%;
	}
	#main_visual img.student05 {
		width: 200px;
		height: 210px;
		left: 56%;
		bottom: 22%;
	}
}


@media all and (max-width:1200px){
	#main_visual{
		background-image: url('/images/main/intro_mo-e45e7b6d4cbea682ea27cb7b53e43963.svg');
	}
	#main_visual img{
		display: none;
	}
}

@media all and (max-width:1000px){
	#header_content{
		padding:0 10px;
	}
	.gnb_list{
		gap:20px;
	}
	#user_info_box,
	#mypage_menu,
	.mypage-container .content_wrap,
	.board_content_wrap,
	#main_container .banner_group,
	.accordion_list_wrap .inner_group,
	.last_banner .inner_group,
	.main_notice_wrap{
		padding-left:10px;
		padding-right:10px;
	}
}