/* 지식관리 > 메뉴관리 전용 스타일 (공통 레이아웃 톤 유지) */

.km-page {
    min-width: 0;
}

.km-breadcrumb {
    font-size: 13px;
    color: #666;
    margin-bottom: 8px;
}

.km-search-wrap {
    background: #fff;
    border: 1px solid var(--layout-content-border, #e0e0e0);
    border-radius: 6px;
    padding: 16px 20px;
    margin-bottom: 12px;
}

.km-search-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 16px;
}

.km-label {
    font-size: 13px;
    color: #333;
    white-space: nowrap;
}

.km-readonly-text {
    font-size: 13px;
    color: #1a1a1a;
    font-weight: 600;
}

.km-select,
.km-input {
    padding: 6px 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 13px;
    min-width: 100px;
}

.km-input {
    width: 140px;
}

.km-btn {
    padding: 6px 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 13px;
    cursor: pointer;
    background: #fff;
    color: #333;
}

.km-btn:hover:not(:disabled) {
    background: #f0f0f0;
    border-color: #bbb;
}

.km-btn-search {
    background: var(--layout-sidebar-active-bg, #1abc9c);
    color: #fff;
    border-color: var(--layout-sidebar-active-bg, #1abc9c);
}

.km-btn-search:hover {
    background: #16a085;
    border-color: #16a085;
    color: #fff;
}

.km-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    margin-bottom: 12px;
}

.km-btn-action {
    background: #ecf0f1;
    border-color: #bdc3c7;
}

.km-result-wrap {
    padding: 16px 20px;
}

/* 목록 영역(wrapper) 기준 스크롤 - 메뉴관리/지식관리 공통. 검색/버튼/건수/목록영역/페이징 구조 통일 */
.km-result-wrap .km-list-area {
    max-height: 60vh;
    overflow-y: auto;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.km-result-wrap .km-list-area .table-wrap {
    min-width: 0;
}

/* 목록 영역 스크롤 시 thead 고정 */
.km-result-wrap .km-list-area .km-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: #f8f9fa;
    box-shadow: 0 1px 0 #e0e0e0;
}

.km-result-info {
    font-size: 13px;
    color: #666;
    margin-bottom: 12px;
}

.km-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.km-table th,
.km-table td {
    padding: 10px 12px;
    border: 1px solid #e0e0e0;
    text-align: left;
}

.km-table th {
    background: #f8f9fa;
    font-weight: 600;
    color: #2c3e50;
}

.km-table tbody tr:hover {
    background: #fafafa;
}

.km-link-screen,
.km-link-view {
    color: #3498db;
    text-decoration: none;
}

.km-link-screen:hover,
.km-link-view:hover {
    text-decoration: underline;
}

.km-page mark,
.km-table mark {
    background: #fff3bf;
    padding: 0 1px;
    border-radius: 2px;
}

.km-no-data {
    text-align: center;
    padding: 32px 16px;
    color: #666;
    font-size: 14px;
    margin: 0;
}

/* 업체 등록/수정 팝업 폼 테이블 */
.company-popup-form-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.company-popup-form-table th,
.company-popup-form-table td {
    padding: 10px 12px;
    border: 1px solid #e0e0e0;
    text-align: left;
    vertical-align: middle;
}
.company-popup-form-table th {
    background: #f8f9fa;
    font-weight: 600;
    color: #2c3e50;
    width: 120px;
}
.company-popup-radio {
    margin-right: 12px;
    font-weight: normal;
    cursor: pointer;
}
.company-popup-remark {
    min-height: 80px;
}
#companyPopupModal .error-msg {
    color: #c00;
    font-size: 13px;
}
#userPopupModal .error-msg {
    color: #c00;
    font-size: 13px;
}

/* ---------- 사용자 등록/수정 팝업 전용: 가로폭 확대 ----------
   desktop 940px, 작은 화면은 calc(100vw - 48px)로 반응형 축소 */
.user-popup-modal .user-popup-modal-card {
    width: 940px;
    max-width: calc(100vw - 48px);
    min-width: 320px;
}
.user-popup-modal .menu-create-modal-body,
.user-popup-modal .company-popup-form-table,
.user-popup-modal .company-popup-form-table th,
.user-popup-modal .company-popup-form-table td {
    box-sizing: border-box;
}
.user-popup-modal .company-popup-form-table {
    width: 100%;
}
.user-popup-modal .company-popup-remark {
    width: 100%;
    min-height: 80px;
    box-sizing: border-box;
}

.km-paging {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 4px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #eee;
}

.km-page-link {
    display: inline-block;
    min-width: 32px;
    padding: 6px 10px;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 4px;
    color: #333;
    text-decoration: none;
    font-size: 13px;
    background: #fff;
}

.km-page-link:hover:not(.disabled) {
    background: #f0f0f0;
    border-color: #bbb;
}

.km-page-link.active {
    background: var(--layout-sidebar-active-bg, #1abc9c);
    color: #fff;
    border-color: var(--layout-sidebar-active-bg, #1abc9c);
}

.km-page-link.disabled {
    pointer-events: none;
    opacity: 0.6;
    cursor: default;
}

/* 메뉴 등록 팝업 (공통 모달 패턴 재사용) */
.menu-create-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 16px;
    box-sizing: border-box;
}

.menu-create-modal.is-open {
    display: flex;
}

.menu-create-modal-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: default;
}

.menu-create-modal-card {
    position: relative;
    width: 96vw;
    max-width: 1400px;
    min-width: 320px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    margin: auto;
}

.menu-create-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e0e0e0;
    flex-shrink: 0;
}

.menu-create-modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.menu-create-modal-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}

.menu-create-modal-close:hover {
    background: #f0f0f0;
    color: #333;
}

/* ========== 공통 그리드 편집 팝업 (메뉴등록/수정/일괄수정, 지식등록/일괄수정) ==========
   - 팝업 전체 세로 스크롤 없음(overflow hidden)
   - 세로 스크롤은 그리드 영역 1개만
   - 가로 스크롤은 그리드 안쪽
   - 상단 검색/안내/툴바, 하단 버튼 고정
   - .grid-edit-modal 클래스를 모달 루트에 부여 */
.menu-create-modal.grid-edit-modal .menu-create-modal-card,
.menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-modal-card {
    max-height: 90vh;
}
.menu-create-modal.grid-edit-modal .menu-create-modal-body,
.menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-modal-body,
.knowledge-bulk-edit-modal.grid-edit-modal .menu-create-modal-body {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.menu-create-modal.grid-edit-modal .menu-create-solution,
.menu-create-modal.grid-edit-modal .menu-create-toolbar,
.menu-create-modal.grid-edit-modal .knowledge-create-header-row,
.menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-search,
.menu-create-modal.grid-edit-modal .knowledge-bulk-edit-search,
.menu-create-modal.grid-edit-modal .menu-create-toolbar:first-of-type,
.knowledge-bulk-edit-modal.grid-edit-modal .menu-create-toolbar {
    flex-shrink: 0;
}
/* 그리드 wrapper: 남는 높이 차지, 최소 380px (메뉴등록 기준), 스크롤은 그리드 내부만 */
.menu-create-modal.grid-edit-modal .menu-create-grid-wrap,
.menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-grid-wrap,
.knowledge-bulk-edit-modal.grid-edit-modal .menu-create-grid-wrap {
    flex: 1;
    min-height: 380px;
    min-width: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    -webkit-overflow-scrolling: touch;
}
.menu-create-modal.grid-edit-modal .menu-create-grid-wrap > div,
.menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-grid-wrap > div,
.knowledge-bulk-edit-modal.grid-edit-modal .menu-create-grid-wrap > div {
    width: 100%;
    height: 100%;
    min-width: 0;
}

.menu-create-modal-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 16px 20px;
}

.menu-create-solution {
    margin: 0 0 12px 0;
    font-size: 13px;
    color: #444;
}

.menu-create-solution #menuCreateProductNm {
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
}

.menu-create-notice {
    margin: 0;
    font-size: 12px;
    color: #666;
}

.menu-create-toolbar {
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.menu-create-toolbar-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
}

.menu-create-grid-wrap {
    height: 380px;
    min-height: 240px;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    overflow-x: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
/* grid-edit-modal 내부는 위 규칙 대신 공통 그리드 편집 블록에서 제어 */

/* 메뉴등록 그리드: 화면명 컬럼 너비 확대 (Toast UI Grid) */
#menuCreateGridContainer {
    min-width: 1280px;
}
#menuCreateGridContainer [data-column-name="screenNm"],
#menuCreateGridContainer .tui-grid-cell[data-column-name="screenNm"] {
    min-width: 220px !important;
    width: 220px !important;
}

#knowledgeCreateGridContainer {
    min-width: 1100px;
}

/* Toast UI Grid: 사용여부/화면타입 select 에디터가 셀 안에 들어가도록 보정 (메뉴등록·일괄수정 공통) */
#menuCreateGridContainer .tui-grid select,
#menuBulkEditGridContainer .tui-grid select,
#knowledgeCreateGridContainer .tui-grid select,
.menu-create-grid-wrap .tui-grid select,
.menu-bulk-edit-grid-wrap .tui-grid select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 4px 24px 4px 8px;
    margin: 0;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 13px;
    background-color: #fff;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 6px center;
}
#menuCreateGridContainer .tui-grid-cell[data-column-name="useYn"],
#menuCreateGridContainer .tui-grid-cell[data-column-name="screenType"],
#menuBulkEditGridContainer .tui-grid-cell[data-column-name="useYn"],
#menuBulkEditGridContainer .tui-grid-cell[data-column-name="screenType"] {
    min-width: 100px;
    overflow: hidden;
    text-align: center;
}
#menuCreateGridContainer .tui-grid-cell[data-column-name="useYn"] .tui-grid-cell-content,
#menuCreateGridContainer .tui-grid-cell[data-column-name="screenType"] .tui-grid-cell-content,
#menuBulkEditGridContainer .tui-grid-cell[data-column-name="useYn"] .tui-grid-cell-content,
#menuBulkEditGridContainer .tui-grid-cell[data-column-name="screenType"] .tui-grid-cell-content {
    justify-content: center;
    text-align: center;
}
/* 에디터 레이어 내 select가 셀 너비를 넘지 않게 */
#menuCreateGridContainer .tui-grid-layer-editing select,
#menuBulkEditGridContainer .tui-grid-layer-editing select,
#menuCreateGridContainer .tui-grid-cell-editor select,
#menuBulkEditGridContainer .tui-grid-cell-editor select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* 메뉴 자동완성 드롭다운 (그리드 편집 시) */
.menu-autocomplete-dropdown {
    position: fixed;
    z-index: 10050;
    min-width: 120px;
    max-height: 240px;
    overflow-y: auto;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    list-style: none;
    margin: 0;
    padding: 4px 0;
    font-size: 13px;
}

.menu-autocomplete-dropdown li {
    padding: 8px 12px;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.menu-autocomplete-dropdown li:hover,
.menu-autocomplete-dropdown li.selected,
.menu-autocomplete-dropdown li.active {
    background: #f0f7ff;
    color: #1a1a1a;
}

.menu-autocomplete-dropdown li.empty {
    cursor: default;
    color: #888;
}

.menu-autocomplete-dropdown li.empty:hover {
    background: transparent;
}

.menu-create-modal-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding: 16px 20px;
    border-top: 1px solid #e0e0e0;
    flex-shrink: 0;
}

.km-attach-link {
    color: #3498db;
    text-decoration: none;
}

.km-attach-link:hover {
    text-decoration: underline;
}

.km-grid-del-btn {
    padding: 2px 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    font-size: 12px;
}

.km-grid-del-btn:hover {
    background: #f0f0f0;
}

/* 지식 등록 팝업: 상단 솔루션 + 라디오 + 버튼 한 줄 */
.knowledge-create-header-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px 24px;
    margin-bottom: 12px;
}
.knowledge-create-header-row .menu-create-solution {
    margin: 0;
}
.knowledge-create-radio-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
}
.knowledge-create-radio-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: #333;
    cursor: pointer;
}
.knowledge-create-radio-label input { cursor: pointer; }

/* 지식 답변 입력 팝업 */
.knowledge-answer-textarea {
    width: 100%;
    min-height: 200px;
    padding: 10px 12px;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    font-size: 13px;
    font-family: inherit;
    resize: vertical;
    box-sizing: border-box;
}

/* 예시질문 팝업 (AC12003) */
.knowledge-question-notice .required-asterisk {
    color: #c00;
    margin-right: 2px;
}
.knowledge-question-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-top: 12px;
}
.knowledge-question-label {
    flex-shrink: 0;
    width: 80px;
    font-size: 13px;
    color: #333;
    line-height: 32px;
}
.knowledge-question-field {
    flex: 1;
    min-width: 0;
}
.knowledge-question-field .knowledge-answer-textarea {
    min-height: 180px;
}

/* 연결화면 선택 팝업 (AC12004) */
.knowledge-screen-select-search .km-label { margin-right: 4px; }
.knowledge-screen-select-solution {
    font-weight: 600;
    color: #1a1a1a;
    margin-right: 12px;
}
.knowledge-screen-select-result-wrap {
    max-height: 220px;
    overflow-y: auto;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    margin-bottom: 16px;
}
.knowledge-screen-select-result-table-wrap { margin: 0; }
.knowledge-screen-select-result-table-wrap .km-table { margin: 0; }
.knowledge-screen-select-selected-wrap { margin-top: 12px; }
.knowledge-screen-select-selected-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 8px 0;
    color: #333;
}
.knowledge-screen-select-selected-wrap .km-table td {
    vertical-align: middle;
}
.knowledge-screen-select-selected-wrap .km-btn-order {
    padding: 2px 8px;
    min-width: 32px;
    font-size: 12px;
}

/* 이미지 첨부 팝업 (AC11003) */
.image-attach-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 10000;
    align-items: center;
    justify-content: center;
    padding: 16px;
    box-sizing: border-box;
}

.image-attach-modal.is-open {
    display: flex;
}

.image-attach-modal-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: default;
}

.image-attach-modal-card {
    position: relative;
    width: 100%;
    max-width: 420px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    overflow: hidden;
}

.image-attach-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e0e0e0;
}

.image-attach-modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.image-attach-modal-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}

.image-attach-modal-close:hover {
    background: #f0f0f0;
    color: #333;
}

.image-attach-modal-body {
    padding: 20px;
}

.image-attach-row {
    display: flex;
    align-items: center;
    margin-bottom: 12px;
}

.image-attach-row:last-of-type {
    margin-bottom: 0;
}

.image-attach-label {
    width: 80px;
    flex-shrink: 0;
    font-size: 13px;
    color: #333;
}

.image-attach-field {
    flex: 1;
    min-width: 0;
}

.image-attach-filename-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
}

.image-attach-filename {
    font-size: 13px;
    color: #444;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.image-attach-remove {
    width: 24px;
    height: 24px;
    padding: 0;
    border: none;
    background: #f0f0f0;
    color: #666;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    border-radius: 4px;
    flex-shrink: 0;
}

.image-attach-remove:hover {
    background: #e0e0e0;
    color: #333;
}

.image-attach-modal-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding: 16px 20px;
    border-top: 1px solid #e0e0e0;
}

/* 메뉴 일괄수정 팝업 (AC11004) - 메뉴등록과 동일 레이아웃 */
.menu-bulk-edit-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 16px;
    box-sizing: border-box;
}
.menu-bulk-edit-modal.is-open {
    display: flex;
}
.menu-bulk-edit-modal-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: default;
}
.menu-bulk-edit-modal-card {
    position: relative;
    width: 96vw;
    max-width: 1400px;
    min-width: 320px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    margin: auto;
}
.menu-bulk-edit-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e0e0e0;
    flex-shrink: 0;
}
.menu-bulk-edit-modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}
.menu-bulk-edit-modal-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}
.menu-bulk-edit-modal-close:hover {
    background: #f0f0f0;
    color: #333;
}
.menu-bulk-edit-modal-body {
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
}
.menu-bulk-edit-solution-inline {
    font-size: 13px;
    color: #444;
    white-space: nowrap;
    margin-right: 4px;
}
.menu-bulk-edit-solution-inline #menuBulkEditProductNmVal {
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
}
.menu-bulk-edit-search {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 16px;
    margin-bottom: 12px;
    flex-shrink: 0;
}
.menu-bulk-edit-search .km-input {
    width: 140px;
    min-width: 100px;
}
.menu-bulk-edit-search.hide-in-single {
    display: none;
}
/* 그리드 팝업: 세로 스크롤은 이 wrapper 1개만 (body는 overflow hidden), 가로 스크롤 유지 */
.menu-bulk-edit-grid-wrap {
    width: 100%;
    flex: 1;
    min-height: 200px;
    min-width: 0;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    overflow: hidden;
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-direction: column;
}

#menuBulkEditGridContainer {
    width: 100%;
    height: 100%;
    min-width: 0;
}

/* Toast Grid 내부 가로 스크롤이 끝까지 가능하도록 */
#menuCreateGridContainer.tui-grid-container .tui-grid-content-area,
#menuCreateGridContainer .tui-grid-rside-area,
#menuBulkEditGridContainer.tui-grid-container .tui-grid-content-area,
#menuBulkEditGridContainer .tui-grid-rside-area,
#knowledgeCreateGridContainer.tui-grid-container .tui-grid-content-area,
#knowledgeCreateGridContainer .tui-grid-rside-area,
#knowledgeBulkEditGridContainer.tui-grid-container .tui-grid-content-area,
#knowledgeBulkEditGridContainer .tui-grid-rside-area {
    overflow-x: auto !important;
}
.menu-bulk-edit-modal-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding: 16px 20px;
    border-top: 1px solid #e0e0e0;
    flex-shrink: 0;
}

/* 이미지 미리보기 팝업 (일괄수정 그리드 보기 클릭) */
.menu-image-preview-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 10010;
    align-items: center;
    justify-content: center;
    padding: 16px;
    box-sizing: border-box;
}
.menu-image-preview-modal.is-open {
    display: flex;
}
.menu-image-preview-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    cursor: default;
}
.menu-image-preview-card {
    position: relative;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    max-width: 90vw;
    max-height: 90vh;
}
.menu-image-preview-header {
    display: flex;
    justify-content: flex-end;
    padding: 8px 12px;
    border-bottom: 1px solid #eee;
}
.menu-image-preview-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}
.menu-image-preview-close:hover {
    background: #f0f0f0;
    color: #333;
}
.menu-image-preview-body {
    padding: 16px;
}

/* 이미지 미리보기 팝업 (새 fragment: 조회/일괄수정 공통) */
.menu-image-preview-modal-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    cursor: default;
}
.menu-image-preview-modal-card {
    position: relative;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    max-width: 90vw;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}
.menu-image-preview-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid #eee;
    flex-shrink: 0;
}
.menu-image-preview-modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}
.menu-image-preview-modal-close {
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}
.menu-image-preview-modal-close:hover {
    background: #f0f0f0;
    color: #333;
}
.menu-image-preview-modal-body {
    padding: 16px;
    overflow: auto;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 120px;
}
.menu-image-preview-image-wrap {
    text-align: center;
    max-width: 100%;
}
.menu-image-preview-image-wrap img {
    max-width: 100%;
    max-height: 70vh;
    width: auto;
    height: auto;
    display: block;
    margin: 0 auto;
}
.menu-image-preview-error {
    color: #c00;
    padding: 16px;
    font-size: 14px;
}
.menu-image-preview-modal-actions {
    padding: 12px 16px;
    border-top: 1px solid #e0e0e0;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    /* 조회화면 검색조건: 2열 배치, 세로 길이 최소화 */
    .km-search-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px 12px;
        align-items: center;
    }
    .km-search-row .km-select,
    .km-search-row .km-input {
        width: 100%;
        min-width: 0;
        max-width: none;
    }
    .km-search-row .km-btn-search {
        grid-column: 1 / -1;
        justify-self: start;
    }
    .km-search-wrap {
        padding: 12px 14px;
    }

    .km-table-wrap {
        overflow-x: auto;
    }

    /* 메뉴등록 팝업: 상단 기준 배치, 화면 밖으로 나가지 않게 */
    .menu-create-modal.is-open {
        align-items: flex-start;
        padding-top: 12px;
        padding-bottom: 12px;
        overflow-y: auto;
    }
    .menu-create-modal-card {
        position: relative;
        top: auto;
        left: auto;
        transform: none;
        width: 95%;
        max-width: 1200px;
        max-height: calc(100vh - 24px);
        margin: 0 auto;
    }
    .menu-create-modal-body {
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
    .menu-create-modal.grid-edit-modal .menu-create-modal-body,
    .knowledge-bulk-edit-modal.grid-edit-modal .menu-create-modal-body {
        overflow: hidden;
    }
    .menu-create-grid-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* 메뉴 일괄수정 팝업: 모바일 동일 대응 */
    .menu-bulk-edit-modal.is-open {
        align-items: flex-start;
        padding-top: 12px;
        padding-bottom: 12px;
        overflow-y: auto;
    }
    .menu-bulk-edit-modal-card {
        position: relative;
        top: auto;
        left: auto;
        transform: none;
        width: 95%;
        max-width: 1200px;
        max-height: calc(100vh - 24px);
        margin: 0 auto;
    }
    .menu-bulk-edit-modal-body {
        overflow: hidden;
    }
    .menu-bulk-edit-modal.grid-edit-modal .menu-bulk-edit-modal-body {
        overflow: hidden;
    }
    .menu-bulk-edit-grid-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* 그리드 셀 말줄임 (예: 솔루션관리 사이트 URL) */
.km-table .km-cell-ellipsis {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* 솔루션 팝업 API-KEY 영역: input과 생성 버튼 한 줄 배치 */
.api-key-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
}
.api-key-wrap input {
    flex: 1;
    min-width: 0;
}
/* readonly: 직접 입력 불가, 스타일은 기존 input과 동일하게 유지 */
.api-key-wrap input[readonly] {
    background-color: #fff;
    cursor: default;
    color: #333;
}
.api-key-wrap .btn-generate {
    white-space: nowrap;
}

/* 이력관리 > 응답 로그 조회 상세 팝업 (AC21001) */
.response-log-detail-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 16px;
    box-sizing: border-box;
}
.response-log-detail-modal.is-open {
    display: flex;
}
.response-log-detail-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: default;
}
.response-log-detail-card {
    position: relative;
    width: 100%;
    max-width: 720px;
    min-width: 320px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    margin: auto;
}
.response-log-detail-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e0e0e0;
    flex-shrink: 0;
}
.response-log-detail-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}
.response-log-detail-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    font-size: 24px;
    line-height: 1;
    color: #666;
    cursor: pointer;
    border-radius: 4px;
}
.response-log-detail-close:hover {
    background: #f0f0f0;
    color: #333;
}
.response-log-detail-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 16px 20px;
}
.response-log-detail-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.response-log-detail-table th,
.response-log-detail-table td {
    padding: 10px 12px;
    border: 1px solid #e0e0e0;
    text-align: left;
    vertical-align: top;
}
.response-log-detail-table th {
    background: #f8f9fa;
    font-weight: 600;
    color: #2c3e50;
    width: 140px;
}
.response-log-detail-table .rl-cell-pre {
    white-space: pre-wrap;
    word-break: break-word;
    max-width: 400px;
}
.response-log-detail-actions {
    display: flex;
    justify-content: flex-end;
    padding: 16px 20px;
    border-top: 1px solid #e0e0e0;
    flex-shrink: 0;
}
.response-log-detail-close-btn {
    min-width: 80px;
}

.response-log-attach-cell {
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
}
.response-log-attach-badge {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-size: 12px;
    color: #2563eb;
    text-decoration: none;
    white-space: nowrap;
}
a.response-log-attach-link {
    cursor: pointer;
}
a.response-log-attach-link:hover {
    text-decoration: underline;
    color: #1d4ed8;
}
.response-log-detail-images-cell {
    vertical-align: middle;
}
.response-log-detail-images-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.response-log-detail-img-btn {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    background: #f8fafc;
    font-size: 12px;
    color: #1e40af;
    cursor: pointer;
    max-width: 100%;
    word-break: break-all;
}
.response-log-detail-img-btn:hover {
    background: #eff6ff;
    border-color: #93c5fd;
}
.response-log-detail-images-empty {
    color: #888;
}

/* 미매칭 상세팝업 (AC22002) */
.unmatch-detail-popup-modal .unmatch-detail-cell-wide {
    word-break: break-word;
    max-width: 320px;
}
.unmatch-detail-popup-modal .company-popup-form-table th {
    width: 110px;
}
.unmatch-detail-popup-modal #udDetailKnowledgeSelectBtn {
    margin-left: 8px;
}

.unmatch-detail-popup-modal .unmatch-detail-images-cell {
    vertical-align: middle;
}
.unmatch-detail-popup-modal .unmatch-detail-images-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.unmatch-detail-popup-modal .unmatch-detail-img-btn {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    background: #f8fafc;
    font-size: 12px;
    color: #1e40af;
    cursor: pointer;
    max-width: 100%;
    word-break: break-all;
}
.unmatch-detail-popup-modal .unmatch-detail-img-btn:hover {
    background: #eff6ff;
    border-color: #93c5fd;
}
.unmatch-detail-popup-modal .unmatch-detail-images-empty {
    color: #888;
}

/* 지식선택 팝업 (AC22003) - 가로폭 확대, body 스크롤, 테이블 가독성 */
.knowledge-select-modal {
    width: 1180px;
    max-width: 96%;
}

.knowledge-select-popup-modal .knowledge-select-popup-body {
    max-height: 82vh;
    overflow-y: auto;
}

.knowledge-select-popup-modal .knowledge-select-search-wrap {
    margin-bottom: 12px;
}
.knowledge-select-popup-modal .knowledge-select-product-readonly {
    margin-right: 12px;
    font-weight: 500;
}

.knowledge-select-popup-modal .knowledge-select-initial-message {
    padding: 24px 16px;
    text-align: center;
    color: #666;
    font-size: 14px;
    line-height: 1.5;
}

.knowledge-select-popup-modal .knowledge-select-result-wrap {
    margin-top: 0;
}

.knowledge-select-popup-modal .knowledge-select-table {
    table-layout: fixed;
    width: 100%;
}
.knowledge-select-popup-modal .knowledge-select-table td {
    word-break: break-word;
}
.knowledge-select-popup-modal .knowledge-select-table th {
    word-break: break-word;
}

.knowledge-select-popup-modal .knowledge-select-row:hover {
    background-color: #fff8e6;
}
.knowledge-select-popup-modal .knowledge-select-row:active {
    background-color: #ffecb3;
}
.knowledge-select-popup-modal .knowledge-select-answer-cell {
    word-break: break-word;
}
.knowledge-select-popup-modal .km-paging {
    margin-top: 12px;
}

/* 응답 로그 상세 위에 지식선택을 올릴 때(동일 z-index 충돌 방지) */
.knowledge-select-popup-modal.knowledge-select-popup-modal--stack-top {
    z-index: 10050;
}

.rl-detail-knowledge-change-btn {
    min-width: 96px;
}

/* 운영관리 > 공지사항관리 */
.notice-search-row {
    align-items: center;
}
.notice-search-actions {
    margin-left: auto;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}
.notice-select-wide {
    min-width: 160px;
}
.notice-input-keyword {
    min-width: 160px;
    width: 180px;
}
.notice-period-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
}
.notice-date-input {
    width: auto;
    min-width: 140px;
}
.notice-time-input {
    width: auto;
    min-width: 110px;
}
.notice-char-count {
    display: block;
    font-size: 12px;
    color: #888;
    margin-top: 4px;
}
.notice-type-badge {
    display: inline-block;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 4px;
    background: #ecf0f1;
    color: #34495e;
}
.notice-type-urgent {
    background: #fadbd8;
    color: #922b21;
    font-weight: 700;
}
.notice-status-badge {
    display: inline-block;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 4px;
    background: #ecf0f1;
    color: #555;
}
.notice-status-live {
    background: #d5f5e3;
    color: #1e8449;
    font-weight: 600;
}
.required-mark {
    color: #c0392b;
    margin-left: 2px;
}
/* 공지 목록: 내용 컬럼 제거, 가로 스크롤 완화 */
.km-table.notice-list-table {
    table-layout: fixed;
    width: 100%;
}
.km-table .notice-col-no {
    width: 48px;
    text-align: center;
    white-space: nowrap;
}
.km-table .notice-col-product {
    width: 14%;
    min-width: 96px;
    word-break: break-word;
}
.km-table .notice-col-type {
    width: 10%;
    min-width: 88px;
    white-space: nowrap;
}
.km-table .notice-col-title {
    width: 26%;
    min-width: 0;
}
.km-table .notice-col-dt {
    width: 15%;
    min-width: 128px;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.km-table .notice-col-status {
    width: 88px;
    white-space: nowrap;
}
/* 제목 셀: 사용자관리 ID 링크(km-link-screen) + 말줄임, 클릭 시 수정 */
.km-table td.notice-title-cell {
    cursor: pointer;
    vertical-align: middle;
    min-width: 0;
}
.km-table td.notice-title-cell:hover {
    background-color: #f9fbfb;
}
.km-table td.notice-title-cell:focus {
    outline: 1px solid #1abc9c;
    outline-offset: -1px;
}
.km-table a.notice-title-link.km-link-screen {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-height: 1.25em;
}
.km-table .notice-title-link--empty {
    display: block;
    min-height: 1.25em;
    color: #bdc3c7;
}

/* 설정 > 문의하기 */
.inquiry-search-actions {
    margin-left: auto;
    display: inline-flex;
    gap: 8px;
}
.inquiry-select-wide {
    min-width: 160px;
}
.km-table.inquiry-list-table {
    table-layout: fixed;
    width: 100%;
}
.km-table .inquiry-col-no {
    width: 56px;
    text-align: center;
}
.km-table .inquiry-col-company {
    width: 12%;
    min-width: 140px;
}
.km-table .inquiry-col-product {
    width: 12%;
    min-width: 140px;
}
.km-table .inquiry-col-type {
    width: 90px;
}
.km-table .inquiry-col-question {
    width: 28%;
}
.km-table .inquiry-col-user {
    width: 14%;
}
.km-table .inquiry-col-answer {
    width: 84px;
}
.km-table .inquiry-col-dt {
    width: 150px;
    white-space: nowrap;
}
.km-table td.inquiry-question-cell {
    cursor: pointer;
}
.km-table a.inquiry-question-link.km-link-screen {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* AICS문의하기 전용 컬럼 폭 보정 - "로그인 전 문의" 라벨 한 줄 표시 + 회사명 컬럼 축소.
   사용자문의관리 등 다른 문의 목록 테이블에는 영향 없음. */
.km-table.inquiry-list-table--aics .inquiry-col-company {
    width: 110px;
    min-width: 100px;
}
.km-table.inquiry-list-table--aics .inquiry-col-type {
    width: 120px;
    min-width: 110px;
    white-space: nowrap;
}
.km-table.inquiry-list-table--aics .inquiry-col-question {
    width: 26%;
}

/* 운영관리 > 사용량 통계 */
.usage-search-row .usage-period-quick {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-right: 8px;
}
.usage-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}
.usage-kpi-card {
    padding: 12px 14px;
}
.usage-kpi-card p {
    margin: 0;
    color: #666;
    font-size: 12px;
}
.usage-kpi-card strong {
    display: block;
    margin-top: 6px;
    font-size: 20px;
    color: #1f2d3d;
}
.usage-section-title {
    margin: 0 0 10px;
    font-size: 16px;
}
.usage-clickable-row {
    cursor: pointer;
}
.usage-clickable-row:hover {
    background: #f4fbf9;
}
.usage-detail-wrap {
    margin-top: 12px;
}
.usage-tab-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}
.usage-tab-btn.active {
    background: var(--layout-sidebar-active-bg, #1abc9c);
    border-color: var(--layout-sidebar-active-bg, #1abc9c);
    color: #fff;
}
.usage-tab-panel {
    display: none;
}
.usage-tab-panel.active {
    display: block;
}

/* 문의 상세 > 답변내용 readonly 표시 */
textarea.inquiry-answer-readonly[readonly] {
    background-color: #f5f6f8;
    color: #555;
    border: 1px solid #ddd;
    cursor: default;
}
textarea.inquiry-answer-readonly[readonly]:focus {
    outline: none;
    box-shadow: none;
}
