/*<style type="text/css">*/

/* [기본 테이블 스타일 보존 - 글보기/글쓰기용] */
table.ej-tbl th {text-align:center; vertical-align:middle; background-color:#eee; font-weight:bold;}
table.ej-tbl td {text-align:left; vertical-align:middle;}
table.ej-tbl td a {display:inline-block; font-weight:normal;}
table.ej-tbl td a img {vertical-align:middle;}
table.ej-tbl .h5-center {text-align:center;}
table.ej-tbl .tbl-no-data {text-align:center;}
#ej-bbs-contents {word-break:break-all; word-wrap:break-word;}

table.ej-view-tbl {width:100% !important; margin:0 auto; padding:5px; font-size:1em; border-spacing:0; border:0; border-collapse:collapse; background:#fff;}
table.ej-view-tbl td, table.ej-view-tbl th {color:#555; padding:10px; border:1px solid #ddd;}
table.ej-view-tbl th {text-align:center; vertical-align:middle; background-color:#eee; font-weight:bold;}
table.ej-view-tbl td {text-align:left; vertical-align:middle;}
table.ej-view-tbl th:first-child {word-break:break-all; word-wrap:break-word;}

table.ej-write-tbl {width:100% !important; margin:0 auto; padding:5px; font-size:1em; border-spacing:0; border:0; border-collapse:collapse; background:#fff;}
table.ej-write-tbl td, table.ej-write-tbl th {color:#555; padding:10px; border:1px solid #ddd;}
table.ej-write-tbl th {text-align:center; vertical-align:middle; background-color:#eee; font-weight:bold;}
table.ej-write-tbl td {text-align:left; vertical-align:middle;}

@media screen and (max-width:980px) {
	table.ej-tbl colgroup{display:none;}
	table.ej-tbl tr, table.ej-tbl td {display:block; border:none;}
	table.ej-tbl td {text-align:left; font-size:1em;}
	table.ej-tbl .h5-center {text-align:left;}
	table.ej-tbl td:first-child {display:none;}
	table.ej-tbl td:nth-last-child(3), table.ej-tbl td:nth-last-child(2) {display:none;} 
	table.ej-tbl tr:not(:last-child) {border:1px dotted #ccc;}
	table.ej-tbl tr {margin:0 0 -1px;}
	table.ej-tbl tr:last-child {border:1px dotted #ccc; margin:0;}
	table.ej-tbl td:not(:first-child) {clear:both; margin:0 10px; padding:4px 30px 4px 60px; position:relative; text-align:left;}
	table.ej-tbl td:not(:first-child):before {color:#999; content:attr(data-cell-header); display:block; position:absolute; left:0; font-weight:normal;}
	table.ej-tbl tr {position:relative; padding:0;}
	table.ej-tbl tr:first-child {display:none;}
}

/* 
=========================================================================
🔥 [최종 완성형] 모던 통합 디자인 시스템 (전체 통합/무결성 체크 완료)
=========================================================================
*/

/* 1. Paperlogy 폰트 및 공통 요소 */
.modern-board-wrap { margin-top: 20px !important; border-top: none !important; font-family: 'Paperlogy', sans-serif !important; }
.modern-board-wrap * { font-family: 'Paperlogy', sans-serif !important; }
.fa, .fas, .far, [class^="fa-"] { font-family: "FontAwesome" !important; }

/* 2. 카드형 리스트 레이아웃 */
.modern-list-item { display: flex !important; align-items: center !important; padding: 18px 20px !important; margin-bottom: 12px !important; background-color: #f8fafc !important; border: 1px solid #e2e8f0 !important; border-radius: 12px !important; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;}
.modern-list-item:hover { background-color: #ffffff !important; border-color: #00a2ff !important; box-shadow: 0 10px 25px rgba(0, 162, 255, 0.12) !important; transform: translateY(-3px) !important; z-index: 10 !important; }
.item-num { width: 55px !important; text-align: center !important; font-weight: 600 !important; color: #a0aec0 !important; font-size: 1rem !important; flex-shrink: 0 !important; }
.item-content { flex-grow: 1 !important; display: flex !important; justify-content: space-between !important; align-items: center !important; padding-left: 15px !important; }
.item-title { font-size: 1.05em !important; font-weight: 500 !important; color: #2d3748 !important; display: flex !important; align-items: center !important; flex-wrap: wrap !important;}
.item-title a { color: inherit !important; text-decoration: none !important; margin-right:8px !important; }

/* 3. 메타데이터 뱃지 스타일 (오와 열 고정 적용) */
.item-meta { 
    display: flex !important; 
    gap: 0 !important; 
    flex-shrink: 0 !important; 
    margin-left: 15px !important;
    align-items: center !important;
}

.meta-badge { 
    background-color: #edf2f7 !important; 
    color: #718096 !important; 
    padding: 5px 0 !important; 
    border-radius: 20px !important; 
    font-size: 0.85em !important; 
    display: inline-flex !important; 
    justify-content: center !important; 
    align-items: center !important; 
    font-weight: 500 !important; 
    margin-left: 8px !important;
}

.meta-badge[title="작성자"] { width: 90px !important; }
.meta-badge[title="등록일"] { width: 105px !important; }
.meta-badge[title="조회수"] { width: 80px !important; }
.meta-badge[title="조회수"] i { font-size: 0.9em !important; margin-right: 4px !important; }

/* 4. 노션 스타일 뱃지 디자인 (통일) */
.badge-new { background-color: #fff1f0 !important; color: #f5222d !important; border: 1px solid #ffa39e !important; font-size: 0.75rem !important; padding: 2px 6px !important; border-radius: 4px !important; font-weight: 700 !important; display: inline-block !important; margin-left: 5px !important; line-height: 1.2 !important; vertical-align: middle !important; }
.badge-hot { background-color: #fffbe6 !important; color: #faad14 !important; border: 1px solid #ffe58f !important; font-size: 0.75rem !important; padding: 2px 6px !important; border-radius: 4px !important; font-weight: 700 !important; display: inline-block !important; margin-left: 5px !important; line-height: 1.2 !important; vertical-align: middle !important; }
.badge-notice { background-color: #e6f7ff !important; color: #00a2ff !important; border: 1px solid #91d5ff !important; font-size: 0.85rem !important; padding: 3px 10px !important; border-radius: 4px !important; font-weight: 700 !important; display: inline-block !important; margin-left:9px !important;}
.badge-secret { color: #cbd5e0 !important; font-size: 1rem !important; margin-left: 6px !important; vertical-align: middle !important; }

/* 5. 검색 영역 수정 (중앙 정렬 동기화) */
.j-search-wrap { 
    margin-bottom: 25px !important; 
    display: flex !important; 
    justify-content: center !important; 
    align-items: center !important; 
    gap: 0 !important; 
    float: none !important; 
    clear: both !important;
}

.j-search-wrap input[type="image"] {
    display: none !important;
}

.j-search-wrap fieldset { border: none !important; padding: 0 !important; margin: 0 !important; }
.j-search-wrap dl { display: flex !important; align-items: center !important; margin: 0 !important; }
.j-search-wrap dl dt { display: none !important; }
.j-search-wrap dl dd { margin: 0 !important; padding: 0 3px !important; }

.j-search-wrap select.bbs-s, 
.j-search-wrap input.bbs-i[type="text"] { 
    height: 42px !important; 
    border: 1px solid #cbd5e0 !important; 
    border-radius: 8px !important; 
    padding: 0 15px !important; 
    background: #fff !important; 
    font-size: 0.95em !important;
}
.modern-search-btn { 
    height: 42px !important; 
    padding: 0 25px !important; 
    border-radius: 8px !important; 
    background-color: #00a2ff !important; 
    color: #fff !important; 
    font-weight: 700 !important; 
    border: none !important; 
    cursor: pointer !important; 
    white-space: nowrap !important;
    transition: all 0.2s !important;
    display: inline-block !important;
}
.modern-search-btn:hover { background-color: #0077ff !important; box-shadow: 0 4px 12px rgba(0, 162, 255, 0.3) !important;  }

/* 6. 관리자 버튼 디자인 */
.renewal-btn-wrap { margin-top: 25px !important; padding-bottom: 30px !important; }
.btn-renewal { 
    background-color: #fff !important; color: #00a2ff !important; border: 1px solid #00a2ff !important; 
    padding: 7px 22px !important; border-radius: 25px !important; font-weight: 600 !important; 
    font-size: 0.9em !important; text-decoration: none !important; display: inline-block !important; transition: all 0.3s !important;
}
.btn-renewal:hover { background-color: #00a2ff !important; color: #fff !important; box-shadow: 0 4px 15px rgba(0, 162, 255, 0.4) !important; }

/* 7. 페이지네이션 버그 수정 */
.j-board-paging { 
    clear:both !important; 
    margin: 40px 0 !important; 
    display: flex !important; 
    justify-content: center !important; 
    overflow: visible !important; 
    height: auto !important;
    padding: 10px 0 !important;
    opacity: 0 ; 
    transition: opacity 0.3s ease ;
    position: relative !important;
    z-index: 10 !important;
    pointer-events: auto !important;
}
.j-board-paging ul { position: static !important; left: auto !important; float: none !important; display: inline-flex !important; gap: 8px !important; margin: 0 auto !important; padding: 0 !important; border: none !important; background: transparent !important; list-style: none !important;}
.j-board-paging ul li { position: static !important; left: auto !important; float: none !important; margin: 0 !important; padding: 0 !important; display: block !important; }

.j-board-paging ul li a, 
.j-board-paging ul li strong, 
.j-board-paging ul li span { 
    display: inline-flex !important; 
    justify-content: center !important; 
    align-items: center !important; 
    min-width: 40px !important; 
    height: 40px !important; 
    border: 1px solid #e2e8f0 !important; 
    border-radius: 10px !important; 
    color: #4a5568 !important; 
    text-decoration: none !important; 
    font-size: 1rem !important; 
    transition: all 0.2s !important; 
    background: #fff !important; 
    font-family: 'Paperlogy', sans-serif !important; 
    text-indent: 0 !important; 
    background-image: none !important; 
    line-height: 1 !important;
    cursor: pointer !important;
}
.j-board-paging ul li strong { background-color: #00a2ff !important; color: #fff !important; border-color: #00a2ff !important; box-shadow: 0 4px 12px rgba(0, 162, 255, 0.3) !important; font-weight: 700 !important; }
.j-board-paging ul li a:hover { border-color: #00a2ff !important; color: #00a2ff !important; background-color: #f0f9ff !important; transform: translateY(-3px) !important; z-index: 20 !important; }
.j-board-paging ul li span { opacity: 0.4 !important; background-color: #f8fafc !important; cursor: default !important; }

/* 8. 답글(RE) 아이콘 및 들여쓰기 리뉴얼 */
/* CMS가 뿌리는 re 이미지를 감지하여 현대적인 SVG 화살표로 교체 */
.item-title img[src*="re"] { 
    width: 0 !important; 
    height: 16px !important; 
    padding-left: 20px !important; 
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23cbd5e0' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.5 1.5A.5.5 0 0 0 1 2v4.8a2.5 2.5 0 0 0 2.5 2.5h9.793l-3.347 3.346a.5.5 0 0 0 .708.708l4.2-4.2a.5.5 0 0 0 0-.708l-4-4a.5.5 0 0 0-.708.708L13.293 8.3H3.5A1.5 1.5 0 0 1 2 6.8V2a.5.5 0 0 0-.5-.5z'/%3E%3C/svg%3E") no-repeat center left !important;
    margin-right: 5px !important;
    display: inline-block !important;
    vertical-align: middle !important;
}

/* 답글일 경우 카드를 오른쪽으로 약간 들여쓰기 하여 계층 표현 */
/* CSS Selector 레벨 4의 :has() 기능을 사용하거나, 이미지 존재 여부로 간접 제어 */
.modern-list-item:has(img[src*="re"]) {
    padding-left: 45px !important;
    background-color: #ffffff !important; /* 답글은 배경을 흰색으로 하여 차별화 */
}

/* 📱 [모바일 전용 레이아웃 수술] - 768px 이하 기기 */
@media screen and (max-width: 768px) {
    /* 1. 전체 카드 구조를 세로형으로 변경 */
    .modern-list-item {
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 15px !important;
        gap: 10px !important;
    }

    /* 2. 번호(ID) 영역: 상단에 작게 배치 */
    .item-num {
        width: 100% !important;
        text-align: left !important;
        font-size: 0.8em !important;
        color: #cbd5e0 !important;
        margin-bottom: -5px !important;
    }

    /* 3. 콘텐츠 영역: 폭 100% 확보 */
    .item-content {
        width: 100% !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        padding-left: 0 !important;
    }

    /* 4. 제목 영역: 세로 정렬 방지 및 폭 100% */
    .item-title {
        width: 100% !important;
        font-size: 1rem !important;
        line-height: 1.5 !important;
        display: block !important; /* 세로 쓰기 방지 */
        margin-bottom: 8px !important;
        white-space: normal !important; /* 줄바꿈 허용 */
        word-break: break-all !important;
    }
    
    .item-title a {
        display: inline !important;
        margin-right: 5px !important;
    }

    /* 5. 메타데이터(작성자, 날짜 등): 하단에 나란히 배치 */
    .item-meta {
        width: 100% !important;
        margin-left: 0 !important;
        justify-content: flex-start !important;
        flex-wrap: wrap !important; /* 공간 부족시 자동 줄바꿈 */
        gap: 5px !important;
    }

    /* 🔥 [중요] 모바일에서는 고정 폭(90px, 105px 등)을 해제해야 함 */
    .meta-badge {
        width: auto !important; 
        min-width: 0 !important;
        margin-left: 0 !important;
        padding: 4px 10px !important;
        font-size: 0.75em !important;
    }

    /* 6. 검색창 모바일 최적화 */
    .j-search-wrap {
        flex-direction: column !important;
        gap: 10px !important;
    }
    .j-search-wrap select.bbs-s, 
    .j-search-wrap input.bbs-i[type="text"], 
    .modern-search-btn {
        width: 100% !important;
        margin: 0 !important;
    }

    /* 7. 페이지네이션 모바일 최적화 (버튼 크기 조정) */
    .j-board-paging ul {
        gap: 4px !important;
    }
    .j-board-paging ul li a, 
    .j-board-paging ul li strong {
        min-width: 32px !important;
        height: 32px !important;
        font-size: 0.9rem !important;
    }
}

/* 초소형 기기 (아이폰 SE 등) */
@media screen and (max-width: 380px) {
    .item-meta {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important; /* 2열 배치 */
        gap: 5px !important;
    }
    .meta-badge {
        width: 100% !important;
        justify-content: center !important;
    }
}