@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@100..900&family=Play:wght@400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&display=swap');
@import url('https://cdn.jsdelivr.net/gh/moonspam/NanumSquare@2.0/nanumsquare.css');

html,body{height: 100%;}

html::-webkit-scrollbar, body::-webkit-scrollbar {
    width: 8px;
    height: 15%;
}

html::-webkit-scrollbar-track, body::-webkit-scrollbar-track {
    background: transparent;
}

html::-webkit-scrollbar-thumb, body::-webkit-scrollbar-thumb {
    background-color: #888;
    border-radius: 10px;
}

html::-webkit-scrollbar-button, body::-webkit-scrollbar-button {
    display: none;
}

.wrap{height: 100%;}
.color_wrap{height: 100%;}
.color_wrap::before{position: fixed;top: 0;left: 0;z-index: -2;;width: 100%;height: 140%;background-color: #f8f7f5;content: "";}
.color_wrap::after{position: fixed;top: 0;left: 0;z-index: -1;;width: 100%;height: 140%;background-color: #101010;transition: 0.5s;content: "";}
.color_wrap.black::after{left: 0;}
.color_wrap.white::after{left: -100%;}
.fit{padding: 0 15px;}
.inner{margin: 0 auto;position: relative;}
.in_14{max-width: 1400px;}
.in_16{max-width: 1600px;}
.in_17{max-width: 1700px;}
.in_18{max-width: 1800px;}
.h_max{height: 100%;}
/*ios swiper 깜빡임 문제*/
.swiper-slide {-webkit-backface-visibility: hidden;-webkit-transform: translate3d(0, 0, 0);}
@media all and (max-width:1600px){
    html{font-size: 14px;}
}
@media all and (max-width:1200px){
    html{font-size: 12px;}
}

/*mo*/
.mo{display: block;transition: 0.6s;transition-delay: 0.3s;}
.mo_up{transform: translate(0,110%);}
.mo_lef{transform: translate(-110%,0);}
.mo_fade{opacity: 0;}
.mo_delay1{transition-delay: 0.6s;}
.mo_delay2{transition-delay: 0.9s;}
.mo.active{transform:translate(0,0);opacity: 1;}

/*intro*/
.intro{overflow: hidden;position: fixed;top: 0;left: 0;z-index: 200;width: 100%;height: 100%;background-color: #f8f7f5;}
.intro.none{display: none;}
.intro_wrap{position: relative;width: 100%;height: 100%;}
.intro .intro_mo{position: absolute;top: 50%;left: -50%;width: 200%;transform: translate(0,-50%);}
.intro::after{position: fixed;top: 50%;left: 0;z-index: 10;width: 100%;height: 0;background-color: #101010;transition: 0.3s;transition-delay: 1.7s;content: "";transform: translate(0,-50%);}
.intro .intro_mo .line{position: absolute;z-index: 10;width: 100%;;height: 1px;background-color: #f8f7f5;transition: 0.2s;transition-timing-function: cubic-bezier( 1,1,1,1 );transition-delay: 1.2s;}
.intro .intro_mo .line span{display: block;width: 100%;height: 100%;}
.intro .intro_mo .line span::before{position: absolute;width: 0;height: 1px;background-color: #e1e1e1;transition: 0.8s;content: "";}
.intro .intro_mo .line.top{top: 0;left: 0;}
.intro .intro_mo .line.top span::before{bottom: 0;left: 25%;}
.intro .intro_mo .line.bot{right: 0;bottom: 0;}
.intro .intro_mo .line.bot span::before{top: 0;right: 25%;}
.intro .intro_txt{display: flex;align-items: center;justify-content: center;padding: 20px 0 30px;position: relative;text-align: center;white-space: nowrap;}
.intro .intro_txt p{display: inline-block;font-size: 7rem;font-weight: 600;color: #101010;transition: 0.6s;opacity: 0;}
.intro .intro_txt p i{font-style: normal;color: #f8f7f5;-webkit-text-stroke: 2px #101010;text-stroke: 2px #101010;-webkit-text-fill-color: #f8f7f5;text-fill-color: #fff; paint-order: stroke fill;}
.intro .intro_txt p.typing{opacity: 1;}
.intro.op_on::after{height: 100%;}
.intro.op_on .line{height: 50%;}
.intro.op_on .line span::before{width: 50%;}
.intro.op_on .intro_txt{animation: txtmove 2.8s;animation-timing-function: cubic-bezier( 1,1,1,1 );animation-fill-mode: forwards;}
.intro.op_on .intro_txt p{opacity: 1;}
@keyframes txtmove {
    0% {transform: translate(0,0);}
    99% {transform: translate(-50%,0);opacity: 1;}
    100% {opacity: 0;}
}
@media all and (max-width:1024px){
    .intro .intro_txt{padding: 10px 0 15px;}
    .intro .intro_txt p{font-size: 4rem;}
    .intro .intro_txt p i{-webkit-text-stroke: 1px #101010;text-stroke: 1px #101010;}
    @keyframes txtmove {
        0% {transform: translate(0,0);}
        99% {transform: translate(-100%,0);opacity: 1;}
        100% {opacity: 0;}
    }
}

/*cursor*/
.cursor{position: absolute;z-index: 100;width: 0;height: 0;pointer-events: none;user-select: none;transform: translate(-50% , -50%);}
.cursor span{display: block;position: relative;width: 100%;height: 100%;}
.cursor span em{display: block;display: flex;align-items: center;justify-content: center;width: 100%;height: 100%;}
.cursor .cir{position: absolute;top: 0;left: 0;width: 100%;height: 100%;stroke-dasharray: 490;stroke-dashoffset: 490;transform: rotate(-90deg);}
.cursor .arr{width: 0;height: 0;transform: rotate(-180deg);opacity: 0;}
.cursor.img_on{width: 140px;height: 140px;}
.cursor.img_on .cir{transition: all 0.6s;stroke-dashoffset: 0;}
.cursor.img_on .arr{width: 36px;height: 24px;transition: 0.3s;transition-delay: 0.3s;transform: rotate(0);opacity: 1;}
.cursor.txt_on{width: 60px;height: 60px;mix-blend-mode: difference;border-radius: 50%;}
.cursor.txt_on span{display: none;}
.color_wrap.black .cursor.txt_on{background-color: #fff;}
.color_wrap.white .cursor.txt_on{background-color: #fff;}
@media all and (max-width:1200px){
    .cursor{display: none;}
}

/*btn*/
.more_btn{position: absolute;right: 4%;bottom: 60px;z-index: 20;}
.more_btn a{display: flex;align-items: center;}
.more_btn a p{padding-right: 12px;font-family: 'Play';font-size: 0.875rem;font-weight: 600;transition: 0.3s;}
.more_btn a span{display: block;width: 28px;height: 28px;background: #d6232f url(../images/star.png) no-repeat center;border-radius: 50%;}
.more_btn a:hover p{transform: translate(-10px,0);}
.color_wrap.black .more_btn a p{color: #fff;}
.color_wrap.white .more_btn a p{color: #000;}
@media all and (max-width:1200px){
    .more_btn{right: 15px;bottom: 20px;}
}

/*cir_btn*/
.cir_btn{text-align: center;}
.cir_btn a{display: inline-block;padding: 50px 0;padding-right: 120px;position: relative;}
.cir_btn p{font-size: 2.25rem;font-weight: 600;line-height: 1.1em;transition: 0.3s;}
.cir_btn .magnetic{position: absolute;top: 0;right: 0;width: 100%;text-align: right;}
.cir_btn .cir{display: inline-block;position: relative;width: 140px;height: 140px;border-radius: 50%;}
.cir_btn .cir .arr{display: inline-block;position: absolute;top: 50%;left: 50%;width: 36px;height: 24px;background: no-repeat center;background-size: contain;transition: 0.3s;transform: translate(-50%,-50%);}
.cir_btn .cir svg{stroke-dasharray: 490;stroke-dashoffset: 490;transform: rotate(-90deg);}
.cir_btn a:hover p{transform: translate(-30px,0);}
.cir_btn a:hover .cir svg{transition: all 0.5s;stroke-dashoffset: 0;}
.color_wrap.black .cir_btn p{color: #fff;}
.color_wrap.black .cir_btn .cir{border: 1px solid rgba(255,255,255,0.2);}
.color_wrap.black .cir_btn .cir .arr{background-image: url(../images/wh-arr.png);}
.color_wrap.black .cir_btn a .cir svg{stroke:#fff;}
.color_wrap.white .cir_btn p{color: #101010;}
.color_wrap.white .cir_btn .cir{border: 1px solid rgba(32,32,32,0.2);}
.color_wrap.white .cir_btn a .cir svg{stroke:#101010;}
.color_wrap.white .cir_btn .cir .arr{background-image: url(../images/bl-arr.png);}
@media all and (max-width:1200px){
    .cir_btn a{padding: 30px 0;padding-right: 60px;}
    .cir_btn p{font-size: 1.5rem;}
    .cir_btn .cir{width: 80px;height: 80px;}
    .cir_btn .cir .arr{width: 24px;height: 12px;}
}

/*header*/
header{padding: 60px 70px 0;position: fixed;top: 0;left: 0;z-index: 100;width: 100%;transition: 0.8s;transform: translate(0,0);}
header .head_in{display: flex;align-items: center;justify-content: space-between;position: relative;}
header h1 a{display: block;width: 138px;height: 24px;background-repeat: no-repeat;background-position: center;background-size: contain;transition: 0.3s; position: relative;}
header h1 a span{position: absolute; display: block; font-size: 15px; font-weight: 400; color: #666; right: -114px; bottom:1px}

header ul{display: flex;padding-right: 25px;}
header ul li{padding: 0 25px;}
header ul li a{display: block;position: relative;font-family: 'Play';font-size: 0.875rem;font-weight: 700;transition: 0.3s;}
header ul li a::before{position: absolute;bottom: -6px;left: 50%;width: 0%;height: 2px;transition: 0.3s;content: "";}
header ul li a:hover::before{left: 0;width: 100%;}
header .color_btn{padding: 3px;width: 64px;height: 36px;transition: 0.3s;border-radius: 25px;}
header .color_btn button{display: block;border: none;;position: relative;width: 100%;height: 100%;background: transparent;}
header .color_btn button span{display: flex;align-items: center;justify-content: center;position: absolute;width: 28px;height: 28px;transition: 0.3s;border-radius: 50%;}
header .color_btn button span em{transition: 0.3s;}
header .color_btn button span .moon{background: url(../images/moon-bl.svg) no-repeat center;background-size: contain;}
header .color_btn button span .sun{background: url(../images/sun-wh.svg) no-repeat center;background-size: contain;}
header.hide{transform: translate(0,-100%);}
header.h_up{transition: 0.5s;transform: translate(0,-100%);}
header.h_down{transition: 0.5s;}
header .menu_btn{display: none;margin-top: -12px;border: none;position: absolute;top: 50%;right: 75px;height: 25px;background: none;transition: 0.5s;}
header .menu_btn span{display: block;margin: 0 0 0 auto;height: 2px;transition: 0.5s;}
header .menu_btn span:nth-child(1){width: 25px;}
header .menu_btn span:nth-child(2){margin-top: 5px;width: 15px;}
nav{padding: 0 15px;overflow-y: auto;position: fixed;top: 0;left: 100%;z-index: 90;width: 100%;height: 100%;transition: 0.6s;}
nav ul{padding-top: 20%;}
nav ul li{padding-bottom: 15%;}
nav ul li a{display: inline-block;position: relative;font-size: 3.25rem;font-weight: 600;}
nav ul li.on a{padding-bottom: 10px;}
nav ul li.on a::before{position: absolute;bottom: 0;left: 0;width: 100%;height: 4px;content: "";}
nav dl ~ dl{padding-top: 8%;}
nav dl dt{margin-bottom: 5px;font-family: 'Play';}
nav dl dd{font-weight: 300;line-height: 1.5em;}
nav dl dd em{font-family: 'Play';font-weight: 400;}
.nav_on header .color_btn{display: none;}
.nav_on .menu_btn{right: 0;}
.nav_on .menu_btn span:nth-child(1){transform: rotate(45deg);}
.nav_on .menu_btn span:nth-child(2){margin-top: -2px;width: 25px;transform: rotate(135deg);}
.nav_on nav{left: 0;}
.color_wrap.black header h1 a{background-image: url(../images/logo-wh.png);}
.color_wrap.black header ul li a{color: #fff;}
.color_wrap.black header ul li a::before{background-color: #fff;}
.color_wrap.black header .color_btn{border: 1px solid #fff;}
.color_wrap.black header .color_btn button span{top: 0;left: auto;left: 100%;background-color: #fff;transform: translate(-100% , 0);}
.color_wrap.black header .color_btn button span .moon{width: 14px;height: 14px;transition-delay: 0.2s;}
.color_wrap.black header .color_btn button span .sun{width: 0px;height: 0px;}
.color_wrap.black header .menu_btn span{background-color: #fff;}
.color_wrap.black nav{background-color: #101010;}
.color_wrap.black nav ul li a{color: #fff;}
.color_wrap.black nav ul li a::before{background-color: #fff;}
.color_wrap.black nav dl dt{color: #aaa;}
.color_wrap.black nav dl dd{color: #fff;}
.color_wrap.white header h1 a{background-image: url(../images/logo-bl.png);}
.color_wrap.white header ul li a{color: #101010;}
.color_wrap.white header ul li a::before{background-color: #101010;}
.color_wrap.white header .color_btn{border: 1px solid #101010;}
.color_wrap.white header .color_btn button span{top: 0;left: 0;background-color: #101010;}
.color_wrap.white header .color_btn button span .moon{width: 0px;height: 0px;}
.color_wrap.white header .color_btn button span .sun{width: 14px;height: 14px;transition-delay: 0.2s;}
.color_wrap.white header .menu_btn span{background-color: #101010;}
.color_wrap.white nav{background-color: #fff;}
.color_wrap.white nav ul li a{color: #101010;}
.color_wrap.white nav ul li a::before{background-color: #101010;}
.color_wrap.white nav dl dt{color: #666;}
.color_wrap.white nav dl dd{color: #101010;}
@media all and (max-width:1700px){
    header{padding: 30px 30px 0;}
}
@media all and (max-width:1200px){
    header{padding: 15px 15px 0;}
    header .head_in{height: 30px;}
    header h1 a{width: 92px;height: 16px;}
    header h1 a span{font-size: 11px; right: -85px; bottom: 0;}
    header ul{display: none;}
    header .color_btn{width: 55px;height: 30px;}
    header .color_btn button span{width: 22px;height: 22px;}
    header .menu_btn{display: block;}
    .color_wrap.black header .color_btn button span .moon,
    .color_wrap.white header .color_btn button span .sun{width: 12px;height: 12px;}
}

@media (max-width: 1200px) and (max-height: 860px) {
    nav ul {padding-top: 100px;}
    nav ul li {padding-bottom: 40px;}
    nav dl ~ dl{padding-top: 40px;}
}
.header_btn_wrap{display: flex; gap: 15px; align-items: center;}
.header_btn_wrap .inquire_btn{display: block; position: relative; width: 126px; height: 36px;}
.header_btn_wrap .inquire_btn a{display: block;padding-left: 32px;border: none; position: relative; z-index: 1;width: 100%; background: transparent;font-size: 14px;font-weight: 600;line-height: 36px;text-align: left; transition: .3s;box-sizing: border-box;border-radius: 18px;}
.header_btn_wrap .inquire_btn a::before{ display: block;position: absolute; top: 50%; left: 15px; width: 10px; height: 10px; background-size: contain; content: ''; transform: translateY(-50%);}
.header_btn_wrap .inquire_btn::after{position: absolute; top:0; left: 0; z-index: 0; width: 100%; height: 100%; transition: .3s; content: ""; border-radius: 18px;}
.color_wrap.black .header_btn_wrap .inquire_btn a{color: #101010;}
.color_wrap.black .header_btn_wrap .inquire_btn::after{background: #fff;}
.color_wrap.black .header_btn_wrap .inquire_btn a::before{background-image: url(../images/inquire-btn-icon.png);}
.color_wrap.white .header_btn_wrap .inquire_btn a{color: #fff;}
.color_wrap.white .header_btn_wrap .inquire_btn::after{background: #101010;}
.color_wrap.white .header_btn_wrap .inquire_btn a::before{background-image: url(../images/inquire-btn-icon-wh.png);}
.header_btn_wrap .badge{position: absolute; top: -8px; right:20px; z-index: 2; width: 36px; height: 16px; background-color: #d6232f; font-family: 'Play'; font-size: 10px; font-weight: 700; line-height: 16px; color: #fff;text-align: center; transition: .3s; border-radius: 8px; transform: none; opacity: 1;}
.header_btn_wrap .inquire_btn:hover a{color: #fff !important;}
.header_btn_wrap .inquire_btn:hover::after{background: #d6232f !important; transform: scale(1.15);}
.header_btn_wrap .inquire_btn:hover a::before{background-image: url(../images/inquire-btn-icon-wh.png) !important;}
.header_btn_wrap .inquire_btn:hover .badge{transform: translateY(-12px); opacity: 0;}

@media all and (max-width:1200px){ 
    .header_btn_wrap .inquire_btn{display: none;}
}

/*footer*/
footer{padding: 40px 20px 150px;}
footer .foot_wrap{display: flex;align-items: center;justify-content: space-between;}
footer .foot_info{display: flex;}
footer .foot_info li ~ li{margin-left: 80px;}
footer .foot_info em{font-family: 'Play';font-weight: 400;}
footer .foot_info span{display: block;margin-bottom: 25px;font-size: 0.875rem;letter-spacing: 0px;transition: 0.3s;}
footer .foot_info p{font-size: 0.875rem;font-weight: 300;line-height: 1.7em;letter-spacing: 0px;transition: 0.3s;}
footer address{font-family: 'Play';font-size: 0.75rem;font-weight: 400;letter-spacing: 0px;transition: 0.3s;}
.color_wrap.black footer .foot_info span{color: #aaa;}
.color_wrap.black footer .foot_info p{color: #fff;}
.color_wrap.black footer address{color: #555;}
.color_wrap.white footer .foot_info span{color: #666;}
.color_wrap.white footer .foot_info p{color: #101010;}
.color_wrap.white footer address{color: #aaa;}
@media all and (max-width:1200px){
    footer{padding: 40px 15px 80px;}
    footer .foot_wrap,
    footer .foot_info{display: block;}
    footer .foot_info li ~ li{margin-top: 30px;margin-left: 0;}
    footer .foot_info span{margin-bottom: 10px;}
    footer address{margin-top: 30px;}
}

/*메인페이지 - 상단 갤러리*/
.top_section{ margin: 0 auto;padding: 172px 0 0; max-width: 1780px;}
.top_section .item_wrap{display: grid; gap: 42px; grid-template-columns: repeat(2, 1fr);}
.top_section .item_box{transition: 1s; opacity: 0; }
.top_section .item_box.active{opacity: 1; transform: translateY(0);}
.top_section .item_img_wrap{display: block; padding-bottom: 66.85%; position: relative;width: 100%; height: 0; background: transparent;}
.top_section .item_img_wrap .bg{position: absolute; z-index: 0; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; max-height: 580px;}
.top_section .item_img_wrap .bg img{width: 100%; height: 100%; object-fit: cover; display: block;}
.top_section .item_img_wrap .over_bg{ overflow: hidden;position: absolute; top: 0; left: 0; z-index: 20; width: 100%; height: 100%; transition: 0.6s; opacity: 0;}
.top_section .item_img_wrap .over_bg .shadow{box-shadow: 0px 0px 100px 70px rgba(0, 0, 0, 0.7);position: absolute;top: 0;left: 0;z-index: 10;width: 100%;height: 0px;transition: 0.3s;}
.top_section .item_img_wrap .shadow .more_detail{ margin-top: 15px; margin-right: 15px; padding-right: 15px; position: relative;font-size: 0.8125em; font-weight: 500; line-height: 0.8125em; color: #fff; text-align: right; user-select: none;}
.top_section .item_img_wrap .shadow .more_detail::after{display: block; position: absolute; top: 0; right: 0; width: 10px; height: 10px; background: url(../images/more-img-arr.svg) no-repeat center; background-size: 9px 9px;content: "";}
.top_section .item_img_wrap .over_bg img{ position: absolute; top: 0; left: 0; z-index: 5;width: 100%; height: auto; animation: scroll 6s linear;}
.top_section .item_img_wrap:hover .over_bg{opacity: 1;}
.color_wrap.black .lef .item_title{color: #fff;}
.color_wrap.white .lef .item_title{color: #101010;}
.item_info_wrap{display: flex; justify-content: space-between; margin-top: 30px;}
.item_info_wrap .lef .item_title{font-family: 'Play' ; font-size: 1.125em; font-weight: 400; line-height: 1.3em; margin-bottom: 8px;}
.item_info_wrap .lef .item_detail{display: flex; gap: 5px; flex-wrap: wrap; flex-wrap: wrap; font-size: 0.875em; }

/* 버튼 */
.item_info_wrap .lef .item_detail span{display: block; padding: 0 10px; border-radius: 1em; border: 1px solid #5c5b59; color:#5c5b59; height: 2em; line-height: 1.8em; }
.item_info_wrap .lef .btn-wrap{display: flex; margin-bottom: 55px; align-items: center; gap: 10px;}
.item_info_wrap .lef .tag_btn_wrap{display:flex; gap: 5px;}
.item_info_wrap .lef .tag_btn{display: flex; flex-wrap: wrap; font-size: 0.875em;}
.item_info_wrap .lef .btn-wrap span{display: block; width: auto; padding: 0 6px; border-radius: 0.875em; border: 1px solid #5c5b59; color:#5c5b59; height: 1.75em; line-height: 1.5em; }

.item_info_wrap .rig{position: relative;}
.item_info_wrap .item_btn{ border: none;width: 100px; height: 44px; font-size: 0.875em; font-weight: 500; line-height: 42px; border-radius: 22px; box-sizing: border-box;}
.item_info_wrap .item_btn span{display:block; transform: translateY(-1px);}
.item_info_wrap .item_btn{border: none; box-sizing: border-box;}
.color_wrap.black .rig .item_btn{ background: #fff;color: #101010;}
.color_wrap.white .rig .item_btn{ background: #101010;color: #fff;}
.item_info_wrap .rig .item_btn:hover{background: #d6232f; color: #fff;}
.color_wrap.black .item_detail{color: #bbb;}
.color_wrap.white .item_detail{color: #555;}
.item_rig_hover{border: 1px solid #fff;box-shadow: 0px 0px 40px 0px rgba(0, 0, 0, 0.4);position: absolute;top: -160px;left: 50%;z-index: 45;width: 140px;height: 140px;transition: .6s;transform: translateX(-50%);border-radius: 50%;opacity: 0;}
.item_rig_hover.active{opacity: 1;}
.item_rig_hover .txt_wrap{ display: flex; align-items: center; justify-content: center; flex-direction: column;position: relative; width: 100%; height: 100%; text-align: center; text-align: center;}
.item_rig_hover .txt_wrap p{ margin-bottom: 15px; z-index: 5;font-size: 0.875em; font-weight: 500; line-height: 1.2em; color: #101010; letter-spacing: -0.05em;}
.item_rig_hover .txt_wrap::before,
.item_rig_hover .txt_wrap::after{ position: absolute;content: ""; }
.item_rig_hover .txt_wrap::before{bottom: 0; left: 0; z-index: 0; width: 100%; height: 100%; background: #fff no-repeat center; background-size: cover; opacity: 0.85; border-radius: 50%;
-webkit-backdrop-filter: blur(10px);backdrop-filter: blur(10px);}
.item_rig_hover .txt_wrap::after{ position: absolute; bottom:20px; width: 100%; height: 22px; background: url(../images/more-btn-arr.svg) no-repeat center; background-size: contain;}
.item_rig_hover.active .txt_wrap::after{animation: scroll 1.3s linear infinite;}
.item_rig_hover .feather-box { overflow: hidden;position: relative; position: absolute; top: -24px; left: 0; width: 100%; height: 60px; background-color: transparent; -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 35%, rgba(0, 0, 0, 1) 75%, rgba(0, 0, 0, 0) 100%); mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 35%, rgba(0, 0, 0, 1) 75%, rgba(0, 0, 0, 0) 100%);}
.feather-box .icon{ position: absolute; top: -100%;width: 18px; height: 18px;}
.item_rig_hover.active .feather-box .icon{animation: more-icon 4.5s cubic-bezier(0.215, 0.610, 0.9, 1) infinite;}
.item_rig_hover.active .feather-box .icon01{left: 10px;}
.item_rig_hover.active .feather-box .icon02{left: 50px; animation-delay: .6s;}
.item_rig_hover.active .feather-box .icon03{left: 80px; animation-delay: .2s;}
.item_rig_hover.active .feather-box .icon04{left: 110px; animation-delay: .8s;}
.item_rig_hover.active .feather-box .icon05{left: 0px; animation-delay: 3s;}
.item_rig_hover.active .feather-box .icon06{left: 30px; animation-delay: 2.8s;}
.item_rig_hover.active .feather-box .icon07{left: 80px; animation-delay: 2s;}
.item_rig_hover.active .feather-box .icon08{left: 110px; animation-delay: 2.4s;}

.item_img_wrap.__m{display: none;}

/* 뱃지 */
.top_section .item_img_wrap .badge{ overflow: hidden;position: absolute; top: 0; left: 40px; z-index: 30; width: 62px; height: 94px; background-repeat: no-repeat; background-position: center; background-size: cover; text-indent: -9999px;} 
.top_section .item_img_wrap .badge.grand{background-image: url(../images/badge-grand.jpg);} 
.top_section .item_img_wrap .badge.winner{background-image: url(../images/badge-winner.jpg);} 
.top_section .item_img_wrap .badge.bronze{background-image: url(../images/badge-bronze.jpg);} 

@keyframes more-icon{
    0% {top: 100%;}
    75% {opacity: 1;}
    90% {opacity: 0;}
    100% {top: -100%; opacity: 0;}
}
@keyframes scroll{
    0% {transform: translateY(0);}
    50% {transform: translateY(10px);}
    100% {transform: translateY(0);}
}


@media all and (min-width: 1701px){
    .top_section .item_box:nth-child(even).active{transition-delay: 0.3s;}
}

@media all and (max-width: 1780px){
    .top_section .item_wrap{padding: 0 30px;}
    .bot_section .item_wrap{padding: 0 30px;}
}

@media all and (min-width: 1201px){
    .__m{display: none !important;}
}

@media all and (max-width: 1200px){
    .item_info_wrap .rig .item_btn{width: 80px; height: 36px; font-size: 12px;line-height: 30px; border-radius: 18px;}
    .item_info_wrap .lef .item_title{ margin-bottom: 8px;font-size: 16px; font-weight: 400; line-height: 1.3em;}
    .top_section{padding: 70px 0;}
    .top_section .item_wrap{padding: 0 15px;}
    .item_rig_hover{display: none;}
    .top_section .item_img_wrap .badge{left: 15px; z-index: 30; width: 31px; height: 47px;} 
    .__p{display: none !important;}
}
@media all and (max-width: 768px){
    .vis{overflow: hidden;}
    .item_info_wrap{margin-top: 20px;}
    .item_info_wrap .rig .item_btn{width: 80px; height: 36px; font-size: 12px;line-height: 36px; border-radius: 18px;}
    .top_section{padding: 70px 0;}
    .top_section .item_wrap{grid-template-columns: 1fr;}
    .item_rig_hover{display: none;}
}

/* 메인페이지 - 중간 섹션 */
.mid_section{ margin: 0 auto;padding: 140px 0 160px; max-width: 1780px; font-family: 'Play'; text-align: center;}
.mid_section .title{ margin-bottom: 20px;font-size: 1.25rem; font-weight: 700;}
.mid_section .detail{ font-family: 0.75em;}
.color_wrap.black .mid_section .title{color: #fff;}
.color_wrap.white .mid_section .title{color: #101010;}
.mid_section .title{ transition: .6s;transform: translateX(50px);  opacity: 0;}
.mid_section .detail{ transition: .6s;transform: translateX(-50px); opacity: 0;}
.mid_section.active .title,
.mid_section.active .detail{transform: none; opacity: 1;}


/* 메인페이지 - 하단 갤러리 */
.bot_section{ margin: 0 auto; padding: 0 0 140px; max-width: 1780px;}
.bot_section .item_wrap{display: grid; gap: 42px; grid-template-columns: repeat(3, 1fr);}

.bot_section .item_box{transition: 1s; opacity: 0; max-width: 565px;}
.bot_section .item_box:nth-child(3n+2) {transition-delay: .3s;}
.bot_section .item_box:nth-child(3n){transition-delay: .6s;}
.bot_section .item_box.active{opacity: 1; transform: translateY(0);}

@media (max-width:1200px){
    .bot_section .item_box{transition: 1s; opacity: 0; }
    .bot_section .item_box{transition-delay: 0s !important;}
}

/* 이미지 썸네일 */
.bot_section .item_img_wrap{ display: block; padding-bottom: 66.85%;position: relative; width: 100%; height: 0;}
.item_img_wrap .img_box{display: block; overflow: hidden; position: absolute; width: 100%; height: 100%; max-height: 378px; background: #363636; transition: .4s;}
.item_img_wrap .img_box img{width: 100%; height: 100%; object-fit: cover;}
.link_box .bg{position: absolute; top: 0; left: 0; z-index: 0; width: 100%; height: 100%; background-color: #fff; opacity: 0.9;}
.link_box .link_info{position: relative; z-index: 5;}
.img_box .link_box .title{ margin-bottom: 15px;font-size: 2.25em; font-weight: 600; line-height: 1.25; color: #101010; letter-spacing: -0.025em;
}
.img_box .link_box .detail{ margin-bottom: 40px;font-size: 0.875em; line-height: 1.5; color: #666; letter-spacing: -0.025em;}
.img_box .link_box .btn_wrap{display: flex; gap: 38px; justify-content: center; font-size: 1.063rem; color: #101010; letter-spacing: -0.05em;}
.img_box .link_box .btn_wrap button, 
.img_box .link_box .btn_wrap a {border:none; background: transparent; line-height: 1.5;}
.bot_section .item_info_wrap .rig{display: none;}
.color_wrap.black .rig .site-btn{ background: #fff;color: #101010;}
.color_wrap.white .rig .site-btn{ background: #101010;color: #fff;}
.color_wrap.black .link_box .btn_wrap button,
.color_wrap.black .link_box .btn_wrap a{border-bottom: 1px solid #101010; color: #101010;}
.color_wrap.white .link_box .btn_wrap button,
.color_wrap.white .link_box .btn_wrap a{border-bottom: 1px solid #fff; color: #fff;}

@media (min-width: 1201px){
    .img_box .link_box{
        display: flex; align-items: center; justify-content: center; position: absolute; top: 0; left: 0; z-index: 10; width: 100%; height: 100%; text-align: center; transition: .4s; opacity: 0;
    }
    .img_box:hover .link_box{opacity: 1;}
}

@media (max-width: 1200px){
    .mid_section{padding: 0px 0 70px;}
    .bot_section .item_wrap{display: grid; gap: 20px; margin: 0 auto; padding: 0 15px; grid-template-columns: repeat(3, 1fr);}
    .bot_section .img_box{border-radius: 0 !important;}
    .img_box .link_box{display: none;}
    /* .item_info_wrap .lef .item_detail{margin-bottom: 20px;} */
    .item_info_wrap .lef .btn-wrap{margin-bottom: 20px; gap: 8px;}
    .bot_section .item_info_wrap {flex-direction: column;}
    .bot_section .item_info_wrap .rig{display: flex; flex-shrink: 0;}
    .bot_section .item_info_wrap .rig .btn-wrap{display: flex; gap: 10px; flex-shrink: 0; margin-bottom: 20px;}
    .bot_section .item_info_wrap .rig .btn-wrap button,
    .bot_section .item_info_wrap .rig .btn-wrap a{ display: block; border: none;width: 80px; height: 36px; font-size: 12px; font-weight: 500; line-height: 34px; transition: .4s; border-radius: 18px;box-sizing: border-box;}
    .bot_section .item_info_wrap .rig .btn-wrap a{text-align: center;}
    .color_wrap.black .rig .btn-wrap button{ background: #fff;color: #101010;}
    .color_wrap.white .rig .btn-wrap button{ background: #101010;color: #fff;}
}

@media (max-width: 600px){
    .bot_section .item_wrap{grid-template-columns: repeat(1, 1fr);}
    .bot_section .item_info_wrap {flex-direction: row;}
}

/* 메인페이지 더 보기 */
.learn_more_section{margin: 50px auto 200px; color: #fff; text-align: center;}
.learn_more_section .top-txt{ display: block; margin-bottom: 40px; overflow: hidden; width: 100%;font-family: 'Play'; font-size: 1.25rem; font-weight: 700;}
.learn_more_section .bot-txt{ display: flex; align-items: center; justify-content: center;font-size: 2.5rem; font-weight: 700;letter-spacing: -0.025em; cursor: pointer;}
.learn_more_section .bot-txt .arr.__m{display: none;}
.learn_more_section .bot-txt .arr {display: flex; align-items: center; justify-content: center; position: relative; width: 40px; height: 40px; transition: 0.3s; transform: none;}
.learn_more_section .bot-txt .arr .icon{ display: block;width: 36px; height: 24px;}
.learn_more_section .bot-txt .arr .circle{position: absolute; top: 50%; left: 50%; transition: .6s; transform: translate(-50%, -50%); opacity: .2;}
.learn_more_section .bot-txt .arr .circle2{opacity: 1; transform: translate(-50%, -50%) rotate(-90deg);}
.circle_line{stroke-dasharray: 490; stroke-dashoffset: 490;}
.learn_more_section.active:hover .circle_line.line2{animation: draw .4s linear forwards;}
.learn_more_section .top-txt span{ transition-property: opacity, transform; transition-duration: 0.6s;opacity: 0; transform: translateX(40px);}
.learn_more_section .bot-txt p{ display: block; overflow: hidden; position: relative;width: 0; height: 40px; transition-property: width, opacity, transform; transition-duration: 0.6s;}
.learn_more_section .bot-txt .lef span{ display: block; position: absolute; top: 0; right: 0; width: 346px; height: 100%; transition-property: opacity, transform; transition-duration: 0.6s;opacity: 0;}
.learn_more_section .bot-txt{gap: 0;}
.learn_more_section  .arr .icon{ transition-property: opacity, transform; transition-duration: 0.6s; opacity: 0; transform: rotate(-180deg);}
.learn_more_section.active .bot-txt{gap: 30px;}
.learn_more_section.active .top-txt span{opacity: 1; transform: translateX(0);}
.learn_more_section.active .bot-txt p{width: 346px;}
.learn_more_section.active .bot-txt .lef span{opacity: 1;}
.learn_more_section.active .arr{transform: translateX(0);}
.learn_more_section.active .arr .icon{opacity: 1; transform: none;}
.learn_more_section.active .circle_line:not(.line2){animation: draw .4s linear forwards;}
.learn_more_section.active:hover .bot-txt .arr{transform: translateX(30px);}

.color_wrap.white .learn_more_section span{color: #101010;}
.color_wrap.white .learn_more_section.active .circle_line{stroke: #101010;}
.color_wrap.black .learn_more_section .icon{background: url(../images/learnmore-btn-arr.svg) no-repeat center; background-size: contain;}
.color_wrap.white .learn_more_section .icon{background: url(../images/learnmore-btn-arr-b.svg) no-repeat center; background-size: contain;}

@keyframes draw {
    to {
        stroke-dashoffset: 0;
        
    }
}

@media (max-width: 1200px) {
    .learn_more_section .top-txt{margin-bottom: 15px;}
    .learn_more_section .bot-txt .arr.__p{display: none;}
    .learn_more_section .bot-txt .arr.__m{display: flex;}
    .learn_more_section .bot-txt{font-size: 2rem;}
    .learn_more_section{margin: 0px auto 100px; color: #fff; text-align: center;}
    .learn_more_section .bot-txt{gap:0px}
    .learn_more_section.active .bot-txt{gap:0px}
    .circle_line {stroke-width: 1; -webkit-stroke-width: 1;}
    .learn_more_section .bot-txt p{height: 24px;}
    .learn_more_section.active .bot-txt p{width: 210px;}
    .learn_more_section .bot-txt .lef span{width: 210px;}
    .learn_more_section.active .bot-txt .arr{transform: translateX(10px);}
    .learn_more_section.active:hover .bot-txt .arr{transform: translateX(10px);}
}

.bot_section .item_img_wrap .badge{ overflow: hidden;position: absolute; top: 0; left: 20px; z-index: 2; width: 62px; height: 94px; background-repeat: no-repeat; background-position: center; background-size: cover; text-indent: -9999px;} 
.bot_section .item_img_wrap .badge.grand{background-image: url(../images/badge-grand.jpg);} 
.bot_section .item_img_wrap .badge.winner{background-image: url(../images/badge-winner.jpg);} 
.bot_section .item_img_wrap .badge.bronze{background-image: url(../images/badge-bronze.jpg);} 
.projects .item_img_wrap .badge{overflow: hidden;position: absolute;top: 0;left: 20px;z-index: 2;width: 62px;height: 94px;background-repeat: no-repeat;background-position: center;background-size: cover;text-indent: -9999px;} 
.projects .item_img_wrap .badge.grand{background-image: url(../images/badge-grand.jpg);} 
.projects .item_img_wrap .badge.winner{background-image: url(../images/badge-winner.jpg);} 
.projects .item_img_wrap .badge.bronze{background-image: url(../images/badge-bronze.jpg);} 

@media(max-width:1200px){
    .bot_section{padding: 0 0px 80px;}
    .bot_section .item_img_wrap .badge{left: 15px; z-index: 30; width: 31px; height: 47px;} 
    .projects .item_img_wrap .badge{left: 15px; z-index: 30; width: 31px; height: 47px;} 
}


/* 메인페이지 견적문의 */
.inquire_bg{ display: none; display: none; align-items: center; justify-content: center; padding:40px 0;position: fixed; top: 0; left: 0; z-index: 9999; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.7); box-sizing: border-box;}
.inquire_wrap{position: relative; width: 100%; max-width: 1145px; height: 100%;}
.inquire_in{display: flex;align-items: center;justify-content: center;flex-direction: column;height: 100%;}
.inquire_title{margin-bottom: 30px;position: relative;width: 100%;font-size: 1.25em;font-weight: 700;color: #fff;text-align: center;}
.inquire_wrap .close_btn{border: none;position: absolute;top: -14px;right: -5px;width: 40px;height: 40px; background:url(../images/close-btn.svg) transparent no-repeat center; background-size: 20px;}
.inquire_form{ display: flex; padding: 100px 20px 50px 100px;width: 100%; max-height: 660px; background-color: #fff; box-sizing: border-box;}
.inquire_form .lef{flex-shrink: 0;width: 445px;}
.inquire_form .lef .top .title{margin-bottom: 70px; padding-right: 20px; position: relative;font-size: 2.25em;font-weight: 300;line-height: 1.4;color: #101010;letter-spacing: -0.05em;transform: translateY(-0.3em);}
.inquire_form .lef .top .title strong{font-weight: 600;}
.inquire_form .lef em{position: absolute;bottom: -35px;left: 0px;width: 85%;height: 1px;background-color: #ddd;}
.inquire_form .lef .bottom .detail{ margin-bottom:20px;color:#555; letter-spacing: -0.05em;}
.address-wrap p{display: flex; width: 100%; font-weight: 600; color: #101010;}
.address-wrap p~p{margin-top:16px;}
.address-wrap .title{ display: block; width: 68px;font-weight: 400;}
.inquire_form  .rig{display: flex; flex-direction: column; position: relative;}
.inquire_form .rig form{ padding-right: 80px; overflow-x: hidden;overflow-y: scroll; box-sizing: border-box;}
.inquire_form .rig form::-webkit-scrollbar {width: 3px; height: 15%;}
.inquire_form .rig form::-webkit-scrollbar-track { width: 1px;background: transparent;}
.inquire_form .rig form::-webkit-scrollbar-thumb {background-color: #101010; border-radius: 3px;}
.inquire_form .rig form::-webkit-scrollbar-button {display: none;}
.form-group~.form-group{margin-top: 50px;}
.form-group .question{ margin-bottom: 20px;font-size: 1.25em; font-weight:500; color: #101010; letter-spacing: -0.05em;}
.form-group .question em{ margin-left: 6px;font-size: 0.75rem; color: #888;}
.inquire_form .button-wrap {display: flex; gap: 6px; flex-wrap: wrap;}
.inquire_form .button-wrap input[type="checkbox"]{display: none; }
.inquire_form .button-wrap input[type="radio"]{display: none; }
.inquire_form .button-wrap span{display: inline-block;padding: 0 20px;border: 1px solid #ccc;width: auto;height: 44px;background-color: #fff;font-size: 0.875em;line-height: 40px;color: #101010;border-radius: 22px;box-sizing: border-box;}
.inquire_form .button-wrap input:checked + span{ border: 1px solid #101010;background-color: #101010; color: #fff;}
.inputs-wrap input{ display: block; border:none; width: 100%; font-size: 0.875rem;line-height: 48px; letter-spacing: -0.05em;}
.inputs-wrap input:focus{ border-bottom: 1px solid #101010;outline:none;}
.inputs-wrap input{border-bottom:1px solid #ccc}
.inquire-scroll{position: absolute;bottom: -25px;width: calc(100% - 80px);height: 20px;text-align: center;}
.inquire-scroll img{ display: block; margin: 0 auto;width: 9px; height: 5px; object-fit: cover;}
.inquire-scroll span{display: block; margin-top: 8px; font-family: 'Play'; font-size: 8px; color: #101010; letter-spacing: 0.15em;}
.inquire_more_btn{ display: flex; gap: 8px; align-items: center; justify-content: center; height: 70px;font-size: 0.815rem; color: #fff;}
.inquire_more_btn em{display: block; width: 13px; height: 8px; background: url(../images/inquire-arr.png) no-repeat center; background-size: contain;}
.detail-wrap{ margin-top: 10px;width: 100%; height:180px; font-size:0.875rem; line-height: 2em; color: #101010;}
.detail-wrap textarea{padding: 15px 20px;border: none;border: 1px solid #ccc;outline: none;width: 100%;height: 100%;resize: none;-webkit-appearance: none;appearance: none;border-radius: 0;}
.detail-wrap textarea:focus{border: 1px solid #101010;}
.detail-wrap textarea::-webkit-scrollbar {display: none;}
.inquire_agree{margin-top:20px;}
.inquire_agree input{display: none;}
.inquire_agree label{display: block;display: flex; padding-left: 26px; position: relative; font-size: 0.8125em; line-height: 1em; color: #101010; letter-spacing: -0.05em; cursor: pointer;}
.inquire_agree label a{ position: relative;color: #101010;}
.inquire_agree label a::after{ position: absolute; bottom: 0px; left: 0;width: 100%; height: 1px; background: #101010; content: "";}
.inquire_agree input[type="checkbox"] +  .check_box{display: block; border: 1px solid #101010; position: absolute; top: -1px; left: 0; width: 18px; height: 18px; background-size: contain; border-radius: 4px; }
.inquire_agree input[type="checkbox"]:checked + .check_box{background: url(../images/inquire-chk.png) no-repeat center;background-size: contain;}

.inquire_submit_btn{display:flex; justify-content: flex-end; margin-top: 20px; width: 100%;}
.inquire_submit_btn button{border: none; width: 100px; height: 44px; background: #d6232f; font-size: 14px; font-weight: 500; line-height: 40px; color: #fff; border-radius: 22px;box-sizing: border-box;}

.inquire_form .term_txt{border: 1px solid #ccc !important; height: 120px;}
.inquire_form .term_txt p{height: 80px !important; color: #101010 !important;}
.inquire_form .chk_box {color: #101010 !important;}
.inquire_form .chk_box p{font-size: 0.875rem; color: #101010 !important;}
.inquire_form .chk_box span{border: 1px solid #101010 !important; width: 16px; height: 16px;}
.inquire_form .chk_box .chk_line{stroke: #101010 !important;}
.inquire_form .scrollbar::-webkit-scrollbar-thumb{background-color:#101010 !important;}
.inquire_form .scrollbar::-webkit-scrollbar-track{background: linear-gradient(to left, rgba(0,0,0,0) 0% 33%, rgba(16,16,16,0.2) 33% 66% , rgba(0,0,0,0) 66% 100%) !important;background-color:rgba(16,16,16,0.2) !important;}


@media (max-width: 1024px){
    .inquire_bg{padding: 0; background: #fff;}
    .inquire_wrap{height: 100%;}
    .inquire_in{ display: block;height: 100%;}
    .inquire_title{display: flex;align-items: center;justify-content: center;margin: 0px auto;border-bottom: 1px solid #ccc;height: 60px;line-height: 40px;color: #101010;}
    .inquire_wrap .close_btn{top: 0;right: 0;width: 60px;height: 60px;background:url(../images/close-btn-bl.svg) transparent no-repeat center;background-size: 14px;}
    .inquire_form{gap: 50px;flex-direction: column;padding: 40px 20px;border-bottom: 1px solid #ccc; overflow-x:hidden;overflow-y: scroll; height: calc(100% - 150px);max-height: none;}
    .inquire_form::-webkit-scrollbar {width: 3px; height: 15%;}
    .inquire_form::-webkit-scrollbar-track { width: 1px;background: transparent;}
    .inquire_form::-webkit-scrollbar-thumb {background-color: #101010; border-radius: 3px;}
    .inquire_form .lef{display:flex; gap: 20vw; justify-content: flex-start;width: 100%}
    .inquire_form .lef .top{position: relative;}
    .inquire_form .lef .top::after{display: block;position: absolute;top: 0;right: -50%;width: 1px;height: 100%;background-color: #ddd;content: '';transform: translateX(-2.5vw);}
    .inquire_form .lef .top .title{flex-shrink: 0; margin-bottom: 50px;}
    .inquire_form .lef .top .title em{bottom:-25px;}
    .inquire_form .lef .bottom .detail{margin-bottom: 25px;}
    .inquire_form .rig form{padding-right: 0;}
    .inquire-scroll{margin-top: 10px;position: fixed;bottom: 50px;left: 0;width: 100%;}
    .inquire_form .lef em{display: none;}
    .inquire_form .button-wrap span{padding: 0 18px;height: 38px;line-height: 38px;border-radius: 19px;}
    .inquire_more_btn{position:fixed;bottom: 5px;left: 0;z-index: 10;width: 100%;height: 40px;color: #101010;}
    .inquire_form .lef{display:flex; gap: 0px; flex-direction: column;}
    .inquire_form .lef .top::after{display: none;}
    .inquire_form .lef em{ display: block;bottom:-10px; width: 170px;}
    .inquire_more_btn em{background: url(../images/inquire-arr-bl.png) no-repeat center; background-size: contain;}
    .inquire_agree input[type="checkbox"] + .check_box{ top: -2px;width: 14px; height: 14px;}
}

@media (max-width: 1024px) and (min-width:768px) {
    .inquire_form{ gap:70px;height: calc(100% - 205px)}
    .inquire_form .lef .top .title{ margin-bottom: 60px;font-size: 3rem;}
    .inquire_form .lef .top .title em{bottom:-30px;}
    .inquire_form .lef .top .title br{display: none;}
    .inquire_form .lef .bottom .detail{ margin-bottom: 40px;font-size: 1.5rem;}
    .inquire_form .lef .address-wrap p{font-size: 1.5rem;}
    .address-wrap p~p{margin-top: 24px;}
    .inquire_wrap .form-group~.form-group{margin-top: 70px;}
    .inquire_wrap .form-group .question{ margin-bottom: 30px;font-size: 2rem;}
    .inquire_wrap .form-group .question em{font-size: 1.25rem;}
    .inquire_form .button-wrap span{font-size: 1.2rem;}
    .inputs-wrap input{font-size: 1.25rem; line-height: 52px;}
    .detail-wrap{ margin-top: 25px;height: 180px; font-size: 1.25rem;}
    .inquire_agree label{font-size: 1.25rem;}
    .inquire_agree input[type="checkbox"] + .check_box{width: 18px; height: 18px;}
    .inquire-scroll {bottom: 90px;}
    .inquire-scroll img{width: 12px; height: 7px;}
    .inquire-scroll span{font-size: 12px;}
    .inquire_more_btn{position:fixed;bottom: 5px;left: 0;z-index: 10;width: 100%;height: 80px;color: #101010;}
}

@media (max-width:1260px) and (min-width: 1024px) and (max-height: 860px) {
    .inquire_form{max-height: 70vh;}
}

@media (max-width:768px){
    .inquire_form .lef .top .title{margin-bottom: 60px;font-size: 2.25rem;}
    .inquire_form .lef .top .title em{bottom:-30px;}
    .inquire_form .lef .top .title br{display: none;}
    .inquire_form .lef .bottom .detail{margin-bottom: 30px;font-size: 1.15rem;}
    .inquire_form .lef .address-wrap p{font-size: 1.15rem;}
    .address-wrap p~p{margin-top: 20px;}
    .inquire_wrap .form-group~.form-group{margin-top: 60px;}
    .inquire_wrap .form-group .question{margin-bottom: 25px;font-size: 1.65rem;line-height: 1.35;}
    .inquire_wrap .form-group .question em{font-size: 1.15rem;}
    .inquire_form .button-wrap{gap:8px}
    .inquire_form .button-wrap span{padding: 0 18px;height: 42px;line-height: 40px;border-radius: 20px; font-size: 1.15rem;}
    .inputs-wrap input{font-size: 1.25rem; line-height: 52px;}
    .detail-wrap{margin-top: 25px;height: 180px;font-size: 1.25rem;line-height: 1.6;}
    .inquire_agree label{font-size: 1.15rem;}
    .inquire_agree input[type="checkbox"] + .check_box{ top: -1px;width: 16px;height: 16px;}
}

/*contents*/
.content{padding: 370px 0 140px; overflow: hidden;}
.content.project{padding: 240px 0 140px; overflow: visible;}
.con_tit p{overflow: hidden;font-size: 7rem;font-weight: 600;line-height: 1.3em; text-align: center;}
.con_tit p ~ p {margin-top: 50px;}
.menu_tab{ display: flex; justify-content: center;padding-top: 30px; position: sticky; top: 0px; z-index: 80; width: 100%; max-width: 1780px; height: 80px;transition: .3s;}
.menu_tab .home_btn{ position: absolute; top: 28px; left: 0;width: 138px; height: 24px; background:url(../images/logo-wh.png) no-repeat center; background-size: contain; opacity: 0;}
.menu_tab.sticky .home_btn a{display: block; width: 100%; height: 100%;}
.menu_tab .search_btn{ display: none; position: absolute; top: -100%; right: 0;width: 80px; height: 80px; opacity: 0;}
.menu_tab .search_btn button{ border: none;width: 100%; height: 100%; background:transparent;}
.menu_tab.sticky .home_btn{opacity: 1;}
.menu_tab.sticky .search_btn{ display: block;top: 0px; opacity: 1;}
.menu_tab_search{display: flex;justify-content: center; border-bottom:1px solid #282828; overflow: hidden;position: absolute;top: 0;left: 50%;z-index: -1;width: 100vw;height: 80px;transition: .3s;transform: translateX(-50%); opacity: 0;}
.menu_tab.search .menu_tab_search{height: 250px;}
.menu_tab.sticky .menu_tab_search{opacity: 1; }
.menu_tab_search .scr_bar{display:none;}
.menu_tab_search form{ display: block; margin-top: 120px; position: relative;width: 100%; max-width: 680px; height: 70px; border-radius: 35px;}
.menu_tab_search input{ padding: 0px 30px; border: none; outline: none;width: 100%; height: 100%; background: transparent; font-size: 1.125em; box-sizing: border-box;}
.menu_tab_search button{ border: none;position: absolute; top: -2px; right: 0; width: 70px; height: 70px;}

.color_wrap.black .menu_tab_search{background-color: #101010;}
.color_wrap.black .menu_tab .search_btn button{background: url(../images/search-btn.png) no-repeat center right; background-size: 24px; transition: .3s;}
.color_wrap.black .menu_tab.search .search_btn button{background: url(../images/close-btn.svg) no-repeat center right; background-size: 24px;}
.color_wrap.white .menu_tab.search .search_btn button{background: url(../images/close-btn-bl.svg) no-repeat center right; background-size: 24px;}
.color_wrap.black .menu_tab .home_btn{background-image: url(../images/logo-wh.png);}
.color_wrap.black .menu_tab_search form{border: 2px solid #fff;}
.color_wrap.white .menu_tab .home_btn{background-image: url(../images/logo-bl.png);}
.color_wrap.white .menu_tab_search{ border-bottom: 1px solid #ccc;background-color: #f8f7f5;}
.color_wrap.white .menu_tab_search form{border: 2px solid #101010;}
.color_wrap.black .menu_tab_search button{background: url(../images/search-btn.png) no-repeat center; background-size: 24px;}
.color_wrap.white .menu_tab .search_btn button{background: url(../images/search-btn-bl.png) no-repeat center right; background-size: 24px;}
.color_wrap.white .menu_tab_search button{background: url(../images/search-btn-bl.png) no-repeat center; background-size: 24px;}
.color_wrap.black  .menu_tab_search input{color: #fff;}
.color_wrap.white  .menu_tab_search input{color: #101010;}

.menu_tab ul{overflow-x: auto;overflow-y: hidden; position: relative; z-index: 10;text-align: center;white-space: nowrap;}
.menu_tab ul::-webkit-scrollbar{height: 0;opacity: 0;}
.menu_tab ul li{display: inline-block;overflow: hidden;}
.menu_tab ul li ~ li{margin-left: 40px;}
.menu_tab ul li > div{display: flex;align-items: flex-start;}
.menu_tab ul li button{padding-bottom: 8px;border: none;position: relative;background: none;font-family: 'Play'; font-size: 1.125em;transition: 0.3s;}
.menu_tab.sticky ul li button{font-size: 0.9375em;}
.menu_tab ul li button::before{position: absolute;bottom: 0;left: 50%;width: 0;height: 2px;transition: 0.3s;content: "";}
.menu_tab ul li .leng{margin-left: 7px;padding: 0 7px;background-color: #d6232f;font-family: 'Play';font-size: 0.625rem;line-height: 16px;color: #fff;transition: 0.3s;border-radius: 30px;opacity: 0;}
.menu_tab ul li.on button{font-weight: 600;}
.menu_tab ul li.on button::before{left: 0;width: 100%;}
.menu_tab ul li.on .leng{opacity: 1;}
.color_wrap.black .con_tit p{color: #fff;}
.color_wrap.black .menu_tab ul li button{color:#fff;}
.color_wrap.black .menu_tab ul li button::before{background-color: #fff;}
.color_wrap.white .con_tit p{color: #101010;}
.color_wrap.white .menu_tab ul li button{color:#101010;}
.color_wrap.white .menu_tab ul li button::before{background-color: #101010;}
.color_wrap.black .menu_tab_search form input::placeholder{color: #fff;}
.color_wrap.white .menu_tab_search form input::placeholder{color: #101010;}

.header_menu_wrap{position: absolute; top: 0; left: 50%; width: 100vw; max-width: 1780px; height: 60px; transform: translateX(-50%);}

@media all and (max-width:1240px){
    .content{padding: 40% 0 20%;}
    .content.project{padding: 30% 0 20%;}
    .con_tit p{font-size: 3.5rem;}
    .con_tit p ~ p{margin-top: 20px;}
    .menu_tab{height: 90px;}
    .menu_tab ul{display: flex;justify-content: center;flex-wrap: wrap;width: 100%;column-gap: 24px;row-gap: 20px;}
    .menu_tab ul li ~ li{margin-left: 0px;}
    .menu_tab.sticky {height: 110px;}
    .menu_tab.sticky .tag_wrap{display: block;margin-top: 40px;width: 100%;position:relative;}
	.menu_tab.sticky ul::-webkit-scrollbar{display: none;}
    .menu_tab.sticky ul{display: block;column-gap: 0;height: 100%;}
    .menu_tab.sticky ul li >{display: flex; align-items: flex-start; height: 30px;}
    .menu_tab.sticky ul li ~ li{margin-left: 16px;}
    .menu_tab.sticky ul li button{font-size: 1rem;}
    .menu_tab_search{ padding: 0 15px;height: 110px; box-sizing: border-box;}
    .menu_tab_search form{margin-top: 120px;width: 100%;height: 48px;line-height: 44px;}
    .menu_tab.sticky ul{flex-wrap: nowrap;overflow-x: scroll;}
    .menu_tab.search .menu_tab_search{height: 200px;}
	.menu_tab_search .scr_bar{display:block;position:absolute;left:0;bottom:0;height:2px;z-index:2;}
	.color_wrap.white .menu_tab_search .scr_bar{background:#101010;}
	.color_wrap.black .menu_tab_search .scr_bar{background:#fff;}
    .menu_tab .search_btn{height: 60px;}
    .menu_tab_search button{width: 48px;height: 48px;background-size: 14px !important;}
    .menu_tab .home_btn{width: 96px; height: 30px;}
    .menu_tab.sticky .home_btn{top:15px; left: 15px;}
    .menu_tab.sticky .search_btn{right: 15px;}
    
    .color_wrap.black .menu_tab .search_btn button{background: url(../images/search-btn.png) no-repeat center right; background-size: 16px; transition: .3s;}
    .color_wrap.black .menu_tab_search button{background: url(../images/search-btn.png) no-repeat center; background-size: 16px;}
    .color_wrap.white .menu_tab .search_btn button{background: url(../images/search-btn-bl.png) no-repeat center right; background-size: 16px;}
    .color_wrap.white .menu_tab_search button{background: url(../images/search-btn-bl.png) no-repeat center; background-size: 16px;}
    .color_wrap.black .menu_tab.search .search_btn button{background: url(../images/close-btn.svg) no-repeat center right; background-size: 16px;}
    .color_wrap.white .menu_tab.search .search_btn button{background: url(../images/close-btn-bl.svg) no-repeat center right; background-size: 16px;}
}

@media (max-width:1240px) and (min-width:1024px) and (max-height:860px){
    .content:not(.project){padding: 30% 0 20%;}
    .content.project{padding: 140px 0 200px;}
    .menu_tab.search .menu_tab_search{height: 230px;}
    .menu_tab_search form{ display: block;width: 100%; height: 70px;}
    .menu_tab_search input{padding: 0px 30px;border: none;outline: none;width: 100%;height: 100%;background: transparent;font-size: 1.125em;box-sizing: border-box;}
    .menu_tab_search button{width: 70px; height: 70px;}
    .color_wrap.black .menu_tab_search input,
    .color_wrap.black .menu_tab_search input::placeholder{color: #fff;}
    .color_wrap.black .menu_tab_search button{background: url(../images/search-btn.png) no-repeat center; background-size: 26px !important;}
    /* .color_wrap.white .menu_tab_search {border: 2px solid #101010;} */
    .color_wrap.white .menu_tab_search input,
    .color_wrap.white .menu_tab_search input::placeholder{color: #101010;}
    .color_wrap.white .menu_tab_search button{background: url(../images/search-btn-bl.png) no-repeat center; background-size: 26px !important;}
}
@media all and (max-width:450px){
	.menu_tab ul{column-gap: 4.5vw;}
	.menu_tab ul li button,
	.menu_tab.sticky ul li button{font-size: 3.1vw;}
}

/*projects*/
.projects{margin-top: 160px;}

.stk_{overflow:hidden;}
.search_box{display: block; margin: 80px auto 50px; position: relative; width: 70px; max-width: 680px; height: 70px; transition: 2s; border-radius: 35px; opacity: 0;}
.search_box.active{width: 100%; opacity: 1;}
.search_box form{ display: block;width: 100%; height: 100%;}
.search_box input{padding: 0px 30px;border: none;outline: none;width: 100%;height: 100%;background: transparent;font-size: 1.125em;box-sizing: border-box;}
.search_box button{ border: none;position: absolute; top: -2px; right: 0; width: 70px; height: 70px;}

.color_wrap.black .search_box {border: 2px solid #fff;}
.color_wrap.black .search_box input,
.color_wrap.black .search_box input::placeholder{color: #fff;}
.color_wrap.black .search_box button{background: url(../images/search-btn.png) no-repeat center; background-size: 26px;}
.color_wrap.white .search_box {border: 2px solid #101010;}
.color_wrap.white .search_box input,
.color_wrap.white .search_box input::placeholder{color: #101010;}
.color_wrap.white .search_box button{background: url(../images/search-btn-bl.png) no-repeat center; background-size: 26px;}

@media all and (max-width: 1200px){
    .search_box{margin: 50px auto 40px; height: 48px; transition: 1s;}
    .search_box.active{width: 100%; opacity: 1;}
    .search_box input{padding: 0px 20px;}
    .search_box button{width: 48px; height: 48px; background-size: 14px !important;}
}

@media all and (max-width: 768px){
    .search_box{margin: 40px auto 30px; height: 48px;}
    .search_box input{padding: 0px 20px;}
    .search_box button{width: 48px; height: 48px; background-size: 14px !important;}
}


.projects > ul{display:grid; gap: 95px 40px; grid-template-columns: repeat(3, 1fr);}
.projects > ul > li{width: 100%;}
.projects > ul > li:nth-child(3n+1){left: 0;}
.projects > ul > li:nth-child(3n+2){left: calc(33.33% + 12.5px);}
.projects > ul > li:nth-child(3n+3){left: calc(66.66% + 25px);}
.projects > ul > li.none{left: 0;transition: 0s;}

.projects .item_box{transition: 1s; opacity: 0; max-width: 504px;}
.projects .item_box:nth-child(3n+2) {transition-delay: .3s;}
.projects .item_box:nth-child(3n){transition-delay: .6s;}
.projects .item_box.active{opacity: 1; transform: translateY(0);}
.projects .item_img_wrap{ display: block; padding-bottom: 66.7%;position: relative; width: 100%; height: 0; }
.projects .link_box .bg{position: absolute; top: 0; left: 0; z-index: 0; width: 100%; height: 100%; opacity: 0.9;}
.projects .link_box .link_info{position: relative; z-index: 5;}

.projects .img_box{display: block;overflow: hidden;position: absolute;width: 100%;height: 100%;background: #363636;transition: .4s;max-height: 336px;}
.projects .img_box img{width: 100%; object-fit: cover;}
.projects .img_box .link_box .title{ margin-bottom: 15px;font-size: 2.25em; font-weight: 600; line-height: 1.25;letter-spacing: -0.025em;}
.projects .img_box .link_box .detail{ margin-bottom: 40px;font-size: 0.875em; line-height: 1.5; color: #666; letter-spacing: -0.025em;}
.projects .img_box .link_box .btn_wrap{display: flex; gap: 38px; justify-content: center; font-size: 1.063rem; color: #101010; letter-spacing: -0.05em;}
.projects .img_box .link_box .btn_wrap button, 
.img_box .link_box .btn_wrap a{line-height: 1.5;}
.projects .item_info_wrap .rig{display: none;}


.color_wrap.black .link_box .bg{background-color: #fff;}
.color_wrap.white .link_box .bg{background-color: #101010;}
.color_wrap.black .img_box .link_box .title{color: #101010;}
.color_wrap.white .img_box .link_box .title{color: #fff;}
.color_wrap.black .img_box .link_box .detail{color: #666;}
.color_wrap.white .img_box .link_box .detail{color: #ddd;}
.color_wrap.white .img_box .link_box .btn_wrap{color: #101010;}
.color_wrap.white .img_box .link_box .btn_wrap{color: #fff;}

@media (max-width: 1200px){
    .projects > ul{display:grid; gap: 20px; grid-template-columns: repeat(3, 1fr);}
    .projects .item_info_wrap {flex-direction: column;}
    .projects .item_info_wrap .rig{display: flex;}
    .projects .item_info_wrap .rig .btn-wrap{display: flex; gap: 10px; flex-shrink: 0; margin-bottom: 20px;}
    .projects .item_info_wrap .rig .btn-wrap button,
    .projects .item_info_wrap .rig .btn-wrap a{ display: block; border: none;width: 80px; height: 36px; font-size: 12px; font-weight: 500; line-height: 34px; transition: .4s; border-radius: 18px;box-sizing: border-box;}
    .projects .item_info_wrap .rig .btn-wrap a{text-align: center;}
    .projects .item_box{transition-delay: 0s !important;}
}

@media (max-width: 540px){
    .projects > ul{grid-template-columns: repeat(1, 1fr);}
    .projects .item_info_wrap {flex-direction: row;}
}

.roll_txt{margin: 300px 0 180px;padding: 20px 0 30px;position: relative;text-align: center;white-space: nowrap; transition: .6s; opacity: 0;}
.roll_txt .txt_wrap{display: flex;align-items: center;justify-content: center;}
.roll_txt .txt_wrap p{font-size: 7rem;font-weight: 600;animation: rollmove 10s infinite;animation-timing-function: cubic-bezier( 1,1,1,1 );}
.roll_txt .txt_wrap p i{font-style: normal; transition: 0.3s; paint-order: stroke fill;}
.color_wrap.black .roll_txt .txt_wrap p i{color: #101010;}
.color_wrap.white .roll_txt .txt_wrap p i{color: #f8f7f5;}
.roll_txt .line{position: absolute;left: 50%;z-index: 5;width: 100vw;height: 1px;transform: translateX(-50%);}
.roll_txt .line.top{top: 0;}
.roll_txt .line.bot{bottom: 0;}

.roll_txt_wrap{ overflow: hidden;position: absolute; top: 20px; left: 50%; width: 100vw; height: 100%; transform: translateX(-50%);}
.roll_txt_wrap .txt_wrap{margin-top: 15px;}
.roll_txt.ov{height: 148px;}


@media (max-width:1200px){
    .roll_txt_wrap .txt_wrap{margin-top: 10px;}
    .roll_txt.ov{height: 73px;}
}

@keyframes rollmove {
    0% {transform: translate(0,0);}
    100% {transform: translate(-100%,0);}
}
.projects_more{margin-top: 150px;}
.loading{padding-top: 30px;text-align: center;opacity: 0;}
.loading ul{display: inline-flex;}
.loading ul li{margin: 0 7px;position: relative;width: 4px;height: 4px;}
.loading ul li span{display: block;position: absolute;top: 50%;left: 50%;width: 100%;height: 100%;border-radius: 50%;transform: translate(-50%,-50%);opacity: 0.3;}
.loading.on{display: block;opacity: 1;}
.loading.on ul li:nth-child(1) span{animation: loading_ball1 2.5s infinite;animation-timing-function: cubic-bezier( 1,1,1,1 );}
.loading.on ul li:nth-child(2) span{animation: loading_ball2 2.5s infinite;animation-timing-function: cubic-bezier( 1,1,1,1 );}
.loading.on ul li:nth-child(3) span{animation: loading_ball3 2.5s infinite;animation-timing-function: cubic-bezier( 1,1,1,1 );}
@keyframes loading_ball1 {
    0% {transform: scale(1);opacity: 0.3;}
    20% {transform: scale(1.5);opacity: 1;}
    40% {transform: scale(1);opacity: 0.3;}
    100% {transform: scale(1);opacity: 0.3;}
}
@keyframes loading_ball2 {
    0% {transform: scale(1);opacity: 0.3;}
    20% {transform: scale(1);opacity: 0.3;}
    40% {transform: scale(1.5);opacity: 1;}
    60% {transform: scale(1);opacity: 0.3;}
    100% {transform: scale(1);opacity: 0.3;}
}
@keyframes loading_ball3 {
    0% {transform: scale(1);opacity: 0.3;}
    40% {transform: scale(1);opacity: 0.3;}
    60% {transform: scale(1.5);opacity: 1;}
    80% {transform: scale(1);opacity: 0.3;}
    100% {transform: scale(1);opacity: 0.3;}
}
.color_wrap.black .projects .thumb_txt ul li em{background-color: #f8f7f5;color: #101010;}
.color_wrap.black .projects .thumb_txt strong{color: #f8f7f5;}
.color_wrap.black .projects .thumb_txt span{color: #bbb;}
.color_wrap.black .loading ul li span{background-color: #f8f7f5;}
.color_wrap.black .roll_txt .txt_wrap p{color: #f8f7f5;}
.color_wrap.black .roll_txt .line{background-color: rgba(255,255,255,0.2);}
.color_wrap.black .roll_txt .txt_wrap p i{-webkit-text-stroke: 2px #f8f7f5;text-stroke: 1px #f8f7f5;}
.color_wrap.white .projects .thumb_txt ul li em{background-color: #101010;color: #f8f7f5;}
.color_wrap.white .projects .thumb_txt strong{color: #101010;}
.color_wrap.white .projects .thumb_txt span{color: #777;}
.color_wrap.white .loading ul li span{background-color: #101010;}
.color_wrap.white .roll_txt .txt_wrap p{color: #101010;}
.color_wrap.white .roll_txt .line{background-color: rgba(16,16,16,0.2);}
.color_wrap.white .roll_txt .txt_wrap p i{-webkit-text-stroke: 2px #101010;text-stroke: 2px #101010;}
@media all and (max-width:1200px){
    .projects{margin-top: 90px;}
    .projects > ul{height: auto !important;}
	.projects > ul > li:nth-child(3n),
	.projects > ul > li:nth-child(3n+2){margin-left:0;}
    .projects .thumb_bg::before{position: absolute;top: 0;left: 0;z-index: 10;width: 100%;height: 100%;content: "";}
    .projects .thumb_txt{margin-top: 20px;}
    .projects .thumb_txt span{margin-top: 10px;}
    .projects .thumb_txt ul{display: block;}
    .projects .thumb_txt ul li{margin-right: 0;margin-bottom: 4px;}
    .projects .thumb_txt ul li em{padding: 2px 5px;}
    .loading{padding-top: 20px;}
    .roll_txt{margin: 80px 0 100px;padding: 10px 0 15px;}
    .roll_txt .txt_wrap p{font-size: 4rem;}
    .projects_more{margin-top: 60px;}
    .color_wrap.black .roll_txt .txt_wrap p i{-webkit-text-stroke: 1px #f8f7f5;text-stroke: 1px #f8f7f5;}
    .color_wrap.white .roll_txt .txt_wrap p i{-webkit-text-stroke: 1px #101010;text-stroke: 1px #101010;}
}

.circle_btn_wrap{margin: 50px auto 200px; color: #fff; text-align: center;}
.circle_btn_wrap .txt{ display: flex; align-items: center; justify-content: center;font-size: 2.5rem; font-weight: 700;letter-spacing: -0.025em; cursor: pointer;}
.circle_btn_wrap .txt .arr.__m{display: none;}
.circle_btn_wrap .txt .arr {display: flex; align-items: center; justify-content: center; position: relative; width: 40px; height: 40px; transition: 0.3s; transform: none;}
.circle_btn_wrap .txt .arr .icon{ display: block;width: 36px; height: 24px;}
.circle_btn_wrap .txt .arr .circle{position: absolute; top: 50%; left: 50%; transition: .6s; transform: translate(-50%, -50%); opacity: .2;}

.circle_btn_wrap .txt p{display: block;overflow: hidden;position: relative;width: 0;height: 40px;transition-property: width, opacity, transform;transition-duration: 0.8s;}
.circle_btn_wrap .txt .lef span{ display: block; position: absolute; top: 0; right: 0; width: 520px; height: 100%; transition-property: opacity, transform; transition-duration: 0.8s;opacity: 0;}
.circle_btn_wrap .txt{gap: 0;}
.circle_btn_wrap  .arr .icon{ transition-property: opacity, transform; transition-duration: 0.8s;opacity: 0; transform: rotate(-180deg);}
.circle_btn_wrap.active .txt{gap: 30px;}
.circle_btn_wrap.active .txt p{width: 520px;}
.circle_btn_wrap.active .txt .lef span{opacity: 1;}
.circle_btn_wrap.active .arr{transform: translateX(0);}
.circle_btn_wrap.active .arr .icon{opacity: 1; transform: none;}
.circle_btn_wrap.active:hover .txt .arr{transform: translateX(10px);}

.color_wrap.white .circle_btn_wrap span{color: #101010;}
.color_wrap.white .circle_btn_wrap.active .circle_line{stroke: #101010;}
.color_wrap.black .circle_btn_wrap .icon{background: url(../images/learnmore-btn-arr.svg) no-repeat center; background-size: contain;}
.color_wrap.white .circle_btn_wrap .icon{background: url(../images/learnmore-btn-arr-b.svg) no-repeat center; background-size: contain;}

.circle_btn_wrap .txt .arr .circle.circle2{opacity: 1;}
.circle_btn_wrap.active .circle_line:not(.line2){animation: draw .4s linear forwards;}
.circle_btn_wrap.active:hover .circle_line.line2{animation: draw .4s linear forwards;}

@media (max-width: 1200px){
    .circle_btn_wrap{margin: 50px auto 100px; color: #fff; text-align: center;}
    .circle_btn_wrap.active .txt{gap: 5px;}
    .circle_btn_wrap.active .txt p{width: 232px;height: 18px;}
    .circle_btn_wrap .txt .lef span{width: 232px;}
    .circle_btn_wrap .txt .arr.__m{display: flex;}
    .circle_btn_wrap .txt{font-size: 1.45rem;}
}


/*contact*/
.contact_info{position: absolute;right: 0;bottom: 0;}
.contact_info dl ~ dl{margin-top: 75px;}
.contact_info dl dt{margin-bottom: 25px;overflow: hidden;font-family: 'Play';font-size: 1.25rem;}
.contact_info dl dd{overflow: hidden;}
.contact_info dl dd strong{display: inline-block;padding-bottom: 3px;font-family: 'Play';font-size: 2.25rem;font-weight: 600;transition: 0.3s;}
.contact_info dl dd > span > span{font-family: 'Play';font-size: 1.25rem;line-height: 1.4em;transition: 0.3s;}
.contact_info dl dd span em{font-family: 'Noto Sans KR';letter-spacing: 0px;}
.contact{margin-top: 190px;}
.form .box ~ .box{margin-top: 100px;}
.form .tit{margin-bottom: 80px;font-size: 2.25rem;font-weight: 600;transition: 0.3s;}
.form ul li{display: flex;justify-content: space-between;}
.form ul li ~ li{margin-top: 45px;}
.form ul li dl{display: flex;align-items: center;width: 100%;}
.form dl dt,
.form .inp p{width: 135px;font-size: 1.25rem;transition: 0.3s;}
.form dl dd,
.form .inp > div{flex-grow: 1;}
.form .inp{display: flex;align-items: center;position: relative;transition: 0.3s;}
.form .inp2{width: 47%;}
.form .inp input[type=text]{border: none;outline: none;width: 100%;height: 65px;background-color: transparent;font-size: 1.25rem;font-weight: 300;}
.form .inp .line{position: absolute;bottom: -2px;left: 0;width: 100%;height: 2px;transition: 0.2s;opacity: 0;}
.form .inp input[type=text]:focus ~ .line{opacity: 1;}
.form .inp .file_box input[type=file]{display: none;}
.form .inp .file_box label{display: flex;align-items: center;}
.form .inp .file_box .file_name{width: 100%;height: 65px;font-size: 1.25rem;font-weight: 300;line-height: 65px;}
.form .inp .file_box span{padding-right: 20px;position: relative;transition: 0.3s;}
.form .inp .file_box span::before{position: absolute;right: 5px;bottom: 0;width: 2px;height: 12px;transition: 0.3s;content: "";}
.form .inp .file_box span::after{position: absolute;right: 0;bottom: 5px;width: 12px;height: 2px;transition: 0.3s;content: "";}
.form .selarea{display: flex;flex-wrap: wrap;}
.form .selarea label{display: flex;align-items: center;margin-right: 40px;}
.form .selarea label:last-child{margin-right: 0;}
.form .selarea label input{display: none;}
.form .selarea label span{display: block;position: relative;width: 24px;height: 24px;transition: 0.3s;border-radius: 50%;}
.form .selarea label span::before{position: absolute;top: 50%;left: 50%;width: 0;height: 0;transition: 0.1s;content: "";transform: translate(-50%,-50%);border-radius: 50%;}
.form .selarea label input:checked + span::before{width: 50%;height: 50%;}
.form .selarea label p{padding-left: 10px;font-size: 1.25rem;font-weight: 300;transition: 0.3s;}
.form .textarea{padding: 20px;position: relative;transition: 0.3s;}
.form .textarea textarea{border: none;outline: none;width: 100%;height: 160px;background-color: transparent;font-family: 'Noto Sans KR';font-size: 1.25rem;font-weight: 300;line-height: 1.5em;resize: none;}
.form .textarea textarea::placeholder{font-size: 1.25rem;font-weight: 300;color: #666;}
.form .textarea .line{position: absolute;transition: 0.2s;opacity: 0;}
.form .textarea .line1{top: -2px;left: 0;width: 100%;height: 2px;}
.form .textarea .line2{top: -2px;right: -2px;width: 2px;height: calc(100% + 2px);}
.form .textarea .line3{right: -2px;bottom: -2px;width: calc(100% + 4px);height: 2px;}
.form .textarea .line4{top: -2px;left: -2px;width: 2px;height: calc(100% + 2px);}
.form .textarea textarea:focus ~ .line{opacity: 1;}
.form .term{width: 100%;}
.form .term_txt{padding: 20px;transition: 0.3s;}
.form .term_txt p{overflow-y: auto;height: 100px;font-size: 0.875rem;font-weight: 300;line-height: 1.4em;transition: 0.3s;}
.chk_box{margin-top: 20px;}
.chk_box label{display: flex;align-items: center;}
.chk_box input{display: none;}
.chk_box span{display: flex;align-items: center;justify-content: center;width: 18px;height: 18px;transform: translateY(1px);}
.chk_box span svg{width: 10px; stroke-dasharray: 90;stroke-dashoffset: 90;}
.chk_box input:checked ~ span svg{stroke-dashoffset: 0;}
.chk_box .chk_line{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:6px;}
.chk_box p{margin-left: 10px;font-size: 1rem;transition: 0.3s;}
.scrollbar::-webkit-scrollbar{width:3px;background-color: rgba(0,0,0,0);}
.scrollbar::-webkit-scrollbar-thumb{border-radius:10px;}
.cir_arr_btn{margin-top: 80px;text-align: center;}
.cir_arr_btn button{border: none;position: relative;width: 140px;height: 140px;background: none;}
.cir_arr_btn button .arr{position: absolute;top: 0;left: 0;z-index: 4;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;transition: 0.3s;}
.cir_arr_btn button::before{position: absolute;top: 0;left: 0;z-index: 2;width: 100%;height: 100%;transition: 0.6s;content:"";border-radius: 50%;}
.cir_arr_btn button::after{position: absolute;top: 0;left: 0;z-index: 1;width: 100%;height: 100%;transition: 0.6s;content:"";border-radius: 50%;transform: scale(0);}
.cir_arr_btn button .txt{position: absolute;top: 0;left: 0;z-index: 3;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: contain;animation: rotate 8s linear infinite;transition-delay: 0.2s;opacity: 0;}
.cir_arr_btn button:hover::before{transform: scale(0.4);}
.cir_arr_btn button:hover::after{transform: scale(1);}
.cir_arr_btn button:hover .txt{transition-delay: 0.3s;opacity: 1;}
.quick_btn{position: fixed;right: 50px;bottom: 20px;z-index: 50;}
.quick_btn::before{box-shadow: 2px 5px 10px rgb(0 0 0 / 40%);position: absolute;right: 0;left: 0;z-index: -1;width: 100%;height: 100%;transition: 0.6s;content: "";transform: scale(0.6);border-radius: 50%;}
.quick_btn::after{box-shadow: 2px 5px 10px rgb(0 0 0 / 40%);position: absolute;right: 0;left: 0;z-index: -1;width: 100%;height: 100%;transition: 0.6s;content: "";transform: scale(0);border-radius: 50%;}
.quick_btn:hover::before{transform: scale(0.2);}
.quick_btn:hover::after{transform: scale(1);}
.quick_btn button{border: none;position: relative;width: 104px;height: 104px;background: none;}
.quick_btn button .ico{position: absolute;top: 0;left: 0;z-index: 4;width: 100%;height: 100%;background-image: url(../images/quick-ico.svg);background-repeat: no-repeat;background-position: center;background-size: 22px auto;transition: 0.3s;}
.quick_btn button::before{position: absolute;top: 0;left: 0;z-index: 2;width: 100%;height: 100%;background-color: #cb1212;transition: 0.6s;content:"";border-radius: 50%;transform: scale(0.6);}
.quick_btn button .txt{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background-color: #cb1212;transition: 0.6s;border-radius: 50%;transform: scale(0);}
.quick_btn button .txt::after{position: absolute;top: 0;left: 0;z-index: 3;width: 100%;height: 100%;background-image: url(../images/quick-txt.png);background-repeat: no-repeat;background-position: center;background-size: contain;animation: rotate 8s linear infinite;content:"";}
@media (hover: hover) {
    .quick_btn button:hover::before{transform: scale(0.2);}
    .quick_btn button:hover .txt{transform: scale(1);}
}
.top_btn{position: fixed;right: 50px;bottom: 120px;z-index: 50;}
.top_btn.bot{bottom:20px;}
.top_btn::before{box-shadow: 2px 5px 10px rgb(0 0 0 / 40%);position: absolute;right: 0;left: 0;z-index: -1;width: 100%;height: 100%;transition: 0.6s;content: "";transform: scale(0.6);border-radius: 50%;}
.top_btn::after{box-shadow: 2px 5px 10px rgb(0 0 0 / 40%);position: absolute;right: 0;left: 0;z-index: -1;width: 100%;height: 100%;transition: 0.6s;content: "";transform: scale(0);border-radius: 50%;}
.top_btn:hover::before{transform: scale(0.2);}
.top_btn:hover::after{transform: scale(1);}
.top_btn button{border: none;position: relative;width: 104px;height: 104px;background: none;}
.top_btn button .ico{position: absolute;top: 0;left: 0;z-index: 4;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: 22px auto;transition: 0.3s;}
.top_btn button::before{position: absolute;top: 0;left: 0;z-index: 2;width: 100%;height: 100%;transition: 0.6s;content:"";border-radius: 50%;transform: scale(0.6);}
.top_btn button .txt{position: absolute;top: 0;left: 0;width: 100%;height: 100%;transition: 0.6s;border-radius: 50%;transform: scale(0);}
.top_btn button .txt::after{position: absolute;top: 0;left: 0;z-index: 3;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: contain;animation: rotate 8s linear infinite;content:"";}
@media (hover: hover) {
    .top_btn button:hover::before{transform: scale(0.2);}
    .top_btn button:hover .txt{transform: scale(1);}
}
@keyframes rotate {
	0% {transform: rotate(0deg);}
	50% {transform: rotate(180deg);}
	100% {transform: rotate(360deg);}
}
.map{margin: 300px 0 160px;}
.map_wrap{margin-top: 200px;position: relative;}
.map_wrap .lef{position: absolute;top: 0;left: 0;z-index: 10;width: 10%;height: 100%;content: "";}
.map_wrap .rig{position: absolute;top: 0;right: 0;z-index: 10;width: 10%;height: 100%;content: "";}
.map_area{overflow: hidden;height: 640px;}
.map_area #map{height: 100%;transform: scale(1.2);}
.map_area #map > div:first-child > div:first-child > div:nth-child(1),
.map_area #map > div:first-child > div:first-child > div:nth-child(2){filter: grayscale(100%);}
.color_wrap.black .contact_info dl dt{color: #aaa;}
.color_wrap.black .contact_info dl dd strong,
.color_wrap.black .contact_info dl dd span > span,
.color_wrap.black .form .tit,
.color_wrap.black .form dl dt,
.color_wrap.black .form .inp p,
.color_wrap.black .form .selarea label p,
.color_wrap.black .form .inp .file_box span,
.color_wrap.black .form .term_txt p,
.color_wrap.black .chk_box p,
.color_wrap.black .form .inp input[type=text],
.color_wrap.black .form .textarea textarea,
.color_wrap.black .form .inp .file_box .file_name{color: #fff;}
.color_wrap.black .form .selarea label span,
.color_wrap.black .chk_box span{border: 1px solid #fff;}
.color_wrap.black .form .selarea label span::before,
.color_wrap.black .form .inp .line,
.color_wrap.black .form .textarea .line,
.color_wrap.black .form .inp .file_box span::before,
.color_wrap.black .form .inp .file_box span::after,
.color_wrap.black .cir_arr_btn button::before,
.color_wrap.black .cir_arr_btn button::after{background-color: #fff;}
.color_wrap.black .form .inp{border-bottom: 1px solid #888;}
.color_wrap.black .form .textarea,
.color_wrap.black .form .term_txt{border: 1px solid #888;}
.color_wrap.black .chk_box .chk_line{stroke: #fff;}
.color_wrap.black .cir_arr_btn button .arr{background-image: url(../images/bl-arr.png);}
.color_wrap.black .cir_arr_btn button .txt{background-image: url(../images/cir_arr_txt_bl.png)}
.color_wrap.black .map_wrap .lef,
.color_wrap.black .map_wrap .rig{background-color: #101010;}
.color_wrap.black .contact_info dl dd strong{border-bottom: 2px solid #fff;}
.color_wrap.black .scrollbar::-webkit-scrollbar-thumb{background-color:#fff;}
.color_wrap.black .scrollbar::-webkit-scrollbar-track{background: linear-gradient(to left, rgba(0,0,0,0) 0% 33%, rgba(255,255,255,0.2) 33% 66% , rgba(0,0,0,0) 66% 100%);background-color:rgba(255,255,255,0.2);}
.color_wrap.black .form .inp input[type=text]::-moz-selection,
.color_wrap.black .form .textarea textarea::-moz-selection{background-color:#fff;color:#222;}
.color_wrap.black .form .inp input[type=text]::selection,
.color_wrap.black .form .textarea textarea::selection{background-color:#fff;color:#222;}
.color_wrap.black .top_btn button .ico{background-image: url(../images/top-ico-bl.svg);}
.color_wrap.black .top_btn button::before,
.color_wrap.black .top_btn button .txt{background-color: #fff;}
.color_wrap.black .top_btn button .txt::after{background-image: url(../images/top-txt-bl.png);}
.color_wrap.white .contact_info dl dt{color: #aaa;}
.color_wrap.white .contact_info dl dd strong,
.color_wrap.white .contact_info dl dd span > span,
.color_wrap.white .form .tit,
.color_wrap.white .form dl dt,
.color_wrap.white .form .inp p,
.color_wrap.white .form .selarea label p,
.color_wrap.white .form .inp .file_box span,
.color_wrap.white .form .term_txt p,
.color_wrap.white .chk_box p,
.color_wrap.white .form .inp input[type=text],
.color_wrap.white .form .textarea textarea,
.color_wrap.white .form .inp .file_box .file_name{color: #101010;}
.color_wrap.white .form .selarea label span,
.color_wrap.white .chk_box span{border: 1px solid #101010;}
.color_wrap.white .form .selarea label span::before,
.color_wrap.white .form .inp .line,
.color_wrap.white .form .textarea .line,
.color_wrap.white .form .inp .file_box span::before,
.color_wrap.white .form .inp .file_box span::after,
.color_wrap.white .cir_arr_btn button::before,
.color_wrap.white .cir_arr_btn button::after{background-color: #101010;}
.color_wrap.white .form .inp{border-bottom: 1px solid #ccc;}
.color_wrap.white .form .textarea,
.color_wrap.white .form .term_txt{border: 1px solid #ccc;}
.color_wrap.white .chk_box .chk_line{stroke: #101010;}
.color_wrap.white .cir_arr_btn button .arr{background-image: url(../images/wh-arr.png);}
.color_wrap.white .cir_arr_btn button .txt{background-image: url(../images/cir_arr_txt_wh.png)}
.color_wrap.white .map_wrap .lef,
.color_wrap.white .map_wrap .rig{background-color: #f8f7f5;}
.color_wrap.white .contact_info dl dd strong{border-bottom: 2px solid #101010;}
.color_wrap.white .scrollbar::-webkit-scrollbar-thumb{background-color:#101010;}
.color_wrap.white .scrollbar::-webkit-scrollbar-track{background: linear-gradient(to left, rgba(0,0,0,0) 0% 33%, rgba(16,16,16,0.2) 33% 66% , rgba(0,0,0,0) 66% 100%);background-color:rgba(16,16,16,0.2);}
.color_wrap.white .form .inp input[type=text]::-moz-selection,
.color_wrap.white .form .textarea textarea::-moz-selection{background-color:#222;color:#fff;}
.color_wrap.white .form .inp input[type=text]::selection,
.color_wrap.white .form .textarea textarea::selection{background-color:#222;color:#fff;}
.color_wrap.white .top_btn button .ico{background-image: url(../images/top-ico-wh.svg);}
.color_wrap.white .top_btn button::before,
.color_wrap.white .top_btn button .txt{background-color: #101010;}
.color_wrap.white .top_btn button .txt::after{background-image: url(../images/top-txt-wh.png);}
@media all and (max-width:1700px){
    .quick_btn{right: 10px;}
	.top_btn{right: 10px;}
}
@media all and (max-width:1200px){
    .quick_btn{right: 10px;bottom: 20px;}
    .quick_btn button{width: 50px;height: 50px;}
    .quick_btn button::before{transform: scale(1);}
    .quick_btn button .ico{background-size: 18px;}
    .quick_btn::after{box-shadow: 0px 3px 5px rgb(0 0 0 / 40%);transform: scale(0.95);}
	.top_btn{right: 10px;bottom: 80px;}
    .top_btn button{width: 50px;height: 50px;}
    .top_btn button::before{transform: scale(1);}
    .top_btn button .ico{background-size: 18px;}
    .top_btn::after{box-shadow: 0px 3px 5px rgb(0 0 0 / 40%);transform: scale(0.95);}
    .contact_info{margin-top: 40px;position: static;}
    .contact_info dl ~ dl{margin-top: 30px;}
    .contact_info dl dt{margin-bottom: 10px;}
    .contact{margin-top: 120px;}
    .form .tit{margin-bottom: 40px;}
    .form ul li dl,
    .form .inp{display: block;}
    .form dl dt{margin-bottom: 20px;}
    .form .inp p{margin-bottom: 5px;}
    .form dl dt,
    .form .inp p{width: 100%;}
    .form .selarea label{margin-right: 15px;margin-bottom: 10px;}
    .form .selarea label span{width: 18px;height: 18px;}
    .form .selarea label p{padding-left: 5px;}
    .form ul li{display: block;}
    .form ul li ~ li{margin-top: 20px;}
    .form .inp2{width: 100%;}
    .form .inp ~ .inp{margin-top: 20px;}
    .form .inp input[type=text],
    .form .inp .file_box .file_name{height: 45px;}
    .form .textarea,
    .form .term_txt{padding: 10px;}
    .form .textarea textarea,
    .form .term_txt p{height: 130px;}
    .chk_box{margin-top: 20px;}
    .chk_box span{width: 14px;height: 14px;}
    .chk_box span svg{width: 10px;}
    .cir_arr_btn button{width: 100px;height: 100px;}
    .cir_arr_btn button .arr{background-size: 26px;}
    .map{margin: 120px 0 80px;}
    .map_wrap{margin-top: 50px;}
    .map_area{height: 300px;}
    .chk_box p{margin-left: 6px;}
}

/*company*/
/*
.fix_h1{height: 520vh;}
.fix_h2{height: 440vh;}
*/
.mo_box{overflow: hidden;position: relative;}
/*
.mo_box .trigger{position: absolute;left: 0;}
.mo_box .trigger1{top: 50vh;}
.mo_box .trigger2{top: 90vh;}
.mo_box .trigger3{top: 130vh;}
.mo_box .trigger4{top: 170vh;}
.mo_box .trigger5{top: 210vh;}
.mo_box .trigger6{top: 350vh;}
.mo_box .trigger7{top: 550vh;}
.mo_box .trigger8{top: 640vh;}
*/
.company{position: relative;}
.company .line{position: absolute;height: 8px;}
.company .top_line{top: 0;left: 0;}
.company .bot_line{right: 0;bottom: 0;}
.company_box1 .line{width: 0%;transition:0.6s;}
.mo_box1{padding: 180px 0 220px;}
.formula{display: flex;align-items: center;padding: 270px 0;}
.formula ul{display: flex;align-items: center;justify-content: center;width: 100%;font-size: 7rem;}
.formula ul li{font-weight: 600;transition:0.6s;opacity: 0;}
.formula .num1{transition-delay:0.4s;}
.formula .num2{transition-delay:0.7s;}
.formula .num3{transition-delay:0.4s;}
.formula .num4{transition-delay:1s;}
.formula .num5{transition-delay:0.4s;}
.formula ul li.sign1{margin: 0 50px;}
.formula ul li.sign2{margin: 0 30px;}
.formula ul li.num4{transform: rotate(90deg);}
.company_box1.on .line{width:100%;}
.company_box1.on .formula  ul li{opacity:1;}
.company_box1.on .formula  .sign2{transform:none;}
.mo_box2{padding-bottom: 300px;overflow: visible;}
.mean{display: flex;align-items: center;justify-content: center;text-align: center;white-space: nowrap;}
.mean p span{display: block;font-size:7rem;font-weight: 600;color: transparent;transition: 0.4s;opacity:0;}
.mean p .top{transform:translate(0,-80px);}
.mean p .bot{transform:translate(0,80px);}
.mean p strong{display: block;padding: 20px 0 60px;font-size: 3rem;font-weight: 600;line-height: 1.75em;transition: 0.3s;transition-delay:0.4s;opacity:0;}
.mean p strong em{background-repeat: no-repeat;background-position: left center;-webkit-background-clip: text;background-size: 0% 100%;}
.mean p strong .txt1{transition:0.3s cubic-bezier(1,1,1,1);transition-delay:0.8s;}
.mean p strong .txt2{transition:0.7s cubic-bezier(1,1,1,1);transition-delay:1.2s;}
.company_box2.on .mean p span,
.company_box2.on .mean p strong{opacity:1;}
.company_box2.on .mean p .top,
.company_box2.on .mean p .bot{transform:none;}
.company_box2.on .mean p strong .txt1,
.company_box2.on .mean p strong .txt2{background-size: 100% 100%;}
.mo_box3{padding: 220px 0 360px;}
.vision{display: flex;align-items: center;}
.vision .tri_box{display: flex;justify-content: space-between;position: relative;width: 100%;text-align: center;}            
.vision .tri_box .tri{display: flex;align-items: flex-end;position: relative;}
.vision .tri_lef .tri_top{background: url(../images/tri-lef-bl.png) no-repeat center;background-size: 0;text-align: right;}
.vision .tri_lef .tri_top > div{display: inline-block;position: relative;transform: rotate(15deg);}
.vision .tri_lef .tri_img{display: inline-block;position: relative;-webkit-mask-image: url(../images/tri-lef-bl.png);-webkit-mask-repeat: no-repeat;-webkit-mask-position: center bottom;-webkit-mask-size: contain;}
.vision .tri_lef .tri_img ul{position: absolute;top: 15%;left: 15%;width: 100%;transform: rotate(30deg);}
.vision .tri_lef .tri_img ul li{position: relative;width: 100%;height: 15px;}
.vision .tri_lef .tri_img ul li ~ li{margin-top: 15px;}
.vision .tri_lef .tri_img ul li span{display: block;position: relative;width: 100%;height: 0;transition: 0.3s;}
.vision .tri_lef .tri_img ul li span::before{position: absolute;top: 0;left: 0;width: 100%;height: 100%;content: "";}
.vision .tri_cen .tri_top{transition: 0.3s;transition-delay: 0.8s;}
.vision .tri_cen .tri_img{display: inline-block;position: relative;background: url(../images/tri-lef-wh.png) no-repeat center;background-size: 0;}
.vision .tri_cen .tri_img .tri2{position: absolute;top: 0;left: 0;transition: 0.5s;transition-delay: 1s;transform-origin: 50% 67%;transform: rotate(180deg);}
.vision .tri_cen .tri_img .tri2 > img{position: relative;z-index: 10;}
.vision .tri_cen .tri_img .tri_line{position: relative;}
.vision .tri_cen .tri_img .tri_line li{opacity: 0;}
.vision .tri_cen .tri_img .tri_line li:nth-child(n+2){position: absolute;background-repeat: no-repeat;background-size: cover;opacity: 1;}
.vision .tri_cen .tri_img .tri1 .tri_line li:nth-child(2){bottom: 0;width: 0;height: 100%;}
.vision .tri_cen .tri_img .tri1 .tri_line li:nth-child(3){top: 0;width: 0;height: 100%;}
.vision .tri_cen .tri_img .tri1 .tri_line li:nth-child(4){right: 0;width: 100%;height: 0;}
.vision .tri_cen .tri_img .tri2 .tri_line li:nth-child(2){bottom: 0;left: 0;width: 0;height: 100%;transition: 0.6s;transition-delay: 1.3s;}
.vision .tri_cen .tri_img .tri2 .tri_line li:nth-child(3){top: 0;right: 0;width: 0;height: 100%;background-position: right center;transition: 1.1s;transition-delay: 1.3s;}
.vision .tri_cen .tri_img .tri2 .tri_line li:nth-child(4){top: 0;right: 0;width: 100%;height: 0;transition: 0.6s;transition-delay: 1.3s;}
.vision .tri_cen .tri_bg{position: absolute;top: 0;left: 0;z-index: -1;width: 100%;height: 100%;-webkit-mask-repeat: no-repeat;-webkit-mask-position: center;-webkit-mask-size: 95%;}
.vision .tri_cen .tri_bg ul{width: 100%;transform: rotate(45deg);}
.vision .tri_cen .tri_bg ul li{display: flex;align-items: flex-end;position: relative;width: 100%;height: 15px;}
.vision .tri_cen .tri_bg ul li ~ li{margin-top: 15px;}
.vision .tri_cen .tri_bg ul li span{display: block;margin: auto 0 0 0;position: relative;width: 100%;height: 0;transition: 0.3s;transition-delay: 1.8s;}
.vision .tri_cen .tri_bg ul li span::before{position: absolute;top: 0;left: 0;width: 100%;height: 100%;content: "";}
.vision .tri_rig .tri_top{text-align: left;}
.vision .tri_rig .tri_img{display: inline-block;position: relative;transform: rotate(-45deg);}
.vision .tri_rig .tri_img ul{display: inline-block;position:relative;}
.vision .tri_rig .tri_img ul li{opacity: 0;}
.vision .tri_rig .tri_img ul li:nth-child(n+2){position: absolute;background-repeat: no-repeat;background-size: cover;opacity: 1;}
.vision .tri_rig .tri_img ul li:nth-child(2){bottom: 0;width: 0;height: 100%;}
.vision .tri_rig .tri_img ul li:nth-child(3){top: 0;width: 0;height: 100%;}
.vision .tri_rig .tri_img ul li:nth-child(4){right: 0;width: 100%;height: 0;}
.vision .tri_arr span{display: block;margin-top: -30px;position: relative;top: 26%;width: 39px;height: 60px;background-repeat: no-repeat;background-position: center;background-size: contain;transition: 0.4s;transition-delay: 0.8s;}
.vision .tri_arr.lef span{margin-left: -50px;opacity: 0;}
.vision .tri_arr.rig span{margin-right: -50px;opacity: 0;}
.vision .tri_txt{position: absolute;width: 100%;text-align: center;}
.vision .tri_txt span{display: inline-block;overflow: hidden;}
.vision .tri_txt span em{display: inline-block;font-weight: 600;transition: 0.8s;transition-delay: 0.3s;}
.vision .tri_lef .tri_txt.txt1{top: calc(100% + 20px);left: 0;}
.vision .tri_lef .tri_txt.txt2{bottom: 5px;left:30px;transform: rotate(60deg);transform-origin: 100% 0;}
.vision .tri_lef .tri_txt.txt3{bottom: 15px;left:-15px;transform: rotate(-60deg);transform-origin: 0 100%;}
.vision .tri_lef .tri_txt span em{transform: translate(0,110%);}
.vision .tri_rig .tri_txt.txt1{bottom: 35px;left:0;}
.vision .tri_rig .tri_txt.txt2{bottom: -35px;left:-25px;transform: rotate(60deg);transform-origin: 100% 0;}
.vision .tri_rig .tri_txt.txt3{bottom: calc(100% - 15px);left: calc(50% + 30px);transform: rotate(120deg);transform-origin: 0 100%;}
.vision .tri_rig .tri_txt span em{transform: translate(110%,0);}
.vision .tri_cen .tri_txt{top: 67%;left: 0;line-height: 1.5em;transform: translate(0, -50%);}
.vision .tri_cen .tri_txt span em{font-weight: 600;transition-delay: 1.9s;transform: translate(0,110%);}
.vision .tri_box .tri dl{padding-top: 180px;}
.vision .tri_box .tri dl dt{margin-bottom: 50px;overflow: hidden;font-size: 2.25rem;font-weight: 600;}
.vision .tri_box .tri dl dt span{display: block;transition: 0.8s;transition-delay: 1.1s;transform: translate(0,110%);}
.vision .tri_box .tri dl dd{font-size: 1.25rem;font-weight: 300;line-height: 1.8em;}
.vision .tri_box .tri dl dd p{overflow: hidden;}
.vision .tri_box .tri dl dd p span{display: block;transition: 0.8s;transition-delay: 1.3s;transform: translate(0,110%);}
.vision.on .tri_arr.lef span,
.vision.on .tri_arr.rig span{margin-right: 0;margin-left: 0;opacity: 1;}
.vision.on .tri_txt span em{transform: none;}
.vision.on .tri_lef .tri_img ul li span{height: 100%;}
.vision.on .tri_lef .tri_img ul li span::before{animation: tri_lef_line 2s cubic-bezier( 1,1,1,1 ) infinite;animation-delay: 0.6s;}
@keyframes tri_lef_line {
    0% {top:0}
    100% {top:200%}
}
.vision.on .tri_cen .tri_img .tri_bg ul li span{height: 100%;}
.vision.on .tri_cen .tri_img .tri_bg ul li span::before{animation: tri_cen_line 2s cubic-bezier( 1,1,1,1 ) infinite;animation-delay: 2s;}
@keyframes tri_cen_line {
    0% {top:0}
    100% {top:-200%}
}
.vision.on .tri_rig .tri_img ul li:nth-child(2){animation: tri_rig_line1 5s infinite;}
@keyframes tri_rig_line1 {
    10% {left: 0;width: 100%;background-position: left bottom;}
    80% {right: 0;left: auto;width: 100%;background-position: right bottom;}
    90% {right: 0;left: auto;width: 0%;background-position: right bottom;}
    100% {right: 0;left: auto;width: 0%;background-position: right bottom;}
}
.vision.on .tri_rig .tri_img ul li:nth-child(3){animation: tri_rig_line2 5s infinite;}
@keyframes tri_rig_line2 {
    0% {right: 0;left:auto;background-position: right top;}
    20% {right: 0;left:auto;width: 100%;background-position: right top;}
    50% {right: 0;width: 100%;background-position: left top;}
    80% {right: auto;left: 0;width: 100%;background-position: left top;}
    100% {right: auto;left: 0;width: 0%;background-position: left top;}
}
.vision.on .tri_rig .tri_img ul li:nth-child(4){animation: tri_rig_line3 5s infinite;}
@keyframes tri_rig_line3 {
    0% {top: 0;}
    10% {height: 100%;}
    80% {top: auto;bottom: 0;height: 100%;background-position: left bottom;}
    90% {top: auto;bottom: 0;height: 0;background-position: left bottom;}
    100% {top: auto;bottom: 0;height: 0;background-position: left bottom;}
}
.vision.on .tri_cen .tri_img .tri1 ul li:nth-child(2){animation: tri_cen_line1 5s infinite;animation-delay: 1.3s;}
@keyframes tri_cen_line1 {
    10% {left: 0;width: 100%;background-position: left bottom;}
    80% {right: 0;left: auto;width: 100%;background-position: right bottom;}
    90% {right: 0;left: auto;width: 0%;background-position: right bottom;}
    100% {right: 0;left: auto;width: 0%;background-position: right bottom;}
}
.vision.on .tri_cen .tri_img .tri1 ul li:nth-child(3){animation: tri_cen_line2 5s infinite;animation-delay: 1.3s;}
@keyframes tri_cen_line2 {
    0% {right: 0;left:auto;background-position: right top;}
    20% {right: 0;left:auto;width: 100%;background-position: right top;}
    50% {right: 0;width: 100%;background-position: left top;}
    80% {right: auto;left: 0;width: 100%;background-position: left top;}
    100% {right: auto;left: 0;width: 0%;background-position: left top;}
}
.vision.on .tri_cen .tri_img .tri1 ul li:nth-child(4){animation: tri_cen_line3 5s infinite;animation-delay: 1.3s;}
@keyframes tri_cen_line3 {
    0% {top: 0;}
    10% {height: 100%;}
    80% {top: auto;bottom: 0;height: 100%;background-position: left bottom;}
    90% {top: auto;bottom: 0;height: 0;background-position: left bottom;}
    100% {top: auto;bottom: 0;height: 0;background-position: left bottom;}
}
.vision.on .tri_cen .tri2 .tri_line li:nth-child(n+2){width: 100%;height: 100%;}
.vision.on .tri_box .tri dl dt span{transform: translate(0,0);}
.vision.on .tri_box .tri dl dd span{transform: translate(0,0);}
.services{margin-top: 200px;overflow: hidden;position: relative;transition: 0.3s;}
.services ul::before{margin-left: -4px;position: absolute;top: 0;left: 50%;z-index: 10;width: 8px;height: 100%;transition: 0.3s;content: "";}
.services ul::after{margin-top: -4px;position: absolute;top: 50%;left: 0;z-index: 10;width: 100%;height: 8px;transition: 0.3s;content: "";}
.services ul{display: flex;flex-wrap: wrap;position: relative;}
.services ul li{position: relative;width: 50%;transition: 0.4s;transition-timing-function: cubic-bezier( 1,1,1,1 );}
.services ul li .over{position: absolute;top: 0;left: 0;z-index: 15;width: 100%;height: 100%;}
.services .img{padding-bottom: 76.5%;position: relative;}
.services .img .bg{position: absolute;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: cover;transition: 0.4s;transition-timing-function: cubic-bezier( 1,1,1,1 );}
.services .box1 .img .bg{top: 0;left: 0;background-image: url(../images/services-bg1.jpg);}
.services .box2 .img .bg{top: 0;right: 0;background-image: url(../images/services-bg2.jpg);}
.services .box3 .img .bg{bottom: 0;left: 0;background-image: url(../images/services-bg3.jpg);}
.services .box4 .img .bg{right: 0;bottom: 0;background-image: url(../images/services-bg4.jpg);}
.services .txt{display: flex;align-items: center;justify-content: center;position: absolute;top: 0;left: 0;width: 100%;height: 100%;text-align: center;transition: 0.5s;}
.services .txt dt{overflow: hidden;font-size: 2.25rem;font-weight: 600;color: #fff;transition: 0.3s;}
.services .txt dd{overflow: hidden;max-height: 0;transition: 0.6s;transition-delay: 0.2s;}
.services .txt dd p{overflow: hidden;font-size: 1.25rem;font-weight: 300;line-height: 1.8em;color: #fff;}
.services .txt dd p span{display: block;transition: 0.5s;transition-delay: 0s;transform: translate(0,110%);}
.services ul li:hover .txt{background-color: rgba(16,16,16,0.8);}
.services ul li:hover .txt dd{margin-top: 45px;max-height: 200px;transition-delay: 0s;}
.services ul li:hover .txt dd p span{transition-delay: 0.2s;transform: none;}
.mo_box5{padding: 360px 0 180px;}
.overview{margin-top: 200px;}
.overview .tit{display: flex;align-items: center;margin-bottom: 80px;overflow: hidden;font-size: 2.25rem;font-weight: 600;line-height: 1.3em;transition: 0.3s;}
.overview ul{display: flex;align-items: center;justify-content: space-between;flex-wrap: wrap;}
.overview ul li{width: 47%;}
.overview ul li:nth-child(n+3){margin-top: 50px;}
.overview dl{display: flex;align-items: center;padding: 25px 0;overflow: hidden;position: relative;transition: 0.3s;}
.overview dl dt{flex-shrink: 0;width: 135px;font-size: 1.25rem;font-weight: 600;color: #fff;transition: 0.3s;}
.overview dl dd{font-size: 1.25rem;font-weight: 300;line-height: 1.3em;color: #fff;transition: 0.3s;}
.mo_box6{padding: 180px 0 60px;}
.partners{margin-top: 200px;padding: 120px 0;position: relative;}
.partners .line{position: absolute;width: 0%;height: 8px;transition: 1s;}
.partners .top_line{top: 0;left: 0;}
.partners .bot_line{right: 0;bottom: 0;}
.partners ul{display: flex;align-items: center;flex-wrap: wrap;}
.partners ul li{padding: 0 10px;width: 12.5%;text-align: center;transition: 0.3s;}
.partners ul li:nth-child(n+9){margin-top: 130px;}
.partners .line.on{width: 100%;}
.scroll{margin-right:-14px;position:fixed;right:50%;bottom:40px;z-index: 10;width: 28px;height: 41px;background-repeat: no-repeat;background-position: center;background-size: contain;transition:0.3s;}
.scroll span{display: block;position: relative;width: 100%;height: 100%;}
.scroll span::before{position: absolute;top: 7px;left: 50%;width: 4px;height: 4px;animation: scroll_icon 1.5s infinite;content: "";border-radius: 50%;transform: translate(-50%,0);}
.scroll.none{opacity:0;}
@keyframes scroll_icon{
    0%{top: 7px;}
    60%{top: 15px;opacity: 0;}
    100%{opacity: 0;}
}
.color_wrap.black .company .line{background-color: #fff;}
.color_wrap.black .formula ul li{color: #fff;}
.color_wrap.black .formula ul li.bor{color: transparent;-webkit-text-stroke: 1px #fff;}
.color_wrap.black .mean p span{-webkit-text-stroke: 1px #fff;}
.color_wrap.black .mean p strong{color: rgba(255,255,255,0.4);}
.color_wrap.black .mean p strong em{background-image: linear-gradient(0deg, #fff 0%, #fff 100%);}
.color_wrap.black .vision .tri_txt span em{color: #fff;}
.color_wrap.black .vision .tri_lef .tri_img ul li span::before{background-color: #fff;}
.color_wrap.black .vision .tri_cen .tri_bg ul{background-color: #101010;}
.color_wrap.black .vision .tri_cen .tri_bg ul li span::before{background-color: #fff;}
.color_wrap.black .vision .tri_cen .tri_txt span em{text-shadow: -2px 0 #101010, 0 2px #101010, 2px 0 #101010, 0 -2px #101010;}
.color_wrap.black .vision .tri_cen .tri_img .tri_line li:nth-child(2){background-image: url(../images/tri-rig-1-wh.png);}
.color_wrap.black .vision .tri_cen .tri_img .tri_line li:nth-child(3){background-image: url(../images/tri-rig-2-wh.png);}
.color_wrap.black .vision .tri_cen .tri_img .tri_line li:nth-child(4){background-image: url(../images/tri-rig-3-wh.png);}
.color_wrap.black .vision .tri_rig .tri_img ul li:nth-child(2){background-image: url(../images/tri-rig-1-wh.png);}
.color_wrap.black .vision .tri_rig .tri_img ul li:nth-child(3){background-image: url(../images/tri-rig-2-wh.png);}
.color_wrap.black .vision .tri_rig .tri_img ul li:nth-child(4){background-image: url(../images/tri-rig-3-wh.png);}
.color_wrap.black .vision .tri_box .tri dl dt,
.color_wrap.black .vision .tri_box .tri dl dd{color: #fff;}
.color_wrap.black .vision .tri_arr.lef span{background-image: url(../images/tri-arr-lef-wh.png);}
.color_wrap.black .vision .tri_arr.rig span{background-image: url(../images/tri-arr-rig-wh.png);}
.color_wrap.black .vision .tri_lef::after{color: #fff;}
.color_wrap.black .vision .tri_cen::before{background-image: url(../images/tri-arr-lef-wh.png);}
.color_wrap.black .services{border-top: 8px solid #fff;border-bottom: 8px solid #fff;}
.color_wrap.black .services ul::before,
.color_wrap.black .services ul::after{background-color: #fff;}
.color_wrap.black .services ul li:hover .txt{background-color: rgba(16,16,16,0.9);}
.color_wrap.black .overview .tit{color: #fff;}
.color_wrap.black .overview dl{border-bottom: 1px solid #888;}
.color_wrap.black .overview dl dt,
.color_wrap.black .overview dl dd{color: #fff;}
.color_wrap.black .overview dl:hover{border-color: #fff;}
.color_wrap.black .partners .line{background-color: #fff;}
.color_wrap.black .vision .tri_cen .tri_bg{-webkit-mask-image: url(../images/tri-lef-bl.png);}
.color_wrap.black .scroll{background-image:url(../images/scroll-icon-wh.svg);}
.color_wrap.black .scroll span::before{background-color:#fff;}
.color_wrap.white .company .line{background-color: #101010;}
.color_wrap.white .formula ul li{color: #101010;}
.color_wrap.white .formula ul li.bor{color: transparent;-webkit-text-stroke: 1px #101010;}
.color_wrap.white .mean p span{-webkit-text-stroke: 1px #101010;}
.color_wrap.white .mean p strong{color: rgba(16,16,16,0.4);}
.color_wrap.white .mean p strong em{background-image: linear-gradient(0deg, #101010 0%, #101010 100%);}
.color_wrap.white .vision .tri_txt span em{color: #101010;}
.color_wrap.white .vision .tri_lef .tri_img ul li span::before{background-color: #101010;}
.color_wrap.white .vision .tri_cen .tri_bg ul{background-color: #fff;}
.color_wrap.white .vision .tri_cen .tri_bg ul li span::before{background-color: #101010;}
.color_wrap.white .vision .tri_cen .tri_txt span em{text-shadow: -2px 0 #fff, 0 2px #fff, 2px 0 #fff, 0 -2px #fff;}
.color_wrap.white .vision .tri_cen .tri_img .tri_line li:nth-child(2){background-image: url(../images/tri-rig-1-bl.png);}
.color_wrap.white .vision .tri_cen .tri_img .tri_line li:nth-child(3){background-image: url(../images/tri-rig-2-bl.png);}
.color_wrap.white .vision .tri_cen .tri_img .tri_line li:nth-child(4){background-image: url(../images/tri-rig-3-bl.png);}
.color_wrap.white .vision .tri_rig .tri_img ul li:nth-child(2){background-image: url(../images/tri-rig-1-bl.png);}
.color_wrap.white .vision .tri_rig .tri_img ul li:nth-child(3){background-image: url(../images/tri-rig-2-bl.png);}
.color_wrap.white .vision .tri_rig .tri_img ul li:nth-child(4){background-image: url(../images/tri-rig-3-bl.png);}
.color_wrap.white .vision .tri_box .tri dl dt,
.color_wrap.white .vision .tri_box .tri dl dd{color: #101010;}
.color_wrap.white .vision .tri_arr.lef span{background-image: url(../images/tri-arr-lef-bl.png);}
.color_wrap.white .vision .tri_arr.rig span{background-image: url(../images/tri-arr-rig-bl.png);}
.color_wrap.white .vision .tri_lef::after{color: #101010;}
.color_wrap.white .vision .tri_cen::before{background-image: url(../images/tri-arr-lef-bl.png);}
.color_wrap.white .services{border-top: 8px solid #101010;border-bottom: 8px solid #101010;}
.color_wrap.white .services ul::before,
.color_wrap.white .services ul::after{background-color: #101010;}
.color_wrap.white .services ul li:hover .txt{background-color: rgba(255,255,255,0.9);}
.color_wrap.white .services ul li:hover .txt dt,
.color_wrap.white .services ul li:hover .txt dd p{color: #101010;}
.color_wrap.white .overview .tit{color: #101010;}
.color_wrap.white .overview dl{border-bottom: 2px solid #cfcfcf;}
.color_wrap.white .overview dl dt,
.color_wrap.white .overview dl dd{color: #101010;}
.color_wrap.white .overview dl:hover{border-color: #101010;}
.color_wrap.white .partners .line{background-color: #101010;}
.color_wrap.white .partners ul li{filter: invert(1);}
.color_wrap.white .vision .tri_cen .tri_bg{-webkit-mask-image: url(../images/tri-lef-wh.png);}
.color_wrap.white .scroll{background-image:url(../images/scroll-icon-bl.svg);}
.color_wrap.white .scroll span::before{background-color:#101010;}
/*
@media all and (max-width:1200px){
    .formula ul{font-size: 5rem;}
    .formula ul li.sign1{margin: 0 30px;}
    .formula ul li.sign2{margin: 0 20px;}
    .mo_box2{padding-bottom: 100px;}
    .mean p strong{font-size: 2.5rem;}
    .mo_box3{padding: 120px 0 300px;}
    .vision{padding: 0 20px;}
    .vision .tri_arr span{width: 26px;height: 40px;}
    .vision .tri_rig .tri_top,
    .vision .tri_lef .tri_top,
    .vision .tri_cen .tri_top{width: 200px;}
    .vision .tri_lef .tri_txt.txt1{top: calc(100% + 15px);}
    .vision .tri_lef .tri_txt.txt2{left: 25px;bottom: 0px;}
    .vision .tri_lef .tri_txt.txt3{left: -5px;bottom: 5px;}
    .vision .tri_rig .tri_txt.txt1{bottom: 25px;}
    .vision .tri_rig .tri_txt.txt2{left: -20px;bottom: -25px;}
    .vision .tri_rig .tri_txt.txt3{left: calc(50% + 25px);bottom: calc(100% - 10px);}
    .vision .tri_box .tri dl dt{margin-bottom: 30px;font-size: 2rem;}
    .vision .tri_box .tri dl dd{font-size: 1rem;}
    .vision .tri_box .tri dl{padding-top: 130px;}
    .services{margin-top: 100px;}
    .services .txt dt{font-size: 2rem;}
    .services .txt dd p{font-size: 1rem;}
    .services ul li:hover .txt dd{margin-top: 30px;}
    .mo_box5{padding: 300px 0 100px;}
    .overview{margin-top: 100px;}
    .overview .tit{margin-bottom: 40px;}
    .overview dl dt{width: 100px;font-size: 1.125rem;}
    .overview dl dd{font-size: 1.125rem;}
    .overview ul li:nth-child(n+3){margin-top: 30px;}
    .mo_box6{padding: 200px 0 100px;}
    .partners{margin-top: 100px;padding: 70px 0;}
    .partners ul li:nth-child(n+9){margin-top: 30px;}
    .partners ul li{padding: 0 20px;}
}
*/
@media all and (max-width:1200px){
    .company .line{height: 5px;}
	.mo_box1{padding:100px 0 140px;}
	.formula{padding:80px 0;}
    .formula ul{justify-content: center;flex-wrap: wrap;font-size: 12vw;text-align: center;}
    .formula ul li.num1{width: 100%;}
    .formula ul li.num2{width: 100%;transform: rotate(90deg);}
    .formula ul li.sign1{margin: 20px 0;}
    .formula ul li.sign2{margin: 0 1vh;}
    .mo_box2{padding-bottom: 180px;}
    .mean p span{font-size: 10vh;}
    .mean p strong{padding: 10px 0 30px;font-size: 3.5vh;}
    .mo_box3{padding: 60px 0 200px;}
    .vision{padding: 0;}
    .vision .tri_box{flex-wrap: wrap;}
    .vision .tri_box .tri{align-items:baseline;}
    .vision .tri_box .tri_cen,
    .vision .tri_box .tri > div{width: 100%;}
    .vision .tri_lef{padding-right: 20px;width: 50%;order: 1;}
    .vision .tri_rig{padding-left: 20px;width: 50%;order: 2;}
    .vision .tri_cen{padding-top: 100px;order: 3;}
    .vision .tri_cen::before{margin-top: -20px;margin-left: -13px;position: absolute;top: 50px;left: 50%;width: 26px;height: 40px;background-repeat: no-repeat;background-size: contain;transition: 0.3s;transition-delay: 1.4s;content: "";transform: rotate(90deg);opacity: 0;}
    .vision .tri_lef .tri_top{margin: 0 auto;position: relative;left: 10px;width: 120px;}
    .vision .tri_rig .tri_top{margin: 0 auto;position: relative;right: 10px;width: 120px;}
    .vision .tri_cen .tri_top{margin: 0 auto;width: 160px;}
    .vision .tri_lef .tri_img ul li{height: 8px;}
    .vision .tri_lef .tri_img ul li ~ li{margin-top: 8px;}
    .vision .tri_cen .tri_bg ul li{height: 9px;}
    .vision .tri_cen .tri_bg ul li ~ li{margin-top: 9px;}
    .vision .tri_txt{font-size: 0.8rem;}
    .vision .tri_lef .tri_txt.txt1{top: calc(100% + 7px);}
    .vision .tri_lef .tri_txt.txt2{left: 15px;}
    .vision .tri_rig .tri_txt.txt1{bottom: 10px;}
    .vision .tri_rig .tri_txt.txt2{bottom: -15px;left: -10px;}
    .vision .tri_rig .tri_txt.txt3{bottom: calc(100% - 5px);left: calc(50% + 10px);}
    .vision .tri_arr{display: none;}
    .vision .tri_lef::after{position: absolute;top: 50%;right: 0;font-size: 4rem;font-weight: 600;transition: 0.3s;transition-delay: 1s;content: "+";transform: translate(50%,-50%);opacity: 0;}
    .vision .tri_box .tri dl{padding-top: 60px;}
    .vision .tri_box .tri_cen dl{padding-top: 80px;}
    .vision .tri_box .tri dl dt{margin-bottom: 10px;font-size: 1.5rem;}
    .vision .tri_box .tri dl dd{font-size: 0.8rem;}
    .vision.on .tri_lef::after{opacity: 1;}
    .vision.on .tri_cen::before{opacity: 1;}
    .color_wrap.black .vision .tri_cen .tri_txt span em {text-shadow: -1px 0 #101010, 0 1px #101010, 1px 0 #101010, 0 -1px #101010;}
    .color_wrap.white .vision .tri_cen .tri_txt span em {text-shadow: -1px 0 #fff, 0 1px #fff, 1px 0 #fff, 0 -1px #fff;}
    .services{margin-top: 50px;border-width: 5px;border-width: 5px !important;}
    .services ul{display: block;}
    .services ul::before,
    .services ul::after{display: none;}
    .services ul li{width: 100%;}
    .services .img{padding-bottom: 45%;}
    .services .txt dt{font-size: 1.4rem;}
    .services .txt dd p{font-size: 0.8rem;}
    .services ul li:hover .txt dd{margin-top: 15px;}
    .color_wrap.black .services ul li ~ li{border-top: 5px solid #fff;}
    .color_wrap.white .services ul li ~ li{border-top: 5px solid #101010;}
    .mo_box5{padding: 200px 0 100px;}
    .overview{margin-top: 50px;}
    .overview .tit{margin-bottom: 20px;font-size: 1.5rem;}
    .overview ul li{width: 100%;}
    .overview ul li:nth-child(n+3){margin-top: 0;}
    .overview dl{padding: 15px 0;}
    .overview dl dt{width: 80px;font-size: 1rem;}
    .overview dl dd{font-size: 1rem;}
    .mo_box6{padding: 100px 0;}
    .partners{margin-top: 50px;padding: 40px 0;}
    .partners .line{height: 5px;}
    .partners ul li{padding: 0 15px;width: 25%;}
    .partners ul li:nth-child(n+5){margin-top: 30px;}
	.scroll{margin-right: -12px;bottom: 20px;width: 24px;height: 38px;}
}

/* contact form */


.map .con_tit p{text-align: left;}


.contact_form .fit{display: flex;padding: 0 50px;box-sizing: border-box;}

.contact_form .lef.fix{position: sticky; top: 180px; left: 0; height: 560px;}

.color_wrap.black .contact_form .lef{color: #fff;}
.color_wrap.white .contact_form .lef{color: #101010;}
.contact_form .fit .lef{width: 100%;}
.contact_form .fit .lef .con_tit p{ margin-bottom: 70px; line-height: 1;text-align: left;}
.contact_form .fit .lef .detail{font-size: 1.75rem; line-height: 1.5;}
.contact_box .detail span{transition-property: opacity, transform;}

.q_inq_box{margin-top: 70px;}
.q_inq_box > p:not(.mail_info){ margin-bottom: 25px; font-family: 'Play';font-size: 1.25rem; color: #aaa;}
.q_inq_box > a{ position: relative;font-family: 'Play'; font-size: 2rem; font-weight: 700;}
.q_inq_box > a::after{ display: block; position: absolute; bottom:-8px; left: 0;width: 100%; height: 3px; content: ''}
.q_inq_box > .mail_info{font-family: 'Play'; font-size: 1.25rem;}
.q_inq_box.tell{ transition: .8s; transition-property: opacity, transform; transition-delay: .8s;opacity: 0;}
.q_inq_box.mail{ transition: .8s; transition-property: opacity, transform; transition-delay: 1s;opacity: 0;}

.contact_form .fit .rig{ transition: .8s; transition-delay: 1.4s;opacity: 0;}
.contact_form .fit .rig.active{opacity: 1;}
.contact_form .lef.active .q_inq_box.tell,
.contact_form .lef.active .q_inq_box.mail{opacity: 1;}

.contact_form .fit .rig{ flex-shrink: 0; width: 100%;max-width: 890px;}
.contact_form .fit .rig form{padding-right: 90px; box-sizing: border-box;}
.contact_form .button-wrap input:checked + span{ border: 1px solid transparent !important;font-weight: 600;}

.contact_form .question{ display: flex; align-items: center; margin-bottom: 40px;font-size: 1.875rem;}
.contact_form .question em{font-size: 0.94rem;}
.contact_form .form-group~.form-group {margin-top: 80px;}
.color_wrap.black .contact_form .question{color: #fff;}
.color_wrap.black .contact_form .question em{color: #aaa;}
.color_wrap.black .q_inq_box > a::after{background: #fff;}
.color_wrap.white .contact_form .question{color: #101010;}
.color_wrap.white .contact_form .question em{color: #aaa;}
.color_wrap.white .q_inq_box > a::after{background: #101010;}

.contact_form .button-wrap {display: flex; gap: 10px; flex-wrap: wrap;}
.contact_form .button-wrap input[type="checkbox"]{display: none; }
.contact_form .button-wrap input[type="radio"]{display: none; }
.contact_form .button-wrap span{ display: inline-block; padding: 0 32px;width: auto; height: 56px; background: transparent; font-size: 1.125em; line-height: 54px; border-radius: 28px; box-sizing: border-box;}
.color_wrap.black .contact_form .button-wrap span{border: 1px solid #888; color: #fff;}
.color_wrap.white .contact_form .button-wrap span{border: 1px solid #ccc; color: #101010;}
.color_wrap.black .contact_form .button-wrap input:checked + span{background-color: #fff; color: #101010;}
.color_wrap.white .contact_form .button-wrap input:checked + span{background-color: #101010; color: #fff;}

.contact_form .input-wrap{display: grid; grid-template-columns: 1fr 1fr; column-gap: 40px;}
.contact_form .input-wrap input[type="text"]{ padding: 0px; border:none; width: 100%; height: 60px; background: transparent; font-size: 1.125em; box-sizing: border-box;}
.contact_form .input-wrap input[type="text"]:nth-of-type(3),
.contact_form .input-wrap input[type="text"]:nth-of-type(4) {margin-top: 10px;}
.contact_form .input-wrap input[type="text"]:focus{border-bottom: 1px solid #fff !important; outline: none;}

.color_wrap.black .contact_form .input-wrap input[type="text"]{
    border-bottom: 1px solid #888;
}
.color_wrap.white .contact_form .input-wrap input[type="text"]{
    border-bottom: 1px solid #ccc;
}

.contact_form textarea{padding: 30px 20px;width: 100%; height: 220px; background: transparent; font-size: 1.125em; line-height: 2; letter-spacing: -0.025em; resize: none; box-sizing: border-box;}
.contact_form textarea:focus{outline: none;}

.color_wrap.black .contact_form .input-wrap input[type="text"]{color: #fff;}
.color_wrap.black .contact_form .input-wrap input[type="text"]:focus{border-bottom: 1px solid #fff !important;}
.color_wrap.white .contact_form .input-wrap input[type="text"]{color: #101010;}

.color_wrap.white .contact_form .input-wrap input[type="text"]:focus{border-bottom: 1px solid #101010 !important;}
.color_wrap.black .contact_form textarea{ border: 1px solid #888;color: #fff;}
.color_wrap.black .contact_form textarea::placeholder{color: #ccc;}
.color_wrap.white .contact_form textarea{ border : 1px solid #ccc;color: #101010}
.color_wrap.white .contact_form textarea::placeholder{color: #888;}

.color_wrap.black .contact_form textarea:focus{border-top: 1px solid #fff !important; border-bottom: 1px solid #fff !important;}
.color_wrap.white .contact_form textarea:focus{border-top: 1px solid #101010 !important; border-bottom: 1px solid #101010 !important;}

.contact_form .file_wrap{display: flex; gap: 25px; flex-wrap: wrap; flex-direction: column; margin-top: 40px;}
.contact_form .file_wrap li{display: flex;gap: 40px;height: 44px;}
.contact_form .file_wrap input[type="file"]{display: none;}
.contact_form .file_wrap li .lef{display: flex; gap:10px; width: 100%; max-width: 480px;}
.contact_form .file_wrap .lef span{overflow: hidden;width: 100%;height: 54px;background: transparent;font-size: 1.125rem;line-height: 52px;letter-spacing: -0.025em;white-space: nowrap;text-overflow: ellipsis;}
.contact_form .file_wrap .lef span.disabled{color: #888;}
.contact_form .file_wrap label{display: block; flex-shrink: 0; width: 92px; height: 44px; font-size:0.875rem; font-weight: 500; line-height: 44px;text-align: center; border-radius: 22px;}
.color_wrap.black .contact_form .file_wrap label{ background: #fff;color: #101010;}
.color_wrap.white .contact_form .file_wrap label{ background: #101010;color: #fff;}
.add_btn_wrap{display: flex; gap:20px; font-size: 15px;}
.add_btn_wrap button{ display: flex; gap: 10px; align-items: center; border: none;background: transparent;}
.add_btn_wrap .circle{ display: block; margin: 0 auto; position: relative;width: 25px; height: 25px; background-repeat: no-repeat; background-position: center; transition: 0.3s; cursor: pointer; border-radius: 50%;}

.color_wrap.black .file_wrap .lef span{color: #fff;}
.color_wrap.black .file_wrap label{color: #101010;}
.color_wrap.black .contact_form .file_wrap .lef span{border-bottom: 1px solid #888;}

.color_wrap.black .add_btn_wrap span{color: #fff;}
.color_wrap.black .add_btn_wrap .circle{border: 1px solid #fff;}
.color_wrap.black .add_btn_wrap .circle.plus{background-image: url(../images/add_btn_plus-wh.svg); background-size: 7px;}
.color_wrap.black .add_btn_wrap .circle.minus{background-image: url(../images/add_btn_minus-wh.svg); background-size: 7px;}

.color_wrap.white .add_btn_wrap span{color: #101010;}
.color_wrap.white .add_btn_wrap .circle{border: 1px solid #101010;}
.color_wrap.white .add_btn_wrap .circle.plus{background-image: url(../images/add_btn_plus-bl.svg); background-size: 7px;}
.color_wrap.white .add_btn_wrap .circle.minus{background-image: url(../images/add_btn_minus-bl.svg); background-size: 7px;}
.color_wrap.white .contact_form .file_wrap .lef span{border-bottom: 1px solid #ccc;}

.submit_btn{display: flex; justify-content: center;}
.submit_btn #btn_submit{display: flex;gap:16px;align-items: center;justify-content: center;flex-direction: column;margin-top: 60px;border: none; position: relative;width: 140px;height: 140px;font-size: 1.25rem;font-weight: 600;letter-spacing: -0.05em;border-radius: 50%;}
.submit_btn #btn_submit .arr{ display: block;width: 30px; height: 20px; background-repeat: no-repeat; background-position: center; background-size: contain; transition: .3s;}
.submit_btn #btn_submit:hover .arr{animation: move 1s linear infinite;}

@keyframes move{
    0%{transform: translateX(0);}
    50%{transform: translateX(10px);}
    100%{transform: translateX(0);}
}

#btn_submit > span{position: relative; z-index: 5;}
#btn_submit::after{position: absolute; top: 0; left: 0; z-index: 0; width: 100%; height: 100%; transition: .3s; content: ""; transform: none; border-radius: 50%;}
#btn_submit:hover::after{transform: scale(1.2);}
.color_wrap.black #btn_submit::after{background: #fff;}
.color_wrap.white #btn_submit::after{background: #101010;}
.color_wrap.black #btn_submit span{color: #101010;}
.color_wrap.white #btn_submit span{color: #fff;}
.color_wrap.black #btn_submit .arr{background-image: url(../images/submit_arr-bl.svg);}
.color_wrap.white #btn_submit .arr{background-image: url(../images/submit_arr-wh.svg);}

@media (max-width: 1500px){
    .contact_form .fit .rig form{padding-right: 0px; box-sizing: border-box;}
    .contact_form .fit{ gap: 80px;flex-direction: column; padding: 0 20px;}
    .contact_form .fit .lef .detail{font-size: 18px;}
    .contact_form .lef.fix{position: relative; top: 0; height: auto;}
    .contact_form .fit .lef{display: flex;gap: 60px;justify-content: flex-start;flex-direction: column;width: 100%;}
    .contact_form .fit .lef > div:last-of-type{display: flex; gap: 60px; justify-content: flex-start;}
    .q_inq_box{margin-top: 0;}
    .q_inq_box~.q_inq_box{margin-top: 40px;}
    .submit_btn #btn_submit{ gap:16px;width: 140px; height: 140px; font-size: 16px;}
    .submit_btn #btn_submit .arr{width: 22px; height: 18px;}
    .submit_btn #btn_submit:hover .arr{transform: none;}
    .contact_form .fit .rig{max-width: none;}
    .q_inq_box~.q_inq_box{margin-top: 0;}
    .contact_form .button-wrap span{padding:0 28px;}
    .contact_form .file_wrap li .lef{flex-direction: row;max-width: none;}
    .add_btn_wrap{flex-shrink: 0;}
    .contact_form .form-group~.form-group{margin-top: 60px;}
}
@media (max-width: 1024px){
    .con_tit p{font-size: 72px;}
    .contact_form .con_tit p{margin-bottom: 40px;}
    .contact_form .fit .lef .detail{font-size: 16px;}
    .q_inq_box > p{font-size: 16px;}
    .q_inq_box > a{font-size: 18px;}
    .q_inq_box > .mail_info{font-size: 16px;}
    .contact_form .question{font-size: 32px;}
    .contact_form .question em{font-size: 16px;}
}

@media (max-width:768px){
    .con_tit p{font-size: 44px;}
    .contact_form .fit{ gap: 80px;flex-direction: column; padding: 0 20px;}
    .contact_form .fit .lef .con_tit p{margin-bottom: 30px;}
    .contact_form .fit .lef{display: flex; gap: 40px; flex-direction: column;}
    .contact_form .fit .lef > div:last-of-type{display: flex; gap:30px;}
    .q_inq_box{margin-top: 0;}
    .q_inq_box > p:not(.mail_info){margin-bottom: 14px;}
    .q_inq_box~.q_inq_box{margin-top: 0;}
    
    .contact_form .question{ margin-bottom:25px;font-size: 1.5rem;}
    .contact_form .button-wrap{gap:8px;}
    .contact_form .button-wrap span{ padding: 0 16px; height: 42px;line-height: 40px; border-radius: 21px;}
    .contact_form .input-wrap{column-gap: 20px; grid-template-columns: 1fr}
    .contact_form .input-wrap input[type="text"]{padding: 0px; height: 48px; line-height: 46px;}
    .contact_form textarea{margin: 0 auto; padding: 20px 10px;}
    .contact_form .question{gap: 10px;align-items: flex-start;justify-content: flex-start;flex-direction: column;}
    .form-group .question em{margin-left: 0;}
    .contact_form .form-group~.form-group{margin-top: 50px;}
    .contact_form .file_wrap{gap: 15px;margin-top: 0;}
    .contact_form .file_wrap li{gap: 10px;align-items: flex-start;justify-content: flex-start;flex-direction: column;height: auto;}
    .contact_form .file_wrap li .lef{gap: 5px;align-items: center;justify-content: flex-start;flex-direction: row;width: 100%;}
    .contact_form .file_wrap label{width: 60px;height: 36px;font-size: 0.8rem;line-height: 36px;}
    .contact_form .file_wrap .lef span{width: 100%;height: 44px; line-height: 44px;}
    .add_btn_wrap{gap:10px;justify-content: flex-end;flex-shrink: 0;width: 100%;font-size: 12px;}
    .contact_form .file_wrap .circle{width: 20px; height: 20px;}
    .submit_btn #btn_submit{ gap:8px;width: 135px; height: 135px; font-size: 14px;}
    .submit_btn #btn_submit .arr{width: 18px; height: 14px;}
    .submit_btn #btn_submit:hover .arr{transform: none;}
    .contact_form .fit .lef .con_tit p{margin-bottom: 40px;font-size: 44px ;}
    .contact_form .fit .lef .detail{font-size: 14px;}
    .contact_form .fit .rig{max-width: none;}
    .q_inq_box~.q_inq_box{margin-top: 0;}
    .q_inq_box > p{font-size: 14px;}
    .q_inq_box > a{font-size: 16px;}
    .q_inq_box > .mail_info{font-size: 14px;}
    .contact_form .question{font-size: 24px; line-height: 1.25;}
    .contact_form .question em{font-size: 14px;}
    .contact_form .input-wrap input[type="text"]:nth-of-type(3),
    .contact_form .input-wrap input[type="text"]:nth-of-type(4) {margin-top: 0px;}

    .map .con_tit p{font-size:44px}
}

/* 하단 견적문의, 탑버튼 */
.bottom_btn_wrap{display: none;align-items: center;justify-content: center;flex-direction: column;position: fixed;right:30px;bottom:20px;z-index: 80;}
.bottom_btn_wrap.on{display: flex;}

.bottom_btn_wrap .inquire{ display: flex; align-items: center; justify-content: center; border: none; position: relative;width: 140px; height: 140px; background: transparent;}
.bottom_btn_wrap .inquire::after{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; animation: roll 8s linear infinite;content: "";}
.bottom_btn_wrap .inquire .button{ display: flex; align-items: center; justify-content: center; flex-direction: column; position: relative;width: 100px; height: 100px; font-size: 1.25rem;}
.bottom_btn_wrap .inquire .button::after{ position: absolute; top: 0; left: 0; z-index: 0; width: 100%; height: 100%; background: #d6232f; transition: cubic-bezier(0.175, 0.885, 0.32, 1.275) 0.7s;content: ""; border-radius: 50%; transform: none;}
.bottom_btn_wrap .inquire .ico{ position: relative; z-index: 1; width: 20px; height: 20px; background: url(../images/inquire-btn-icon-wh.png) no-repeat center; background-size: contain;}
.bottom_btn_wrap .inquire .txt{ margin-top: 10px;position: relative; z-index: 1; font-size: 1rem; font-weight: 500; color: #fff; text-align: center; letter-spacing: -0.05em;}

.color_wrap.black .bottom_btn_wrap .inquire::after{background: url(../images/banner-btn-wh.png) no-repeat center / contain;}
.color_wrap.white .bottom_btn_wrap .inquire::after{background: url(../images/banner-btn-b.png) no-repeat center / contain;}
.bottom_btn_wrap .inquire:hover .button::after{transform: scale(1.65);}
.bottom_btn_wrap .inquire:hover::after{background: url(../images/banner-btn-wh.png) no-repeat center / contain !important;}

@keyframes roll {
    0% {transform: rotate(0deg);}
    100% {transform: rotate(360deg);}
}

.bottom_btn_wrap .top{display: flex;align-items: center;justify-content: center;margin-top: 20px;border: none;position: relative;width: 60px; width:100%;height: 40px;background: transparent;}
.bottom_btn_wrap .top .button span{ position: relative; font-family: 'Play';font-size: 0.75rem; font-weight: 700; letter-spacing: 0.05em;}
.bottom_btn_wrap .top .button span::after{ position: absolute; top: 50%; right: -12px; z-index: 1; width: 7px; height: 4px; background-repeat: no-repeat; background-position: center; background-size: contain;content: ""; transform: translateY(-50%);}

.color_wrap.black .bottom_btn_wrap .top .button span{color: #fff;}
.color_wrap.black .bottom_btn_wrap .top .button span::after{background-image: url(../images/top-btn-arr-wh.svg);}
.color_wrap.white .bottom_btn_wrap .top .button span{color: #101010;}
.color_wrap.white .bottom_btn_wrap .top .button span::after{background-image: url(../images/top-btn-arr-bl.svg);}

@media all and (max-width: 1200px){
    .bottom_btn_wrap{right: 10px; bottom:20px;}
    .bottom_btn_wrap .top{ margin-top: 0px;height: 30px;}
    .bottom_btn_wrap .inquire{width: 80px; height: 80px;}
    .bottom_btn_wrap .inquire .button{width: 60px; height: 60px;}
    .bottom_btn_wrap .inquire .txt{ margin-top: 5px;font-size: 0.75rem;}
    .bottom_btn_wrap .inquire .ico{width: 14px; height: 14px;}
        
    .inquire_wrap .form-group.term-box{margin-top:50px;}
    .inquire_form .term-box .question{margin-bottom: 25px;}
    .inquire_form .term_txt{height: 120px;}
    .inquire_form .term_txt p{height: 100px !important; font-size: 1rem; font-weight: 400;}   
    .inquire_form .chk_box {color: #101010; margin-top: 20px;}
    .inquire_form .chk_box p{font-size: 1rem;}
    .inquire_form .chk_box span{width: 16px; height: 16px;}
    .inquire_form .chk_box span svg{width: 8px;}
    .inquire_form .chk_box .chk_line{stroke: #101010;}
}

@media all and (max-width:768px) {
    .inquire_wrap .form-group.term-box{margin-top:40px;}
    .inquire_form .term-box .question{margin-bottom: 15px;}
    .inquire_form .chk_box {margin-top: 15px;}
}


/* 스크롤 검색버튼 */
.menu_scroll_wrap {position: fixed; top: 0; left: 0; z-index: 105; width: 100%; background: #101010;}
.menu_scroll_wrap .menu_tab{margin-top: 30px;}

/*process*/
.process{padding: 18.75rem 7.5rem 0;}
.process .area_tit{text-align:center;font-family: "Play";font-size:0.94rem;font-weight:700;letter-spacing: 0;opacity:0;transform:translate(0,100%);transition:0.6s;transition-delay:0.6s;}
.process .area1{margin:4.38rem 0 8.75rem;}
.process .area1 .txt{text-align:center;margin-top:1.56rem;}
.process .area1 .txt p{font-size:1rem;line-height:1.88em;letter-spacing: -0.05em;opacity:0;transform:translate(0,100%);transition:0.6s;}
.process .area1 .txt p:nth-child(1){transition-delay:0.8s;}
.process .area1 .txt p:nth-child(2){transition-delay:0.9s;}
.process .area1 .txt p:nth-child(3){transition-delay:1s;}
.process .area1 .cir{margin-top:7.5rem;position:relative;}
.process .area1 .cir ul{display:flex;justify-content:center;position:relative;z-index:5;}
.process .area1 .cir ul li{width:33.33%;max-width:450px;position:relative;}
.process .area1 .cir ul .c1{margin-right:-4.69rem;}
.process .area1 .cir ul .c3{margin-left:-4.69rem;}
.process .area1 .cir ul li span{display:block;padding-bottom:100%;position:relative;}
.process .area1 .cir ul li span::before{content:"";position:absolute;left:0;top:0;width:100%;height:100%;border-radius:50%;box-sizing:border-box;opacity:0;transform:scale(0.7);transition:0.6s;}
.process .area1 .cir ul .c1 span::before{border:1px solid #697ded;transition-delay:1.3s;}
.process .area1 .cir ul .c2 span::before{border:1px solid #8438da;transition-delay:1.4s;}
.process .area1 .cir ul .c3 span::before{border:1px solid #df4197;transition-delay:1.5s;}
.process .area1 .cir ul li .t{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;}
.process .area1 .cir ul li .t dl{opacity:0;transform:translate(0,80%);transition:0.8s;transition-delay:1.7s;}
.process .area1 .cir ul li .t dl dt{font-size:1.88rem;font-weight:300;letter-spacing:-0.075rem;}
.process .area1 .cir ul li .t dl dd{font-size:1.25rem;font-weight:700;margin-top: 0.94rem;letter-spacing:0;}

.process .area2{padding-bottom:20rem;}
.process .area2 .step{margin-top:8.13rem;position:relative;}
.process .area2 .step{display:flex;}
.process .area2 .step .mg{padding-top:0.32rem;}
.process .area2 .step .s{width:33.33%;opacity:0;transform:translate(0,10%);transition:0.6s;}
.process .area2 .step .s2{transition-delay:0.2s;}
.process .area2 .step .s3{transition-delay:0.4s;}
.process .area2 .step .top_txt{text-align:center;padding-bottom:1.56rem;position:relative;}
.process .area2 .step .s ~ .s .top_txt{border-left:1px solid #ccc;}
.process .area2 .step .top_txt span{display:block;font-size:0.75rem;font-weight:700;letter-spacing:0.075rem;}
.process .area2 .step .top_txt strong{display:block;font-size:1.63rem;font-weight:300;letter-spacing:-0.075rem;margin-top:0.63rem;}
.process .area2 .step .top_txt .arr{position:absolute;left:0;top:50%;transform:translate(-50%,-50%);}
.process .area2 .step .top_txt .arr span{display:block;width:4.5rem;margin: 0 auto;position:relative;opacity:0;transform:translate(-30%,0);transition:0.6s;}
.process .area2 .step .top_txt .arr img{display:block;width:100%;}
.process .area2 .step .top_txt .arr .w{position:absolute;left:0;top:0;}
.process .area2 .step .top_txt .ar1 span{transition-delay:0.6s;}
.process .area2 .step .top_txt .ar2 span{transition-delay:0.8s;}
.process .area2 .step .box .tit{display:flex;align-items:center;justify-content:center;height:2.19rem;}
.process .area2 .step .red .tit{background-color:#bd1b26;}
.process .area2 .step .box .tit span{display:block;color:#fff;font-size:1rem;font-weight:400;}
.process .area2 .step .s1 .box .tit span,
.process .area2 .step .s3 .box .tit span{display:none;}
.process .area2 .step .box .s ~ .s .con{border-left:1px solid #ccc;}
.process .area2 .step .red .con .h{padding: 0.63rem 1.88rem 1.25rem;}
.process .area2 .step .bl .con .h{padding: 1.25rem 1.88rem 1.88rem;}
.process .area2 .step .s1 .con{background-color:#f3f3f3;}
.process .area2 .step .s2 .con{background-color:#ebebeb;}
.process .area2 .step .s3 .con{background-color:#e0e0e0;}
.process .area2 .step .box .con dl{display:flex;}
.process .area2 .step .box .con dl ~ dl{margin-top:0.63rem;}
.process .area2 .step .box .con dl dt{font-size:1rem;letter-spacing:-0.05em;line-height:1.88em;font-weight:500;width:5rem;flex-shrink: 0;}
.process .area2 .step .red .con dl dt{color:#d6232f;}
.process .area2 .step .bl .con dl dt{color:#000;}
.process .area2 .step .box .con dl dd{flex-grow:1;}
.process .area2 .step .box .con dl dd p{color:#666;font-size:1rem;line-height:1.88em;letter-spacing:-0.04em;}
.process .area2 .step .box .con dl dd .dot{display:flex;gap:0 0.25rem;}
.process .area2 .step .box .con dl dd .dot::before{content:"";display:block;width:0.38rem;height:0.38rem;background-color:#666;border-radius:50%;position:relative;top:0.685rem;}
.process .area2 .step .box .con dl dd .half{display:flex;width:100%;}
.process .area2 .step .box .con dl dd .half > div{width:50%;}
.process .area2 .ori{margin-top:1.25rem;opacity:0;transform:translate(0,100%);transition:0.6s;}
.process .area2 .ori p{font-size:0.94rem;letter-spacing:-0.05em;color:#888;line-height:1.67em;display: flex;gap: 0 0.25rem;}
.process .area2 .ori p::before{content:"";display:block;width:0.38rem;height:0.38rem;background-color:#888;border-radius:50%;position:relative;top:0.65rem;}
.color_wrap.white .process .area_tit,
.color_wrap.white .process .area1 .cir ul li .t dl dt,
.color_wrap.white .process .area1 .cir ul li .t dl dd,
.color_wrap.white .process .area2 .step .top_txt span,
.color_wrap.white .process .area2 .step .top_txt strong{color:#101010;}
.color_wrap.white .process .area1 .txt p{color:#666;}
.color_wrap.black .process .area_tit,
.color_wrap.black .process .area1 .cir ul li .t dl dt,
.color_wrap.black .process .area1 .cir ul li .t dl dd,
.color_wrap.black .process .area2 .step .top_txt span,
.color_wrap.black .process .area2 .step .top_txt strong{color:#fff;}
.color_wrap.black .process .area1 .txt p{color:#ddd;}
.color_wrap.white .process .area2 .step .bl .tit{background-color:#101010;}
.color_wrap.black .process .area2 .step .bl .tit{background-color:#777;}
.color_wrap.white .process .area2 .step .top_txt .arr .w{opacity:0;}
.color_wrap.black .process .area2 .step .top_txt .arr .b{opacity:0;}

.process .area1.active .area_tit,
.process .area1.active .txt p,
.process .area1.active .cir ul li span::before,
.process .area1.active .cir ul li .t dl,
.process .area2 .step .s.active,
.process .area2 .step .s.active .top_txt .arr span,
.process .area2 .ori.active{opacity:1;transform:none;}

@media all and (max-width:1400px) {
	.process .area2 .step .box .con dl dd .half{display:block;}
	.process .area2 .step .box .con dl dd .half > div{width:100%;}
}
@media all and (min-width:1001px) {
	.process .area1 .cir ul .c1 .bg{position:absolute;left:0;top:0;width:100%;height:100%;border-radius:250px;overflow:hidden;z-index: -1;transform:scale(0);animation: cir_ani 7s 3s infinite;}
	.process .area1 .cir ul .c1 .bg::before{content:"";display:block;width:100%;height:100%;background:#697ded;animation: cir_color 7s 3s infinite;}
	.color_wrap.white .process .area1 .cir ul .c1 .t dl dt,
	.color_wrap.white .process .area1 .cir ul .c1 .t dl dd{animation: cir_txt1 7s 3s infinite;}
	.color_wrap.white .process .area1 .cir ul .c2 .t dl dt,
	.color_wrap.white .process .area1 .cir ul .c2 .t dl dd{animation: cir_txt2 7s 3s infinite;}
	.color_wrap.white .process .area1 .cir ul .c3 .t dl dt,
	.color_wrap.white .process .area1 .cir ul .c3 .t dl dd{animation: cir_txt3 7s 3s infinite;}
	@keyframes cir_txt1 {
		0% {color:#101010;}
		5% {color:#fff;}
		25% {color:#fff;}
		35% {color:#101010;}
		100% {color:#101010;}
	}
	@keyframes cir_txt2 {
		0% {color:#101010;}
		15% {color:#101010;}
		20% {color:#fff;}
		55% {color:#fff;}
		65% {color:#101010;}
		100% {color:#101010;}
	}
	@keyframes cir_txt3 {
		0% {color:#101010;}
		45% {color:#101010;}
		50% {color:#fff;}
		75% {color:#fff;}
		85% {color:#101010;}
		100% {color:#101010;}
	}
	@keyframes cir_ani {
		0% {transform:scale(0);}
		/*처음 커짐*/
		10% {transform:scale(1);width:100%;left:0;}
		/*정지*/
		15% {transform:scale(1);width:100%;left:0;}
		/*가운데로 이동*/
		25% {transform:scale(1);width:calc(200% - 4.69rem);left:0;}
		/*가운데에서 원형 유지*/
		35% {transform:scale(1);width:100%;left:calc(100% - 4.69rem);}
		/*정지*/
		45% {transform:scale(1);width:100%;left:calc(100% - 4.69rem);}
		/*맨 끝으로 이동*/
		55% {transform:scale(1);width:calc(200% - 4.69rem);left:calc(100% - 4.69rem);}
		/*맨 끝에서 원형 유지*/
		65% {transform:scale(1);width:100%;left:calc(200% - 9.38rem);}
		/*정지*/
		75% {transform:scale(1);width:100%;left:calc(200% - 9.38rem);}
		/*작아짐*/
		85% {transform:scale(0);width:100%;left:calc(200% - 9.38rem);}
		/*대기*/
		100% {transform:scale(0);}
	}
	@keyframes cir_color {
		0% {background:#697ded;}
		15% {background:#697ded;}
		35% {background:#8438da;}
		45% {background:#8438da;}
		65% {background:#df4197;}
		100% {background:#df4197;}
	}
}
@media all and (max-width:1000px) {
	.process .area1 .cir{width:70%;max-width:400px;margin: 0 auto;margin-top: 5rem;}
	.process .area1 .cir ul{justify-content: flex-start;}
	.process .area1 .cir ul li{margin: 0 !important;}
	.process .area1 .cir ul li span::before{opacity:0;transform:scale(1.2);transition:1s;}
	.process .area1 .cir ul li .t dl dt,
	.process .area1 .cir ul li .t dl dd{opacity:0;transform:translate(0,100%);transition:0.6s;}
	.process .area1 .cir ul .swiper-slide-active span::before{opacity:1;transform:none;}
	.process .area1 .cir ul .swiper-slide-active .t dl dt{opacity:1;transform:none;transition-delay:0.3s;}
	.process .area1 .cir ul .swiper-slide-active .t dl dd{opacity:1;transform:none;transition-delay:0.6s;}
	.process .area2{padding-bottom:12rem;}
	.process .area2 .step{display:block;margin-top: 5rem;}
	.process .area2 .step .s{width:100%;}
	.process .area2 .step .top_txt{border:none !important;}
	.process .area2 .step .top_txt .arr{position:static;transform:rotate(90deg);padding: 5rem 0;}
	.process .area2 .step .top_txt .arr span{width:3rem;}
	.process .area2 .step .s1 .box .tit span,
	.process .area2 .step .s3 .box .tit span{display:block;}
}
@media all and (max-width:700px) {
	.process{padding:12rem 0 0;}
	.process .area2{padding-bottom: 6rem;}
	.process .area2 .step .top_txt .arr{padding: 3.5rem 0;}
	.process .area2 .step .top_txt .arr span{width: 2.5rem;}
}
@media all and (min-width:701px) {
	.__m2{display:none;}
}

/* product */
.products{padding: 18.75rem 7.5rem 0;}
.con_tit.product{margin-bottom: 40px;}
.mobile_tab.product{display: none;}
.menu_tab.product{height: 120px; z-index: 88; padding-top: 0; }
.menu_tab.product.on::after{width: 100vw; height: 100%; position: absolute; z-index: 1; display: block; content: ''; left: 50%; transform: translateX(-50%); top: 0;}
.white .menu_tab.product.on::after{background: #f8f7f5;}
.black .menu_tab.product.on::after{background: #101010;}
.white .menu_tab.product.on{background: #f8f7f5;}
.black .menu_tab.product.on{background: #101010;}
.menu_tab.product .tag_wrap{height: 100%; display: flex; align-items: center;}
.menu_tab.product .tag_wrap ul{height: 90px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; max-width: 1580px; gap: 10px;}
.menu_tab.product .tag_wrap li{display: flex; width: auto; font-size: 18px; line-height: 38px; height: 40px; border-radius: 20px; background: transparent; padding: 0 26px; margin: 0;}
.menu_tab.product ul li button{font-size: 1.125rem; transition: none;}

.white .menu_tab.product .tag_wrap li{border: 1px solid #101010;}
.white .menu_tab.product .tag_wrap li.on{background: #101010; color: #fff;}
.white .menu_tab.product .tag_wrap li.on button{color: #fff;}

.black .menu_tab.product .tag_wrap li{border: 1px solid #fff;}
.black .menu_tab.product .tag_wrap li.on{background: #fff; color: #101010;}
.black .menu_tab.product .tag_wrap li.on button{color: #101010;}

.menu_tab.product ul li{transform: translateX(20px); opacity: 0;}
.menu_tab.product.active ul li{animation: menuTab 0.5s forwards;}
.menu_tab.product ul li:nth-child(1){animation-delay: 0.5s;}
.menu_tab.product ul li:nth-child(2){animation-delay: 0.6s;}
.menu_tab.product ul li:nth-child(3){animation-delay: 0.7s;}
.menu_tab.product ul li:nth-child(4){animation-delay: 0.8s;}
.menu_tab.product ul li:nth-child(5){animation-delay: 0.9s;}
.menu_tab.product ul li:nth-child(6){animation-delay: 1.0s;}
.menu_tab.product ul li:nth-child(7){animation-delay: 1.1s;}
.menu_tab.product ul li:nth-child(8){animation-delay: 1.2s;}
.menu_tab.product ul li:nth-child(9){animation-delay: 1.3s;}
.menu_tab.product ul li:nth-child(10){animation-delay: 1.4s;}
.menu_tab.product ul li:nth-child(11){animation-delay: 1.5s;}
.menu_tab.product ul li:nth-child(12){animation-delay: 1.6s;}
.menu_tab.product ul li:nth-child(13){animation-delay: 1.7s;}
.menu_tab.product ul li:nth-child(14){animation-delay: 1.8s;}
.menu_tab.product ul li:nth-child(15){animation-delay: 1.9s;}
.menu_tab.product ul li:nth-child(16){animation-delay: 1.9s;}
.menu_tab.product ul li:nth-child(17){animation-delay: 1.9s;}

@keyframes menuTab {
    0%{opacity: 0; transform: translateX(20px);}
    100%{opacity: 1; transform: none;}
}

#product{width: 100%; display: flex; justify-content: space-between; margin-bottom: 260px;  margin-top: 50px;}
.white #product{border-top: 1px solid #101010;}
.black #product{border-top: 1px solid #fff;}

#product .section_title{font-family: 'Play'; font-size: 0.938rem; font-weight: 800; margin-top: 100px; position: sticky; top: 160px; height: 20px; display: block; z-index: 10; left: 0;}
.white #product .section_title{color: #101010;}
.black #product .section_title{color: #fff;}

#product .mockup-title{position: absolute; width: 100%; text-align: center; color: #e9e9eb; font-size: 0.75rem; letter-spacing: 0.76em; z-index: 10; top: 10%; left: 0; font-family: 'NanumSquare'; font-weight: 800;}
#product .mockup-title.rotate{top: 50%;left: -37.5%;transform: rotate(90deg);}

#product .section_wrap{width: 100%; max-width: 1120px; flex-shrink: 0;}
#product .section{height: 960px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden;}
#product .en_tit{font-size: 0.938rem; font-weight: 600; margin-bottom: 10px; text-transform: uppercase;}
#product .ko_tit{font-size: 2.5rem; font-weight: 300; margin-bottom: 40px;}
#product .ko_tit em{font-size: 1.5rem;}
#product .detail{font-size: 1rem; line-height: 1.6em; margin-bottom: 60px;}

.white #product .title .en_tit,
.white #product .title .ko_tit{color: #101010;}
.white #product .detail{color: #666;}
.black #product .title .en_tit,
.black #product .title .ko_tit{color: #fff;}
.black #product .detail{color: #ddd;}

#product .mockup{position: relative;}
#product .bg{width: 100%; height: 0; position: relative; padding-bottom: 55.35%; max-height: 620px; overflow: hidden;}
#section01 .bg{background: #6768a1;}
#section02 .bg{background: #b89154;}
#section03 .bg{background: #42b2a9;}
#section04 .bg{background: #a1676b;}
#section05 .bg{background: #67a16e;}
#section06 .bg{background: #6795a1;}
#section07 .bg{background: #a18167;}
#section08 .bg{background: #8867a1;}
#section09 .bg{background: #b35a53;}
#section10 .bg{background: #977551;}
#section11 .bg{background: #999067;}
#section12 .bg{background: #67998d;}
#section13 .bg{background: #aa9f8a;}
#section14 .bg{background: #7b6a83;}
#section15 .bg{background: #999067;}
#product .bg img{width: 100%; height: 100%; object-fit: contain; position: absolute; bottom:0; left: 0;}

#product .monitor{position: absolute;left: 22.65%;top: 22.25%;width: 54.35%;max-width: 608px;height: 0;padding-bottom: 34.285%;max-height: 384px; overflow: hidden; background: #fff;}
#product .monitor .swiper-wrapper{width: 100%; height: 100%; position: absolute; top: 0; left: 0; background-color: #fff;}
#product .monitor .swiper-wrapper img{display: block;}

/* motion */
#product .section .detail,
#product .section .title{opacity: 0; transition: 1s; transform: translateX(80px);}
#product .section .mockup{opacity: 0; transition: 1s; transform: translateY(80px);}

#product .section.active .detail,
#product .section.active .title{opacity: 1; transform: none; transition-delay: 0.4s;}
#product .section.active .mockup {opacity: 1; transform: none; transition-delay: 0.8s;}

.menu_list{padding: 0 15px;z-index:20;position:sticky;top:0;background-color:#f8f7f5;}
.menu_mob{display:none;}
.menu_mob ul{display:flex;justify-content:center;gap:5px;flex-wrap:wrap;}
.menu_mob ul li button{display:block;text-align:center;border: 1px solid #101010;color:#101010;border-radius: 25px;font-size: 1rem;line-height: 35px;padding: 0 10px;font-family: 'Play';background-color:#f8f7f5;}
.menu_mob ul li.on button{color: #fff;background: #101010;font-weight:600;}
.menu_sd{overflow:hidden;width:100%;padding: 15px 0;background-color:#f8f7f5;}
.menu_sd .swiper-wrapper{flex-wrap:wrap;justify-content:center;gap: 10px 0;}
.menu_sd .swiper-slide{width:auto;}
.menu_sd .swiper-slide span{cursor:pointer;display:block;text-align:center;border: 1px solid #101010;color:#101010;border-radius: 25px;font-size: 1.125rem;line-height: 37px;padding: 0 25px 1px;font-family: 'Play';letter-spacing: 0;}
.menu_sd .on span{color: #fff;background: #101010;font-weight:600;}

@media all and (min-width: 1501px){
	.menu_sd .swiper-wrapper{transform: none !important;}
}
@media all and (max-width: 1500px){
    .products{padding:12rem 0 0;}
    .menu_tab.product{height: auto; position: relative;}
    .menu_tab.product .tag_wrap ul{height: auto; gap: 5px;}
    .menu_tab.product .tag_wrap li{padding: 0 10px; height: 40px; line-height: 38px;}
    #product{flex-direction: column; margin-bottom: 40px; width: 100%; overflow: hidden; height: auto;}   
    #product .section_wrap{width: 100%; margin: 0 auto;}
    #product .section{height: auto; padding-top: 80px;}
    #product .section:first-of-type{margin-top: -20px;}
    .white .mobile_tab.on.product{background: #f8f7f5;}
    .black .mobile_tab.on.product{background: #101010;}
    .mobile_tab.product{display: flex; position: sticky; top: -1px; width: 100%; height: 61px; z-index: 89; left: 0; padding: 0 ; overflow: hidden;}
    .mobile_tab .tag_wrap{width: 100%;height: 100%;overflow-x: scroll;position: relative; z-index: 10;}
    .mobile_tab .tag_wrap::-webkit-scrollbar{display: none;}
    .mobile_tab.product ul{display: flex; justify-content: flex-start;  height: 100%; align-items: center; gap: 8px; width: auto; position: absolute; left: 0; top: -100%; transition: 0.4s;}
    .mobile_tab.product.on ul{top: 0;}
    .mobile_tab.product .tag_wrap li{padding: 0 10px;height: 36px;line-height: 34px;border-radius: 20px; background: transparent;width: auto;}
    .mobile_tab.product .tag_wrap li button{background: transparent; border: none; height: 100%; text-wrap: nowrap;}
    .white .mobile_tab.product .tag_wrap li button{color: #101010;}
    .black .mobile_tab.product .tag_wrap li button{color: #fff;}

    .white .mobile_tab.product .tag_wrap li.on{background: #101010;}
    .white .mobile_tab.product .tag_wrap li.on button{color: #fff;}
    .black .mobile_tab.product .tag_wrap li.on{background: #fff;}
    .black .mobile_tab.product .tag_wrap li.on button{color: #101010;}

    .white .mobile_tab.product .tag_wrap li{border: 1px solid #101010;}
    .black .mobile_tab.product .tag_wrap li{border: 1px solid #ffff;}

    #product .section_title{display: none;}
    /* #product .section_title{top: 60px; height: 40px; line-height: 40px; width: 100%; margin-top: 50px; margin-bottom: 40px;}
    #product .section_title span{position: relative; z-index: 10;}
    #product .section_title::after{width: 100vw; height: 100%; position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ''; display: block; z-index: 5;}
    .white #product .section_title::after{background: #f8f7f5;}
    .black #product .section_title::after{background: #101010;} */
    #product .section .mockup{order: 1; margin-bottom: 25px;}
    #product .section .title, .section .detail{order: 3;}
    #product .mockup-title{font-size: 0.5em;}
    #product .en_tit{margin-bottom: 10px;}
    #product .ko_tit{font-size: 1.75rem; margin-bottom:15px}
    #product .ko_tit em{display: block; margin-top: 5px;font-size: 1.4rem;letter-spacing:-0.05em;}
    #product .detail{margin-bottom: 0;}

    /* motion */
    #product .section .detail,
    #product .section .title{opacity: 0; transition: 1s; transform: translateX(15%);}
    #product .section .mockup{opacity: 0; transition: 1s; transform: translateX(-15%);}

    #product .section.active .detail,
    #product .section.active .title{opacity: 1; transform: none; transition-delay: 0.8s;}
    #product .section.active .mockup {opacity: 1; transform: none; transition-delay: 0.4s;}

	.menu_list{position:relative;}
	.menu_mob{display:block;}
	.menu_sd{position:fixed;top:0;left: 0;width: 100%;overflow: hidden;padding: 15px;transform:translate(0,-100%);transition:0.6s;}
	.menu_sd.fix{transform:none;}
	.menu_sd .swiper-wrapper{flex-wrap: nowrap;justify-content:flex-start;gap: 7px 0;}
	.menu_sd .swiper-slide span{padding: 0 10px;font-size:1rem;line-height:32px;}
}

@media all and (min-width:768px) and (max-width:1500px){
    .mobile_tab.product{overflow: visible;}
    .mobile_tab.product::after{width: 100vw; height: 100%; position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ''; display: block; z-index: 0;}
    .white .mobile_tab.product::after{background: #f8f7f5;}
    .black .mobile_tab.product::after{background: #101010;}
    #product .mockup-title{font-size: 0.75rem;}
}

.client{padding: 100px 0 160px;}
.client .tit{font-family:"Play";font-weight:700;letter-spacing:0.1em;margin-bottom:160px;text-align:center;overflow:hidden;}
.client .tit p{transform:translate(0,100%);transition:0.6s;}
.client .ban .box{display:flex;width:140vw;}
.client .ban .box ~ .box{margin-top:50px;}
.client .ban ul{display:flex;align-items: center;justify-content: space-around;width:100%;flex-shrink: 0;gap: 0 8vw;padding: 0 4vw;}
.client .ban ul li img{display:block;width:100%;margin: 0 auto;}
.client .ban .top{animation: client_lef 40s linear infinite;}
.client .ban .top ul{transform:translate(-100%,0);}
.client .ban .bot{animation: client_rig 40s linear infinite;}
.client .tit.active p{transform:none;}
.color_wrap.white .client .tit{color:#101010;}
.color_wrap.black .client .tit{color:#fff;}
.color_wrap.black .client .ban{filter: invert(1);}
@keyframes client_lef {
    0% {transform: translate(0);}
    100% {transform: translate(100%, 0);}
}
@keyframes client_rig {
    0% {transform: translate(0);}
    100% {transform: translate(-100%, 0);}
}
@media all and (max-width:1300px){
	.client .ban .box{width:180vw;}
}
@media all and (max-width:900px){
	.client .ban .box{width:250vw;}
}
@media all and (max-width:700px){
	.client{padding: 50px 0 100px;}
	.client .tit{margin-bottom: 100px;}
	.client .ban .box{width:300vw;}
	.client .ban .box ~ .box{margin-top:35px;}
	.client .ban ul{gap: 0 14vw;padding: 0 7vw;}
}