@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */ 

.only-desktop {display:block !important;}
.only-tablet {display:none !important;}
.only-mobile {display:none !important;}
.only-desktop-tablet {display:block !important;}
.only-tablet-mobile {display:none !important;}

#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:1460px; margin:0 auto; padding-left:var(--contain-padding); padding-right:var(--contain-padding);}
.contain:after {content:" "; display:block; clear:both;}

/* header */
#header {position:fixed; width:100%; z-index:102; top:0; left:0; right:0;}
#header .contain {position:relative; display:flex; align-items:center; height:var(--header-height);}

.sitelogo a {display:block; background:url('../images/common/logo-w.png') 0 50%/contain no-repeat;}
.sitelogo img {height:52px; visibility:hidden;}

#gnb {position:relative; text-align:center; flex:1;}
#gnb > ul {display:flex; justify-content:flex-end;}
#gnb > ul > li {position:relative; z-index:1;}
#gnb > ul > li:before {width:0; height:2px; opacity:0; position:absolute; content:''; bottom:-1px; left:50%; transform:translateX(-50%); transition:all 0.2s; background-color:var(--color-primary);}
#gnb > ul > li > a {height:var(--header-height); padding:0 var(--gnb-gutter); font-size:var(--font-size-18); font-weight:600; letter-spacing:0; color:#fff; display:flex; align-items:center; justify-content:center; position:relative; text-align:center; z-index:5;}
#gnb > ul > li:hover > a {color:var(--color-primary);}
#gnb > ul > li:hover:before {opacity:1; transition:all 0.2s; width:80%;}

#gnb .submenu {position:absolute; left:0; width:100%; height:0; overflow:hidden; text-align:center;}
#gnb .submenu>ul {padding:20px 0;}
#gnb .submenu>ul>li {margin-bottom:13px;}
#gnb .submenu>ul>li:last-child {margin-bottom:0;}
#gnb .submenu>ul>li>a {display:block; line-height:1.5em; font-weight:500;}
#gnb .submenu>ul>li>a:hover {color:var(--color-primary);}

.submenu-bg {display:none; position:absolute; width:100%; left:0; background:#fff; border-bottom:1px solid #ddd; border-top:1px solid #ddd;}

#header.fixed {background-color:#fff; box-shadow:1px 3px 10px rgba(0,0,0,.1);}
#header.fixed .sitelogo a {background-image:url('../images/common/logo.png');}
#header.fixed #gnb > ul > li > a {color:var(--color-bk);}
#header.fixed .btn-m-menu span,
#header.fixed .btn-m-menu span:before,
#header.fixed .btn-m-menu span:after {background-color:var(--color-bk);}

#header.header-hover {background-color:#fff;}
#header.header-hover .sitelogo a {background-image:url('../images/common/logo.png');}
#header.header-hover #gnb > ul > li > a {color:var(--color-bk);}

html.menu-opened #header {background-color:#fff;}
html.menu-opened #header .sitelogo a {background-image:url('../images/common/logo.png');}
html.menu-opened #header .btn-m-menu span,
html.menu-opened #header .btn-m-menu span:before,
html.menu-opened #header .btn-m-menu span:after {background-color:var(--color-bk);}

/* for mobile */
.btn-m-menu {position:relative;width:30px;height:30px;text-align:center;text-indent:-9999em;z-index:50; display:none;}
.btn-m-menu span {position:absolute; right:0; top:50%; width:20px; height:3px; background:#fff; border-radius:2px;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:27px; height:3px; background:#fff; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s; border-radius:2px;}
.btn-m-menu span:before {top:-9px; transition-property:top, transform;}
.btn-m-menu span:after {bottom:-9px; transition-property:bottom, transform;}

.mobile-navigation {border-top:1px solid #ddd; position:fixed; top:var(--header-height); right:0; width:280px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:10px 18px; display:block; color:#333; font-size:17px; 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 #454545; border-bottom:2px solid #454545;}
.mobile-navigation .nav-menu>ul>li.active {background:#f4f4f4}
.mobile-navigation .nav-menu>ul>li.active>a {color:#fff; background:var(--color-primary);}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#fff}
.mobile-navigation .nav-menu>ul>li.home>a {padding:19px 18px;}
.mobile-navigation .nav-menu>ul>li.home>a:after {display:none;}
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:10px 0;}
.mobile-navigation .nav-menu .submenu ul li a {display:block; padding:5px 18px; color:#454545; font-size:14px; font-weight:400; line-height:1.4em;}
.mobile-navigation .nav-menu .submenu ul li a:hover {color:var(--color-primary);}
.mobile-navigation .menu-close {position:absolute; top:15px; right:15px; width:30px; height:30px;overflow:hidden; text-indent:-999em;}
.mobile-navigation .menu-close:before, 
.mobile-navigation .menu-close:after {content:""; position:absolute; left:14px; height:30px; width:2px; background-color:#ddd;}
.mobile-navigation .menu-close:before {transform:rotate(45deg);}
.mobile-navigation .menu-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 .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 !important;}
html.menu-opened .btn-m-menu span:before,
html.menu-opened .btn-m-menu span:after {transition-delay:0s, 0.3s; background-color:#242424;}
html.menu-opened .btn-m-menu span:before {top:0; transform:rotate(45deg);}
html.menu-opened .btn-m-menu span:after {bottom:0; transform:rotate(-45deg);}

/* main */
.main-visual,
.main-visual .item {position:relative; height:100vh; overflow:hidden;}

.main-visual {background:#000; font-family:var(--font-graphie);}
.main-visual .image {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; transition:5s linear; transform:scale(1.15);}
.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 {bottom:calc(58% - 55px);}
.main-visual .caption p {transition:1.2s; transform:translate(50px,0); opacity:0;}
.main-visual .caption .txt1 {font-size:clamp(30px, calc( 70 / var(--inner) * 100vw ), 70px); font-weight:700; line-height:1.17em; letter-spacing:0;}
.main-visual .caption .txt2 {font-size:var(--font-size-26); font-weight:300; line-height:1.17em; letter-spacing:0; margin-top:20px;}
.main-visual .controls {top:calc(40% + 120px); display:flex; align-items:center;}
.main-visual .pager .current {display:inline-block; width:.6em;}
.main-visual .progress {position:relative; margin:0 10px; width:150px; height:2px; background:#fff;}
.main-visual .progress-bar {position:absolute; top:0; left:0; height:100%; background:#105089;}
.main-visual .slide-btn {width:24px; height:24px; margin-right:6px; border: 1px solid var(--color-primary); background-position:50% 50%; background-repeat:no-repeat; border-radius:100%; overflow:hidden;}
.main-visual .slide-prev {background-image:url("../images/main/ctr_prev.png");}
.main-visual .slide-next {background-image:url("../images/main/ctr_next.png");}
.main-visual .slide-stop {background-image:url("../images/main/ctr_stop.png");}
.main-visual .slide-play {display:none; background-image:url("../images/main/ctr_play.png");}
.main-visual .active .image {transform:scale(1);}
.main-visual .active .caption p {transform:translate(0,0); opacity:1;}
.main-visual .active .caption .txt1 {transition-delay:.2s;}
.main-visual .active .caption .txt2 {transition-delay:.5s;}
.main-visual .scroll {position:absolute; bottom:80px; left:50%; width:20px; margin-left:-10px; animation:scrollDown .9s linear infinite alternate; z-index:40;}

.main-visual .caption,
.main-visual .controls {position:absolute; left:50%; transform:translateX(-50%); padding:0 var(--contain-padding); width:100%; max-width:1460px; color:#fff; z-index:40;}

.progress-bar.animated {animation:progressBar 1 linear;}
.progress-bar.paused {animation-play-state:paused !important;}
.progress-bar.play {animation-play-state:running !important;}

@keyframes progressBar {
	0%{width:0;}
	100%{width:100%;}
}
@keyframes scrollDown {
	0%{transform:translateY(0);}
	100%{transform:translateY(15px);}
}
.visual-scroll {position:absolute; bottom:var(--space-70); left:50%; margin-left:-10px; z-index:10; line-height:0; animation:pulse 2s infinite;}

@-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-sec2 {padding:var(--space-130) 0 var(--space-150); background-image:url('../images/main/sec2bg.jpg'); background-position:50% 100%; background-repeat:no-repeat;}
.sec2-wrap {display:flex; align-items:flex-end; position:relative;}
.sec2-wrap .img {order:2; max-width:65%;}
.sec2-wrap .cont {flex:1; font-size:var(--font-size-18); letter-spacing:-.03em; line-height:1.67em;}
.sec2-wrap .cont .title {top:var(--space-70); font-size:var(--font-size-90); position:absolute; left:0; font-weight:700; color:var(--color-bk); letter-spacing:.26em; line-height:1em; font-family:var(--font-graphie);}
.sec2-wrap .cont .title span {color:#fff;}
.sec2-wrap .cont ul {margin:var(--space-40) 0 var(--space-20); max-width:220px;}
.sec2-wrap .cont ul li {position:relative;}
.sec2-wrap .cont ul li:after {content:''; position:absolute; bottom:0; left:0; width:100%; height:1px; background-color:#ddd;}
.sec2-wrap .cont ul li a {height:50px; display:flex; align-items:center; position:relative;}
.sec2-wrap .cont ul li a:after {width:6px; height:10px; content:''; position:absolute; right:0; top:50%; transform:translateY(-50%); background-image:url('../images/main/sec2-arrow.png'); background-size:contain; background-repeat:no-repeat; transition:all 0.2s;}
.sec2-wrap .cont ul li:hover:after {border-bottom:2px solid var(--color-primary);}
.sec2-wrap .cont ul li a:hover {color:var(--color-primary);}
.sec2-wrap .cont ul li a:hover:after {right:3px; background-image:url('../images/main/sec2-arrow-on.png'); transition:all 0.2s;}

.m-tit {font-family:var(--font-graphie); font-size:var(--font-size-50); letter-spacing:-.03em; line-height:1.2em; font-weight:700; color:var(--color-bk); text-align:center; margin-bottom:var(--space-50);}

.main-sec3 {padding:var(--space-120) 0 var(--space-140); text-align:center;}
.main-sec3 .slick-arrow {width:40px; height:74px; position:absolute; top:50%; transform:translateY(-50%); z-index:20; border:0; font-size:0; line-height:0; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; background-size:contain;}
.main-sec3 .slick-prev {left:-100px; background-image:url("../images/main/sec3-prev.png");}
.main-sec3 .slick-next {right:-100px; background-image:url("../images/main/sec3-next.png");}
.main-sec3 .slick-prev:hover {background-image:url("../images/main/sec3-prev-on.png");} 
.main-sec3 .slick-next:hover {background-image:url("../images/main/sec3-next-on.png");}
.main-sec3 .items {margin:0 -13px;}
.main-sec3 .item {margin:0 13px; display:block; position:relative;}
.main-sec3 .item:after {content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid #ddd;}
.main-sec3 .thumb {position:relative; padding-bottom:75%; overflow:hidden;}
.main-sec3 .thumb 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-sec3 .cont {border-top:1px solid #ddd; padding:var(--space-20) 0;}
.main-sec3 .cont .value {color:var(--color-secondary); font-weight:600; line-height:1.2em; letter-spacing:-.03em;}
.main-sec3 .cont .tit {margin-top:10px; font-weight:600; font-size:var(--font-size-18); line-height:1.3em; letter-spacing:-.03em; color:var(--color-bk);}

.main-sec4 {padding:var(--space-120) 0 var(--space-140); background-image:url('../images/main/sec4bg.jpg'); background-size:cover; background-position:50% 50%; background-repeat:no-repeat;}
.sec4-wrap {display:flex; gap:var(--space-20);}
.sec4-wrap .item {flex:1;}
.sec4-wrap .item a {align-items: center; display:flex; padding:var(--space-45) var(--space-50); background-color:#fff;}
.sec4-wrap .item a .txt {flex:1;}
.sec4-wrap .item a .txt .tit {font-size:var(--font-size-28); font-weight:700; line-height:1.3em; letter-spacing:-.03em; color:var(--color-bk);}
.sec4-wrap .item a .txt p {margin-top:var(--space-25); line-height:1.4em; letter-spacing:-.03em;}

/* sub page */
.sub-visual {text-align:center; position:relative; height:clamp(250px, calc( 500 / var(--inner) * 100vw ), 500px); color:#fff; background:#333; 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;}
.sub-visual .inner {margin-top:40px; position:absolute; top:50%; left:0; width:100%; transform:translateY(-50%);}
.sub-visual strong {font-size:clamp(25px, calc( 54 / var(--inner) * 100vw ), 54px); line-height:1em; display:block; letter-spacing:-.03em;}
.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 [data-aos=fade-up] {transform:translate3d(0,30px,0);}
.loaded .sub-visual .bg {transform:scale(1); opacity:1;}

.depth-menu {margin-bottom:var(--space-25); display:flex; justify-content:center;}
.depth-menu span {padding:0 15px; display:flex; align-items:center; font-weight:500; color:#ddd; position:relative;}
.depth-menu span:first-child {padding-left:0;}
.depth-menu span:last-child {padding-right:0;}
.depth-menu span:after {border-radius:50%; content:''; position:absolute; top:50%; right:-2px; width:3px; height:3px; background-color:#ccc; transform:translateY(-50%);}
.depth-menu span:last-child:after {display:none;}
.depth-menu .home i {width:14px; height:16px; margin-top:-3px; background-image:url('../images/common/home.png'); background-size:contain; background-position:50% 50%; background-repeat:no-repeat; display:inline-block;}

.lnb {margin:var(--space-100) 0 var(--space-80);}
.lnb ul {justify-content:center;}
.lnb ul li {padding:0 10px; width:auto; position:relative; z-index:1;}
.lnb ul li a {height:56px; padding:0 20px; color:#999; border-radius:30px; font-size:var(--font-size-18); align-items:center; justify-content:center; display:flex; letter-spacing:-.03em; font-weight:600; position:relative;}
.lnb ul li.active a {background:linear-gradient(180deg,rgba(23, 104, 178, 1) 0%, rgba(25, 150, 211, 1) 100%); color:#fff !important;}
.lnb ul li:hover a {color:var(--color-primary);}

.sub-title {padding:var(--space-120) 0 var(--space-55); text-align:center;}
.sub-title h1 {font-size:var(--font-size-32); letter-spacing:-.03em; line-height:1.3em; color:var(--color-bk);}

#contArea {width:100%; max-width:1460px; margin:0 auto; padding:0 var(--contain-padding);}
#contArea.wide {max-width:none; padding:0;}

.real-cont {padding:var(--space-120) 0 var(--space-120);}

/* footer */
#footer {border-top:1px solid #ddd; font-size:var(--font-size-14); letter-spacing:-.03em; line-height:1.3em; padding:var(--space-40) 0 var(--space-25);}
#footer span {display:inline-block;}
#footer .contain {display:flex; gap:10px;}

#footer .col-l {flex:1;}
#footer .col-r {text-align:right; display:flex; flex-direction:column; justify-content:space-between;}

.foot-info {margin-top:var(--space-30); display:flex; flex-wrap:wrap;}
.foot-info dl {line-height:1.8em; display:flex; gap:var(--space-20); color:var(--color-bk);}
.foot-info dl dt {width:75px; font-weight:600;}
.foot-info dl dd {font-weight:300;}
.foot-info p {margin-top:var(--space-20);}
.foot-info p span {padding-right:var(--space-25);}
.foot-info p span:last-child {padding-right:0;}

.foot-link {font-size:var(--font-size-15); letter-spacing:-0.03em; line-height:1.4em; font-weight:300; display:flex; gap:var(--space-50); justify-content:flex-end;}
.foot-link img {margin:-2px 10px 0 0; vertical-align:middle;}

.foot-copy {color:#888;}
.foot-copy a {font-size:13px; letter-spacing:-.03em; display:inline-block;}