@charset "utf-8";

@import url('base.css');

/************************************************
  skipLink
************************************************/
#skipLink{ width:100%; overflow:hidden; position:relative; z-index:1000;}
#skipLink a{ margin:0px -1px -1px 0px; width:1px; height:1px; text-align:center; line-height:0; overflow:hidden; font-size:0px; display:block;}
#skipLink a:focus{ background:rgb(32, 38, 44); margin:0px; padding:8px 0px 8px 15px; width:auto; height:30px; color:rgb(255, 255, 255); line-height:1; font-size:12px; font-weight:700;}
#skipLink a:hover{ background:rgb(32, 38, 44); margin:0px; padding:8px 0px 8px 15px; width:auto; height:30px; color:rgb(255, 255, 255); line-height:1; font-size:12px; font-weight:700;}
#skipLink a:active{ background:rgb(32, 38, 44); margin:0px; padding:8px 0px 8px 15px; width:auto; height:30px; color:rgb(255, 255, 255); line-height:1; font-size:12px; font-weight:700;}



/* --------------------------------------------
 * layout
/* ------------------------------------------ */
.mbg{ display:none; position:fixed; left:0; top:0; width:100%; height:100%; background-color:#000; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; filter:alpha(opacity=70); opacity:.7; z-index:9;}
.mbg.type01{ height: calc(100vh - 6rem);}
body.ovf_hdn, .ovf_hdn{ overflow:hidden; height:100%;}

#wrap{ position: relative; width:100%; margin:0 auto; padding: 0;}

#header{ position: absolute; top: 0; left: 0; width:100%; z-index:5; -webkit-transition: all 0.2s ease-in-out;-moz-transition: all 0.2s ease-in-out;-ms-transition: all 0.2s ease-in-out;-o-transition: all 0.2s ease-in-out; transition:all 0.2s ease-in-out; }
#header > .inner{ height: 90px; margin: 0 auto; display: flex; position: relative; z-index: 2; padding: 0 60px; align-items: center; transform: translateY(-100%); }
#header > .inner::after{ content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 1px; display: block; background-color: rgba(230,230,230,.9);}
#header .logo{ width: 270px; z-index: 3;} /*width: 152px;*/
#header .logo a{ display: block; text-indent: -9999px; height: 50px; background: url(../images/logo2.png) no-repeat 50% 50% / 100% auto; }

#header .utill{ position: relative; display: flex; justify-content: flex-end; align-items: center; margin: 0 0 0 auto; z-index: 1;}
#header .utill .lang{ position: relative; display: inline-block; margin-left: 20px; }
#header .utill .lang .langBtn{ position: relative; display: flex; align-items: center; width: 92px; height: 34px; color: #1e1e1e;  }
#header .utill .lang .langBtn i{ width: 24px; height: 24px; background: url(../images/ic_lang2.png) no-repeat 50% 50% / cover; margin-right: 10px; text-indent: -9999px;}
#header .utill .lang .langBtn::after{ content: ''; position: absolute; top: 50%; right: 0; width: 8px; height: 8px; border-top: #1e1e1e 2px solid; border-right: #1e1e1e 2px solid; transform: translateY(-6px) rotate(135deg); transition: all 0.2s ease-in-out;}
#header .utill .lang .langBtn.on::after{ transform: translateY(-2px) rotate(-45deg); }
#header .utill .lang .langList{ position: absolute; top: 34px; border-radius: 14px; background-color: #f8f8fa; color: #fff; width: 100%; padding: 10px 0; text-align: center; display: none;}
#header .utill .lang .langList a{ display: block; color: #1e1e1e; padding: 5px 10px; font-size: .9em;}
#header .utill .lang .langList a:hover{ text-decoration: underline; color: #2b40f5;}

#header .utill .searchBtn{ display: flex; width: 32px; height: 32px; background: url(../images/ic_sch2.png) no-repeat 50% 50% / 24px; margin-left: 25px; text-indent: -9999px; position: relative; z-index: 3;}
#header .utill .searchBtn.on,
#header.main  .utill .searchBtn.on{ background: url(../images/ic_x.png) no-repeat 50% 50% / 16px; }
#header .utill .menuBtn{ position: relative; width: 32px; height: 32px; margin-left: 20px; font-size: 0; color: transparent; }
#header .utill .menuBtn::before{ content: ''; position: absolute; top: 50%; right: 0; width: 32px; height: 2px; background-color: #1e1e1e; transform: translate(0, -6px); transition:all 0.2s ease-in-out;}
#header .utill .menuBtn::after{ content: ''; position: absolute; top: 50%; right: 0; width: 24px; height: 2px; background-color: #1e1e1e; transform: translate(0, 3px); transition:all 0.2s ease-in-out;}
#header .utill .menuBtn:hover::before{ width: 24px; }
#header .utill .menuBtn:hover::after{ width: 32px; }
#header .subBg{ position: absolute; background-color: #fff; top: 0; left: 0; width: 100%; height: 360px; display: none;}

nav{ position: relative; margin: 0; flex: 1; display: flex; justify-content: center;}
nav > ul{ display: flex; align-items: center; justify-content: center; height: 100%; }
nav > ul > li > a{ display: block; height: 90px; line-height: 90px; padding: 0 32px; color: #1e1e1e; text-transform: uppercase; font-size: 20px; font-weight: 500; text-decoration: none; position: relative; white-space: nowrap; z-index: 2; }
nav > ul > li:hover > a{ font-weight: bold; color: #2b40f5;}
nav > ul > li > .subDepth{ position: absolute; top: 80px; left: 0; padding: 25px 0 0 0; width: 100%; display: none;}
nav > ul > li.gnb1 > .subDepth .depth2 > li:last-child > a{ padding-right: 0;}
nav > ul > li > .subDepth a{ color: #333; font-size: 20px;}
nav > ul > li > .subDepth .depth2{ display: flex; gap:24px; justify-content: center;}
nav > ul > li > .subDepth .depth2 > li > a{ padding-right: 2.2vw; white-space: nowrap; }
nav > ul > li.gnb1 > .subDepth .depth2{ gap: 0;}
nav > ul > li.gnb1 > .subDepth .depth2 > li > a{ padding-right: 6.2vw; }
nav > ul > li.gnb1 > .subDepth{ margin-left: -250px;}
nav > ul > li.gnb2 > .subDepth{ margin-left: -120px;}
nav > ul > li.gnb3 > .subDepth{ margin-left: 34px;}
nav > ul > li.gnb4 > .subDepth{ padding-left: 285px;}
nav > ul > li.gnb5 > .subDepth{ padding-left: 560px;}
nav > ul > li > .subDepth .depth2 > li > a:hover{ color:#4558f6;}
nav > ul > li > .subDepth .depth3{ margin: 15px 0 0 0;}
nav > ul > li > .subDepth .depth3 > li + li{ margin-top: 5px;}
nav > ul > li > .subDepth .depth3 > li a{ color: #999; font-size: 16px;}
nav > ul > li > .subDepth .depth3 > li a:hover{ color: #1e1e1e; text-decoration: underline;}

#header.w .logo a{ background: url(../images/logo2.png) no-repeat 50% 50% / 100% auto;}
#header.w .utill .lang .langBtn i{ background: url(../images/ic_lang2.png) no-repeat 50% 50% / cover;}
#header.w .utill .lang .langBtn{ color: #1e1e1e;}
#header.w .utill .lang .langBtn::after{ border-color:#1e1e1e;}
#header.w .utill .menuBtn::before,
#header.w .utill .menuBtn::after{ background-color: #1e1e1e;}
#header.w > .inner::after{ background-color: rgba(230,230,230,.9);}

#header.w nav > ul > li > a{ color: #1e1e1e;}

#header.main.w .logo a{ background: url(../images/logo2.png) no-repeat 50% 50% / 100% auto;}
#header.main.w .utill .lang .langBtn i{ background: url(../images/ic_lang2.png) no-repeat 50% 50% / cover;}
#header.main.w .utill .lang .langBtn{ color: #1e1e1e;}
#header.main.w .utill .lang .langBtn::after{ border-color:#1e1e1e;}
#header.main.w .utill .menuBtn::before,
#header.main.w .utill .menuBtn::after{ background-color: #1e1e1e;}
#header.main.w > .inner::after{ background-color: rgba(230,230,230,.9);}

#header.main.w nav > ul > li > a{ color: #1e1e1e;}

#header.main .logo a{ background: url(../images/logo.png) no-repeat 50% 50% / 100% auto;}
#header.main .utill .lang .langBtn i{ background: url(../images/ic_lang.png) no-repeat 50% 50% / cover;}
#header.main .utill .lang .langBtn{ color: #fff;}
#header.main .utill .lang .langBtn::after{ border-color:#fff;}
#header.main .utill .searchBtn{ background: url(../images/ic_sch.png) no-repeat 50% 50% / 24px;}
#header.main .utill .menuBtn::before,
#header.main .utill .menuBtn::after{ background-color: #fff;}
#header.main > .inner::after{ background-color: rgba(255,255,255,.15);}

#header.main nav > ul > li > a{ color: #d3d3d3;}
#header.main nav > ul > li > .subDepth .depth2 > li > a{ color: #fff;}
#header.main nav > ul > li > .subDepth .depth2 > li > a:hover{ color:#4558f6;}
#header.main nav > ul > li > .subDepth .depth3 > li a:hover{ color: #999;}

#header.main nav > ul > li > a{ color: #fff;}
#header.main nav > ul > li:hover > a{ color: #2b40f5;}

#header.main .subBg{ background-color: rgba(0,0,0,.75);}

#header.aMnuOpen > .inner{ z-index: 12; }
#header.aMnuOpen > .inner::after{ content: none; }
#header.aMnuOpen nav,
#header.aMnuOpen .utill .lang,
#header.aMnuOpen .utill .searchBtn{ display: none;}
#header.aMnuOpen .utill .menuBtn::before,
#header.aMnuOpen .utill .menuBtn::after{ width: 32px; transform: rotate(45deg); left: 50%; top: 50%; margin: -1px 0 0 -16px; background-color: #fff;}
#header.aMnuOpen .utill .menuBtn::after{ transform: rotate(-45deg);}

#header.aMnuOpen .logo a,
#header.aMnuOpen.w .logo a{ background: url(../images/logo.png) no-repeat 50% 50% / 100% auto;}
#header.aMnuOpen.w .utill .menuBtn::before,
#header.aMnuOpen.w .utill .menuBtn::after{ background-color: #fff;}

.headSearch{ position: absolute; top: 0; left: 0; width: 100%; background-color: #fff; padding: 115px 60px 0; height: 360px; display: none;}
.headSearch .searchWr{ max-width: 600px; margin: 0 auto;}
.headSearch .searchInp { border-bottom:#1e1e1e 1px solid; display: flex;}
.headSearch .searchInp .searchInput{ height: 60px; border: none; flex: 1; font-size: 18px; width:calc(100% - 50px);}
.headSearch .searchInp .searchInput::-webkit-input-placeholder{ color:#1e1e1e;}
.headSearch .searchInp .sch{ text-indent: -9999px; width: 50px; height: 60px; background: url(../images/ic_sch2.png) no-repeat 90% 50% / 14px;}
.headSearch .keywords{ margin: 35px 0 0 0;}
.headSearch .keywords dt{ color:#0e1a73;}
.headSearch .keywords dd{ display: flex; flex-wrap: wrap; margin: 20px 0 0 0; font-size: 14px; gap: 20px 10px; }
.headSearch .keywords dd span{ display: inline-flex; align-items: center; color:#333; align-items: center;}
.headSearch .keywords dd .del{ font-size: 0; color: transparent; width: 12px; height: 12px; background: url(../images/ic_x_s.png) no-repeat 50% 50% / 8px; margin-left: 8px; }

.menu-bg{ position: fixed; top: 0; left: 0;  width: 100%;  height: 100%;  pointer-events: none; z-index: 10;}
.menu-bg .bg-part { position: absolute;  width: 25%;  height: 100%; background-color: #000; background-image: url(../images/bg_menu.jpg); background-size: 1920px; background-repeat: no-repeat; transform: scaleY(0);  transform-origin: top;}
.menu-bg .part1 { top: 0; left: 0; transform-origin: top; background-position: 0 0;}
.menu-bg .part2 { top: 0; left: 25%; transform-origin: bottom; background-position: 25% 0;}
.menu-bg .part3 { top: 0; left: 50%; transform-origin: top; background-position: 50% 0;}
.menu-bg .part4 { top: 0; left: 75%; transform-origin: bottom; background-position: 100% 0;}
.menu-content{ position: fixed;  top: 0; left: 0; z-index: 11; width: 100%; height: 100%; padding: 120px 60px 0;  display: none;}
.menu-content .allMenu{ display: flex; color: #fff;}
.menu-content .allMenu a{ display: block;}
.menu-content .allMenu > li{ flex:1;}
.menu-content .allMenu > li > a{ font-size: 30px; color: #fff; font-weight: 600;}
.menu-content .allMenu > li > ul{ margin: 24px 0 0 0;}
.menu-content .subDepth{ margin: 25px 0 0 0;}
.menu-content .depth2 > li + li{ margin-top: 20px;}
.menu-content .depth2 > li > a{ font-size:20px; color:#d3d3d3; padding-right:10px;}
.menu-content .depth2 > li > a:hover{ color:#4558f6;}
.menu-content .depth3{ margin-top: 18px;}
.menu-content .depth3 > li + li{ margin-top: 6px;}
.menu-content .depth3 > li > a{ font-size:16px; color:#999; padding-right:1rem;}
.menu-content .depth3 > li > a:hover{ color: #fff; text-decoration: underline;}

footer{ position: relative; width: 100%; background: #000 url(../images/footer_bg.png) no-repeat calc(100% + 14px) 50%; color: #fff; padding: 80px 60px; display: flex; z-index: 2;}
footer .footerLogo{ display: flex; flex-direction: column; width: 475px; display: flex; flex-direction: column;}
footer .footerLogo .logo{ width: 310px;}
footer .btPrivacy{ position: absolute; bottom: 80px; left: 60px; height: 48px; display: flex; align-items: center; color: #fff; width: 210px; border: #999 1px solid; border-radius: 30px; padding: 0 30px;}
footer .btPrivacy::after{ content: ''; position: absolute; top: 50%; right: 30px; width: 14px; height: 14px; display: block; background: url(../images/ic_arr5.png) no-repeat 50% 50% / cover; margin: -7px 0 0 0; transition:all 0.2s ease-in-out;}
footer .footerLogo .btPrivacy:hover::after{ right: 20px; }
footer .footerAddr{ flex: 1; padding: 30px 0 40px;}
footer .footerAddr .contact{ margin-top: 140px;}
footer .footerAddr dt{ font-size: 24px; text-transform: uppercase;}
footer .footerAddr dd{ margin: 20px 0 0 0; color: #999;}
footer .footerAddr dd b{ display: block; color: rgba(255,255,255,.9);}
footer .footerCopy{ display: flex; flex-direction: column; justify-content: flex-end; width: 510px; padding: 30px 0 0 0; text-align: right;}
footer .footerCopy .copyTxt{ color: rgba(153,153,153,.75); }
footer .footerCopy .copyright{ margin: 60px 0 0 0; font-size: 18px; padding: 0;}

.btTop{ position: fixed; top: auto; right: 0; bottom: 0; margin-bottom: 0; width: 40px; height: 40px; display: block; background:#000 url(../images/bt_top.png) no-repeat 50% 50% / 24px; font-size: 0; color: transparent; z-index: 4; transition:all 0.4s ease-in-out;}
.btTop.fComp{ position: absolute; top: 70px; right: 100px; }

.ckWrap{ position: fixed; z-index: 99; bottom: 0; left: 0; width: 100%; background-color: #fbfbfd;}
.ckWrap .ckWrapInner{ max-width: 1440px; margin: 0 auto; display: flex; font-size: 16px; color: #333; padding: 34px 0; justify-content: space-between;}
.ckWrap .ckText a{ color:#0e1a73; text-decoration: underline;}
.ckWrap .ckBtn{ display: flex; gap: 8px;} 

#container{ padding: 90px 0 0 0;}

/* index */
#indexWrap{ position: relative; margin: 0 auto; background-color: #fff; z-index: 1;}
.mainH2{ display: flex; align-items: center; font-size: 54px; line-height: 1.2; color: #000; font-weight: 500; text-transform: uppercase; font-weight: 400; font-family: 'HarmonyOS Sans Medium';}
.mainH2 .more{ margin-left: auto; width: 24px; height: 24px; font-size: 0; background: url(../images/ic_arr2.png) no-repeat 50% 50% / 24px; text-indent: -9999px; transition:all 0.2s ease-in-out;}
.mainH2 > em{ font-size: 42px; font-weight: 400; margin: 0 20px; }
.mainInner{ position: relative;}
.headSubTxt{ color: rgba(255,255,255,.75); font-size: 24px; }

/* 간단한 스타일링 */
.boxMotion{ position: absolute; top: 0; left: 0; height: 960px; width: 100%; z-index: 3;}
.boxMotion .box { width: 1458px; height: 960px;  position: absolute; left: 0;  opacity: 0; background-repeat: no-repeat;}
.boxMotion .box.box1{ background-image: url(../images/boxM1.png); top: -50px; width:120px; height:420px;}
.boxMotion .box.box2{ background-image: url(../images/boxM2.png); top: -50px; width:550px; height:250px;}
.boxMotion .box.box3{ background-image: url(../images/boxM3.png); top: 50px; }
.boxMotion .box.box4{ background-image: url(../images/boxM4.png); top: 50px; display:none;}
.boxMotion .box.box5{ background-image: url(../images/boxM5.png); top: -100px; left: 100px; }
.boxMotion .box.box6{ background-image: url(../images/boxM6.png); top: 100px; left: 100px; display:none;}
.boxMotion .box.box7{ background-image: url(../images/boxM7.png); top: 200px; left: -200px; }
#mainVisual .text{ position: absolute; top: 0; height: 960px; width: 100%; display: flex; flex-direction: column; justify-content: end; padding: 60px 60px 164px; color: #fff; font-family: "Archivo", sans-serif; font-size: 36px; z-index: 4;}
#mainVisual .text span{ opacity: 0;}
#mainVisual .text strong{ font-size: 120px; line-height: 1.2; margin-top: 20px; font-weight: 400; opacity: 0;}

.mainCareer .boxMotion{ position: absolute; top: 0; left: 0; height: 780px; width: 100%; z-index: 3;}
.mainCareer .boxMotion .box { width: 856px; height: 780px;  position: absolute; left: 0;  opacity: 0; background-repeat: no-repeat;}
.mainCareer .boxMotion .box.box1{ background-image: url(../images/boxM21.png); top: -50px; }
.mainCareer .boxMotion .box.box2{ background-image: url(../images/boxM22.png); top: -50px; }
.mainCareer .boxMotion .box.box3{ background-image: url(../images/boxM23.png); top: 50px; }
.mainCareer .boxMotion .box.box4{ top: 50px; }
.mainCareer .boxMotion .box.box5{ background-image: url(../images/boxM25.png); top: -100px; left: 100px; }
.mainCareer .boxMotion .box.box6{ background-image: url(../images/boxM26.png); top: 100px; left: 100px; }
.mainCareer .boxMotion .box.box7{ background-image: url(../images/boxM27.png); width: 905px; top: 200px; left: auto; right: 233px; }

#mainVisual{ position: relative; overflow: hidden;}
#mainVisual::after{ content: ''; width: 100%; height: 2px; background-color: #fff; display: block; position: absolute; bottom: 0; left: 0; z-index: 5;}
#mainVisual img{ width: 100%; }
#mainVisual .swiper-slide{ position: relative;}
#mainVisual .bg{ position: relative;  display:flex; min-height: 960px; }
#mainVisual .bg > div{ position: absolute; top:0; left:0; bottom:0;flex:1; width:100%; background-size: cover; background-position:50% 50%; background-repeat:no-repeat;}
#mainVisual .bg > div.bg-mob{ display:none;}
#mainVisual .pag{ position: absolute; z-index: 2; display: flex; bottom: 60px; left: 60px; color: #fff; align-items: center; font-family: "Archivo", sans-serif; z-index: 4;} 
#mainVisual .pag .swiper-pagination-total{ opacity: .25;}
#mainVisual .custom-scrollbar{ width: 40px; margin: 0 20px; height: 2px; position: relative; z-index: 4;}
#mainVisual .swiper-scrollbar{ top: 0; left: 0; height: 2px; background-color: rgba(255,255,255,.25); width: 100%; opacity: 1 !important;}
#mainVisual .swiper-scrollbar-drag{ background-color: #fff;}
#mainVisual .progress-bx{ position: absolute; top: auto; bottom: 390px; left: 60px; padding: 0; width: calc(100% - 330px); height: 1px; background: rgba(255,255,255,.25); z-index: 3;}
#mainVisual .progress-bx .scroll-progress{  position: relative; height: 1px; background: rgba(255,255,255,1); width: 0%; pointer-events: none;}
#mainVisual .bulletPag{ position: absolute; left: 0; bottom: 64px; width: 100%; z-index: 2; display: flex; justify-content: center;  z-index: 4;}
#mainVisual .bulletPag .swiper-pagination-bullet{ position: relative; width: 16px; height: 16px; background-color: transparent; opacity: 1; margin: 0 4px;  cursor:pointer;}
#mainVisual .bulletPag .swiper-pagination-bullet::after{ content: ''; position: absolute; top: 50%; left: 50%; width: 2px; height: 16px; display: block; background-color: rgba(255,255,255,.5); margin: -8px 0 0 -1px; transition:all 0.2s ease-in-out;}
#mainVisual .bulletPag .swiper-pagination-bullet.swiper-pagination-bullet-active::after{ background-color: rgba(255,255,255,1); transform: rotate(-45deg);}

.quickWrap{ position: absolute; right: 0; top: calc(50% - 250px); width: 270px; overflow: hidden; z-index: 5;}
.floatQuick{ position: relative; width: 580px; height: 580px; }
.floatQuick::before{ content: ''; position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); border-radius: 50%; display: block; width: 10px; height: 10px; opacity: 0; border: rgba(255,255,255,.6) 2px solid; transition:all 0.4s ease-in-out;}
.floatQuick.on::before{ width: 578px; height: 578px; opacity: 1;}
.quick-item{ position: absolute; width: 130px; height: 40px; color: white; display: flex; align-items: center; cursor: pointer;  font-size: 18px; }
.quick-item:hover{ text-decoration: underline;}
.quick-item::before{ content: ''; width: 26px; height: 26px; margin-right: 5px; background-repeat: no-repeat; background-size: cover;}
.quick-item:nth-child(1):before{ background-image: url(../images/ic_quick2.png);}
.quick-item:nth-child(2):before{ background-image: url(../images/ic_quick3.png);}
.quick-item:nth-child(3):before{ background-image: url(../images/ic_quick4.png);}
.quick-item:nth-child(4):before{ background-image: url(../images/ic_quick5.png);}
.quick-item:nth-child(5):before{ background-image: url(../images/ic_quick6.png);}
.quick-item:nth-child(6):before{ background-image: url(../images/ic_quick6.png);}
#quick-button{ position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); width: 165px; height: 165px;       cursor: pointer; z-index: 10; }
#quick-button::before{ content: ''; border-radius: 50%; opacity: .3; width: 195px; height: 195px; display: block; position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); background: linear-gradient(176deg,rgba(180, 55, 53, 1) 0%, rgba(80, 91, 167, 1) 100%, rgba(80, 91, 167, 1) 75%);}
#quick-button span{ position: relative; width: 165px; height: 165px; background: #fe320f; color: white; border-radius: 50%; display: flex; align-items: center; justify-content: start; font-size: 16px; padding: 16px 0 0 0; flex-direction: column;transform: rotate(-90deg) translateZ(0);  transform-origin: 50% 51%;  will-change: transform;  -webkit-font-smoothing: antialiased;}
#quick-button span::before{ content: ''; width: 8px; height: 8px; border-top: #fff 2px solid; border-right: #fff 2px solid; transform: rotate(-45deg); margin: 0 0 5px 0; transition:all 0.4s ease-in-out;}
#quick-button.active span::before{ transform: rotate(135deg);}

.mainValue{ padding: 110px 60px 120px; display: flex; flex-direction: column; align-items: center;}
.mainValue .valueState{ display: flex; align-items: center; width: 100%; }
.mainValue .valueState .valueItm{ position: relative; flex: 1; display: flex; align-items: center; justify-content: center; flex-direction: column;}
.mainValue .valueState .valueItm:nth-child(2)::before{ content: ''; display: block; top: 40px; bottom: 40px; left: 0; width: 1px; position:absolute; background-color:#e6e6e6; }
.mainValue .valueState .valueItm:nth-child(2)::after{ content: ''; display: block; top: 40px; bottom: 40px; right: 0; width: 1px; position:absolute; background-color:#e6e6e6; }
.mainValue .valueState .num{ position: relative; display: flex; font-size: 18px; color: #000; letter-spacing: -.05em; line-height: 1;}
.mainValue .valueState .num b{ font-weight: 400; font-size: 240px; letter-spacing: -.1em; padding-right: 50px; font-family: 'HarmonyOS Sans Regular';}
.mainValue .valueState .num i{ width: 30px; height: 30px; position: absolute; bottom: 40px; right: 0; display: block;}
.mainValue .valueState .num i::before,
.mainValue .valueState .num i::after{ content: ''; position: absolute; top: calc(50% - 1px); left: 50%; margin-left: -15px; background-color: #185eed; width: 30px; height: 2px; display: block;}
.mainValue .valueState .num i::after{ transform: rotate(90deg); }
.mainValue .valueState .txt{ padding: 50px 0; color: #333; font-family: 'HarmonyOS Sans Regular';}
.mainValue .valueState .name{ font-size: 30px; letter-spacing: -.05em; font-family: 'HarmonyOS Sans Regular';}
.mainValue .valueTxt{ color: #e6e6e6; font-size: 60px; display: flex; flex-direction: column; align-items: center;  letter-spacing: -.07em; font-weight: 600;}
.mainValue .valueTxt-mob{ display: none;}
.mainValue .valueImg{ margin: 40px auto;}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.mainValue .txt_wrap{display: flex; flex-direction: column; align-items: center;}
.mainValue .txt_wrap .tit{display: inline-block; position: relative; white-space: nowrap; color: #e6e6e6; letter-spacing: -.07em;  font-size: 60px; font-weight: 600; line-height: 1.425em;}
.mainValue .txt_wrap .tit .copy {position: absolute; left: 0; top: 0; width: 0%; height: 100%; font-size: 1em; font-weight: inherit; color: #000; overflow: hidden; white-space: nowrap;}
.mainValue .txt_wrap.vis-mob{ display: none;}


.mainSlide{ padding: 0 120px 0; }
.mainSlide .slideWrap{ display: flex; justify-content: space-between; border-top: #e6e6e6 1px solid; padding: 120px 0 200px; }
.mainSlide .image-stack{ position: relative;  width: 718px;  height: 550px;  padding: 0; margin: 120px 0 0 0;}
.mainSlide .slide {  position: absolute;  left: 0;  width: 718px;  height: 550px;  transform-origin: top center;  transition: transform 0.6s ease, top 0.6s ease, opacity 0.6s ease;  opacity: 1;}
.mainSlide .slide.visible { opacity: 1;}
.mainSlide .image-stack img.n1{ filter: none;}
.mainSlide .textArea{ width: 700px; display: flex; flex-direction: column; padding: 50px 20px 90px 0;}
.mainSlide .text h2,
.mainSlide .text p{ opacity: 0; letter-spacing: -.1em;}
.mainSlide .text h2{ font-size: 48px; line-height: 1.4; font-weight: 500; color: #000;}
.mainSlide .text h2 b{ font-size: 72px; font-weight: 500; display: block;}
.mainSlide .text p{ font-size: 30px; margin: 60px 0 0 0;}
.mainSlide .text.fade-anim h2,
.mainSlide .text.fade-anim p {  animation: fadeInUp 0.6s ease forwards;}
.mainSlide .slider-buttons{ margin: auto 0 0; display: flex; align-items: center;}
.mainSlide .slider-buttons button{ width: 32px; height: 32px; background: url(../images/ic_arr.png) no-repeat 50% 50% / cover; border: none; cursor: pointer; font-size:0; opacity: .2; transition:all 0.2s ease-in-out;}
.mainSlide .slider-buttons button:hover{ opacity: 1;}
.mainSlide .slider-buttons button.prev{ transform: rotate(180deg); }
.mainSlide  #counter{ margin: 0 45px; color: #999;}
.mainSlide  #counter b{ color: #000; font-weight: 500; }

.mainSlide2{ display: none;}

.mainProd{ padding: 100px 60px; border-top: #000 1px solid; overflow: hidden;}
.mainProd .tab{ display: flex; margin: 60px 0 0 0; padding: 0 0 30px 0;}
.mainProd .tab > * + *{ margin-left: 8px;}
.mainProd .tab2{ display: flex; align-items: center; font-size: 18px; padding: 28px 0 0 0; border-top: #e6e6e6 1px solid; line-height: 1; overflow-x:auto;}
.mainProd .tab2 > *{ color:#999; padding: 0 40px;}
.mainProd .tab2 > * + *{ border-left: #d9d9d9 1px solid;}
.mainProd .tab2 > *.on,
.mainProd .tab2 > *:hover{ color:#1e1e1e; }
.mainProd .tab2 > *.on{ font-weight: 600;}
.prodSlide{ margin: 40px 0 0 0;}
.prodSlide .swiper-slide{ width: 420px;}
.prodSlide .swiper-slide .img{ height: 510px; display: flex; background-color: #f6f9f6; justify-content: center; align-items: center; border-radius: 10px; transition:all 0.2s ease-in-out;}
.prodSlide .swiper-slide .img img { transition: transform 0.5s cubic-bezier(0.4,0,0.2,1);}
.prodSlide .swiper-slide .txt{ padding: 0 80px 0 15px; margin: 30px 0 0 0; line-height: 1.4; color:#1e1e1e; font-size: 21px;}
.prodSlide .swiper-slide:hover .img{ border-radius: 20px; background-color: #e9eee8;}
.prodSlide .swiper-slide:hover .img img { transform: scale(1.12);}
.prodSlide .control{ margin: 85px 0 0 0; display: flex; align-items: center; justify-content: center;}
.prodSlide .control .pag{ width: auto; margin: 0 45px; color: #999;}
.prodSlide .control .pag .swiper-pagination-current{ color: #000; font-weight: 500; }
.prodSlide .control button{ width: 32px; height: 32px; background: url(../images/ic_arr.png) no-repeat 50% 50% / cover; border: none; cursor: pointer; font-size:0; opacity: .2; transition:all 0.2s ease-in-out;}
.prodSlide .control button:hover{ opacity: 1;}
.prodSlide .control button.prev{ transform: rotate(180deg); }
.mainCert{ padding: 110px 60px; background-color: #0f112a;}
.mainCert .mainH2,
.mainPartners .mainH2{ color: #fff;}
.mainCert .mainH2 .more,
.mainPartners .mainH2 .more{ background-image: url(../images/ic_arr3.png); }
.mainCert .certList{ overflow: hidden; margin: 80px 0 0 0;}
.mainCert .certList .swiper-slide{ width: 450px; display: flex; padding: 0 0 0 30px;}
.mainCert .certList .img{ width: 127px;}
.mainCert .certList .txt{ flex: 1; display: flex; flex-direction: column; color: #fff; line-height: 1.2; padding: 0 20px 5px 0;}
.mainCert .certList .txt h3{ font-size: 21px; font-weight: 500;}
.mainCert .certList .txt p{ margin: auto 0 0 0; opacity: .5; word-break: break-all;}

.mainPartners{ padding: 0 60px 110px; background: #0f112a url(../images/bg_mPart.jpg) no-repeat 50% 0 / cover; overflow: hidden;}
.mainPartners .mainInner{ padding: 110px 0 0 0; }
.mainPartners .line{ position: absolute; width: 100%; top: 0; left: 0; display: flex;}
.mainPartners .line > div{ width: 12px;}
.mainPartners .line > div > div{ width: 1px; background-color: #fff; opacity: 0; height: 18px;}
.mainPartners .headSubTxt{ margin: 75px 0 0 0;}

.marquee-con{ display: flex; height: 67px; margin: 270px -60px 0; overflow: hidden;}
.marquee-con .marquee{ display: flex; align-items: center; justify-content: center; width: auto;  animation: marquee 200s linear infinite; }
.marquee-con .marquee div{ width: 3800px; height: 67px; padding: 0 80px; display: flex; justify-content: center;}
.marquee-con .marquee div img{ width: auto; height: 67px; filter:brightness(0) invert(1); transition:all 0.2s ease-in-out;}
.marquee-con .marquee div img + img{ margin-left: 80px;}
.marquee-con .marquee div img:hover{ filter:brightness(100%) invert(0);}
@keyframes marquee {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-200%);
  }
}

.animated-button{ position: relative; display: inline-block; padding: 0 50px; line-height: 58px;  background-color: #fff;  color: #999; border-radius: 40px;  border: 1px solid #d3d3d3; font-size: 16px;  cursor: pointer;  overflow: hidden;  transition:all 0.8s ease;}
.animated-button::before {  content: ""; position: absolute; left: -40%; bottom: -100px; width: 140%; height: 100px; border-radius: 100% 100% 0 0;  background-color: #ff320f; z-index: 1; transition: bottom 0.4s ease;}
.animated-button::after{ content: attr(data-text); position: absolute; left: 50%; bottom: -100px; display: block; line-height: 58px; transform: translateX(-50%);  color: #fff; z-index: 2;  transition: bottom 0.6s ease 0.1s;  white-space: nowrap; font-weight: 600;}
.animated-button:hover,
.animated-button.on{ color: transparent; border-color:#ff320f;}
.animated-button:hover::before,
.animated-button.on::before{ bottom: 0; left: -40%;}
.animated-button:hover::after,
.animated-button.on::after{ bottom: 0; transform: translateX(-50%) translateY(0);}

@keyframes separatorBar {
    0%,to {
        transform: scaleY(1) scaleX(1);
        opacity: .2
    }
    50% {
        transform: scaleY(1.3) scaleX(1.2);
        opacity: .5
    }
}
.animate-separator{ animation: separatorBar 4s ease-in-out infinite}

.mainCust{ padding: 120px 60px; background-color: #f8f8fa; display: flex;}
.mainCust > a{ border-radius: 30px; padding: 50px 60px 60px; flex:1; background-color: #fff; display: flex; flex-direction: column; align-items: center; font-size: 30px; color: #000;}
.mainCust > a + a{ margin-left: 30px;}
.mainCust > a::before{ content: ''; width: 120px; height: 120px; display: block; margin: 0 auto 40px; background-size: cover;}
.mainCust > a.mCustItm1::before{ background-image: url(../images/mCust1.png); }
.mainCust > a.mCustItm2::before{ background-image: url(../images/mCust2.png); }
.mainCust > a.mCustItm3::before{ background-image: url(../images/mCust3.png); }
.mainCust > a:hover{ background-color: #edeef4; color: #0e1a73;}

.mainNews{ padding: 110px 60px; overflow: hidden;}
.newsWrap{ display: flex; flex-direction: column; margin: 60px 0 0 0; border-top: #000 2px solid;}
.newsWrap .newsItm{ position: relative; display: flex; flex-wrap: wrap; align-items: center; margin: 0 -60px; padding: 0 60px;}
.newsWrap .newsItm > *{ position: relative; padding: 30px 0; line-height: 1.2;  transition:all 0.4s ease-in-out;}
.newsWrap .newsItm .cate{ display: flex; text-transform: uppercase; width: 300px; z-index: 2; font-weight: 500;}
.newsWrap .newsItm .cate .new{font-size: 0; color: transparent; background-color: #ff320f; width: 6px; height: 6px; border-radius: 50%; margin-left: 10px;}
.newsWrap .newsItm .newsTxt{ flex:1; font-weight: 300; z-index: 2; }
.newsWrap .newsItm .date{ width: 120px; font-weight: 500; z-index: 2;}

/*.newsWrap .newsItm .date{ width: 740px; font-weight: 300; z-index: 2;}
.newsWrap .newsItm .newsTxt{ font-weight: 500; z-index: 2;} */
.newsWrap .newsItm::before{ content: ''; position: absolute; bottom: 0; left: 60px; right: 60px; height: 1px; background-color: #e6e6e6; }
.newsWrap .newsItm::after{ content: ''; position: absolute; width: 100%; height: 0; background-color: #0f112a; bottom: 0; left: 0; transition:all 0.4s ease-in-out;}
.newsWrap .newsItm:hover::after{  height: calc(100% + 1px); }
.newsWrap .newsItm:first-child:hover::after{ height: calc(100% + 2px); }
.newsWrap .newsItm:hover > *{ color: #fff; font-weight: 500;}

.mainSolution{ padding: 0 60px 110px; display: flex; gap: 20px;}
.mainSolution .solutionItm{ width: 0; height: 480px; background-color: #185eed; color: #fff; border-radius: 20px; padding: 120px 60px 60px; transform: translateX(-100px); opacity: 0; display: flex; flex-direction: column;}
.mainSolution .solutionItm1{ background-color: #0e1a73;}
.mainSolution .solutionItm b{ font-size: 48px; font-weight: 500;}
.mainSolution .solutionItm span{ margin: 110px 0 0 0; padding: 0 0 0 350px; font-size: 24px;}
.mainSolution .solutionItm i{ position: absolute; left: 60px; bottom: 80px; width: 120px; height: 120px; display: block; margin: 0; background-size: cover;}
.mainSolution .solutionItm.solutionItm1 i{ background-image: url(../images/mSolu1.png); }
.mainSolution .solutionItm.solutionItm2 i{ background-image: url(../images/mSolu2.png); }
.mainSolution .solutionItm::after{ content: ''; position: absolute; width: 47px; height: 47px; display: block; background: url(../images/ic_arr4.png) no-repeat 50% 50% / cover; top: 60px; right: 60px;}
.mainSolution .solutionItm .icon,
.mainSolution .solutionItm .text,
.mainSolution .solutionItm .tit{  opacity: 0;  transform: translateY(20px); /* 업효과를 위한 초기 설정 */}

.mainCareer{ position: relative; overflow: hidden;}
.mainCareer .careerImg{ transform-origin: center bottom; transform: scale(0.5) translateY(80px); opacity: 0; max-width: 100%; }
.mainCareer .careerImg img{ width: 100%; height: 778px; object-fit: cover;}
.mainCareer .careerImg img.img-mob{ display: none;}
.mainCareer .text{ position: absolute; top: 0; left:0;  padding: 150px 110px 220px 110px; opacity: 0; transform: translateY(30px); z-index: 6;}
.mainCareer .text .mainH2{ color: #fff;}
.mainCareer .text .headSubTxt{ margin: 60px 0 0 0; font-size: 48px; line-height: 1.2; color:#fff; font-weight: 500;}
.mainCareer .text .bt{ position: absolute; width: 47px; height: 47px; display: block; background: url(../images/ic_arr4.png) no-repeat 50% 50% / cover; bottom: 0; left: 110px; text-indent:-9999px;}


/* sub layout */
.tit_wrap{ padding: 120px 0 0 240px; margin-bottom: 80px; color: #000; font-size: 36px; display: flex; align-items: baseline;}
.tit_wrap .tit{ font-size: 60px; font-weight: 700;}
.tit_wrap .desc{ padding: 0 0 0 50px; font-weight: 600; font-family: 'HarmonyOS Sans Medium';}

.visual_sect{ overflow: hidden; position: relative; height: 480px; margin: 0;}
.visual_sect .tit_box{ position: absolute; top: 0; bottom: 0; width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: start; padding: 0 240px 72px;  color: #fff; font-size: 36px; z-index: 2;}
.visual_sect .tit_box em{ font-size: .6675em; margin-top: 20px; color: #d3d3d3;}
.visual_sect .img { position: relative; width: 100%;}
.visual_sect .img img { width: 100%; height: 480px; object-fit: cover;}
.visual_sect:after { display:block; content:''; width:100%; height:101%; position:absolute; top: -0.5%; left: 0; right: 0; bottom: 0; background-color:#fff; transition: left 1.4s ease-in-out; -webkit-transition: left 1.4s ease-in-out; -moz-transition: left 1.4s ease-in-out; -ms-transition: left 1.4s ease-in-out; -o-transition: left 1.4s ease-in-out; } 
.visual_sect.animate::after { left:100%; } 

.locationBar{ position:relative; padding: 0 60px; margin: 0; width:100%; z-index:3; border-bottom: #d3d3d3 1px solid; border-top: #d3d3d3 1px solid; background-color: #fff; display: flex;}
.visual_sect + .locationBar{ margin-top: -70px;}
.locationBar .inner{ position:relative; margin:0; display: flex; z-index: 1;}
.locationBar .home{ width:72px; border-right:#d3d3d3 1px solid; display: flex; align-items: center;}
.locationBar .home > a{ width: 100%; display: block; height: 71px; background:url('../images/ic_h.png') 50% 50% no-repeat; font-size: 0;}
.locationBar .location{ position:relative; min-width:205px; float:left;}
.locationBar .location > a,
.locationBar .location > span{ display:block; white-space: nowrap; line-height:70px; height:70px; padding:0 40px 0 25px; font-size:18px; color:#1e1e1e; border-right:#d3d3d3 1px solid;}
.locationBar .location>a:after{ content:""; position:absolute; top:50%; right:22px; margin-top:-5px; width:10px; height:10px; display:block; border-top: #1e1e1e 2px solid; border-right: #1e1e1e 2px solid; transform: rotate(135deg); transition: all 0.2s ease-in-out; }
.locationBar .location.active > a:after{ margin-top:-4px; transform:rotate(-45deg); }
.locationBar .location > ul{ display:none; position:absolute; top:72px; left:-1px; right:0; background-color:#fff; border:#999 1px solid; border-top:none; padding:15px 0;}
.locationBar .location > ul>li>a{ display:block; font-size: 16px; color: #575757; padding:10px 10px 10px 28px; white-space: nowrap;}
.locationBar .location > ul>li>a:hover{ background-color: #f5f5f5; color: #000;}
.locationTab{ margin-left: auto; display: flex; gap: 50px;}
.locationTab a{ position: relative; line-height: 71px; font-size: 18px; color: #1e1e1e; padding: 0 5px;}
.locationTab a::after{ content: ''; position: absolute; bottom: -1px; left: 50%; width: 0; background-color: #000; height: 3px; transition:all 0.2s ease-in-out;}
.locationTab a.active{ color: #000; font-weight: 600;}
.locationTab a:hover::after,
.locationTab a.active::after{ width: 100%; left: 0;}
.locationBar.fixed{ position: fixed; top: 0; left: 0; margin: 0;}

.visual_sect.h0{ height: 0;}
.visual_sect.h0 + .locationBar{ margin-top: 0;}

.contents{ position: relative; padding: 0 60px 120px; margin: 120px 0 0 0; display: flex; justify-content: center;}
.contents .page{ max-width: 1440px; margin: 0 auto; flex:1;}

.sorting-bx{ display: flex; align-items: center; padding: 0 0 23px 0; border-bottom: #e6e6e6 1px solid; gap: 8px; }
.sorting-bx .sort-itm{ border:#999 1px solid;  height: 36px; display: flex; align-items: center; justify-content: space-between; padding: 0 14px; color:#000; font-size: 14px; border-radius: 10px; min-width: 90px; font-weight: 600; }
.sorting-bx .sort-itm .del{ width: 14px; height: 14px; background: url(../images/ic_x_s2.png) no-repeat 50% 50% / 8px; font-size: 0;}
.sorting-bx .btReset{ color:#1e1e1e; font-size: 14px; font-weight: 600;  border-radius: 10px; min-width: 90px; height: 36px; display: flex; padding: 0 14px; align-items: center; border:#f3f3f7 1px solid; background-color: #f3f3f7;}
.sorting-bx .btReset::after{ content: ''; width: 16px; height: 16px; background: url(../images/ic_reset.png) no-repeat 50% 50% / cover; margin-left: 24px; }
.sorting-bx .btReset:hover{ border-color:#dfe1eb; background-color: #fff;}
.sorting-bx .btGuide{ margin-left: auto; background-color: #fe320f; height: 48px; font-size: 14px; color: #fff; align-items: center; border-radius: 24px; padding: 0 24px; display: flex; justify-content: center; min-width:230px;}
.sorting-bx .btGuide::after{ content: ''; width: 20px; height: 20px; background: url(../images/ic_guide.png) no-repeat 50% 50% / 20px; margin-left: 15px;}
.sorting-bx .sorting-bx-l{ display: flex; gap:8px; flex-wrap: wrap;}
.sorting-bx .sorting-bx-r{ margin-left: auto;}
.sorting-bx .btFilter{ display: none; background-color: #808290; color:#fff; border-radius: 30px; align-items: center; justify-content: center;} 
.sorting-bx .btFilter::after{ content: ''; width: 1.9rem; height: 1.9rem; display: block; border-radius: 50%; margin-left: .5rem; background: #2b40f5 url(../images/ic_filter.png) no-repeat 50% 50% / 1rem;}

.tblHd{ margin: 30px 0 0 0; height: 60px; display: flex; justify-content: space-between; align-items: center;}
.tblHd .total strong{ color:#2b40f5; font-weight:400;}
.tblHd .tblHd-r .btFilter{ display: none; background-color: #808290; color:#fff; border-radius: 30px; align-items: center; justify-content: center;} 
.tblHd .tblHd-r .btFilter::after{ content: ''; width: 1.9rem; height: 1.9rem; display: block; border-radius: 50%; margin-left: .5rem; background: #2b40f5 url(../images/ic_filter.png) no-repeat 50% 50% / 1rem;}
.tblHd .tblSch{ position: relative; width: 420px; display: flex;}
.tblHd .tblSch .inp{ background-color: #f2f2f2; height: 60px; line-height:60px; padding: 0 70px 0 30px; border: none; border-radius: 30px; flex:1;}
.tblHd .tblSch .inp:focus{ outline: none; background-color:#f2f2f2; }
.tblHd .tblSch .sch{ position: absolute; top: 50%; right: 0; width: 60px; height: 60px; transform: translateY(-50%); border-radius: 50%;  background: #484a5d url(../images/ic_sch.png) no-repeat 50% 50% / 24px;}
.tblHd .tblSch .sch:hover{ background: #333 url(../images/ic_sch.png) no-repeat 50% 50% / 24px;}
.form-hdtx{ display: flex; justify-content: end; align-items: center; margin: -90px 0 60px; width: 100%;}
.form-hdtx .req{ font-size: 16px; font-weight: 400; color:#fe320f; margin-right: 10px;}

.tblList{ border-top: #000 1px solid; margin: 30px 0 0 0; min-height:92vh;}
.tblList > .hd{ height: 76px; display: flex; align-items: center; border-bottom: #000 1px solid;}
.tblList > .hd .hd-itm{ width: 240px; color:#000; font-weight: 600; text-align: center; border-left: #fff 1px solid;}
.tblList > .bd .bd-row{ display: flex; align-items: center; border-bottom: #e6e6e6 1px solid; width: 100%;}
.tblList > .bd .bd-row:last-child{ border-color:#999; }
.tblList > .bd .bd-itm{ width: 240px; padding: 26px 0; text-align: center;}
.tblList > .hd .hd-itm.no,
.tblList > .bd .bd-itm.no{ width: 84px; border-left:none;}
.tblList > .hd .hd-itm.ico,
.tblList > .bd .bd-itm.ico{ width: 140px;}
.tblList > .hd .hd-itm.date,
.tblList > .bd .bd-itm.date{ width: 180px;}
.tblList > .hd .hd-itm.vew,
.tblList > .bd .bd-itm.vew{ width: 100px;}
.tblList > .hd .hd-itm.model,
.tblList > .bd .bd-itm.model{ width: 220px;}
.tblList > .hd .hd-itm.rev,
.tblList > .bd .bd-itm.rev{ width: 180px;}
.tblList > .hd .hd-itm.prod,
.tblList > .bd .bd-itm.prod{ flex:1; padding: 26px 40px;}
.tblList > .hd .hd-itm.subj,
.tblList > .bd .bd-itm.subj{ flex:1; padding: 26px 40px;}
.tblList > .bd .bd-itm a:hover{ text-decoration: underline; }
.tblList.notice > .bd .bd-itm.subj{ text-align: left;}
.tblList .btDown{ display: inline-block; font-size: 0; width: 24px; height: 24px; }
.tblList .btDown::after{ content: ''; display: inline-block; width: 24px; height: 24px; background: url(../images/ic_down.png) no-repeat 50% 50% / cover;}

div.paging{ text-align:center; padding:0; margin:90px 0 0 0; position:relative; }
div.paging a,
div.paging strong{ display:inline-block; width:42px; height:42px; line-height:40px; color:#1e1e1e; text-align:center; margin:0; vertical-align:middle; overflow: hidden; margin-left: -5px; }
div.paging a:hover{ color:#2b40f5;}
div.paging .on,
div.paging .on:hover{ color:#2b40f5; font-weight:400;}
div.paging .direction{ position:relative; background-position: 50% 50%; background-size: 24px; background-repeat: no-repeat; opacity: .2;}
div.paging .direction > span{ position:absolute; top:-9999px; left:-9999px;}
div.paging .direction.first{ background-image: url(../images/ic_paging_last.png); transform:rotate(-180deg);}
div.paging .direction.prev{ background-image: url(../images/ic_paging_next.png); transform:rotate(-180deg);}
div.paging .direction.next{ background-image: url(../images/ic_paging_next.png);}
div.paging .direction.last{ background-image: url(../images/ic_paging_last.png);}
div.paging .direction:hover{ opacity: 1;}

#filterWr{ max-width: 300px; flex:1 1 300px; margin-left: -60px; margin-right: 120px;}
#filterWr label{ display: flex; width: 100%; font-size: 14px; color: #484a5d; align-items: center; font-weight: 500;}
#filterWr label input{ margin-right: 15px;}
#filterWr > .hd{ background-color: #808290; height: 60px; display: flex; align-items: center; justify-content: space-between; padding: 0 28px;}
#filterWr > .hd h3{ font-size: 18px; font-weight: 400; color: #fff; display: flex; align-items: center; }
#filterWr > .hd h3::after{ content: ''; width: 14px; height: 14px; background: url(../images/ic_filter.png) no-repeat 50% 50% / cover; margin-left: 16PX;}
#filterWr > .hd h3 .close{ display: none;}
#filterWr > .hd .btReset{ font-size: 0; width: 16px; height: 16px;  }
#filterWr > .hd .btReset::after{ content: ''; display: block; width: 16px; height: 16px; background: url(../images/ic_reset.png) no-repeat 50% 50% / cover;  filter: brightness(0) invert(1);}
#filterWr > .hd .hd-r{ display: flex;}
#filterWr > .hd .btResult{ display: none;}
#filterWr > .all{ background-color: #fbfbfc; padding: 20px 28px;}
#filterWr > .all label{ font-size: 16px; color: #2d3685; font-weight: 600;}

.filterLst > li{ border-bottom:#c2c3d8 1px solid; border-top:#c2c3d8 1px solid;}
.filterLst > li + li{ margin-top: -1px;}
.filterLst > li:first-child{ border-top:#c2c3d8 1px solid;}
.filterLst > li .btOpen{ width: 100%; align-items: center; justify-content: space-between; display: flex; color:#2d3685; font-weight: 600; padding: 0 28px; height: 58px; font-size: 16px; background-color: #f7f7fa;}
.filterLst > li .btOpen i{ position: relative; width: 12px; height: 12px; }
.filterLst > li .btOpen i::before,
.filterLst > li .btOpen i::after{ content: ''; position: absolute; top: calc(50% - 1px); left: calc(50% - 6px); display: block; width: 12px; height: 2px; background-color: #2d3685; display: block; transition:all 0.2s ease-in-out;}
.filterLst > li .btOpen i::after{ transform: rotate(0);}
.filterLst > li.on{ border-color:#f3f3f7; }
.filterLst > li.on .btOpen{ background-color:#fbfbfc;}
.filterLst > li.on .btOpen i::after{ transform: rotate(90deg); background-color: #2d3685; }
.filterLst .depth2{ padding: 24px 40px; display: flex; flex-direction: column; gap: 16px;}
.depth2-grp > strong{ display: flex; height: 60px; align-items: center; font-size: 15px; color: #2b2d43; padding: 0 28px; border-bottom: #f1f2f5 1px solid;  border-top: #f1f2f5 1px solid; }
.depth2-grp > strong::before{ content: ''; background-color: #dfe1eb; width: 4px; height: 4px; margin-right: 13px;}

.no-result{ color:#808290; display: flex; flex-direction: column; text-align: center; align-items: center; font-size: 20px; padding: 120px 0; width:100%;}
.no-result::before{ content: ''; display: block; margin: 0 auto 50px; width: 66px; height: 66px; background: url(../images/ic_exc.png) no-repeat 50% 50% / auto 100%;}

.catalogLst{ width: 100%; display: flex; flex-wrap: wrap; gap: 90px 0;}
.catalogLst .itm{ width: calc(33.3% - 44px); background-color: #f7f9f6; margin-left: 66px; display: flex; flex-direction: column; padding: 0 56px;}
.catalogLst .itm:nth-child(3n+1){ margin-left: 0; }
.catalogLst .itm img{ width: 100%;}
.catalogLst .itm .down{ padding: 30px 0; display: flex; justify-content: space-between; font-size: 18px;}
.catalogLst .itm .down::after{ content: ''; width: 24px; height: 24px; background: url(../images/ic_down.png) no-repeat 50% 50% / cover;}

.form-wr{ display: flex; flex-wrap: wrap; gap: 60px;}
.form-wr .form-itm{ width: calc(50% - 30px);}
.form-wr .form-itm.w100{ width: 100%;}
.form-wr .form-itm .hd{ font-size: 21px; color:#000; font-weight: 700; margin: 0 0 20px 0;}
.form-wr .form-itm .hd strong{ font-size: 16px; font-weight: 400; display: inline-block; margin-right: 15px; color: #999;}
.form-wr .form-itm .hd strong.req{ color:#fe320f;}
.form-wr .form-itm .bd{ display: flex;}
.form-wr .form-itm .bd.column{ flex-direction: column;}
.form-wr .form-itm .bd + .bd{ margin-top: 15px;}
.form-wr .form-itm .inp{ width: auto; flex: 1;}
.form-wr .form-itm .inp-grp{ display: flex; align-items: center; gap:10px; width: 100%; flex-wrap: wrap;}
.form-wr .form-itm .inp-grp .btType input[type="radio"] + span, 
.form-wr .form-itm .inp-grp .btType input[type="checkbox"] + span{ white-space: nowrap;}
.form-wr .form-itm .inp-grp .select,
.form-wr .form-itm .inp-grp .inp{ flex: 1; min-width: 40px;}
.form-wr .form-itm .inp-grp.type{ flex-wrap: wrap;}
.form-wr .form-itm .inp-grp .ba{ color: #999;}
.form-wr .form-itm .textarea{ height: 350px; overflow-y: scroll;}
.form-wr .form-itm .textarea::-webkit-scrollbar{ width: 4px; display: block;}
.form-wr .form-itm .textarea::-webkit-scrollbar-thumb{ background-color: #d3d3d3; border-radius: 0; }
.form-wr .form-itm .textarea::-webkit-scrollbar-thumb:hover{ background-color: #b3b3b3; }
.form-wr .form-itm .textarea::-webkit-scrollbar-track{ background-color: #f5f5f5; border-radius: 0; }
.form-wr .form-itm .textarea::-webkit-scrollbar-track:hover{ background-color: #e6e6e6; }
.form-wr .form-itm input[type=text].inp, 
.form-wr .form-itm input[type=number].inp, 
.form-wr .form-itm input[type=password].inp{ border-radius:0; -webkit-border-radius:0; }
.form-wr .input-wrapper{ position: relative; flex: 1;}
.form-wr .input-wrapper .inp{ width: 100%;}

.fileDown{ display: inline-flex; align-items: center; margin: 20px 0 0 0; padding: 0 12px; font-size: 18px; color: #000;}
.fileDown::before{ content: ''; width: 40px; height: 40px; margin-right: 20px; background: #f6f6f6 url(../images/ic_down.png) no-repeat 50% 50% / 18px; border-radius: 50%; }

.ul-list01 > li{ text-indent: -15px; padding-left: 15px;}
.ul-list01 > li + li{ margin-top: 6px;}
.ul-list01 > li::before{ content: ''; width: 3px; height: 3px; background-color: #d5d6dc; display: inline-block; margin-right: 10px; vertical-align: 5px;}

.form-bottom{ margin: 55px 0 0 0; border-top:#484a5d 2px solid;}
.form-bottom .dv-privacy{ padding: 15px 0; display: flex; align-items: center;}
.form-bottom .dv-privacy .capt{ margin-left: auto; width: auto;}
.form-bottom .dv-privacy label{ margin-right: 50px;}
.form-bottom .dv-privacy label input{ margin-right: 10px;}
.form-bottom .dv-privacy-tx{ display: flex; background-color: #fbfbfc;}
.form-bottom .dv-privacy-tx dl{ flex: 1; padding: 40px 70px;}
.form-bottom .dv-privacy-tx dl + dl{ border-left:#f3f3f7 1px solid;}
.form-bottom .dv-privacy-tx dl dt{ color: #0e1a73; font-size: 20px; font-weight: 600; margin-bottom: 20px;}

/* named upload */
.filebox{ position: relative; text-align: left; display: flex; width: 100%; background-color: #f5f5f5;}
.filebox input[type="file"]{ position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip:rect(0,0,0,0); border: 0;}
.filebox label{ background-color: #fff; display: flex; align-items: center; border: #d3d3d3  1px solid; height: 60px; line-height: 60px; padding: 0 30px; text-align: center; color: #575757;  cursor: pointer; font-weight: 600;}
.filebox label:hover{ border-color: #999; color: #1e1e1e;}
.filebox label::after{ content: ''; margin-left: 50px; width: 16px; height: 16px; background: url(../images/ic_clib.png) no-repeat 50% 50% / cover;}
.filebox .upload-name{ flex: 1; display: inline-block; padding:0 20px; color:#1e1e1e; border: none; font-size: inherit; font-family: inherit; line-height: 60px; height: 60px; vertical-align: middle; border-radius:0; -webkit-appearance: none; -moz-appearance: none; appearance: none;}
.filebox .upload-display{ margin-bottom: 5px;}
.filebox .upload-thumb-wrap{ display: inline-block; max-width:360px; padding: 2px; vertical-align: middle; border: 1px solid #ddd; border-radius: 5px; background-color: #fff;}
.filebox .upload-display img { display: block; max-width: 100%; width: 100%; height: auto;}
.filebox .bt_add,
.filebox .bt_del{ position: relative; display: flex; align-items: center; padding: 0 20px 0 28px; font-size: 16px; color: #484a5d;}
.filebox .bt_del{ padding-left: 58px;}
.filebox .bt_add:hover,
.filebox .bt_del:hover{ color: #0e1a73; font-weight: 600;}
.filebox .bt_add::before,
.filebox .bt_del::before{ content: ''; position:absolute; left: 0; top: 50%; width: 1px; height: 20px; margin-top: -10px; background-color: #484a5d;}
.filebox .bt_add i,
.filebox .bt_del i{ position: relative; width: 13px; height: 13px; margin-left: 30px;}
.filebox .bt_del i{ transform: rotate(45deg);}
.filebox .bt_add i::before,
.filebox .bt_add i::after,
.filebox .bt_del i::before,
.filebox .bt_del i::after{ content: ''; position: absolute; top: 50%; left: 0; display: block; width: 10px; height: 2px; background-color: #484a5d;}
.filebox .bt_add i::after,
.filebox .bt_del i::after{ transform: rotate(90deg); }
.filebox .clear-btn{ right: 170px;}

.lay-pop{ position: fixed; top: 0; left: 0; bottom: 0; width: 100%; background-color: rgba(0,0,0,.5); z-index: 99; display: none;} 
.lay-pop .pop-inner{ width: 100%; height: 100vh; padding: 30px; display: flex; justify-content: center; align-items: center;}
.lay-pop .pop-bx{ position: relative; width: 800px; max-height: 90vh;  display: flex; flex-direction: column; overflow-y: auto;}
.lay-pop .pop-con{ background-color: #fff; padding: 50px; flex:1;overflow-y: auto;}
.lay-pop .pop-close{ position: absolute; top: 20px; right: 20px; width: 20px; height: 20px; display: block; font-size: 0; color: transparent;}
.lay-pop .pop-close::before,
.lay-pop .pop-close::after{ content: ''; position: absolute; width: 16px; height: 2px; background-color: #1e1e1e; display: block; top: 50%; left: 50%; margin: -1px 0 0 -8px; transform: rotate(45deg);}
.lay-pop .pop-close::after{ transform: rotate(-45deg);}
.lay-pop .pop-bt{ background-color:#fff; display: flex; justify-content: center; padding: 30px;}
.lay-pop.sm .pop-bt{ background-color:#2c3684; display: flex; justify-content: center; padding: 0;}
.lay-pop.sm .pop-bt > *{ flex: 1; color:#fff; height:56px; display: flex; justify-content: center; align-items: center;}
.lay-pop.sm .pop-bx{ width: 380px; }
.lay-pop.sm .pop-con{ text-align: center; display: flex; align-items: center; min-height: 110px; width: 100%; justify-content: center;}

.main-pop{ width: 450px;  margin: 0 auto;}
.main-pop .pop-slide{ position: relative; overflow: hidden;}
.main-pop .ctlr{ position: absolute; bottom: 25px; right: 30px; z-index: 2; height: 34px; background-color: rgba(0,0,0,.5); border-radius: 20px; display: flex; padding: 0 14px; color: #a3a4a5; justify-content: center; align-items: center;}
.main-pop .ctlr .pag{ text-align: center; font-size: 14px;}
.main-pop .ctlr .pag .swiper-pagination-current{ color: #fff;}
.main-pop .ctlr .prev,
.main-pop .ctlr .next{ position: relative; width: 20px; height: 20px; font-size: 0; color: transparent;}
.main-pop .ctlr .prev::after,
.main-pop .ctlr .next::after{ content: ''; width: 7px; height: 7px; position: absolute; top: 50%; left: 50%; margin: -3px 0 0 -3px; border-top: #fff 1px solid; border-right: #fff 1px solid; transform: rotate(45deg);}
.main-pop .ctlr .prev::after{ transform: rotate(-135deg);}
.main-pop .ctlr .swiper-button-disabled{ display: none;}
.main-pop-bottom{ display: flex; height: 60px; background-color: #fff; padding: 0 25px; justify-content: space-between; align-items: center;}

.modalPop{ display:none;position:fixed;top:0;left:0;width:100vw;height:100vh; background-color: rgba(0,0,0,.5); z-index:9999;justify-content:center;align-items:center; overflow-y: auto;}
.modalPop .inner{ position: relative; top:50%; transform: translateY(-50%); margin: 0 auto; width: 630px; display: flex; height: 900px; align-items: center; justify-content: center;}
.modalPop #imgModalImg{ width: 100%; height: 900px; max-width:90vw; }
.modalPop .pop-close{ position: absolute; top: 4px; right: -60px; cursor:pointer; z-index:10001; width: 60px; height: 60px; display: block; background-color: #000; font-size: 0; color: transparent;}
.modalPop .pop-close::before,
.modalPop .pop-close::after{ content: ''; position: absolute; width: 20px; height: 2px; background-color: #fff; display: block; top: 50%; left: 50%; margin: -1px 0 0 -8px; transform: rotate(45deg);}
.modalPop .pop-close::after{ transform: rotate(-45deg);}

.newsLst{ display: flex; flex-direction: column; border-top:#000 1px solid; margin: 30px 0 0 0;}
.newsLst .newsLst-itm{ border-bottom:#e6e6e6 1px solid; padding: 55px 0;}
.newsLst .newsLst-itm > a{ display: flex; align-items: center; padding: 0 28px;}
.newsLst .newsLst-itm .img{ width: 346px;  overflow: hidden; margin-right: 35px;}
.newsLst .newsLst-itm .img img{ width: 100%; height: 260px; object-fit: cover; border-radius: 10px;}
.newsLst .newsLst-itm .desc{ flex: 1; display: flex; flex-direction: column; font-size: 18px;}
.newsLst .newsLst-itm .desc .tit{ font-size: 36px; color:#000;}
.newsLst .newsLst-itm .desc .tit em{ color: #2b40f5;}
.newsLst .newsLst-itm .desc .txt{ margin: 35px 0; }
.newsLst .newsLst-itm .desc .date{ color: #1e1e1e;}
.newsLst .newsLst-itm > a:hover .desc .tit{ text-decoration: underline; }

.tblView{ display: flex; flex-direction: column;}
.tblView .prev{ color: #484a5d; font-weight: 600; display: flex; align-items: center; }
.tblView .prev::before{ content: ''; width: 20px; height: 20px; background: url(../images/ic_prev.png) no-repeat 50% 50% / 20px; margin-right: 10px;}
.tblView > .hd{ margin-top: 60px; border-bottom: #000 1px solid;}
.tblView .subject{ font-size: 64px; color: #000; font-weight: 600; line-height: 1.2;}
.tblView .hd-tx{ margin-top: 50px; padding: 15px 0; display: flex; align-items: center; gap:80px;}
.tblView .hd-tx .itm{ display: flex; gap:20px;}
.tblView > .bd{ max-width: 1080px; margin: 140px auto 0; font-size: 18px;}
.tblView.recruit > .bd{ max-width: none; width: 100%; padding: 60px 45px 110px; margin: 0;  border-bottom: #e6e6e6 1px solid;}
.file-list{ margin: 50px 0 0 0;}
.file-list a{ display: flex; align-items: center; background-color:#f3f3f5; padding: 15px 20px 15px 28px;}
.file-list a.jpg::before{ content: ''; width: 20px; height: 20px; background: url(../images/ic_file_jpg.png) no-repeat 0 50% / auto 20px; margin-right: 15px;}
.file-list a::after{ content: ''; width: 20px; height: 20px; background: url(../images/ic_down2.png) no-repeat 50% 50% / 19px; margin: 0 0 0 auto;}

.viewBottomList{ margin: 115px 0 0 0; border-top: #e5e5e5 1px solid; border-bottom: #e5e5e5 1px solid;}
.viewBottomList > ul{ display: flex; padding: 0 30px; }
.viewBottomList > ul > li{ flex:1; padding: 25px 0; width: 50%; display: flex; align-items: center;}
.viewBottomList > ul > li + li{ border-left: #e5e5e5 1px solid;}
.viewBottomList .title{ flex:1;}
.viewBottomList a:hover{ text-decoration: underline; }
.viewBottomList .viewBottomNext .title{ display: block; text-align: right; text-overflow: ellipsis; overflow: hidden;white-space: nowrap;}
.viewBottomList .orderPrev,
.viewBottomList .orderNext{ display: flex; width: 140px; align-items: center; justify-content: center;}
.viewBottomList .orderPrev::before{ content: ''; margin:-2px 10px 0 0; width: 10px; height: 10px; border-top:#1e1e1e 2px solid; border-right:#1e1e1e 2px solid; transform: rotate(-135deg);}
.viewBottomList .orderNext::after{ content: ''; margin:-2px 0 0 10px; width: 10px; height: 10px; border-top:#1e1e1e 2px solid; border-right:#1e1e1e 2px solid; transform: rotate(45deg);}
.viewBottomList .dis{ opacity: .4;}

.skew::before{ content: ''; display: block; background-color: #2b3ab9; transform: skewY(-35deg); width: 20px; height:10px; margin-bottom:10px;}

.sub-tit{ margin: 120px 0 50px;}
.sub-tit .tit{ font-size: 48px; color: #000; font-weight: 700; min-height: 88px; display: flex; line-height: 1.1; align-items: center;}
.sub-tit .tit em{ font-size: .63em; font-weight: 400; display: inline-block; margin-left: 10px;}
.sub-tit.sm .tit{ font-size: 42px;}
.sub-tit.ssm { margin: 85px 0 40px;}
.sub-tit.ssm::before{ margin-bottom: 20px;}
.sub-tit.ssm .tit{ font-size: 36px; min-height: auto;}
.sub-tit .sub-tx{ margin-top: 10px; font-size: 26px;}
.sub-tit .link{ color:#484a5d; font-size:16px; margin-left: auto; text-decoration: underline; font-weight: 400;}

.h3-tit{ font-size: 48px; margin: 100px 0 50px; display: flex; align-items: center; font-weight: 700;}
.h3-tit .link{ color:#484a5d; font-size:16px; margin-left: auto; text-decoration: underline; font-weight: 400;}

.h4-tit{ font-size: 30px; color: #000; margin: 60px 0 30px; font-weight: 500;}
.h4-tit em{ font-size: .63em; font-weight: 400; display: inline-block; margin-left: 10px;}
.sub-tit + .h4-tit{ margin-top: 0;}

/* company */
.company01-obj{ position: absolute; display: inline-block; top: 60px; right: 0; width: 29vw;}
.company01-bx{ position: relative; }
.company01-bx .tx01{ font-size: 45px; font-weight: 700; padding: 0 0 120px 0; border-bottom: #000 1px solid;}
.company01-bx .tx02{ margin: 90px 0 0 0; padding-bottom: 130px; background: url(../images/company01_kv.jpg) no-repeat 100% 100%; color: #000; font-size: 30px;}
.company01-bx .tx02 .tx02-01{ margin-bottom: 90px; font-weight: 500;}
.company01-bx .tx02 .tx02-01 .tit{ font-size: 36px; font-weight: 500;}
.company01-bx .tx02 .tx02-01 b{ display: block; font-size: 78px; font-weight: 600; line-height: 1.2; margin-top: 10px;}
.company01-bx .tx03{ margin: 60px 0 0 0; padding: 170px 60px 110px; position: relative; left: 50%; width: 100vw; transform: translateX(-50%); background: #0f112a url(../images/company01_img_inf.jpg) no-repeat 54% 0 / cover; color: #fff;}
.company01-bx .tx03 .tit{ font-size: 36px; font-weight: 500; max-width:1440px; margin:0 auto;}
.company01-bx .tx03 .tit b{ display: none;}
.company01-bx .tx03 > ul{ font-size: 24px; max-width: 840px; max-width:1440px; margin:100px auto 0; letter-spacing:-.09em;}
.company01-bx .tx03 > ul > li{ display: flex; align-items:center; padding: 35px 0; border-bottom: rgba(255,255,255,.25) 1px solid; max-width:900px;}
.company01-bx .tx03 > ul > li:nth-child(1){ border-top: rgba(255,255,255,.25) 1px solid;}
.company01-bx .tx03 > ul > li strong{ width: 170px; font-weight: 600;}
.company01-bx .tx03 > ul > li span,
.company01-bx .tx03 > ul > li ul{ flex:1;}
.company01-bx .tx03 > ul > li ul li + li{ margin-top: 5px;}
.company01-bx .tx03 > ul > li ul li{ text-indent: -25px; padding-left: 25px;}
.company01-bx .tx03 > ul > li ul li::before{ content: ''; display: inline-block; width: 4px; height: 4px; background-color: #999; margin-right: 20px; vertical-align: 5px;}
.company01-bx .company01-img{ text-align: center; position: relative; width: 100vw; left: 50%; transform: translateX(-50%); margin-bottom: -120px;}
.company01-bx .company01-img .img-pc{ background-color: #000; color: #d3d3d3; font-size: 24px; }
.company01-bx .company01-img .img-pc div{ position: absolute; top: 0; left: 0; width: 100%; padding-top: 7.2vw; display: flex; flex-direction: column; align-items: center;}
.company01-bx .company01-img .img-pc .tit{ font-size: 36px; color: #fff; font-weight: 500;}
.company01-bx .company01-img .img-pc em{ font-size: 78px; margin: 20px 0 30px; color: #fff;}
.company01-bx .company01-img img{ width: 100%;}

.company02-bx .tx01{ font-size: 30px; color: #000; gap:40px; display: flex; flex-direction: column; padding-bottom: 110px; border-bottom: #000 1px solid;}
.company02-bx .tx01 b{ font-size: 54px; }
.history-tab{ position: relative; padding: 0;}
.history-tab::before{ content: ''; position: absolute; top: 0; left: 0; width: 50%; bottom: 0; display: block; background-color: #fff;}
.history-tab.fixed{ position: fixed; top:71px; left: 0; width: 100%; z-index: 2;}
.history-tab .inner{ max-width: 1440px; margin: 0 auto; display: flex; gap:60px;}
.history-tab .itm{ position: relative; width: 120px; color: #999; font-size: 18px; display: flex; flex-direction: column; align-items: center; gap:5px; padding: 60px 0;}
.history-tab .itm b{ font-size: 21px; font-weight: 700;}
.history-tab .itm::after{ content: ''; width: 0; height: 3px; bottom: 40px; left: 50%; background-color: #999; display: block; position: absolute; transition: all 0.2s ease-in-out;}
.history-tab .itm.active{ color:#1e1e1e;}
.history-tab .itm.active::after{ left: 0; width: 100%; background-color: #000;}
.history-con .itm{ margin-top: -250px; padding: 250px 0; display: flex;}
.history-con .itm .history-hd{ position: relative; flex:1;}
.history-con .itm .history-hd .img{ position: relative; height: 480px;}
.history-con .itm .history-hd .img img{ position: absolute; top: 0; right:0; width: calc(50vw - 30px); height: 480px; object-fit: cover; object-position: center; max-width: none;}
.history-con .itm .history-hd .desc{ margin-top: 60px; font-size: 28px; display: flex; flex-direction: column; gap:15px;}
.history-con .itm .history-hd .desc .tit{ font-size: 60px; font-weight: 500;}
.history-con .itm .history-bd{ width: 750px; padding: 0 0 0 120px; }
.history-con .itm .history-bd > ul{ border-bottom:#f5f5f5 1px solid; padding: 45px 0;}
.history-con .itm .history-bd > ul:first-child{ padding-top: 0;}
.history-con .itm .history-bd > ul:last-child{ border-bottom: none; padding-bottom: 0;}
.history-con .itm .history-bd > ul > li{ display: flex; font-size:24px;}
.history-con .itm .history-bd > ul > li + li{ margin-top: 25px;}
.history-con .itm .history-bd > ul > li .y{ width:170px; font-weight:600;}
.history-con .itm .history-bd > ul > li .t{ flex:1;}
.history-con .itm .history-bd > ul > li p{ margin-bottom: 10px; font-weight: 600;}

.company05-bx .tx01{ font-size: 45px; color:#000; font-weight: 700; padding-bottom: 110px; border-bottom: #000 1px solid; }
.ci-bx1{ margin-top: 100px;}
.ci-bx1 .tit{ font-size: 30px; font-weight: 500; margin-bottom: 25px; text-transform: uppercase;}
.ci-bx1 .desc{ font-size: 30px; margin-top: 80px;}
.ci-bx1 .ci-vis{ position: relative; margin-top: 80px;}
.ci-bx1 .ci-vis img{ position: relative; width: 100vw; max-width: none; left: 50%; transform: translateX(-50%); height: 570px; object-fit: cover; object-position: center;}
.ci-bx1 .ci-vis .txt{ position: absolute; top: 0; left: 0; bottom: 0; max-width: 580px; display: flex; align-items: center; color: #fff; font-size: 30px; z-index: 2;}
.ci-thumb{ display: flex; gap:40px;}
.ci-thumb.verical{ flex-direction: column; gap:90px;}
.ci-thumb > li{ display: flex; flex-direction: column; justify-content: space-between;}
.ci-thumb > li > b{ margin-bottom: 25px; color: #010101; font-size: 24px;}
.ci-bx3 p{ margin-top: 50px; font-size: 30px;}
.ci-thumb2{ display: flex; justify-content: space-between;}
.ci-thumb2 .txt{ margin-top: 45px; display: flex; flex-direction: column; font-size: 16px; gap:10px;}
.ci-thumb2 .txt b{ font-size: 24px;}
.ci-bx5 p{ margin-bottom: 50px; font-size: 30px;}

.company03-bx .tx01{ font-size: 54px; font-weight: 700; color: #000;}

.partners-lst{ display: flex; flex-wrap: wrap; gap: 60px 24px; }
.partners-lst .itm{ width: calc(25% - 18px); border: #e6e6e6 1px solid; display: flex; flex-direction: column;  background-color: #f5f5f5;}
.partners-lst .itm .img{ height: 128px; display: flex; align-items: center; justify-content: center;  background-color: #fff; }
.partners-lst .itm .txt{ height: 58px; display: flex; align-items: center; justify-content: center; font-weight: 500; border-top: #e6e6e6 1px solid; font-size: 20px;  text-align: center;}
.partners-lst.n3{ gap: 60px 45px;}
.partners-lst.n3 .itm{ width: calc(33.3% - 30px);}
.partners-lst.n3 .itm .img{ height: 165px;}
.partners-lst.n3 .itm .txt{ flex-direction: column; padding: 30px 55px; height: auto; align-items: flex-start;}
.partners-lst.n3 .itm .txt ul{ margin-top: 10px; font-size: 18px;}
.partners-lst.n3 .itm .txt ul > li{ display: flex;}
.partners-lst.n3 .itm .txt ul > li + li{ margin-top: 5px;}
.partners-lst.n3 .itm .txt ul > li em{ width: 72px; font-weight: 600;}

.cert-list{ display: flex; gap:80px 30px; flex-wrap: wrap;}
.cert-list .itm{ width: calc(20% - 24px); }
.cert-list .itm .img{ position: relative; cursor: pointer;}
.cert-list .itm .img img{ border: #e6e6e6 1px solid;}
.cert-list .itm .img::before{ content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 100%; border:#404040 2px solid; background: rgba(255,255,255,.0) ; opacity: 0; transition:all 0.2s ease-in-out;}
.cert-list .itm .img::after{ content: ''; position: absolute; top: 50%; left: 50%; width: 60px; height: 60px; margin: -30px 0 0 -30px; border-radius: 50%; background: #fe320f url(../images/ic_sch.png) no-repeat 50% 50% / 24px; opacity: 0; transition:all 0.2s ease-in-out;}
.cert-list .itm:hover .img::before,
.cert-list .itm:hover .img::after{ opacity: 1; }
.cert-list .itm .txt{ margin-top: 30px; padding: 0 10px; font-size: 18px;}
.cert-list .itm .txt li::before{ content: ''; width: 4px; height: 4px; background-color: #d3d3d3; margin-right: 10px; vertical-align: 4px; display: inline-block; }
.cert-list .itm .txt li + li{ margin-top: 5px;}
.cert-list.n3,
.cert-list.n4{ gap:80px 128px}
.cert-list.n3 .itm,
.cert-list.n4 .itm{ width: auto; flex:1; max-width: calc(20% - 24px);}
.cert-list.n03{ justify-content: space-between; margin-top: 110px; gap:80px 0;}
.cert-list.n03 .itm{ width: 18vw;}
.cert-list.n03 .itm .txt{ text-align: center;}
.company04-bx .tx01{ font-size: 45px; color:#000; font-weight: 700; padding-bottom: 110px; border-bottom: #000 1px solid; }
.company04-bx .tx01-1{ margin-top:10px; color:#999; font-size:12px;}

.fin-state{ background: url(../images/fin_img.jpg) no-repeat 50% 50% / cover; color: #fff; padding: 60px 50px; display: flex; align-items: center;}
.fin-state .tx{ display: flex; flex-direction: column; gap:30px; flex:1; padding-right: 30px;}
.fin-state .tx b{ font-size: 30px; font-weight: 500;}
.fin-state .sc-bx span{ display: none; }
.fin-state .sc{ position: relative; }
.fin-state .sc b{ position: relative; z-index: 1; width: 195px; height: 195px; display: flex; justify-content: center; align-items: center; font-size: 100px; font-weight: 900; background-color: rgba(43,64,245,1); border-radius: 50%;}
.fin-state .sc::before{ content: ''; display: block; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 235px; height: 235px; border-radius: 50%; background-color: rgba(43,64,245,.2);}
.fin-state .sc::after{ content: ''; display: block; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 215px; height: 215px; border-radius: 50%; background-color: rgba(43,64,245,.5);}
.fin-tbl .smy{ text-align: right; margin-bottom: 20px;}
.fin-tbl > .hd{ padding: 25px 0; color:#000; display: flex; justify-content: end; border-top: #000 1px solid; border-bottom: #000 1px solid;}
.fin-tbl > .hd .th{ font-weight: 600; text-align: center;}
.fin-tbl > .hd .th.g{ width: 350px; margin-right: auto;}
.fin-tbl > .hd .th.y{ width: 330px;}
.fin-tbl .row-itm{ padding: 25px 0; display: flex; justify-content: end; border-bottom: #e6e6e6 1px solid; align-items: center;}
.fin-tbl .row-itm .td{ text-align: center; justify-content: center; align-items: center; display: flex;}
.fin-tbl .row-itm .td.g{ width: 350px; margin-right: auto; font-weight: 600; color:#000;}
.fin-tbl .row-itm .td.y{ width: 330px;}
.fin-tbl .row-itm.bg{ background-color: #f9f9f9; }
.fin-tbl .row-itm.bg .td{ color:#000; font-weight: 600; }
.fin-tbl .tbl-bt{ margin-top: 40px; display: flex; align-items: center; justify-content: end; gap:8px;}
.fin-inf{ margin: 110px 0 -120px; padding: 70px 0; position: relative; width: 100vw; left: 50%; transform: translateX(-50%); background-color: #d5d6db;}
.fin-inf .inner{ max-width: 1440px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; cursor:pointer;}
.fin-inf .fin-l{ display: flex; flex-direction: column; align-items:start;}
.fin-inf .fin-l .bt{ height: 76px; width: 300px; border: #000 1px solid; margin-top: 20px; display: flex; justify-content: space-between; padding: 0 40px; font-size: 18px; font-weight: 600; align-items: center;}
.fin-inf .fin-l .bt::after{ content: ''; width: 24px; height: 24px; background: url(../images/ic_arr2.png) no-repeat 50% 50% / cover; }
.fin-inf .fin-l .bt:hover{ background-color: #000; color:#fff; border-color: #000;}
.fin-inf .fin-l .bt:hover::after{ filter: invert(100%) sepia(0%) saturate(7500%) hue-rotate(324deg) brightness(109%) contrast(119%);}
.fin-inf .h3-tit{ margin-top: 0;}
.fin-inf p{ font-size: 30px; }

.map-bx{ padding-bottom: 50px; border-bottom: #000 1px solid;}
.map-bx dt iframe{ width: 100%; height: 500px;}
.map-bx dd{ margin-top: 55px; display: flex;}
.map-bx dd .addr{ width: 740px; font-size: 30px; color: #000;}
.map-bx dd > ul{ flex:1; font-size: 24px;}
.map-bx dd > ul > li{ display: flex;}
.map-bx dd > ul > li + li{ margin-top: 25px;}
.map-bx dd > ul > li b{ width: 130px;}
.contact-bx{ display: flex;}
.contact-bx + .contact-bx{ margin-top: 90px;}
.contact-bx .tit{ width: 370px; color: #1d2db4; font-size: 30px; font-weight: 500;}
.contact-bx .desc{ flex:1;}
.contact-bx-itm{ display: flex; font-size: 24px; align-items: start;}
.contact-bx-itm + .contact-bx-itm{ margin-top: 24px;}
.contact-bx-itm dt{ display: flex; align-items: center; min-width: 270px; padding-right: 56px; font-weight: 600; }
.contact-bx-itm dt b{ width: 40px; height: 36px; background: transparent url(../images/ico_highway.svg) no-repeat 50% 50% / cover; color: #fff; font-size: 16px; font-weight: 600; display: flex; justify-content: center; align-items: center; margin-right: 14px; padding-top: 5px;}
.contact-bx-itm dd em{ color: #999; font-size: .75em;}
.contact-bx-itm .aw{ position: relative; vertical-align: 4px; display: inline-flex; justify-content: center; align-items: center; margin: 0 10px; width: 12px; height: 12px;}
.contact-bx-itm .aw::after{ content: ''; width: 8px; height: 8px; display: block; border-top: #000 1px solid; border-right: #000 1px solid; transform: rotate(45deg);}
.contact-bx-itm2{ font-size: 24px; color: #000;}
.contact-bx-itm2 .map-img img{ width: 100%;}
.contact-bx-itm2 h4{ font-size: 24px; color: #000; margin: 60px 0 20px;}
.contact-tbl{ border-top: #000 1px solid; font-size: 16px; }
.contact-tbl .tbl-hd{ display: flex; padding: 25px 0; align-items: center; color: #000; border-bottom: #000 1px solid; text-align: center; font-weight: 500;}
.contact-tbl .tbl-hd .th:nth-child(1),
.contact-tbl .tbl-bd .td:nth-child(1){ width: 125px;}
.contact-tbl .tbl-hd .th:nth-child(2),
.contact-tbl .tbl-bd .td:nth-child(2){ flex:1;}
.contact-tbl .tbl-hd .th:nth-child(3),
.contact-tbl .tbl-bd .td:nth-child(3){ width: 240px;}
.contact-tbl .tbl-hd .th:nth-child(4),
.contact-tbl .tbl-bd .td:nth-child(4){ width: 174px;}
.contact-tbl .tbl-hd .th:nth-child(5),
.contact-tbl .tbl-bd .td:nth-child(5){ width: 230px;}
.contact-tbl .tbl-bd .row-itm{ display: flex; align-items: center; border-bottom: #e6e6e6 1px solid; text-align: center;}
.contact-tbl .tbl-bd .td{ padding: 34px 15px; border-left: #f5f5f5 1px solid;}
.contact-tbl .tbl-bd .td:nth-child(1){ border-left:none;}
.contact-tbl .tbl-bd a{ color:#2b3ab9; text-decoration: underline; }
.contact-tbl .tbl-bd .row-itm:last-child{ border-bottom: #999 1px solid;}
.contact-tbl .tbl-hd .th:nth-child(2),
.contact-tbl .tbl-bd .td:nth-child(2){ flex:1;}
.contact-tbl .tbl-hd .th:nth-child(3),
.contact-tbl .tbl-bd .td:nth-child(3){ flex:1;}
.busan .contact-tbl .tbl-hd .th:nth-child(4),
.busan .contact-tbl .tbl-bd .td:nth-child(4){ width: 240px;}

.contactPop-tx dt{ display: flex; flex-direction: column; gap: 20px; font-size: 20px; color: #000; margin-bottom: 40px;}
.contactPop-tx dt b{ font-size: 24px;}
.contactPop-tx dd{ height: calc(100vh - 300px); overflow-y: auto;}

/* recruit */
.recruit01,
.recruit02,
.recruit03{ line-height: 1.3;}
.recruit-lg{ font-size: 48px; font-weight: 700; }
.recruit01-bx1 .desc{ color: #000; font-size: 30px; font-family: 'HarmonyOS Sans Medium'; }
.recruit01-bx1 .recruit-lg{ margin: 50px 0 0 0; font-size: 54px;}
.recruit01-bx1 .img{ margin: 100px 0 0 0; } 
.recruit01-bx1 .img img{ width: 100%; height: 480px; object-fit: cover;}
.recruit01-bx2 .recruit-lg{ margin: 120px 0 100px;}
.recruit01-bx2 dl{ padding: 50px 0 100px; display: flex; border-top: #000 1px solid;}
.recruit01-bx2 dl dt{ width: 715px; font-size: 16px; font-weight: 600;}
.recruit01-bx2 dl dt strong{ display: block; font-size: 75px; font-weight: 500;}
.recruit01-bx2 dl dd{ flex: 1; font-size: 30px; padding: 110px 0 0 0;}
.recruit01-bx2 dl ul li + li{ margin-top: 50px;}
.recruit01-bx2 dl ul li::before{ content: ''; display: block; background-color: #2b3ab9; transform: skewY(-35deg); width: 20px; height:10px; margin-bottom: 20px; }

.recruit02-bx1 .recruit-lg{ font-size: 48px; font-weight: 700; } 
.recruit02-bx1 .img{ margin: 110px 0 0 0; } 
.recruit02-bx2{ margin: 180px 0 0 0; display: flex;}
.recruit02-bx2-l{ width: 480px;}
.recruit02-bx2-l p{ font-size: 16px; font-weight: 600; margin-bottom: 30px;}
.recruit02-bx2-l .recruit-lg{ font-weight: 500;}
.recruit02-bx2-l .tx-lg{ font-size: 75px; font-weight: 500; margin-top: 40px;} 
.recruit02-bx2-tx{ flex: 1; gap:58px; display: flex; flex-wrap: wrap;}
.recruit02-bx2-tx .itm{ position: relative; background-color: #f8f8fa; width: calc(50% - 29px); padding: 40px 28px; display: flex; flex-direction: column; font-size: 21px;}
.recruit02-bx2-tx .itm h3{ font-size: 27px; padding-right: 100px;}
.recruit02-bx2-tx .itm ul{ margin: 90px 0 0 0; color: #000;}
.recruit02-bx2-tx .itm ul li + li{ margin-top: 10px;}
.recruit02-bx2-tx .itm i{ position: absolute; top: 20px; right: 20px;}

.recruit03 .tblHd{ margin-top: 100px; }

.recruitHd{ display: flex; justify-content: end; align-items: center; gap:20px;}
.recruitHd .select{ width: 300px;}
.recruitHd .btn{ height: 60px; line-height: 60px;}

.recruitLst{ display: flex; flex-wrap: wrap; gap:30px;}
.recruitLst .recruitLst-itm{ width: calc(33.3% - 20px); height: 360px; border: #e3e4e9 1px solid; padding: 50px 30px 40px; border-radius: 24px; display: flex; flex-direction: column;}
.recruitLst .recruitLst-itm .cate{ color: #999; font-weight: 600;}
.recruitLst .recruitLst-itm .tit{ font-size: 30px; line-height: 1.2; margin: 10px 0 0 0; font-weight: 500;}
.recruitLst .recruitLst-itm .tit:hover{ text-decoration: underline; text-decoration-thickness:1px; text-underline-offset:8px;}
.recruitLst .recruitLst-itm .bottom{ margin-top: auto; display: flex; flex-direction: column; color: #000; font-weight: 500;}

.recruit-vew-desc{ position: relative; margin: 50px 0 0 0; background-color: #f3f3f7; padding: 50px 60px; }
.recruit-vew-desc::after{ content:'Top-Tier Technologhy, Certified Global Valve K Valve'; line-height: 1.2; text-align: right; position: absolute; right: 60px; bottom: 50px; width: 230px; display: block; color: #234981; opacity: .2;}
.recruit-vew-desc .desc-hd{ border-bottom:#d6d6dd 1px solid; padding: 0 0 50px 0;}
.recruit-vew-desc .desc-hd .logo img{ height: 38px;}
.recruit-vew-desc .desc-hd strong{ font-size: 36px; margin-top: 10px; display: block;}
.recruit-vew-desc .desc-bd{ padding: 50px 0 0 0; }
.recruit-vew-desc .desc-bd-itm{ text-indent: -25px; padding-left: 25px;}
.recruit-vew-desc .desc-bd-itm::before{ content: '*'; margin-right: 15px;}
.recruit-vew-bt{ margin: 60px 0 0 0; display: flex; justify-content: center; gap:8px;}
.recruit-vew-bt .btn::after{ content:''; width: 24px; height: 24px; margin-left: 70px; background-image: url(../images/ic_arr3.png);}

/* esg */
.esg-lg{ font-size: 54px; font-weight: 700;}
.esg01-img{ text-align: center;}
.esg01-bx1{ margin: 100px 0 0 0;}
.esg01-bx1 .itm + .itm{ margin-top: 110px; }
.esg01-bx1 .itm{ display: flex;}
.esg01-bx1 .itm .img{ width: 440px; margin-right: 50px;}
.esg01-bx1 .itm .desc{ flex: 1; padding: 10px 0 0 0;}
.esg01-bx1 .itm .desc h3{ font-size: 28px; font-weight: 600;}
.esg01-bx1 .itm .desc h3::before{ content: ''; display: block; background-color: #2b3ab9; transform: skewY(-35deg); width: 20px; height:10px; margin-bottom: 20px;}
.esg01-bx1 .itm .desc ul{ margin: 35px 0 0 0; font-size: 24px;}
.esg01-bx1 .itm .desc ul li{ display: flex;}
.esg01-bx1 .itm .desc ul li + li{ margin-top: 10px;}
.esg01-bx1 .itm .desc ul li strong{ font-weight: 600; width: 170px;}
.esg01-bx1 .itm:first-child .desc ul li strong{ width: 125px;}
.esg02 .h3-tit{ margin-top: 0; }
.esg02 .tx1{ font-size: 36px; font-weight: 700; color: #000;}
.esg02 .tx2{ margin: 50px 0 0 0; padding: 40px; color: #484a5d; font-size: 18px; background-color: #fbfbfc;}
.esg02 .tx3{ font-size: 18px; margin: 50px 0 0 0; color: #000;}
.esg02 .tx3 li{ text-indent: -15px; padding-left: 15px;}
.esg02 .tx3 li + li{ margin-top: 10px;}
.esg02 .tx3 i{ display: inline-block; margin-right: 10px; text-indent: 0;}
.esg04-tx1{ font-size: 30px; padding-bottom: 90px; border-bottom: #000 1px solid; font-weight: 600;}
.esg04-tx1::before{ display: none;}
.esg04-tx2{ font-size: 24px;}
.esg04-tx2 .h4-tit{ color: #0e1a73; font-size: 30px; font-weight: 600; margin: 60px 0 30px;}
.esg04 .div-tab{ margin: 110px 0 20px;}
.esg04 .tblHd{ margin-top: 0;}

.div-tab{ display: flex;}
.div-tab .itm{ border: #b9bac3 1px solid; flex:1; display: flex; height: 88px; align-items: center; justify-content: center; font-size: 24px; color: #575757;}
.div-tab .itm i{ width: 20px; height: 20px; border-radius: 50%; margin-left: 15px; background-color: #e6e6e6; background-image: url(../images/ic_check_on.png); background-repeat: no-repeat; background-position: 80% 50%;}
.div-tab .itm.on{ background-color: #2c3684; border-color:#2c3684; color:#fff;}
.div-tab .itm.on i{ background-color: #fff; background-image: url(../images/ic_check.png);}

.popEsg04 .tx1,
.popEsg040 .tx1{ text-align: center; font-size: 24px; font-weight: 600; color: #000;}
.popEsg04 .tx2{ margin: 60px 0 0 0; background-color: #fbfbfc; padding: 25px;}
.popEsg04 .tx2 dt{ color:#0e1a73; font-size:18px; margin: 30px 0 0 0;}
.popEsg04 .tx2 dd{ margin: 20px 0 0 0; color: #484a5d;}
.popEsg04 .tx2 dd li + li{ margin-top: 5px;}
.popEsg04 .tx2 dd li{ text-indent: -15px; padding-left: 15px;}
.popEsg04 .tx2 dd li i{ text-indent: 0;}
.popEsg040 .tx2{ margin: 50px 0 0 0; display: flex; gap:20px; font-size: 18px;}
.popEsg040 .tx2 > li{ flex:1; background-color: #fbfbfc; padding: 15px 50px 30px; display: flex; flex-direction: column;}
.popEsg040 .tx2 > li i{ text-align: center;}
.popEsg040 .tx2 > li strong{ text-align: center; margin: 25px 0 5px; font-size: 30px; white-space: nowrap;}
.popEsg040 .tx2 > li em{ text-align: center; color: #333;}
.popEsg040 .tx2 > li > ul{ margin: 20px 0 0 0;}

.esg03-tx1{ text-align: center; font-size: 60px; position: relative;}
.esg03-tx1 .tit{ font-size:72px; color: #000;}
.esg03-tx2{ position: relative; left: 50%; width: 100vw; margin: 100px 0 0; transform: translateX(-50%); background: url(../images/esg03_img1.jpg) no-repeat 50% 0 / cover; color: #fff; padding: 120px 0;}
.esg03-tx2::before{ content: ''; position: absolute; height: 45px; width: 1px; background-color: #1a1f4b; display: block; left: 50%; top: -45px;}
.esg03-tx2::after{ content: ''; position: absolute; height: 45px; width: 1px; background-color: #fff; display: block; left: 50%; top:0;}
.esg03-tx2 ul{ max-width: 1440px; margin: 0 auto; font-size: 24px;}
.esg03-tx2 ul li{ display: flex; padding: 40px 0; }
.esg03-tx2 ul li + li{ border-top: #32375b 1px solid;}
.esg03-tx2 ul li i{ width: 240px; font-size: 42px; font-weight: 700;}
.esg03-tx2 ul li p{ flex:1;}
.esg03-tx3{ position: relative; margin: 180px 0 0 0; padding: 110px 115px 100px; font-size: 24px; background: url(../images/esg03_bx.png)  no-repeat 50% 0 / 100% auto;}
.esg03-tx3 .ln1,
.esg03-tx3 .ln2{ position: absolute; top: 0; right: 220px; height: 395px; display: flex; flex-direction: column; z-index: 2;}
.esg03-tx3 .ln1::before,
.esg03-tx3 .ln2::before{ content: ''; background-color: #fe320f; flex: 1;}
.esg03-tx3 .ln1::after,
.esg03-tx3 .ln2::after{ content: ''; width: 72px; border: transparent 36px solid; border-top: #fe320f 36px solid; border-left: #fe320f 36px solid; }
.esg03-tx3 .ln2{ height: 1040px; right: 88px;}
.esg03-tx3 .ln2::before{ background-color: #2c3684; }
.esg03-tx3 .ln2::after{  border-left:transparent 36px solid; border-top: #2c3684 36px solid; border-right: #2c3684 36px solid;} 
.esg03-tx3 .bg{ position: absolute; top: 0; left: 0; width: 100%; height: 50px; background: url(../images/esg03_bx2.png) 0 0 repeat-x;  z-index: 1;}
.esg03-tx3 .bg::before,
.esg03-tx3 .bg::after{ content: ''; position: absolute; top: 0; left: 0; display: block; width: 50px; height: 50px; background: url(../images/esg03_bx1.png) no-repeat 50% 50% / cover;}
.esg03-tx3 .bg::after{ left: auto; right: 0; transform: rotate(90deg); }
.esg03-tx3 .bg.bg-bottom{ top: auto; bottom: 0; transform: rotate(180deg); }
.esg03-tx3 .tit{ margin: 0; color: #0e1a73; font-size: 72px; padding: 0 0 70px 0; border-bottom: #ccccd6 1px dashed;}
.esg03-tx3 .tit2{ margin: 100px 0 40px; font-size: 30px; color: #000;}
.esg03-tx3::before,
.esg03-tx3::after{ content: ''; position: absolute; top: 0; bottom: 0; left: 0; width: 50px; background:url(../images/esg03_bx3.png) 0 0 repeat-y;}
.esg03-tx3::after{ left: auto; right: 0; transform: rotate(180deg);}
.esg03-tx301{ margin: 100px 0 0 0; display: flex;}
.esg03-tx301 .txt{ display: flex; flex-direction: column; padding: 20px 0 0 0;}
.esg03-tx301 .sign{ margin: 0 0 0 70px;}

/* products */
.products-list{ display: flex; flex-wrap: wrap; gap:85px 24px;}
.products-list .products-itm{ width: calc(25% - 18px); display: flex; flex-direction: column;}
.products-list .products-itm .bx{ background-color: #f6f9f6; border-radius: 10px; padding: 30px 30px 50px;}
.products-list .products-itm .bx .img{ text-align: center;}
.products-list .products-itm .bx img{ transition: transform 0.5s cubic-bezier(0.4,0,0.2,1);}
.products-list .products-itm:hover .bx{ border-radius: 20px; background-color: #e9eee8;}
.products-list .products-itm:hover .bx .img img { transform: scale(1.12);}
.products-list .products-itm .tit{ font-size: 21px; font-weight: 500;}
.products-list .products-itm .procudts-bt{ display: flex; justify-content: center; margin: 22px 0 0 0; gap:6px;}
.products-list .products-itm .procudts-bt a{ display: flex; justify-content: space-between; align-items: center; font-size: 14px; color: #999; width: 138px; height:36px; border:#d3d3d3 1px solid; padding: 0 14px;}
.products-list .products-itm .procudts-bt a::after{ content: ''; background: url(../images/ic_down2.png) no-repeat 50% 50% / 16px; width: 16px; height: 16px; transition:all 0.2s ease-in-out;}
.products-list .products-itm .procudts-bt a:hover{ border-color: #999; color:#3c3c3c; }
.products-list .products-itm .procudts-bt a:hover::after{ -webkit-filter: grayscale(100%) brightness(0); filter: grayscale(100%) brightness(0);}
.products-list .products-itm .procudts-bt a:active{ border-color: #1e1e1e; color:#000; }

body.prodView .contents{ padding-bottom: 0; margin-top: 0;}
.products-hd{ position: relative; width: 100vw; left: 50%; transform: translateX(-50%); display: flex;}
.products-hd .prev{ position: absolute; display: flex; left: 60px; top: 60px;  color: #484a5d; font-weight: 600; display: flex; align-items: center; }
.products-hd .prev::before{ content: ''; width: 20px; height: 20px; background: url(../images/ic_prev.png) no-repeat 50% 50% / 20px; margin-right: 10px;}
.products-hd .img{ position: relative; flex:1; background-color: #f7f7fa; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 100px 0 60px;}
.products-hd .img .b-img{ width: 100%; display: flex; flex: none; justify-content: center; align-items: center;}
.products-hd .img .b-img img{ width: 45vw; height: 45vw; object-fit: cover; transition:all 0.2s ease-in-out;}
.products-hd .img .s-img{ position: relative; margin: 50px auto 0; display: flex; align-items: center; gap:5px;}
.products-hd .img .s-img .itm{ position: relative; display: flex; flex: 1; background-color: #fff;}
.products-hd .img .s-img .itm.on::after{ content:''; position: absolute; top: 0; left: 0; width: 100%; bottom: 0; display: block; border:#000 1px solid }
.products-hd .img .s-img .itm img{ object-fit: cover; object-position: center; width: 90px; height: 90px;}
.products-hd .img .slide-img{ width: 45vw; max-width: 800px; overflow:hidden;}
.products-hd .img .slide-img .pag{ text-align:center;}
.products-hd .img .slide-img .pag .swiper-pagination-bullet{ width: 8px; height: 8px;background-color: rgb(51, 51, 51); opacity: 0.5; transition: 0.2s;}
.products-hd .img .slide-img .pag .swiper-pagination-bullet-active{ width: 16px; border-radius: 20px; opacity: 1;}
.products-hd .desc{ width: 34vw; padding: 50px 60px 0; display: flex; flex-direction: column;}
.products-hd .desc .tit{ font-size: 48px; font-weight: 700; line-height: 1.2; margin: 0 0 20px 0;}
.products-hd .desc .desc-tx1{ border-bottom: #000 1px solid; display: flex;}
.products-hd .desc .desc-tx1 li{ font-size: 18px; flex-direction: column; display: flex; flex:1; padding: 35px 0;}
.products-hd .desc .desc-tx1 li b{ text-transform: uppercase;}
.products-hd .desc .desc-tx2{ padding: 60px 30px;}
.products-hd .desc .desc-tx2 .hd-tit{ color: #2b40f5; font-size: 24px; font-weight: 600;}
.products-hd .desc .desc-tx2 .hd-tit2{ color: #000; font-size: 20px; font-weight: 600; margin: 20px 0 15px;}
.products-hd .desc .desc-tx2 ul{ font-size: 21px;}
.products-hd .desc .desc-tbl{ border-top:#000 1px solid; padding-bottom: 100px;}
.products-hd .desc .desc-tbl thead th{ color: #000; font-size: 18px; font-weight: 600; padding: 20px 25px; text-align: left; background-color: #fafafa; border-bottom: #d3d3d3 1px solid; border-left: #d3d3d3 1px solid;}
.products-hd .desc .desc-tbl tbody td{ color: #000; padding: 20px 25px; text-align: left; border-bottom: #d3d3d3 1px solid; border-left: #d3d3d3 1px solid;}
.products-hd .desc .desc-tbl thead th:first-child,
.products-hd .desc .desc-tbl tbody td.brdLn{ border-left: none;}
.products-hd .procudts-bt{ margin: auto 0 0 0; display: flex; flex-wrap: wrap; gap:4px;}
.products-hd .procudts-bt + .procudts-bt{ margin-top: 4px;}
.products-hd .procudts-bt a{  flex: 1;  display: flex; justify-content: space-between; align-items: center; font-size: 18px; color: #575757; height:60px; border:#d3d3d3 1px solid; padding: 0 30px;}
.products-hd .procudts-bt a::after{ content: ''; background: url(../images/ic_down2.png) no-repeat 50% 50% / 16px; width: 16px; height: 16px; margin-left: 25px; }
.products-hd .procudts-bt a:hover{ border-color:#999; color:#1e1e1e; }
.products-hd .procudts-bt a:active{ border-color:#1e1e1e; color:#000; }
.products-hd .procudts-bt a.block{ width: 100%; background-color: #333; border-color:#333; color:#fff;}
.products-hd .procudts-bt a.block::after{ content: ''; background-image: url(../images/ic_arr5.png); }
.products-hd .procudts-bt a.block:hover{ background-color: #1e1e1e; border-color:#1e1e1e; }
.products-hd .procudts-bt a.block:active{ background-color: #000; border-color:#000; }

.products-bd{ padding: 120px 0 100px 0;}
.products-bd + .products-bd{ border-top: #000 1px solid;}
.products-bd .tit{ font-size: 48px; color:#000; position: relative; margin: 0 0 80px 0; font-weight: 700;}
.products-bd .tit::before{ content: ''; display: block; background-color: #2b3ab9; transform: skewY(-35deg); width: 20px; height:10px; margin-bottom: 20px; }
.prod-app{ display: flex; flex-wrap: wrap; gap:24px;}
.prod-app .itm{ background-color: #fafafa; display: flex; gap:40px; align-items: center;  width: calc(33.3% - 16px); padding: 75px 60px; border-radius: 14px; font-size: 27px; color:#000; }
.prod-app .itm i{ width: 80px;}
.prod-app .itm span{ flex:1; font-weight: 600;}
.prod-features{ font-size: 24px;}
.prod-features .tit2{ font-size: 30px; color: #1d2db4; margin: 45px 0 30px; font-weight: 600;}
.prod-features .tit2:first-child{ margin-top: 0;}
.prod-doc{ display: flex; flex-direction: column; border-top: #d3d3d3 1px solid;}
.prod-doc .itm{ border-bottom: #d3d3d3 1px solid; padding: 28px 30px; display: flex; color:#000; font-size: 24px; align-items: center;}
.prod-doc .itm i{ margin-right: 30px;}
.prod-doc .itm span{ flex:1; padding-right:10px; text-align:left;}
.prod-doc .itm::after{ content: ''; background: url(../images/ic_down.png) no-repeat 50% 50% / cover; width: 24px; height: 24px; margin-left: auto; }

.products-bottom{ background: url(../images/products_inq.jpg) no-repeat 50% 0 / cover; width: 100vw; left: 50%; position: relative; transform: translateX(-50%); padding: 90px; display: flex; flex-direction: column; justify-content: center; color: #fff; text-align: center;}
.products-bottom .tit{ font-size: 78px; font-weight: 600; line-height: 1.2;}
.products-bottom a{ border:#fff 1px solid; height: 90px; display: flex; color: #fff; justify-content: space-between; width: 300px; margin: 100px auto 0; padding: 0 40px; text-transform: uppercase; font-size: 18px; font-weight: 600; align-items: center;}
.products-bottom a:after{ content: ''; background: url(../images/ic_arr3.png) no-repeat 50% 50% / 24px; width: 24px; height: 24px; }
.products-bottom a:hover{background-color: #1d2db4; border-color:#1d2db4;}
.products-bottom a:active{background-color: #1e1e1e; border-color:#1e1e1e;}
.products-hd + .products-bottom{ margin-top: 120px; }
.prod-material{ font-size: 30px; color: #000;}

.products04-bx .tx01{ font-size: 45px; font-weight: 600; color: #000; padding-bottom: 120px; border-bottom: #000 1px solid;}
.products04-bx .tx02 p{ font-family: 'HarmonyOS Sans'; padding: 100px 0; text-align: center; font-size: 78px; }
.products04-bx .tx02 .img{ text-align:center;}
.products04-vis{ position: relative; width: 100vw; margin: 110px 0 0 0; left: 50%; transform: translateX(-50%); color: #fff; display: flex; justify-content: center; align-items: center; text-align: center; font-size: 72px; font-weight: 500; padding: 120px 60px; background: url(../images/products04_img2.jpg) no-repeat 50% 50% / cover; font-family: 'HarmonyOS Sans';}
.product04-tbl .row-hd{ display: flex; background-color: #1e1e1e;}
.product04-tbl .row-hd .th{ flex:1; padding: 15px; color: #fff; font-size: 21px; font-weight: 500; text-align: center; display: flex; justify-content: center; flex-direction: column; align-items: center;}
.product04-tbl .row-hd .th span{ font-size: 18px; font-weight: 400;}
.product04-tbl .row-hd .th:first-child{ flex:none; width: 350px; }
.product04-tbl .row-bd .row-itm{ display: flex; border-bottom: #000 1px solid; font-size: 18px;}
.product04-tbl .row-bd .row-itm .th{ width: 350px; padding: 30px; font-weight: 600; color: #000; display: flex; align-items: center;}
.product04-tbl .row-bd .row-itm .td{ display: flex; flex-direction: column; flex:1; padding: 30px; display: flex; border-left: #000 1px solid;}
.product04-tbl .tx-th{ display: none;}
.products04-bottom{ background: url(../images/products04_bottom.jpg) no-repeat 50% 50% / cover; width: 100vw; position: relative; left: 50%; transform: translateX(-50%); padding: 90px 60px; margin: 120px 0 -120px; display: flex; flex-direction: column;}
.products04-bottom .tit{ font-size: 48px; color: #000; font-weight: 600; text-align: center;}
.products04-bottom .btz{ margin: 100px 0 0 0; display: flex; justify-content: center; gap: 5px;}
.products04-bottom .btz a{ width: 360px; height: 74px; display: flex; padding: 0 28px; font-size: 18px; color: #fff; align-items: center;}
.products04-bottom .btz a.blue{ background: url(../images/products04_bt1.jpg) no-repeat 50% 50% / cover;}
.products04-bottom .btz a.red{ background: url(../images/products04_bt2.jpg) no-repeat 50% 50% / cover;}
.products04-bottom .btz a::after{ content:""; width:24px; height:24px; background:url(../images/ic_arr3.png) no-repeat 50% 50% / cover; margin-left:auto;}
.products04-bottom .btz a span{ color: #d5d6dc; margin-left: 24px; padding-left: 24px; position: relative;}
.products04-bottom .btz a span::before{ content: ''; position: absolute; top: 50%; left: 0; width: 1px; height: 14px; transform: translateY(-50%); background-color: rgba(255,255,255,.25); display: block;}
.products04-bx.products0402 .tx02{ margin-bottom: -120px;}
.products04-bx.products0402 .tx02 .img{ width: 100vw; position: relative; left: 50%; transform: translateX(-50%); max-width: 1920px; }

.prod-tx{ text-align:center; background-color:#fafafa; padding:24px; font-size:12px; color:#999; margin-top:120px;}
.prod-tx + .products-bottom{ margin-top:70px;}

.search-wr{ max-width: 1440px; margin: 100px auto 120px;}
.search-bx{ max-width: 1080px; margin: 0 auto 100px;}
.search-bx .search-inp{ position: relative; }
.search-bx .search-inp .inp{ height: 90px; height: 90px; width: 100%; border-bottom-width: 2px; padding: 0 120px 0 0; font-size: 60px; color: #000; font-weight: 600;}
.search-bx .search-inp .inp::placeholder{ color: #999; font-weight: 400; font-size: 24px;}
.search-bx .input-wrapper{ width: 100%;}
.search-bx .input-wrapper .clear-btn{ right: 70px;}
.search-bx .sch{ position: absolute; top: 50%; right: 0; width: 60px; height: 60px; transform: translateY(-50%); font-size: 0; color: transparent; display: block; background: url(../images/ic_sch3.png) no-repeat 50% 50% / 42px; }
.search-wr .search-keywords{ margin-top: 30px; font-size: 24px; text-align: center;}
.search-wr .search-keywords b{ font-weight: 500; color:#1d2db4;}
.search-list{ border-top: #000 1px solid; display: flex; flex-direction: column; }
.search-list .itm{ padding: 25px 0; font-size: 18px; font-weight: 600; border-bottom: #e6e6e6 1px solid;}
.search-list a:hover{ text-decoration: underline;}
.search-list.news .itm{ display: flex; align-items:center;}
.search-list.news .itm .tit{ width: 145px; font-weight: 500; color: #000; text-transform: uppercase;}
.search-list.news .itm a{ flex:1;}

.privacy-wr{ max-width: 1440px; margin: 100px auto 120px;}
.privacy-bx{ font-size: 18px;}
.privacy-bx .privacy-tx01{ font-size: 24px; font-weight: 600; border-bottom: #000 1px solid; padding: 0 0 85px 0;}
.privacy-bx .privacy-tx02{ font-size: 24px; font-weight: 600;}
.privacy-bx .privacy-tx03{ font-size: 16px; color:#575757;}
.privacy-bx .privacy-tx02 + ul{ margin-top: 30px;}
.privacy-bx ul + .privacy-tx03{ margin-top: 30px;}
.tbl-privacy{ margin-top: 30px;}
.tbl-privacy thead th{ background-color: #1e1e1e; padding: 21px 10px; text-align: center; color: #fff; font-size:18px; font-weight: 600; border-left: #000 1px solid;}
.tbl-privacy tbody td{ border-bottom: #000 1px solid; border-left: #000 1px solid; padding: 30px 20px;}
.tbl-privacy thead th:first-child,
.tbl-privacy tbody td:first-child{ border-left: none;}
.tbl-privacy tbody td p{ color: #575757; font-size:16px;}

@media screen and (min-width:1920px){
  .contents{ justify-content: space-between;}
  body.dataroom .contents .page{ max-width: none; }
}

@media screen and (max-width:1600px){

  #header > .inner{ padding: 0 30px;}
  .mainValue .valueTxt{ font-size: 40px;}

  .mainSolution .solutionItm span{ padding: 0 0 0 200px;}  

  .tblList > .hd .hd-itm,
  .tblList > .bd .bd-itm{ width: auto;}

  .products-list .products-itm .procudts-bt a::after{ margin-left: .5vw;}

  /* esg */
  .esg04-tx1 br.br-pc{ display: none;}

  @media screen and (max-width:1440px){

    .contents .page{ width: 100%;}

    .tit_wrap{ padding: 120px 0 0 30px;}

    .ckWrap .ckWrapInner{ padding: 30px;}

	.locationTab a{ display:flex; align-items:center; text-align:center; min-height:70px; font-size:16px; line-height:1.2;}

	.mainValue .txt_wrap .tit{ font-size: 3.6vw; }
	.mainSlide{ padding: 0 60px; }

    /* company */
    .history-con .itm .history-bd{ width: 52%; padding-left: 6vw;}
    .history-con .itm .history-hd .img img{ width: 100%;}

    .ci-bx1 .ci-vis{ width: calc(100% + 120px); left: 0; transform: translateX(0); margin: 80px -60px 0;}
    .ci-bx1 .ci-vis .txt{ padding: 50px 60px;}

    .fin-inf .inner{ padding: 0 60px;}
    
    .cert-list.n3,
    .cert-list.n4{  gap:80px 30px; }
    .cert-list.n3 .itm,
    .cert-list.n4 .itm{width: calc(20% - 24px); }

    .contact-tbl .tbl-hd .th:nth-child(1),
    .contact-tbl .tbl-bd .td:nth-child(1){ width: 8.6vw;}
    .contact-tbl .tbl-hd .th:nth-child(2),
    .contact-tbl .tbl-bd .td:nth-child(2){ flex:1;}
    .contact-tbl .tbl-hd .th:nth-child(3),
    .contact-tbl .tbl-bd .td:nth-child(3){ width: 16vw;}
    .contact-tbl .tbl-hd .th:nth-child(4),
    .contact-tbl .tbl-bd .td:nth-child(4){ width: 8.6vw;}
    .contact-tbl .tbl-hd .th:nth-child(5),
    .contact-tbl .tbl-bd .td:nth-child(5){ width: 14vw;}

    /* recruit */
    .recruit01-bx1 .desc{ padding: 0;}
    .recruit01-bx2 .tx-lg{ padding: 0;}
    .recruit01-bx2 dl{ padding: 50px 0 100px;}

    /* products */
    .products-list{ gap: 60px 15px;}
    .products-list .products-itm{ width: calc(33.3% - 10px);}
    .products-list .products-itm .procudts-bt{ margin: 15px 0 0 0;}
    .products-list .products-itm .procudts-bt a{ padding: 0 10px;}
    .products-list .products-itm .procudts-bt a::after{ width: 14px; height: 14px; background-size: 14px;}
    .products-list .products-itm .bx{ padding: 15px 15px 20px;}

    .products-hd .img .b-img img{ width: 50vw; height: 50vw;}
	.products-hd .img .slide-img{ width: 50vw;}
    
    .products04-bottom{ width: calc(100% + 120px); left: 0; transform: translateX(0); margin: 120px -60px -120px;}
    .products04-bx.products0402 .tx02 .img{ width: 100%; left: 0; transform: translateX(0);}

    .search-wr,
    .privacy-wr{ padding: 0 60px;}

    /* esg */
    .esg03-tx2{ padding: 120px 60px;}
    .esg03-tx3 .ln1, 
    .esg03-tx3 .ln2{ display: none;}

  }

	@media screen and (orientation: landscape) and (max-width:1366px){
		.visual_sect .tit_box{ padding:0 60px 72px;}
		
		/* products */
		.products04-bx.products0402 .tx02 { margin-bottom: 0;	}
		
		/* company */
		.ci-bx1 .ci-vis .txt{ width: 100%; align-items: flex-start; max-width: none; font-size: 3.1vw;}
		.ci-bx1 .ci-vis img { height: 100vw; }
	}
  @media screen and (max-width:1280px){
    
    nav > ul > li > a{ padding: 0 2vw;}


    .contents .page{ width: 100%;}

    #mainVisual .text{ padding: 60px 30px 164px;}
    #mainVisual .text strong{ font-size: 90px;}
    #mainVisual .progress-bx{ left: 30px; bottom:353px;}

    .mainValue{ padding: 80px 30px 80px;}

    .mainSlide{ padding: 0 30px;}
    .mainSlide .image-stack{ width: 560px;}
    .mainSlide .slide{ width: 560px; height: 429px;}
    .mainSlide .textArea{ padding-right: 20px;}
    .mainSlide .text h2{ font-size: 38px;}
    .mainSlide .text h2 b{ font-size: 50px;}

    .mainProd{ padding: 80px 30px;}

    .mainCert{ padding: 80px 30px;}

    .mainPartners{ padding: 0 30px 80px;}
    .mainPartners .mainInner{ padding: 80px 0 0 0;}

    .mainCust{ padding: 80px 30px;}
    
    .mainNews{ padding: 80px 30px;}
    .newsWrap .newsItm .cate{ width: 200px;}
    .newsWrap .newsItm .date{ width: 200px;}

    .mainSolution{ padding: 0 30px 80px;}
    .mainSolution .solutionItm{ padding: 80px 30px 30px;}

    footer{ flex-wrap: wrap;}
    footer .footerLogo{ width: 260px;}
    footer .footerLogo .logo{ width: 200px;}
    footer .footerAddr{ padding: 0;}
    footer .footerAddr .contact{ margin-top: 60px;}
    footer .footerCopy{ width: 100%;}

    .contents{ padding: 0 60px 100px;}
    #filterWr{ margin-left: -30px; margin-right: 30px; max-width: 260px;}

    /* company */
    .partners-lst.n3 .itm .txt{ padding: 20px 30px;}

    /* recruit */
    .recruit01-bx1 .tx-lg,
    .recruit01-bx2 dl dt strong{ font-size: 48px;}
    .recruit01-bx2 dl dt{ width: 40%;}

    /* products */
    .products04-bx{ padding: 0;}
    .products04-bx .tx01{ font-size: 3.2vw;}
    .products04-bx .tx02 .img{ display: flex; justify-content: center; text-align: center;}
    .products04-bx .tx02 p{ font-size: 5vw;}
    .products04-vis{ margin: 110px -60px 0; width: calc(100% + 120px); left: 0; transform: translateX(0); font-size: 5vw;}
    .product04-tbl .row-hd .th:first-child,
    .product04-tbl .row-bd .row-itm .th{ width: 280px;}
    .products04-bottom{ margin-bottom: -100px;}
    .prod-app .itm{ padding: 40px 30px; gap:20px;}

	@media screen and (max-width:1180px){
		.contents{ padding: 0 60px 100px; margin: 30px 0 0 0;}
		#filterWr{ position: fixed; top: 0; left: 0; width: 100%; bottom: 0; margin: 0; background-color: #fff; flex:none; max-width: none; z-index: 9; display: none;}
		#filterWr > .hd{ background-color: #fff; padding: 0 30px; height: 5rem;  }
		#filterWr > .hd h3{ position: relative; color: #000; font-weight: 600; width: 100%; justify-content: space-between;}
		#filterWr > .hd h3::after{ display: none;}
		#filterWr > .hd h3 .close{ display: block; width: 2rem; height: 2rem; position: relative; font-size: 0; color: transparent;}
		#filterWr > .hd h3 .close::before,
		#filterWr > .hd h3 .close::after{ content: ''; position: absolute; width: 1.4rem; height: .1rem; display: block; top: 50%; left: 50%; margin: 0 0 0 -.5rem; background-color: #000; transform: rotate(45deg);}
		#filterWr > .hd h3 .close::after{ transform: rotate(-45deg);}
		#filterWr .hd-r{ position: absolute; bottom: 0; left: 0; width: 100%; height: 8rem; padding: 0 30px; display: flex; background-color: #fff; border-top: #e6e6e6 1px solid; align-items: center; gap:1rem;}
		#filterWr > .hd .btReset{ width: 12rem; background-color: #f3f3f7; color:#000; justify-content: space-between;}
		#filterWr > .hd .btReset::after{ filter: brightness(1) invert(0);}
		#filterWr > .hd .btResult{ flex:1; background-color: #000; color: #fff; justify-content: center; }
		#filterWr > .hd .btReset,
		#filterWr > .hd .btResult{ padding: 0 1.6rem; font-weight: 600; display: flex; align-items: center; height: 5rem; font-size:15px;}
		#filterWr > .all{ height: 5.5rem; padding: 0 30px; display: flex; align-items: center;}
		#filterWr .filterLst{ height: calc(100vh - 18.6rem); overflow-y: auto;}
		
      .sorting-bx{ gap:2rem; flex-direction: column; align-items: flex-start;}
      .sorting-bx .btFilter{ display: inline-flex; height: 48px; padding: 0 8px 0 18px;}
      .sorting-bx .btFilter::after{ margin-left: 10px;}
      .sorting-bx .sorting-bx-r{ order:1; width: 100%; display: flex; align-items: center;}
      .sorting-bx .sorting-bx-l{ order:2;}
      .tblHd{ margin: 0; padding: 20px 0; width: 100%; height: auto;}
      .tblHd .total{  width: 30%; padding: 0;}
      .tblHd .tblSch{ flex: 1; width: auto;}
      .tblHd .tblSch .inp{ height: 4.4rem; padding: 0 5rem 0 2rem;}
      .tblHd .tblSch .sch{ width: 4.4rem; height: 4.4rem; background-size: 1.5rem;}
      .tblHd .tblHd-r{ display: flex; width: 100%; gap:1rem;}
      .tblHd .tblHd-r .btFilter{ display: flex; width: 8.5rem; }
      .form-hdtx{ margin: -1rem 0 3rem;}
	}

    @media screen and (max-width:1024px){

      nav{ display: none;}

      footer{ background-image: none; }
      footer .footerCopy .copyTxt{ text-align: left;}

      .btTop.fComp{ right: 50px;}

      #mainVisual .text{ top: 0; padding: 40vw 7vw 0; font-size: 4.5vw;  justify-content: start; height:126vw; }
      #mainVisual .text strong{ font-size: 10.2vw; margin-top: 4vw;}
      #mainVisual .bulletPag,
      #mainVisual .progress-bx{ display: none;}
      #mainVisual .pag{ left: 7vw; top: 84vw; bottom: auto; font-size: 3.6vw;}
      #mainVisual .custom-scrollbar{ width: 8.3vw;}
      #mainVisual .swiper-scrollbar{ height: .5vw;}
      #mainVisual .bg{ min-height: 126vw;}
	  #mainVisual .bg > div.bg-pc{ display:none;}
	  #mainVisual .bg > div.bg-mob{ display:block;}
      #mainVisual .vis01 .bg{ background-image: url(../images/visual01_mob.jpg);}
      #mainVisual .vis02 .bg{ background-image: url(../images/visual02_mob.jpg);}
      #mainVisual .vis03 .bg{ background-image: url(../images/visual03_mob.jpg);}
      .boxMotion{ height: 126vw;}
      .boxMotion .box{ display: none; height: 126vw;}
      .boxMotion .box.box1{ display: block; width: 100%; height: 126vw; background: url(../images/boxM_mob.png) no-repeat 50% 0 / cover;}

      .mainValue .valueState .num { flex-direction: column;}
      .mainValue .valueState .num b{ font-size: 14vw; line-height: 1;}
      .mainValue .valueState .num .counter{ order: 2;}
      .mainValue .valueState .txt{ padding: 0; order: 1; text-align: right;}
      .mainValue .valueState .num i{ bottom: 0;}
      .mainValue .valueTxt{ font-size: 3.6vw;}
      .mainValue .txt_wrap .tit{ font-size: 3.6vw;}
      
      .mainSlide .slideWrap{ flex-direction: column; padding: 120px 0 0;}
      .mainSlide .image-stack{ order:1; margin: 60px auto 0;}
      .mainSlide .textArea{ width: 100%; order:2; text-align: center;}
      .mainSlide .slider-buttons{ margin: 50px  auto 0;}

      .quickWrap{ width: 75vw; height: 75vw; bottom: -38vw; top: auto; left: 50%; transform: translateX(-50%); right: auto;}
      .floatQuick{ width: 75vw; height: 75vw;}
      .floatQuick.on::before{ width: 75vw; height: 75vw;}
      .quick-item{ width: 16vw; height: auto; font-size: 3.4vw; flex-direction: column; align-items: center;}
      .quick-item::before{ width: 3.2vw; height: 3.2vw; margin: 0 0 .4rem 0; background-size: 100% auto;}
      #quick-button{ width: 18vw; height: 18vw;}
      #quick-button span{ width: 18vw; height: 18vw; transform: rotate(0deg); font-size: 2.2vw; padding: 1.7vw 0 0 0;}
      #quick-button span::before{ margin-bottom: 1vw;}
      #quick-button::before{ width: 24vw; height: 24vw;}

      .mainCareer .text{ padding: 90px 30px;}
      .mainCareer .text .bt{ left: 30px;}
      .mainCareer .boxMotion{ display: none;}
      .mainCareer .text .headSubTxt{ font-size: 4.4vw;}
      .mainCareer .careerImg img{ height: 64vw;}
      .mainCareer .careerImg img.img-pc{ display: none;}
      .mainCareer .careerImg img.img-mob{ display: block; }

      .tit_wrap{ padding: 60px 0 0 60px; flex-direction: column;}
      .tit_wrap .desc{ padding: 0;}
      .visual_sect{ margin-top: 60px; height: 220px;}
      .visual_sect .img img{ height: 220px;}
      .visual_sect .tit_box{ padding: 0 0 0 60px;}
      .visual_sect + .locationBar{ margin-top: 0;}
      .locationBar{ margin-top: 0; padding: 0; flex-wrap: wrap;}
      .locationBar .inner{ width: 100%; padding: 0;}
      .locationBar .home{ display: none;}
      .locationTab{ width: 100%; margin: 0; padding: 0 60px; border-top: #d3d3d3 1px solid;}

      .contents{ padding: 0 60px 100px; margin: 30px 0 0 0;}

      /* customer */    
      .sorting-bx{ gap:2rem; flex-direction: column; align-items: flex-start;}
      .sorting-bx .btFilter{ display: inline-flex; height: 48px; padding: 0 8px 0 18px;}
      .sorting-bx .btFilter::after{ margin-left: 10px;}
      .sorting-bx .sorting-bx-r{ order:1; width: 100%; display: flex; align-items: center;}
      .sorting-bx .sorting-bx-l{ order:2;}
      .tblHd{ margin: 0; padding: 20px 0; width: 100%; height: auto;}
      .tblHd .total{  width: 30%; padding: 0;}
      .tblHd .tblSch{ flex: 1; width: auto;}
      .tblHd .tblSch .inp{ height: 4.4rem; padding: 0 5rem 0 2rem;}
      .tblHd .tblSch .sch{ width: 4.4rem; height: 4.4rem; background-size: 1.5rem;}
      .tblHd .tblHd-r{ display: flex; width: 100%; gap:1rem;}
      .tblHd .tblHd-r .btFilter{ display: flex; width: 8.5rem; }
      .form-hdtx{ margin: -1rem 0 3rem;}
	   
	  .tblList{ min-height:auto;}
      .tblList > .hd .hd-itm.prod, 
      .tblList > .bd .bd-itm.prod{ padding: 20px;}
      .tblList > .hd .hd-itm.ico, 
      .tblList > .bd .bd-itm.ico,
      .tblList > .hd .hd-itm.date, 
      .tblList > .bd .bd-itm.date{ width: 100px;}
      .tblList > .hd .hd-itm.no, 
      .tblList > .bd .bd-itm.no,
      .tblList > .hd .hd-itm.rev, 
      .tblList > .bd .bd-itm.rev{ width: 80px;}
      .tblList > .hd .hd-itm.model, 
      .tblList > .bd .bd-itm.model{ flex:1;}

      div.paging{ margin-top: 3.5rem;}
      div.paging a, div.paging strong{ width: 3rem; height: 3rem; line-height: 3rem;}
      
      #filterWr{ position: fixed; top: 0; left: 0; width: 100%; bottom: 0; margin: 0; background-color: #fff; flex:none; max-width: none; z-index: 9; display: none;}
      #filterWr > .hd{ background-color: #fff; padding: 0 30px; height: 5rem;  }
      #filterWr > .hd h3{ position: relative; color: #000; font-weight: 600; width: 100%; justify-content: space-between;}
      #filterWr > .hd h3::after{ display: none;}
      #filterWr > .hd h3 .close{ display: block; width: 2rem; height: 2rem; position: relative; font-size: 0; color: transparent;}
      #filterWr > .hd h3 .close::before,
      #filterWr > .hd h3 .close::after{ content: ''; position: absolute; width: 1.4rem; height: .1rem; display: block; top: 50%; left: 50%; margin: 0 0 0 -.5rem; background-color: #000; transform: rotate(45deg);}
      #filterWr > .hd h3 .close::after{ transform: rotate(-45deg);}
      #filterWr .hd-r{ position: absolute; bottom: 0; left: 0; width: 100%; height: 8rem; padding: 0 30px; display: flex; background-color: #fff; border-top: #e6e6e6 1px solid; align-items: center; gap:1rem;}
      #filterWr > .hd .btReset{ width: 12rem; background-color: #f3f3f7; color:#000; justify-content: space-between;}
      #filterWr > .hd .btReset::after{ filter: brightness(1) invert(0);}
      #filterWr > .hd .btResult{ flex:1; background-color: #000; color: #fff; justify-content: center; }
      #filterWr > .hd .btReset,
      #filterWr > .hd .btResult{ padding: 0 1.6rem; font-weight: 600; display: flex; align-items: center; height: 5rem; font-size:15px;}
      #filterWr > .all{ height: 5.5rem; padding: 0 30px; display: flex; align-items: center;}
      #filterWr .filterLst{ height: calc(100vh - 18.6rem); overflow-y: auto;}
      .filterLst > li .btOpen{ height: 4.5rem; padding: 0 30px;}
      .filterLst .depth2{ padding: 2rem 2.5rem;}

      .catalogLst{ gap: 10vw 0;}
      .catalogLst .itm{ padding: 0 30px; margin-left: 6vw; width: calc(33.3% - 4vw);}
      .catalogLst .itm .down{ padding: 20px 0;}

      .btType input[type="radio"] + span, 
      .btType input[type="checkbox"] + span{ padding: 0 20px; min-width: 160px; }

      .no-result{ font-size: 1.5rem; padding: 10rem 0;}
      .no-result::before{ width: 4rem; height: 4rem; margin-bottom: 3rem;}

      /*company */
      .company01-obj{ width: 22vw; top: 180px;}
      .company01-bx .tx01{ padding-bottom: 50px;}
      .company01-bx .tx02{ padding: 0 0 190px; margin-top: 50px; font-size: 23px; background-size: 500px auto;}
      .company01-bx .tx02 .tx02-01{ margin-bottom:50px; font-size: 30px;}
      .company01-bx .tx02 .tx02-01 .tit{ font-size: 30px;}
      .company01-bx .tx02 .tx02-01 b{ font-size: 54px;}
      .company01-bx .tx03{ position: relative; background:#0f112a url(../images/company01_img_inf_tab.jpg) no-repeat 0 0 / 100% auto; padding: 8vw 60px 0;  height:113vw; margin: 0;}
      .company01-bx .tx03::after{ content: ''; width: 100%; left: 0; position: absolute; display: block; background-color: #fff; height: 2px; top: -1px;}
      .company01-bx .tx03 .tit{ font-size: 30px; display: flex; flex-direction: column; }
      .company01-bx .tx03 .tit b{ font-size: 72px; text-transform: uppercase; display: block; }
      .company01-bx .tx03 > ul{ margin-top: 6vw; max-width: none; font-size: 18px;}
      .company01-bx .tx03 > ul > li{  flex-direction: column; align-items: start; padding: 3vw 3vw 3vw 0; gap:2vw;}
      .company01-bx .tx03 > ul > li strong{ width: 130px;}
	  .company01-bx .tx03 > ul > li:nth-child(2){ max-width:60vw;}
	  .company01-bx .tx03 > ul > li:nth-child(3){ max-width:56vw;}
	  .company01-bx .tx03 > ul > li:nth-child(4){ border-bottom:none;}
      .company01-bx .company01-img{ margin-bottom: -100px;}

      .history-tab{ padding: 0;}
      .history-tab::before{ width: 100%;}
      .history-tab .inner{ justify-content: space-around;}
      .history-tab .itm{ padding: 34px 0;}
      .history-tab .itm::after{ bottom: 20px;}
      .company02-bx .tx01{ font-size:26px;}
      .company02-bx .tx01 b{ font-size: 40px;}
      .history-con .itm{ margin-top: -195px; padding: 195px 0; flex-direction: column;}
      .history-con .itm .history-hd .img{ height: 320px;}
      .history-con .itm .history-hd .img img{ height: 320px; width: calc(100% + 60px);}
      .history-con .itm .history-hd .desc{ font-size: 24px;}
      .history-con .itm .history-hd .desc .tit{ font-size: 54px;}
      .history-con .itm .history-bd{ margin-top: 100px; padding-left: 0; width: 100%;}
      .history-con .itm .history-bd > ul > li .y{ width: 135px;}

      .company05-bx .tx01{ padding-bottom: 50px;}
      .ci-bx1{ margin-top: 50px;}
      .ci-bx1 .desc{ font-size: 3.1vw;}
      .ci-bx1 .ci-vis .txt{ width: 100%; align-items: flex-start; max-width:none; font-size: 3.1vw;}
      .ci-bx1 .ci-vis img{ height: 100vw;}
      .ci-thumb{ gap:20px;}
      .ci-thumb2 > li{ width: 18vw;}
      .ci-bx3 p{ font-size: 25px;}

      .partners-lst{ gap:40px 12px;}
      .partners-lst .itm{ width: calc(25% - 9px);}
      .partners-lst.n3 .itm .img{ padding: 10px;}
      .partners-lst.n3 .itm .txt ul{ font-size: 14px;}
      .partners-lst.n3 .itm .txt ul > li{ flex-direction: column;}

      .fin-inf{ margin-bottom: -100px;}

      .map-bx dd{ flex-direction: column;}
      .map-bx dd .addr{ width: 100%; margin-bottom: 50px;}
      .contact-bx{ flex-direction: column;}
      .contact-bx .tit{ width: 100%; margin-bottom: 30px;}     

      .contact-tbl .tbl-hd .th:nth-child(1),
      .contact-tbl .tbl-bd .td:nth-child(1){ width: 13vw;}
      .contact-tbl .tbl-hd .th:nth-child(2),
      .contact-tbl .tbl-bd .td:nth-child(2){ flex:1;}
      .contact-tbl .tbl-hd .th:nth-child(3),
      .contact-tbl .tbl-bd .td:nth-child(3){ width: 20vw;}
      .contact-tbl .tbl-hd .th:nth-child(4),
      .contact-tbl .tbl-bd .td:nth-child(4){ width: 13vw;}
      .contact-tbl .tbl-hd .th:nth-child(5),
      .contact-tbl .tbl-bd .td:nth-child(5){ width: 20vw;}
      
      .busan .contact-tbl .tbl-hd .th:nth-child(4),
      .busan .contact-tbl .tbl-bd .td:nth-child(4){ width: 16vw;}

      /* recruit */
      .recruit01-bx2 dl{ flex-direction: column;}
      .recruit01-bx2 dl dt{ width: 100%;}
      .recruit01-bx2 dl dd{ padding-top: 60px;}

      .recruit02-bx1 .recruit-lg{ font-size: 40px;}
      .recruit02-bx2-l{ width: 40%;}
      .recruit02-bx2-l .tx-lg{ font-size: 50px;}
      .recruit02-bx2-tx{ gap:30px;}

      .recruitLst{ margin-top: 1rem;}    
      .recruit-vew-desc{ padding-bottom: 120px;}
      .recruit-vew-desc::after{ bottom: 20px; right: 20px;}  
      .recruit-vew-bt .btn{ flex:1; }

      /* esg */
      .esg01-bx1 .itm{ flex-direction: column;}
      .esg01-bx1 .itm .img{ width: 100%; margin-right: 0; margin-bottom: 60px;}
      .esg01-bx1 .itm .img img{ width: 100%;}
      .esg04 .form-wr .form-itm .textarea{ height: 400px;}
            
      .lay-pop .pop-bt .btn{ padding: 20px;}
      .modalPop .pop-close{ top: 0;}

      .esg03-tx2 ul li i{ width: 100px;}
      .esg03-tx3{ padding: 60px 60px;}

      /* products */      
      .products-hd .desc{ width: 44%; padding: 50px 30px 0;}
		.products-hd .img .s-img .itm img{ width: 8vw; height: 8vw;}

      .products04-bx .tx01{ font-size: 40px; padding: 0 0 60px;}F
      .products04-bx .tx02 p{ font-size: 38px; padding: 0 0 20px;}
      .products04-vis{ margin: 70px -60px 0; padding: 32px 40px; width: calc(100% + 120px); font-size: 40px; background: url(../images/products04_img2_tab.jpg) no-repeat 50% 50% / cover;}
      .product04-tbl .row-hd{ display: none;}
      .product04-tbl .row-bd .row-itm{ flex-wrap: wrap;}
      .product04-tbl .row-bd .row-itm .th{ width: 100%; background-color: #000; color: #fff; text-align: center; justify-content: center;}
      .product04-tbl .row-bd .row-itm .th + .td{ border-left: none;}
      .product04-tbl + .ul-list01{ margin-top: 20px;}
      .product04-tbl .tx-th{ display: block; margin-bottom: 10px;}
      .product04-tbl .row-bd .row-itm .th br{ display: none; }
      .products04-bottom{ margin:110px -60px -100px; padding: 60px;}
      .products04-bottom .tit{ font-size: 40px;}
      .products04-bottom .btz{ margin: 50px 0 0 0;}
      .products04-bx.products0402 .tx01{ font-size: 4.4vw;}
      .products04-bx.products0402 .tx02{margin-bottom: 0;}
      .prod-app .itm{ padding: 20px 20px 40px; flex-direction: column; align-items: center; text-align: center; min-height: 12rem;}
		
		 /* support */      
	  .form-bottom .dv-privacy-tx{ flex-direction: column; }
	  .form-bottom .dv-privacy-tx dl + dl{ border:none; border-top:#f3f3f7 1px solid;}
      
		@media (orientation: portrait) and (max-width:1024px) {
			.menu-bg .bg-part{ background-image: none;}
		}

      @media screen and (max-width:820px){

        .menu-bg .bg-part{ background-image: none;}

        .menu-content{ padding: 120px 30px 0;}
        .menu-content .allMenu > li > a{ font-size: 26px;}

        footer{ padding: 70px 50px; flex-direction: column;}
        footer .footerAddr{ margin: 40px 0 0 0;}
        footer .footerCopy{ margin: 40px 0 0 0; text-align: left;}
        footer .btPrivacy{ position: relative; left: auto; bottom: auto; margin: 35px 0 0 0; }

        .tit_wrap{ padding: 60px 0 0 60px;}
        
        .ckWrap .ckWrapInner{ padding: 30px; flex-direction: column;}
        .ckWrap .ckBtn{ margin-top: 20px; justify-content: center;}
                
        .quickWrap{ width: 75vw; height: 75vw; bottom: -38vw; top: auto; left: 50%; transform: translateX(-50%); right: auto;}
        .floatQuick{ width: 75vw; height: 75vw;}
        .floatQuick.on::before{ width: 75vw; height: 75vw;}
        .quick-item{ width: 16vw; height: auto; font-size: 3.4vw; flex-direction: column; align-items: center;}
        .quick-item::before{ width: 3.2vw; height: 3.2vw; margin: 0 0 .4rem 0; background-size: 100% auto;}
        #quick-button{ width: 18vw; height: 18vw;}
        #quick-button span{ width: 18vw; height: 18vw; transform: rotate(0deg); font-size: 2.2vw; padding: 1.7vw 0 0 0;}
        #quick-button span::before{ margin-bottom: 1vw;}
        #quick-button::before{ width: 24vw; height: 24vw;}
                        
        .animated-button{ font-size: 1.2rem; line-height: 4rem; padding: 0 1.5rem;}
        .animated-button::after{ line-height: 4rem; }
		.animated-button:hover{ border-color: #d3d3d3; color: #999;}
		.animated-button:hover::before{ bottom: -100px;}
		.animated-button:hover::after{left: 50%; bottom: -100px; transform: translateX(-50%);}
		.animated-button.on{ color: transparent; border-color: #ff320f;}
		.animated-button.on::before { bottom: 0; left: -40%;}
		.animated-button.on::after { bottom: 0; transform: translateX(-50%) translateY(0);}
        
        .mainValue .valueState .num b{ padding-right: 2vw; }
        .mainValue .valueState .num i{ width: 2vw; height: 2vw;}
        .mainValue .valueState .num i::before{ bottom: -100px;}
        .mainValue .valueState .num i::after{ width: 2vw; margin-left: -1vw;}
        
        .mainPartners{ background:#0f112a url(../images/bg_mPart_mob.jpg) no-repeat 50% 100% / cover;}

        .mainCust > a{ padding: 15px; font-size: 3vw;}
        .mainCust > a::before{ width: 8vw; height: 8vw; margin-bottom: 2vw;}

        .prodSlide{ overflow: hidden; margin: 40px -30px 0 0;}

        .newsWrap .newsItm{ padding: 30px 0; margin: 0;}
        .newsWrap .newsItm > *{ padding: 0;}
        .newsWrap .newsItm .cate,
        .newsWrap .newsItm .date{ width: 100px;}
        .newsWrap .newsItm .newsTxt{ padding: 0;}
        .newsWrap .newsItm::before{ left: 0; right: 0; }
        .newsWrap .newsItm::after{ display: none;}
        .newsWrap .newsItm:hover > *{color: initial;}
        
        .mainSolution .solutionItm{ padding: 1.5rem; height: 14rem; width: 100% !important;}
        .mainSolution .solutionItm b{ font-size: 2rem;}
        .mainSolution .solutionItm i{ width: 4rem; height: 4rem; left: 1.5rem; bottom: 2rem; background-size:100% auto; background-position:0 50%; background-repeat:no-repeat;}
        .mainSolution .solutionItm::after{ width: 2.5rem; height: 2.5rem; top: 1.5rem; right: 1.5rem;}
        .mainSolution .solutionItm span{ margin: 7vw 0 0 0; font-size: 1.2rem; padding: 0 0 0 5rem;}
        .btType input[type="radio"] + span, 
        .btType input[type="checkbox"] + span{ min-width: 160px;}

        .locationBar .inner{ padding: 0;}
        .locationTab{ padding: 0 4vw; overflow-x: auto;}
        .locationTab a{ white-space: nowrap;}

        /* customer */
        .form-wr{ gap:30px 0;}
        .form-wr .form-itm{ width: 100%;}
        .form-wr .form-itm .inp-grp .select, 
        .form-wr .form-itm .inp-grp .inp{ width: 20%;}
        .form-wr .form-itm .inp-grp .input-wrapper .select,
        .form-wr .form-itm .inp-grp .input-wrapper .inp{ width: 100%;}
		
		.form-bottom .dv-privacy{ flex-wrap: wrap;}
		.form-bottom .dv-privacy .dv-privacy-l{ width:100%; }
		.form-bottom .dv-privacy .capt{ margin:20px auto 0;}

        .newsLst .newsLst-itm{ padding: 50px 0;}
        .newsLst .newsLst-itm > a{ padding: 0;}
        .newsLst .newsLst-itm .img{ width: 240px;}
        .newsLst .newsLst-itm .desc .tit{ font-size: 28px;}
        .newsLst .newsLst-itm .desc .txt{ margin: 20px 0; max-height: 125px; overflow: hidden; white-space: normal; word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical;}

        /* company */
        .company01-bx .tx01{ font-size: 40px;}
        .company01-obj{ top: 240px;}

        .partners-lst .itm .img{ height: 80px;}
        .partners-lst .itm .txt{ font-size: 16px; height: 40px;}

        .fin-state .tx b{ font-size: 20px;}
        .fin-state .sc{ transform: scale(.8);}
        .fin-inf p{ font-size: 20px;}
        
        /* recruit */        
        .recruit-lg{ font-size: 5vw;}
        .recruit01-bx1 .recruit-lg{ font-size: 40px;}
        .recruit01-bx1 .img img{ height: auto;}
        .recruit01-bx2 .recruit-lg{ margin: 120px 0 100px;}
        .recruit02-bx1 .tx-lg{ font-size: 40px;}
        .recruit02-bx1 .img{ margin: 50px 0 0; }
        .recruit02-bx2{ margin: 110px 0 0 0; flex-direction: column;}
        .recruit02-bx2-l{ width: 100%;}
        .recruit02-bx2-l p{ font-size: 15px;}
        .recruit02-bx2-l .recruit-lg br{ display: none;}
        .recruit02-bx2-tx{ margin: 58px 0 0 0; width: 100%;}
        .recruit02-bx2-tx .itm{ width: calc(50% - 15px);}
        .recruit02-bx2-tx .itm h3{ font-size: 28px;}
        .recruit02-bx2-tx .itm ul{ font-size: 18px;}

        .recruitHd .select{ flex:1; width: 30%;}
        .recruitHd .btn{ width: 120px;}
        .recruitLst .recruitLst-itm{ width: calc(50% - 15px); padding: 45px 25px 40px; height: 300px;}
        .recruitLst .recruitLst-itm .tit{ font-size: 25px;}

        /* products */        
        .products-hd{ flex-direction: column;}
        .products-hd .img{ padding-bottom: 60px;}
        .products-hd .img .b-img{ width: 80%;}
        .products-hd .img .b-img img{ width: 80vw; height: 80vw;}
		.products-hd .img .slide-img{ width: 80vw;}
        .products-hd .img .s-img{ position: relative; bottom: auto; left: auto; transform: translateX(0);}
		.products-hd .img .s-img .itm img{ width: 11vw; height: 11vw;}
        .products-hd .desc{ width: 100%; padding: 60px;}
        .products-hd .desc .tit{ margin-bottom: 0;}
        .products-hd .desc .desc-tx2{ padding: 60px 0 0;}
        .products-hd .procudts-bt{ margin-top: 40px;}
        .products-bd + .products-bd{ padding: 60px 0 100px;}
        .products-bd .tit{ margin-bottom: 50px;}
        .products-bottom{ padding: 100px 90px;}
        .products-bottom .tit{ font-size: 56px;}
        .products-bottom a{ margin: 40px 0 0; width: 100%;}
        .products04-bottom{ width: calc(100% + 120px); margin: 110px -60px -100px; }

        @media screen and (max-width:768px){

          .menu-content .allMenu{ line-height: 1.2;}
          .menu-content .allMenu > li > a{ font-size: 20px;}
          .menu-content .depth2 > li > a{ font-size: 18px;}

          .popEsg040 .tx2 > li{ padding: 15px 20px 30px;}
          .lay-pop .pop-con{ padding: 60px 30px;}

          .ci-bx1 .ci-vis .txt{ letter-spacing: -.05em;}      
          
          @media screen and (max-width:767px){
            .tblList > .hd{ display: none;}

            .tblList{ margin: 0;}
            .tblList > .bd .bd-itm{ padding: 0; width: 100%; text-align: left; }
            .tblList > .bd .bd-row{ flex-wrap: wrap; padding: 3rem 2.5rem; align-items: flex-start;}
            .bd .bd-itm.no{ display: none;}
            .tblList > .bd .bd-itm.model,
            .tblList > .bd .bd-itm.subj{ order:1; flex: none; font-size: 20px; margin-bottom: 2rem; width: 100%;}
            .tblList > .bd .bd-itm.ico{ width: 100%; margin-top: 1rem; order:99;}
            .tblList > .bd .bd-itm.ico .btDown{ width: 100%; border: #b9bac3 1px solid; height: 3.8rem; padding: 0 1.5rem; display: flex; justify-content: space-between; align-items: center; color: #333; font-weight: 600; font-size: 13px;}
            .tblList .btDown::after{ width: 1.5rem; height: 1.5rem;}
            .tblList > .bd .bd-itm.subj{ padding: 0; width: 100%;}
            .tblList > .bd .bd-itm.type,
            .tblList > .bd .bd-itm.vew{ display: inline-block; width: 100%;}
            .tblList > .bd .bd-itm.prod{ order: 2; padding: 0; flex:none; width: 100%; }
            .tblList > .bd .bd-itm.type{ order: 3; width: auto; margin-right: 40px;}
            .tblList > .bd .bd-itm.date{ order: 4; width: 60%;}
            .tblList > .bd .bd-itm.rev{ order: 5; width: auto; margin-left:auto;}

            .lay-pop.m-full .pop-inner{ padding: 0;}
            .lay-pop.m-full .pop-bx{ width: 100%; height: 100vh; max-height: none;}
          }

          @media screen and (max-width:480px){

            #header > .inner{ padding: 0 4vw; height: 4.6rem;}
            #header .logo{ width: 13rem;} /*width: 9.8rem;*/
            #header .logo a{ height: 4rem;}
            #header .utill .lang .langBtn{ font-size: 1.1rem; width: 7rem;}
            #header .utill .lang .langBtn i{ background-size: 1.6rem; width: 1.6rem; height: 1.6rem;}
            #header .utill .searchBtn,
            #header.main .utill .searchBtn{ width: 3rem; height: 3rem; margin-left: 1.4rem; background-size: 1.6rem;}
            #header .utill .searchBtn.on{ background-size: 1.2rem;}
            #header .utill .menuBtn{ width: 2.4rem; height: 2.4rem; margin-left: .2rem;}
            #header .utill .menuBtn::before{ width: 1.4rem; height: .1rem; transform: translate(0, -2px);}
            #header .utill .menuBtn::after{ width: 1rem; height: .1rem;}

            .headSearch .searchInp .sch{ background-size: 2rem;}
            .headSearch .keywords dt{ font-size:1.5rem; font-weight: 600;}
            
            #header.aMnuOpen .utill{ margin: 0; width: 100%; justify-content: space-between;}
            #header.aMnuOpen .utill .lang{ display: block; margin-left: 0;}
            #header.aMnuOpen .logo{ display: none;}
            #header.aMnuOpen .utill .menuBtn{ width: 1rem;}
            #header.aMnuOpen .utill .menuBtn::before, 
            #header.aMnuOpen .utill .menuBtn::after,
            #header.aMnuOpen .utill .menuBtn:hover::before, 
            #header.aMnuOpen .utill .menuBtn:hover::after,
            #header .utill .menuBtn:hover::before{ width: 1.6rem;}
            #header .utill .menuBtn:hover::after{ width: 1.1rem;}
            .menu-content{ padding: 8.5rem 4vw 0;}
            .menu-content .allMenu{ flex-direction: column; overflow-y: auto; height: calc(100vh - 8.5rem); display: block;}
            .menu-content .allMenu > li{ flex: none;}
            .menu-content .allMenu > li + li{ margin-top: 1.8rem;}
            .menu-content .allMenu > li > a{ position: relative; font-size: 2rem;}
            .menu-content .allMenu > li > a::after{ content: ''; position: absolute; display: block; top: 50%; right: .5rem; margin-top: -1rem; transform: rotate(135deg); width: 1.5rem; height: 1.5rem; border-top: #fff .2rem solid; border-right:#fff .2rem solid;}
            .menu-content .allMenu > li.on > a::after{ margin-top: -.6rem; transform: rotate(-45deg);}
            .menu-content .subDepth{ margin: 1.5rem 0 0 0; padding: 0 0 0 1rem; }
            .menu-content .depth3{ margin: 1.5rem 0 0 0; padding: 0 0 0 1.5rem;}
            .menu-content .subDepth {  max-height: 0;  opacity: 0;  transform: translateY(-10px);  overflow: hidden; transition: max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease;}
            .menu-content .allMenu > li.on .subDepth {  max-height: 55rem;  opacity: 1;  transform: translateY(0);}
            
            .headSearch{ padding: 8rem 4rem 0; height: 27rem;}
            .headSearch .searchInp .searchInput{ height: 5rem; font-size: 1.5rem;}
            .headSearch .searchInp .sch{ width: 5rem; height: 5rem;}

            footer{ padding: 3rem 4vw; flex-direction: column;}          
            footer .footerLogo{ width: 100%;}
            footer .footerLogo .logo{ width: 11.5rem;}
            footer .btPrivacy{ margin: 2rem 0 0 0; width: 100%; height: 3.8rem; padding: 0 2.5rem;}
            footer .footerAddr{ margin: 2.6rem 0 0 0;}
            footer .footerAddr .contact{ margin: 2.6rem 0 0 0;}
            footer .footerAddr dl{ flex: 1;}
            footer .footerAddr dt{ font-size: 1.5rem;}
            footer .footerAddr dd{ margin-top: 1rem; font-size: 1.2rem;}
            footer .footerCopy{ margin-top: 3.5rem; padding: 0;}
            footer .footerCopy .copyTxt br{ display: none; }
            footer .footerCopy .copyright{ margin: 2.5rem 0 0 0; font-size: 1.2rem;}

            .btTop,
            .btTop.fComp{ right: 0; bottom: 0; background-size: 1.5rem;}

            .btTop.fComp{ top: 3rem;}
            
            .ckWrap .ckWrapInner{ padding: 5vw; font-size: 1.3rem; flex-direction: column;}
            .ckWrap .ckBtn{ margin-top: 2rem; justify-content: center;}

            .quickWrap{ width: 30rem; height: 30rem; bottom: -14.5rem; top: auto; left: 50%; transform: translateX(-50%); right: auto;}
            .floatQuick{ width: 30rem; height: 30rem;}
            .floatQuick.on::before{ width: 28rem; height: 28rem;}
            .quick-item{ width: 6rem; height: auto; flex-direction: column; align-items: center; font-size: 1.2rem;}
            .quick-item::before{ width: 1.4rem; height: 1.4rem; margin: 0 0 .4rem 0; background-size: 100% auto;}
            #quick-button{ width: 7rem; height: 7rem;}
            #quick-button span{ width: 7rem; height: 7rem; transform: rotate(0deg); font-size: 1rem; padding: .8rem 0 0 0;}
            #quick-button::before{ width: 8.5rem; height: 8.5rem;}
            #quick-button span::before{ width: .6rem; height: .6rem; border-width: .1rem;}

            .mainH2{ font-size: 2rem;}
            .mainH2 > em{ font-size: 1.4rem; margin: 0 .5rem;}
            .mainH2 .more{ background-size: 1rem;}

            #mainVisual .text{ padding: 48vw 4vw 4vw; font-size: 4.5vw; height:134vw; }
            #mainVisual .text strong{ font-size: 10.2vw; margin-top: 4vw;}
            #mainVisual .bulletPag,
            #mainVisual .progress-bx{ display: none;}
            #mainVisual .pag{ left: 4vw; top: 84vw; bottom: auto; font-size: 2.7vw;}
            #mainVisual .bg{ min-height: 134vw;}
            .boxMotion{  height:134vw;}
            .boxMotion .box{ display: none;  height:134vw;}
            .boxMotion .box.box1{ display: block; width: 100%;  height:134vw; background: url(../images/boxM_mob.png) no-repeat 50% 0 / cover;}

            .mainValue{ padding: 3rem 4vw;}
            .mainValue .valueState .num{ font-size: 1rem; }
            .mainValue .valueState .num b{ font-size: 5.5rem; padding-right: 3vw; font-weight: 500;}
            .mainValue .valueState .name{ font-size:1.2rem;}
            .mainValue .valueState .num i{ width: .6rem; height: .6rem; bottom: .4rem; right: -.5rem;}
            .mainValue .valueState .num i::before, 
            .mainValue .valueState .num i::after{ width: .6rem; height: .1rem; margin-left: -.3rem;}
            .mainValue .valueState .txt{ padding: 0; order:1; text-align: right;}
            .mainValue .valueState .num .counter{ order:2;}
            .mainValue .valueState .valueItm:nth-child(2)::before{ top: 1rem; bottom: 1rem; }
            .mainValue .valueState .valueItm:nth-child(2)::after{ top: 1rem; bottom: 1rem; }
            .mainValue .valueImg{ margin: 2rem auto; max-width: 18rem;}
            .mainValue .valueTxt{ display: none;}
            .mainValue .valueTxt-mob{ font-size: 1.6rem; text-align: center; display: block;}
            .mainValue .vis-pc{ display: none;} 
            .mainValue .txt_wrap.vis-mob{ display: flex;}
            .mainValue .txt_wrap.vis-mob .tit{ font-size: 4.6vw;}

            .mainSlide{ padding: 0 4vw;}
            .mainSlide .slideWrap{ flex-direction: column; padding: 4rem 0;}
            .mainSlide .image-stack{ width: 100%; order:1; max-width: 22rem; height: 17rem; margin: 4rem auto;}
            .mainSlide .slide{ width: 22rem; height: 17rem;}
            .mainSlide .textArea{ padding: 0; order:2; width: 100%;}
            .mainSlide .text{ text-align: center;}
            .mainSlide .text h2{ font-size: 1.5rem;}
            .mainSlide .text h2 b{ font-size: 2.5rem;}
            .mainSlide .text p{ font-size: 1.5rem; margin-top: 2rem;}
            .mainSlide .slider-buttons{ margin: 3.5rem auto 0;}
            .mainSlide .slider-buttons button{ width: 1.5rem; height: 1.5rem; opacity: .5;}
            .mainSlide #counter{ margin: 0 2rem;}

            .mainProd{ padding: 3rem 4vw;}
            .mainProd .tab{ margin: 2.6rem 0 0 0; padding: 0 0 1.5rem 0;}
            .animated-button{ font-size: 1.2rem; line-height: 4rem; padding: 0 1.5rem;}
            .animated-button::after{ line-height: 4rem; }
            .mainProd .tab2{ padding: 1.2rem 0 0 0; font-size: 1.2rem; gap:2rem;}
            .mainProd .tab2 > *{ padding: 0;}
            .mainProd .tab2 > * + *{ border:none;}
            .prodSlide{ margin: 2.5rem 0 0 0;}
            .prodSlide .swiper-slide{ width: 16rem;}
            .prodSlide .swiper-slide .img{ height: 18rem;}
            .prodSlide .swiper-slide .txt{ font-size: 1.3rem; padding: 0; margin: 1rem 0 0 0;}
            .prodSlide .control{ margin: 3.5rem 0 0 0;}
            .prodSlide .control button{ width: 1.5rem; height: 1.5rem; opacity: .5;}
            .prodSlide .control .pag{ margin: 0 2rem;}

            .mainCert{ padding: 3rem 4vw;}
            .mainCert .certList{ margin: 6rem 0 0 0;}
            .mainCert .certList .swiper-slide{ width: 16.5rem; padding: 0 0 0 1.5rem;}
            .mainCert .certList .img{ width: 6.5rem;}
            .mainCert .certList .txt{ padding: 0 1rem 0 0;}
            .mainCert .certList .txt h3{ font-size: 1.2rem;}

            .mainPartners{ padding: 0 4vw 2rem;}
            .mainPartners .line > div > div{ height: 1rem;}
            .mainPartners .headSubTxt{ margin: 3rem 0 0 0; font-size: 1.5rem;}
            .marquee-con{ margin: 10rem -4vw 0;}
            .marquee-con .marquee div{ width:227rem; height: 4rem;}
            .marquee-con .marquee div img{ height: 4rem;}
			.marquee-con .marquee div img + img{ margin-left:5rem;}

            .mainCust{ padding: 3rem 4vw;}
            .mainCust > a{ padding: 2.4rem 1rem; font-size: 1.5rem; border-radius: 1rem;}
            .mainCust > a::before{ width: 5rem; height: 5rem; margin: 0 0 2.5rem;}
            .mainCust > a + a{ margin-left: 1rem;}

            .mainNews{ padding: 3rem 4vw;}
            .newsWrap{ margin: 1.2rem 0 0 0;}
            .newsWrap .newsItm{ padding: 1.4rem 0; margin: 0;}
            .newsWrap .newsItm > *{ padding: 0;}
            .newsWrap .newsItm .cate{ width: 6rem; padding: 0;}
            .newsWrap .newsItm .cate .new{ width: .3rem; height: .3rem; margin-left: .4rem;}
            .newsWrap .newsItm .date{ width: 9rem; padding: 0;}
            .newsWrap .newsItm .newsTxt{ padding: 0; margin-top: 1rem; width:100%; flex: none;}
            .newsWrap .newsItm::before{ left: 0; right: 0;}

            .mainSolution{ padding: 3rem 4vw; flex-direction: column; gap:1.5rem}
            .mainSolution .solutionItm{ padding: 1.5rem; height: 14rem; width: 100% !important;}
            .mainSolution .solutionItm b{ font-size: 2rem;}
            .mainSolution .solutionItm i{ width: 6rem; height: 6rem; left: 1.5rem; bottom: 2rem;}
            .mainSolution .solutionItm::after{ width: 2.5rem; height: 2.5rem; top: 1.5rem; right: 1.5rem;}
            .mainSolution .solutionItm span{ margin: 4vw 0 0 0; font-size: 1.4rem; padding: 0 0 0 12rem;}

            .mainCareer .careerImg img{ height: 23.5rem;}
            .mainCareer .careerImg img.img-mob{ display: block;}
            .mainCareer .boxMotion{ display: none;}
            .mainCareer .text{ padding: 3rem 4vw;}
            .mainCareer .text .headSubTxt{ margin: 2.5rem 0 0 0; font-size: 1.5rem;}
            .mainCareer .text .bt{ width: 2rem; height: 2rem; left: 4vw; bottom: -2.5rem;}

            #container{ padding: 4.6rem 0 0 0;}
            .tit_wrap{ padding: 4rem 4vw 0; margin-bottom: 5rem; font-size: 1.8rem;}
            .tit_wrap .tit{ font-size: 3.5rem;}
            .visual_sect{ margin-top: 1.8rem; height: 16rem;}
            .visual_sect .img img{ height: 16rem;}
            .visual_sect .tit_box{ font-size: 1.7rem; padding: 1.6rem 4vw; }
            .visual_sect .tit_box em{ margin-top: 1rem;}

            .locationBar .inner{ padding: 0;}
            .locationBar .location{ min-width: auto; flex: 1;}
            .locationBar .home > a{ height: 4rem;}
            .locationBar .location > a, 
            .locationBar .location > span{ height: 4rem; line-height: 4rem; padding: 0 2.5rem 0 1.5rem; font-size: 1.2rem;}
            .locationBar .location>a:after{ width: .7rem; height: .7rem; border-width: .1rem;}
            .locationBar .location > ul{ top: 4rem; padding: .5rem 0;}
            .locationBar .location > ul>li>a{ font-size: 1.2rem; padding: .4rem .4rem .4rem 1.5rem;}
            .locationTab{ padding: 0 4vw; gap:2.5rem;}
            .locationTab a{ min-height: 4rem; font-size: 1.2rem; padding: 0;}

            .contents{ padding: 0 4vw 6rem; margin: 3rem 0 0 0;}

            /* customer */
            .tblList > .hd{ display: none;}

            .tblList{ margin: 0;}
            .tblList > .bd .bd-itm{ padding: 0; width: 100%; text-align: left; order:2; font-size: 1.4rem;}
            .tblList > .bd .bd-row{ padding: 3rem 2.5rem;}
            .bd .bd-itm.no{ display: none;}
            .tblList > .bd .bd-itm.model,
            .tblList > .bd .bd-itm.subj{ order:1; font-size: 2.6rem; margin-bottom: 2rem;}
            .tblList > .bd .bd-itm.ico{ width: 100%; margin-top: 1rem;}
            .tblList > .bd .bd-itm.ico .btDown{ width: 100%; border: #b9bac3 1px solid; height: 3.8rem; padding: 0 1.5rem; display: flex; justify-content: space-between; align-items: center; color: #333; font-size: 1.2rem; font-weight: 600;}
            .tblList .btDown::after{ width: 1.5rem; height: 1.5rem;}
            .tblList.notice > .bd .bd-row{ padding: 1.5rem 2rem 1.5rem 0;}
            .tblList.notice > .bd .bd-itm.date{ width: auto; padding-left: 4rem;}
            .tblList.notice > .bd .bd-itm.vew{ display: none;}
            .tblList.notice > .bd .bd-itm.no{ display: inline-block; order:1; width: 4rem; text-align:center;}
            .tblList.notice > .bd .bd-itm.subj{ width: calc(100% - 4rem); font-size: 1.5rem; margin-bottom: .5rem;}
            .tblList > .bd .bd-itm.vew,
            .tblList > .bd .bd-itm.type{ margin-right: 2rem;}

            .sorting-bx .btFilter{ height: 3.4rem; font-size: 1.2rem; }
            .sorting-bx .btGuide{ height: 3.4rem; padding: 0 1.2rem; font-size: 1.2rem; min-width:auto; }
            .sorting-bx .btGuide::after{ width: 1rem; height: 1rem; background-size: cover; margin-left: .5rem;}
            .sorting-bx .sort-itm,
            .sorting-bx .btReset{ font-size: 1.2rem; height: 3rem; padding: 0 .6rem; min-width: 6rem;}
            .sorting-bx .btReset::after{ width: 1rem; height: 1rem; margin-left: .5rem;}

            .tblHd{ flex-direction: column; width: 100%; height: auto; gap:2rem 0;}
            .tblHd .total{ order:2; width: 100%;}
            .tblHd .tblSch{ order:1; flex: 1; width: auto; }
            .tblHd .tblSch .inp{ height: 4.5rem; padding: 0 5rem 0 2rem;}
            .tblHd .tblSch .sch{ width: 4.5rem; height: 4.5rem; background-size: 1.5rem;}
            .tblHd .tblHd-r{ display: flex; width: 100%; gap:1rem;}
            .tblHd .tblHd-r .btFilter{ display: flex; width: 8.5rem; height: 4.4rem;}

			.newsLst{ margin:0;}

            div.paging{ margin-top: 3.5rem;}
            div.paging a, 
            div.paging strong{ width: 3rem; height: 3rem; line-height: 3rem;}
            
            #filterWr{ position: fixed; top: 0; left: 0; width: 100%; bottom: 0; margin: 0; background-color: #fff; flex:none; max-width: none; z-index: 9; display: none;}
            #filterWr > .hd{ background-color: #fff; padding: 0 4vw; height: 5rem;  }
            #filterWr > .hd h3{ position: relative; color: #000; font-size: 1.8rem; font-weight: 600; width: 100%; justify-content: space-between;}
            #filterWr > .hd h3::after{ display: none;}
            #filterWr > .hd h3 .close{ display: block; width: 2rem; height: 2rem; position: relative; font-size: 0; color: transparent;}
            #filterWr > .hd h3 .close::before,
            #filterWr > .hd h3 .close::after{ content: ''; position: absolute; width: 1.4rem; height: .1rem; display: block; top: 50%; left: 50%; margin: 0 0 0 -.5rem; background-color: #000; transform: rotate(45deg);}
            #filterWr > .hd h3 .close::after{ transform: rotate(-45deg);}
            #filterWr .hd-r{ position: absolute; bottom: 0; left: 0; width: 100%; height: 8rem; padding: 0 4vw; display: flex; background-color: #fff; border-top: #e6e6e6 1px solid; align-items: center; gap:1rem;}
            #filterWr > .hd .btReset{ width: 12rem; background-color: #f3f3f7; color:#000; justify-content: space-between;}
            #filterWr > .hd .btReset::after{ filter: brightness(1) invert(0);}
            #filterWr > .hd .btResult{ flex:1; background-color: #000; color: #fff; justify-content: center; }
            #filterWr > .hd .btReset,
            #filterWr > .hd .btResult{ padding: 0 1.6rem; font-size: 1.3rem; font-weight: 600; display: flex; align-items: center; height: 5rem;}
            #filterWr > .all{ height: 5.5rem; padding: 0 4vw; display: flex; align-items: center;}
            #filterWr .filterLst{ height: calc(100vh - 18.6rem); overflow-y: auto;}
            .filterLst > li .btOpen{ height: 4.5rem; font-size: 1.4rem; padding: 0 4vw;}
            .filterLst .depth2{ padding: 2rem 2.5rem;}

            .catalogLst .itm:nth-child(3n+1),
            .catalogLst .itm{ margin-left: 6vw; width: calc(50% - 3vw); padding: 0 4vw;}
            .catalogLst .itm:nth-child(2n+1){ margin-left: 0;}
            .catalogLst .itm .down{ padding: 4vw 0; font-size: 1.3rem;}
            .catalogLst .itm .down::after{ width: 1.4rem; height: 1.4rem;}

            .form-wr .form-itm .hd{ font-size: 1.5rem; margin-bottom: 1rem;}
            .btType input[type="radio"] + span, 
            .btType input[type="checkbox"] + span{ min-width: 4rem; height: 4rem; line-height: 4rem; padding: 0 1.5rem;}
            .btType input[type="radio"] + span::after, 
            .btType input[type="checkbox"] + span::after{ margin-left: .8rem;}

            .form-wr .form-itm .bd + .bd{ margin-top: 1.4rem;}
            .filebox label{ height: 4rem; line-height: 4rem; padding: 0 1rem; font-size: 1.2rem;}
            .filebox label::after{ margin-left: .4rem;}
            .filebox .upload-name{ height: 4rem; line-height: 4rem; padding: 0 3rem 0 1rem; width: 100%;}
            .filebox .bt_add,
            .filebox .bt_del{ padding: 0 1.4rem; font-size: 1.2rem;}
            .filebox .bt_del{ padding-left: 3.6rem;}
            .filebox .bt_add i,
            .filebox .bt_del i{ margin-left: .5rem;}
            .filebox .clear-btn{ right: 10rem;}

            .form-bottom{ margin-top: 1.5rem; }
            .form-bottom .dv-privacy{ align-items: flex-start; flex-direction: column;} 
            .form-bottom .dv-privacy .dv-privacy-l{ display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%;}
            .form-bottom .dv-privacy label{ margin-right: 0; text-indent:-3rem; padding-left:3rem;}
			.form-bottom .dv-privacy a{ padding-left:3rem;}
            .form-bottom .dv-privacy .capt{ margin-top: 2rem;}
            .form-bottom .dv-privacy-tx{ flex-direction: column;}
            .form-bottom .dv-privacy-tx dl{ padding: 2.5rem 3rem;}
            .form-bottom .dv-privacy-tx dl + dl{ border:none; border-top: #f3f3f7 1px solid;}
            .form-bottom .dv-privacy-tx dl dt{ font-size: 1.5rem; margin-bottom: 1rem;}
            .form-bottom .dv-privacy-tx dl dd br{ display: none;}
            .form-wr .form-itm .textarea{ height: 18rem;}

            .clear-btn{ width: 1.2rem; height: 1.2rem; right: 0; background-size: 1.2rem;}

            .lay-pop .pop-inner{ padding: 4vw;}
            .lay-pop .pop-con{ padding: 4rem 1.5rem;}
            .lay-pop.sm .pop-bx{ width: 90vw;}
            .lay-pop.sm .pop-con{ padding: 2rem;}
            .lay-pop .pop-bt{ padding: 1.5rem; border-top: #e6e6e6 1px solid;}
            .main-pop{ max-width: 32rem; width: 90vw;}

            .newsLst .newsLst-itm{ padding: 3rem 0;}
            .newsLst .newsLst-itm > a{ flex-direction: column;}
            .newsLst .newsLst-itm .img{ width: 100%; margin: 0 0 2.5rem 0;}
            .newsLst .newsLst-itm .img img{ height: 25rem;}
            .newsLst .newsLst-itm .desc{ font-size: 1.3rem;}
            .newsLst .newsLst-itm .desc .tit{ font-size: 2rem;}
            .newsLst .newsLst-itm .desc .txt{ margin: 1.3rem 0; max-height: 6rem; overflow: hidden; white-space: normal; word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;}

            .tblView > .hd{ margin-top: 3rem;}
            .tblView .subject{ font-size: 2rem;}
            .tblView .hd-tx{ margin-top: 1rem; padding: .5rem 0; gap:2rem;}
            .tblView .hd-tx .itm{ gap:1rem;}
            .tblView > .bd{ margin: 3rem 0 0 0; font-size: 1.3rem;}
            .tblView.recruit > .bd{ margin: 3rem 0 0 0; padding: 0;}
            .file-list{ margin: 3rem 0 0 0;}

            .viewBottomList{ margin: 4rem 0 0 0; }
            .viewBottomList > ul{ padding: 0; flex-direction: column;}
            .viewBottomList > ul > li{ padding: 1rem 0; width: 100%;}
            .viewBottomList > ul > li + li{ border:none; border-top: #e5e5e5 1px solid;}
            .viewBottomList .orderPrev, 
            .viewBottomList .orderNext{ order:1; width: 8rem;}
            .viewBottomList .title{ order:2;}
            .viewBottomList .viewBottomNext .title{  text-align: left;}
            .viewBottomList .orderNext::after{ display: none;}
            .viewBottomList .orderPrev::before,
            .viewBottomList .orderNext::before{ content: ''; margin: -2px .8rem 0 0; width: .6rem; height: .6rem; border-top: #1e1e1e 1px solid; border-right: #1e1e1e 1px solid; transform: rotate(-45deg);}
            .viewBottomList .orderNext::before{ transform: rotate(135deg);}
            
            .sub-tit{ margin: 4rem 0 1.5rem;}
            .sub-tit .tit,
            .sub-tit.sm .tit{ font-size: 2.4rem; min-height: 2.4rem;}
            .sub-tit.ssm{ margin: 4rem 0 1.5rem;}
            .sub-tit.ssm .tit{ font-size: 2rem;}
            .sub-tit.ssm::before{ margin-bottom: 1rem;}
            .sub-tit .sub-tx{ font-size: 1.4rem; margin-top: .5rem;}

            .skew::before{ width: 1rem; height: .5rem; margin-bottom: 1rem;}

            .h4-tit{ font-size: 1.8rem; margin: 3rem 0 1.5rem;}
            
            /* company */
            .company01-obj{ display: none;}
            .company01-bx .tx01{ font-size: 2rem;}
            .company01-bx .tx02{ font-size: 1.3rem; padding-bottom: 6rem; background-size: 21rem auto;}
            .company01-bx .tx02 .tx02-01{ margin-bottom: 2.5rem; font-size: 1.4rem;}
            .company01-bx .tx02 .tx02-01 .tit{font-size: 1.4rem;}
            .company01-bx .tx02 .tx02-01 b{ font-size: 3rem;}
            .company01-bx .tx03{ padding: 9vw 4vw 0; height:173vw; background: #0f112a url(../images/company01_img_inf_mob.jpg) no-repeat 0 100% / 100% auto;}
            .company01-bx .tx03 .tit{ font-size: 1.4rem;}
            .company01-bx .tx03 .tit b{ font-size: 3rem;}
            .company01-bx .tx03 > ul{ font-size: 1.3rem; margin-top: 8vw;}
			.company01-bx .tx03 > ul > li{ padding: 5vw 3vw 5vw 0; }
			.company01-bx .tx03 > ul > li:nth-child(3){ max-width:none;}
            .company01-bx .tx03 > ul > li strong{ width: 9rem;}
            .company01-bx .tx03 > ul > li ul li{ text-indent: -1rem; padding-left: 1rem;}
            .company01-bx .tx03 > ul > li ul li::before{ width: .3rem; height: .3rem; margin-right: .5rem;}

            .company02-bx .tx01{ font-size:1.4rem; gap:2.4rem; padding-bottom: 5rem;}
            .company02-bx .tx01 b{ font-size: 2.5rem;}
            .history-con .itm{ margin-top: -10rem; padding: 10rem 0 ;}
            .history-con .itm .history-hd .img{ height: 12rem;}
            .history-con .itm .history-hd .img img{ height: 12rem; width: calc(100% + 4vw);}
            .history-con .itm .history-hd .desc{ margin-top: 2.5rem; font-size: 1.2rem; gap:.5rem;}
            .history-con .itm .history-hd .desc .tit{ font-size: 3rem;}
            .history-con .itm .history-bd{ margin-top: 5rem;}
            .history-con .itm .history-bd > ul{ padding: 2.2rem 0;}
            .history-con .itm .history-bd > ul > li{ font-size: 1.4rem;}
            .history-con .itm .history-bd > ul > li .y{ width: 7.5rem;}
            .history-tab.fixed{ top: 4rem; padding: 0;}
            .history-tab .inner{ gap:0;}
            .history-tab .itm{ font-size: 1.1rem; gap:0; padding: 1.5rem 0;}
            .history-tab .itm b{ font-size:1.2rem;}
            .history-tab .itm::after{ bottom: .5rem; height: .2rem;}
            .history-tab .itm.active::after{ width: 70%; left: 15%;}

            .company05-bx .tx01{ font-size: 2rem; padding-bottom: 2.5rem;}
            .ci-bx1{ margin-top: 2.5rem;}
            .ci-bx1 .tit{ font-size: 1.6rem; margin-bottom: 1.4rem;}
            .ci-bx1 .desc{ margin-top: 2.5rem; font-size: 1.6rem;}
            .ci-bx1 .ci-vis{ width: calc(100% + 8vw); margin: 3rem -4vw 0;}
            .ci-bx1 .ci-vis img{ height: 125vw;}
            .ci-bx1 .ci-vis .txt{ padding: 2.5rem 4vw; font-size: 1.6rem;}
            .ci-thumb > li > b{ font-size: 1.3rem; margin-bottom: .5rem;}
            .ci-thumb{ gap:1rem;}
            .ci-thumb.verical{ gap:2rem;}
            .ci-bx3 p{ font-size: 1.7rem; margin-top: 2rem;}
            .ci-bx5 p{ font-size: 1.7rem; margin-bottom: 2rem;}
            .ci-thumb2 > li{ width: 21vw;}
            .ci-thumb2 .txt b{ font-size: 1.6rem; line-height: 1.1;}
            .ci-thumb2 .txt{ margin-top: .6rem; gap:.5rem; font-size: 1rem;}

            .company03-bx .tx01{ font-size: 2rem;}
            .partners-lst,
            .partners-lst.n3{ gap: 3rem 1.8rem}
            .partners-lst .itm,
            .partners-lst.n3 .itm{ width: calc(50% - .9rem);}
            .partners-lst .itm .img,
            .partners-lst.n3 .itm .img{ height: 7rem;}
            .partners-lst .itm .txt,
            .partners-lst.n3 .itm .txt{ font-size: 1.4rem; padding: 1rem;}
            .partners-lst.n3 .itm .txt ul{ font-size: 1.3rem;}

            .company04-bx .tx01{ font-size: 2rem; padding-bottom: 3rem;}
            .cert-list,
            .cert-list.n3,
            .cert-list.n03,
            .cert-list.n4{ flex-wrap: wrap; gap: 3rem 1.8rem; margin-top:4rem;}
            .cert-list .itm,
            .cert-list.n3 .itm,
            .cert-list.n03 .itm,
            .cert-list.n4 .itm{ width: calc(50% - .9rem); flex: none; max-width: none;}
            .cert-list .itm .txt{ font-size: 1.4rem; margin-top: 1rem; padding: 0 .4rem;}
			
            .modalPop .inner{ width: 30rem; height: 42rem;}
            .modalPop .pop-close{ width: 3rem; height: 3rem; top:0; right: 0;}
            .modalPop #imgModalImg{ height: 42rem;}

            .fin-state{ padding: 2rem; flex-direction: column;}
            .fin-state .tx{ padding: 0; gap:2rem;}
            .fin-state .tx b{ font-size: 1.8rem;}
            .fin-state .tx span{ display: none;}
            .fin-state .sc-bx{ display: flex; flex-direction: column; align-items: center; gap:1rem 0;}
            .fin-state .sc-bx span{ display: block;}
            .fin-tbl > .hd{ padding: 1rem 0;}
            .fin-tbl .row-itm{ padding: 1rem 0;}
            .fin-tbl .tbl-bt{ margin-top: 1rem;}
            .fin-tbl .tbl-bt img{ height: 1.4rem;}
            .fin-inf{ padding: 3rem 0; margin: 4rem -4vw -6rem; width: calc(100% + 8vw); left: 0; transform: translateX(0);}
            .fin-inf .inner{ padding: 0 4vw; flex-direction: column; align-items: flex-start;}
            .fin-inf p{ font-size: 1.6rem;}
            .fin-inf .fin-l{ width: 100%;}
            .fin-inf .fin-l .bt{ width: 100%; height: 4.8rem; padding: 0 2rem; font-size: 1.5rem;  margin-top: 1rem;}
            .fin-inf .fin-l .bt::after{ width: 1.4rem; height: 1.4rem;}
            .fin-inf .fin-r{ margin-top: 3rem;}
            .fin-inf .fin-r img{ height: 3rem;}

            .map-bx dt iframe{ height:25rem;}
            .map-bx dd{ margin-top: 2.5rem;}
            .map-bx dd .addr{ font-size:1.8rem; margin-bottom: 2.5rem;}
            .map-bx dd > ul{ font-size:1.5rem;}
            .map-bx dd > ul > li + li{ margin-top: 1rem;}
            .map-bx dd > ul > li b{ width:7.5rem;}
            .contact-bx .tit{ font-size:1.8rem;}
            .contact-bx-itm{ font-size:1.4rem;}
            .contact-bx-itm dt{ min-width:14rem; padding-right: 0;}
            .contact-bx-itm dt b{ width:2.2rem; height:2.2rem; font-size:1rem;}
            .contact-bx-itm .aw::after{ width: .4rem; height: .4rem;}
            .contact-bx-itm .aw{ margin: 0 .5rem;}
            .contact-bx-itm + .contact-bx-itm{ margin-top:1.2rem;}
            .contact-bx + .contact-bx{ margin-top:4.5rem;}
            .contact-bx-itm2{ font-size:1.4rem;}
            .contact-bx-itm2 h4{ font-size:1.5rem; margin:3rem 0 1rem;}
            .contact-tbl{ font-size:1.3rem;}
            .contact-tbl .tbl-hd{ padding: 1.3rem 0;}
            .contact-tbl .tbl-bd .td{ padding:1.5rem .5rem; font-size:1.25rem;}
            .contactPop-tx dt{ font-size: 1.5rem; gap:.5rem; margin-bottom: 2rem;}
            .contactPop-tx dt b{ font-size: 1.8rem;}
            .contactPop-tx dd{ height: calc(100vh - 14rem); }
            .contactPop-tx dd img{ width: 150vw; max-width: none;}
            
            /* recruit */
            .recruit-lg{ font-size: 2.2rem;}
            .recruit01-bx1 .desc{ padding: 0 4vw}
            .recruit01-bx1 .recruit-lg{ font-size: 2.2rem; margin-top: 2rem;}
            .recruit01-bx1 .img img{ height: auto;}
            .recruit01-bx1 .desc{ font-size: 1.1rem;}
            .recruit01-bx1 .tx-lg{ font-size: 3rem; margin: 2rem 0 0 0;}
            .recruit01-bx1 .img{ margin: 5rem 0 0 0;}
            .recruit01-bx2 .recruit-lg{ padding: 0; margin: 5rem 0 3rem; font-size: 2.2rem;}
            .recruit01-bx2 dl{ padding: 2rem 0 3rem; flex-direction: column;}
            .recruit01-bx2 dl dt{ width: 100%; font-size: 1.1rem;}
            .recruit01-bx2 dl dt strong{ font-size: 3rem;}
            .recruit01-bx2 dl dd{ padding: 3rem 0 0 0; font-size: 1.4rem;}
            .recruit01-bx2 dl ul li + li{ margin-top: 2rem;}
            .recruit01-bx2 dl ul li::before{ width: 1rem; height: .5rem; margin-bottom: 1rem;}
            .recruit02-bx1 .recruit-lg{ font-size: 2rem;}
            .recruit02-bx1 .img{ margin: 5rem 0 0;}
            .recruit02-bx1 .img img{ height: 20rem; width: 60rem; object-fit: cover; object-position: 60% 50%;}
            .recruit02-bx2{ margin: 5rem 0 0 0;}
            .recruit02-bx2-l p{ font-size: 1.2rem;}
            .recruit02-bx2-l .recruit-lg{ font-size: 3.2rem;}
            .recruit02-bx2-tx{ margin: 4rem 0 0 0; gap:1.4rem}
            .recruit02-bx2-tx .itm{ width: calc(50% - .7rem); padding: 1.8rem 1.4rem;}
            .recruit02-bx2-tx .itm h3{ font-size: 1.6rem; padding-right: 5.5rem;}
            .recruit02-bx2-tx .itm i{ width: 4rem; height: 4rem; top: 1rem; right: 1rem;}
            .recruit02-bx2-tx .itm ul{ margin: 2.4rem 0 0 0; font-size: 1.3rem;}
            .recruit02-bx2-tx .itm ul li + li{ margin-top: .5rem;}

            .recruitHd{ gap:.5rem;}
            .recruitHd .btn{ height: 4rem; line-height: 4rem; width: 7rem; padding: 0;}
            .recruitLst{ gap:1.5rem;}
            .recruitLst .recruitLst-itm{ padding: 3.5rem 2.5rem; width: 100%; height: 22rem;}
            .recruitLst .recruitLst-itm .tit{ font-size: 2rem;}

            .recruit-vew-desc{ margin: 3rem 0 0 0; padding: 2rem;}
            .recruit-vew-desc::after{ display: none;}
            .recruit-vew-desc .desc-hd{ padding: 0 0 2rem 0;}
            .recruit-vew-desc .desc-hd .logo img{ height: 2rem;}
            .recruit-vew-desc .desc-hd strong{ font-size: 2rem;}
            .recruit-vew-desc .desc-bd{ padding: 2rem 0 0 0;}
            .recruit-vew-bt{ margin: 3rem 0 0 0;}
            .recruit-vew-bt .btn{ padding: 0;}
            .recruit-vew-bt .btn.lg{ min-width: auto;}
            .recruit-vew-bt .btn::after{ margin-left: 1rem;}

            /* esg */
            .h3-tit{ font-size: 3rem; margin: 4rem 0 2rem;}

            .esg-lg{ font-size: 3rem;}
            .esg01-bx1{ margin: 4rem 0 0 0;}
            .esg01-bx1 .itm + .itm{ margin-top: 5rem;}
            .esg01-bx1 .itm .img{ width: 100%; margin: 0 0 2rem 0;}
            .esg01-bx1 .itm .desc h3::before{ width: 1rem; height: .5rem; margin-bottom: 1rem;}
            .esg01-bx1 .itm .desc h3{ font-size: 2rem;} 
            .esg01-bx1 .itm .desc ul{ margin: 2rem 0 0 0; font-size: 1.5rem;}
            .esg01-bx1 .itm .desc ul li{ flex-direction: column;}
            .esg02 .tx1{ font-size: 1.8rem;}
            .esg02 .tx2{ margin: 3rem 0 0 0; font-size: 1.4rem; padding: 2rem;}
            .esg02 .tx3{ margin: 3rem 0 0 0; font-size: 1.4rem;}
            .esg02 .tx3 li{ text-indent: -2rem; padding-left: 2rem;}
            .esg02 .tx3 li + li{ margin-top: .5rem;}
            .esg04-tx1{ font-size: 1.8rem; padding-bottom: 4rem;}
            .esg04-tx1::before{ width: 1rem; height: .5rem; margin-bottom: 1rem;}
            .esg04-tx2 .h4-tit{ font-size: 2rem; margin: 3rem 0 1rem;}
            .esg04-tx2{ font-size: 1.4rem;}
            .esg04 .div-tab{ margin: 4rem 0 1rem;}
            .div-tab .itm{ height: 4rem; font-size: 1.4rem;}
            .div-tab .itm i{ width: 1.4rem; height: 1.4rem; background-size: 1rem;}
            .esg04 .tblHd{ margin-top: 1rem;}
            .esg04 .form-wr .form-itm .inp-grp{ flex-wrap: wrap;}
            .esg04 .form-wr .form-itm .textarea{ height: 46rem;}
            .popEsg04 .tx1,
            .popEsg040 .tx1{ font-size: 1.7rem;}
            .popEsg04 .tx2{ padding: 2rem; margin: 3rem 0 0 0;}
            .popEsg04 .tx2 dt{ font-size: 1.5rem; margin: 2.5rem 0 0 0;}
            .popEsg04 .tx2 dd{ margin: 1rem 0 0 0;}
            .popEsg040 .tx2{ margin: 2.5rem 0 0 0; gap:2rem; font-size: 1.5rem; flex-direction: column;}
            .popEsg040 .tx2 > li i{ width: 5.5rem; margin: 0 auto;}
            .popEsg040 .tx2 > li strong{ font-size: 2.5rem; margin: 1.5rem 0 .4rem;}

            .esg03-tx1{ font-size: 2rem;}
            .esg03-tx1 .tit{ font-size: 2.2rem;}
            .esg03-tx2{ margin: 6rem 0 0 0; padding: 4rem 4vw;}
            .esg03-tx2::before,
            .esg03-tx2::after{ height: 2rem;}
            .esg03-tx2::before{ top: -2rem;}
            .esg03-tx2 ul{ font-size: 1.6rem;}
            .esg03-tx2 ul li{ padding: 2rem 0;}
            .esg03-tx2 ul li i{ width: 6rem; font-size: 1.8rem;}
            .esg03-tx3{ margin: 6rem 0 0 0; padding: 4rem 3rem; font-size: 1.4rem;}
            .esg03-tx3 .bg{ height: 2rem; background-size: auto 2rem;}
            .esg03-tx3 .bg::before, 
            .esg03-tx3 .bg::after{ width: 2rem; height: 2rem;}
            .esg03-tx3::before, 
            .esg03-tx3::after{ width: 2rem; background-size: 2rem auto;}
            .esg03-tx3 .tit{ font-size: 2.2rem; padding-bottom: 2rem;}
            .esg03-tx3 .tit2{ margin: 3rem 0 1.5rem; font-size: 1.8rem;}
            .esg03-tx301{ margin: 3rem 0 0 0; flex-direction: column;}
            .esg03-tx301 .txt{ padding: 0;}
            .esg03-tx301 .sign{ margin: 2rem 0 0 0; width: 10rem;}

            /* products */
            .products-list{ gap: 4rem 2rem;}
            .products-list .products-itm{ width: calc(50% - 1.5rem); }
            .products-list .products-itm .bx{ padding: 1.5rem 1.5rem 2rem;}
            .products-list .products-itm .procudts-bt{ margin: 1.4rem 0 0 0; flex-direction: column;}
            .products-list .products-itm .procudts-bt a{ width: 100%;}
			.products-list .products-itm .tit{ font-size: 1.3rem;}

            .products-hd .prev{ display: none;}
            .products-hd .img{ padding: 4rem 4vw; }
            .products-hd .img .s-img .itm img{ width:15vw; height: 15vw;}
            .products-hd .desc{ padding: 5.5rem 4vw 0;}
            .products-hd .desc .tit{ font-size: 3rem;}
            .products-hd .desc .desc-tx1 li{ font-size: 1.3rem; flex: auto; justify-content: space-between;}
            .products-hd .desc .desc-tx1 li b{ font-size:1.5rem;}
            .products-hd .desc .desc-tx2{ padding: 3rem 0 0;}
            .products-hd .desc .desc-tx2 .hd-tit{ font-size:1.6rem;}
            .products-hd .desc .desc-tx2 .hd-tit2{ margin: 2rem 0 1rem; font-size: 1.5rem;}
            .products-hd .desc .desc-tx2 ul{ font-size: 1.6rem;}
            .products-hd .desc .desc-tbl{ padding-bottom: 0;}
            .products-hd .desc .desc-tbl thead th, 
            .products-hd .desc .desc-tbl tbody td{ padding: 1rem 1.5rem; font-size: 1.4rem;}
            .products-hd .procudts-bt{ margin-top: 2.5rem;}
            .products-hd .procudts-bt a{ height: 4.2rem; font-size: 1.3rem; padding: 0 1.4rem;}
            .products-hd .procudts-bt a::after{ width: 1.4rem; height: 1.4rem;}
            .products-bd{ margin: 0; padding: 6rem 4vw 5rem;}
            .products-bd + .products-bd{ padding: 6rem 4vw 5rem;}
            .products-bd .tit{ font-size: 2.5rem; margin-bottom: 2.5rem;}
            .products-bd .tit::before{ width: 1rem; height: .5rem; margin-bottom: 1rem;}
            .prod-app{ gap:1.4rem;}
            .prod-app .itm{ padding: 1.2rem 1rem 2rem; width: calc(33.3% - 1rem); font-size: 1.3rem; gap:1rem;}
            .prod-app .itm i{ width: 4rem;}
            .prod-features{ font-size: 1.3rem;}
            .prod-features .tit2{ font-size: 1.7rem; margin: 1.5rem 0;}
            .prod-doc .itm{ padding: 1.5rem; font-size: 1.3rem; text-align: left;}
            .prod-doc .itm i{ width: 1.3rem; margin-right: 1.5rem;}
            .products-bottom{ padding: 5rem 4vw;}
            .products-bottom .tit{ font-size: 2.4rem;}
            .products-bottom a{ height: 4.7rem; font-size: 1.4rem; padding: 0 2rem;}
            .products-hd + .products-bottom{ margin-top: 4rem;}
            .prod-material{ font-size: 1.4rem;}
            
            .products04-bx{ padding: 0;}
            .products04-bx .tx01{ font-size: 2rem; padding: 0 0 3rem;}
            .products04-bx .tx02 p{ font-size: 1.6rem; padding-bottom: 2rem;}
            .products04-bx .tx02 .img{ margin: 0 -4vw;}
            .products04-vis{ margin: 4rem -4vw 0; width: calc(100% + 8vw); padding: 1.5rem 4vw; font-size: 2.4rem;}
            .product04-tbl .row-bd .row-itm{ font-size: 1.4rem; border-bottom: none;}
            .product04-tbl .row-bd .row-itm + .row-itm{ margin-top: 1.5rem;}
            .product04-tbl .row-bd .row-itm:last-child{ border-bottom: #000 1px solid;}
            .product04-tbl .row-bd .row-itm .th{ font-size: 1.5rem; padding: .8rem;}
            .product04-tbl .row-bd .row-itm .td{ padding: 1.5rem 2.5rem; width: 100%; flex: none;}
            .product04-tbl .row-bd .row-itm .td + .td{ border:none; border-top:#000 1px solid;}
            .product04-tbl .tx-th{ margin-bottom: 1rem;}
            .products04-bottom{ width: calc(100% + 8vw); margin: 5.5rem -4vw -6rem; padding: 5rem 4vw;}
            .products04-bottom .tit{ font-size: 2.5rem;}
            .products04-bottom .btz{ margin-top: 2rem; flex-direction: column; gap:1rem}
            .products04-bottom .btz a{ width: 100%; height: 4.8rem; padding: 0 2.5rem; font-size: 1.6rem;}
            .products04-bottom .btz a span{ margin-left: 1.5rem; padding-left: 1.5rem;}
            .products04-bottom .btz a::after{ width: 2rem; height: 2rem;}
            .products04-bx.products0402 .tx02 .img{ width: 100%; padding: 0 4vw; margin: 0;}

			.prod-tx{ margin-top:5rem; padding:1rem;}
			.prod-tx + .products-bottom{ margin-top:3rem;}

            /* search */
            .search-wr,
            .privacy-wr{ margin: 4rem 0; padding: 0 4vw;}
            .search-bx{ margin-bottom: 4rem;}
            .search-bx .search-inp .inp{ height: 5rem; font-size: 2.4rem;}
            .search-bx .search-inp .inp::placeholder{ font-size: 2rem;}
            .search-bx .sch{ width: 3rem; height: 3rem; background-size: 2.4rem;}
            .search-bx .input-wrapper .clear-btn{ right: 4rem;}
            .search-wr .search-keywords{ margin-top: 1rem; font-size: 1.5rem;}
            .search-list .itm{ padding: 1.5rem 0; font-size: 1.4rem;}
            .search-list.news .itm .tit{ width: 6rem;}

            .privacy-bx{ font-size:1.4rem;}
            .privacy-bx .privacy-tx01{ font-size: 1.5rem; padding-bottom: 3rem;}
            .privacy-bx .privacy-tx02{ font-size: 1.5rem;}
            .privacy-bx .privacy-tx03{ font-size: 1.3rem;}
            .privacy-bx .privacy-tx02 + ul{ margin-top: 1.5rem;}
            .tbl-privacy{ margin-top: 1.5rem;}
            .tbl-privacy thead th{ font-size: 1.3rem; padding: 1rem;}
            .tbl-privacy tbody td{ font-size: 1.3rem; padding: 1rem;}
            .tbl-privacy tbody td p{ font-size: .875em;}
            .privacy-bx ul + .privacy-tx03{ margin-top: 1.5em;}
            
          }/* /480px */

        }/* /768px */

      }/* /768px */

    } /* /1024px */

  } /* /1280px */

} /* /1600px */

@media screen and (max-width:1024px) and (min-width:821px){
  .mainSolution .solutionItm span br{ display: none; }
  
  footer .footerAddr{ display: flex; gap:30px;}
  footer .footerAddr .office,
  footer .footerAddr .contact{ flex: 1; margin-top: 0;}
  footer .footerCopy .copyTxt br{ display: none;}

  .locationBar > .inner > div:nth-child(2){ border-left: #d3d3d3 1px solid;}
}

@media screen and (min-width:1024px) and (max-height: 700px) {
  .main-pop{ max-width: 50vh; width: auto;}
  .modalPop .inner{ top: 0; transform: translateY(0);}
}