@charset "utf-8";
 @import url("./font.css");
/* layout */
body, table, th, td, button, select, input, textarea {
	font-family: 'Noto Sans KR', "돋움", Dotum, Arial, sans-serif;
	font-size: 16px;
	color: #333333;
	-webkit-text-size-adjust: none;
}
body {
	overscroll-behavior: contain;
	background-color: #fff;
}
.hidden {
	margin-right: 17px;
	overflow-y: hidden;
}
#wrap {
	width: 100%;
	position: relative;
	overscroll-behavior: contain;
	padding: 0 4%;
}
/* ****************** 공통클래스 ********************** */
.area {
	max-width: 1280px;
	margin: 0px auto;
	position: relative;
	z-index: 10;
}
.clearfix {
*zoom:1;
}
.clearfix:after {
	clear: both;
	display: block;
	content: "";
}
.table-layout {
	display: table;
	width: 100%;
	height: 100%;
}
.table-cell-layout {
	display: table-cell;
	width: 100%;
	height: 100%;
	vertical-align: middle;
}
/* ****************** HEADER ********************** */
#header {
	width: 100%;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	text-align: center;
	position: relative;
	border-bottom: 1px solid #82978b;
}
#header h3 {
	font-family: DB Dream ExtraBold;
	font-size: 33px;
	font-weight: 800;
	color: #000;
	padding: 20px 0;
	position: absolute;
	left: 50%;
	transform: translate(-50%, -50%);
}
#header p {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
#header p a {
	color: #000;
}
#header p.prev-btn {
	left: 0;
	font-size: 30px;
}
#header p.filter-btn {
	right: 0;
}
#news-wrap {
	display: flex;
	justify-content: space-between;
	padding:0;
}
#news-wrap article {
	width: 32.3333%;
	position: relative;
}
.news-header {
	background: #f5f5f5;
	padding: 20px;
	position: relative;
}
.news-header h4 {
	text-align: center;
	font-size: 25px;
	color: #000;
}
.news-header .graph-btn {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}
.news-body ul li {
	padding: 19px 0;
	border-bottom: 1px solid #e0e0e0;
}
.news-body ul li a {
	display: flex;
	align-items: center;
	justify-content: space-between
}
.news-body ul li a .news-thum {
	width: 139px;
	height:86px;
	border-radius: 10px;
	overflow: hidden;
}
.news-body ul li a .news-thum img {
	width: 100%;
}
.news-body ul li a .news-list-item {
	width: calc(100% - 155px);
}
.news-body ul li a .news-list-item .subject {
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	word-wrap: break-word;
	line-height: 1.3em;
	height: 2.6em;
	color: #000;
	font-size: 19px;
	font-weight: 600;
	-webkit-transition: all 0.6s;
	-moz-transition: all 0.6s;
	-o-transition: all 0.6s;
	-ms-transition: all 0.6s;
	transition: all 0.6s;
}
.news-body ul li a .news-list-item .news-item-info {
	display: flex;
	justify-content: space-between;
	margin-top: 15px;
}
.news-body ul li a .news-list-item .news-item-info .date {
	color: #a6a6a6;
	font-size: 0.9em;
}
.news-body ul li a .news-list-item .news-item-info .date span {
	display: inline-block;
	position: relative;
	padding: 0 10px 0 12px;
}
.news-body ul li a .news-list-item .news-item-info .date span:after {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	height: 100%;
	background: #d0d0d0;
	display: block;
	content: "";
}
.news-body ul li a .news-list-item .news-item-info .date span:first-child {
	padding-left: 0;
}
.news-body ul li a .news-list-item .news-item-info .date span:first-child:after {
	display: none;
}
.news-body ul li a .news-list-item .news-item-info .hash {
	color: #007f41;
	font-size: 0.9em;
}
.news-body ul li a:hover .news-list-item .subject {
	color: #007f41;
	-webkit-transition: all 0.6s;
	-moz-transition: all 0.6s;
	-o-transition: all 0.6s;
	-ms-transition: all 0.6s;
	transition: all 0.6s;
}
.board_pager {
	text-align: center;
	margin-top: 20px;
	margin-left: 50px;
}
.board_pager a.arr {
	background: #eaeaea;
	border-radius: 5px;
}
.board_pager a.arr::before {
	display: block;
	width: 100%;
	height: 100%;
	font-family: "xeicon";
	text-align: center;
	line-height: inherit;
}
.board_pager a.arr.prev::before {
	content: "";
}
.board_pager a.arr.next::before {
	content: "";
	
}
.board_pager a.arr.first::before {
	content: "";
}
.board_pager a.arr.last::before {
	content: "";
}

.board_pager .group {
	margin: 0 0.2rem;
}
.board_pager .group a {
	background: #eaeaea;
	border-radius: 5px;
}
.board_pager a {
	-webkit-transition: all 0.2s;
	transition: all 0.2s;
	display: inline-block;
	overflow: hidden;
	width: 40px;
	height: 1.9rem;
	border-radius: 100%;
	text-align: center;
	line-height: 1.9rem;
	vertical-align: top;
	margin: 2px;
}
.board_pager a.active {
	background: #007f41;
	color: #fff;
}
.board_pager a.arr:hover, .board_pager a.arr:focus {
	background: #007f41;
	color: #fff;
}
.board_pager .group a:hover, .board_pager .group a:focus {
	background: #007f41;
	color: #fff;
}
/*filter*/
.filter-head {
	border-bottom: 1px solid #dcefeb;
	display: flex;
	padding: 10px 0;
	margin-top: 25px;
}
.filter-head h4 {
	margin-right: 10px;
	padding: 5px 0 0 0;
}
.filter-head p {
	font-size: 14px;
	font-weight: bold;
	display: inline-block;
	-webkit-user-select: none;
	line-height: 30px;
	z-index: 1;
	margin-left:7px;
}
.filter-body {
}
.checkbox-group {
	display: flex;
	flex-wrap: wrap;
	margin-top: 15px;
}
.checkbox-group p {
	margin: 0 5px 5px 0;
}
.analysis-head {
	font-size: 18px;
	color: #000;
	font-weight: 600;
	margin-bottom: 5px;
}
.analysis-body {
	border: 1px solid #d6d6d6;
	border-radius: 10px;
	overflow: hidden;
}
.analysis-box {
	margin-bottom: 5px;
}
.analysis-box.last {
	margin-bottom: 0;
}
/* Popup */
.popup-box {
	position: fixed;
	left: 50%;
	top:   2%;
	/* transform: translateY(-50%); */
	z-index: 10007;
	width: 100%;
	outline: 0;
	overflow: hidden;
	display: none;
	height: calc(100vh - 60px);
}
.popup-box.filter {
	width: 36%;
}
.pop-box.search {
	width: 100%;
	top: 75px;
	background-color: #e8f3d2;
	position: absolute;
	padding: 47px;
	border-bottom-left-radius: 20px;
	border-bottom-right-radius: 20px;
}
.searchbox {
	border: 3.5px solid rgb(0, 133, 74);
	border-radius: 20px;
	background-color: white;
	height: 50px;
	left: 50%;
	position: absolute;
	transform: translate(-50%, -50%);
	width: 50%;
}

.popup-box.analysis {
	position: absolute;
	height: 100%;
}
.popWrap {
	border-radius: 10px;
	background-color: #ffffff;
	padding: 30px;
	height: 100%;
	position: relative;
}
.popWrap.scroll {
	padding: 30px 10px 30px 30px;
}
.popup-box .pop-tit {
	font-size: 25px;
	margin-bottom: 15px;
	font-weight: 600;
	padding-bottom: 10px;
	color: #000;
	border-bottom: 1px solid #82978b;
}
.popup-box h3 {
	font-size: 20px;
	margin-bottom: 20px;
	font-weight: 500;
}
.popWrap.scroll .scrollbar-inner {
	height: calc(100% - 0px);
	overflow-y: auto;
	overflow-x: hidden;
}
.analysis .popWrap.scroll .scrollbar-inner {
	height: calc(100% - 40px);
}
.popWrap.scroll .scrollbar-inner::-webkit-scrollbar {
 width: 10px;
 height: 30px;
 background-color: rgba(0, 0, 0, 0.2);
 border-radius: 10px;
 background-clip: padding-box;
 border: 2px solid transparent;
}
.popWrap.scroll .scrollbar-inner:hover::-webkit-scrollbar-thumb {
 height: 30px;
 background-color: rgba(0, 0, 0, 0.2);
 border-radius: 10px;
 background-clip: padding-box;
 border: 2px solid transparent;
}
.popup-box .layer-close {
	position: absolute;
	top: 30px;
	right: 30px;
	width: 30px;
	height: 30px;
	font-size: 25px;
	color: #000;
	display: inline-block;
}
#dimmd-layer {
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 100;
	background-color: rgba(0, 0, 0, 0.6);
	width: 100%;
	height: 100vh
}
#dimmd-layer2 {
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 100;
	background-color: rgba(0, 0, 0, 0.6);
	width: 100%;
	height: 100vh
}
input[type="checkbox"] {
	display: none;
}
input[type="checkbox"] + label {
	margin: 0px;
	display: block;
	background: #eeeeee;
	border: 3px solid #eeeeee;
	border-radius: 30px;
	padding: 8px 20px;
	color: #686868;
	box-sizing: border-box;
}
input[type="checkbox"] + label:before {
	display: none;
}
input[type="checkbox"]:checked + label {
	background: #e8f3d2;
	border: 3px solid #007f41;
	color: #007f41;
}
.switch_container {
	position: relative;
}
.switch_container:after {
	clear: both;
	display: block;
	content: "";
}
.switch_container .switch {
	position: relative;
	display: inline-block;
	width: 65px;
	height: 30px;
	vertical-align: middle;
	-webkit-tap-highlight-color: rgba(255,255,255,0);
	float: right;
}
.switch_container .switch input {
	display: none;
}
.switch_container .switch input:focus, .switch_container .switch input:active {
	outline: 0;
	background: none;
}
.switch_container .switch .slider {
	position: absolute;
	cursor: pointer;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #c8c8c8;
	-webkit-transition: .4s;
	transition: .4s;
	border-radius: 30px;
}
.switch_container .switch .slider:before {
	position: absolute;
	content: "";
	height: 22px;
	width: 22px;
	left: 4px;
	bottom: 4px;
	background-color: white;
	-webkit-transition: .4s;
	transition: .4s;
	border-radius: 50%;
}
.switch_container .switch input:checked + .slider {
	background-color: #007f41;
}
.switch_container .switch input, .switch_container .switch input:focus + .slider, .switch_container .switch input:active + .slider {
	box-shadow: 0 0 1px #007f41;
	outline: 0;
}
.switch_container .switch input:checked + .slider:before {
	-webkit-transform: translateX(34px);
	-ms-transform: translateX(34px);
	transform: translateX(34px);
}
.switch_container p {
	position: absolute;
	font-size: 14px;
	font-weight: bold;
	display: inline-block;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	line-height: 30px;
	z-index: 1;
	left:70px;
	top:0;
}
.top-keyword-box {
	display: inline-flex;
	margin-top : 16px;
	position: relative;
	width: 566.08px;
}
.top-keyword-box .keyword-box-body {
	width: 139px;
	text-align: center;
}
.top-keyword-box .keyword-box-body .keyword-text {
	font-size: 19px;
	font-family: 'DB Dream ExtraBold';
	position: relative;
	top: 50%;
    transform: translateY(-50%);
}
.top-keyword-box .keywordList-box {
	margin-left: 16px;
}
.top-keyword-box .keywordList-box div {
	display: inline-flex;
}
.top-keyword-box .keywordList-box div .keyword-btn {
	position: relative;
    font-size: 17px;
    border-radius: 8px;
    padding: 5px 10px 5px 10px;
	color: rgb(0, 133, 74);
	margin-right: 10px;
	border: 3px solid #e8f3d2;
}
.category-header { 
	display: flex;
	align-items: center; 
	padding: 5px; 
	margin-top: 30px;
	border-bottom: 1px solid #dcefeb;
}
.category-header h3 { 
	margin-right: 10px;
}
.chip { 
	background-color: #e0e0e0; 
	border-radius: 15px; 
	padding: 5px 10px; 
	display: flex; 
	align-items: center;
	margin: 10px 10px 0 0;
}
.chip button { 
	background: none; 
	border: none; 
	cursor: pointer; 
	font-size: 16px;
	margin-left: 5px;
}
.input-keyword { 
	margin-top: 10px; 
	border-radius: 15px;
	border: 2px solid #4CAF50;
}
.footer-buttons { 
	text-align: right; 
	margin-top: 20px;
}
.footer-buttons button { 
	margin-left: 10px; 
}
.keywords {
	display: flex;
    flex-wrap: wrap;
}
.edit-btn { 
	background-color: #4CAF50; 
	color: white; 
	padding: 5px 10px; 
	border: none; 
	border-radius: 4px; 
	cursor: pointer; 
}
#login-form {
	position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    padding: 50px 100px;
    border-radius: 8px;
    background-color: #fff;
    text-align: center;
    box-shadow: 0 1px 4px 0 rgba(0,0,0,0.06);
}

.admin-password-input {
    width: 100%;
    padding: 10px;
    margin: 10px 0;
    border: 1px solid #dadada;
    border-radius: 3px;
    font-size: 16px;
    box-shadow: 0 2px 6px 0 rgba(68,68,68,.08);
}

.admin-button {
    background-color: rgb(0, 133, 74);
    color: #fff;
    border: none;
    border-radius: 3px;
    padding: 10px 20px;
    font-size: 18px;
    cursor: pointer;
}
.overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7); /* 어두운 배경 색상 */
    z-index: 999; /* 팝업 위로 나타나게 함 */
}

.keyword-popup-box {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -45%);
    background-color: white;
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: 20px;
    z-index: 1000; /* 어두운 배경 위로 나타나게 함 */
}
.pop-cont-popup {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -45%);
    padding: 30px 50px;
    border-radius: 8px;
    background-color: #fff;
    box-shadow: 0 1px 4px 0 rgba(0,0,0,0.06);
}
.guide {
	background-color:#E0E0E0;
	padding: 20px;
	border-radius: 8px;
}
#excludeKeyword {
	border: 1px solid white;
    border-radius: 8px;
    margin-left: 10px;
    width: 550px;
    background-color: white;
}