@charset "utf-8";
/* =======================================================
defalut layout
   ======================================================= */

.inner {
	width: 100%;
	max-width: 1600px;
	position: relative;
	margin-left: auto;
	margin-right: auto;
}
.s-inner {
	width: 100%;
	max-width: 1600px;
	position: relative;
	margin-left: auto;
	margin-right: auto;
}
#wrap {
	font-size: 1.6rem;
}
 @media all and (max-width:1480px) {
}
 @media all and (max-width:1280px) {
.s-inner {
	width: 100% !important;
}
}
 @media all and (max-width:1023px) {
html {
	font-size: 0.6rem !important;
}
body {
/* 	border: 5px solid red;
	 */}
}
 @media all and (max-width:767px) {
html {
	font-size: 0.55rem !important;
}
body {
/* 	border: 7px solid blue;
	 */}
}
 @media all and (max-width:650px) {
html {
	font-size: 0.5rem !important;
}
}
/* =======================================================
defalut layout 2 
   ======================================================= */

#header {
	overflow: hidden;
}
#content {  box-sizing:Border-box; padding:20px 30px ;
	flex: 1; overflow:Hidden;
	
}
#wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 0px 0px;
}
/* =======================================================
header
   ======================================================= */

#header {
	position: relative;
	z-index: 99;
	max-width: 302px;
	width: 20%;
	height: auto;
	background: linear-gradient(to bottom, #035271, #22c1c3 );
}
#gnb_pc {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
}
#header #logo {
	position: absolute;
	top: 40px;
	left: 40px;
	z-index: 555;
	font-size: 0;
	border: 0px solid red;
	width: 310px;
	height: 100px;
}
#header #logo img {
	vertical-align: middle;
}
.logo_top2 {	
    overflow: hidden;
    position: relative;
    background: #003435;
    padding: 40px 11% 65px 11%;
    border-radius: 0px 0px 70% 70%;
	text-align:center
}

.logo_top2 p {
	text-align: Center;
	position: absolute;
	font-size: 18px;
	bottom: 11%;
	left: 0;
	width: 100%;
	text-align: center;
	font-weight: 500;
}
.logo_top2 img {
	/*width: 100%;*/
}
.logo_top {
	height: 150px;
	background: url('/img/logo_new.png?v=1.1.1') no-repeat top center;
	z-index: 555 !important;
	position: absolute;
	top: 0; /* right:150px; */
	font-size: 0.9em; /* margin-top:100px;  */
	border: 0px solid #000;
	padding: 0px 12px;
	border-radius: 25px;
	text-align: center;
	width: 100%;
	background-size: 100% auto;
}
#content #hd_ico {
	float: right;
	margin: 0rem;
}
#content #hd_ico a {
	border: 0px solid red;
	text-align: center;
	padding: 7px 10px;
	margin-top: 20px;
	font-size: 14px;
	color: #131c55;
	letter-spacing: -0.5px;
	margin-top: 120px;
	display:inline

}
.gnb {
	display: flex;
	flex-wrap: wrap;
	gap: 1.2rem 0px;
	flex-direction: column;
	margin-top: 30px;
	padding: 30px 4%;
	box-sizing: border-box;
}
.gnb li {
	list-style: disc;
	text-align: left;
	margin-left: 2vw;
}
.gnb li a {
	color: #fff;
	line-height: 1.5;	
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: -1px;
}
.gnb li.on a {
	color: #8deef0;
}
#gnb_pc {
	position: relative;
	overflow: hidden;
	width: 100%;
	box-sizing: border-box;
	color: #fff;
	text-align: center;
	border: 0px solid red;
}
#gnb_pc .gnb_dp1 {
	display: inline-block;
	vertical-align: top;
	text-align: center;
	width: 100%;
}
#gnb_pc .gnb_dp1>div {
	padding: 6px 45px;
	height: 50px;
	font-size: 19px;
	box-sizing: border-box;
	cursor: pointer;
}
#gnb_pc .gnb_dp1>div>a {
	display: inline-block;
	position: relative;
	color: #fff;
	font-weight: 600;
}
#gnb_pc .gnb_dp1 .smenu::after {
	display: block;
	content: '';
	width: 100%;
	height: 400px;
	position: absolute;
	left: 0;
	top: 0px;
	background: #045286;
	transition: all .3s;
	transform: scaleY(0);
	z-index: 1;
}
#gnb_pc .gnb_dp1 .smenu {
	display: none;
	padding: 20px 0;
	color: #fff;
	font-size: 14.5px;
	position: relative;
}
#gnb_pc .gnb_dp1 .smenu li {
	line-height: 1.3em;
	margin: 1em 0;
	z-index: 10;
	position: relative;
}
#gnb_pc .gnb_dp1 .smenu li a {
	color: #fff;
}
#gnb_pc .gnb_dp1 .smenu li:hover a {
	font-weight: 600;
}
.ml105 {
	margin-left: 190px;
}
#gnb_pc li.gnb_dp1:hover > div > a {
	color: #0ad7fc !important;
	font-weight: 700;
}
#gnb_pc li.gnb_dp1:hover .smenu:after {
	transform: scaleY(1);
}
.mobileshow {
	display: none;
}
 @media all and (max-width:767px) {
.mobileshow {
	display: block;
}
.copy {
	font-size: 12px;
}
}
 @media all and (max-width:568px) {
}
 @media (min-width: 1024px) {
.logo_top2 img.mobile_logo {
	display: none
}
}
.close-btn {
	display: none
}
 @media (max-width: 1023px) {
.logo_top2 img.web_logo {
	display: none
}
#wrap {
	flex-direction: column;
}
#gnb_pc {
	height: auto;
}
#header {
	width: auto;
	background: none;
	width: 100%;
	max-width: 100%;
	height: auto;
}
.logo_top2 {
	background: #080c39;
	position: relative;
	z-index: 2;
	width: 170px;
	border-radius: 0px;
	padding: 20px 20px;
}
#content {
	padding:20px 20px;
	width: 100%;
	box-sizing:border-box;
	margin:0;
}
#content #hd_ico {
	margin: 0;
}
.logo_top2 {
	width: 100%;
	text-align: left;
}
.logo_top2 img { height:50px;
}
.gnb {
	position: fixed;
	top: 0;
	margin-top: 0;
	background: #131c55;
	left: -240px;
	width: 240px;
	height: 100%;
	padding-top: 60px;
	transition: left 0.3s ease;
	z-index: 2000;
	display: block !important;
}
/* 메뉴 열릴 때 클래스 */
.gnb.open {
	left: 0;
}
/* 햄버거 메뉴 보이기 */
.menuToggle {
	display: block !important;
	position: fixed;
	top: 27px;
	right: 25px;
	z-index: 2100;
	cursor: pointer;
	text-align: left;
}
.menuToggle svg {
	width: 40px;
	height: 40px;
}
.gnb li {
	margin-left: 20px;
	margin-top: 25px;
}
.gnb li a {
	font-size: 18px;
}
.mobile-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0, 0, 0, 0.6);
	z-index: 80;
}
.mobile-overlay.active {
	display: block;
}
.mobileopen .close-btn {
	top: 30px;
	position: fixed;
	left: 250px;
	color: #fff;
	cursor: pointer;
	z-index: 2101;
	display: block;
}
.mobileopen .close-btn svg {
	width: 37px;
	height: 37px;
}
.mobileopen .menuToggle {
	display: none !important;
}
}
 @media (min-width: 1024px) {
.gnb {
	position: static !important;
	height: auto !important;
	width: auto !important;
	left: auto !important;
	box-shadow: none !important;
	padding: 0 !important;
}
.menuToggle {
	display: none !important;
}
.mobile-overlay {
	display: none !important;
}
}
 @media all and (max-width:650px) {
}
