@charset "utf-8";
@media (max-width:1600px) {
	#main #container .contain {max-width:1260px;}
	/* main */
	.main-visual .caption, .main-visual .controls {max-width:1260px;}
}

@media (max-width:1200px) {
	.sitelogo img {height:16px;}
	#gnb > ul > li > a {padding:0 20px;}
}

/* Landscape tablet */
@media (max-width:1024px) {
	
	/* header */
	#header .contain.c1 a {height:30px; padding:0 15px;}
	#header .contain.c2 {height:56px;}

	#gnb ul {display:none;}
	.btn-m-menu {display:block;}

	#header .util {margin-right:20px;}

	.mobile-navigation {display:block;}
	.mobile-navigation .close {top:22px;}

	.sitelogo img {height:15px;}

	/* main */
	.main-visual, .main-visual .item {height:40vh;}
	.main-visual .controls {bottom:20%;}

	.main-sec3 .col-r {width:65%;}

	.partners li {width:33.3333%;}

	/* footer */
	#footer {padding:var(--space-80) 0;}

	.f-logo img {height:20px;}
	.foot-info {gap:3px 0;}

	/* sub layout */
	.real-cont {min-height:300px;}

	.sub-title h1:after {width:25px; bottom:-20px;}

	.sub-tab li a {padding-bottom:12px;}
	.sub-tab2 li a {padding:0 12px; line-height:34px;}

	/* content */
	.about dt {width:300px;}
	
	.curriculum .title span {line-height:34px; padding:0 15px;}
		
	.gallery-list ul {margin:0 -20px -30px;}
	.gallery-list ul li {width:33.3333%; padding:0 20px; margin-bottom:30px;}

	.calendar-mid .item:before, 
	.calendar ul li:before, 
	.schedule table td .etc:before {width:6px; height:6px;}

	.schedule table td .etc {padding-left:12px; margin-top:10px;}
	.schedule table td .etc:before {top:3px;}

	.apply-wrap .right {width:350px; top:130px;}
	.apply-imgs .num-3 {margin:0 -5px 10px;}
	.apply-imgs .num-3 .thumb {padding:0 5px;}

	.btn-pack.xxlarge {line-height:48px; height:50px;}
	
	.my-task dd a {min-width:80px;}

	.inq-form .input {height:50px;}
	.lecture .table table th, .lecture .table table td {height:52px;}
	.lecture .table .checkbox label:before {width:22px; height:22px;}

	.pop-director .col-img {width:350px;}
	.pop-director .col-info {max-height:440px;}

	/* member */
	.member-leave .form .group .input,
	.join-form dl .input {height:50px;}
	.join-form dl dd .btn-pack {height:50px; line-height:48px;}

	.join-form dl .input.v-wid,
	.join-form dl .input.v-wid {width:240px !important;}
	
	/* board */
	.input {padding:5px 14px; height:40px;}
	textarea.input {padding:12px 14px;}

	.board-search .search input.input {width:240px;}

	.board-list colgroup col {width:auto !important;}
	.board-list table thead th {font-size:15px;}
	.board-list table tbody td {font-size:15px;}

	.gallery-list ul li .tit {font-size:15px;}

	.news-list .thumb {width:200px;}
	.news-list .tit {font-size:17px;}
	.news-list .txt {font-size:14px;}
	.news-list .date {font-size:13px;}

	.event-list ul li .tit {font-size:15px;}

	.faq .tit {font-size:15px;}
	.faq .tit a {padding:9px 60px 9px 12px;}
	.faq .tit a:after {top:14px;}
	.faq .q {flex:0 0 32px; width:32px; height:32px; font-size:16px; line-height:32px;}
	.faq .cnt {padding:18px 25px 18px 60px;}

	.calendar-head h3 {font-size:28px; margin:0 30px;}
	.calendar-head .cal-btn {width:40px; height:40px;}
	.calendar table th {font-size:15px;}
	.calendar table td {height:110px; font-size:14px;}
	.calendar ul li {padding-left:12px; margin-bottom:12px;}
	.calendar ul li:before {top:6px;}

	.board-white table {font-size:15px;}

	.board-form table {font-size:15px;}

	.files-upload-text .upfiles-alt {font-size:14px;}

	.board-view-tit h3 {font-size:18px;}
	.board-view-info {padding:13px 6px; font-size:13px;}
	.board-view-cnt {padding:15px 6px 40px;}

	.board-prev-next {font-size:14px;}

	.btn-pack.medium {height:40px; padding:0 16px; font-size:15px; line-height:38px;}
	.btn-pack.large {min-width:140px; height:50px; font-size:18px; line-height:48px;}

	.product-list ul li {width:25%;}
	.product-list ul li .tit {font-size:15px;}
	.product-image {width:350px;}
	.product-info .tit {font-size:25px;}

	.store-search {padding:22px 5%;}
	.store-search .map-area {width:280px;}
	.store-search .map-img .local {padding:0 10px; font-size:13px; line-height:22px;}

	.result-group .gall li {width:25%;}

}


/* portrait tablet */
@media (max-width:900px) {	
	.only-desktop {display:none;}
	.only-tablet {display:block;}

	/* content */
	.lec-table {display:block; width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;}
	.lec-table table {width:1000px;}

	.instr-search .itm {flex:auto;}

	.lec-table thead th, .lec-table tbody td {height:54px;}

	.modal a.close-modal {top:25px;}

	/* board */	
	.gallery-list ul {margin:0 -10px;}
	.gallery-list ul li {width:33.33333333%; padding:0 10px;}

	.event-list ul li {width:50%;}

	.store-search {padding:30px; margin-bottom:30px;}
	.store-search .map-area {display:none;}
	.store-search .search-area h3 {text-align:center; margin-bottom:30px;}

} 

/* Landscape phone */
@media (max-width:700px) {
	:root {
		--contain-padding:15px; 
	}
	
	.only-desktop-tablet {display:none;}
	.only-tablet {display:none;}
	.only-mobile {display:block;}

	/* header */
	.sitelogo img {height:12px;}

	.btn-m-menu {margin-left:12px; width:22px;}
	.btn-m-menu svg {display:block; width:100%; height:auto;}

	.mobile-navigation {width:240px;}
	.mobile-navigation .home img {height:10px;}
	.mobile-navigation .close {top:20px; width:20px; height:20px;}
	.mobile-navigation .close:before, .mobile-navigation .close:after {top:9px; height:2px;}
	.mobile-navigation .nav-menu>ul>li>a {font-size:15px;}
	.mobile-navigation .nav-menu .submenu {font-size:14px;}
	
	#wrapper {padding-top:82px;}
	#header {background:#fff; box-shadow:0 0 3px rgba(0,0,0,.15); color:#242424;}
	#header .contain.c1 {padding:0;}
	#gnb > ul > li > a {height:80px;}
	.sitelogo a {background-image:url('../images/common/logo.png');}
	#header .contain.c1 a {height:32px !important; color:#fff;}

	#header .util {margin-right:10px; gap:0 20px;}
	#header .util a:after {height:8px; right:-10px; background-color:#ddd; opacity:1;}
    
	.btn-m-menu span,
	.btn-m-menu span:before,
	.btn-m-menu span:after {background:#242424;}
	.btn-m-menu span:before {top:-8px;}
	.btn-m-menu span:after {bottom:-8px;}

	.mobile-navigation .nav-menu>ul>li>a:after {width:10px; height:10px;}
	
	#header .contain.c2 {height:50px;}

	.hFix #wrapper {padding-top:80px;}

	/* main */
	.main-visual, .main-visual .item {height:30vh;}
	.main-visual .caption .txt1 {margin-bottom:12px;}
	.main-visual .progress {width:120px;}
	.main-visual .scroll {bottom:30px;}

	.main-visual .caption {padding:0 15px;}
	.main-visual .controls {font-size:13px; bottom:10%;}
	
	.main-sec2 .contain {flex-direction:column; gap:10px 0;}

	.main-sec3 .contain {flex-direction:column;}
	.main-sec3 .col-l {width:100%; margin-bottom:30px;}
	.main-sec3 .col-l a {padding-left:25px; line-height:50px;}
	.main-sec3 .col-l a:before {width:50px; height:50px;}
	.main-sec3 .col-r {width:100%;}

	.partners li {width:50%;}
	
	/* footer */
	#footer .contain {display:block;}

	.f-logo img {height:14px;}
	
	.foot-info dl {flex-direction:column;}
	.foot-info dd {gap:0 12px; flex-wrap:wrap;}

	#footer .col-r ul {flex-wrap:wrap; justify-content:flex-start;}
	#footer .col-r ul.sns {margin-top:15px;}
	#footer .col-r ul.sns img {height:26px;}

	/* layout */
	.sub-title h1:after {width:15px;}

	.sub-tab li a {padding-bottom:8px; font-size:14px;}

	/* content */
	.s-tit .title {font-size:var(--font-size-20);}
	.about-tit br {display:none;}
	.about dl {flex-direction:column;}
	.about dt {font-size:16px; padding-left:0; width:100%;} 
	.about dd {width:100%; font-size:15px;}
	.about dd br {display:none;}

	.about-wrap {padding:0;}

	.about-flex {display:block;}
	.about-flex .img {margin-bottom:30px;}
	.about-cnt2 .item {margin-bottom:50px;}
		
	.curriculum .title {display:block;}
	.curriculum .title p {padding-left:0; margin-top:15px;}

	.tablescroll {display:block; width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;}
	.tablescroll table {width:800px;}

	.calendar-mid .item:before, 
	.calendar ul li:before, 
	.schedule table td .etc:before {width:4px; height:4px;}

	.apply-wrap {display:block;}
	.apply-wrap .left {width:100%; margin-right:0;}	
	.apply-wrap .right {width:100%; margin-top:20px;}

	.schedule table td {padding:10px;}
	
	.rad-btn {min-width:70px; line-height:30px; border-radius:4px;}
	
	.my-course .table .pf {line-height:1.2em; font-size:13px;}

	.my-task {border-top:1px solid #ddd; flex-wrap:wrap;}
	.my-task .wrap {width:100%; border-top:0;}
	.my-task dt, .my-task dd {height:48px;}
	
	.inq-form .input {height:44px;}

	.btn-pack.xxlarge {line-height:40px; height:42px; min-width:150px; font-size:15px;}

	.modal {border-radius:10px !important;}

	.pop-wrap {padding:20px;}
	.modal a.close-modal {width:16px; height:16px; top:22px; right:22px;}
	
	.lecture .table th {padding:0 15px;}
	.lecture .table table th,
	.lecture .table table td {height:42px;}
	.lecture .table .checkbox label:before {width:20px; height:20px;}

	.board-search .search input.input {height:50px;}

	.pop-director {display:block;}
	.pop-director .col-img {width:100%;}
	.pop-director {padding:20px 15px;}
	.pop-director .col-info {max-height:none; overflow:auto; padding-bottom:0;}

	.instr-search {justify-content:flex-start;}
	.instr-search p {width:100%;}	
	.instr-search .itm {width:50%; max-width:calc(50% - 5px);}
	.instr-search .btn-pack.medium {width:100%; max-width:100%;}
	.instr-search .btn-pack.medium.wi {width:100%; max-width:100%;}
	.lecture-memo i {width:14px; height:12px;}
	.lecture-mod i {width:16px; height:16px;}
	.lec-table .radiobox label:before {width:18px; height:18px;}
	.lec-table .radiobox input + label:before {border-width:1px; background-size:75%;}
	
	.sub-tab2 ul.wide a {min-width:100px;}

	.lec-table thead th, .lec-table tbody td {height:auto;}

	.my-course .table {display:block; width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;}
	.my-course .table table {width:800px;}

	/* board */
	.input {font-size:14px; padding:0 10px; height:38px;}
	select.input {padding-right:26px; background-position:right 8px center; background-size:12px auto;}
	textarea.input {padding:7px 10px;}

	.board-search {display:flex; flex-direction:column; margin-bottom:10px;}
	.board-search .total-page {order:3; float:none; font-size:13px;}
	.board-search .cate {float:none; order:1; margin-left:0; margin-bottom:5px;}
	.board-search .cate .input {display:block; width:100%;}
	.board-search .search {float:none; order:2; display:flex;}
	.board-search .search .input {flex:1 1 auto; min-width:0; width:1%;}

	.board-list {display:none;}
	.board-list-m {display:block;}

	.gallery-list {padding-top:15px;}
	.gallery-list ul {margin:0 -7px;}
	.gallery-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.gallery-list ul li .thumb {margin-bottom:10px;}
	.gallery-list ul li .tit {font-size:14px;}
	.gallery-list ul li .date {font-size:12px; margin-top:4px;}

	.news-list ul li {padding:17px 0;}
	.news-list .thumb {width:38%; margin-right:14px;}
	.news-list .tit {font-size:15px; max-height:2.8em; white-space:normal; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
	.news-list .txt {font-size:13px; margin-top:3px; max-height:3em; -webkit-line-clamp:2;}
	.news-list .date {display:none;}

	.event-list {padding-top:20px;}
	.event-list ul li {width:100%; margin-bottom:32px;}
	.event-list ul li .thumb {margin-bottom:10px;}
	.event-list ul li .tit {font-size:15px;}
	.event-list ul li .date {font-size:12px; margin-top:4px;}

	.faq .tit a {padding:7px 0 7px 5px;}
	.faq .tit a:after {display:none;}
	.faq .q {flex:0 0 26px; width:26px; height:26px; font-size:15px; line-height:26px; margin-right:10px;}
	.faq .cnt {padding:12px 12px 12px 15px;}

	.calendar-head {margin-bottom:15px;}
	.calendar-head h3 {font-size:20px; margin:0 17px;}
	.calendar-head .cal-btn {width:34px; height:34px; background-size:9px auto;}
	.calendar-head .cal-prev {background-image:url("/images/bbs/cal_prev_x2.png");}
	.calendar-head .cal-next {background-image:url("/images/bbs/cal_next_x2.png");}
		
	.calendar table th {adding:10px 4px; height:50px; font-size:14px;}
	.calendar table td {font-size:13px; padding:15px;}
	.calendar .cal-date {margin-bottom:10px;}
	.calendar ul li {padding-left:9px; margin-bottom:9px;}
	.calendar ul li a {max-height:4.2em; -webkit-line-clamp:3;}

	.board-white table {display:block; border-top:0; border-bottom:0; font-size:14px;}
	
	.board-white table tbody {display:block;}
	.board-white table tr {display:block; padding:12px 0;}
	.board-white table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.board-white table td {display:block; border:0; padding:0;}
	.board-white .editor {padding:0; margin-top:-12px;}
	.board-white .item {margin:3px 12px 3px 0;}
	.board-white #user_name {max-width:100% !important;}
	.board-white + .buttons {margin-top:30px;}

	.board-form table tbody {display:block;}
	.board-form table tr {display:block; padding:12px 0;}
	.board-form table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.board-form table td {display:block; border:0; padding:0;}
	.board-form + .buttons {margin-top:30px;}

	.form-agree {margin:30px 0 30px;}
	.form-agree h3 {font-size:16px;}
	.form-agree .scroll-box {font-size:12px; max-height:110px; overflow:auto;}
	.form-agree .check {margin-top:12px; font-size:14px;}

	.board-view-tit h3 {font-size:17px;}
	.board-view-info {font-size:12px;}

	.board-prev-next dl {padding:10px 6px;}
	.board-prev-next dt {width:70px}

	.buttons {margin:15px 0;}

	.btn-pack.small {height:26px; padding:0 8px; font-size:11px; line-height:24px;}
	.btn-pack.medium {height:38px; padding:0 14px; font-size:14px; line-height:36px;}
	.btn-pack.large {min-width:120px; height:42px; padding:0 18px; font-size:15px; line-height:40px;}
	.btn-pack.xlarge {min-width:120px; height:50px; padding:0 22px; font-size:16px; line-height:48px;}
	.btn-pack.comment {width:80px; height:32px; font-size:14px;}

	.paginate {margin-top:20px;}
	.paginate a,  
	.paginate strong{margin:0 1px;width:30px;height:30px;font-size:14px;line-height:30px;}  
	.paginate a.direction {margin:0;}
	.paginate a.direction.prev {margin-right:14px;}
	.paginate a.direction.next {margin-left:14px;}

	.comment-area {margin-top:37px;}
	.comment-total {font-size:14px; margin-bottom:12px;}
	.comment-write {position:relative; padding:10px;}
	.comment-write .byte {position:absolute; bottom:15px; left:12px; font-size:12px;}
	.comment-write .write {display:block;}
	.comment-write .write textarea {display:block; width:100%; height:65px; margin-right:0;}
	.comment-write .write .btn {text-align:right; margin-top:6px;}
	.comment-item {padding:17px 4px;}
	.comment-item.comment-reply {padding-left:25px; background-image:url("/images/bbs/icon_reply_x2.png"); background-position:3px 18px; background-size:auto 13px;}
	.comment-info {font-size:14px;}
	.comment-info .name {margin-right:5px;}
	.comment-info .date {font-size:11px;}
	.comment-ctr {font-size:12px;}
	.comment-ctr .bar {vertical-align:middle; margin:-.2em 4px 0;}
	.comment-txt {font-size:14px;}
	.comment-link {font-size:13px;}
	.comment-input {padding:10px;}
	.comment-input textarea {height:48px;}

	.board-password {padding:30px 20px;}

	.product-list ul {margin:0 -7px;}
	.product-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.product-list ul li .thumb {margin-bottom:10px;}
	.product-list ul li .tit {font-size:14px;}
	.product-summary {display:block;}
	.product-image {width:100%; margin-bottom:20px;}
	.product-info {width:100%;}
	.product-info .tit {font-size:22px; padding-bottom:14px; margin-bottom:14px;}
	.product-detail {padding-bottom:25px; margin-bottom:25px;}
	.product-detail .tit {font-size:17px; padding-bottom:10px; margin-bottom:14px;}

	.store-search {padding:0;}
	.store-search .search-area h3 {font-size:16px; padding:15px 25px; margin-bottom:20px; background:#f4f4f4;}
	.store-search .search-area dl {display:block; padding:0 15px; margin:20px 0;}
	.store-search .search-area dl dt {width:auto; margin-bottom:6px; font-size:15px;}
	.store-search .search-area dl dd {width:auto;}
	.store-search .search-area input.input {width:calc(100% - 74px); margin-right:4px;}
	.store-search .search-area select.input {width:calc(50% - 39px); margin-right:4px;}
	.store-search .search-area .btn-pack.medium {width:70px;}

	.result-top {font-size:18px;}
	.result-group .gall {margin:0 -7px;}
	.result-group .gall li {width:50%; padding:0 7px;}
	.result-group dl dt {font-size:15px;}
	.result-group dl dd {font-size:13px;}
	.result-group dl dd.date {font-size:12px;}

	/* member */
	.radiobtn-menu ul li label {height:32px; padding:0 10px;}
	.login-tab {border-bottom-width:2px; margin-bottom:35px;}
	.login-tab ul {padding:0 1px;}
	.login-tab ul li {border-width:2px; margin:0 -1px;}
	.login-tab ul li a {font-size:16px; line-height:46px;}
	.login-content .group .input {height:48px; font-size:14px;}

	.sns-login .tit {margin-bottom:20px;}
	.sns-login .tit span {padding:0 20px;}
	.sns-login a {margin:0 8px}
	.sns-login img {width:44px;}

	.agree-wrap {margin-bottom:35px;}
	.agree-wrap .group {margin-top:30px;}
	.agree-wrap .agree-tit {font-size:16px;}
	.agree-wrap .agree-tit .checkbox label:before {background-image:url("../images/member/checkbox_x2.png"); background-size:11px auto;}
	.agree-wrap .agree-tit .checkbox input:checked + label:before {background-image:url("../images/member/checkbox_on_x2.png");}
	.agree-wrap .agree-box {margin-top:7px; max-height:130px; padding:10px 13px;}
	.agree-wrap .agree-box .terms-wrap {line-height:1.4em; word-break:break-all;}

	.terms-wrap .policy-contact {display:block; padding:0 15px;}
	.terms-wrap .policy-contact dl {border-left:0; padding:20px 5px; border-top:1px solid #e5e5e5;}
	.terms-wrap .policy-contact dl:first-child {border-top:0;}

	.join-form table tbody {display:block;}
	.join-form table tr {display:block; padding:12px 0;}
	.join-form table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.join-form table td {display:block; border:0; padding:0;}
	.join-form + .buttons {margin-top:30px;}
	.join-form .help-text {display:block; clear:both; padding-top:6px; margin-left:0; font-size:14px; line-height:1.5em;}
	.join-form #user_id {float:left; width:calc(100% - 90px) !important;}
	.join-form #user_id + .btn-pack {width:90px; text-align:center;}
	.join-form #user_pw,
	.join-form #user_pw2,
	.join-form #user_name {width:100% !important;}

	.join-complete .txt {font-size:16px;}
	.join-complete .icon {width:110px; height:110px; background-size:48px;}

	.find-tab {border-bottom-width:2px; margin-bottom:35px;}
	.find-tab ul {padding:0 1px;}
	.find-tab ul li {border-width:2px; margin:0 -1px;}
	.find-tab ul li a {font-size:16px; line-height:46px;}
	.find-content .group .input {height:48px; font-size:14px;}
	.find-result {padding:30px 15px; font-size:16px;}
	.find-result h4 {font-size:19px;}
	.find-result .name {font-size:24px;}

	.member-leave .txt .tit {font-size:15px;}
	.member-leave .form {font-size:15px;}
	
	.join-form .flex {margin:0; padding:0;}
	.join-form dl {width:100%; padding:0;}
	.join-form dl.none {display:none;}

	.wid500-btn .btn-pack.xxlarge {min-width:auto;}
	.member-leave .form .group .input, .join-form dl .input {height:44px;}
	
	.join-form dl dd .btn-pack {height:44px; line-height:42px;}

} 

/* Landscape phones and down */
@media (max-width:420px) {
	
	
} 