@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */ 

#skipToContent a {z-index:100000;position:absolute;top:0;left:0;width:1px;height:1px;font-size:0;line-height:0;overflow:hidden}
#skipToContent a:focus, 
#skipToContent a:active {width:200px;height:50px;background:#21272e;color:#fff;font-size:14px;font-weight:bold;text-align:center;text-decoration:none;line-height:50px}

.contain {width:100%; max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
.contain:after {content:""; display:block; clear:both;}

.only-desktop {display:block;}
.only-desktop-tablet {display:block;}
td.only-desktop-tablet {display:table-cell;}
.only-tablet-mobile {display:none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

/* header */
#header {position:relative; width:100%; z-index:100; border-bottom:1px solid #ddd;}
#header .contain {position:relative; max-width:1260px; height:65px; padding-left:30px; padding-right:30px;}

.sitelogo {}
.sitelogo a {display:block; width:402px; height:87px; overflow:hidden; text-indent:-9999em; background:url("../images/common/logo.png") 50% 50% no-repeat; background-size:contain;}

#gnb {position:relative; height:65px; width:100%; text-align:right; z-index:2; display:flex; justify-content:center;}
#gnb > ul {display:flex; width:100%;}
#gnb > ul:after {content:" "; display:block; clear:both;}
#gnb > ul > li {flex:1; text-align:center; position:relative; height:65px; z-index:1;}
#gnb > ul > li:before {position:absolute; content:""; background:#ddd; top:50%; right:0; width:1px; height:22px; margin-top:-11px;}
#gnb > ul > li:last-child:before {display:none;}
#gnb > ul > li > a {display:block; height:65px; line-height:65px; position:relative; font-size:20px; color:#2c2c2c; font-weight:700; z-index:5; letter-spacing:-0.05em;}
#gnb > ul > li:hover > a {color:#070a35; font-weight:500;}
#gnb > ul > li:hover > a:before {position:absolute; content:""; left:50%; margin-left:-7px; bottom:-7px; width:14px; height:14px; border-radius:100%; background:#f9cc0d;}
 

#header.header-hover {background:#fff;}
#header.header-hover .sitelogo a {background-image:url("../images/common/logo.png");}

#gnb .submenu {display:none; position:absolute;  z-index:1; padding:0 15px; margin-top:-10px; left:0; }

#gnb .submenu ul {display:flex;}
#gnb .submenu ul:after {content:" "; display:block; clear:both;}
#gnb .submenu ul li {float:left; padding-top:20px; padding-right:30px; white-space:nowrap;}
#gnb .submenu ul li a {display:block; text-decoration:none; color:#feffff; font-size:16px; line-height:40px; position:relative;} 
#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a {color:#fff; text-decoration:underline;}
#gnb .m2 .submenu:before {left:50px;}

.submenu-bg {display:none; position:absolute; z-index:9; top:165px; left:0; width:100%; background: linear-gradient(to left, #070a35, #070a35);}

.main-line {border-bottom:1px solid #ddd;}
.main-line .main-link-flex {display:flex; width: 100%; max-width:1260px; margin:0 auto; justify-content:space-between; align-items:center; height:100px; line-height:100px;}
.main-line .main-link ul {display:flex; width:100%; max-width:1780px; margin:0 auto; justify-content:flex-end;}
.main-line .main-link ul li {position:relative; font-size:14px; color:#878787; padding:0 15px; height:45px; line-height:45px;}
.main-line .main-link ul li:nth-child(1),
.main-line .main-link ul li:nth-child(2) {font-size:16px; color:#0b51d1; font-weight:500;}
.main-line .main-link ul li:nth-child(1):before {background:#0b51d1;}
.main-line .main-link ul li:before {position:absolute; content:""; width:1px; height:15px; top:50%; margin-top:-7.5px; right:0; background:#dfdfdf;}
.main-line .main-link ul li:last-child:before {display:none;}


.main-links {display:flex; align-items:center; position:absolute; top:50%; margin-top:5px; right:260px; z-index:101;}
.main-links .go-home {display:none; margin-top:30px;}
.custom-select {display:inline-block; vertical-align:middle; position:relative; z-index:10;}
.custom-select .select-hidden {display:none;}
.custom-select .select-input {position:relative; width:85px; background:#f9cc0d; height:25px; line-height:25px; color:#2c2c2c; font-size:14px; letter-spacing:-.03em; font-weight:700; overflow:hidden; white-space:nowrap; cursor:pointer; z-index:2; text-align:center; padding-right:15px;}
.custom-select .select-input:before {position:absolute; content:""; width:9px; height:5px; background:url('../images/main/slide-down.png')50% 50% no-repeat; background-size:contain; top:50%; margin-top:-2.5px; right:10px;}
.custom-select .select-options {display:none; border:1px solid #ddd; border-radius:10px; position:absolute; height:80px; background:#fff; color:#2c2c2c; margin-top:-1px; left:0; width:100%; max-height:460px; font-size:14px; line-height:1.5em; letter-spacing:-.03em; position:absolute; top:25px; z-index:99;}
.custom-select .select-options ul {display:flex; align-items: center; justify-content: center; flex-direction: column; align-content: center; height: 80px;}
.custom-select .select-options li {position:relative; padding:5px 10px; font-weight:500; font-size:14px; display:inline-block; width:100%; text-align:center; margin-right:0; padding:5px 10px; cursor:pointer; transition:.2s;}
.custom-select .select-options li a {display:block;}
.custom-select .select-options li.selected {background:#fff}
.custom-select.active .select-input {border-color:#ff5500;}
.select-input .img {width:24px; height:24px; background:url("../images/main/language.png")50% 50% no-repeat; background-size:contain;}

.main-login {position:absolute; top:50%; margin-top:-15px; right:100px; z-index:9;}
.main-login ul {display:flex;}
.main-login ul li {font-size:13px; color:#878787; letter-spacing:-.04em; text-align:center; margin-left:20px;}
.main-login ul li a {display:block; width:100%; height:100%;}

 /* main */ 
.main-visual {position:relative; overflow:hidden;}
.main-visual .item img {width:100%;}
.main-visual .caption {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; color:#fff; text-align:left; z-index:40;}
.main-visual .caption p {font-size:20px; font-weight:300; line-height:1.600em; letter-spacing:-.03em;}
.main-visual .caption h2 {display:inline-block; position:relative; font-size:54px; color:#fff; font-weight:700; line-height:1.3em; letter-spacing:-.03em;}
.main-visual .caption h3 {font-size:14px; color:#f9cc0d; line-height:1.3em; padding:15px 0 30px; font-weight:500; letter-spacing:0.7em;}
.main-visual .con-wrap {width:100%; max-width:1200px; margin:0 auto; text-align:center; padding:0 20px;}
.main-visual .caption .bold {font-weight:500;}

.main-visual .slick-arrow {position:absolute; top:50%; margin-top:-28px; width:30px; height:56px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-visual .slick-prev {left:100px; background-image:url("../images/main/main-prev.png");}
.main-visual .slick-prev:hover {background-image:url("../images/main/main-prev_w.png");}
.main-visual .slick-next {right:100px; background-image:url("../images/main/main-next.png");}
.main-visual .slick-next:hover { background-image:url("../images/main/main-next_w.png");}


.main-visual .slick-dots {position:absolute; bottom:120px; left:0; width:100%; text-align:center; z-index:50; line-height:0;}
.main-visual .slick-dots li {position:relative; display:inline-block; padding:0 20px;}
.main-visual .slick-dots li button {position:relative; display:block; background:#fff; opacity:0.5; width:13px; height:13px; border:3px solid #fff; border-radius:100%; overflow:hidden; text-indent:-9999px;}
.main-visual .slick-dots li.slick-active button {border-color:transparent; background:#fff; opacity:1;}
.main-visual .slick-dots li.slick-active:before {width:32px; height:32px; top:50%; margin-top:-16px; left:50%; margin-left:-16px; border-radius:100%; position:absolute; content:""; border:1px solid rgba(255, 255, 255, 0.5); }


.main-visual .btn-flex {display:flex; justify-content:space-between; align-items:center; margin-top:50px; max-width:260px;}
.main-visual .paging {font-weight:500;}
.main-visual .paging span {padding:0 5px;}
.main-visual span.current {font-size:20px; font-weight:700; letter-spacing:-.03em; line-height:1.200em;}


.visual-scroll {position:absolute; width:49px; height:64px; left:50%; animation:pulse 2s infinite; bottom:80px; margin-left:-24.5px;}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

@keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

.main-tit {margin-bottom:40px;}
.main-tit h3 {font-size:42px; font-weight:700; letter-spacing:-.04em; color:#2c2c2c; line-height:1.190em;}
.main-tit p {font-size:18px; margin-top:10px; color:#878787;}

/* main-education */
.main-education {text-align:center; padding:120px 0; background-repeat:no-repeat; background-size:cover; background-position:50% 50%;}
.main-education .main-education-list ul {display:flex;}
.main-education .main-education-list ul li {transition:.2s; position:relative; width:25%; background-repeat:no-repeat; background-size:cover; background-position:50% 50%; min-height:400px; padding:60px 40px; max-height:400px;}
.main-education .main-education-list ul li:nth-child(even) {margin-top:60px;}
.main-education .main-education-list ul li a {display:flex; align-items:flex-end; width:100%; height:100%;}
.main-education .main-education-list ul li p {font-size:28px; font-weight:700; text-align:left; letter-spacing:-.03em; line-height:1.071em; color:#fff;}
.main-education .main-education-list ul li .txt-box {transition:.2s; display:none; color:#fff; width:100%; height:100%; position:absolute; top:0; left:0; background:rgba(7, 10, 53, 0.8); padding:40px 0 0 20px;}
.main-education .main-education-list ul li .txt-box p {padding-bottom:15px; border-bottom:3px solid rgba(255, 255, 255, 0.4); margin-bottom:15px;}
.main-education .main-education-list ul li .txt-box .txt {line-height:1.875em; text-align:left;}
.main-education .main-education-list ul li .txt-box span {font-weight:500; letter-spacing:-.04em; position:absolute; bottom:30px; right:20px;}
.main-education .main-education-list ul li .txt-box span img {margin-left:5px; vertical-align:baseline;}
.main-education .main-education-list ul li:hover .txt-box {transition:.2s; display:block;}
.main-education .main-education-list ul li:hover p {display:none;}
.main-education .main-education-list ul li:hover .txt-box p {display:block;}


/* main-default */
.main-default {display:flex; padding:120px 0; margin:0 -40px;}
.main-default .main-default-wrap {padding:0 40px;}
.main-default .main-default-wrap .txt {font-size:15px; color:#878787; letter-spacing:-.04em; line-height:1.857em; margin-top:25px; border-bottom:1px solid #ddd; margin-bottom:25px; overflow: hidden; text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp:2; -webkit-box-orient: vertical; padding-bottom:30px;}
.main-default .main-default-wrap .main-tit {display:flex; justify-content:space-between; align-items:center; margin-bottom:40px;}
.main-default .main-default-wrap .main-tit h3 {font-size:38px; font-weight:700; letter-spacing:-.04em; line-height:1.474em; color:#0d202f;}
.main-default .main-default-wrap .main-tit P {font-size:16px; font-weight:500; color:#505050; letter-spacing:-.04em;}
.main-default .main-default-wrap .main-tit span img {vertical-align:inherit; margin-left:5px;}
.main-default .main-default-flex {display:flex;}
.main-default .main-default-flex h4 {display:flex; flex-direction:column; justify-content:center; font-size:32px; font-weight:700; color:#2c2c2c; text-align:center; width:80px; height:80px; background:#f9cc0d;}
.main-default .main-default-flex h4 p {font-size:13px; font-weight:500; letter-spacing:-.06em; line-height:1.4em;}
.main-default .main-default-flex .tit {width:80%; margin-left:20px; font-size:24px; color:#2c2c2c; font-weight:500; letter-spacing:-.04em; line-height:1.500em; overflow: hidden; text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;}
.main-default .main-default-tt dl {display:flex; justify-content:space-between; margin-bottom:15px;}
.main-default .main-default-tt dl:hover dt:before {position:absolute; content:""; width:100%; left:0; bottom:0; height:2px; background:#848484;}
.main-default .main-default-tt dl:hover dd:before {position:absolute; content:""; width:100%; left:0; bottom:0; height:1px; background:#848484;}
.main-default .main-default-tt dl dt {position:relative; font-size:18px; color:#2c2c2c; letter-spacing:-.04em; line-height:1.3em; overflow: hidden; text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical;}
.main-default .main-default-tt dl dd {position:relative; font-size:14px; color:#878787; overflow: hidden; text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp:1; -webkit-box-orient: vertical;}

/* for mobile */
.btn-m-menu {position:absolute; top:50%; right:15px; margin-top:-12px; width:27px; height:24px; text-indent:-9999em; z-index:50; display:none;}
.btn-m-menu span {position:absolute; left:0; right:0; top:11px; height:2px; background:#242424;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; right:0; height:2px; background:#242424;}
.btn-m-menu span:before {top:-9px;}
.btn-m-menu span:after {bottom:-9px;}

.mobile-navigation {display:block; position:fixed; top:0; right:0; width:280px; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .home {padding:8px 20px;}
.mobile-navigation .home a {display:block;}
.mobile-navigation .home img {height:38px;}
.mobile-navigation .nav-menu>ul {border-top:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:13px 20px; display:block; color:#242424; font-size:16px; font-weight:700; line-height:1.5em;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:12px; height:12px; border-right:2px solid #242424; border-bottom:2px solid #242424;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#f9cc0d;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg);}
.mobile-navigation .nav-menu .submenu {display:none; padding:10px 20px; background:#f9cc0d; color:#fff; font-size:16px; line-height:1.5em;}
.mobile-navigation .nav-menu .submenu > ul >  li > a {display:block; padding:6px 0;}
.mobile-navigation .close {position:absolute; top:16px; right:10px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:11px; left:0; width:100%; height:2px; background:#242424; border-radius:3px;}
.mobile-navigation .close:before {transform:rotate(45deg);}
.mobile-navigation .close:after {transform:rotate(-45deg);}
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}

/* sub */
.sub-visual {position:relative; display:table; table-layout:fixed; width:100%; height:445px; background-color:#fff; background-position:50% 50%; background-repeat:no-repeat; background-size:cover;}
.sub-visual .cell {display:table-cell; vertical-align:middle; width:100%; height:100%;}
.sub-visual .in {text-align:center;}
.sub-visual h3 {font-family: 'NanumSquare'; position:relative; font-size:40px; line-height:1.4em; color:#fff; letter-spacing:-.03em; font-weight:800; padding-bottom:15px;}
.sub-visual p {font-size:14px; line-height:1.3em; color:#fff; letter-spacing:0.8em;}
.sub-visual.bg1 {background-image:url("../images/common/sv1.jpg");}
.sub-visual.bg2 {background-image:url("../images/common/sv2.jpg");}
.sub-visual.bg3 {background-image:url("../images/common/sv3.jpg");}
.sub-visual.bg4 {background-image:url("../images/common/sv4.jpg");}
.sub-visual.bg5 {background-image:url("../images/common/sv5.jpg");}
.sub-visual.bg6 {background-image:url("../images/common/sv6.jpg");}

#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:none;} 

.sub-title {text-align:center;}
.sub-title.pb {padding-bottom:0;}
.sub-title h2 {position:relative; color:#242424; font-size:38px; font-weight:700; line-height:1.316em; letter-spacing:-.04em;}

.real-cont {padding-bottom:100px;}
.real-cont.pb0 {padding-bottom:0;}

/* lnb */
.lnb {width:100%; max-width:1220px; margin:0 auto; position:relative; z-index:2; background:rgba(7, 10, 53, 0.76); height:82px; margin-top:-82px;}
.lnb.bg .swiper-container {left:0;}
.lnb.bg {height:65px; margin-top:0; background:#fafafa;}
.lnb.bg ul li {height:65px; line-height:63px; border:1px solid #ddd; border-left:0;}
.lnb.bg ul li:first-child {border-left:1px solid #ddd;}
.lnb.bg ul li a {color:#505050;}
.lnb.bg ul li.active a {background:#070a35; color:#fff;}
.lnb .swiper-container {max-width:1200px; position:absolute; width:100%; bottom:0; left:10px;}
.lnb ul {display:flex; justify-content:center;}
.lnb ul li {position:relative; flex:1; height:72px; line-height:72px; text-align:center; letter-spacing:-.04em;}
.lnb ul li a {display:block; position:relative; font-size:17px; color:#fff; letter-spacing:-.04em; font-weight:300;} 
.lnb ul li:before {position:absolute; content:""; width:1px; height:20px; background:rgba(255, 255, 255, 0.32); top:50%; margin-top:-10px; right:0;}
.lnb ul li:last-child:before {display:none;}
.lnb ul li.active {background:#fff;}
.lnb ul li.active a {color:#162842; font-weight:500;}
.lnb ul li.active a:before {position:absolute; content:""; width:131px; height:4px; background:#070a35; left:50%; margin-left:-65.5px; bottom:0;}

/* footer */
#footer {padding:20px 0 40px 0; font-size:14px; position:relative; background:#333; color:#e8e8e8; line-height:28px;}
#footer .contain {max-width:1260px; letter-spacing:-.03em; line-height:1.600em; align-items:center;}
#footer address {font-style:normal; font-weight:300; line-height:1.714em; margin-top:10px; text-align:left;}
#footer .foot_logo {padding-bottom:15px; font-weight:500;}
.link-wrap {border-bottom:1px solid #666666;}
.foot-logo {order:1; padding:40px 0 30px;}
.foot-info .foot-link {display:inline-block; font-weight:400;}
.foot-info {text-align:center; order:2;}
.foot-info .foot-links {margin:0 auto; margin-bottom:10px;}
.foot-info .foot-link a {display:block;}
.foot-info span {font-size:16px; color:#dfdfdf; font-weight:300; letter-spacing:-.04em; display:inline-block; padding-right:20px; line-height:1.625em;}
.foot-info .bottom {padding-top:10px;}
.foot-info .foot-after {padding-right:25px; letter-spacing:-.03em; line-height:1.600em;}
.foot-links {margin-bottom:50px;}
.foot-links ul {display:flex; justify-content:flex-start; padding-bottom:10px;}
.foot-links ul li {font-size:17px; font-weight:500; letter-spacing:-.04em; line-height:1.923em; position:relative; padding:0 20px;}
.foot-links ul li:first-child {padding-left:0;}
.foot-links ul li:hover {color:#f9cc0d;}
.foot-links .name {font-weight:500; padding-right:33px;}

.foot-wrap ul li {color:#878787;}

.foot-flex .foots-tt .tit {font-size:26px; color:#fff; font-weight:500; letter-spacing:-.04em; line-height:1.923em;}
.foot-flex .foots-tt .txt {font-size:17px; color:#f9cc0d; font-weight:500; letter-spacing:-.04em; line-height:1.3em; white-space:nowrap;}

.footer-wrap {border-bottom:1px solid rgba(255, 255, 255, 0.2); padding-bottom:20px; margin-bottom:20px;}

.privacy {display:flex; justify-content:space-between; width:100%; max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
.privacy ul {display:flex;}
.privacy ul li {font-size:16px; position:relative; padding:0 20px 0 10px;}
.privacy ul:last-child li {padding:0 15px;}
.privacy ul:first-child li:before {position:absolute; content:""; top:50%; margin-top:-3px; left:0; width:6px; height:6px; background:#fff; border-radius:100%;}
.privacy ul:last-child li:after {position:absolute; content:""; right:0; top:50%; margin-top:-7.5px; height:15px; width:1px; background:#fff; height:15px;}
.privacy ul:last-child li:last-child:after {display:none;}

/* quick */
.quick {position:fixed; bottom:100px; right:50px; width:120px; text-align:center; z-index:90; background:#fff;}
.quick h3 {text-align:center; font-weight:700; background:#f9cc0d; height:46px; line-height:46px; }
.quick ul.padding {padding:15px 0; margin-bottom:10px;}
.quick ul li {padding:20px 0; margin:0 15px; border-bottom:2px solid #ddd;}
.quick ul li:nth-child(4) {border-bottom:0;}
.quick ul li:last-child {background:transparent; padding:0; margin:0; border-bottom:0; border:1px solid #070a35;}
.quick ul li p {font-size:14px; color:#595959; line-height:1.143em; white-space:nowrap; margin-top:5px;}
.quick ul li p span {font-weight:500; color:#070a35;}
