@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400..700;1,400..700&family=Noto+Sans+KR:wght@100..900&display=swap');
@import url('https://cdn.jsdelivr.net/gh/xpressengine/xeicon@2.3.3/xeicon.min.css');
@import url('default.css');
@import url('aos.css');
@import url('swiper.min.css');

@font-face {
	font-family: 'Pretendard';
	src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraLight.woff') format('woff');
	font-weight: 200;
	font-style: normal;
  }

@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
}


@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
}


@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Bold.woff') format('woff');
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraBold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: 'Pretendard';
  src: url('https://cdn.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Black.woff') format('woff');
  font-weight: 900;
  font-style: normal;
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 100;
    src: local('Noto Sans Thin'), local('NotoSans-Thin'),
    url(../fonts/NotoSansKR-Thin-Hestia.eot),
    url(../fonts/NotoSansKR-Thin-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Thin-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Thin-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 200;
    src: local('Noto Sans Light'), local('NotoSans-Light'),
    url(../fonts/NotoSansKR-Light-Hestia.eot),
    url(../fonts/NotoSansKR-Light-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Light-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Light-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 300;
    src: local('Noto Sans DemiLight'), local('NotoSans-DemiLight'),
    url(../fonts/NotoSansKR-DemiLight-Hestia.eot),
    url(../fonts/NotoSansKR-DemiLight-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-DemiLight-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-DemiLight-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 400;
    src: local('Noto Sans Regular'), local('NotoSans-Regular'),
    url(../fonts/NotoSansKR-Regular-Hestia.eot),
    url(../fonts/NotoSansKR-Regular-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Regular-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Regular-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 600;
    src: local('Noto Sans Medium'), local('NotoSans-Medium'),
    url(../fonts/NotoSansKR-Medium-Hestia.eot),
    url(../fonts/NotoSansKR-Medium-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Medium-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Medium-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 700;
    src: local('Noto Sans Bold'), local('NotoSans-Bold'),
    url(../fonts/NotoSansKR-Bold-Hestia.eot),
    url(../fonts/NotoSansKR-Bold-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Bold-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Bold-Hestia.otf) format('opentype');
}

@font-face {
    font-family: 'noto';
    font-style: normal;
    font-weight: 900;
    src: local('Noto Sans Black'), local('NotoSans-Black'),
    url(../fonts/NotoSansKR-Black-Hestia.eot),
    url(../fonts/NotoSansKR-Black-Hestia.eot?#iefix) format('embedded-opentype'),
    url(../fonts/NotoSansKR-Black-Hestia.woff) format('woff'),
    url(../fonts/NotoSansKR-Black-Hestia.otf) format('opentype');
}

@font-face{
  font-family: 'nq';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/NanumSquareL.eot'); 
  src: local('※'), url('../fonts/NanumSquareL.woff') format('woff'), url('../fonts/NanumSquareL.ttf') format('truetype'); 
}  
@font-face{
  font-family: 'nq';
  font-style: normal;
  font-weight: normal;
  src: url('../fonts/NanumSquareR.eot'); 
  src: local('※'), url('../fonts/NanumSquareR.woff') format('woff'), url('../fonts/NanumSquareR.ttf') format('truetype'); 
} 
@font-face{
  font-family: 'nq';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/NanumSquareB.eot'); 
  src: local('※'), url('../fonts/NanumSquareB.woff') format('woff'), url('../fonts/NanumSquareB.ttf') format('truetype'); 
} 
@font-face{
  font-family: 'nq';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/NanumSquareEB.eot'); 
  src: local('※'), url('../fonts/NanumSquareEB.woff') format('woff'), url('../fonts/NanumSquareEB.ttf') format('truetype'); 
} 

/**************************************************************************************************************
	공통
**************************************************************************************************************/
:root { 
    --blue:#7D83FF;
    --mainPd:260px;
    --en: 'Instrument Sans';
    --kr: 'Pretendard';
}
.m0 { margin:0  !important }
.mb0 { margin-bottom:0 !important }
.mb2 { margin-bottom:2px !important }
.mb4 { margin-bottom:4px !important }
.mb5 { margin-bottom:5px !important }
.mb6 { margin-bottom:6px !important }
.mb10 { margin-bottom:10px !important }
.mb15 { margin-bottom:15px !important }
.mb20 { margin-bottom:20px !important }
.mb25 { margin-bottom:25px !important }
.mb30 { margin-bottom:30px !important }
.mb35 { margin-bottom:35px !important }
.mb40 { margin-bottom:40px !important }
.mb45 { margin-bottom:45px !important }
.mb50 { margin-bottom:50px !important }
.mb55 { margin-bottom:55px !important }
.mb60 { margin-bottom:60px !important }
.mb70 { margin-bottom:70px !important }
.mb80 { margin-bottom:80px !important }
.mb90 { margin-bottom:90px !important }
.mb110 { margin-bottom:110px !important }
.mb140 { margin-bottom:140px !important }
.pd0 { padding:0 !important }
.mbr10 { margin-right:10px }
.pdl50 { padding-left:50px !important }
.pdtop90 { padding-top:90px }
.none-bor { border:0 !important }
.text-center { text-align:center !important }
.text-left { text-align:left !important }
.text-right { text-align:right !important }
.f12 { font-size:1.2rem !important; line-height: 1.4em; }
.f16 { font-size:1.6rem !important; line-height: 1.4em; }
.f17 { font-size:1.7rem !important; line-height: 1.4em; }
.f18 { font-size:1.8rem !important; line-height: 1.4em; }
.f19 { font-size:1.9rem !important; line-height: 1.4em; }
.f20 { font-size:2rem !important; line-height: 1.4em; }
.f24 { font-size:2.4rem !important; line-height: 1.4em; }
.f25 { font-size:2.5rem !important; line-height: 1.4em; }
.f29 { font-size:2.9rem !important; line-height: 1.4em; }
.f31 { font-size:3.1rem !important; line-height: 1.4em; }
.f34 { font-size:3.4rem !important; line-height: 1.4em; }

.lh34 { line-height: 34px !important; }
.lh44 { line-height: 44px !important; }
.clear:after { display: block; content: ''; clear: both; }
.fl { float:left; }
.fr { float:right; }

/***********************************************************************************
	Common
************************************************************************************/



html { font-size:10px; } 
body { font-size:1.2rem; }


html,body,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,address,big,cite,code,del,dfn,em,font,img,ins,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,ul,ol,li,dl,dt,dd,table,caption,tbody,tfoot,thead,tr,th,td,fieldset,fo7m,label,legend,input,button,textarea,select{margin:0;padding:0}
header,footer,section,article,aside,nav,hgroup,details,menu,figure,figcaption{display:block;margin:0;padding:0}
legend{display:block;overflow:hidden;position:absolute;width:1px;height:1px;font-size:1px;line-height:0;text-indent:-999em;white-space:nowrap; }
fieldset,img,table,caption,tbody,tfoot,thead,tr,th,td,button,hr{border:0 none}
img{vertical-align:middle}
body li{*vertical-align:top}
ul li{list-style:none; padding:0; margin:0;}
table{border-collapse:collapse}
th { background: #eee;}
caption{visibility:hidden;overflow:hidden;width:0;height:0;font-size:0;line-height:0;}
button{overflow:visible;border:0 none;cursor:pointer}
button::-moz-focus-inner,input[type="button"]::-moz-focus-inner,input[type="submit"]::-moz-focus-inner,input[type="reset"]::-moz-focus-inner {padding: 0;border: 0 none}
a { text-decoration:none; color:#000;  }
address,
em { font-style:normal }
body,input,select,textarea,button,h1,h2,h3,h4,h5,h6 { font-family:var(--en),'Pretendard',  sans-serif; color: #000;}
body,textarea,input,select { font-family:var(--en),'Pretendard', sans-serif;  color: #000; text-decoration: none; } 
textarea,.inp,select { border:0; outline:none; border-radius:0; resize:none; box-shadow:none; -webkit-appearance:none; appearance:none; font-weight: normal;}
a:hover { text-decoration: none;}
body { -webkit-text-size-adjust: none; background:none; }
form { padding: 0; margin: 0; }
* {box-sizing: border-box; -webkit-box-sizing:border-box;}
::-ms-clear { display: none;}
select::-ms-expand { display:none; }
.inner { max-width:1440px; margin: 0 auto; padding:0 20px; }
.inner1280 { max-width:1320px; margin: 0 auto; padding:0 20px; }
.inner1600 { max-width:1640px; margin: 0 auto; padding:0 20px; }

/* Form */
.select  { vertical-align:middle;  height: 52px;  border-radius:8px; border: 1px solid #E0E0E0; padding:0 50px 0 16px; font-size:1.6rem; color: #202020; background: #fff url(../img/common/bu_select.svg) no-repeat 90% 50%; background-position:right 15px center;}
.inp { vertical-align:middle; padding:0 0 0 16px; height:52px; border-radius:8px; background:#fff; border:1px solid #E0E0E0; font-size:1.6rem; color:#202020; }
#wr_content { padding:15px 10px; height:300px; background:#fff; border:1px solid #ccc; font-size:1.7rem; line-height:1.6; color:#444; border-radius:0;box-shadow:none; border-radius:8px;}
#wr_content.textarea { vertical-align:middle; padding:12px 16px; height:52px; border-radius:8px; background:#fff; border:1px solid #E0E0E0; font-size:1.6rem; color:#202020; }
.w100 { width:100%; }


.btn1 { display: inline-flex; gap:4px; align-items: center; vertical-align: middle; padding:0 23px; height: 58px; line-height: 55px; text-align: center; border:1px solid #000; font-size:2rem; color: #fff; border-radius:55px; font-weight:700; background-color: #000; transition:all 0.3s ease;}
.btn1:hover { background:#fff; color:#000;  }
.btn1:hover img { content: url("/img/common/ico_list_black.svg"); display:inline-block; width:24px; }


.btn2 { display: inline-block; vertical-align: middle; padding:0 23px; height: 58px; line-height: 57px; text-align: center; border:0; border-radius:8px; font-size:2rem; color: #fff; font-weight:700; background-color: #000;transition:all 0.3s ease;}
.btn3 { display: inline-block; vertical-align: middle; padding:0 23px; height: 58px; line-height: 57px; text-align: center; border:0; border-radius:8px; font-size:2rem; color: #fff; font-weight:700; background-color: #BBBBBB;transition:all 0.3s ease;}
.btns { display: flex; gap:7px; }
.btns > a,
.btns > button,
.btns > input { width:100%; }

.btn-type0 { display: inline-block; vertical-align: middle; min-width:180px; height: 60px; line-height: 59px; font-size:2rem; color: #fff; background: #000000; text-align: center; font-weight:200 }
.btn-type1 { display: inline-block; vertical-align: middle; min-width:180px; height: 60px; line-height: 59px; font-size:2rem; color: #fff; background: #cccccc; text-align: center; font-weight:200 }



.checkbox { position: absolute;  display: none; }
.checkbox + div { display: flex; align-items: center; }
.checkbox + div em { display: inline-block; vertical-align: middle; width:24px; height: 24px; border: 1px solid #E0E0E0; border-radius:8px; background:#fff; position: relative; margin:0 7px 0 0; transition:all 0.4s ease;}
.checkbox + div em:before { content: ''; position: absolute;left: 0; top:0; right:0; bottom:0; background: url(../img/common/checkbox.svg) no-repeat 50% 50%;  transition:all 0.4s ease;}
.checkbox + div p { display: inline-block; vertical-align: middle; font-size:1.6rem; }
.checkbox:checked + div em { background-color: var(--blue);; }
.checkbox:checked + div em:before { opacity:1; }



/*
#bo_sch .inp { height:50px; border:0; border-bottom:1px solid #1eb9ee; width:280px; }
#bo_sch .inp:focus { box-shadow:none; border:0 !important; border-bottom:1px solid #1eb9ee !important;outline:none;  }
*/

::-webkit-input-placeholder { color: #888;}
:-moz-placeholder { color: #888;}
:-ms-input-placeholder {  color: #888;}
:-moz-placeholder {  color: #888;}

a,a:active,a:visited { text-decoration:none !important; }
p,div { word-break:keep-all; }
img { max-width:100%; }



/*********************************************************************************************************************************************************************
	Common
*********************************************************************************************************************************************************************/
#s-header { position: fixed; left: 0; right:0; top:0; height:80px; z-index:1000; }
.main #s-header { position: fixed; }
#s-header .bg-menu { position: absolute; left: 0; right:0; top:0; height:400px; display:none; background: #fff;  border-bottom:2px solid var(--blue); }
#s-header .header-inner { max-width:1440px; padding:0 20px; margin:0 auto; position: relative;z-index:2;}
#s-header h1 { position: absolute; left: 20; top:0; height: 100%; display: flex; align-items: center; }
#s-header h1 a { display: block; background: url(../img/common/logo.svg) no-repeat 0 0; width:135px; height:48px; text-indent: -9999px;}
#s-header .lang { position: absolute; right:20px; top:50%; transform: translateY(-50%);z-index:3; }
#s-header .lang .btn-lang { font-size:1.6rem;; padding-right:16px; display: inline-block; vertical-align: middle; background: url(../img/common/ico_top_arr_gray.svg) no-repeat right 50%; }
#s-header .lang ul { visibility: hidden; opacity: 0;; transition: all 0.5s ease; position: absolute; left: 0; top:100%; width:150px; background-color: #fff; border-radius:4px; border:1px solid #e0e0e0; padding:0 8px; }
#s-header .lang ul li + li { border-top:1px solid #e0e0e0; }
#s-header .lang ul a { display: block; text-align: center; line-height: 48px; font-size:1.6rem;; color:#000; }
#s-header .lang:hover ul { visibility: visible; opacity: 1; }

#s-header .btn-m { display: none;}

#s-gnb{ display: flex; justify-content: center; }
#s-gnb > ul:after { display: block; content: ''; clear: both; }
#s-gnb > ul > li {float:left; position: relative;width:186px;   transition: all 0.5s ease;}
#s-gnb .btn-dep1 { display: block; height:80px; line-height: 80px; font-size:1.8rem;  padding: 0; position: relative ;font-weight:500;}
#s-gnb .btn-dep1:before { content:''; position: absolute; left: 25px; right:25px; bottom:0; height:0; background: #fff; opacity:0; transition: all 0.3s ease; -webkit-transition: all 0.3s ease; }

#s-gnb > ul > li:hover .btn-dep1,
#s-gnb > ul > li .btn-dep2:hover { color:var(--blue) !important}

#s-gnb .dep2 { display: none; position: absolute; left: 0; right:0; top:80px; height: 250px; padding-top:20px; z-index:10;   }
#s-gnb .btn-dep2 { display: block; font-size:1.6rem;; line-height: 38px;  font-weight: 400; white-space: nowrap; transition:all 0.3s ease; -webkit-transition:all 0.3s ease; }
#s-gnb .btn-dep2 strong { font-family:var(--en);}

#s-gnb .btn-dep2:hover { color: #009fe3;  }


.main #s-gnb .btn-dep1 { color:#fff; }
.main #s-header .lang .btn-lang { color:#fff; }
.main #s-header h1 a { background-image: url(../img/common/logo_white.svg);}
.main #s-header .lang .btn-lang { background-image: url(../img/common/ico_top_arr.svg);}
#s-header { transition:all 0.3s ease; -webkit-transition:all 0.3s ease; }
#s-header .etc .lang { border-color:#fff; background-image:url(../img/common/bu_arr_lang_main.png);  }
#s-header.active h1 a { background-image:url(../img/common/logo.svg); }
#s-gnb .btn-dep1,
#s-header .etc .btn-link,
#s-header .etc .lang .btn-lang,
#s-header .etc .lang ul li a { color:#000; transition:all 0.3s ease; -webkit-transition:all 0.3s ease; }
#s-header .etc .btn-all span { background:#fff; transition:all 0.3s ease; -webkit-transition:all 0.3s ease; }
/* #s-header.active { background:#fff; } */
#s-header.active #s-gnb .btn-dep1 { color:#000; }
#s-header.active .etc .btn-link,
#s-header.active .etc .btn-all span { background-color: #0077ed;  }
#s-header.active.sub { transform: translateY(-110%);}
#s-header.active .lang .btn-lang { color:#000; background-image: url(../img/common/ico_top_arr_gray.svg);}



.m-gnb { display: none; position: fixed; left: 0; right:0; top:0; bottom:0; background: #fff; z-index:2000;  }
.m-gnb .head { display: flex; align-items: center; height: 55px; position: relative; padding-left: 20px; ;}
.m-gnb .head .logo { display: block; width:130px; height: 32px; background:url(../img/common/logo.svg) no-repeat 0 0 ; background-size: auto 30px; ;}
.m-gnb .head .btn-close { position: absolute; right:0; top:0; width:55px; height: 55px; background: url(../img/common/ico_gnb_close.svg) no-repeat 50% 50%;  z-index:2; }
.m-gnb .lang { display: flex; justify-content: flex-end; align-items: center; height: 80px; padding-right:20px; }
.m-gnb .lang img { margin-right:6px;}
.m-gnb .lang a { font-size:14px; }
.m-gnb .lang a + a:before {content: '|'; display: inline; margin:0 5px; color:#ccc;}
.m-gnb .scroll { overflow: auto; position: absolute; left: 0; right:0; bottom:0; top:135px; padding:20px 0;}
.m-gnb .scroll > ul > li { margin-bottom:10px;}
.m-gnb .dep2 { display: none; padding-top:10px;}
.m-gnb .btn-dep1 { display: block; font-size:18px; line-height: 50px; padding-left: 20px; position: relative; font-weight:700;}
.m-gnb .btn-dep1.flip:before { content: ''; position: absolute; right:10px; top:10px; width:30px; height: 30px; background: url(../img/common/ico_gnb.svg) no-repeat 50% 50%; transform: rotate(180deg); transition: all 0.5s ease;}
.m-gnb .btn-dep2 { display: block; font-size:14px;  line-height: 30px; padding-left: 20px;} 
.m-gnb li.active .btn-dep1:before { transform: unset;}




/*********************************************************************************************************************************************************************
	Main
*********************************************************************************************************************************************************************/
.hidden { overflow: hidden; } /* 애니메이션 하단 잘리는 효과 적용 */

body,html { height: 100%; }
.container {  padding-bottom: 200px; overflow: hidden;}

#wrap.main { background-color: #000; padding-bottom:1px;}
.main1 { position: relative;}
.main1 .swiper-slide { height: 100vh; position: relative; }
.main1 .swiper-slide video {  position: absolute; left:0;top:0; right:0; bottom:0; width:100%; height: 100%; object-fit: cover; z-index:1;}
.main1 .txt-box:before { content: ''; position: absolute; left: 0; right:0; top:0; bottom:0; background-color: rgba(0,0,0,0.2); z-index:2;}
.main1 .txt-box1 { position: absolute; left: 0; right:0; top:50%;  text-align: center; font-size:4.8rem; font-weight:700; line-height: 1.4; color:#fff; z-index:3; transform: translateY(-30%); opacity:0; transition: all 1s ease 0.5s;}
.main1 .txt-box1 .t1 { font-size:10rem; font-weight:600; margin-bottom: 10px;}
.main1 .swiper-slide video {clip-path: inset(100% 0 0 0); transition: clip-path 0.5s ease-in-out;}
.main1 .swiper-slide-active video {   clip-path: inset(0 0 0 0); }
.main1 .swiper-slide-active .txt-box1 { transform: translateY(-50%); opacity:1;}
.main1 .slide8 .txt-box1 { transform: 0;}
/*.main1 .slide8.swiper-slide-active .txt-box1 { transform: unset; top:65%; }*/
.main1 .controls { position: absolute; left: 0; right:0; bottom:20px; display: flex; justify-content: center; gap:20px; z-index:3;}
.main1 .controls button { background: none; display: none;}
.main1 .controls button.active { display: block;}
.main1 .controls button img { width:86px;}


.main2 { margin:var(--mainPd) 0;  }
.main2 .title { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 30px;}
.main2 .title h2 { font-size:8rem; font-weight:700; color:#fff; font-family: var(--en); line-height: 1; ; }
.main2 .controls { display: flex; gap:55px; }
.main2 .controls a { font-size:2.8rem; font-weight:700; color:#fff; padding-bottom: 5px; position: relative;;}
.main2 .controls a:before { content: ''; position: absolute; left: 0; bottom:0; width:0; height: 3px; background-color: var(--blue); opacity: 0; transition: all 0.5s ease;}
.main2 .controls a.active { color:var(--blue); }
.main2 .controls a.active:before { width:100%; opacity: 1;}
.main2 .swiper-slide .item { display: flex; gap:24px; }
.main2 .swiper-slide .item .img { flex:1; border-radius:24px; overflow: hidden;}
.main2 .swiper-slide .item .text { width:28.57%; border-radius:24px; background-color: #262626; padding: 36px; color:#fff; display: flex; flex-direction: column; justify-content: space-between; transition: all 0.5s ease;}
.main2 .swiper-slide .item .text .num { font-size:6.4rem; font-weight:700; position: relative; line-height: 1;}
.main2 .swiper-slide .item .text .num:before { content: ''; position: absolute; right:0; top:10px; background: url(../img/main/ico_biz.svg) no-repeat 50% 50%; width:42px; height: 42px; background-size: contain; transition: all 0.4s ease;}
.main2 .swiper-slide .item .text .t1 { font-size:2.8rem; font-weight:700;line-height: 1; margin-bottom: 10px;}
.main2 .swiper-slide .item .text .t2 { font-size:5.6rem; font-weight:700; line-height: 1;;}
.main2 .swiper-slide .item .text .t3 { font-size:2rem; margin-top:24px; letter-spacing: -1px;}
.main2 .swiper-slide .item:hover .text { background-color: #111;}
.main2 .swiper-slide .item:hover .text .num:before { right:-10px; top:0; }

.main3 { margin-bottom: var(--mainPd);}
.main3 h3 { font-size:6.4rem; font-weight:700; line-height: 1.3; margin-bottom: 48px; color:#fff; }
.main3 ul { display: flex; gap:37px; }
.main3 ul li { flex:1; }
.main3 ul li .item { display:flex; flex-direction: column; align-items: flex-end; height: 100%; padding: 36px;  border-radius:24px; background-color: #262626; color:#fff; position: relative; transition: all 0.5s ease;}
.main3 ul li .item i { display: block; text-align: right; width:100%; margin-bottom: 50px;}
.main3 ul li .item dl { width:100%; }
.main3 ul li .item dl dt { font-size:2.4rem; margin-bottom: 8px; display: flex; align-items: center; gap:6px; }
.main3 ul li .item dl dd { font-size:1.8rem; line-height: 1.5; ;}
.main3 ul li .item:hover { transform: translateY(-20px);}


#s-footer{  padding: 95px 0 ; border-top:1px solid #e8e8e8;}
#s-footer .inner { position: relative; }
#s-footer .etc { display: flex; justify-content: space-between; margin-bottom: 48px;align-items: center;}
#s-footer .etc .logo { background: url(../img/common/logo.svg) no-repeat 0 0; background-size: contain; width:135px; height: 48px;}
#s-footer .etc .menu a { font-size:2rem;;  font-weight:700; }
#s-footer .addr { display: flex; flex-wrap: wrap; gap:12px 48px; margin-bottom: 8px;; }
#s-footer .addr dl { display: flex; align-items: center;  font-size:1.6rem;; }
#s-footer .addr dl dt { opacity:0.8;position: relative; }
#s-footer .addr dl dt:after { content: '|'; display: inline; margin:0 5px; opacity:0.4; }
#s-footer .copy { font-size:1.6rem;; opacity:0.8; margin-top:24px;}

.main #s-footer { border-top:0;}
.main #s-footer .etc .logo { background-image: url(../img/common/logo_white.svg); }
.main #s-footer .etc .menu a { color:#fff; }
.main #s-footer .addr dl { color:#fff; }
.main #s-footer .copy { color:#fff; }

/*********************************************************************************************************************************************************************
	Sub
*********************************************************************************************************************************************************************/
.sub-head { min-height:500px; padding-top:170px;  margin-bottom: 120px; overflow: hidden;}
.sub-head.type2 { min-height:inherit; margin-bottom:0;}
.sub-head h2 { font-size:1.8rem; font-weight:700; margin-bottom: 10px; }
.sub-head .h2-desc { font-size:4rem; font-weight:700; line-height: 1.4;; margin-bottom: 95px; }
/*.sub-head .h2-desc.type2 { font-size:6.4rem;}*/
.sub-head .h2-desc p { margin-top:10px; font-size:2.4rem; font-weight:400;}
.sub-head .tabs {position: relative; padding:20px 0; }
.sub-head .tabs:before { content: ''; left: -40vw; right: -40vw; bottom:0; height: 1px; background-color: #f0f0f0; position: absolute;  z-index:2; pointer-events: none;}
.sub-head .tabs ul { display: flex; gap:30px; position: relative; z-index:10;}
.sub-head .tabs ul li a { display: block; padding: 0 20px; line-height: 40px; border-radius:12px; font-size:1.8rem;; transition:all 0.5s ease;}
.sub-head .tabs ul li a small { font-size:1.2rem; color:rgba(0,0,0,0.4); display: inline-block; vertical-align: middle; position: relative; margin-left: 5px; transform: translateY(-3px); }
.sub-head .tabs ul li.active a { color:#fff !important; background-color: var(--blue); }
.sub-head .tabs ul li.active a small { color:rgba(255,255,255,0.6)}
.sub-head .tabs ul li a:hover { color:var(--blue); }
.is-sticky .tabs { z-index:100 !important; }
.is-sticky .tabs:after { content: ''; position: absolute; left: -30vw; top:0; right:-30vw; height: 79px; background-color: #fff; }

.ceo  {/* margin-top:-120px;*/ }
.ceo .box { position: relative; height: 100vh; display: flex; justify-content: center; align-items: center; }
.ceo .box { position: relative; height: auto; padding:0 0 100px; display: flex; justify-content: center; align-items: center; }
/* .ceo .box .txt-box { text-align: center; z-index:2; position: sticky; top:50%; transform: translateY(-50%);} */
.ceo .box .txt-box { text-align: center; } 
.ceo .box .txt-box .t1 { font-size:2rem; margin-bottom: 19px; font-weight:500; transition: all 2s cubic-bezier(0.16, 1, 0.3, 1); }
.ceo .box .txt-box .t2 { font-size:4rem; line-height: 1.5; font-weight:700; margin-bottom: 30px; transition: all 2s cubic-bezier(0.16, 1, 0.3, 1); }
.ceo .box .img { position: absolute; top:60%; width:50%; aspect-ratio: 16/9; transition: all 3s cubic-bezier(0.16, 1, 0.3, 1); }
.ceo .box .img img { width:100%; height:100%; object-fit: cover; }
.ceo .box.active .img { top:0; width:100%; height: 100%; ;}
.ceo .box.active .t1 { color:#fff; }
.ceo .box.active .t2 { color:#fff; }
.ceo .intro { max-width:1150px; margin:0 auto;  margin-top:180px; display: flex; justify-content: space-between; align-items: flex-start; padding:0 20px;}
.ceo .intro h3 { font-size:6.4rem; font-weight:700; flex-shrink: 0; line-height: 1; }
.ceo .intro .text { font-size:1.8rem; line-height: 1.6; width:59%;}
.ceo .intro .text .sign  { margin-top:64px; font-size:1.6rem; }
.ceo .intro .text .sign strong { margin-left: 15px;}

.h3  { font-size:6.4rem; font-weight:700; margin-bottom: 10px; line-height: 1;}
.h3-desc { font-size:2.4rem; line-height: 1.5; margin-bottom: 95px;;}
.h4 { font-size:2.8rem; font-weight:700; margin-bottom: 40px; }

.auth .box1 { margin:180px 0;  display: flex; justify-content: space-between;  }
.auth .box1 .item { width:43%; }
.auth .box1 .item h4 { font-size:2.8rem; font-weight:700; line-height: 1; margin-bottom: 32px;; }
.auth .box1 .item .t1 { font-size:6rem; font-weight:700; line-height: 1; margin-bottom: 10px; letter-spacing: 1px; }
.auth .box1 .item .t1 strong { color:var(--blue); }
.auth .box1 .item .t2 { font-size:1.8rem; line-height: 1.5; margin-bottom: 32px; }
.auth .box1 .item .t3 { font-size:4.8rem; font-weight:700; line-height: 1.5; margin-bottom: 32px; }
.auth .box1 .item .img { flex:1; }
.auth .box1 .item .img img { width:100%; height:100%; object-fit: cover; }
.auth .box2 h4 { font-size:2.8rem; font-weight:700; margin-bottom: 30px;;}
.auth .box2 ul { display: flex; gap:24px; }
.auth .box2 ul li { flex:1; }
.auth .box2 ul li .item { height: 100%; border-radius:12px; background-color: #F9F9F9; padding: 24px; }
.auth .box2 ul li .item i { display: block; text-align: right; margin-bottom: 30px;}
.auth .box2 ul li dl dt { font-size:2.8rem; font-weight:700; margin-bottom: 5px;}
.auth .box2 ul li dl dt span { color:var(--blue);}
.auth .box2 ul li dl dd { font-size:1.8rem; line-height: 1.5;  letter-spacing: -0.5px;}

.introduce-file .img { margin-top:65px; }
.introduce-file dl { margin:30px 0 60px; }
.introduce-file dl dt { font-size:5.2rem; font-weight:700; line-height: 1.5;}
.introduce-file dl dd { font-size:2.4rem; line-height: 1.5; ;}
.introduce-file .btn-download { display: inline-flex; align-items: center; gap:5px; padding:0 40px; line-height: 56px; border-radius:56px; background-color: #000; border:1px solid #000; transition:all 0.5s ease; font-size:1.8rem; color:#fff;;}
.introduce-file .btn-download svg path { transition:all 0.5s ease;}
.introduce-file .btn-download:hover { background:#fff; color:#000; }
.introduce-file .btn-download:hover svg path { stroke:#000; }



.history { position: relative; margin:240px 0;}
.history .line { position: absolute; left:50%; width:3px; margin-left: -1px; top:20px; height: calc(100% - 60px); background-color: #E8E8E8;}
.history .line span { position: absolute; left: 0; top:0; right:0; height: 10px; background-color:var(--blue); ;}
.history .box .year { font-size:5.2rem; font-weight:700; line-height: 1; ;  }
.history .box .year.first { position: absolute; top:-95px; right:80px; }
.history .box > div  { display: flex ;align-items: flex-start; padding:0 16px; position: relative;}
.history .box .left { width:50%; display: flex; flex-direction: row-reverse; }
.history .box .right { width:50%; margin-left: auto; }
.history .box .right .year { padding:100px 0 40px 60px;;}
.history .box .month { font-size:2.8rem; font-weight:700; padding:0 16px; padding-top:10px; position: relative; }
.history .box .month em { position: absolute; left: -24px; top:50%; margin-top:-4px; width:16px; height: 16px; border-radius:100%; background-color:var(--blue); ;}
.history .box .left .month em { left: inherit; right:-24px;}
.history .box ul li { margin-bottom: 8px;;}
.history .box ul li p { display: inline-block; font-size:2rem; font-size:1.8rem; line-height: 1.5; background-color: #F9F9F9; border-radius:12px; padding:12px 16px; font-weight:600;}
.history .box ul li p strong { display: block;}
.history .box .left li { text-align: right;}

.auth-list ul { display: flex; flex-wrap: wrap; gap:80px 0; margin:0 -12px;}
.auth-list ul li { width:20%; padding:0 12px;  text-align: center;}
.auth-list ul li .img { max-width:200px;margin:0 auto; }
.auth-list ul li p { font-size:1.4rem; line-height: 1.5;}
.hr1 { display: block; padding:0;margin:0;border:0; outline:none; padding-top:60px; margin-top:60px; border-top:1px solid #e0e0e0; width:100%;}
.partner-list ul { display: flex; flex-wrap: wrap; gap:80px 0; margin:0 -12px;}
.partner-list ul li { width:20%; padding:0 12px;  text-align: center;}
.partner-list ul li .img { max-width:200px; margin:0 auto; }
.partner-list ul li p { font-size:1.4rem; }

.biz .title { margin-bottom: 50px;}
.biz .title h3  small { font-size:1.8rem; font-weight:600; display: none;}
.biz .title h3 p { font-size:6.4rem; font-weight:400; line-height: 1.4; }
.biz .title h3 p strong { font-weight:700; }
.biz .title .txt { font-size:3.2rem; line-height: 1.4; font-weight:500; margin-top:1rem;}
.biz .img1 { margin-bottom: 130px; ;}
.biz .img1 img { width:100%; }
.biz .txt1 { text-align: center; font-size:2.8rem; line-height: 1.6; color: rgba(0,0,0,0.6); margin-bottom: 180px}
.biz .txt1 strong { color:#000;  }
.biz .feature { display: flex; justify-content: space-between; gap:95px; margin-bottom: 300px;}
.biz .feature dl { max-width:445px;display: flex; flex-direction: column; justify-content: space-between; }
.biz .feature dl dt { margin-bottom: 40px;}
.biz .feature dl dt small { font-size:1.6rem; font-weight:600; color:rgba(0,0,0,0.6); }
.biz .feature dl dt div { font-size:2.8rem; font-weight:500; line-height: 1.6; margin-top:8px; letter-spacing: -0.5px;}
.biz .feature dl dt div p { font-size:1.6rem; }
.biz .feature dl dd img { width:100%; }
.biz .h4-sub { text-align: center; margin-bottom: 60px; ;}
.biz .h4-sub small { font-size:2.8rem; display: block; font-weight:400; margin-bottom: 10px; }
.biz .h4-sub b { font-size:6.4rem; font-weight:700;  display: block;}
.biz .goods { padding-bottom: 180px; overflow: hidden;}
.biz .goods ul { display: grid; grid-template-columns: repeat(3, 1fr); gap:28px;}
.biz .goods ul li .item { height: 100%; border-radius:32px; padding: 36px; display: flex; flex-direction: column; justify-content: space-between; }
.biz .goods ul li .item i { display: block; text-align: right; ;}
.biz .goods ul li .item dl { margin-top:53px; }
.biz .goods ul li .item dl dt { font-size:2.8rem; margin-bottom: 8px; font-weight:700; }
.biz .goods ul li .item dl dd { font-size:1.8rem; line-height: 1.5; color:rgba(0,0,0,0.6); ;}
.biz .goods ul li:nth-child(1) .item,
.biz .goods ul li:nth-child(3) .item,
.biz .goods ul li:nth-child(5) .item { background-color: #F9F9F9;}
.biz .keys { padding: 148px 0; background-color: rgba(0,0,0,0.8); margin-bottom: 180px;  overflow: hidden; }
.biz .keys .h4-sub { color:#fff; }
.biz .keys .slider { padding:0 130px; position: relative; }
.biz .keys .slider .swiper { padding:50px 0;}
.biz .keys .slider .swiper-button-prev,
.biz .keys .slider .swiper-button-next { top:50%; width:48px; height: 48px; background: url(../img/sub2/ico_slider.svg) no-repeat 50% 50%; ;}
.biz .keys .slider .swiper-button-prev { transform: scaleX(-1);;}
.biz .keys .slider .swiper-button-prev:after,
.biz .keys .slider .swiper-button-next:after { display: none;}
.biz .keys .slider .item { padding: 22px; border-radius:20px;  background-color: #fff; transition: all 0.5s ease;}
.biz .keys .slider .item .img {  }
.biz .keys .slider .item .img img { width:100%;  }
.biz .keys .slider .item .text .tit { font-size:2.3rem; font-weight:700; line-height: 1.5; margin: 20px 0;  letter-spacing: -1px;}
.biz .keys .slider .item .text .txt { font-size:1.5rem; line-height: 1.5; color:rgba(0,0,0,0.6); ;letter-spacing: -0.5px;}
.biz .keys .slider .item .text .txt strong { color:#000; font-weight:600;font-size:1.7rem; display: block; margin-bottom: 8px;}
.biz .keys .slider .swiper-slide  { height: auto;}
.biz .keys .slider .swiper-slide .item { opacity:0.5; height: 100%; }
.biz .keys .slider .swiper-slide-active .item { transform: scale(1.15); opacity:1;  }
.biz .keys .slider .swiper-pagination { position: relative; bottom:0; margin-top: 30px; display: flex; justify-content: center; align-items: center; gap:7px; display: none;}
.biz .keys .slider .swiper-pagination .swiper-pagination-bullet { width:7px; height:7px; background-color:#fff; opacity:0.3;}
.biz .keys .slider .swiper-pagination .swiper-pagination-bullet-active { opacity:1;}
.biz .example { overflow: hidden;}
.biz .example .slider a { display: flex; flex-direction: column; justify-content: space-between; height: 100%; padding: 36px; border-radius:32px; border:1px solid #E0E0E0; height: 386px; }
.biz .example .slider a dl dt { font-size:1.8rem; }
.biz .example .slider a dl dd span { font-size:2.8rem; font-weight:500;  display: block; margin:5px 0 15px;; line-height: 1.5; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; }
.biz .example .slider a dl dd div { display: flex; gap:10px; ;}
.biz .example .slider a dl dd div p  { padding:4px 7px; border-radius:8px; border:1px solid #D9D9D9; font-size:1.6rem; color:rgba(0,0,0,0.6); ;}
.biz .example .slider a .logos { display: flex; justify-content: space-between; align-items: center; padding-top:12px; border-top:1px solid #e8e8e8;}
.biz .example .slider a .logos p { max-width:150px; width:100%; }
.biz .example .slider a .logos p img { width:100%; }
.biz .example .slider a .logos i { width:32px; height: 32px; background: url(../img/sub2/ico_arr.svg) no-repeat 50% 50%; background-size: contain;}
.biz .example .slider .swiper-pagination { position: relative; bottom:0; margin-top: 30px; display: flex; justify-content: center; align-items: center; gap:7px; }
.biz .example .slider .swiper-pagination .swiper-pagination-bullet { width:7px; height:7px; background-color:#d9d9d9; opacity:1;}
.biz .example .slider .swiper-pagination .swiper-pagination-bullet-active { background-color: #000;}
.biz .request-quick { position: fixed; bottom:20px; left: 0; right:0;; display: flex; justify-content: center; z-index:10; }
.biz .request-quick .box { display: flex; align-items: center; padding: 16px 36px; border-radius:60px; background-color: #000; box-shadow:0 8px 20px rgba(0,0,0,0.25);  }
.biz .request-quick .box p { font-size:2.4rem; font-weight:500; color:#fff; margin-right:35px; }
.biz .request-quick .box a { display: flex; align-items: center; line-height: 44px;; border-radius:44px; background-color: #fff; font-size:1.6rem; color:#000; font-weight:700; padding:0 16px;}
.biz .request-quick .box a:after { content: ''; display: inline-block; width:24px; height: 24px; background: url(../img/sub2/ico_arr_btn.svg) no-repeat 50% 50%; background-size: contain; margin-left: 10px; }

.works { margin-top:50px;}
.works ul li { margin-bottom: 32px;}
.works ul li a { display: flex; justify-content: space-between; padding: 36px; border-radius:32px; border:1px solid #E0E0E0; }
.works ul li a .text { flex:1; max-width:410px; }
.works ul li a .text .type {  margin-bottom: 20px; }
.works ul li a .text .type p { display: inline-block; vertical-align: middle; font-size:2rem; font-weight:500; line-height:34px; border:1px solid #e0e0e0; border-radius:8px; padding:0 7px;}
.works ul li a .text .tit { font-size:3.2rem; font-weight:700; line-height: 1.5; margin-bottom: 10px; }
.works ul li a .text .txt { font-size:1.8rem; line-height: 1.5; color:rgba(0,0,0,0.6); max-height:195px; overflow:auto;}
.works ul li a .text .txt::-webkit-scrollbar{width: 10px;}
.works ul li a .text .txt::-webkit-scrollbar-thumb{background: #ddd; border-right: 5px solid #fff; border-radius: 3px; border-top-right-radius: 8px 3px; border-bottom-right-radius: 8px 3px;}
.works ul li a .text .txt::-webkit-scrollbar-track{background: #fff;}
.works ul li a .img { width:50%; }
.works ul li a .img .no_image { display:flex; align-items:center; justify-content:center; border-radius:20px; background:#f9f9f9; font-size:16px; font-weight:600; height:100%;}
.works ul li a .img img { width:100%; aspect-ratio: 66/34; object-fit: cover; border-radius:20px; }
.works ul li.none a { display:block; font-size:22px; font-weight:600;  text-align:center; padding:100px 30px; pointer-events:none;}
.works .more { text-align: center; margin-top:60px;}
.works .more .btn-more { display: inline-flex; align-items: center; gap:5px; padding:0 23px; line-height: 58px; border-radius:56px; background-color: #000; font-size:2rem; color:#fff;;}

.esg { overflow: hidden;}
.esg .item { padding: 200px 0; border-bottom: 1px solid #000; }
.esg .item:last-child { border-bottom: 0;}
.esg .item .box { display: flex; justify-content: space-between;}
.esg .item .box .left { max-width:90%; }
.esg .item .box .left .tit small { font-size:1.8rem; }
.esg .item .box .left .tit p{ font-size:3.2rem; font-weight:500; margin-top:10px; }
.esg .item .box .left .txt { font-size:4.8rem; line-height: 1.4; font-weight:700; margin-top:70px}
.esg .item .box .right { max-width:560px; }
.esg .item .info { display: flex; justify-content: space-between; gap:80px; margin-top:85px;}
.esg .item .info dl { flex:1; }
.esg .item .info dl dt span { display: inline-flex; align-items: center; justify-content: center; width:30px; height: 30px; border-radius:100%; background-color:#000; font-size:1.6rem;; color:#fff; font-weight:700;; }
.esg .item .info dl dt p { font-size:2.4rem; margin:12px 0 8px; line-height: 1.5; font-weight:700; ;}
.esg .item .info dl dd { font-size:2rem; line-height: 1.5;}

.search-box { display: flex; justify-self: flex-end; margin-bottom: 24px; gap:12px; }
.search-box .select { height: 44px; padding-left: 12px;}
.search-box .inp { height: 44px; padding-left: 12px;;}
.search-box .inp-box { position: relative; }
.search-box .inp-box .btn-srch { position: absolute; right:0; top:0; width:40px; height: 100%; background: url(../img/common/ico_search.svg) no-repeat 50% 50%; outline:none; border:0; font-size:0; ;}


.table { }
.table table { width:100%; border-collapse: collapse; }
.table table thead th { height: 50px; background-color: #F9F9FB ;font-size:1.6rem; color:#60646C; font-weight:500; ;}
.table table tbody td { font-size:1.6rem; color:#646464; padding:14px 10px; border-bottom: 1px solid #E8E8EC; text-align: center;;}
.table table tbody td a { color:#202020; display: block; text-align: left; }
.table table tbody td .notice { color:#7D83FF}
.table table tbody td a .notice { display: none;}

.board-view .tit { font-size:3.2rem; font-weight:500; line-height: 1.4; margin-bottom: 22px;}
.board-view .info .box { display: flex; gap:25px;  font-family: var(--kr); margin-bottom: 15px;;}
.board-view .info .box dl { display: inline; font-size:1.6rem; ;}
.board-view .info .box dl dt { display: inline; color:#646464;}
.board-view .info .box dl dt:after { content: '|'; display: inline; margin:0 3px 0 6px; color:#bbb; }
.board-view .info .box dl dd { display: inline; ;}
.board-view .info .box dl dd img { vertical-align: middle; margin-top:-3px;}
.board-view .text { padding: 36px 0; margin:36px 0; font-size:1.6rem; line-height: 1.6; border-top:1px solid #d9d9d9;}



.bottom-page { border-top:1px solid #D9D9D9; padding-top:20px;  margin-bottom: 95px;}
.bottom-page li {  position: relative; font-size:1.6rem; }
.bottom-page li span { position: absolute; left: 0; top:5px; color:#646464; }
.bottom-page li:before { content: ''; position: absolute; left: 40px; top:14px; width:1px; height: 14px; background-color: #BBBBBB; margin-top:-6px; ;}
.bottom-page li a { display: block; padding:5px 5px 5px 50px; ;}

.tabs1 { display: flex; gap:36px; margin:40px 0; }
.tabs1 a {font-size:2.4rem; font-weight:700; line-height: 1.8; position: relative;}
.tabs1 a:before {content: ''; position: absolute; left: 0; bottom:0; width:0; height: 2px; background-color: #000; transition: all 0.5s ease;}
.tabs1 a.active:before { width:100%; }

.map-box .map { margin-bottom: 36px; }
.map-box .map iframe { width:100%; height: auto; aspect-ratio: 14/6;}
.map-box .addr { display: flex; justify-content: space-between; align-items: center; }
.map-box .addr dl { display: inline; font-size:2rem;; ;}
.map-box .addr dl dt { display: inline; color:#646464;}
.map-box .addr dl dt:after { content: '|'; display: inline; margin:0 3px 0 6px; color:#bbb; }
.map-box .addr dl dd { display: inline; ;}
.map-box .addr .btns a { display: inline-block; padding: 0 23px; line-height: 58px; height: 60px; border:1px solid #D9D9D9; font-size:1.8rem; font-weight:700; border-radius:60px;;}

.request { display: flex; justify-content: space-between; gap:20px; }
.request .left { width:51.9%; display: flex; flex-direction: column; justify-content: space-between;}
.request .left .t1 { font-size:5.2rem; line-height: 1.4; font-weight:700; }
.request .left .t2 { font-size:2.4rem; line-height: 1.4; margin:20px 0;  }
.request .left .img { display:none; }
.request .right { width:43.1%;  }
.request .right .desc{ text-align: right; font-size:1.6rem; margin-bottom: 12px;}
.request .right .req { color:#FB3B3B; font-weight:700; }
.request .right .form-box { padding: 36px; background-color: #F9F9F9;}
.request .right .form-box .tit { font-size:1.4rem; font-weight:500; margin-bottom: 10px; color:#8D8D8D; ;}
.request .right .form-box .text { padding: 12px 16px; border-radius:8px; background-color: #fff; border: 1px solid #e0e0e0; font-size:1.4rem; line-height: 1.5; color:#838383; margin-bottom: 10px;}
.request .right .form-box .agree { margin-bottom: 10px}
.request .right .form-box .box { margin-bottom: 25px;}
.request .right .form-box .box .inp { width:100%; }
.request .right .form-box .box .checks { max-width:400px; display:grid; grid-template-columns: repeat(3, 1fr); gap:12px;}
.request .right .form-box .box .checks + .inp-box { margin-top:10px; }
.request .right .form-box .inp-box { display: flex; align-items: center; gap:10px; }
.request .right .form-box .inp-box > span { font-size:1.6rem; text-align: center;;}
.request .right .form-box .inp-box .file-box { width:100%; }

.request .file-box .btn-file { display:block; width:100%; line-height: 52px; text-align:center; border-radius:8px;background-color: #fff; border:1px solid #E0E0E0; font-size:1.6rem;  cursor:pointer;;}
.request .file-box .files { font-size:1.6rem; margin:15px 0; }
.request .file-box .desc1 { font-size:1.4rem; line-height: 1.5; color:#646464;;}

.terms { max-width:880px; margin:0 auto; padding-top:200px;}
.terms .h4 { font-size:4rem; margin-bottom: 55px; }
.terms .t1 { padding: 24px; border-radius:8px; border:1px solid #E0E0E0; font-size:1.6rem; line-height: 1.6; color:#838383; margin-bottom: 17px;}
.terms .t1 strong { color:#000; }
.terms .date { font-size:1.8rem; text-align: right; line-height: 1.7; padding-bottom: 55px; margin-bottom: 55px; border-bottom: 1px solid #e0e0e0; ;}
.terms .t2 { font-size:1.8rem; line-height: 1.7; color:#646464;;}

/* GNU */
.pg_wrap { margin-bottom: 50px; float:none; display:block; text-align:center;  }
.pg_page { width:24px; height:24px; background:#fff; line-height:24px; font-size:1.2rem; border:0; color:#80838D; margin:0 2px; border-radius:3px; font-weight:700;min-width:auto ;padding:0;}
.pg_page:hover { background-color:transparent; color:#7D83FF; transition: all 0.3s ease; -webkit-transition: all 0.3s ease; }
.pg_current { width:24px; height:24px; background:#7D83FF; border:1px solid #7D83FF; line-height:24px; font-size:1.2rem; color:#fff; margin:0 2px; border-radius:3px; box-shadow:none; min-width: auto; padding:0; }
.pg_start { border:0; background:url(../img/common/ico_page_first.svg) no-repeat 50% 50%; }
.pg_prev{ border:0; background:url(../img/common/ico_page_prev.svg) no-repeat 50% 50%; }
.pg_next { border:0; background:url(../img/common/ico_page_next.svg) no-repeat 50% 50%; }
.pg_end { border:0; background:url(../img/common/ico_page_last.svg) no-repeat 50% 50%; }

.auth-img img { max-width:550px; width:100%;}
.bo_fx { float:none; margin-bottom:40px;  }
.btn_bo_user  { display:flex; justify-content:flex-end; gap:10px; margin-top:30px; flex-wrap:wrap;}
.btn_bo_user li { margin-bottom:5px; }
.write_div { margin:30px 0; text-align:center;}


.fa.fa-download { display:inline-block; width:24px; height:24px; background:url(/img/common/ico_file.svg) no-repeat 0 0; }
.fa.fa-download:before { display:none; }


.board-write { border-top:2px solid #646465; margin-bottom: 15px; }
.board-write table { width:100%; border-collapse: collapse; }
.board-write table tbody th { background:#f5f5f5; width:20%; padding-left: 40px; font-size:18px; text-align: left; font-weight: 300; border-bottom: 1px solid #b2b2b2;  }
.board-write table tbody td { border-bottom: 1px solid #ababab; padding:10px;  }
.board-bottom-desc { font-size:16px; letter-spacing: -1px; line-height: 1.4; margin-bottom: 60px;}





/************************************************************************************************************************ 
	MODAL 
************************************************************************************************************************/
.popup-wrap { position: fixed; left: 0; top: 0; right: 0; bottom: 0; z-index: 5000; background: rgba(0,0,0,0.8); overflow: auto; display: none; } 
.popup-box { display: table; width: 100%; height: 100%; } 
.popup-cont { display: table-cell; vertical-align: middle; padding: 16px; } 
.popup-head { position: relative; display: flex; align-items: center; gap:40px; margin-bottom: 25px; }
.popup-head h2 { font-size:26px; font-weight:500; }
.popup-head h2 span + span:before {content: '>'; display: inline; margin:0 7px;}
.popup-head .btn-close { position: absolute; right:0; top:-10px; width:40px; height: 40px; background: url(../img/common/ico_close_modal.png) no-repeat 50% 50%;}
.popup { border-radius: 10px; background: #fff; margin: 0 auto; position: relative;  padding:30px 25px;  background:none; padding:0;} 
.popup .board-btm-area { margin-bottom: 0;}
.popup .btn-close { position:absolute; right:0; top:-60px;  padding:0;  font-size:0; border:0;background:none;z-index:10; width:40px; height:40px; border-radius:100%; background:#fff; display:flex;align-items:center; justify-content:center; }
.popup .btn-close svg { width:40px; }
.popup .btn-close svg path { fill:#000; }
.popup .swiper-button-next, 
.popup .swiper-button-prev { display:none; }
.popup .img { background:#f2f2f2; text-align:center;}

.mobile { display: none; }



@media all and (max-width:1480px) {
    .auth .box2 ul li dl dd br { display: none;}

}
@media all and (max-width:1380px) {
    html { font-size:9px;}
    #s-gnb { padding-left:160px; }
    #s-gnb > ul > li { width:145px; }
    .main2 .swiper-slide .item .text .t2 { font-size:4.5rem;}
    .main3 ul { gap:20px; }
    .main3 ul li .item { padding:20px;  border-radius:15px;}
}

@media all and (max-width:1220px) {
    .biz .keys .slider .item .text .txt br { display: none;}
}
@media all and (max-width:1160px) {
.esg .item .box .left .pc{ display: none;}
.biz .goods ul li .item dl dd br { display: none;}
}
	

/* 모바일 시작 */
@media all and (max-width:1024px) {
    html { font-size:8px; }
    #s-header.active.sub { transform: unset; background-color: #fff; ;}
	#s-header .btn-m { position: absolute; right:20px; top:17px; height: 55px; }
	#s-header .btn-m {   width:22px; height: 18px; display: flex; flex-direction: column; justify-content: space-between;}
	#s-header .btn-m span { display:block; height:3px; background: #000; border-radius:3px; }
    #wrap.main #s-header .btn-m span { background-color: #fff;;}
	#s-header.active .btn-m span { background-color: #000 !important;;}
    #s-gnb{ display: none;}
    #s-header .lang { display: none;}
	
	

	
	#s-header { height:55px; ; z-index:1000; position: fixed; }
	#s-header h1 { position: static; text-align: left; padding-top:12px; }
	#s-header h1 a {  width:130px; height:32px; background-size:auto 30px; }
	#s-header .etc { position: static;}
	#s-header .etc .btn-link { display: none; }
	#s-header .etc .lang { position: absolute; left: 10px; top:10px;  margin: 0; float:none; width:90px; padding:0 7px; border-radius:10px; background-position: 69px 10px;  }
	#s-header .etc .lang .btn-lang { height: 25px; line-height: 26px; font-size:11px;  }
	#s-header .etc .lang ul li a { font-size:11px; }
	#s-header .etc .lang ul { padding:2px 0; line-height: 20px; }
	#s-header .etc .btn-all { position: absolute; right:10px; top:10px; margin-top:0; padding:3px 4px 0 5px; }
	#s-header .etc .btn-all span { width:27px; }
	#s-header .etc .btn-all span:nth-child(2) { width:22px; margin:6px 0 6px 5px;}
	
	#s-header { transition:all 0.3s ease; -webkit-transition:all 0.3s ease; }
	#s-header .etc { display: none; }
	#s-header .etc .lang { border-color:#fff !important; background-image:url(../img/common/bu_arr_lang_main.png) !important;  }
	#s-header.active h1 a { background-image:url(../img/common/logo.svg); }
	#s-gnb .btn-dep1,
	#s-header.active #s-gnb .btn-dep1 { color:#00514b; }
	#s-header.active .etc .btn-all span { background-color:#000; }
	
    .sub-head { min-height: 330px; padding-top:100px; margin-bottom: 70px; }
    .sub-head .h2-desc { margin-bottom: 35px;;}
    .sub-head .tabs { padding:10px 0; }
    .sub-head .tabs ul { gap:15px; }

    :root { 
        --mainPd: 150px;
    }
    .main1 .txt-box1 { font-size:3rem; }
    .main1 .txt-box1 .t1 { font-size:8rem; }
    .main1 .controls button img { width:65px;}
    .main2 .title h2 { font-size:6.5rem; }
    .main2 .controls { gap:30px; }
    .main2 .controls a {font-size:2.2rem; }
    .main2 .swiper-slide .item { gap:15px; }
    .main2 .swiper-slide .item .text { padding:22px; }
    .main2 .swiper-slide .item .text .num { font-size:5rem; }
    .main2 .swiper-slide .item .text .num:before { width:35px; height: 35px;;}
    .main2 .swiper-slide .item .text .t2 { font-size:4rem; }
    .main2 .swiper-slide .item .text .t3 { font-size:1.8rem; }
    .main3 h3 { font-size:5rem; margin-bottom: 25px;;}
    .main3 ul li .item i { width:70px; }

    .table table thead th,
    .table table tbody td { font-size:13px; }
    .map-box .addr .btns a { padding:0 18px; height: 50px; line-height: 48px;}
    .request .right .form-box .tit { font-size:13px; }
    .auth .box2 ul li .item i img { width:65px; }
    .auth .box2 ul li dl dt { font-size:2.3rem; }
    .auth .box2 ul { gap:15px; }
    .auth .box1 { margin:90px 0;}
    .auth .box1 .item .t3 br { display: none;}
    .introduce-file .btn-download { padding:0 20px; line-height: 45px; ;}
    .biz .keys .slider { padding:0 60px; }
    .biz .feature dl dt div p { font-size:14px; letter-spacing: -0.5px;}
    .biz .goods ul li .item { padding:20px; border-radius:20px; }
    .biz .goods ul li .item i img { width:65px; }
    .sub-head .h2-desc.type2 { font-size:4.5rem; }
    .sub-head .h2-desc p { font-size:2.5rem;}
    .esg .item { padding:50px 0;}
    .esg .item .box .left { padding-right:10%; width:55%; }
    .esg .item .box .right { width:45%; }
    .terms { padding-top:120px;}
    

}

/* 모바일 */
@media all and (max-width:800px) {
    :root { 
        --mainPd:100px;
    }
    .pc { display: none;}
    .mobile { display: block;}
	html { font-size:7px; }
    .main1 .txt-box1 {font-size:2.5rem; padding-left:10px; padding-right:10px; }
    .main1 .txt-box1 .t1 { font-size:6rem; }
    .main2 .swiper-slide .item { display: block;}
    .main2 .title { display: block;}
    .main2 .title h2 { margin-bottom: 20px;}
    .main2 .controls { gap:15px; }
    .main2 .swiper-slide .item .img { border-radius:10px; }
    .main2 .swiper-slide .item .text { width:auto; border-radius:10px; margin-top:15px;}
    .main2 .swiper-slide .item .text .num { font-size:3rem; margin-bottom: 25px; }
    .main2 .swiper-slide .item .text .num:before { display: none;}
    .main2 .swiper-slide .item .text .t3 { letter-spacing: 0; line-height: 1.7; margin-top:10px}
    .main3 h3 { font-size:4rem; }
    .main3 ul { display: grid; grid-template-columns: repeat(2, 1fr); gap:10px;}
    .main3 ul li .item { padding:15px; }
    .main3 ul li .item i { width:48px; }
    .main3 ul li .item dl dt { font-size:2.2rem; gap:4px;}
    .main3 ul li .item br { display: none;}
    #s-footer { padding:50px 0;}
    #s-footer .addr .last{ flex-direction: column; align-items: flex-start; }
    #s-footer .addr .last dd { margin-top:5px; }

    .sub-head .tabs ul { gap:10px; }
    .sub-head .tabs ul li a { padding:0 15px; line-height: 35px; border-radius:10px; font-size:14px; ;}
    .is-sticky .tabs:after{ height:55px; }
    .sub-head h2 { font-size:2rem; }
    .sub-head .h2-desc { font-size:3.2rem; font-size:2.8rem }
    .sub-head { min-height: 290px; padding-top:90px; margin-bottom: 10px;}
    .h3 { font-size:4.5rem; margin-bottom: 20px;;}
    .h3-desc { font-size:2.2rem; margin-bottom: 40px; }
    .h4 { margin-bottom: 25px;}
    .inp{  font-size:13px; }
    .select { font-size:13px; }
    .pg_page,
    .pg_current { font-size:12px; }

    .table { margin:0 -20px;  border-top:1px solid #e8e8ec;}
    .table thead { display: none;}
    .table table,
    .table table tbody,
    .table table tr,
    .table table tbody td { display: block; border:0; padding:0; }
    .table table tr { display: flex; flex-wrap: wrap;}
    .table table tr .hit,
    .table table tr .num ,
    .table table tr .file { display:none; }
    .table table tr .date {flex-basis: 100%; text-align: left; font-size:12px; color:#646464;  margin-top:10px;}
    .table table tr { border-bottom: 1px solid #e8e8ec; padding:15px 20px;}
    .table table tr a { font-size:16px; font-weight:700; }
    .table table tbody td a .notice{ display: inline; margin-right:5px; }
    .board-view .info .box { display: block; margin-bottom: 10px;}
    .board-view .info .box dl { display: block;}
    .board-view .info .box dl + dl { margin-top:10px; }
	.board-view .text { font-size:13px; }
    .bottom-page li { font-size:13px; }
	.bottom-page li:before { left: 35px;;}

    .btn1 { height: 40px; line-height: 40px; ;}
    .btn1 img { width:19px; }
    .btn2 { height: 50px; line-height: 49px; font-size:16px; ;}
    .btn3 { height: 50px; line-height: 49px; font-size:16px; ;}
    .map-box .map iframe { aspect-ratio: 1/1;}
    .map-box .addr { display: block;}
    .map-box .addr .btns  { display: flex; justify-content:flex-end; margin-top:15px; }
    .map-box .addr .btns a { display: inline-block; width: auto; height: 45px; line-height: 43px;}
    .request { display: block;}
    .request .left,
    .request .right { width:auto}
    .request .left .t1 { font-size:3.5rem; }
    .request .left .t2 { font-size:2.2rem; margin-bottom: 30px;}
    .request .right .desc { margin-top:30px; font-size:14px; }
    .request .right .form-box { padding:20px; }
    .request .right .form-box .tit { font-size:14px; }
    .request .right .form-box .text { padding:10px; font-size:12px; }
    .checkbox + div p { font-size:15px; }
    .request .right .form-box .box .checks { display: flex; flex-wrap: wrap; gap:12px 20px; }
    .inp,
    .select { height: 45px; font-size:14px; }
    .textarea {  font-size:14px; }
    .request .file-box .btn-file { line-height: 45px; font-size:14px; ;}
    .request .file-box .files { font-size:15px; }
    .request .file-box .desc1 { font-size:14px; }
    .sub-head .tabs {  }
    .sub-head .tabs ul { white-space: nowrap; overflow-x: auto; padding:0 20px; margin:0 -20px;}
    .sub-head .tabs ul::-webkit-scrollbar { display: none;}
    .ceo { margin-top:0;}
    .ceo .box { height: auto;}
    .ceo .box .txt-box { position: static; transform: unset; padding:0 20px;}
    .ceo .box .txt-box .t2 { font-size:3rem; }
    .ceo .intro { margin-top:50px; display: block;}
    .ceo .intro h3 { font-size:4.5rem; margin-bottom: 30px;; }
    .ceo .intro .text { width:auto; font-size:16px; word-break: break-all; }
    .ceo .intro .text .sign { font-size:40px; font-size:16px;}
    .auth .box1 { margin:45px 0; display: block; }
    .auth .box1 .item  { width:auto; }
    .auth .box1 .item + .item { margin-top:50px; }
    .auth .box1 .item h4 { margin-bottom: 20px;}
    .auth .box1 .item .t1 { font-size:5rem; }
    .auth .box1 .item .t2 { font-size:16px; }
    .auth .box1 .item .t3 {font-size:4rem; }
    .auth .box2 ul { display: block; }
    .auth .box2 ul li { margin-bottom: 10px;}
    .auth .box2 ul li .item { padding:20px; border-radius:10px; }
    .auth .box2 ul li .item i { margin-bottom: 20px;}
    .auth .box2 ul li .item i img { width:50px; }
    .auth .box2 ul li dl dd {font-size:14px; }
    .introduce-file dl dt { font-size:4.2rem; }
    .introduce-file dl dd { margin-top:20px; }
    .org { padding:0; margin:0 -20px; }
    .history { margin:100px 0 0;}
    .history .box .year.first { top:-55px; left:0; font-size:3.5rem; }
    .history .box .left { width:auto; flex-direction: row;}
    .history .box .right { width:auto; }
    .history .line { left: 0; ;}
    .history .box .left .month em{ right:inherit; left: -8px;;}
    .history .box .month em { left: -8px;}
    .history .box .left,
    .history .box .right { padding-left: 0;}
    .history .box .month { font-size:15px; }
    .history .box ul li p { font-size:14px; text-align: left;}
    .history .box .left li { text-align: left;}
    .auth-list ul { gap:16px 0; margin:0 -8px;}
    .auth-list ul li { width:50%; padding:0 8px;}
    .auth-list ul li p { font-size:13px; letter-spacing:-1px; }
    .partner-list ul { gap:35px 0; margin:0 -8px; }
    .partner-list ul li { padding:0 2px; width:33.33333%; }
    .partner-list ul li p { font-size:12px; word-break: break-all; letter-spacing:-1px;}

    .biz .title { display: block;}
    .biz .title h3 small { font-size:13px; }
    .biz .title h3 p {font-size:4.5rem; }
    .biz .title h3 p strong { display: block;}
    .biz .title .txt { font-size:18px; margin-top:20px;}
    .biz .img1 { margin:0 -20px; margin-bottom: 60px; }
    .biz .img1 .pc { display: block;;}
    .biz .img1 .mobile { display: none;;}
    .biz .txt1 { font-size:16px; margin-bottom: 60px;; text-align: left;}
    .biz .feature { margin-bottom: 180px;}
    .biz .feature { display: block; ;}
    .biz .feature dl { margin-bottom: 40px;}
    .biz .feature dl dt { margin-bottom: 25px;}
    .biz .feature dl dt small {font-size:15px; }
    .biz .feature dl dt div { font-size:3rem; }
    .biz .h4-sub b { font-size:5rem; }
    .biz .goods ul { display: block; ;}
    .biz .goods ul li { margin-bottom: 10px; ;}
    .biz .goods ul li .item { padding:20px; border-radius:10px; }
    .biz .goods ul li .item i img { width:50px; }
    .biz .goods ul li .item dl { margin-top:30px; }
    .biz .goods ul li .item dl dd { font-size:14px;}
    .biz .goods { padding-bottom: 120px; ;}
    .biz .keys { padding:100px 0; margin-bottom: 100px;}
    .biz .keys .slider { padding:0; }
    .biz .keys .slider .swiper { padding:0 20px; margin:0 -20px; }
    .biz .keys .slider .controls { display: none;;}
    .biz .keys .slider .swiper-pagination { display: flex;;}
    .biz .keys .slider .swiper-slide {}
    .biz .keys .slider .swiper-slide-active .item { transform: unset; }
    .biz .keys .slider .swiper-slide .item { padding:20px; border-radius:15px; }
    .biz .keys .slider .item .text .tit { font-size:2.5rem; margin:10px 0;}
    .biz .keys .slider .item .text .txt { font-size:13px; }
    .biz .keys .slider .item .text .txt strong { font-size:14px; }
    .biz .example .slider .swiper { padding:0 20px; margin:0 -20px; }
    .biz .example .slider a { border-radius:15px; padding:20px; height: 250px; }
    .biz .example .slider a .logos p { max-width:110px; }
    .biz .example .slider a .logos i { width:22px; height:22px;}

    .biz .request-quick .box { border-radius:15px; padding:12px 18px;}
    .biz .request-quick .box p { font-size:15px; margin-right:20px; }
    .biz .request-quick .box a { line-height: 32px; font-size:14px; ;}
    .biz .request-quick .box a:after { width:20px; height:20px;}

    .works ul li { margin-bottom: 20px;}
    .works ul li a { display: block; padding:20px; border-radius:15px; }
    .works ul li a .text .type p{ line-height: 25px; ;}
    .works ul li a .text .tit { font-size:2.5rem; }
    .works ul li a .text .txt { font-size:14px;  margin-bottom: 30px;}
    .works ul li a .img { width: auto;}
	/* .works ul li a .img .no_image { height:100px; } */
    .works .more .btn-more { line-height: 40px; font-size:14px; ;}
    .works .more .btn-more svg { width:15px; height: auto;}
    .sub-head .h2-desc.type2 { font-size:3.2rem; }
    .sub-head .h2-desc.type2 br { display: none;}
    .esg .item .box { display: block;}
    .esg .item .box .left { width:auto; padding:0; }
    .esg .item .box .right { width:auto; max-width:100%; }
    .esg .item .box .left .tit small { font-size:15px; }
    .esg .item .box .left .txt { margin-top:30px; font-size:3.5rem; margin-bottom: 50px;}
    .esg .item .info { margin-top:30px; display: block;}
    .esg .item .info dl + dl { margin-top:50px;}
    .esg .item .info dl dt p { font-size:3rem; }
    .esg .item .info dl dt span { font-size:15px;}
    .esg .item .info dl dd { font-size:16px;}
    .terms .t1 { font-size:13px; }
    .terms .t2 { font-size:13px;}
	
	.popup { max-width:320px !important; }
    .biz .example .slider .swiper-pagination { gap:3px; }
    .biz .example .slider .swiper-pagination .swiper-pagination-bullet { margin:0 2px;}
}
























