/*<style type="text/css">*/

/* [1. 기본 시스템 스타일 보존 - 글보기/글쓰기용] */
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;}
}

/* 
=========================================================================
🔥 [최종 완성형] 모던 통합 디자인 시스템 (사용자 만족 100% 보존)
=========================================================================
*/

/* 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: 1 ; 
    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; }


/* 
=========================================================================
📱 [모바일 반응형 최적화] - 768px 이하 (기획 1번: 컴팩트 뷰 + 자동 줄바꿈)
=========================================================================
*/

/* (1) 브라우저 전체의 가로 스크롤을 물리적으로 완벽 차단 */
html, body {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

@media screen and (max-width: 768px) {
    /* (2) 카드 레이아웃: 가로 일렬 -> 세로 적층 구조로 변경 */
    .modern-list-item {
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 15px !important;
        gap: 10px !important;
    }

    /* 번호(ID) 영역 작게 위로 올림 */
    .item-num {
        width: 100% !important;
        text-align: left !important;
        font-size: 0.85em !important;
        margin-bottom: -5px !important;
    }

    /* 콘텐츠 영역 전체 폭 사용 */
    .item-content {
        width: 100% !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        padding-left: 0 !important;
    }

    /* 제목 영역: 글자가 세로로 서는 현상 방지 */
    .item-title {
        width: 100% !important;
        font-size: 1.05rem !important;
        display: block !important;
        margin-bottom: 10px !important;
        white-space: normal !important; /* 줄바꿈 허용 */
        word-break: break-all !important;
    }

    /* (3) 메타데이터 배지: 고정폭 해제 및 유연한 배치 */
    .item-meta {
        width: 100% !important;
        margin-left: 0 !important;
        justify-content: flex-start !important;
        flex-wrap: wrap !important; /* 넘치면 다음 줄로 */
        gap: 6px !important;
    }
    
    .meta-badge {
        width: auto !important; /* PC 고정폭 무력화 */
        min-width: 0 !important;
        padding: 4px 10px !important;
        margin-left: 0 !important;
        margin-right: 4px !important;
        font-size: 0.75em !important;
    }

    /* (4) 검색창 터치 최적화 */
    .j-search-wrap {
        flex-direction: column !important;
        width: 100% !important;
        padding: 0 10px !important;
        box-sizing: border-box !important;
        gap: 10px !important;
    }
    .j-search-wrap dl,
    .j-search-wrap select.bbs-s, 
    .j-search-wrap input.bbs-i[type="text"], 
    .modern-search-btn {
        width: 100% !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }

 /* (5) 페이지네이션 모바일 폭주 방지 (초소형 압축 뷰 - 10개 한줄에 다 넣기) */
    .j-board-paging {
        width: 100% !important;
        padding: 15px 0 !important; /* 양옆 여백을 완전히 없애서 공간 최대 확보 */
        box-sizing: border-box !important;
        justify-content: center !important; 
        overflow: hidden !important; /* 🔥 가로 스크롤 완전 물리적 차단 */
    }
    
    .j-board-paging ul {
        flex-wrap: nowrap !important; /* 🔥 무조건 한 줄 (줄바꿈 절대 금지) */
        justify-content: center !important;
        margin: 0 auto !important;
        gap: 2px !important; /* 버튼 사이 간격을 2px로 극한 축소 */
    }
    
    /* 모바일용 버튼 크기 초소형(Micro) 압축 */
    .j-board-paging ul li a, 
    .j-board-paging ul li strong, 
    .j-board-paging ul li span {
        min-width: 22px !important; /* 기존 40px -> 22px로 대폭 축소 */
        height: 28px !important;    /* 기존 40px -> 28px로 대폭 축소 */
        font-size: 0.75rem !important; /* 글씨 크기 축소 */
        border-radius: 4px !important; /* 둥근 모서리도 작게 */
        padding: 0 !important; /* 내부 패딩 완전히 제거 */
        letter-spacing: -0.5px !important; /* 숫자 자간 좁힘 */
    }

    /* 화살표 아이콘 크기 미세 조정 */
    .j-board-paging ul li i {
        font-size: 0.7rem !important;
    }
}