@charset "utf-8";

:root{
  /* --mainColor : #fba012;
  --subColor : #FFCF50; */
  --mainColor : #0f76bb;
  --subColor : #687a85;
  --basic: rgba(0, 0, 0, .8);
  --lightFont: rgba(0, 0, 0, .5);
  --header-top: 0;
  --header-fixed-height: 100px;
  --header-height: 180px;
  --transition-custom: all 0.3s ease-in-out;
  --transition-custom2: all 0.8s ease-in-out;
  --font-family2 : 'Paperlogy-8ExtraBold', "Noto Sans KR", sans-serif;
  --clr-dark: #151515;

}

.main-color {color: var(--mainColor) !important;}
.mainColor{color: var(--mainColor) !important;}

.header {position: fixed; left: 0; top: 0; width: 100%; z-index: 30 ; height: 90px;  border-bottom: 1px solid transparent; transition: background-color .3s , transform .3s; }
.header .mo {display: none;}

/*.header.tr {transition: all 0.3s}*/
.header.down {transform: translateY(-103%) !important; }
.header .in { display: flex; align-items: center ;width: 100%; height: 100% ;padding: 0 max(20px,3vw); max-width: none;}
.header .logo {display: block; position: relative; z-index: 5; width: 300px;}
.header .logo img{width:  100%;}
.header .logo svg {width: 100%}
.header .logo .color {display: none}

.header .logo .color_1{fill:var(--mainColor);}
.header .logo .color_2{fill:#1972da;}
.header .logo .color_3{fill:#BCBBC2;}

.header nav {position: absolute; left: 50%; top: 0; height: 100%; transform: translate(-50%,0%); z-index: 1}
.header nav .depth1 {display: flex; align-items: center; height: 100%; color: #fff;}
.header nav .depth1 > li { position: relative; height: 100%; display: flex; align-items: center}
.header nav .depth1 > li:before {content: "";position: absolute; left: 50%; top: 0px; transform: translate(-50%,0) ;width: 100%; height: 0px;
	opacity: 0; ;background-color: var(--subColor); }
.header nav .depth1 a {display: flex; align-items: center; justify-content: center ;position: relative; padding: 0 3em; width: 100%; font-size: 18px; font-weight: 500; white-space: nowrap ;transition: padding .3s}
.header nav .depth1 a svg {font-size: 15px; margin-left: 10px}
.header nav .depth1 > li > a:before {content: ""; position: absolute; left: 50%; top: -5px; transform: translate(-50%,-100%); width: 6px; height: 6px; background-color: var(--mainColor); border-radius: 50%; opacity: 0; }
.header nav .depth1 .depth2 {position: absolute; bottom: -30px; left: 50%; transform: translate(-50%,100%); width: 100%; height: 240px; white-space: nowrap; text-align: center; opacity: 0; pointer-events: none ;}
.header nav .depth1 .depth2 li + li {margin-top: 17px}
.header nav .depth1 .depth2 > li {/* padding-left: 3em; */display: flex; flex-wrap: wrap}
.header nav .depth1 .depth2 li a {position: relative; display: inline-flex; width: 100%; font-size: 14px; font-weight: 400; padding: 0em; /* justify-content: flex-start; */ justify-content: center;}
.header nav .depth1 .depth2 li a span {position: relative}
.header nav .depth1 .depth2 li a span:before {content: ""; position: absolute; left: 50%; bottom: 0px; transform: translate(-50%,100%); width:0%; height: 1px; background-color: #fff; }

.header nav .depth1 .depth2 > li > a.active span:before {width: 100%}

.header nav .depth1 .depth2 li .depth3 {margin-top: 15px}
.header nav .depth1 .depth2 li .depth3 > li {display: flex; padding-left: 2.5em}
.header nav .depth1 .depth2 li .depth3 > li + li {margin-top: 10px}
.header nav .depth1 .depth2 li .depth3 a {display: flex; align-items: center; font-weight: 300; font-size: 13px; position: relative}
.header nav .depth1 .depth2 li .depth3 a:before {content: ""; width: 3px; height: 3px; margin-right: 5px ;border-radius: 50%; ;background-color: #fff;}
.header nav .depth1 .depth2 li .depth3 a.active {color: var(--mainColor)}
.header nav .depth1 .depth2 li .depth3 a.active:before {background-color: var(--mainColor)}

.header nav .depth1 > li > a.active:before {opacity: 1}

.header nav .depth1 .depth2 li > a span:before{ content: ""; position: absolute; left: 0%; bottom: -2px; transform: translate(0%,100%) ;width: 0%; height: 1px; background-color: #fff; transition: width .3s}


.header .right_cont {display: flex; align-items: center; position: relative; z-index: 2; margin-left: auto; gap: 10px; }
.header .system_btn{padding: 2px 10px 7px; border: 1px solid #2A292D;  background-color: #2A292D; border-radius: 100%; margin-right: 5px;}
.header .system_btn img {width: 16px; filter: invert(1);}
.header .contact_btn {padding:7px 12px 9px; font-size: 15px; font-weight: 500; border-radius: 100px; background-color: #2A292D; color: #fff; transition: all .3s}

.header .le_select .nice-select {margin-left: 3.5em; padding: 0 3em 0 0; height: auto; line-height: 1.5 ;background-color: transparent; border: none; color: #fff; font-weight: 500; font-size: 1.6em}
.header .le_select .nice-select .current {font-weight: 500}
.header .le_select .nice-select:after {content: "\f078"; font-family: "Font Awesome 6 Pro"; color: #fff; width: auto; height: auto; border: none; transform: translateY(-50%); margin-top: 0; line-height: 1; right: 5px; transform-origin: center; font-size: 0.9em}
.header .le_select .nice-select.open:after {transform: translateY(-50%) rotate(180deg)}
.header .le_select .nice-select .list {border-radius: 0}
.header .le_select .nice-select .list .option {color: #262932; padding: 10px 10px; height: auto; line-height: normal; min-height: 0; font-size: 0.8em}

.header .gnb_bg {position: absolute; left: 0%; top: 00px; width: 100%; height: 0px; background-color: rgba(0,0,0,0.4); backdrop-filter: blur(25px); z-index: -1; overflow: hidden; opacity: 0; }

.header.scroll_down {background-color: #fff; }
.header.scroll_down .logo .white {display: none}
.header.scroll_down .logo .color {display: block}
.header.scroll_down nav .depth1 {color: #262932}
.header.scroll_down .le_select .nice-select {color: #262932}
.header.scroll_down .le_select .nice-select:after {color: #262932}
.header.scroll_down .ham_btn {fill: #262932}
.header.scroll_down nav .depth1 a svg {fill: #262932}

.header.on {background-color: transparent; box-shadow: none;}
.header.on nav .depth1 > li > a{padding: 0 4em}
.header.on .gnb_bg{height: 400px; opacity: 1; transition: height 0.3s ease-in-out, opacity 0.2s ease-in-out;}
.header.on nav .depth1 > li:before{height: 400px;  transition: height  ease-in-out.5s, opacity ease-in-out .5s }
.header.on nav .depth1 > li .depth2 {opacity: 1;;pointer-events: visible; transition: opacity 0.3s; transition-delay: .1s}
.header.on nav .depth1 > li > a:before {background-color: #fff}
.header.on nav .depth1 a svg {fill: #fff}


.header.on .logo path {fill: #fff}
.header.on nav .depth1 {color: #fff}
.header.on .right_cont .nice-select {color: #fff}
.header.on .right_cont .nice-select:after {color: #fff}

.header.on .logo .white{display: inline-block;}
.header.on .logo .color{display: none;}

@media screen and (max-width: 1640px) {
	.header .in {padding: 0 20px}
  .header .logo {width: 200px;}
	.header .in,
	.sub .in,
	.in {width: 100%}
}

@media screen and (max-width: 1440px) {
  .header .logo {width: 160px;}
	.header nav {left: 50%}
	.header nav .depth1 a {padding: 0 2em}
	.header.on nav .depth1 > li > a{padding: 0 3em}

}

@media screen and (max-width: 1200px) {
	.header .contact_btn {padding: 0.6em 1.5em 0.7em; font-size: 12px;}
  .header .mo {display: block;}
  .header .mo.flex {display: flex;}
  .header .pc {display: none;}
	.header.down,
	.header {transform: none !important}
	.header .gnb_bg {display: none}


	.header .right_cont {align-items: flex-start}

	.header .le_select .nice-select {font-size: 14px}
	.header .le_select .nice-select:after {font-size: 12px;}

	.header.on .gnb_bg{height: 350px; opacity: 1; transition: height 0.3s ease-in-out, opacity 0.2s ease-in-out;}
	.header.on nav .depth1 > li:before{height: 420px;  transition: height  ease-in-out.5s, opacity ease-in-out .5s }
	.header.on nav .depth1 > li .depth2 {opacity: 1;;pointer-events: visible; transition: opacity 0.3s; transition-delay: .1s}


	.header nav{display: block; display: flex; flex-direction: column; align-items: flex-start; overflow: auto; position: fixed; top: 0; left:-0%; right: auto;
		transform: translate(100%,0); z-index: 50; width: 100%; height: 100%; padding: 20px 0px; margin-left: 0; background-color: #2A292D; transition: left .5s ease-in-out}
	.header.nav_on .nav{left: -100%}

	.header nav .depth1 > li > a:before{display: none !important}
	.header nav .depth1{flex-direction: column; width: 100%; height: auto; padding: 0; margin-top: 40px}
	.header nav .depth1 > li{display: block; width: 100%; height: auto; padding: 0 0px 0px; font-weight: 500; cursor: pointer}
	.header nav .depth1 > li + li{margin-left: 0}
	.header nav .depth1 > li > a{display: flex; justify-content: flex-start; align-items: center; height: auto; padding: 0px; padding: 20px 30px 0px; padding-bottom: 20px; color: #fff; font-size: 18px}
	.header nav .depth1 > li > a{pointer-events: none}
	.header nav .depth1 > li > a::after{content: "\f078"; display: inline-block; position: static; transform: translateX(0); transform: none !important; opacity: 1; width: auto; width: auto; height:auto; margin-left: auto; background-color: transparent; font-size: 15px; font-family: "Font Awesome 6 Pro"; font-weight: 500; vertical-align: middle; line-height: 1; transition: all .3s}

	.header nav .depth1 > li > a.active span {border-bottom: 1px solid #fff}

	.header nav .depth1 > li:last-child > a {pointer-events: visible}
	.header nav .depth1 > li:last-child > a::after{display: none}

	.header nav .depth1 > li.on{background-color: transparent; color: #fff}
	.header nav .depth1 > li.on > a::after{transform: rotate(180deg) !important}

	.header nav .depth1 > li .depth2{display: none; position: static; height: auto; transform: none; opacity: 1; padding: 20px 0 ;visibility: visible; background:#373738; transition: none; pointer-events: visible}
	.header nav .depth1 > li .depth2 li{text-align: left}
	.header nav .depth1 > li .depth2 li > a{position: relative; display: block; justify-content: flex-start; opacity: 1; padding-left: 20px; color:#fff !important; font-size: 16px; transition: all .3s}
	.header nav .depth1 > li .depth2 a:before{left: 40px; top: 48%; transform: translateY(-50%); width: 4px; height: 4px; border-radius: 50%; opacity: 0}
	.header nav .depth1 > li .depth2 a.active:before {opacity: 1}

	.header .nav_top {align-items: center; padding: 0 30px}
	.header .contact_btn {background-color:#fff; color: #000}
	.header .system_btn{background-color: #fff;     border: 1px solid #fff;}
	.header .system_btn img{filter: none;}
	.header .le_select .nice-select .list {margin-top: 10px}

	.header .nav .close{display:block; position: absolute; top: 20px; right:28px; color: #fff; font-size: 28px}
	.header .nav .close i{color: #fff}

	.header .logo {width: 240px;}

	.header .ham_btn {fill: #fff; width: 20px; margin-left: 20px}
	.header .ham_btn svg {width: 100%; height: auto; }
	.main .header .ham_btn svg {fill: #fff}
	.header.scroll_down .ham_btn svg {fill: #262932}
	.sub .header .ham_btn svg {fill: #262932}
	.header nav .depth1 a svg {fill: #fff !important; font-size: 12px}

	.main .header nav .depth1 a svg {fill: #fff !important}


}


@media screen and (max-width: 768px){
  .header{width: 100%}

	.phone_only { display:block !important}
	.phone_over { display:none !important}

  .phone_only { display:block !important}
	.phone_over { display:none !important}

  .header {padding: 2em 0; border-bottom: none; font-size: 7px}
	.header.scroll_down {border: 1px solid #e0e0e0}

  .header .le_select .nice-select {font-size: 13px; padding: 0 1.8em 0 0; line-height: 1.7}
	.header .logo {width: 180px}
	.header .le_select .nice-select:after {margin-top: -1px}

	.header nav .depth1 > li > a {padding: 15px 20px 15px; font-size: 18px;}
	.header nav .depth1 > li .depth2 li > a { font-size: 15px; padding-left: 10px}
	.header .nav_top {padding: 0 20px}
	.header .system_btn{padding: 7px;}
	.header .nav .close {right: 20px}

}

@media screen and (min-width: 1200px) {
  .header nav .depth1 .depth2 li > a:hover span:before {width: 100%}
	.header .contact_btn:hover {background-color: #262932; color: #fff}
	.header .nav .depth1 > li:hover:before{opacity: 1;}
}







/******************************************** footer ********************************************/

.sec-footer{background:#1b1b1b; color:#fff; padding-bottom:80px;}
.sec-footer .ft-top{border-bottom:1px solid #333; padding:25px 0; overflow:hidden; margin-bottom:40px; }
.sec-footer .ft-top .inner{display:flex; justify-content:space-between; align-items:center;}
.sec-footer .ft-link a{color:#fff; font-size:15px; margin-left:30px;}
.sec-footer .ft-logo img{height:36px; vertical-align:top;}
.sec-footer p{opacity:.5; font-size:15px; line-height:2;}
.sec-footer p span{font-weight:100; margin:0 10px;}
.sec-footer p.copy{opacity:1; margin-top:30px;}

@media screen and (max-width:768px) {
  	/* footer */
	.sec-footer{padding-bottom:40px;}
	.sec-footer .ft-top{margin-bottom:25px;}
	.sec-footer .ft-top .inner{    flex-wrap: wrap;}
	.sec-footer .ft-link { margin-top:20px;}
	.sec-footer .ft-link a{margin-right:20px; margin-left:0; }

	.sec-footer p span{
		display: none;
	}
}


.fix_btn_box {position: fixed; right: 30px; bottom: 30px;visibility: hidden;  opacity: 0; z-index: 100;  transition: all .3s}
.fix_btn_box.show{opacity: 1; visibility: visible;}
.fix_btn_box .menu_btn_box {display: flex; align-items: center; justify-content: center; position: relative; width: 2em; padding: 1em 0; background: #fff; font-size: 35px; text-align: center; border-radius: 50px; box-shadow: 0 9px 80px rgba(144, 144, 144, 0.14); transition: all .3s;}
.fix_btn_box .menu_btn_box ul{width: 100%;}
.fix_btn_box .menu_btn_box ul li + li {margin-top: 45px;}
.fix_btn_box .menu_btn_box ul li a{display: flex; flex-direction: column; align-items: center; justify-content: center; flex-wrap: wrap}
.fix_btn_box .menu_btn_box ul li span{display: block; margin-top: 1em; font-size: 13px; font-weight: bold;}
.fix_btn_box .menu_btn_box ul li svg{opacity: 0.2; font-size: 25px; transition: opacity 0.2s;}

.fix_btn_box .top_btn_box {margin-top: 10px;}
.fix_btn_box .top_btn {display: flex; align-items: center; justify-content: center; z-index: 200; width: 2em; height: 2em; background: #000; font-size: 35px; border-radius: 50%; box-shadow: 0 9px 80px rgba(144, 144, 144, 0.14); transition: all .3s}
.fix_btn_box .top_btn svg{ font-size: 25px; fill: #fff;}

@media screen and (max-width:768px) {
	/*quick*/
    .fix_btn_box { /* display: none; */ right: 10px; bottom: 10px; }
    .fix_btn_box .menu_btn_box { width: 60px; padding: 0.85em 0; }
    .fix_btn_box .menu_btn_box ul li + li { margin-top: 25px; }
    .fix_btn_box .menu_btn_box ul li svg { font-size: 25px; }
    .fix_btn_box .menu_btn_box ul li span { margin-top: 8px; }

    .fix_btn_box .top_btn_box { margin-top: 10px; }
    .fix_btn_box .top_btn { width: 60px; height: 60px; font-size: 20px; }
}