@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;outline-color:#f37736;}

.only-desktop-tablet {display:block;}
.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}

#wrapper {position:relative; overflow:hidden;}
#sub #wrapper {padding-top:var(--header-height);}

/* header */
#header {position:fixed; top:0; left:0; width:100%; z-index:100; transition:.3s;}
#header .contain {max-width:1860px; position:relative; display:flex; align-items:center; justify-content:space-between; height:var(--header-height); z-index:10;}

.sitelogo a {display:block; background:url("/images/common/logo-w.png") no-repeat 0 center / contain; width:clamp(80px, calc(167 / var(--inner) * 100vw), 167px); height:clamp(29px, calc(60 / var(--inner) * 100vw), 60px); font-size:0; line-height:0;}

#gnb>ul {display:flex; text-align:center;} 
#gnb>ul>li {position:relative; padding:0 var(--space-50);}
#gnb>ul>li>a {font-size:var(--font-size-20); font-weight:600; letter-spacing:-.03em; line-height:1.3em; display:flex; align-items:center; justify-content:center; height:var(--header-height); color:#fff;}
#gnb .submenu {position:absolute; left:0; width:100%; height:0; overflow:hidden; text-align:center;}
#gnb .submenu>ul {padding:var(--space-30) 5px var(--space-65);}
#gnb .submenu>ul>li>a {display:block; padding:var(--space-10) 0; color:#121212; font-size:var(--font-size-17); line-height:1.59em; letter-spacing:-.03em;}
#gnb .submenu>ul>li>a:hover {color:var(--color-primary); font-weight:600; transition:.2s;}
.submenu-bg {border-top:1px solid #eee; display:none; position:absolute; width:100%; left:0; background:#fff url('/images/common/submenu-bg.png') no-repeat 100% 100%;}

.pull-right {display:flex; align-items:center; gap:0 var(--space-55);}

.language {position:relative; display:inline-block;}
.language .toggle-button {display:flex; align-items:center; gap:8px; background:none; border:0; color:#fff; font-weight:600; text-align:left;}
.language .toggle-button .ico {width:16px;}
.language .toggle-button .txt {font-weight:600; letter-spacing:-.03em;}
.language .toggle-button .chevron {width:8px; height:6px; background:url('/images/common/chevron-w.png') no-repeat 50% 50% / contain;}
.language .toggle-button svg {display:block; width:100%; height:auto;}
.language .toggle-button path {fill:#fff;}
.language .toggle-layer {display:none; position:absolute; left:50%; top:calc(100% + var(--space-15)); transform:translateX(-50%); width:60px; text-align:center;}
.language .toggle-layer ul {display:grid; gap:var(--space-5);}
.language .toggle-layer a {border-radius:var(--radius-12); padding:3px; background:#ccc; display:block; font-size:var(--font-size-14); font-weight:600; letter-spacing:-.03em; line-height:1.3em;}
.language .toggle-layer a:hover {color:#fff; background:#000;}
.language.active .toggle-button .chevron {transform:scaleY(-1);}

/* 전체메뉴 */
.btn-all-menu {display:block; position:relative; width:60px; height:17px;}
.btn-all-menu span {position:absolute; left:20px; right:0; bottom:0; height:3px; margin-top:-1px; background:#fff;}
.btn-all-menu span:before {top:-17px; content:" "; position:absolute; left:-20px; right:0; height:3px; background:#fff;}

.allmenu {position:fixed; top:0; left:0; width:100%; height:100%; background:url('/images/common/sitemap-logo.png') no-repeat 0 100% / clamp(300px, calc(1474 / var(--inner) * 100vw), 1474px) auto, linear-gradient(to right, var(--color-secondary), var(--color-primary)); transform:translateX(100%); transition:.4s ease-out; z-index:102; color:#fff;}
.allmenu .heading {position:absolute; top:0; left:0; width:100%; height:var(--header-height); z-index:10;}
.allmenu .heading .contain {max-width:1860px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; height:var(--header-height); z-index:10;}
.allmenu .heading h2 {font-size:var(--font-size-56); font-weight:700; letter-spacing:-.03em; line-height:1.3em;}
.allmenu .close {position:relative; width:46px; height:100%; text-indent:-9999em; overflow:hidden;}
.allmenu .close:before,
.allmenu .close:after {content:" "; position:absolute; top:50%; left:50%; margin:-2px 0 0 -23px; width:46px; height:2px; background:#fff;}
.allmenu .close:before {transform:rotate(45deg);}
.allmenu .close:after {transform:rotate(-45deg);}
.allmenu .nav {display:flex; align-items:center; position:relative; height:100%; padding:0 var(--space-40);}
.allmenu .nav > ul {display:flex; width:100%;}
.allmenu .nav > ul > li {flex:1; padding:var(--space-70) var(--space-40); border-left:1px solid rgba(255,255,255,.3);}
.allmenu .nav > ul > li:first-child {border-left:0;}
.allmenu .nav > ul > li > a {display:inline-block; font-size:var(--font-size-32); font-weight:700; letter-spacing:-.03em; line-height:1.33em; color:rgba(255,255,255,.7);}
.allmenu .nav .submenu {position:relative; padding-top:var(--space-40);}
.allmenu .nav .submenu ul {display:grid; gap:var(--space-20) 0;}
.allmenu .nav .submenu ul li a {position:relative; display:inline-block; color:rgba(255,255,255,.7); font-size:var(--font-size-18); font-weight:600; letter-spacing:-.03em; line-height:1.4em;}
.allmenu .nav .submenu ul li a br {display:none;}
.allmenu .nav .submenu ul li a:after {content:''; position:absolute; left:0; bottom:0; width:0; height:2px; background:#fff; transition:.2s;}
.allmenu .nav .submenu ul li a:hover:after {width:100%;}
.allmenu .nav > ul > li:hover > a {color:#fff;}
.allmenu .nav > ul > li:hover .submenu ul li a {color:#fff;}

html.all-menu-opened {overflow:hidden;}
html.all-menu-opened .allmenu {transform:translateX(0);}

#header:hover {background:#fff;}
#header:hover .sitelogo a {background-image:url('/images/common/logo.png');}
#header:hover #gnb>ul>li>a {color:#121212;}
#header:hover .language .toggle-button {color:#121212;}
#header:hover .language .toggle-button path {fill:#121212;}
#header:hover .language .toggle-button .chevron {background-image:url('/images/common/chevron.png');}
#header:hover .btn-all-menu span,
#header:hover .btn-all-menu span:before {background:#121212;}

#header.header-fixed {background:#fff; box-shadow:0px 3px 5px rgba(0,0,0,0.1);}
#header.header-fixed .sitelogo a {background-image:url('/images/common/logo.png');}
#header.header-fixed #gnb>ul>li>a {color:#121212;}
#header.header-fixed .language .toggle-button {color:#121212;}
#header.header-fixed .language .toggle-button path {fill:#121212;}
#header.header-fixed .language .toggle-button .chevron {background-image:url('/images/common/chevron.png');}
#header.header-fixed .btn-all-menu span,
#header.header-fixed .btn-all-menu span:before {background:#121212;}

.fp-viewing-business #header {background:#fff; box-shadow:0px 3px 5px rgba(0,0,0,0.1);}
.fp-viewing-business #header .sitelogo a {background-image:url('/images/common/logo.png');}
.fp-viewing-business #header #gnb>ul>li>a {color:#121212;}
.fp-viewing-business #header .language .toggle-button {color:#121212;}
.fp-viewing-business #header .language .toggle-button path {fill:#121212;}
.fp-viewing-business #header .language .toggle-button .chevron {background-image:url('/images/common/chevron.png');}
.fp-viewing-business #header .btn-all-menu span,
.fp-viewing-business .btn-all-menu span:before {background:#121212;}

.fp-viewing-main_footer #header {background:#fff; box-shadow:0px 3px 5px rgba(0,0,0,0.1);}
.fp-viewing-main_footer #header .sitelogo a {background-image:url('/images/common/logo.png');}
.fp-viewing-main_footer #header #gnb>ul>li>a {color:#121212;}
.fp-viewing-main_footer #header .language .toggle-button {color:#121212;}
.fp-viewing-main_footer #header .language .toggle-button path {fill:#121212;}
.fp-viewing-main_footer #header .language .toggle-button .chevron {background-image:url('/images/common/chevron.png');}
.fp-viewing-main_footer #header .btn-all-menu span,
.fp-viewing-main_footer .btn-all-menu span:before {background:#121212;}

#sub #header {background:#fff;}
#sub #header .sitelogo a {background-image:url('/images/common/logo.png');}
#sub #header #gnb>ul>li>a {color:#121212;}
#sub #header .language .toggle-button {color:#121212;}
#sub #header .language .toggle-button path {fill:#121212;}
#sub #header .language .toggle-button .chevron {background-image:url('/images/common/chevron.png');}
#sub #header .btn-all-menu span,
#sub #header .btn-all-menu span:before {background:#121212;}

/* main */
#main #container .contain {max-width:1860px;}

/* 기존 메인비주얼 */
.main-visual {position:relative; overflow:hidden;}
.main-visual .item {height:100vh;}
.main-visual .item .video-js,
.main-visual .item video {position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover;}
.main-visual .item iframe {position:absolute; top:50%; left:50%; width:100vw; height:100vh; -webkit-transform:translate(-50%,-50%); transform:translate(-50%,-50%);}
.main-visual .item 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;}

/* video는 메인비주얼 높이에 따라 달라지도록 수정하였습니다. */
.main-visual2 {position:relative; overflow:hidden;}
.main-visual2 .item {height: auto;}
.main-visual2 .item .video-js,
.main-visual2 .item video {position: relative; top:0; left:0; width:100%; height:100%; object-fit:cover;}
.main-visual2 .item iframe {position:absolute; top:50%; left:50%; width:100vw; height:100vh; -webkit-transform:translate(-50%,-50%); transform:translate(-50%,-50%);}
.main-visual2 .item 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-visual2 .video-js .vjs-tech {position: initial;}
.main-visual2 .main_visual_vod_0-dimensions {width: auto; height: auto;}

@media (min-aspect-ratio:16/9) {
	.main-visual .item iframe {height:56.25vw;}
}
@media (max-aspect-ratio:16/9) {
	.main-visual .item iframe {width:177.78vh;}
}

.scroll {text-align:center; position:absolute; bottom:var(--space-60); width:100%;}
.scroll .txt {margin-bottom:var(--space-8); color:#fff;}
.scroll .track { border-radius:3px; position:relative; margin:0 auto; width:8px; height:50px; background:rgba(255,255,255,.3); overflow:hidden;}
.scroll .track span {position:absolute; left:0; width:8px; height:8px; top:0; border-radius:100%; background:#fff; animation:scrollDown 1.8s linear infinite;}

@keyframes scrollDown {
    0% {
        transform:translateY(0);
    }

    100% {
        transform:translateY(70px);
    }
}

.main-business .section-inner {padding:calc(var(--header-height) + 10px) var(--space-60);}
.main-business .sliders {display:flex; justify-content:space-between; gap:0 var(--space-100); margin:0 -250px;}
.main-business .unfold {position: relative; width:60%;}
.main-business .unfold .slick-slide {opacity: 0;}
.main-business .unfold .slick-slide.slick-current {opacity:1;}
.main-business .unfold .wrap {display:flex; gap:0 var(--space-80);}
.main-business .unfold .image {width:46%; height:642px; aspect-ratio:620/682; border-radius:var(--radius-40); overflow:hidden;}
.main-business .unfold .image img {width:100%; height:100%; object-fit:cover;}
.main-business .unfold .content {flex:1; max-width:586px;}
.main-business .unfold .text {min-height:275px; padding-bottom:var(--space-25);}
.main-business .unfold .text h2 {margin-bottom:var(--space-30); font-size:var(--font-size-48); font-weight:700; letter-spacing:-.03em; line-height:1em;}
.main-business .unfold .text h2 img {margin-right:var(--space-20); display:inline-block; height:clamp(30px, calc(55 / var(--inner) * 100vw), 55px);}
.main-business .unfold .text p {font-size:var(--font-size-18); line-height:1.67em; color:#505050;}
.main-business .unfold .cnt h3 {margin-bottom:var(--space-35); font-size:var(--font-size-18); font-weight:700; letter-spacing:-.03em; line-height:1.3em; color:var(--color-primary);}
/* .main-business .unfold .prods {display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--space-25) var(--space-10);}
.main-business .unfold .prod .img {border-radius:var(--radius-8); position:relative; padding-bottom:75%; overflow:hidden;}
.main-business .unfold .prod .img:after {border-radius:var(--radius-8); content:''; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid #ddd;}
.main-business .unfold .prod .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-business .unfold .prod p {margin-top:var(--space-12); font-weight:600; letter-spacing:-.03em; line-height:1.4em; text-align:center;} */
.main-business .unfold .list ul li {margin-bottom:var(--space-20); padding-left: 16px; position: relative; font-size: var(--font-size-18); font-weight: 400; line-height: 1.4em; color: #505050;}
.main-business .unfold .list ul li:last-child {margin-bottom: 0;}
.main-business .unfold .list ul li:before {transition:.3s; content:''; position: absolute; left:0; top:.5em; width: 6px; height: 6px; border-radius:100%; background: #cecece;}
.main-business .unfold .list ul li:hover {color:var(--color-secondary); font-weight: 600;}
.main-business .unfold .list ul li:hover:before {background:var(--color-secondary);}
.main-business .unfold .slick-arrow {position:absolute; top:50%; margin-top: -21px; width: 23px; height: 42px; background-size:contain; background-repeat: no-repeat; background-position: 50% 50%; border:0; font-size: 0; background-color:transparent;}
.main-business .unfold .slick-prev {left:-4.5%; background-image: url('/images/main/biz-prev.png');}
.main-business .unfold .slick-next {right:-4.5%; background-image: url('/images/main/biz-next.png');}
.main-business .unfold .slick-dots {text-align:center; margin-top:var(--space-30);}
.main-business .unfold .slick-dots li {display:inline-block; margin:0 var(--space-8);}
.main-business .unfold .slick-dots li button {border:0; font-size: 0; border-radius:100%; width:clamp(8px, calc(12 / var(--inner) * 100vw), 12px); height:clamp(8px, calc(12 / var(--inner) * 100vw), 12px); background: #ccc;}
.main-business .unfold .slick-dots li.slick-active button {background:#000;}

.main-business .fold {flex:1 1 auto; min-width:0; width:1%; opacity: 0.5;}
.main-business .fold .items .item {display: none;opacity: 0; transition: opacity .25s ease;} 
.main-business .fold .image {height:642px; border-radius:var(--radius-40); overflow:hidden;}
.main-business .fold .image img {width:100%; height:100%; object-fit:cover;}
/* .main-business .fold .items {}
.main-business .fold .item {opacity:1; width:621px;}

.main-business .fold .slick-current .item {opacity:.5;} */


.section.main-business .fold .items .item.is-active {
  display: block;
  opacity: 1;
}


/* sub */
.path-wrap {position:relative; border-bottom:1px solid #eee; border-top:1px solid #eee; z-index:50;}
.path-wrap .wrap {max-width:1400px; margin:0 auto;}
.path-wrap .inner {display:flex;}
.path-wrap .home a {display:block; width:clamp(40px, calc(80 / var(--inner) * 100vw), 80px); height:clamp(40px, calc(80 / var(--inner) * 100vw), 80px); background:url("../images/common/home.png") 50% 50% no-repeat; text-indent:-999em; overflow:hidden; border-left:1px solid #eee; border-right:1px solid #eee;}
.path-wrap .part {position:relative; min-width:240px; border-right:1px solid #ddd; z-index:50;}
.path-wrap .part > a {display:flex; align-items:center; position:relative; height:clamp(40px, calc(80 / var(--inner) * 100vw), 80px); color:#121212; font-weight:600; line-height:1.3em; padding:0 60px 0 20px;}
.path-wrap .part > a:after {content:""; position:absolute; top:50%; right:12px; margin-top:-3px; width:11px; height:7px; background:url("/images/common/path-down.png") 50% 50% no-repeat;}
.path-wrap .part ul {display:none; position:absolute; left:-1px; right:-1px; background:#fff; border:1px solid #ddd; z-index:50;}
.path-wrap .part ul li {color:#505050; line-height:1.3em; border-bottom:1px solid #ddd;}
.path-wrap .part ul li:last-child {border-bottom:0;}
.path-wrap .part ul li a {display:block; padding:var(--space-15) 20px;}
.path-wrap .part ul li a:hover,
.path-wrap .part ul li.active a {color:#242424; background:#f8f8f8;}

.sub-title {position:relative; height:clamp(200px, calc(305 / var(--inner) * 100vw), 305px);}
.sub-title .text {position:absolute; top:50%; left:0; width:100%; transform:translateY(-50%);}
.sub-title .text p {margin-bottom:var(--space-12); display:inline-block; font-size:var(--font-size-18); font-weight:700; letter-spacing:-0.03em; line-height:1.3em; background:linear-gradient(to right, var(--color-secondary), var(--color-primary)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent;}
.sub-title .text h1 {font-size:var(--font-size-64); font-weight:700; letter-spacing:-.03em; line-height:1.3em; color:#121212;}

.lnb-wrap {position:absolute; left:0; bottom:0; width:100%; text-align:center; padding:0 30px;}
.lnb {max-width:1400px; margin:0 auto;}
.lnb ul {display:flex; gap:0 var(--space-60);}
.lnb ul li a {height:clamp(34px, calc(45 / var(--inner) * 100vw), 45px); font-size:var(--font-size-18); font-weight:500; letter-spacing:-.03em; line-height:1.3em; color:#505050; position:relative; display:block; text-align:center;}
.lnb ul li a:after {display:none; content:""; position:absolute; left:0; width:100%; height:4px; bottom:0; background:var(--color-secondary);}
.lnb ul li.active a {color:var(--color-secondary); font-weight:700;}
.lnb ul li.active a:after {display:block;}

.sub-visual {position:relative; height:clamp(180px, calc(500 / var(--inner) * 100vw), 500px); text-align:center; color:#fff; overflow:hidden; background:#333;}
.sub-visual .bg {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; transition:2s; opacity:1; transform:scale(1.1); background-repeat:no-repeat; background-position:100% 0; background-size:cover;}
.sub-visual .bg1-1 {background-image:url("/images/common/sv1-1.jpg");}
.sub-visual .bg1-2 {background-image:url("/images/common/sv1-2.jpg");}
.sub-visual .bg2-1 {background-image:url("/images/common/sv2-1.jpg");}
.sub-visual .bg4 {background-image:url("/images/common/sv4.jpg");}
.sub-visual .bg5 {background-image:url("/images/common/sv5.jpg");}
.sub-visual .bg5-2 {background-image:url("/images/common/sv5-2.jpg");}
.sub-visual .bg5-3 {background-image:url("/images/common/sv5-3.jpg");}
.sub-visual .bg5-4 {background-image:url("/images/common/sv5-4.jpg");}
.sub-visual .bg6 {background-image:url("/images/common/sv6.jpg");}
.sub-visual .txt {position:absolute; width:100%; bottom:var(--space-30); text-align:center; font-size:var(--font-size-48); font-weight:700; letter-spacing:-.03em; line-height:1.3em; color:#fff;}

.loaded .sub-visual .bg {transform:scale(1); opacity:1;}

.contain {width:100%; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}

#contArea {max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}

.real-cont {min-height:300px; padding:var(--space-100) 0 var(--space-180);}

/* footer */
#footer {background:url('/images/common/foot-bg.jpg') no-repeat 0 100% / cover; color:rgba(255,255,255,.5); line-height:1.4em; letter-spacing:-.03em;}
#footer .contain {max-width:1860px;}

.foot-info {padding:var(--space-75) 0;}
.foot-info .contain {display:flex; justify-content:space-between;}
.foot-info .f-info address {display:grid; gap:var(--space-20) 0; font-style:normal;}
.foot-info .f-info address .title {font-size:var(--font-size-20); font-weight:700; letter-spacing:-.03em; line-height:1.3em; color:#fff;}
.foot-info .f-info address strong {min-width:110px; display:inline-block; font-weight:400; color:#fff;}
.foot-info .f-menu>ul {display:flex; gap:0 var(--space-55)}
.foot-info .f-menu>ul>li>a {display:inline-block; margin-bottom:var(--space-20); font-weight:600; color:#fff;}
.foot-info .f-menu .submenu ul {font-size:var(--font-size-14); display:grid; gap:var(--space-15) 0;}

.familysite {margin-top:var(--space-55); position:relative; display:inline-block; width:200px;}
.familysite .toggle-button {border-radius:var(--radius-8); display:flex; justify-content:space-between; align-items:center; width:100%; padding:var(--space-12) var(--space-20); background:none; color:#fff; border:1px solid rgba(255,255,255,.6); font-weight:400; font-size:var(--font-size-14); line-height:1.5em; text-align:left;}
.familysite .toggle-button .chevron {width:11px;}
.familysite .toggle-button svg {display:block; width:100%; height:auto;}
.familysite .toggle-button path {fill:#fff;}
.familysite .toggle-layer {overflow:hidden; display:none; position:absolute; bottom:100%; left:0; width:100%; background:#fff; border:1px solid #ddd; border-radius:var(--radius-8); border-top:0;}
.familysite .toggle-layer ul li:not(:last-child) {border-bottom:1px dotted #ddd;}
.familysite .toggle-layer a {display:block; padding:8px 15px; color:#767676; font-weight:400; line-height:1.5em;}
.familysite .toggle-layer a:hover {background:#f7f7f7; color:#2c2c2c;}
.familysite.active .toggle-button .chevron {transform:scaleY(-1);}

.foot-etc {border-top:1px solid rgba(255,255,255,.2); padding:var(--space-20) 0;}
.foot-etc .contain {display:flex; align-items:center; justify-content:space-between;}
.foot-etc .f-logo img {height:clamp(24px, calc(40 / var(--inner) * 100vw), 40px);}
.foot-etc .copy {font-size:var(--font-size-12);}

.scroll-top {position:fixed; bottom:var(--space-80); right:var(--space-60); transition:.2s; opacity:0; display:flex; flex-direction:column; justify-content:center; width:80px; height:80px; text-align:center; border-radius:var(--radius-8); color:#fff; font-size:var(--font-size-12); font-weight:600; line-height:1.3em; letter-spacing:0; background:#505050; z-index:90;}
.scroll-top:before {content:""; display:block; margin:0 auto 8px; width:0; height:0; border-left:6px solid transparent; border-right:6px solid transparent; border-bottom:8px solid #fff;}
.scroll-top.active {opacity:1;}