@charset "utf-8";


/*List */
#container #fboardlist {
    display: flex;
    position: relative;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
}

#fboardlist * {
    box-sizing: border-box;
}

#container #fboardlist ol,
#container #fboardlist ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#container ul.btn_top,
#container #fboardlist ul.btn_top {
    margin-left: auto;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-end;
    align-items: center;
    gap: .5em;
}

#container ul.btn_top>li,
#container #fboardlist ul.btn_top>li {
    position: relative;
    line-height: 1.5em;
    margin: 0;
    padding: 0;
}

#container a.btn,
#container .btn,
#container #fboardlist a.btn,
#container #fboardlist .btn {
    display: block;
}


#fboardlist .list_btn {
    position: relative;
}

#container ul.bo_vc_act,
#container #bo_v_share,
#container ul.more_opt {
    position: absolute;
    top: 1.9em;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid #b8bfc4;
    z-index: 999;
    font-size: 0.8em;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
    margin: 0;
    padding: 0;
    display: none;
}
#container ul.bo_vc_act:before,
#container ul.bo_vc_act:after,
#container #bo_v_share:before,
#container #bo_v_share:after,
#container ul.more_opt:before,
#container ul.more_opt:after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 6px 8px 6px;
}
#container ul.bo_vc_act:before,
#container #bo_v_share:before,
#container ul.more_opt:before {
    top: -8px;
    border-color: transparent transparent #b8bfc4 transparent
}
#container ul.bo_vc_act:after,
#container #bo_v_share:after,
#container ul.more_opt:after {
    top: -6px;
    border-color: transparent transparent #fff transparent
}

#container #bo_v_share ul {
    margin: 0;
    padding: 0;
}
#container ul.bo_vc_act li,
#container #bo_v_share li,
#container ul.more_opt li {
    display: flex;
    border-bottom: 1px solid #f1f1f1;
    padding: 0;
    margin: 0;
    color: #6b757c;
    text-align: left;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: center;

}
#container ul.bo_vc_act li:last-child,
#container #bo_v_share li:last-child,
#container .ul.more_opt li:last-child {
    border-bottom: 0
}
#container ul.bo_vc_act li a,
#container #bo_v_share li a,
#container ul.more_opt li button,
#container ul.more_opt li a {
    width: 100%;
    border: 0;
    color: #6b757c;
    font-weight: 500;
    padding: 0.6em 1em;
    white-space: nowrap;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}
#container ul.bo_vc_act li:hover,
#container #bo_v_share li:hover a,
#container ul.more_opt li:hover a,
#container ul.more_opt li:hover button {
    color: #000
}
#container ul.bo_vc_act li i,
#container #bo_v_share li i,
#container ul.more_opt li i {
    margin-right: 0.8em;
    font-size: 1.2em;
    display: block;
    width: 1.3em;
    height: 1em;
}

#container a.btn_admin {
    color: #aaa;
}

#bo_list_total {
    font-size: .9em;
    line-height: 2.3em;
    letter-spacing: 0;
}

#bo_list_total span {}

#bo_list_total span:after {
    content: ' /';
}


/* 게시판 목록 공통 */
#bo_list {
    width: 100%;
}

#bo_cate {
    display: block;
    /*margin-bottom: +1.9em;*/
    /*margin-top: -1.9em;*/
}

#bo_list .all_chk {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5em;
    font-size: 1em;
    line-height: 2.4em;
    border-bottom: solid 1px #dfdfdf;
}

#bo_list .all_chk label {
    font-size: 0.9em;
    color: #444;
}

#bo_list>ul {}

#bo_list>ul>li {

}

#bo_list>ul>li>figure {
    background: #fff;
    border-radius: 0.5em;
    margin: 1em 0;
    padding: 1em;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: flex-start;
    width: 100%;
    position: relative;
    gap:  1em;
}
#bo_list>ul>li>figure > a {
    display: block;
}
#bo_list>ul>li>figure > a > img {
    width: auto;
    height: 100px;
}
#bo_list>ul>li>figure > figcaption {
    width: calc(100% - (30% + 1em));
}
#bo_list>ul>li>figure > figcaption > dl {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: .5em;
    font-size: 0.9em;
}
#bo_list>ul>li>figure > figcaption > dl > dt {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 1.3em;
    gap: .5em;
    line-height: 1em;
}
#bo_list>ul>li>figure > figcaption > dl > dt a.bo_subject {
    font-weight: 700;
    line-height: 1em;
}

#bo_list>ul>li>figure > figcaption > dl > dd {
    font-size: 0.9em;
    line-height: 1.7em;
}
#bo_list>ul>li>figure > figcaption > dl > dd a.link_href{
    font-size: 0.9em;
    letter-spacing: 0.03em;
    color: deepskyblue;
}


@media screen and (max-width:  425px) {
    #bo_list>ul>li>figure {
    flex-direction: column;
    }
    #bo_list>ul>li>figure > a {
        margin: 0 auto;
    }
    #bo_list>ul>li>figure > figcaption {
        width: 100%;
    }
    #bo_list>ul>li>figure > figcaption > dl {
        font-size: 1em;
    }
    #bo_list>ul>li>figure > figcaption > dl > dd {
        font-size: 1em;
    }
}



#container ul.btn_top {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-end;
    align-items: flex-start;
}




#bo_list .notice_icon {
    display: inline-block;
    background: #fbe2e6;
    padding: 0 5px;
    line-height: 20px;
    border-radius: 5px;
    font-weight: bold;
    font-size: 11px;
    color: #f1364c
}

#bo_list .bo_subject .fa-download {
    width: 16px;
    line-height: 16px;
    background: #ffefb9;
    color: #daae37;
    text-align: center;
    font-size: 10px;
    border-radius: 2px;
    vertical-align: baseline
}

#bo_list .bo_subject .fa-link {
    width: 16px;
    line-height: 16px;
    background: #edd3fd;
    color: #b451fd;
    text-align: center;
    font-size: 10px;
    border-radius: 2px;
    vertical-align: baseline
}

#bo_list .bo_subject .fa-heart {
    color: #ff0000;
    text-align: center;
    font-size: 10px;
    border-radius: 2px
}

#bo_list .bo_subject .new_icon {
    display: inline-block;
    width: 16px;
    line-height: 16px;
    font-size: 0.833em;
    color: #23db79;
    background: #b9ffda;
    text-align: center;
    border-radius: 2px;
    margin: 0 4px;
    font-weight: bold;
    vertical-align: middle
}

#bo_list .bo_subject .fa-lock {
    display: inline-block;
    line-height: 16px;
    width: 16px;
    color: #4f818c;
    background: #cbe3e8;
    text-align: center;
    border-radius: 2px;
    font-size: 12px;
    border: 1px solid #cbe3e8;
    vertical-align: baseline
}

#bo_cate h2 {
    width: 0;
    height: 0;
    font-size: 0;
    line-height: 0;
    overflow: hidden
}

#fboardlist #bo_cate ul {
    padding-left: 1px;
    border-bottom: 1px solid #d9dce3;
    zoom: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    align-content: flex-end;
}

#bo_cate ul:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: ""
}

#bo_cate li {

}

#bo_cate a {
    display: block;
    font-size: 0.9em;
    font-weight: 500;
    padding: 0 0.8em;
    line-height: 3.2em;
    position: relative;
    opacity: .5;
}

#bo_cate #bo_cate_on {
    color: deepskyblue;
    opacity: 1;
}

#bo_cate #bo_cate_on:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0.1em;
    display: block;
    background: deepskyblue;
}

#container h2#bo_v_title {
    font-size: 2em;
    padding: 0 0 1em;
    margin: 1.3em auto 0.4em;
    line-height: 1.5em;
    text-align: center;
    font-weight: 700;
    border-bottom: solid 1px #a2a2a2;
    width: 80%;
} 

#container h2#bo_v_title span.bo_v_cate {
    display: block;
    font-size: 0.6em;
    line-height: 2.4em;
    color: deepskyblue;
}

#container .bo_v_tit  {
    font-weight: inherit;
}

#bo_v_con {
font-size: 1.00em;
    line-height: 2.00em;
    padding-top: 0.563em;
    margin-bottom: 1.44em;
}

#bo_v_img {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 2em;
}
#bo_v_img a {
display: block;
    max-width: 80%;
    box-shadow: 0 0 1em #0000001f;
}
#bo_v_img a img {}

#bo_v_file,
#bo_v_link {}
#bo_v_file ul,
#bo_v_link ul {
    margin: 1em 0;
    padding: 0;
    list-style: none;
    border-top: 1px solid deepskyblue;
}
#bo_v_file ul li,
#bo_v_link ul li {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.6em;
    padding: 0.5em 1em;
}
#bo_v_file ul li a,
#bo_v_link ul li a {
}
#bo_v_file ul li a i,
#bo_v_link ul li a i {
    color: deepskyblue;
    opacity: .7;
    padding-right: 0.5em;

}
#bo_v_file ul li a strong,
#bo_v_link ul li a strong {
    color: deepskyblue;
    font-weight: 700;

}
#bo_v_file ul li span,
#bo_v_link ul li span {
    font-size: 0.9em;
    opacity: 0.6;
    letter-spacing: 0;
}


#bo_v_link h2,
#bo_v_file h2,
#container h2.bo_vc_tit,
#container .comment_inner h2,
#container #bo_vc_w > h2,
#container h2.bo_vc_tit,
#container h2#bo_v_atc_title,
#container #bo_v_info h2 {
    width: 0;
    height: 0;
    font-size: 0;
    line-height: 0;
    overflow: hidden
}

#bo_v_info {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: center;
    align-items: center;
    gap: 1em;
    font-size: 0.8em;
    opacity: 0.4;
    margin-bottom: 1.4em;
}



p#bo_vc_empty {
    background: #f7fdff;
    text-align: center;
    padding: 3em 0;
    margin: 2em 0 4em;
    border-radius: 0.6em;
    box-shadow: 0 0 10px #d7ebf2;
}


#fviewcomment  textarea,
#fviewcomment  input[type=text],
#fviewcomment  input[type=password] {
    border: solid 1px #ccc;
    outline-color: #1095c1;
    font-family: inherit;
    font-size: 1.00em;
    line-height: 2.00em;

}
#fviewcomment  textarea {
    width: 100%;
    padding: 0.6em 1em;
    min-height: calc(6em + 1.2em);
}
#fviewcomment #captcha #captcha_key ,
#fviewcomment  input[type=text],
#fviewcomment  input[type=password] {
    font-size: 1.00em;
    line-height: 2.00em;
    width: unset;
    height: unset;
    padding: 0.5em 1em;
    max-width: 10em;
}


#fviewcomment .bo_vc_w_info {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1em;
}

#fviewcomment .bo_vc_w_info > fieldset {
    border: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: space-between;
    align-items: center;
    white-space: nowrap;
    line-height: calc( 2em + 1em + 2px);
    gap: 0.5em;
}



#fviewcomment fieldset#captcha {
    white-space: unset;
    position: relative;
    margin-right: 0;
    margin-left: auto;
}


#fviewcomment fieldset#captcha #captcha_img {
    height: calc( 2em + 1em + 2px);
    border: none;
}

#fviewcomment fieldset#captcha input[type=text] {
margin-right: calc( 1.5em + 2px);
}

#fviewcomment fieldset#captcha button {
    position: absolute;
    top: 0;
    right: 0;
    width: 1.5em;
    height: 1.5em;
    background-size: 100% auto;
    background-position: 0 0;
}

#fviewcomment fieldset#captcha button#captcha_reload {
    top: calc(1.5em + 2px);
    background-position: 0 -1.5em;
}

#fviewcomment fieldset#captcha #captcha_info {
    display: block;
    font-size: .8em;
    letter-spacing: unset;
    color: deepskyblue;
    position: absolute;
    top: 100%;
    left: 0;
    line-height: 1.9em;
    height: unset;
    margin: 0;
    padding: 0;
    width: 100%;
    text-align: right;
}


#fviewcomment  button.btn_submit {
    font-size: 1em;
    display: block;
    width: 100%;
    font-weight: 500;
    line-height: 1em;
    padding: 1em 0;
    border-radius: 3em;
    max-width: 20em;
    margin: 1em auto;
    opacity: .5;
}


#fviewcomment  button.btn_submit:hover {
    opacity: 1;
    background: #1095c1;
}

#bo_vc {
    margin: 3em 0 0;
    border-top: solid 1px deepskyblue;
    padding: 2em 0 2em;
}

#bo_vc_w {
    margin: 0 0 3em;
    border-bottom: solid 1px deepskyblue;
}

#bo_vc > article {
    background: #ffffff;
    border-radius: 0 0.5em;
    padding: 1.5em 2em 1em;
    margin: 0 0 1em;
    box-shadow: 4px 4px 10px #cacaca;
    position: relative;
    font-size: 0.925em;
}
#bo_vc > article.reply {
    margin-top: -0.7em;
    border-radius: 0 0 0 0.5em;
    
}
#bo_vc > article.reply:before {
    content: '';
    display: block;
    position: absolute;
    width: 0.5em;
    height: 2em;
    top: -1.1em;
    left: -0.5em;
    border-left: solid 4px #e4e4e4;
    border-bottom: solid 4px #e4e4e4;
    border-radius: 0 0 0 0.3em;
    z-index: -1;
}
#bo_vc > article  header {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-content: center;
    align-items: center;
    gap: 1em;
    position: relative;
}

#bo_vc > article  header > span {
    font-size: 0.9em;
    font-weight: 400;
    letter-spacing: 0;
    opacity: .4;
}

#bo_vc > article  header > span.guest,
#bo_vc > article  header > span.member {
    margin-left: -1em;
}
#bo_vc > article  header > span i {
    margin-right: 0.4em;
}

#bo_vc > article  header > .bo_vl_opt {
    margin-left: auto;
    margin-right: 0;
    position: relative;
}

#bo_vc > article .cmt_contents p {
    margin: 1em 0 0;
    padding: 0;
    background: no-repeat;
    font-size: 0.925em;
}


.comment_inner > span > form {
    margin-top: 1em;
    border-top: dotted 1px #ccc;
    padding-top: 1em;
}



#container .bo_v_nb {
    list-style: none;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    margin: 0;
    padding: 0;
}


#container .bo_v_nb li {
    position: relative;
    width: 100%;
}
#container .bo_v_nb li a {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
    gap: 1em;
    font-size: 1em;
    padding: 0.6em 0;
    width: 100%;
}
#container .bo_v_nb li a i {
    opacity: 0.5;
    color: deepskyblue;
}
#container .bo_v_nb li a span {
    display: block;
    position: relative;
    overflow: hidden;
    max-width: 100%;
    white-space: nowrap;
    text-overflow: ellipsis;
}

#fwrite {}

#fwrite .write_div {
    letter-spacing: unset;
    font-weight: unset;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    align-items: center;
    justify-content: flex-start;
    position: relative;
    margin: 1em 0;
    gap: 1em;
}


#fwrite .write_div > span.label,
#fwrite .write_div > label {
    letter-spacing: unset;
    font-weight: 400;
    font-size: .85em;
    width: 9em;
    text-align: right;
    position: relative;
    color: deepskyblue;
}
#fwrite .write_div > label > i {
    color: deepskyblue;
    padding-right: .5em;
}
#fwrite .write_div > label strong.require {
    position: absolute;
    width: 1em;
    height: 1em;
    text-indent: +999em;
    overflow: hidden;
    display: block;
    top: 50%;
    right: -1em;
    transform: translateY(-50%);
}
#fwrite .write_div > label strong.require:before {
    content: '*';
    text-indent: 0;
    position: absolute;
    top: -0.1em;
    left: 0.1em;
    color: deeppink;}



#fwrite  .bo_v_option {
    margin: 0;
    padding: 0;
    line-height: unset;
    list-style: none;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: flex-start;
}
#fwrite .write_div .file_wr,
#fwrite .write_div .cheditor-container,
#fwrite .write_div > input[type=text],
#fwrite .write_div > textarea {
    height: unset;
    width: 100%;
    max-width: calc( 100% - 9em);
}



#fwrite .write_div .file_wr  {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: nowrap;
    align-content: flex-start;
    gap: .5em;
}

#fwrite .write_div .file_wr input[type=text],
#fwrite .write_div .file_wr input[type=file] {
    height: unset;
    width: 100%;

}
#fwrite .write_div .file_wr .file_del {}
#fwrite .write_div .file_wr .file_del label {
    font-size: 0.8em;
    letter-spacing: 0.03em;
    color: deepskyblue;
}
#fwrite .write_div .file_wr .file_del label:hover {
    color: deeppink;
}



#fwrite .btn_confirm  {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    margin: 1em 0 2em;
    gap: 1em;
}
#fwrite .btn_confirm  a,
#fwrite .btn_confirm  button {
    font-size: 1em;
    font-weight: 500;
    padding: 0.8em 3em;
    border-radius: 1.5em;
}