@charset "utf-8";

.tt { margin: 0 0 100px 0; padding: 0 0 30px 0; color: #283278; border-bottom: 1px solid #283278; }
.tt > div { display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; }
.tt > div::before,
.tt > div::after { display: none; }
    .tt h2 { font-size: 2.88em; font-weight: 700;  }
@media (max-width:991px) {
    .tt { margin: 0 0 30px 0; padding: 0 0 15px 0; }
    .tt > div { align-items: flex-start; flex-direction: column; gap: 10px; }
}

/* -- 게시판 공통 -- */
    #board          { position: relative; width: 100%; }
    #board .web_col { display: table-column-group; }
    #board .mob_col { display: none; }
    #board .web_td  { display: table-cell; }
    #board .mob_td  { display: none; }
    @media ( max-width: 991px) {
		#board table th, #board table td { padding: 15px 5px; }
	    #board .web_col { display: none; }
	    #board .mob_col { display: table-column-group; }
	    #board .web_td  { display: none; }
	    #board .mob_td  { display: table-cell; }
    }

/* 게시판 제목 말줄임 */
    #board .subject  { display: inline-block; width: 100%; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    #board .subject2 { text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; /* 라인수 */ -webkit-box-orient: vertical; word-wrap:break-word; line-height: 1.2em; height: 2.4em; overflow: hidden; }
    #board .subject3 { text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 3; /* 라인수 */ -webkit-box-orient: vertical; word-wrap:break-word; line-height: 1.2em; height: 3.6em; overflow: hidden; }

/* -- 비밀번호 팝업 -- */
	#board_pw .modal-body { padding: 3rem; }
    #board_pw .pw_title   { padding:0 0 1rem 0; text-align: center; }
    #board_pw a           { display: block; height: 40px; line-height: 37px; text-align: center; border-radius: 5px; }
    #board_pw input       { border-radius: 5px; }

/* -- 글갯수 -- */
    #board .total{ padding: 0 2px 10px 0; text-align: left; line-height: 1em; }
    @media (max-width:991px) {
        #board .total{ text-align: right; }
    }

/* -- 개시물 없음 -- */
	.no_data{ padding: 10% 0; text-align: center; }
	.no_data i{ font-size: 3em; color: var(--PU-28); }
	.no_data p{ padding: 10px 0 0 0; }

/* -- 첨부파일 -- */
    .filebox              { overflow: hidden; }
    .filebox .upload-name { vertical-align: middle; }
    .filebox label        { padding: 0; }
    .filebox label i      { display: block; height: 40px; line-height: 38px; text-align: center; border-radius: 40px; cursor: pointer; }
    
/* -- 버튼 -- */
    .btn_wrap   { padding: 3% 0 0 0; overflow: hidden; }
    .btn_wrap ul { display: flex; justify-content: space-between; gap: 10px; width: 100%; }
    .btn_wrap a { display: inline-block; height: 50px; text-align: center; line-height: 50px; border: 0; border-radius: 50px; transition: all 0.3s ease 0.2s; }
    .btn_wrap a:hover { opacity: 0.9; }
    .btn_wrap input  { display: inline-block; height: 50px; text-align: center; line-height: 50px; border: 0; border-radius: 50px; transition: all 0.3s ease 0.2s; }
    .btn_wrap input:hover { opacity: 0.9; }
    .btn_wrap button { display: inline-block; height: 50px; text-align: center; line-height: 50px; border: 0; border-radius: 50px; transition: all 0.3s ease 0.2s; }
    .btn_wrap button:hover { opacity: 0.9; }
    .btn_wrap .bt_list li:nth-child(2) a { padding: 0 50px; }
    /* .btn_wrap .bt_list li:nth-child(1) { width: 70px; margin-right: auto; }    
    .btn_wrap .bt_list li:nth-child(3) { width: 70px; margin-left: auto; text-align: right; } */
    @media ( max-width: 991px) {
        .btn_wrap .bt_list li:nth-child(2) a { padding: 0 30px; }
    }

/* -- 리스트 -- */
    #board .list { border-top: 2px solid var(--RD-FF); }
    #board .list th { width: calc(100% - 120px); padding: 0 10px; border-bottom:1px solid var(--BK-EE); }
    #board .list td { width: 120px; padding: 0 10px; text-align: right; border-bottom:1px solid var(--BK-EE); }
    #board .list a { display:block; padding: 50px 0; font-size: 1.3em; }
    #board .list tr { transition-property: box-shadow; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 200ms; }
    #board .list tr:hover { box-shadow: 4px 4px 24px var(--BK-OP-02); }
    @media ( max-width: 991px) {
        #board .list a { padding: 20px 0;}
    }

/* -- 보기 -- */
	#board .view th { padding: 0 10px 15px 10px; font-weight: 700; }
    #board .view th h1 { font-weight: 700; }
    #board .view td { padding: 15px 10px; border-bottom: 1px solid var(--BK-F2); }
	#board .view .date { font-size: 0.9em; color: var(--BK-BD); }
	#board .view .con { text-align: left; }
	#board .view .con img{ display: block; width: auto; max-width: 100%; margin: 0 auto; }
    #board .download a { display: block; padding: 5px 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    #board .download a:hover { text-decoration: underline; color: var(--PU-28); }

/*뉴스*/
    #board .news { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start; gap: 20px; }
    #board .news li { position: relative; width: calc(100%/3 - 15px); }
    #board .news li.no_data { width: 100%; }
    #board .news a { display: block; padding: 40px 25px; border: 2px solid transparent; border-radius: 0 0 0 5px; background: var(--BK-F9); transition: all 0.3s; }
    #board .news a:hover { border: 2px solid var(--RD-FF); background: var(--white); }
    #board .news .tit_box { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    #board .news .txt_box { height: 3em; line-height: 1.5em; font-size: 24px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
    #board .news .date { padding: 25px 0 0 0; color: var(--BK-BD); }
    #board .news .arr { position: absolute; right: 35px; bottom: 20px; width: 50px; opacity: 0; transition: all 0.6s; }
    #board .news a:hover .arr { opacity: 1; transform: translateY(-10px); }
    @media ( max-width: 991px) {
        #board .news li { width: 100%; }
        #board .news a { padding: 15px 10px; }
        #board .news .txt_box{ height: auto; max-height: 3em; font-size:18px; }
        #board .news .date { padding: 10px 0 0 0; }
    }

/*letter*/
    #board .letter { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start; gap: 20px; }
    #board .letter li { position: relative; width: calc(100%/3 - 15px); height: 270px; border-radius: 10px; overflow: hidden; }
    #board .letter li.no_data { width: 100%; }
    #board .letter li a { display: block; will-change: transform; transition: all .7s ease-in-out; }
    #board .letter li:hover a { transform: scale(1.05); }
    @media ( max-width: 991px) {
        #board .letter { gap: 10px; }
        #board .letter li { width: calc(100%/2 - 5px); height: 170px; }
    }

/*photo*/
    #board .photo { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start; gap: 20px; }
    #board .photo li { position: relative; width: calc(100%/3 - 15px); border-radius: 10px; overflow: hidden; }
    #board .photo li.no_data { width: 100%; }
    #board .photo li a { display: block; will-change: transform; transition: all .7s ease-in-out; }
    #board .photo li:hover a { transform: scale(1.05); }
    @media ( max-width: 991px) {
        #board .photo { gap: 10px; }
        #board .photo li { width: calc(100%/2 - 5px); }
    }

/* -- 페이징 -- */
    #page   { padding: 3% 0 0 0; text-align: center; clear: both; }
    #page a { display: inline-block; width: 40px; height: 40px; line-height: 40px; }
    #page a:hover { color: var(--PU-28); }
    #page .on {border-radius: 50%; color: var(--white); background: var(--PU-28); }
    #page .on:hover { color: var(--white); }
    #page .first, #page .prev, #page .next ,#page .last { width: 20px; height: 40px; background: url('../../img/common/arrow.png') no-repeat; vertical-align: top; }
    #page .first { background-position: -40px 8px; }
    #page .prev  { background-position: 0px 8px; margin: 0 2% 0 0; }
    #page .next  { background-position: -20px 8px; margin: 0 0 0 2%; }
    #page .last  { background-position: -60px 8px; }

/* -- 검색 -- */
.board_search    { width: 45%; margin: 0 auto; padding: 3% 0 0 0; text-align: center; }
    .board_search ul { font-size: 0; }
    .board_search ul li { display: inline-block; width: 25%; padding: 0 1px; font-size: 16px; vertical-align: middle; }
    .board_search ul li:nth-child(2) { width: 50%; }
    .board_search input, .board_search select{ border-radius: 5px; }
    @media (max-width:991px) {
        .board_search       { width: 95%; margin: 0 auto; }
        .board_search ul li { font-size: 14px; }
    }
    @media (max-width:767px) {
        .board_search ul li { font-size: 12px; }
    }

/* -- 지도 -- */
.map_box { height: 750px; }
.map_add { padding: 30px 0; color: var(--white); background: var(--PU-28); }
    .map_add ul { display: flex; justify-content: center; gap: 10px 20px; font-weight: 600; }
@media (max-width:767px) {
    .map_add { padding: 15px; }
    .map_add ul { flex-wrap: wrap; }
    .map_add li { width: 100%; }
}

.map_box01 { padding: 100px 0 0 0; border-bottom: 2px solid var(--BK-D3); }
    .map_box01 h3 { padding: 0 0 50px 0; text-align: center; font-weight: 700; }
    .map_box01 h3 span { display: inline-block; padding: 0 0 5px 0; border-bottom: 2px solid var(--PU-28); }

    .map_box01 table { border-top: 3px solid var(--PU-28); }
    .map_box01 th { width: 170px; padding: 10px 0; vertical-align: top; text-align: center; border-right: 20px solid var(--white); background: var(--BK-F2); }
    .map_box01 td { padding: 10px 20px; }
    .map_box01 tr:nth-child(2n+1) td { background: var(--BK-F2); }
    .map_box01 .bo { border-top: 1px solid var(--PU-28); }
    @media (max-width:767px) {
        .map_box01 { padding: 20px 0 0 0; }
        .map_box01 h3 { padding: 0 0 20px 0; text-align: center; font-weight: 700; }
        .map_box01 th { width: 100px; border-right: 10px solid var(--white); }
    }

    .map_box01 strong { display: block; padding: 0 0 20px 0; font-weight: 600; }
    .map_box01 p { position: relative; padding: 0 0 0 15px; }
    .map_box01 p:before { content: "ㆍ"; position: absolute; left: 0; }
    .map_box01 span { display: block; padding: 0 0 0 15px; }
    .map_box01 img { width: 58px; }

.map_box02 { padding: 100px 0 0 0; border-bottom: 2px solid var(--BK-D3); }
    .map_box02 h3 { padding: 0 0 50px 0; text-align: center; font-weight: 700; }
    .map_box02 h3 span { display: inline-block; padding: 0 0 5px 0; border-bottom: 1px solid var(--PU-28); }

    .map_box02 table { border-top: 3px solid var(--PU-28); }
    .map_box02 tr { background: var(--BK-F2); }
    .map_box02 tr:nth-child(3) { background: var(--white); }
    .map_box02 th,
    .map_box02 td { padding: 10px 20px; text-align: center; }
    .map_box02 .bo_b { border-bottom: 1px dashed var(--PU-28); }
    .map_box02 .bo_r { border-right: 20px dashed var(--BK-F2); }
    .map_box02 .bo_t { border-top: 1px solid var(--PU-28); }
    @media (max-width:767px) {
        .map_box02 { padding: 20px 0 0 0; }
        .map_box02 h3 { padding: 0 0 20px 0; }
        .map_box02 th,
        .map_box02 td { padding: 10px 5px; }
    }

.map_box03 { display: flex; flex-wrap: wrap; gap: 0 20px; padding: 30px 0 0 0; }
    .map_box03 h3 { width: 100%; padding: 0 0 50px 0; text-align: center; font-weight: 700; }
    .map_box03 h3 span { display: inline-block; padding: 0 0 5px 0; border-bottom: 1px solid var(--PU-28); }
    .map_box03 ul { width: calc(50% - 20px); padding: 10px 10px 0 10px; border-top: 2px solid var(--PU-28); }
    .map_box03 li { position: relative; padding-left: 20px; line-height: 2em; }
    .map_box03 li i { position: absolute; left: 0; }
    @media (max-width:991px) {
        .map_box03 h3 { padding: 0 0 20px 0; }
        .map_box03 ul { width: 100%; padding: 10px; }
    }

/* 참가업체 */
.company .cate { padding: 50px 0 3rem 0; }
.company .cate ul { display: flex; justify-content: center; flex-wrap: wrap; }
    .company .cate button { padding: 20px 50px; border: 1px solid var(--BK-EE); }
    .company .cate .on button,
    .company .cate button:hover { color: var(--white); border: 1px solid var(--PU-28); background: var(--PU-28); }

.company .list ul { display: flex; flex-wrap: wrap; gap: 20px; }
    .company .list li { width: calc(25% - 15px); }
    .company .list p { padding: 5px 10px 0 10px; text-align: center; }
    .company .list .no_data { width: 100%; text-align: center; }

    .company .btn_wrap { text-align: center; }
    .company .btn_wrap input { width: auto; padding: 0 70px; font-size: 1.2em; font-weight: 700; }
    .company .btn_wrap a { width: auto; padding: 0 70px; }
    @media (max-width:991px) {
        .company .cate { padding: 1rem 0; }
        .company .cate button { padding: 10px 10px; }
        .company .list ul { gap: 10px; }
        .company .list li { width: calc(50% - 10px); }
    }

.company .view { display: flex; flex-wrap: wrap; align-items: center; gap: 50px; padding: 50px 0 0 0; }
    .company .view div { display: flex; align-items: center; width: 40%; height: 300px; padding: 2rem; border: 1px solid var(--BK-BD); border-radius: 20px; overflow: hidden; }
    .company .view ul { display: flex; flex-direction: column; gap: 10px; width: calc(60% - 50px); }
    .company .view h1 { padding: 10px 0 0 0; font-weight: 800; }
    @media (max-width:991px) {
        .company .view { padding: 20px 0 0 0; }
        .company .view div { width: 100%; height: 270px; }
        .company .view ul { width: 100%; }
    }