@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}

.only-desktop-tablet {display:block;}
.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}

.contain {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
.contain:after {content:""; display:block; clear:both;}

/* header */
#header {position: relative; top:0; left:0; width:100%; z-index:90; background: #fff;}
#header .contain {position:relative; max-width: 1780px;}
#header .inner {position: relative; max-width: 1460px; height: 100%;}

.sitelogo {position:absolute; top:50%; left:0; margin-top:-44px; z-index:2;background-image:url("../images/common/logo.png"); background-repeat: no-repeat; background-size:contain;}
.sitelogo a {display: block;}
.sitelogo img {visibility: hidden;}

#gnb {text-align:center;}
#gnb > ul {display:flex;justify-content: center;}
#gnb > ul > li {position:relative; padding: 0 55px; text-align:center;}
#gnb > ul > li > a {display:block; font-size:22px; font-weight: 700; line-height:120px;}
#gnb > ul > li.active > a {color: #3783da;}

.util {position:absolute;right:30px;top:50%;margin-top: -17px;z-index:3; display: flex;}

.top-links ul {display: flex; margin: 0 -14px;}
.top-links ul li {position: relative; padding: 0 14px;}
.top-links ul li:after {content:""; position: absolute; top: 50%; right: -1px; margin-top: -6px; width: 1px; height: 13px; background: #ddd;}
.top-links ul li:last-child:after {display: none;}
.top-links ul li a {color: #686868; font-weight: 500; line-height: 35px; letter-spacing: -.02em;}

.language {position: relative; width: 100px; margin-left: 40px;}
.language a {display:block;font-size:0.875em;line-height:33px;letter-spacing:-0.01em;color:#686868;}
.language > a {border: 1px solid #ddd;border-radius:4px;padding: 0 26px 0 12px;background: #fff url("../images/common/language_arrow.png") right 12px center no-repeat;text-align:left;}
.language ul {position:absolute;width: 100%; left: 0; top: calc(100% - 1px); background: #f4f4f4; border: 1px solid #ddd; border-radius:4px; padding: 10px 0; display:none;}
.language ul li {}
.language ul li a {line-height:22px;padding: 5px 12px;}
.language ul li:hover a {text-decoration:underline; text-underline-position:under;}

/* for mobile */
.btn-m-menu {display: none; position:absolute; top:50%; right:30px; width:32px; height:32px; margin-top:-17px; text-align:center; text-indent:-9999em; z-index:50; transition:all 0.5s linear;}
.btn-m-menu span {position:absolute; left:0; right:0; top:50%; margin-top:0px; height:2px; background:#2c2c2c;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0px; right:0; height:2px; background:#2c2c2c; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s;}
.btn-m-menu span:before {top:-11px; transition-property:top, transform;}
.btn-m-menu span:after {bottom:-11px; transition-property:bottom, transform;}

.mobile-navigation {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 {max-height:60px; padding: 19px 20px;}
.mobile-navigation .home a {display: block;  color: #000; font-size: 18px; font-weight: 700; line-height: 1.3em;}
.mobile-navigation .links {border-top:1px solid #ddd; padding:20px;}
.mobile-navigation .links ul {display:flex; flex-wrap:wrap; margin:-3px;}
.mobile-navigation .links ul li {width:50%; padding:3px;}
.mobile-navigation .links ul li a {display:block; font-size:14px; line-height:1.5em; padding:5px; text-align:center; border:1px solid #ddd;}
.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:#2c2c2c; font-size:18px; font-weight:700; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu {display:none; background:#da251c; padding: 10px 0;}
.mobile-navigation .nav-menu .submenu ul li a {display:block; padding:8px 20px; color:#fff; font-size:16px; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu ul li a br {display: none;}
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:101;}

.mobile-navigation .close {position:absolute; right:15px; top:18px; width:22px; height:22px;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {position:absolute; left:11px; content:""; height:25px; width:2px; background-color:#333;transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s;}
.mobile-navigation .close:before {transform:rotate(90deg); transition-property:transform;}
.mobile-navigation .close:after {transform:rotate(-90deg); transition-property:transform;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}
html.menu-opened .btn-m-menu span {background:none;}
html.menu-opened .btn-m-menu span:before,
html.menu-opened .btn-m-menu span:after {transition-delay:0s, 0.3s; background:#1191d0; height:2px;}
html.menu-opened .btn-m-menu span:before {top:0; transform:rotate(45deg);}
html.menu-opened .btn-m-menu span:after {bottom:2px; transform:rotate(-45deg);}
html.menu-opened .close:before {transform:rotate(45deg);}
html.menu-opened .close:after {transform:rotate(-45deg);}

/* intro */
.intro-wrap {display: table; width: 100%; height: 100vh; background: #f3f3f3; padding: 50px 0; text-align: center;}
.intro-wrap .inner {display: table-cell; vertical-align:middle;}
.intro-links {margin: 70px 0 105px;} 
.intro-links ul {display: flex; margin: 0 -16px;} 
.intro-links ul li {width: 33.33333333%; padding: 0 16px;} 
.intro-links ul li a {display: block; box-shadow:rgba(0,0,0,.15) 0 0 10px; border-radius:20px; overflow:hidden;} 
.intro-links ul li .box {background: #fff; padding: 25px 5px 30px 5px;} 
.intro-links ul li .box .tit {font-family: 'Roboto', sans-serif; font-size: 25px; font-weight: 500; line-height: 1.3; margin-bottom: 20px;} 
.intro-links ul li .box .view {position: relative; display: inline-block; width: 40px; height: 40px; border: 1px solid #bcbcbc; border-radius:100%;} 
.intro-links ul li .box .view:before {content:""; position: absolute; top: 50%; margin-top: -1px; right: 50%; margin-right: -2px; width: 43px; height: 2px; background: #bcbcbc;}
.intro-links ul li .box .view span {position: absolute; top: 50%; margin-top: -5px; left: 50%; margin-left: -7px; display: block; width: 10px; height: 10px; border-top: 2px solid #bcbcbc; border-right: 2px solid #bcbcbc; transform: rotate(45deg);}
.intro-txt {color: #454545; font-size: 1.063em; font-weight: 500; line-height: 1.529em; letter-spacing: -.015em;}
.intro-links ul li a:hover .view {border: 0; background-image: linear-gradient(90deg, #3c3275 0%, #439ed5 100%);}
.intro-links ul li a:hover .view:before {background: #cfebff;}
.intro-links ul li a:hover .view span {border-color: #cfebff;}
/* main */
.main-visual {position:relative; height:auto;}
.main-visual .img {position:relative; padding-bottom:40%; overflow:hidden;}
.main-visual .img img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}

.main-visual .slick-dots {position:absolute; bottom:50px; left:0; width:100%; text-align:center; line-height:0; z-index:50;}
.main-visual .slick-dots li {display:inline-block; padding: 0 20px;}
.main-visual .slick-dots li button {position:relative; z-index:2; display:block; width:13px; height:13px; font-size:0; line-height:0; text-indent:-999em; background:rgba(255,255,255,.52); border:0; border-radius:100%;}
.main-visual .slick-dots li.slick-active button {position: relative; background: #fff;}
.main-visual .slick-dots li.slick-active button:before {content:""; position: absolute; top: 50%; left: 50%; margin-top: -17px; margin-left: -16px; width: 32px; height: 32px; border: 1px solid rgba(255,255,255,.6); border-radius:100%;}

.main-visual .slick-arrow {position:absolute; top:50%; width:29px; height:55px; margin-top:-27px; z-index:50; background-size: contain; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; overflow:hidden; text-indent:-9999em;}
.main-visual .slick-prev {background-image:url("../images/main/slide_prev.png"); left:65px}
.main-visual .slick-next {background-image:url("../images/main/slide_next.png"); right:65px}

.main-visual-m {position:relative; display:none; overflow:hidden;}
.main-visual-m .slick-dots {position:absolute; bottom:15px; left:0; width:100%; text-align:center; line-height:0; z-index:50;}
.main-visual-m .slick-dots li {position:relative; display:inline-block; padding:2px 6px;}
.main-visual-m .slick-dots li:before,
.main-visual-m .slick-dots li:after {content:""; position:absolute; top:7px; width:6px; height:1px; background:#fff;}
.main-visual-m .slick-dots li:before {left:0;}
.main-visual-m .slick-dots li:after {right:0;}
.main-visual-m .slick-dots li:first-child::before {display:none;}
.main-visual-m .slick-dots li:last-child::after {display:none;}
.main-visual-m .slick-dots li button {position:relative; z-index:2; display:block; width:11px; height:11px; font-size:0; line-height:0; text-indent:-999em; background:#fff; border:2px solid #transparent; border:0; border-radius:100%;}
.main-visual-m .slick-dots li.slick-active {padding:0 4px;}
.main-visual-m .slick-dots li.slick-active button {width:15px; height:15px; background:transparent; border:2px solid #fff;}

.m-head {margin-bottom:30px;}
.m-head.center {text-align: center;}
.m-head h2 {font-family: 'NanumSquare', sans-serif; font-size:25px; font-weight: 800; line-height:1.3em; letter-spacing:0;}
.m-head .i-head {display: inline-block; width: 29px; height: 29px; margin: -.2em 10px 0 0; vertical-align: middle; background-position:50% 50%; background-repeat:no-repeat; background-size:contain;}

.main-goods {padding:80px 0;}
.main-goods .contain {position: relative;}

.main-bot-wrap {}
.main-bot-wrap .section {padding: 100px 0;}
.main-bot-wrap .section.bg {background: #1a4087;}
.main-bot-wrap .flexwrap {display: flex;justify-content: space-between;}
.main-bot-wrap .flexwrap .cnt {width: calc(50% - 15px);}
.main-bot-wrap .flexwrap .cnt .m-head {color: #fff; margin-bottom: 15px;}
.main-bot-wrap .flexwrap .cnt .m-head h2 {font-weight: 400;}

.requestZone {}
.requestZone .m-head .i-head {background-image:url("../images/main/icon_mb_head1.png");}
.requestZone .inputBox {background: #fff; padding: 25px 20px 26px 30px; border-radius:20px; margin-bottom: 10px;}
.requestZone .inputBox .row {margin-bottom: 10px;}
.requestZone .inputBox .row:last-child {margin-bottom: 0;}
.requestZone .inputBox dl {display: flex;align-items: center;}
.requestZone .inputBox dl dt {min-width: 85px;color: #454545; font-size: 17px;}
.requestZone .inputBox dl dd {flex: 1 1 auto; min-width: 0; width: 1%;}
.requestZone .inputBox dl dd .items {display: flex;flex-wrap:wrap;align-items: center;	margin: -2px -5px;}
.requestZone .inputBox dl dd .item {position: relative; display: inline-block; padding: 2px 5px;}
.requestZone .inputBox dl dd .item.w2 {width: calc(50% - 5.5px);}
.requestZone .inputBox dl dd input {height: 48px; border-radius:4px;}
.requestZone .btn-request {display: block; text-align: center; background: #3783da; border:0; border-radius:10px; font-family: 'NanumSquare', sans-serif; font-size: 22px; font-weight: 500; color: #fff; line-height: 60px; width: 100%;}
.requestZone .btn-request span:before {content:""; display: inline-block; width: 25px; height: 20px; margin: -.2em 14px 0 0; background: no-repeat url("../images/main/btn_request.png") center center / contain; vertical-align:middle;}

.requestZone .inputBox .row.flex {display: flex; margin-left: -8px; margin-right: -8px;}
.requestZone .inputBox .row.flex dl {width: 50%; padding: 0 8px;}


.requestZone .inputBox input.datepicker2 {padding-right: 45px;}
.requestZone .inputBox .ui-datepicker-trigger {position: absolute; top: 2px; right: 5px; border: 0; height: 48px;}
.requestZone .checkbox2 input {position:absolute; top:0; left:0; width:0; height:0; border:0; opacity:0; z-index:-1;}
.requestZone .checkbox2 label {display: inline-block; color: #454545; font-size: 17px; line-height: 38px; white-space: nowrap; border: 1px solid #ddd; border-radius:20px; padding: 0 12px; min-width: 60px; text-align: center;} 
.requestZone .checkbox2 input:checked + label {background:#1a4087; border-color:#1a4087; color: #ffff;}
.requestZone .checkbox2 input:focus + label:before {outline:2px solid highlight;}

.pop-request {max-width: 660px; width: 100%; margin: 0 auto;}
.pop-request .request-form-wrap {padding: 50px;}
.pop-request .requestZone .m-head {color: #fff; background: #1a4087; padding:15px 30px; margin-bottom: 0; text-align: center;}
.pop-request .requestZone .inputBox {border: 1px solid #1a4087; border-radius:20px; margin-bottom: 15px;}

.eventZone {position: relative;}
.eventZone .m-head .i-head {background-image:url("../images/main/icon_mb_head2.png");}
.eventZone .items {border-radius:20px; overflow:hidden;}
.eventZone .btn-more {position: absolute; top: 5px; right: 0; color: #fff;}
.eventZone .slider {position:relative;}
.eventZone .slider .item img {width: 100%;}
.eventZone .slider .slick-arrow {position:absolute; top:50%; margin-top:-25px; width:40px; height:50px; background-color:rgba(0,0,0,.4); background-position:50% 50%; background-repeat:no-repeat; border:0; overflow:hidden; text-indent:-9999em; z-index:50;}
.eventZone .slider .slick-prev {left:0px; background-image:url("../images/main/event_prev.png");}
.eventZone .slider .slick-next {right:0px; background-image:url("../images/main/event_next.png");}

.about-links {}
.about-links ul {display: flex; margin: 0 -20px;}
.about-links ul li {width: 33.333333%; padding: 0 20px; border-radius:20px;}
.about-links ul li a {display: table; width: 100%; min-height: 400px; height: 100%; padding: 30px; background-position:50% 50%; background-repeat:no-repeat; background-size:cover;}
.about-links ul li a.bg1 {background-image:url("../images/main/bg_about_links1.png");}
.about-links ul li a.bg2 {background-image:url("../images/main/bg_about_links2.png");}
.about-links ul li a.bg3 {background-image:url("../images/main/bg_about_links3.png");}
.about-links ul li .cell {display: table-cell; vertical-align:bottom;}
.about-links ul li .box {background: rgba(255,255,255,.9); padding: 30px 10px; border-radius:20px; text-align: center;}
.about-links ul li .box strong {display: block; font-family: 'NanumSquare', sans-serif; font-size: 22px; font-weight: 800; line-height: 1.3; letter-spacing: 0; margin-bottom: 5px;}
.about-links ul li .box p {color: #454545; font-size: 1.063em; line-height: 1.529em;}


/* sub */
#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left: 0; padding-right: 0;}


.sub-visual {position: relative; display:table; table-layout:fixed; width:100%; height:300px; overflow:hidden; text-align: center; color: #fff; background-color:#eee; background-position:82% 50%; background-attachment:scroll; background-repeat:no-repeat; background-size:cover;}
.sub-visual .cell {display:table-cell; vertical-align:middle; width: 100%; padding:20px; position: relative; z-index: 1;}
.sub-visual h2 {font-size:30px; font-weight: 700; line-height:1.5em; letter-spacing: 0;}
.sub-visual .bg {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.sub-visual .bg img {width: 100%; height: auto !important; max-width: 100%; min-height: 100%; object-fit: cover;}

.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")}

.top-visual {display:table; table-layout:fixed; width:100%; height:400px; overflow:hidden; text-align: center; color: #fff; background-color:#eee; background-position:82% 50%; background-attachment:scroll; background-repeat:no-repeat; background-size:cover;}
.top-visual .cell {display:table-cell; vertical-align:middle; padding:20px;}
.top-visual h2 {font-size:30px; font-weight: 700; line-height:1.5em; letter-spacing: 0;}

.top-visual.bg1 {background-image:url("../images/common/tv1.jpg")}
.top-visual.bg2 {background-image:url("../images/common/tv2.jpg")}
.top-visual.bg3 {background-image:url("../images/common/tv3.jpg")}

.sub-title {padding-top: 55px; padding-bottom: 30px; text-align:center;}
.sub-title h2 {font-size:30px; font-weight: 700; line-height:1.3em;}

.lnb {text-align:center; border-bottom: 1px solid #ddd;}
.lnb .contain {max-width:1200px; padding: 0;}
.lnb ul {display:flex;}
.lnb ul li {position: relative; flex:1; width:auto; background: #fff; border-right: 1px solid #ddd;}
.lnb ul li:first-child {border-left: 1px solid #ddd;}
.lnb ul li a {display:block; padding:0 10px; font-size: 20px; font-weight: 500; line-height:60px; white-space:nowrap; transition:none;}
.lnb ul li.active {color: #1a4087;}
.lnb ul li.active:after {content:""; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; background: #1a4087;}

.depth {text-align:center; background:#fff; margin-bottom:50px;}
.depth ul {display:flex; justify-content:center; flex-wrap:wrap; margin: -5px;}
.depth ul li {padding:5px;}
.depth ul li a {display:block; min-width: 180px; padding:0 14px; color:#242424; font-size:18px; font-weight:500; line-height:48px; border: 1px solid #ddd; border-radius:50px;}
.depth ul li a:hover {color:#3783da}
.depth ul li.active a {color:#fff !important; background:#3783da; border-color:#3783da; font-weight:400;} 

.real-cont {min-height:300px; padding-bottom: 100px;}

/* member */
.member #contArea {padding-top: 55px;}
.member .sub-title {padding-top: 0;}

/* quick */
.quick {position:absolute; right:5.2%; width:160px; text-align:center; z-index:99;}
.quick.fixed {position:fixed; top:180px !important;}
#main .quick {top:424px}
#sub .quick {top:300px}

.quick ul {}
.quick ul li {display: table; width: 100%; border-radius:10px; margin-bottom: 5px; color: #fff; font-weight: 500; font-size: 18px; padding: 5px; min-height: 60px;}
.quick ul li.tel {background: #3783da;}
.quick ul li.kakao {background: #ffe800; color: #3a1c1c;}
.quick ul li.request {background: #1ca388;}
.quick ul li.event {background: #3783da;}
.quick ul li a {display: table-cell; vertical-align: middle;}
.quick ul li:not(.tel) a {}
.quick ul li .inner {background: #fff; padding: 15px 5px; margin-top: 6px; border-radius:10px; font-family: 'Roboto', sans-serif; font-size: 22px; font-weight: 700; color: #1a4087;}

.quick ul li i {display: inline-block; width: 29px; height: 29px; vertical-align:middle; margin: -.2em 8px 0 0; background-position:50% 50%; background-repeat:no-repeat; background-size:contain;}
.quick ul li i.ico_tel {background-image:url("../images/common/icon_tel.png");}
.quick ul li i.ico_kakao {width: 37px; height: 37px; background-image:url("../images/common/icon_kakao.png");}
.quick ul li i.ico_request {background-image:url("../images/main/icon_mb_head1.png");}
.quick ul li i.ico_event {background-image:url("../images/main/icon_mb_head2.png");}

.todayview {background:#fff; border:1px solid #ddd; padding:10px 21px;}
.todayview .tt {color:#242424; font-size:15px; font-weight:500; line-height:1.3em; margin-bottom:12px;}
.todayview .items li {margin-bottom:5px;}
.todayview .items li a {display:block; position:relative; padding-bottom:128%; overflow:hidden;}
.todayview .items li a img {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.todayview .arrows {position:relative; height:22px; margin-top:6px;}
.todayview .arrows:before {content:""; position:absolute; top:50%; left:50%; width:1px; height:14px; background:#a6a6a6; margin-top:-7px;}
.todayview .slick-arrow {position:absolute; top:0; width:34px; height:22px; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; overflow:hidden; text-indent:-9999em;}
.todayview .slick-prev {left:0; background-image:url("../images/common/todayview_prev.png");}
.todayview .slick-next {right:0; background-image:url("../images/common/todayview_next.png");}

/* footer */
#footer {color: #fff; line-height: 1.75; background: #222222; padding: 35px 0;}
#footer address {font-style:normal;}

.foot-links {float: right; width: calc(100% - 168px); color: #d7d7d7; line-height: 35px;}
.foot-links ul {display:flex; margin: 0 -14px;}
.foot-links ul li {padding: 0 14px;}
.foot-links ul li a {display:block;}
.foot-links ul li a:hover {text-decoration:underline;}

.foot-info {}
.foot-info address {margin: 10px 0 12px; opacity: .5; font-weight: 300;}
.foot-info address span {display:inline-block; margin-right:14px; font-size: 0.938em;}
.foot-info .comp-name {font-size: 1.25em; font-weight: 600;}
.foot-info .copyright {font-size: 13px; letter-spacing: 0; opacity: .3;}

.scroll-top {position:fixed; right:5.2%; bottom: 75px; width:50px; height:50px; z-index:101; background: url("../images/common/scroll_top.png") center center no-repeat; background-size:contain; text-indent:-9999em; overflow:hidden;}