@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 {display:block;}
.only-desktop-tablet {display:block;}
.only-tablet-mobile {display:none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

#wrapper {position:relative; padding-top:var(--header-height);}

.contain {max-width:1260px; margin:0 auto; padding-right:var(--space-container); padding-left:var(--space-container);}

#container {overflow:hidden;}

/* header */
#header {position:fixed; top:0; left:0; z-index:100; width:100%; height:var(--header-height); padding:0 4.5%; box-shadow:0 0 10px rgba(0, 0, 0, 0.1); transition:.2s; background:#fff;}

#header .contain {position:relative; display:flex; align-items:center; justify-content:space-between; width:100%; max-width:100%; height:100%; padding:0; z-index:2;}

.sitelogo img {height:clamp(46px, calc(61 / var(--inner) * 100vw), 61px);}

#gnb {text-align:center; flex:1 1 auto; min-width:0; width:1%;}
#gnb>ul {display:flex; justify-content:center;} 
#gnb>ul>li {position:relative; padding:0 clamp(10px, calc(15 / var(--inner) * 100vw), 15px);}
#gnb>ul>li>a {position:relative; display:flex; align-items:center; flex-direction:column; justify-content:center; height:var(--header-height); padding:0 clamp(20px, calc(40 / var(--inner) * 100vw), 40px); font-size:var(--font-size-20); letter-spacing:-.03em; line-height:1.3em;}
#gnb>ul>li>a:after {content:""; position:absolute; bottom:-1px; left:50%; transform:translateX(-50%); width:0; height:2px; background:var(--color-primary); transition:.4s;}
#gnb>ul>li:hover>a:after {width:100%;}
#gnb .submenu {position:absolute; left:0; width:100%; height:0; overflow:hidden; text-align:center;}
#gnb .submenu>ul {padding:30px 5px;}
#gnb .submenu>ul>li>a {display:block; padding:8px 0; color:#454545; font-size:var(--font-size-18); line-height:1.33em;}
#gnb .submenu>ul>li>a:hover {text-decoration:underline; color:var(--color-primary); text-underline-offset:3px;}
.submenu-bg {display:none; position:absolute; width:100%; left:0; background:#fff url('/images/common/sm-bg.svg') right 4.5% bottom -20% no-repeat; border-top:1px solid #ddd; border-bottom:1px solid #eee;}

#header:hover {background:#fff; color:#242424;}
#header:hover .sitelogo a {background-image:url('/images/common/logo.svg');}
#header:hover .btn-m-menu span {background:#242424;} 

.header-fixed #header {background:#fff; color:#242424;}
.header-fixed .sitelogo a {background-image:url('/images/common/logo.svg');}
.header-fixed .btn-m-menu span {background:#242424;} 


/* for mobile */
.btn-m-menu {position:relative; width:26px; height:26px;}
.btn-m-menu div {display:flex; flex-direction:column; justify-content:center; align-items:flex-end; gap:8px; width:100%; height:100%;}
.btn-m-menu span {display:block; width:100%; height:2px; background:#242424; border-radius:2px; transition:.2s;}
.btn-m-menu span:nth-child(1),
.btn-m-menu span:nth-child(3) {width:70%;}
.btn-m-menu:hover span:nth-child(1),
.btn-m-menu:hover span:nth-child(3) {width:100%;}

.mobile-navigation {position:fixed; top:0; right:0; width:300px; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .home {display:flex; align-items:center; height:var(--header-height); padding:0 20px;}
.mobile-navigation .home img {height:clamp(46px, calc(61 / var(--inner) * 100vw), 61px);}
.mobile-navigation .nav-menu>ul {border-top:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:10px 48px 10px 20px; display:block; color:#242424; font-size:18px; 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:11px; height:11px; border-right:2px solid #505050; border-bottom:2px solid #505050;}
.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 .submenu {display:none; background:#f8f8f8; color:#454545; font-size:16px; font-weight:400; line-height:1.5em;}
.mobile-navigation .nav-menu .submenu ul li {border-top:1px solid #e5e5e5;}
.mobile-navigation .nav-menu .submenu ul li a {display:block; padding:12px 20px;}
.mobile-navigation .nav-menu .submenu ul li a:hover {color:var(--color-primary);}
.mobile-navigation .close {position:absolute; top:25px; right:15px; width:26px; height:26px; 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:#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;}

/* main */
#main #container .contain {max-width:1460px;}

.m-more {display:inline-flex; align-items:center; justify-content:center; gap:clamp(5px, calc(10 / var(--inner) * 100vw), 10px); width:clamp(120px, calc(140 / var(--inner) * 100vw), 140px); height:clamp(40px, calc(48 / var(--inner) * 100vw), 48px); padding:0 clamp(15px, calc(30 / var(--inner) * 100vw), 30px); border:1px solid #dddddd; border-radius:50px; font-size:var(--font-size-16); font-weight:400; line-height:1.625em; color:#242424; transition:.2s;}
.m-more:hover {border-color:var(--color-primary); background:var(--color-primary); color:#fff;}
.m-more .text {display:inline-block;}
.m-more .arrow {display:inline-block;}

.m-slide-btn {position:absolute; top:50%; z-index:20; -webkit-transform:translateY(-50%); transform:translateY(-50%); width:clamp(40px, calc(48 / var(--inner) * 100vw), 48px); aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid #ddd; border-radius:50%; transition:.2s; color:#aaa;}
.m-slide-btn svg {display:block; transition:.4s;}
.m-slide-btn:hover {background:var(--color-primary); border-color:var(--color-primary); color:#fff;}
.m-slide-btn.prev {left:4.5%;}
.m-slide-btn.next {right:4.5%;}

.main-visual {position:relative; z-index:2; width:100%; height:clamp(200px, calc(500 / var(--inner) * 100vw), 500px); background:#eee; overflow:hidden;}
.main-visual .swiper-slide {position:relative; height:clamp(200px, calc(500 / var(--inner) * 100vw), 500px); overflow:hidden;}
.main-visual .swiper-slide img {position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.15);}
.main-visual .caption {position:absolute; top:50%; left:0; padding:0 var(--space-container); width:100%; -webkit-transform:translate(0,-50%); transform:translate(0,-50%); color:#fff; text-align:center; z-index:40;}
.main-visual .caption img {margin:0 auto;}
.main-visual .caption p {transform:translate(0,20px); opacity:0; transition:.8s;}
.main-visual .caption .txt1 {font-size:clamp(16px, calc(40 / var(--inner) * 100vw), 40px); font-weight:700; line-height:1.3em;}
.main-visual .m-slide-btn {border:0; background:transparent; opacity:.3;}
.main-visual .m-slide-btn:hover {opacity:1;}
.main-visual .swiper-pagination {display:flex; justify-content:center; align-items:center; gap:var(--space-20); position:absolute; bottom:var(--space-40); left:0; width:100%; text-align:center; line-height:0; z-index:50;}
.main-visual .swiper-pagination .swiper-pagination-bullet {position:relative; display:block; width:10px; height:10px; margin:0; background:transparent; border:2px solid #fff; border-radius:50%; overflow:hidden; text-indent:-9999em; transition:.2s; opacity:0.5;}
.main-visual .swiper-pagination .swiper-pagination-bullet-active {background:#fff; opacity:1;}
.main-visual .swiper-slide-active img {animation:mv_image 5s forwards;}
.main-visual .swiper-slide-active .caption .txt1 {animation:mv_text 1.2s .4s forwards;}

@keyframes mv_image {
	0% {transform:scale(1.15);}
	100% {transform:scale(1);}
}
@keyframes mv_text {
	0% {transform:translate(0,20px); opacity:0;}
	100% {transform:translate(0,0); opacity:1;}
}

.main-series {position:relative; overflow:hidden; padding:var(--space-150) 0;}
.main-series .swiper {overflow:visible;}
.main-series .swiper-slide {opacity:.5; transition:.4s;}
.main-series .swiper-slide-active {opacity:1;}
.main-series .wrap {display:flex; justify-content:space-between; width:100%; height:500px; gap:var(--space-40); padding:var(--space-80); background:#f2f2f2;}
.main-series .cnt-area {display:flex; flex-direction:column; justify-content:space-between; gap:var(--space-40);}
.main-series .cnt-area .sub-txt {font-size:var(--font-size-16); font-weight:400; line-height:1.625em; color:#454545; margin-bottom:var(--space-20);}
.main-series .cnt-area h2 {margin-bottom:var(--space-40); font-size:var(--font-size-40); font-weight:700; line-height:1.2em; color:#242424;}
.main-series .cnt-area .desc {display:flex; gap:clamp(20px, calc(36 / var(--inner) * 100vw), 36px);}
.main-series .cnt-area .desc dl {display:flex; flex-direction:column; gap:4px;}
.main-series .cnt-area .desc dt {font-size:var(--font-size-20); font-weight:700; line-height:1.4em; color:#242424;}
.main-series .cnt-area .desc dd {font-size:var(--font-size-16); font-weight:400; line-height:1.4em; color:#454545;}
.main-series .img-area {display:flex; align-items:center; gap:var(--space-30);}
.main-series .img-area .img {position:relative;}
.main-series .img-area .img.multiply img {mix-blend-mode:multiply;}

.main-product {position:relative; overflow:hidden; padding-bottom:var(--space-130);}
.main-product h2 {margin-bottom:var(--space-40); text-align:center; font-size:var(--font-size-40); line-height:1.3em;}
.main-product .slider {position:relative;}
.main-product .link-item {display:block; text-align:center;}
.main-product .link-item .thumb {position:relative; margin-bottom:var(--space-16); overflow:hidden;}
.main-product .link-item .thumb img {width:100%; height:100%; object-fit:cover; transition:.4s;}
.main-product .link-item .thumb:after {content:""; position:absolute; inset:0; width:100%; height:100%; background:rgba(2, 55, 0, 0.60) url('/images/main/plus.svg') 50% 50% no-repeat; opacity:0; transition:opacity .2s;}
.main-product .link-item:hover .thumb img {transform:scale(1.1);}
.main-product .link-item:hover .thumb:after {opacity:1;}
.main-product .link-item .tit {font-size:var(--font-size-24); font-weight:700; line-height:1.3em;}

.main-comm {overflow:hidden; padding:var(--space-150) 0; background:url('/images/main/comm-bg.jpg') no-repeat center center / cover;}
.main-comm .contain {display:flex; gap:var(--space-40);}

.post-zone {width:789px; padding:var(--space-40); background:#fff;}
.post-zone .inner {position:relative;}
.post-zone .tab {margin-bottom:var(--space-30); padding:3px 0;}
.post-zone .tab ul {display:flex;}
.post-zone .tab ul li {display:flex; align-items:center;}
.post-zone .tab ul li:before {content:""; display:block; margin:0 var(--space-30); width:1px; height:var(--space-20); background:#ddd;}
.post-zone .tab ul li:first-child:before {display:none;}
.post-zone .tab ul li a {display:block; font-size:var(--font-size-28); line-height:1.5em; color:#999;}
.post-zone .tab ul li.active a {color:#242424; font-weight:700;}
.post-zone .list {border-top:2px solid #aaa;}
.post-zone .list ul li {height:87px; padding:0 var(--space-20); border-bottom:1px solid #d1d1d1;}
.post-zone .list ul li a {display:flex; align-items:center; width:100%; height:100%; gap:var(--space-20); font-size:var(--font-size-18); line-height:1.5em; color:#242424;}
.post-zone .list ul li a:hover .txt {color:var(--color-primary);}
.post-zone .list ul li .txt {flex:1 1 auto; min-width:0; width:1%; font-size:var(--font-size-18); font-weight:500; line-height:1.5em; color:#242424; height:1.5em; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; word-break:break-all; display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; transition:.2s;}
.post-zone .list ul li .date {font-size:var(--font-size-15); line-height:1.5em; color:#BCBCBC;}
.post-zone .more {position:absolute; top:0; right:0; width:clamp(38px, calc(48 / var(--inner) * 100vw), 48px); aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid rgba(221, 221, 221, 0.30); border-radius:50%; transition:.2s; color:#999;}
.post-zone .more:hover {background:var(--color-primary); border-color:var(--color-primary); color:#fff;}

.inquiry-zone {width:571px; min-height:clamp(180px, calc(496 / var(--inner) * 100vw), 496px); background:url('/images/main/inquiry.jpg') no-repeat center center / cover; text-align:center; color:#fff;}
.inquiry-zone .inner {display:flex; flex-direction:column; align-items:center; justify-content:center; gap:var(--space-60); width:100%; height:100%; padding:var(--space-40);}
.inquiry-zone .title {display:flex; flex-direction:column; gap:var(--space-10);}
.inquiry-zone .title h2 {font-size:var(--font-size-40); line-height:1.3em;}
.inquiry-zone .title p {font-size:var(--font-size-18); line-height:1.5em; color:#ddd;}
.inquiry-zone .btn {text-align:center;}
.inquiry-zone .m-more {color:#fff; border-color:#fff;}
.inquiry-zone .m-more:hover {background:var(--color-primary); border-color:var(--color-primary); color:#fff;}

/* sub */
.sub-visual {position:relative; display:flex; flex-direction:column; background:#eee; height:clamp(220px, calc(300 / var(--inner) * 100vw), 300px); overflow:hidden;}
.sub-visual .bg {position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.05); transition:1.5s;}
.sub-visual .title {position:relative; flex:1 1 auto; min-height:0; height:1%; display:flex; align-items:center;}
.sub-visual .title .contain {width:100%;}
.sub-visual .title h2 {font-size:clamp(28px, calc(60 / var(--inner) * 100vw), 60px); font-weight:700; line-height:1.3em; color:#fff; text-align:center;}
.sub-visual.loaded .bg {transform:scale(1);}

.lnb {position:relative; z-index:2; width:100%; border-top:1px solid #555; background:rgba(0, 0, 0, 0.40); backdrop-filter: blur(4px);}
.lnb .swiper {max-width:1200px; margin:-1px auto 0;}
.lnb ul li {flex:1; text-align:center;}
.lnb ul li a {position:relative; display:flex; flex-direction:column; justify-content:center; align-items:center; width:100%; height:var(--lnb-height); padding:0 clamp(10px, calc(15 / 768 * 100vw), 15px); color:#fff; font-size:var(--font-size-20); font-weight:500; line-height:1.2em; letter-spacing:-.03em;}
.lnb ul li.active a:before {content:""; position:absolute; top:0; left:0; width:100%; height:2px; background:#fff;}

#contArea {max-width:1260px; padding:0 var(--space-container); margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}

.sub-title {padding:var(--space-80) 0 var(--space-40); text-align:center;}
.sub-title h1 {font-size:var(--font-size-40); line-height:1.3em; color:#242424;}

.real-cont {min-height:300px; padding-bottom:var(--space-150);}


/* footer */
#footer {background:#111; color:#aaa;}
#footer .contain {max-width:1460px;}

.footer-links {border-bottom:1px solid rgba(98, 98, 98, 0.50); padding:clamp(18px, calc(38 / var(--inner) * 100vw), 38px) 0;}
.footer-links .contain {display:flex; justify-content:space-between; align-items:center; gap:var(--space-20);}

.foot-links {display:flex; flex-wrap:wrap; gap:10px; font-size:var(--font-size-18); line-height:1.3em;}
.foot-links .bar {color:#999;}
.foot-links a {font-weight:700;}
.foot-links a:hover {text-decoration: underline;}

.familysite {position:relative; display:inline-block; width:160px;}
.familysite .toggle-button {display:flex; justify-content:space-between; align-items:center; width:100%; padding:8px 15px; background:none; border:1px solid #838383; color:#fff; font-weight:400; line-height:1.5em; text-align:left;}
.familysite .toggle-button .chevron {width:12px;}
.familysite .toggle-button svg {display:block; width:100%; height:auto;}
.familysite .toggle-button path {fill:#838383;}
.familysite .toggle-layer {display:none; position:absolute; left:0; width:100%; background:#111; border:1px solid #838383; border-top:0;}
.familysite .toggle-layer ul li:not(:last-child) {border-bottom:1px dotted #111;}
.familysite .toggle-layer a {display:block; padding:8px 15px; color:#aaa; font-weight:400; line-height:1.5em;}
.familysite .toggle-layer a:hover {background:var(--color-primary); color:#fff;}
.familysite.active .toggle-button .chevron {transform:scaleY(-1);}

.footer-info {padding:var(--space-40) 0; font-size:var(--font-size-18); line-height:1.5em;}

.foot-company .item {display:inline-block; margin:7px 0;}
.foot-company .bar {color:#999; margin:0 10px;}
.foot-company .mgr {margin-right:6px;}

.foot-copy {margin-top:var(--space-30); font-weight:300; font-size:var(--font-size-15); line-height:1.3em;}
.foot-copy span {display:inline-block;}
.foot-copy .bar {color:#555;}
.foot-copy .designed {color:#555;}





