/* basic css start here */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
}                                                                                                                       
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
        display: block;
}
html { }
body { font-family: 'Noto Sans KR', sans-serif; border: 0px; padding: 0px; margin: 0px; }
* { box-sizing: border-box; }
ol, ul { list-style: none; }

a:link {
	text-decoration:none;
}

a:visited {
	text-decoration:none;
}

a:hover {
	text-decoration:none;
}

.fp-tooltip {
	color:red !important;
}

#fp-nav {
	top:100px !important;
}

#fp-nav ul li a span {
	background: red !important;
}


/* fullscreen menu start */
#fullpage {
	width:80%;
	margin:0 auto;
}
.hidden {
	display:none;
}

.fullscreen_menu {
	position:fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	background:white;
	display: none;
	z-index:300;
}

.menu_wrap {
	line-height:50px;
	padding:10px;
	position: relative;
	display: block;
	font-size: 200%;
	width: 500px;
	top: 50%;
	margin: 0 auto;
	transform:translateY(-50%);
	font-weight: 900;
}

.menu_wrap {
	color:black;
}

.menu_wrap a {
	color:black;
}

.menu_wrap a:link{
	color:black;
}

.menu_wrap a:visited{
	color:black;
}

.menu_wrap a:hover {
	color:red;
}

.menu_wrap #sub_menu_ctrl {
	position:relative;
}

.menu_wrap #sub_menu_ctrl {
	display:block;
	width: 15px; /* 사이즈 */
	height: 15px; /* 사이즈 */
	border-top: 5px solid black; /* 선 두께 */
	border-right: 5px solid black; /* 선 두께 */
	display: inline-block;
	transform: rotate(135deg); /* 각도 */
	position: relative;
	top:-8px;
	left:20px;
}

.menu_wrap #sub_menu_ctrl:hover{
	border-top: 5px solid red; /* 선 두께 */
	border-right: 5px solid red; /* 선 두께 */
}

.menu_wrap #sub_menu_ctrl_boards {
	position:relative;
}

.menu_wrap #sub_menu_ctrl_boards {
	display:block;
	width: 15px; /* 사이즈 */
	height: 15px; /* 사이즈 */
	border-top: 5px solid black; /* 선 두께 */
	border-right: 5px solid black; /* 선 두께 */
	display: inline-block;
	transform: rotate(135deg); /* 각도 */
	position: relative;
	top:-8px;
	left:20px;
}

.menu_wrap #sub_menu_ctrl_boards:hover{
	border-top: 5px solid red; /* 선 두께 */
	border-right: 5px solid red; /* 선 두께 */
}

.menu_wrap .sub_menu {
	display:none;
	margin-left:30px;
	font-size:80%;
}

.menu_wrap .sub_menu_boards {
	display:none;
	margin-left:30px;
	font-size:80%;
}

.float_close_menu {
	position: absolute;
	right: 10px;
	top: 5px;
	width: 32px;
	height: 32px;
	opacity: 0.5;
}

.float_close_menu:hover {
	opacity: 1;
}

.float_close_menu:before, .float_close_menu:after {
	position: absolute;
	left: 15px;
	content: ' ';
	height: 33px;
	width: 2px;
	background-color: white;
}

.float_close_menu:before {
	transform: rotate(45deg);
}

.float_close_menu:after {
	transform: rotate(-45deg);
}

.close_menu {
	position: absolute;
	right: 10px;
	top: 5px;
	width: 32px;
	height: 32px;
	opacity: 0.5;
}

.close_menu:hover {
	opacity: 1;
}

.close_menu:before, .close_menu:after {
	position: absolute;
	left: 15px;
	content: ' ';
	height: 33px;
	width: 2px;
	background-color: black;
}

.close_menu:before {
	transform: rotate(45deg);
}

.close_menu:after {
	transform: rotate(-45deg);
}

.open_menu {
	margin-top:8px;
	margin-right: 10px;
	float:right;
}

.open_menu>span {
	display: block;
	width: 30px;
	height: 4px;
	margin-bottom: 6px;
	position: relative;
	background:white;
	border-radius: 3px;
	z-index: 1;
	transform-origin: 4px 0px;
	transition: transform 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
        	    background 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
		    opacity 0.55s ease;
}

/* fullscreen menu end */



/* header start */
.header {
	position: fixed;
	left: 0;
	top:0;
	width:100%;
	height:40px;
	line-height:40px;
	background-color:rgba(255,0,0,1);
}

.logo {
	float:left;
}

.logo_image {
	margin-top: 5px;
	margin-left: 10px;
	height: 30px;
}

.about {
	float:left;
	margin-left: 30px;
	font-weight:500;
}

.about a:link {
	color: white;
}

.about a:visited {
	color: white;
}

.about a:hover {
	color: black;
}
/* header end */



/* footer start */
.footer {
	position: fixed;
	left:0;
	height:15px;
	top:calc(100% - 15px);
	width: 100%;
	line-height: 15px;
	background-color:rgba(255,0,0,1);
	color:white;
	font-weight:500;
	text-align:center;
	font-size:11px;
}
/* footer end */




/* main page slide start */
#fullpage > div {
	background-repeat: no-repeat;
	background-size:cover;
	background-position:center;
}

#fullpage > div > div > .main_title {
	width: 100%;
	height: 10%;
	font-size: 60px;
	font-weight: 900;
}
#fullpage > div > div > .main_sub_title {
	width: 100%;
	height: 10%;
	font-size: 30px;
}
#fullpage > div > div > .main_image {
	width:100%;
	height:70%;
	background-repeat: no-repeat;
	background-size:cover;
	background-position:center;
}
/* main page slide start */



/* contents basic structure start */
.inner_contents {
	width:800px;
	margin: 0 auto;
	margin-top: 50px;
	margin-bottom: 50px;
}
/* contents basic structure end */



/* portfolio header start */
.p_title {
	text-align: center;
	margin-top: 10px;
}

.p_info {
	text-align: center;
	font-size: 90%;
	color: #999;
	display: inline-block;
	width: 100%;
	margin-top: 40px;
	margin-bottom: 40px;
}

.p_info a:link {
	color:#999;
}

.p_info a:visited {
	color:#999;
}

.p_info a:hover {
	color:red;
}

/* portfolio header end */



/* portfolio contents start */
.p_contents {
	clear: both;
	overflow-wrap:break-word;
	word-break:break-all;
}

.p_contents a:link {
	color:black;
}

.p_contents a:visited {
	color:black;
}

.p_contents a:hover {
	color:red;
}
/* portfolio contents end */



/* portfolio list start */
.portfolio_item {
	width:100%;
	margin-top: 50px;
	background-repeat: no-repeat;
	background-size:cover;
	background-position:center;
	cursor: pointer;
}

.portfolio_item>.title_bg {
	color:black;
}

.portfolio_item>.p_image {
	width: 80%;
	margin: 0 auto;
	height: 300px;
	background-repeat: no-repeat;
	background-size:cover;
	background-position:center;
}

.portfolio_item .t_right {
	text-align: left;
}

.portfolio_item .t_left {
	text-align: left;
}

.title_bg>.title {
	display:block;
	font-size:200%;
	font-weight:900;
	padding:10px;
	padding-bottom:0px;
}

.title_bg>.sub_title {
	padding:10px;
	font-size:110%;
}

.portfolio_more {
	text-align:center;
	width: 100px;
	padding:15px;
	background-color:red;
	color:white;
	margin: 0 auto;
	margin-top: 50px;
	z-index:0;
}

/* portfolio list end */



/* portfolio menu start */
.portfolio_menu {
	margin-bottom: 40px;
}

.p_menu {
	overflow:hidden;
	padding:0;
	font-size: 80%;
}

.p_menu li {
	float: right;
}

.p_mitem {
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 20px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.p_mitem:visited {
	color: #999;
}

.p_mitem:hover {
	background-color: crimson;
	color: white;
}
/* portfolio menu end */




/* portfolio tags start */
.portfolio_tag {
	margin-top: 40px;
	margin-bottom: 40px;
}

.tags {
	list-style: none;
	margin: 0;
	overflow: hidden;
	padding: 0;
	font-size: 80%;
}

.tags li {
	float: left;
}

.tag {
	background: #eee;
	border-radius: 6px 0 0 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 23px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.tag::before {
	background: #fff;
	border-radius: 10px;
	box-shadow: inset 0 1px rgba(0, 0, 0, 0.25);
	content: '';
	height: 6px;
	left: 10px;
	position: absolute;
	width: 6px;
	top: 7px;
}

.tag::after {
	background: #fff;
	border-bottom: 10px solid transparent;
	border-left: 10px solid #eee;
	border-top: 10px solid transparent;
	content: '';
	position: absolute;
	right: 0;
	top: 0;
}

.tag:hover {
	background-color: crimson;
	color: white;
}

.tag:hover::after {
	border-left-color: crimson; 
}
/* portfolio tags end */



/* portfolio comment start */
.comment {
	margin-bottom: 20px;
	padding: 10px;
	background-color:rgba(255,0,0,0.05);
	position:relative;
	border-radius:5px;
	font-size:85%;
}

.comment:before {
	border-top:0px solid transparent;
	border-left:10px solid transparent;
	border-right:10px solid transparent;
	border-bottom:10px solid rgba(255,0,0,0.05);
	content:"";
	position: absolute;
	top:-10px;
	left:10px;
}

.sub_comment {
	margin-top:15px;
	margin-left:20px;
	padding: 10px;
	background-color:rgba(255,0,0,0.05);
	position:relative;
	border-radius:5px;
}

.sub_comment:before {
	border-top:0px solid transparent;
	border-left:10px solid transparent;
	border-right:10px solid transparent;
	border-bottom:10px solid rgba(255,0,0,0.05);
	content:"";
	position: absolute;
	top:-10px;
	left:10px;
}

.comment_modify_time {
	font-size: 90%;
	color:grey;
}

.comment_user {
	display:block;
	font-weight: 900;
	font-size:110%;
}

.comment_modify_time {
	display:block;
	font-size:90%;
}

.comment_contents {
	clear: both;
	margin-left: 5px;
}

.comment_member {
	float:left;
	background: black;
	border-radius: 7px;
	width: 14px;
	height: 14px;
	color: #999;
	display: inline-block;
	text-decoration: none;
	font-size:8px;
	line-height:12px;
	text-align:center;
	margin-top:7px;
	margin-right:10px;
	-webkit-transition: color 0.2s;
}
.django-ckeditor-widget {
	width:100%;
}

#id_comment_id {
	border:0px;
	width:calc(100% - 74px);
	line-height:20px;
}

#id_comment_pa {
	border:0px;
	width:calc(100% - 74px);
	line-height:20px;
}

.comment p {
	margin-top:5px;
}

.comment textarea {
	margin-top:5px;
	margin-bottom: 20px;
	width:100%;
	resize:none;
	height:100px;
	border:0;
}

.comment label {
	display: inline-block;
	width: 70px;
	line-height:20px;
}

/* portfolio comment end */




/* portfolio comment menu start */
.c_menu {
	position: absolute;
	overflow:hidden;
	padding:0;
	font-size: 80%;
	top:25px;
	right:0px;
}


.c_menu li {
	float: right;
}

.c_mitem {
	font-size:10px;
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 20px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.c_mitem:visited {
	background-color: crimson;
	color: #999;
}

.c_mitem:hover {
	background-color: crimson;
	color: white;
}
/* portfolio comment menu end */

/* portfolio comment submit menu start */
.new_c_menu {
	position: absolute;
	overflow:hidden;
	padding:0;
	font-size: 80%;
	bottom:0px;
	right:0px;
}


.new_c_menu li {
	float: right;
}

.new_c_item {
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 23px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.new_c_item:hover {
	background-color: crimson;
	color: white;
}
/* portfolio comment submit menu end */


/* portfolio comment modal full page start */
.comment_mod {
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	background:rgba(0,0,0,0.7);
	z-index:300;
	color: white;
}

.mod_modal .close_menu {
	position: absolute;
	top:10px;
	right: 20px;
	opacity: 0.5;
}

.mod_modal {
	position: relative;
	padding:10px;
	padding-top:50px;
	vertical-align: middle;
	text-align:center;
	position:relative;
	width: 500px;
	margin: 0 auto;
	top: 50%;
	border-radius:20px;
	background-color:black;
	transform: translateY(-50%);

}

.mod_modal label {
	width: 100%;
}

.mod_modal input {
	width: 100%;
}

.mod_modal textarea {

	width: 100%;
}

.modal_menu {
	overflow:hidden;
	padding:0;
	font-size:80%; 
}

.modal_menu li {
	float:right;
}

.cdp_menu li {
	float: right;
}

.modal_item {
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 23px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.modal_item:hover {
	background-color: crimson;
	color: white;
}

/* portfolio comment modal full page end */



/* boards css start */
.board_writer {
	margin-top:40px;
}
.board_header {
	width:100%;
	padding:0;
	margin-top:40px;
}

.board_header:after {
	content:"";
	display:block;
	clear:both;
}
.board_list {
	width:100%;
	padding:0;
}

.board_item {
	width:100%;
	padding:0;
	margin-top:5px;
	cursor: pointer;
}

.board_item:after {
	content:"";
	display:block;
	clear:both;
}

.board_item:hover {
	color: red;
}

.board_header {
	font-weight:700;
	color:red;
}

.board_header>span {
	display:inline-block;
	float: left;
	text-align:center;
	border:0;
	margin:0;
	margin-right:0.5%;
	padding:0px;
}
.board_header>span:last-child {
	margin-right:0;
}

.board_item>span {
	display:inline-block;
	float: left;
	border:0;
	margin:0;
	margin-right:0.5%;
	padding:0px;
}

.board_item>span:last-child {
	margin-right:0;
}

.board_header>.bh_index {
	width:7%;
}

.board_header>.bh_title {
	width:56%;
}

.board_header>.bh_author {
	width:20%;
}


.board_header>.bh_date {
	width:15%;
}


.board_item>.bi_index {
	width:7%;
	text-align:center;
}

.board_item>.bi_title {
	width:56%;
	vertical-align:middle;
}

.board_item>.bi_author {
	width:20%;
	text-align:center;
}


.board_item>.bi_date {
	width:15%;
	text-align:center;
}
.board_footer {
	margin-top:10px;
}

.page_nav {
	text-align:center;
}

.p_nav {
	padding:2px;
	padding-right:5px;
	padding-left:5px;
	cursor:pointer;
}

.p_nav:hover {
	background-color:rgba(255,0,0,0.1);
}

.cur {
	background-color:red;
	color:white;

}

.board_writer {
	padding: 5px;
}

.board_writer > form > p {
	margin-bottom:5px;
}

.blank {
	width: 100%;
	height: 20px;
}

.board_writer > form > p > label {
	display: inline-block;
	float:left;
	width: 10%;
	text-align: center;
	color: black;
	font-weight:500;
	margin-right:1%;
}

.board_writer > form > p > input {
	width: 89%;
	height: 25px;
	transform: translateY(-2px);
}

.board_writer > form > p > input[type='checkbox'] {
	display: inline-block;
	width: 20px;
	transform: translateY(-3px);
	
}

.board_writer > form > p > input[type='submit'] {
	margin-top: 10px;
}

.board_writer > form > .django-ckeditor-widget {
	width: 100%;
}

.form_submit {
	text-align: center;
	height: 30px;
	background-color:red;
	color:white;
	font-weight: 500;
	line-height:30px;
	margin-top:20px;
}

.form_submit:hover {
	background-color: rgba(255,0,0,0.1);
	color:black;
}

.new_w_menu {
	overflow: hidden;
	font-size: 90%;
}

.new_w_item {
	line-height:30px;
	text-align:center;
	height: 30px;
	width: 100%;
	background:#eee;
	color: #999;
	display: inline-block;
	border-radius:6px;
	font-weight: 500;
}

.write_menu {
	margin-top:10px;
}

/* boards css end */

/* board menu start */
.board_main_menu {
}

.b_m_menu {
	overflow: hidden;
	padding:0;
	font-size:80%;
}

.b_m_menu li{
	float:right;
}

.b_m_mitem {
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 20px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.b_m_mitem:visited {
	color: #999;
}

.b_m_mitem:hover {
	background-color: crimson;
	color: white !important;
}

.board_menu {
	margin-bottom: 40px;
}

.b_menu {
	overflow:hidden;
	padding:0;
	font-size: 80%;
}

.b_menu li {
	float: right;
}

.b_mitem {
	background: #eee;
	border-radius: 6px;
	color: #999;
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding: 0 20px 0 20px;
	position: relative;
	margin: 0 10px 10px 0;
	text-decoration: none;
	-webkit-transition: color 0.2s;
}

.b_mitem:visited {
	color: #999;
}

.b_mitem:hover {
	background-color: crimson;
	color: white;
}
/* board menu end */

/* board header start */
.b_title {
	text-align: center;
	margin-top: 10px;
}

.b_info {
	text-align: center;
	font-size: 90%;
	color: #999;
	display: inline-block;
	width: 100%;
	margin-top: 40px;
	margin-bottom: 40px;
}

.b_info a:link {
	color:#999;
}

.b_info a:visited {
	color:#999;
}

.b_info a:hover {
	color:red;
}

.b_contents {
	margin-bottom: 40px;
}

.b_contents img {
	width:100% !important;
	height:100% !important;
}

.board_mod {
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	background:rgba(0,0,0,0.7);
	z-index:300;
	color: white;
}
.pass_modal .close_menu {
	position: absolute;
	top:10px;
	right: 20px;
	opacity: 0.5;
}

.pass_modal {
	position: relative;
	padding:10px;
	padding-top:50px;
	vertical-align: middle;
	text-align:center;
	position:relative;
	width: 500px;
	margin: 0 auto;
	top: 50%;
	border-radius:20px;
	background-color:black;
	transform: translateY(-50%);

}

.pass_modal input {
	width:60%;
	margin-bottom:30px;
}

.pass_modal>.modal_menu {
	overflow:hidden;
	padding:0;
	font-size:80%;

}

.scroll_down {
	position: absolute;
	left: 50%;
	top: 85%;
	transform:translateX(-50%);
	color:red;
	animation: blinker 2s linear infinite;
}

@keyframes blinker {
	50% {
		opacity: 0;
	}
}

.scroll_down span {
	display:block;
	width: 24px;
	height: 24px;
	margin:auto;
	margin-bottom:10px;
	border-left: 2px solid red;
	border-bottom: 2px solid red;
	transform: rotate(-45deg);
}

/* board header end */

.float_menu {
	position:fixed;
	width:60px;
	height: 60px;
	bottom: 50%;
	right: 40px;
	background-color:red;
	color: white;
	border-radius:50px;
	text-align:center;
	box-shadow:2px 2px 3px #999;
}

.float_menu_detail {
	display:none;
	position:fixed;
	width:300px;
	height: 600px;
	bottom: 50%;
	right: 40px;
	background-color:red;
	color: white;
	border-radius:10px;
	text-align:center;
	box-shadow:2px 2px 3px #999;
	transform:translateY(300px);
	padding-top:20px;
}

.float_menu_label {
	text-align:left;
	font-size:120%;
	margin-left:10px;
	margin-top:40px;
}
.float_menu_search {
	text-align:left;
	font-size:120%;
	margin-left:20px;
	margin-right:20px;
}
.float_menu_search>input {
	width:85%;
	margin-right:10px;
	color:white;
	background-color:red;
	border:none;
	border-bottom: 1px solid white;
	font-size:100%;
	outline:none;
}
.float_menu_search>svg {
	cursor:pointer;	
}

.float_menu_category {
	text-align: left;
	margin-left:20px;
	font-size:120%;

}

.float_menu_sub a {
	color: white;
}
.float_menu_sub a:visited {
	color: white;
}
.float_menu_sub a:hover {
	color: black !important;
}
.float_menu_sub a:link {
	color: white;
}

.float_menu_tag {
	text-align:left;
}

.float_menu_tag a {
	color: white;
}
.float_menu_tag a:visited {
	color: white;
}
.float_menu_tag a:hover {
	color: black !important;
}
.float_menu_tag a:link {
	color: white;
}

.float_menu_tag span {
	margin-left: 20px;
	display:block;
	font-size:120%;
}

.my-float {
	margin-top:13px;
}

.main_search {
	float:right;
	margin-right:30px;
}

.search_input {
	border:0;
	width:300px;
	border-bottom: 2px solid white;
	outline:0;
	background:transparent;
	color:white;
	font-weight:900;
	margin:0;
}

.search_input::placeholder {
	color:white;
}

.search_label {
	color:white;
	cursor:pointer;
}

.hidden_search {
	display:none;
}

.hidden_search_input {
	padding:0;
	border:0;
	width:300px;
	border-bottom: 2px solid black;
	outline:0;
	background:transparent;
	color:black;
	font-weight:900;
	font-size:100%;
	margin:0;
	margin-top:20px;
	margin-right:20px;
}

.hidden_search_input::placeholder {
	color:black;
}

.hidden_search_label {
	color:black;
	cursor:pointer;
}

.hidden_search_label:hover {
	color:red;
}

@media screen and (max-width:800px) {
	.inner_contents {
		width:100%;
		margin:0;
		margin-top: 50px;
		margin-bottom: 50px;
	}
	.p_contents>p>img {
		width:100% !important;
		height:100% !important;
	}
	.c_mitem {
		padding: 0 10px 0 10px;
	}
	.del_pass {
		width:90%;
	}
	#fullpage > div > div > .main_title {
		height:2em;
		line-height:2em;
		font-size:2em;
	}
	#fullpage > div > div > .main_sub_title {
		height:1.5em;
		line-height:1.5em;
		font-size:1.5em;
	}
	.board_header {
		font-size:0.65em;
	}
	.board_list {
		font-size:0.65em;
	}
	.page_nav {
		font-size:0.65em;
	}
	.main_search {
		display:none;
	}
	.hidden_search {
		display:inline-block;
	}
	#write_form label {
		display:inline-block;
		width: 100%;
		text-align:left;
	}
	#write_form input {
		display:inline-block;
		width: 100%;
		text-align:left;
	}
}
