@charset "utf-8";
/**
 * Modern Clean UI Custom for KBoard (Gallery Version)
 */

/* ==============================================
   1. 글로벌 & 버튼 공통
============================================== */
a.kboard-default-button-small,
input.kboard-default-button-small,
button.kboard-default-button-small {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: 10px 20px;
    height: auto;
    font-size: 14px;
    font-weight: 500;
    color: #333 !important;
    background: #f4f5f7 !important;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    text-decoration: none !important;
    cursor: pointer;
    transition: all 0.3s ease;
    box-sizing: border-box;
}

a.kboard-default-button-small:hover,
input.kboard-default-button-small:hover,
button.kboard-default-button-small:hover {
    background: #111 !important;
    color: #fff !important;
    border-color: #111;
}

.kboard-default-poweredby { display: none; }
.kboard-default-new-notify { display: inline-block; padding: 2px 6px; line-height: 1; font-size: 11px; color: white; background-color: #ff4b4b; font-weight: bold; border-radius: 10px; margin-left: 5px; vertical-align: middle; }
.kboard-default-cut-strings { width: auto; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }

/* 하단 버튼 컨트롤 영역 (목록보기, 글쓰기 등 정렬) */
#kboard-default-list .kboard-control,
#kboard-default-document .kboard-control,
#kboard-default-editor .kboard-control { display: flex; justify-content: space-between; width: 100%; padding-top: 20px; clear: both; }
#kboard-default-list .kboard-control .left, #kboard-default-list .kboard-control .right,
#kboard-default-document .kboard-control .left, #kboard-default-document .kboard-control .right,
#kboard-default-editor .kboard-control .left, #kboard-default-editor .kboard-control .right { display: flex; gap: 5px; }


/* ==============================================
   2. 상단 정보 & 카테고리 & 검색 & 페이징
============================================== */
#kboard-default-list { width: 100%; font-family: inherit; }

/* 카테고리 탭 디자인 */
#kboard-default-list .kboard-category.category-mobile { display: none; }
#kboard-default-list .kboard-category.category-pc { display: block; margin-bottom: 20px; }
#kboard-default-list .kboard-category .kboard-category-list { display: flex; flex-wrap: wrap; gap: 10px; list-style: none; padding: 0; margin: 0; border: none; background: transparent; }
#kboard-default-list .kboard-category .kboard-category-list li { margin: 0; padding: 0; border: none; }
#kboard-default-list .kboard-category .kboard-category-list li::before,
#kboard-default-list .kboard-category .kboard-category-list li::after { display: none; }
#kboard-default-list .kboard-category .kboard-category-list li a { display: block; padding: 10px 20px; font-size: 15px; font-weight: 500; color: #666; background: #f4f5f7; border-radius: 30px; text-decoration: none; transition: all 0.2s; border: none; box-shadow: none; }
#kboard-default-list .kboard-category .kboard-category-list li.kboard-category-selected a,
#kboard-default-list .kboard-category .kboard-category-list li a:hover { background: #111; color: #fff; font-weight: 600; border: none; }

/* 리스트 헤더 (총 게시물 수, 정렬) */
#kboard-default-list .kboard-list-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 15px; border-bottom: 2px solid #222; margin-bottom: 20px; }
#kboard-default-list .kboard-list-header .kboard-total-count { font-size: 15px; color: #555; }
#kboard-default-list .kboard-list-header .kboard-sort select { padding: 5px 30px 5px 15px; font-size: 14px; border: 1px solid #ddd; border-radius: 6px; height: 38px; outline: none; }

/* 검색폼 */
#kboard-default-list .kboard-search { margin-top: 30px; text-align: center; display: flex; justify-content: center; gap: 5px; }
#kboard-default-list .kboard-search select,
#kboard-default-list .kboard-search input { height: 46px; padding: 0 15px; border: 1px solid #ddd; border-radius: 6px; font-size: 14px; outline: none; box-sizing: border-box; }
#kboard-default-list .kboard-search input { width: 250px; }

/* 페이징 */
#kboard-default-list .kboard-pagination { padding: 30px 0; text-align: center; }
#kboard-default-list .kboard-pagination .kboard-pagination-pages { display: inline-flex; gap: 5px; list-style: none; padding: 0; margin: 0; }
#kboard-default-list .kboard-pagination .kboard-pagination-pages li a { display: flex; justify-content: center; align-items: center; width: 36px; height: 36px; font-size: 14px; color: #666; background: #fff; border: 1px solid #ddd; border-radius: 6px; text-decoration: none; transition: all 0.2s; }
#kboard-default-list .kboard-pagination .kboard-pagination-pages li:hover a,
#kboard-default-list .kboard-pagination .kboard-pagination-pages li.active a { background: #111; color: #fff; border-color: #111; font-weight: bold; }


/* ==============================================
   3. 갤러리형 리스트 스타일 (PC: 1줄 4개)
============================================== */
#kboard-default-list .kboard-gallery-list { width: 100%; }
#kboard-default-list .kboard-gallery-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4열 배치 */
    gap: 20px; /* 아이템 간격 */
    list-style: none;
    padding: 0;
    margin: 0;
}

/* 개별 갤러리 아이템 디자인 */
#kboard-default-list .kboard-gallery-item {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

#kboard-default-list .kboard-gallery-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.08);
}

#kboard-default-list .kboard-gallery-item a {
    display: block;
    text-decoration: none;
    color: #111;
}

/* 썸네일 이미지 영역 */
#kboard-default-list .kboard-gallery-thumbnail {
    width: 100%;
    aspect-ratio: 4 / 3; /* 이미지 비율 4:3 고정 */
    background-color: #f4f5f7;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

#kboard-default-list .kboard-gallery-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 이미지가 찌그러지지 않고 꽉 차게 */
    transition: transform 0.3s ease;
}

#kboard-default-list .kboard-gallery-item:hover .kboard-gallery-thumbnail img {
    transform: scale(1.05); /* 호버 시 이미지 살짝 확대 */
}

/* 이미지가 없을 때 대체 텍스트 */
#kboard-default-list .kboard-no-image {
    color: #999;
    font-size: 14px;
    font-weight: 500;
}

/* 텍스트 정보 영역 */
#kboard-default-list .kboard-gallery-info {
    padding: 15px;
}

#kboard-default-list .kboard-gallery-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    line-height: 1.4;
}

#kboard-default-list .kboard-gallery-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: #888;
}


/* ==============================================
   4. 글쓰기 에디터
============================================== */
#kboard-default-editor { padding: 20px 0; }
#kboard-default-editor .kboard-attr-row { display: flex; align-items: center; margin-bottom: 15px; border-bottom: none; background: transparent; padding: 0; }
#kboard-default-editor .kboard-attr-row .attr-name { width: 120px; font-size: 15px; font-weight: 600; color: #111; flex-shrink: 0; }
#kboard-default-editor .kboard-attr-row .attr-value { flex: 1; min-width: 0; margin: 0; }

#kboard-default-editor select,
#kboard-default-editor .kboard-attr-row .attr-value input[type=text],
#kboard-default-editor .kboard-attr-row .attr-value input[type=password] { width: 100%; height: 46px; padding: 0 15px; font-size: 15px; border: 1px solid #e5e7eb; border-radius: 8px; background-color: #fff; transition: all 0.3s; box-sizing: border-box; }
#kboard-default-editor .kboard-attr-row .attr-value input:focus { border-color: #111; outline: none; }

#kboard-default-editor .kboard-attr-row .attr-value label { display: inline-flex; align-items: center; margin-right: 15px; cursor: pointer; font-size: 14px; color: #555; }
#kboard-default-editor .kboard-attr-row .attr-value input[type=checkbox],
#kboard-default-editor .kboard-attr-row .attr-value input[type=radio] { margin-right: 6px; width: 16px; height: 16px; cursor: pointer; }
#kboard-default-editor .kboard-attr-row .attr-value input[type=file] { padding: 10px 0; font-size: 14px; width: 100%; }

#kboard-default-editor .kboard-content { margin-top: 10px; width: 100%; }
#kboard-default-editor .kboard-content .editor-textarea { width: 100%; min-height: 350px; border: 1px solid #e5e7eb; border-radius: 8px; padding: 15px; box-sizing: border-box; font-size: 15px; resize: vertical; outline: none; }


/* ==============================================
   5. 게시글 본문 (상세페이지)
============================================== */
#kboard-default-document { padding: 20px 0; }
#kboard-default-document .kboard-title h1 { font-size: 32px; font-weight: 700; color: #111; margin: 0 0 20px 0; line-height: 1.3; letter-spacing: -1px; }

#kboard-default-document .kboard-detail { display: flex; flex-wrap: wrap; align-items: center; padding: 18px 25px; background: #f8f9fa; border-radius: 8px; border: none; margin-bottom: 30px; }
#kboard-default-document .kboard-detail .detail-attr { display: flex; margin-right: 30px; font-size: 14px; color: #555; padding: 0; }
#kboard-default-document .kboard-detail .detail-attr .detail-name { font-weight: 600; color: #111; margin-right: 8px; float: none; }
#kboard-default-document .kboard-detail .detail-attr .detail-value { color: #666; float: none; padding: 0; }

#kboard-default-document .kboard-content { min-height: 300px; padding: 0; }
#kboard-default-document .kboard-content .content-view { font-size: 16px; line-height: 1.8; color: #333; margin: 0; padding: 20px 0; }
#kboard-default-document .kboard-content .content-view img { max-width: 1200px; border-radius: 8px; }

#kboard-default-document .kboard-attach { background: #fcfcfc; border: 1px solid #eee; border-radius: 8px; padding: 15px 20px; margin-top: 40px; font-size: 14px; }

#kboard-default-document .kboard-document-action { display: none; justify-content: space-between; align-items: center; margin-top: 20px; padding: 0; }
#kboard-default-document .kboard-button-action { background: #fff; border: 1px solid #e5e7eb; padding: 8px 16px; border-radius: 30px; font-size: 13px; font-weight: 500; color: #555; cursor: pointer; transition: 0.2s; display: inline-flex; align-items: center; gap: 5px; margin: 0 5px 0 0; }
#kboard-default-document .kboard-button-action:hover { background: #f4f5f7; border-color: #d1d1d1; color: #111; }

#kboard-default-document .kboard-document-navi { border-top: 1px solid #eee; padding-top: 20px; margin-top: 40px; display: flex; justify-content: space-between; }
#kboard-default-document .kboard-document-navi a { font-size: 15px; color: #555; }
#kboard-default-document .kboard-document-navi a:hover { color: #111; font-weight: bold; }


/* ==============================================
   6. 모바일 반응형 (767px 이하)
============================================== */
@media screen and (max-width: 767px) {
    
    /* 모바일 카테고리 (셀렉트 박스 형태 유지) */
    #kboard-default-list .kboard-category.category-mobile { display: block; margin-bottom: 20px; }
    #kboard-default-list .kboard-category.category-pc { display: none; }
    #kboard-default-list .kboard-category select { width: 100%; height: 46px; border-radius: 8px; border: 1px solid #e5e7eb; padding: 0 15px; font-size: 15px; }
    
    /* 모바일 리스트 헤더 */
    #kboard-default-list .kboard-list-header { flex-direction: column; align-items: flex-start; gap: 10px; padding-bottom: 10px; }
    #kboard-default-list .kboard-list-header .kboard-sort { width: 100%; text-align: left; }

    /* ★ 갤러리 모바일 최적화 (1줄 2개) */
    #kboard-default-list .kboard-gallery-container {
        grid-template-columns: repeat(2, 1fr); /* 2열 배치로 변경 */
        gap: 12px; /* 간격을 살짝 좁힘 */
    }

    #kboard-default-list .kboard-gallery-info {
        padding: 12px;
    }

    #kboard-default-list .kboard-gallery-title {
        font-size: 14px; /* 글씨 크기 약간 축소 */
        margin-bottom: 8px;
    }

    #kboard-default-list .kboard-gallery-meta {
        font-size: 12px;
        flex-direction: column; /* 작성자와 날짜를 위아래로 분리 */
        align-items: flex-start;
        gap: 4px;
    }

    /* 모바일 검색창 */
    #kboard-default-list .kboard-search { flex-direction: column; width: 100%; }
    #kboard-default-list .kboard-search select, #kboard-default-list .kboard-search input, #kboard-default-list .kboard-search button { width: 100%; margin-bottom: 5px; height: 46px; }

    /* 모바일 글쓰기 에디터 */
    #kboard-default-editor .kboard-attr-row { flex-direction: column; align-items: flex-start; }
    #kboard-default-editor .kboard-attr-row .attr-name { margin-bottom: 8px; }
    #kboard-default-editor .kboard-attr-row .attr-value { width: 100%; }

    /* 모바일 상세페이지 */
    #kboard-default-document .kboard-title h1 { font-size: 24px; }
    #kboard-default-document .kboard-detail { flex-direction: column; align-items: flex-start; padding: 15px; }
    #kboard-default-document .kboard-detail .detail-attr { margin-bottom: 5px; }
	#kboard-default-document .kboard-content .content-view img { max-width: 100%; }
}



/* ==============================================
   7. 갤러리형 최신글(latest) 추가 스타일
============================================== */
#kboard-default-latest { width: 100%; font-family: inherit; margin-bottom: 30px; }

/* 최신글 헤더 (게시판 이름 및 더보기) */
#kboard-default-latest .kboard-latest-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 15px; padding-bottom: 10px; border-bottom: 2px solid #222; }
#kboard-default-latest .kboard-latest-title { margin: 0; font-size: 18px; font-weight: 600; }
#kboard-default-latest .kboard-latest-title a { color: #111; text-decoration: none; }
#kboard-default-latest .kboard-latest-more { font-size: 13px; color: #666; text-decoration: none; transition: 0.2s; }
#kboard-default-latest .kboard-latest-more:hover { color: #111; font-weight: bold; }

/* 최신글 갤러리 컨테이너 (기존 리스트와 동일한 Grid 구조 적용) */
#kboard-default-latest .kboard-gallery-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 1줄 4개 */
    gap: 20px;
    list-style: none;
    padding: 0;
    margin: 0;
}

/* 개별 아이템 디자인 공통화 */
#kboard-default-latest .kboard-gallery-item {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
#kboard-default-latest .kboard-gallery-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.08);
}
#kboard-default-latest .kboard-gallery-item a { display: block; text-decoration: none; color: #111; }

#kboard-default-latest .kboard-gallery-thumbnail {
    width: 100%;
    aspect-ratio: 4 / 3;
    background-color: #f4f5f7;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
#kboard-default-latest .kboard-gallery-thumbnail img {
    width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease;
}
#kboard-default-latest .kboard-gallery-item:hover .kboard-gallery-thumbnail img { transform: scale(1.05); }
#kboard-default-latest .kboard-no-image { color: #999; font-size: 14px; font-weight: 500; }

#kboard-default-latest .kboard-gallery-info { padding: 15px; }
#kboard-default-latest .kboard-gallery-title { font-size: 16px; font-weight: 600; margin-bottom: 10px; line-height: 1.4; }
#kboard-default-latest .kboard-gallery-meta { display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: #888; }

/* 갤러리 텍스트 영역 전체 좌측 정렬 강제 적용 */
#kboard-default-list .kboard-gallery-info,
#kboard-default-latest .kboard-gallery-info {
    text-align: left !important;
}

/* 갤러리 제목 좌측 정렬 및 텍스트 짤림 방지 보완 */
#kboard-default-list .kboard-gallery-title,
#kboard-default-latest .kboard-gallery-title {
    text-align: left !important;
}

#kboard-default-list .kboard-gallery-title .kboard-default-cut-strings,
#kboard-default-latest .kboard-gallery-title .kboard-default-cut-strings {
    text-align: left !important;
    display: block; /* 줄임표(...) 처리가 좌측부터 정상적으로 먹히도록 블록 요소로 지정 */
}

/* 모바일 반응형 (767px 이하: 1줄 2개) */
@media screen and (max-width: 767px) {
    #kboard-default-latest .kboard-gallery-container {
        grid-template-columns: repeat(2, 1fr); /* 모바일 2열 */
        gap: 12px;
    }
    #kboard-default-latest .kboard-gallery-info { padding: 12px; }
    #kboard-default-latest .kboard-gallery-title { font-size: 14px; margin-bottom: 8px; }
    #kboard-default-latest .kboard-gallery-meta { font-size: 12px; flex-direction: column; align-items: flex-start; gap: 4px; }
}








