@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;} 


/* header */
#header {position:relative; position:fixed; top:0; left:0; width:100%; transition:.2s; background:transparent; z-index:100;} 
#header .contain {height:100px; display:flex; justify-content:center; z-index:2; max-width: 100%;} 

#sub #header {position: absolute;} 

#header.header-white {background: #fff;} 
#header.header-white .sitelogo a {background-image: url("../images/common/logo-on.png");} 
#header.header-white #gnb>ul>li>a {color: #242424;} 
#header.header-white .btn-all-menu span, #header.header-white .btn-all-menu span:before, #header.header-white .btn-all-menu span:after {background: #242424;} 
#header.header-white .btn-m-menu span, #header.header-white .btn-m-menu span:before, #header.header-white .btn-m-menu span:after {background: #242424;} 

.sitelogo {position:absolute; top:50%; left:var(--container-space); transform: translateY(-50%);} 
.sitelogo a {display:block; width:86px; height:62px; background:url("../images/common/logo.png") no-repeat center/contain; overflow:hidden; font-size:0; line-height:0; text-indent:-9999em;} 

#gnb {display: flex; justify-content: flex-end; width: 100%;} 
#gnb > ul {display:flex; text-align:center; padding-right: 30px;} 
#gnb > ul > li {position:relative; padding-right:var(--padding-100);} 
#gnb > ul > li > a {position:relative; display:flex; align-items:center; justify-content:center; height:100px; color:#fff; font-size:var(--font-size-20); font-weight:600; line-height:1.3em; letter-spacing:-.03em;} 
#gnb > ul > li.active > a {color: #0188bf !important;} 

/* layout */
 


/* main */
[data-aos=fade-up] {transform: translate3d(0,100px,0);} 
#main #container .contain {max-width:1460px;} 

.main-visual {position:relative; height:100vh; overflow:hidden; color:#fff;} 
.main-visual .item {position:relative; height:100vh; overflow:hidden;} 
.main-visual .image {position:relative; height:100vh; overflow:hidden; transition:5s; transform:scale(1.1);} 
.main-visual .image img {position:absolute; top:50%; left:0; 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 .caption {position:absolute; top:50%; transform:translateY(-50%); width:100%; z-index:40;} 
.main-visual .caption p {opacity:0; transform:translateY(50px); transition:1.4s; text-align:center;} 
.main-visual .caption .en {font-size: var(--font-size-20); margin-bottom: var(--margin-20);} 
.main-visual .caption .t1 {font-size:60px; font-weight:700; line-height:1.3em; letter-spacing:-.03em; margin-bottom: var(--margin-30);} 
.main-visual .caption .t2 {font-size:24px; line-height:1.45em; letter-spacing:-.03em;} 
.main-visual .slick-arrow {position:absolute; top:50%; transform:translateY(-50%); width:30px; height:57px; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; background-size: contain; border:0; overflow:hidden; text-indent:-9999em; z-index:50; opacity:0.3;} 
.main-visual .slick-prev {left:100px; background-image:url("../images/main/slide-prev.png");} 
.main-visual .slick-next {right:100px; background-image:url("../images/main/slide-next.png");} 
.main-visual .slick-prev:hover,
.main-visual .slick-next:hover {opacity:1;} 

.main-visual .slick-dots {position:absolute; bottom: 60px; left:0; width:100%; display:flex; justify-content:center; z-index:50;} 
.main-visual .slick-dots li {margin:0 5px;} 
.main-visual .slick-dots li button {position:relative; width: 60px; height:4px; background:rgba(255,255,255,.3); overflow:hidden; text-indent:-9999em; font-size:0; line-height:0; border:0;} 
.main-visual .slick-dots li button:before {content:""; position:absolute; top:0; left:0; width:0; height:100%; background:#fff;} 
.main-visual .slick-dots li.slick-active button {border-color:#fff;} 
.main-visual .slick-dots li.slick-active button:before {width:100%; animation:pagerProgress 5s;} 

.main-visual .active .image {transform:scale(1);} 
.main-visual .active .caption p {opacity:1; transform:translateY(0);} 
.main-visual .active .caption .t1 {transition-delay:.4s;}  
.main-visual .active .caption .t2 {transition-delay:.6s;} 


/* sub page */
.contain {max-width:1400px; margin:0 auto; padding-left:var(--container-space); padding-right:var(--container-space);} 
#contArea {max-width:1400px; padding-left:var(--container-space); padding-right:var(--container-space); margin:0 auto;} 
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;} 
 
.sub-title {font-size:var(--font-size-50); line-height:var(--line-height-sm); color:var(--color-primary);} 
.sub-box {display:flex; align-items:center; justify-content:center; width:300px; height:300px; border-radius:var(--border-radius-30); background-color:var(--color-warning); font-size:var(--font-size-20); color:var(--color-white); text-align:center;} 

.real-cont {padding:0 0 var(--padding-100);} 

/* sub */
.sub-visual {position: relative; height: 480px; overflow: hidden;} 
.sub-visual .bg {position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; transition: 2s; opacity: 0; transform: scale(1.1); background-repeat: no-repeat; background-position: 50% 0; background-size: cover;} 
.loaded .sub-visual .bg {transform: scale(1); opacity: 1;} 
.sub-visual .inner {position: absolute; left: 0; width: 100%; bottom: 80px;} 
.sub-visual h2 {display:inline-block; margin-right:25px; color: #fff; font-size:var(--font-size-60); line-height: 1.3em; letter-spacing: -.03em;} 
.sub-visual .desc {display:inline-block; position:relative; padding-left:35px; color: #fff; font-size: var(--font-size-20); font-weight: 600; line-height: 1em;} 
 .sub-visual .desc::before {content: ""; position: absolute; left:0; bottom:0; width:10px; height:10px; background-color: #0188bf; border-radius: 100%;} 
.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");} 


/* footer */
#footer {background-color: #454545; padding: var(--padding-40) 0; letter-spacing: -0.02em;} 
#footer .contain {display: flex; align-items: center; position: relative; max-width: 1600px;} 
#footer .foot-logo {padding-right: var(--padding-60);} 
#footer .foot-info {min-width: 0; width: 1%; flex: 1 1 auto; max-width: 1000px;} 

#footer .foot-info address {font-style: normal; display: flex; margin: 0 -15px; flex-wrap: wrap;} 
#footer .foot-info address p {padding: 0 15px; font-size: var(--font-size-15); color: #b8b8b8; line-height:2em;} 
#footer .foot-info .copy {font-size: var(--font-size-14); color: #b8b8b8; line-height:2.142em;} 
#footer .foot-menu {position: absolute; top: 0; right: var(--container-space); display: flex; justify-content: flex-end;} 
#footer .foot-menu li:nth-child(2) {margin-left: 45px;} 
#footer .foot-menu li a {position: relative; padding-left: 21px; color: #b8b8b8; font-size: var(--font-size-15); line-height: 2em;} 
#footer .foot-menu li a:before {content: ''; width: 15px; height: 15px; background: url('../images/common/pop-up.png')no-repeat 50% 50%/contain; position: absolute; left: 0; top: 2px;} 

/* for mobile */
.only-mobile {display:none;} 
.btn-m-menu {position:absolute; top:50%; margin-top:-11px; right:var(--container-space); width:30px; height:22px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out;} 
.btn-m-menu span {position:absolute; right:0; top:50%; margin-top:-1px; height:2px; width:23px; background:#fff;} 
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:30px; height:2px; background:#fff; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s;} 
.btn-m-menu span:before {top:-10px; transition-property:top, transform;} 
.btn-m-menu span:after {bottom:-10px; transition-property:bottom, transform;} 
.mobile-navigation {position:fixed; top:0; right:0; padding:20px 0; width:400px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202;} 
.mobile-navigation .home {display:block; margin-bottom:20px; padding-left:15px;} 
.mobile-navigation .home img {height:42px;} 
.mobile-navigation .nav-menu>ul {margin-top:30px;} 
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;} 
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:12px 15px; display:block; color:#454545; font-size:18px; font-weight:500; line-height:1.3em;} 
/* .mobile-navigation .nav-menu>ul>li a:after {content:""; position:absolute; top:50%; right:15px; transform:translateY(-75%) rotate(45deg); width:10px; height:10px; border-right:2px solid #2c2c2c; border-bottom:2px solid #2c2c2c;} */
.mobile-navigation .nav-menu>ul>li.active>a {color:#0188bf} 
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#0188bf;} 
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:0 15px 15px;} 
.mobile-navigation .nav-menu .submenu>ul:after {content:""; display:block; clear:both;} 
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; position:relative; padding:5px 15px; color:#454545; font-size:16px; font-weight:400; line-height:1.3em;} 
.mobile-navigation .nav-menu .submenu>ul>li>a:after {display:block; content:""; position:absolute; top:14px; left:5px; width:4px; height:4px; background:#dfdfdf; border-radius:50%; transition:.3s ease-in-out;} 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover {color:#0188bf} 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after {background:#0188bf} 
.mobile-navigation .close {position:absolute; top:20px; right:15px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;} 
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#2c2c2c;} 
.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:201;} 

html.menu-opened {overflow:hidden;} 
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);} 
html.menu-opened .mobile-overlay {display:block;} 