
/******************************  top  ******************************/
#header { height: 160px; border-bottom: 2px solid #21b5d1; text-align: center; }

#header .logo { height: 100px; border-bottom: 1px solid #ddd; }

#header .logo img { margin-top: 18px; }

#header .gnb { display: inline-block; }
#header .gnb li { float: left; }
#header .gnb li a { padding: 0 40px; font-size: 18px; line-height: 60px; }

@media screen and (max-width:830px){
	#header { height: auto; }

	#header .logo { height: auto; }

	#header .logo img { width: 35%; max-width: 170px; margin: 15px 0; }

	#header .gnb { width: 100%; }
	#header .gnb li { width: 14.28%; text-align: center; }
	#header .gnb li a { padding: 0; }
}


/******************************  footer  ******************************/
#footer { padding-bottom: 50px; color: #777; font-size: 14px; }

#footer .f_logo { display: inline-block; vertical-align: top; }

#footer .company { display: inline-block; margin-left: 50px; }

#footer .f_menu_area { border-bottom: 1px solid #ddd; margin-bottom: 35px; text-align: center; }
#footer .f_menu_area .f_menu { display: inline-block; height: calc(60px - 4px); }
#footer .f_menu_area .f_menu li { float: left; margin: 0 25px; }
#footer .f_menu_area .f_menu a { line-height: 60px; }

@media screen and (max-width:940px) {
	#footer { padding-bottom: 30px; }

	#footer .f_logo { width: calc(100% - 20px); margin-left: 20px; }

	#footer .f_logo img { width: 35%; max-width: 170px; }

	#footer .company { margin-left: 20px; }

	#footer .f_menu_area { margin-bottom: 20px; text-align: left; }
	#footer .f_menu_area .f_menu { height: auto; padding: 15px 0; }
	#footer .f_menu_area .f_menu li { width: calc(50% - 20px); padding-left: 20px; margin: 0; }
	#footer .f_menu_area .f_menu li:last-child { width: calc(100% - 20px); }
	#footer .f_menu_area .f_menu a { line-height: 30px; }
}

/******************************  main  ******************************/
.main_content {
	float: left;
	width: 50%;
	height: auto;
	margin: 15px 0;
	box-sizing: border-box;
}

.main_content .inner {
	width: 94%;
	height: 100%;
	margin: 0 auto;
}

.main_content.left {
	border-right: 1px solid #ddd;
}

.main_content.right {}


.main_box01, .main_box03 {
	height: 400px;
}

.main_box02, .main_box04 {}

.main_box01 .inner, .main_box03 .inner {
	border-bottom: 1px solid #ddd;
}

.main_box02 .inner, .main_box04 .inner {
}

.main_box01::after, .main_box02::after, .main_box03::after, .main_box04::after {
	display: block;
	clear: both;
	content: "";
}

.main_box02 {
	height: 300px;
}

.main_box03 {}

.main_box04 {
	height: 285px;
}

.main_box_title {
	padding-top: 10px;
	border-top: 1px solid #ddd;
	font-size: 18px;
	font-weight: bold;
}


@media screen and (max-width:830px){
	.main_content {
		width: 100%;
		margin: 0;
	}

	.main_content .inner {
		width: 94%;
		height: 100%;
		margin: 0 auto;
	}

	.main_content.left {
		border-right: 0;
	}

	.main_content.right {}


	.main_box01, .main_box03 {
		height: auto;
	}

	.main_box02, .main_box04 {
		height: auto;
	}

	.main_box02 {
		margin-top: 0;
	}

	.main_box01 .inner {
		padding-top: 15px;
		padding-bottom: 30px;
		border-bottom: 1px solid #ddd;
	}

	.main_box02 .inner {
		padding-top: 10px;
		padding-bottom: 25px;
		border-bottom: 1px solid #ddd;
	}

	.main_box02 .inner::after {
		display: block;
		clear: both;
		content: "";
	}

	.main_box03 {}

	.main_box04 {
		padding: 20px 0 40px;
	}

	.main_box_title {
		padding-top: 0;
		border-top: 0;
	}
}


.main_box01_title {
	padding-top: 10px;
	font-size: 30px;
	font-weight: bold;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;  /* 말줄임 적용 */
}


.main_box01_content {
	margin: 0;
	font-size: 18px;
	color: #777;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.main_box01_img {
	position: relative;
	height: 285px;
	margin-top: 10px;
	overflow: hidden;
}

.main_box01_img img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
}


.main_box02_list {}

.main_box02_list li {
	float: left;
	width: 100%;
	margin-bottom: 10px;
}

.main_box02_list li.first {
	margin-bottom: 20px;
}

.main_box02_list li.first .main_box02_img {
	position: relative;
	float: left;
	width: 140px;
	height: 95px;
	margin-top: 10px;
	overflow: hidden;
}

.main_box02_list li.first .main_box02_img img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
}

.main_box02_list li.first .main_box02_title {
	float: right;
	width: calc(100% - 145px);
	margin-top: 11px;
}

.main_box02_list li.first .main_box02_content {
	float: right;
	width: calc(100% - 145px);
}

.main_box02_list li .main_box02_title {
	font-size: 18px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.main_box02_list li .main_box02_content {
	margin: 0;
	font-size: 15px;
	color: #777;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}


.main_box03_list {}

.main_box03_list li {}

.main_box03_list li:not(:last-child) {
	border-bottom: 1px solid #ddd;
}

.main_box03_list li::after {
	display: block;
	clear: both;
	content: "";
}

.main_box03_list li .main_box03_titlebox {
	float: left;
	width: calc(100% - 120px);
	height: 99px;
}

.main_box03_list li .main_box03_titlebox .main_box03_category {
	margin: 0;
	margin-top: 22px;
	font-size: 15px;
	color: #777;
}

.main_box03_list li .main_box03_titlebox .main_box03_title {
	font-size: 18px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.main_box03_list li .main_box03_img {
	position: relative;
	float: right;
	margin-top: 12px;
	width: 110px;
	height: 75px;
	overflow: hidden;
}

.main_box03_list li .main_box03_img img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
}


.main_box04_img {
	position: relative;
	margin-top: 15px;
	width: 100%;
	height: 280px;
	overflow: hidden;
}

.main_box04_img img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
}


@media screen and (max-width:830px){
	.main_box01_title {
		font-size: 26px;
	}
}



/******************************  news  ******************************/
.news_title {
	margin-top: 50px;
	font-size: 24px;
}



/******************************  search area  ******************************/
.hd_search_area {
	width: 97%;
	margin: 20px auto 0;
}

.hd_search_area::after {
	display: block;
	clear: both;
	content: "";
}

.hd_search_box {
	float: right;
}

input.search_input, .search_submit {
	float: left;
}

input.search_input {
	height: 36px;
	padding: 0 10px;
	font-size: 15px;
}

input.search_input::placeholder {
	font-size: 15px;
}

.search_submit {
	height: 38px;
	width: 38px;
	border: 2px solid #21b5d1;
	background: #21b5d1;
}

.search_submit > img {}