@charset "utf-8";

.body-main #skip-nav::before { z-index: 9999; position: fixed; inset: 0; background-color: #fff; clip-path: polygon(100% 50%, 0 50%, 0 0, 100% 0, 100% 50%, 100% 100%, 0 100%, 0 50%, 100% 50%); content: ''; animation: intro 1.1s cubic-bezier(0, 0, 0.18, 0.98) .2s both; pointer-events: none;}
@keyframes intro { to { visibility: hidden;clip-path: polygon(100% 0%, 0 0%, 0 0, 100% 0, 100% 50%, 100% 100%, 0 100%, 0 100%, 100% 100%);} }
/* ===================================================== */
/* MAIN-COMMON */
.body-main {--main-right-padding: max(calc(var(--outer-padding) + var(--right-deco) * 1.1), var(--inner-padding)); --main-title: 64px; }
.section {background: no-repeat center/cover; }
.section em {font-weight: 800;}
.sec-tit { font-weight: 200;font-size: var(--main-title);}
.sec-slogan { position: absolute; right: calc(var(--outer-padding) + calc(var(--right-deco) * 0.55)); bottom: 2vh; font-weight: 700; font-size: 20px; font-family: var(--font-montserrat); letter-spacing: calc(0.2em + 0.65vh);color: #fff; text-transform: uppercase; white-space: nowrap; writing-mode: vertical-rl; }

@media (max-width: 1280px) {
  .body-main {--main-title: 5vw;}
  .sec-slogan {font-size: 16px; }
}
@media (max-width: 1024px) {
  .sec-slogan {display: none;}
}
@media (max-width: 768px) {
  .body-main {--main-title: calc(26px + 2.6vw);}
}
/* MAIN-COMMON */
/* ===================================================== */


/* ===================================================== */
/* MAIN-VISUAL */
.visual { overflow: hidden; position: relative; font-size: 1rem; color: #fff; }
.visual-slide {height: 100vh; height: 100svh; min-height: 60rem; }
.visual-img { display: block; height: 100%; background: #222 var(--bg) no-repeat center/cover; transform: scale(1.1); transition: 4s linear;} 
.visual-01 {--bg: url(../images/main/main_visual01.jpg); --pls: 0.48em; }
.visual-02 {--bg: url(../images/main/main_visual02.jpg); --pls: 0;}
.visual-03 {--bg: url(../images/main/main_visual03.jpg); --pls: 0.24em; }
.visual-on .visual-img { transform: scale(1.01); } 

/* 비주얼 텍스트 */
.visual-txt { display: grid; grid-template-rows: 50%;position: absolute; inset: 0; padding: 0 var(--outer-padding); font-weight: 200; font-weight: 800; text-align: center;}
.visual-tit { overflow: hidden; align-self: end; justify-self: center;}
.visual-tit h3 { margin-bottom: calc(1vh + 1rem); font-size: 10em; letter-spacing: normal;}
.visual-tit h3 u {font-weight: 200;}
.visual-desc { overflow: hidden; }
.visual-desc p { padding-top: calc(1.4vh + 1.4rem); font-size: 3.7em; line-height: 1.2; letter-spacing: var(--pls);text-indent: calc(var(--pls) / 2);}
.visual-02 .visual-tit h3 {font-size: 7.5em;}
.visual-02 .visual-desc p { padding-top: calc(1.25vh + 1.25rem);font-size: 7.5em;}
.visual-02 .visual-desc .txt-rect b {background-color: #fff; color: var(--color-main);}
.visual-03 .visual-tit .txt-rect { font-weight: 600;font-family: var(--font-pretendard);}

.visual-on .visual-tit h3 { animation: fade-up .65s ease-out 1.1s both;}
.visual-on .visual-desc p {animation: fade-down 0.7s ease-out both 1.3s;}

/* 슬라이드 페이저, 화살표 */
.visual-nav { z-index: 1; position: absolute; top: 50%; left: var(--outer-padding); width: calc(100% - var(--outer-padding) * 2); height: 1px; background: var(--color-white-a2) linear-gradient(#fff, #fff) no-repeat center/calc(60em + 20%) 100%;}
.visual-arrow-btn {position: absolute; top: calc(-1.35rem + 1px); }
.visual-arrow-btn::before { display: block; width: 4.7rem; height: 2.7rem; background: url(../images/common/arrow_w47.svg) no-repeat center/contain;content: ''; transition: .3s;}
.visual-arrow-prev {transform: scaleX(-1);}
.visual-arrow-next {right: 0;}

.visual-dot {position: absolute; top: calc(7em + 7vh); left: 50%; transform: translateX(-50%); animation: fade-in .6s linear 2s both;} 
.visual-dot button { display: flex; padding: calc(1.8vh + 0.6rem) 2rem; } 
.visual-dot button::before { opacity: 0.75; width: calc(10px + 1.5rem); height: max(3px, 0.4rem); margin: auto; background-color: var(--color-main); content: ''; transition: .3s; } 
.visual-dot li.slick-active button::before { opacity: 1; background-color: #fff; } 

/* 스크롤다운 */
.visual-scroll {position: absolute; bottom: calc(1vh + 1rem); left: 50%; text-align: center; transform: translateX(-50%);}
.visual-scroll-btn { display: grid; justify-items: center; row-gap: calc(0.2vh + 0.2rem); font-weight: 600; font-size: 12px; font-family: var(--font-montserrat); letter-spacing: 0.015em; animation: fade-down 0.9s ease-in-out 2.15s both;} 
.visual-scroll-btn::after {width: 25px; height: 28px; background: url(../images/main/scroll-down.svg) no-repeat center/contain; content: ''; animation: float 2s infinite ease-in-out alternate;}

@media (hover: hover) and (pointer: fine) {
  .visual-dot li:not(.slick-active) button:hover::before { opacity: 1; box-shadow: 0 0 1rem var(--color-main);} 
  .visual-arrow-btn:hover::before {transform: translateX(4px);}
}
@media (max-width: 1024px) {
  .visual {font-size: 0.88vw;}
  .visual-nav {background-size: calc(61em + 10%) 100% ;}
}
@media (max-width: 768px) {
  .visual {font-size: calc(0.6vw + 2px);}
  .visual-nav {background-size: 60em 100% ;}
}
@media (max-width: 480px) {
  .visual-nav {background-size: 0;}
  .visual-01 .visual-desc p { margin-bottom: calc(2vh + 2rem); font-size: 4.8em; letter-spacing: 0.2em;}
  .visual-scroll-btn {font-size: 11px;}
  .visual-scroll-btn::after {width: 20px; height: 23px;}
}
/* MAIN-VISUAL */
/* ===================================================== */


/* ===================================================== */
/* SECTION 2 : STORY */
.story {background-image: url(../images/main/story_bg.jpg); color: #fff;}
.story .sec-wrap {display: flex; justify-content: space-between; align-items: center; max-width: 1500px; margin: 0 calc(var(--outer-padding) + 7%) 0 var(--inner-padding);}
.fp-responsive .story {padding: 14rem 0 16rem;}

/* story-header */
.story .sec-header {flex-shrink: 0;}
.story .sec-tit {margin-bottom: calc(10px + 2rem);}
.story .sec-tit .txt-border {--color: var(--color-ice);}
.story .sec-desc { font-weight: 600;font-size: var(--font-23);}
.story .sec-desc .txt-bg {padding: 0.3em 0.4em; margin-bottom: calc(7px + 1.4rem); font-size: var(--font-20);}
.story .sec-desc mark { font-weight: 200; font-size: var(--main-title); line-height: 1.1;}
.story .sec-desc mark em {display: inline-block;}
.story .sec-desc u {display: block; padding-top: 0.5em;}

/* story-content */
.story-cont {flex-grow: 1; max-width: 1000px; container-type: inline-size;}
.story-list {display: grid; grid-template-areas: 
  " item1 deco1 item2 ..... "
  " ..... item3 deco2 item4"; padding: 7%; font-size: 1cqw;
}
.story-item { z-index: 10;position: relative; padding-top: 100%; transition-delay: calc(.5s + var(--adi));}
.story-item::before { position: absolute; border-radius: 4em; content: ''; transform: rotate(45deg); transition: border-radius .3s;}
.story-link::before { inset: -14%;background-color: #fff;}
.story-link-tit { display: grid; justify-items: center; align-content: center; row-gap: 2em;position: absolute; inset: 0; padding: var(--padding); text-align: center; transition: filter .3s;}
.story-link-tit::before { width: 8.7em; height: 7.5em; background: var(--ico) no-repeat center/contain;content: ''; }
.story-link-tit span { --lh: 2px; padding-top: 0.1em; background: linear-gradient(to bottom, var(--color-main) var(--lh), transparent var(--lh) calc(100% - var(--lh)), var(--color-main) calc(100% - var(--lh))) no-repeat left/0 100%; font-weight: 800; font-size: max(16px, 2.3em); line-height: 1.4; color: var(--color-main); transition: background-size .3s;}
.story-deco {pointer-events: none;}
.story-deco::before { inset: -7%; border: 3px solid var(--color);}

/* story-content grid-area, 변수 */
.story-item:nth-child(1) { --ico: url(../images/main/story_ico01.png); --padding: 0 15% 0 0; --adi: .6s;grid-area: item1;}
.story-item:nth-child(2) { --ico: url(../images/main/story_ico02.png); --padding: 0 0 0 15%; --adi: .3s;grid-area: item2;}
.story-item:nth-child(3) { --ico: url(../images/main/story_ico03.png); --padding: 30% 0 0 0; --adi: .4s;grid-area: item3;}
.story-item:nth-child(4) { --ico: url(../images/main/story_ico04.png); --adi: .1s;grid-area: item4;}
.story-item:nth-child(5) { --color: var(--color-main); --adi: .5s; z-index: 15;grid-area: deco1;}
.story-item:nth-child(6) { --color: var(--color-ice); --adi: .2s; z-index: 5;grid-area: deco2;}

@media (hover: hover) and (pointer: fine) {
  .story-link:hover .story-link-tit {filter: brightness(110%);}
  .story-link:hover .story-link-tit span {background-size: 100% 100%;}
}
@media (max-width: 1280px) {
  .story .sec-wrap {column-gap: 0;}
  .story-cont {margin-left: -3%;}
}
@media (max-width: 1024px) {
  .story .sec-wrap { margin-right: var(--inner-padding);}
  .story .sec-desc {font-size: 2.1vw;}
  .story .sec-desc .txt-bg {font-size: 1.8vw;}
  .story-list { padding-top: 14%;font-size: 1.2cqw;}
  .story-link::before {inset: -16%;}
  .story-deco::before { inset: -8%;border-width: 2px;}
}
@media (max-width: 768px) {
  .story .sec-wrap {flex-direction: column; row-gap: 8rem;}
  .story .sec-header {text-align: center;}
  .story .sec-tit .txt-border {margin: 0.2em auto 0;}
  .story .sec-desc {font-size: 20px;}
  .story .sec-desc .txt-bg {padding: 0.3em 0.5em; margin-bottom: 0.7em; font-size: inherit;}
  .story .sec-desc mark { font-size: inherit;}
  .story .sec-desc mark br {display: none;}
  .story .sec-desc u {display: inline; padding-top: 0;}
  .story-cont { width: 100%;margin-left: 0;}
  .story-list {padding: 8%;}
}
@media (max-width: 576px) {
  .story-cont {width: 80%;}
  .story-list { grid-template-areas: 
    " item1 ..... "
    " deco1 item2 "
    " item3 deco2 "
    " ..... item4 "; padding: 12%; font-size: 2.2cqw;
  }
  .story-link::before { inset: -14%;}
  .story-deco::before { inset: 0;}
  .story-link-tit {--padding: 0;}
  .story-item:nth-child(1) .story-link-tit { padding-bottom: 20%; }
  .story-item:nth-child(2) .story-link-tit { padding-left: 10%; }
  .story-item:nth-child(3) .story-link-tit { padding-top: 20%; }
  .story-item:nth-child(1) {--adi: .2s;}
  .story-item:nth-child(2) {--adi: .4s;}
  .story-item:nth-child(3) {--adi: .5s;}
  .story-item:nth-child(4) {--adi: .6s;}
  .story-item:nth-child(5) {--adi: .3s;}
  .story-item:nth-child(6) {--adi: .7s;}
}
@media (max-width: 480px) {
  .story-cont {width: 100%;}
  .story .sec-desc {font-size: 18px;}
}
/* SECTION 2 : STORY */
/* ===================================================== */


/* ===================================================== */
/* SECTION 3 : PRODUCT */
.product { overflow: hidden;background-image: url(../images/main/product_bg.jpg);}
.fp-responsive .product {padding: 14rem 0 16rem;}
.product .sec-wrap {--deco: 3px; --shd: 25px; display: grid; grid-template-columns: auto 50%; align-items: end; position: relative; padding-right: calc(var(--main-right-padding) + var(--shd)); padding-left: var(--inner-padding);}
.product .sec-wrap::before,
.product .sec-wrap::after { z-index: 5; position: absolute;content: '';  pointer-events: none;}
.product .sec-wrap::before { grid-column: 1 / 2; right: calc(var(--deco) * 60); width: calc(100% + var(--inner-padding) - calc(var(--deco) * 60)); padding-top: calc(var(--deco) * 6); border: solid var(--color-main); border-width: calc(var(--deco) * 6) 0;}
.product .sec-wrap::after {grid-column: 2 / 3; left: calc(var(--deco) * -60); width: 100%; height: calc(var(--deco) * 54); background: url(../images/common/symbol_optimized.svg) no-repeat left bottom/contain;}

/* 왼쪽 텍스트 */
.product .sec-header { padding-bottom: calc(var(--deco) * 18 + 4rem);}
.product-link { width: fit-content;margin-bottom: calc(3rem); animation: fade-up 1s .2s both paused;}
.product .aos-animate .product-link {animation-play-state: running;}
.product .sec-tit {--color: var(--color-main); margin-bottom: calc(4px + 2rem); color: var(--color-main);}
.product .sec-tit .txt-border {position: relative;}
.product .sec-tit .txt-border::before { position: absolute; top: 100%; left: calc(100% + var(--bw)); width: var(--bw); height: var(--bw); border-radius: 50%; background-color: var(--color-main);content: '';}
.product .sec-tit .txt-border i { display: flex;position: absolute; top: 100%; left: calc(100% + var(--bw) * 3); width: 3.25em; height: var(--bw); border-radius: var(--bw); background: var(--color-main); transition: width .2s;}
.product .sec-tit .txt-border i::before { position: absolute; top: 50%; right: calc(-1 * var(--bw)); width: 100%; height: 0.640625em; background: url(../images/common/chevron_h41.svg) no-repeat right/contain;content: ''; transform: translateY(-50%);}
.product .sec-desc { font-weight: 800;font-size: var(--font-20); color: #222;}

/* 왼쪽 슬라이드 페이지네이션 */
.product-nav { animation: fade-up 0.7s .4s both paused;}
.product .aos-animate .product-nav {animation-play-state: running;}
.product-nav button { opacity: 0.4; padding: 0.1em 0;font: 800 var(--main-title)/1 var(--font-montserrat); text-align: left; color: #666; transition: opacity .3s;}
.product-nav .slick-active button { opacity: 1;color: var(--color-blue);}

/* 오른쪽 슬라이드 */
.product .slick-area {position: relative; }
.product .slick-area::before { position: absolute; top: calc(var(--shd) * 2); width: calc(100% + var(--shd)); height: calc(100% - var(--shd)); border-radius: var(--shd) var(--shd) 0 var(--shd); background-color: var(--color-main);content: ''; }
.product .product-slick { overflow: hidden; border-radius: calc(var(--shd) * 2) calc(var(--shd) * 2) 0 0; background-color: #fff;box-shadow: 0 calc(var(--shd) * -1.6) calc(var(--shd) * 1.6) var(--color-black-a1);}

@media (hover: hover) and (pointer: fine) {
  .product-nav button:hover {opacity: 1;}
  .product-link:hover .sec-tit .txt-border i {width: 3.5em;}
}
@media (max-width: 1500px) {
  .product .sec-wrap {--deco: 2px;}
}
@media (max-width: 1280px) {
  .product .sec-wrap {--deco: 1px; --shd: 20px;}
}
@media (max-width: 1024px) {
  .product .sec-wrap {--shd: 2vw;}
  .product .sec-desc {font-size: var(--font-18);}
}
@media (max-width: 768px) {
  .product {background-image: linear-gradient(to top, var(--color-white-a4) 33%, transparent), url(../images/main/product_bg.jpg); }
  .product .sec-wrap { --deco: 2px; --shd: 3vw; grid-template-columns: 1fr 70%; padding-right: var(--inner-padding);}
  .product .sec-header { grid-column: 1 / 3; padding-bottom: 6rem; text-align: center;}
  .product-link { margin-right: auto;margin-left: auto; }
  .product .sec-tit .txt-border {margin: 0.2em auto 0;}
  .product .sec-tit .txt-border i {width: 1em;}
  .product .sec-desc {font-size: 20px;}
  .product-nav button { padding: 4px 0; font-size: calc(var(--main-title) * 0.7);}
  .product-nav .slick-active button { text-align: center;}
  .product .slick-area { grid-column: 2 / 3; grid-row: 2 / 3; margin-right: var(--shd);}
}
@media (hover: hover) and (pointer: fine) and (max-width: 768px) { 
  .product-link:hover .sec-tit .txt-border i {width: 1.25em;} 
}
@media (max-width: 576px) {
  .product .sec-wrap {--shd: calc(3vw + 6px);}
  .product::before { position: absolute; inset: 0; background-color: var(--color-white-a1); mask: url(../images/common/logo_long.svg) no-repeat bottom/contain; -webkit-mask: url(../images/common/logo_long.svg) no-repeat bottom/contain;content: '';}
  .product .sec-wrap::before,
  .product .sec-wrap::after {display: none;}
  .product .slick-area {grid-column: 1 / 3; width: 80%; justify-self: center;}
  .product .slick-area::before { left: var(--shd);width: 100%;}
  .product .product-slick { border-bottom-left-radius: var(--shd);}
}
@media (max-width: 480px) {
  .product .sec-desc {font-size: 18px;}
  .product .slick-area {width: calc(100% - var(--shd));}
}
/* SECTION 3 : PRODUCT */
/* ===================================================== */


/* ===================================================== */
/* SECTION 4 : LOCATION */
.location {background-image: url(../images/main/location_bg.jpg); color: #fff;}
.fp-responsive .location .sec-wrap {row-gap: calc(3.5rem + 3.5vw);}
.location .sec-wrap {display: grid; grid-template-areas: 
  "api text"
  "api link"; grid-template-columns: 50% 50%; justify-content: space-between; row-gap: calc(6vh + 3rem); height: 100%;
}
.location .txt-area { padding-right: var(--main-right-padding); padding-left: max(calc(15% - 75px), 3rem);}

/* 섹션 제목, 주소 목록 */
.location .sec-header {grid-area: text; align-self: end;}
.fp-responsive .location .sec-header {padding-top: 14rem;}
.location .sec-tit { margin-bottom: 3rem;line-height: 1.1;}
.location .sec-tit em {display: block;}
.location .addr-area { display: grid; row-gap: 5px; width: fit-content;font-size: var(--font-18);}
.location .addr-item {display: flex; overflow: hidden; border: 2px solid #fff; border-left: 0; cursor: pointer;}
.location .addr-tit { overflow: hidden; flex-shrink: 0; position: relative; min-width: 5.4em; padding: 0.4em; background-color: #fff;font-weight: 800; text-align: center; color: var(--color-main);}
.location .addr-tit::before { position: absolute; top: 50%; left: -1px; width: 0.5em; height: 1em; background-color: var(--color-main); clip-path: polygon(100% 50%, 0 0, 0 100%);content: ''; transform: translate(-100%, -50%); transition: transform .3s;}
.location .addr-value { padding: 0.4em 1em;font-weight: 700;}

/* 지도 API, 슬라이드 */
.location .api-area {grid-area: api; position: relative; padding-top: var(--header-height);}
.fp-responsive .location .api-area {padding-top: 0;}
.location .api-slick,
.location .api-area .slick-list { height: 100%;}
.location .api-area .slick-track {display: flex; height: 100%;}

/* 하단 링크 (회사소개, 새로운 소식) */
.location .link-area {grid-area: link; font-weight: 700; font-size: 10px;}
.fp-responsive .location .link-area {padding-bottom: 16rem;}
.location .link-area ul {display: flex; overflow: hidden; align-items: start;}
.location .link-area li { flex: 1;}
.location .link-area li a { display: flex; justify-content: center; align-items: center; column-gap: 12%; padding: 3.5em 1em;background-color: var(--color-blue); transition: color .2s, background-color .2s;}
.location .link-area li:nth-child(even) a {background-color: var(--color-mint);}
.location .link-area li a::before { flex-shrink: 0; width: 6.4em; height: 6.4em; background: url(../images/main/location_ico01.svg) no-repeat center/contain;content: '';}
.location .link-area li:nth-child(2) a::before {background-image: url(../images/main/location_ico02.svg);}
.location .link-area li a span {font-size: 2.5em;}

@media (hover: hover) and (pointer: fine) {
  .location .link-area li a:hover {background-color: #fff; color: var(--color-blue);}
  .location .link-area li:nth-child(even) a:hover {color: var(--color-mint);}
  .location .addr-item:hover .addr-tit::before {transform: translate(0, -50%);}
}
@media (max-width: 1280px) {
  .location .link-area {font-size: 0.7825vw;}
}
@media (max-width: 1024px) {
  .location .addr-area {font-size: 16px;}
  .location .link-area {font-size: 0.857vw;}
}
@media (max-width: 768px) {
  .location {background-image: url(../images/main/location_bg_mobile.jpg);}
  .location .sec-wrap { grid-template-areas: "text" "api" "link";grid-template-columns: 100%; }
  .fp-responsive .location .sec-wrap {row-gap: 5rem;}
  .location .txt-area { padding-right: var(--inner-padding);padding-left: var(--inner-padding);}
  .location .sec-tit {text-align: center;}
  .location .addr-area {margin: auto; font-size: 17px;}
  .location .api-area {height: calc(300px + 25vmin); margin-bottom: 3rem;}
  .location .link-area {font-size: calc(4px + 0.8vw);}
}
@media (max-width: 576px) {
  .location .addr-area {font-size: 16px;}
}
@media (max-width: 480px) {
  .location .addr-area {font-size: 15px;}
}
/* SECTION 4 : LOCATION */
/* ===================================================== */