/* ===== 제품 데이터베이스 ===== */

/* DB 스위치 (자재/완제품 · 향료) - 최상단 */
.pd-db-switch{display:flex;gap:4px;padding:10px 24px 0;background:var(--bg3);flex-shrink:0;border-bottom:1px solid var(--border)}
.pd-db-switch-btn{background:var(--bg2);border:1px solid var(--border);border-bottom:none;padding:9px 18px;font-size:13px;font-weight:700;color:var(--txt2);cursor:pointer;font-family:inherit;border-radius:8px 8px 0 0;margin-bottom:-1px;transition:all .12s}
.pd-db-switch-btn:hover{color:var(--txt);background:var(--bg)}
.pd-db-switch-active{background:var(--bg)!important;color:var(--green)!important;border-color:var(--border)!important;border-bottom:1px solid var(--bg)!important}
.pd-db-switch-count{font-size:10px;font-weight:500;opacity:0.7;margin-left:6px;background:rgba(91,107,82,0.12);padding:1px 7px;border-radius:100px}

/* 내부제품명 컬럼 강조 (향료 탭) */
.pd-table th[data-col-key="internalName"],
.pd-table td[data-key="internalName"]{background:#F5FAFE!important}
.pd-table th[data-col-key="internalName"]{color:#0C447C!important;font-weight:700}
.pd-table td[data-key="internalName"]{color:#0C447C;font-weight:600}

/* 사용법 팁 */
.pd-tip{display:flex;align-items:center;gap:10px;padding:10px 24px;background:rgba(91,107,82,0.06);border-bottom:1px solid rgba(91,107,82,0.12);flex-shrink:0}
.pd-tip-text{flex:1;font-size:12px;color:var(--txt2);line-height:1.6}
.pd-tip-close{background:none;border:none;font-size:14px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:4px;flex-shrink:0}
.pd-tip-close:hover{color:var(--txt);background:var(--bg2)}

/* 메인 탭 (제품 / 패키지·부자재) */
.pd-main-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0}
.pd-main-tab{background:none;border:none;border-bottom:2px solid transparent;padding:12px 20px;font-size:13px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;transition:all .15s;position:relative}
.pd-main-tab:hover{color:var(--txt);background:rgba(91,107,82,0.04)}
.pd-main-tab-active{color:var(--green)!important;border-bottom-color:var(--green)!important}
.pd-main-tab-count{font-size:10px;font-weight:400;opacity:0.7;margin-left:4px;background:var(--bg2);padding:1px 6px;border-radius:100px}
.pd-main-tab-active .pd-main-tab-count{background:rgba(91,107,82,0.12)}

/* 툴바 */
.pd-toolbar{display:flex;align-items:center;gap:12px;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0;flex-wrap:wrap}
.pd-cats{display:flex;gap:4px;flex:1;flex-wrap:wrap;min-width:0}
.pd-cat{background:none;border:1px solid transparent;border-radius:100px;padding:5px 12px;font-size:11px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}
.pd-cat:hover{background:var(--bg2);color:var(--txt)}
.pd-cat-active{background:var(--green-bg)!important;border-color:var(--green)!important;color:var(--green)!important}
.pd-cat-count{font-size:10px;font-weight:400;opacity:0.7;margin-left:2px}

.pd-search-wrap{position:relative;min-width:180px;max-width:260px}
.pd-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none}
.pd-search{width:100%;font-size:13px;padding:8px 30px 8px 32px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--txt);outline:none;font-family:inherit;transition:border-color .15s}
.pd-search:focus{border-color:var(--green)}
.pd-search::placeholder{color:var(--txt3)}
.pd-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--txt3);cursor:pointer;padding:2px}
.pd-search-clear:hover{color:#E24B4A}
.pd-toolbar-actions{display:flex;gap:6px;margin-left:auto}
.pd-tool-btn{font-size:12px;padding:7px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--txt);cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}
.pd-tool-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* 빈 상태 */
.pd-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}
.pd-empty-icon{font-size:48px;margin-bottom:16px;opacity:0.6}
.pd-empty-title{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:6px}
.pd-empty-sub{font-size:13px;color:var(--txt2);line-height:1.8}

/* 선택 툴바 */

.pd-sel-count{font-size:12px;font-weight:600;color:var(--green)}
.pd-sel-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;transition:all .15s}
.pd-sel-btn:hover{background:var(--bg2);color:var(--txt)}
.pd-sel-btn-del{color:#E24B4A;border-color:rgba(226,75,74,0.3)}
.pd-sel-btn-del:hover{background:rgba(226,75,74,0.06)}

/* 테이블 */
.pd-table-wrap{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;background:var(--bg3);padding-bottom:60px}
.pd-table{width:max-content;min-width:100%;border-collapse:collapse;table-layout:fixed}
.pd-table thead{background:var(--bg2);position:sticky;top:0;z-index:10}
.pd-table th{padding:10px 12px;text-align:left;font-weight:700;font-size:11px;color:var(--txt2);border-bottom:1px solid var(--border);white-space:nowrap;letter-spacing:0.04em;text-transform:uppercase;user-select:none}
.pd-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:13px;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pd-table tr{background:var(--bg3)}
.pd-table thead tr{background:var(--bg2)}

/* 틀고정 (sticky) 컬럼 — 뒤 컬럼이 비치지 않도록 솔리드 배경 + 우측 그림자 */
.pd-sticky-col{
  position:sticky!important;
  background:#FFFFFF!important;
  z-index:3!important;
}
body.dark .pd-sticky-col{background:#242220!important}
.pd-table thead .pd-sticky-col{background:#F5F5F5!important;z-index:12!important}
body.dark .pd-table thead .pd-sticky-col{background:#2d2b28!important}
.pd-row:hover .pd-sticky-col{background:#FAFAFA!important}
body.dark .pd-row:hover .pd-sticky-col{background:#2d2b28!important}
.pd-row-selected .pd-sticky-col{background:#FFFBF0!important}
.pd-row-active .pd-sticky-col{background:#FFF7E6!important}

/* 마지막 sticky 컬럼 우측 경계선 + 그림자 (시각적 분리) */
.pd-sticky-last{z-index:4!important;box-shadow:2px 0 4px rgba(0,0,0,0.06)}
.pd-table thead .pd-sticky-last{z-index:13!important}

/* 우측 여백 흡수 컬럼 */
.pd-th-end,.pd-td-end{width:auto!important;min-width:0!important;padding:0!important;border:none!important;border-bottom:none!important}
.pd-table thead .pd-th-end{background:var(--bg2)!important;border-bottom:1px solid var(--border)!important}
.pd-td-end{background:var(--bg3)!important}
/* 삭제 컬럼 — 테이블 내 유지, 헤더 스타일 */
.pd-table thead .pd-th-col[data-col-key="_delete"]{text-align:center}
.pd-table th:first-child{width:36px;text-align:center}
.pd-table td:first-child{text-align:center}
.pd-table th:first-child,.pd-table td:first-child{padding:10px 6px}
.pd-th-col{cursor:pointer;position:relative;transition:background .1s}
.pd-th-col:hover{background:rgba(91,107,82,0.06)}
.pd-row{cursor:pointer;transition:background .1s}
.pd-row:hover td{background:var(--bg2)}
.pd-row-selected td{background:rgba(91,107,82,0.06)!important}
.pd-td-brand{font-weight:600}
.pd-td-dim{color:var(--txt2);font-size:12px}
.pd-chk{width:15px;height:15px;accent-color:var(--green);cursor:pointer}
.pd-chk-all{width:15px;height:15px;accent-color:var(--green);cursor:pointer}

/* 상태 뱃지 */
.pd-status{display:inline-flex;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;white-space:nowrap}
.pd-status-active{background:#C0DD97;color:#27500A}
.pd-status-discontinued{background:#F8D7DA;color:#721C24}
.pd-status-prepare{background:#FAC775;color:#633806}
.pd-status-hold{background:#E2E3E5;color:#383D41}

/* 이미지 썸네일 */
.pd-thumb{width:32px;height:32px;border-radius:5px;object-fit:cover;background:var(--bg2);border:1px solid var(--border);cursor:pointer}
.pd-thumb-empty{width:32px;height:32px;border-radius:5px;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--txt3)}

/* 펼침 행 */
.pd-expand-row td{padding:0!important;background:var(--bg)!important;border-bottom:2px solid var(--green)}
.pd-expand{padding:18px 22px}
.pd-expand-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.pd-expand-title{font-size:16px;font-weight:700;color:var(--txt)}
.pd-expand-btns{display:flex;gap:6px}
.pd-detail-grid{display:grid;grid-template-columns:90px 1fr 90px 1fr;gap:6px 12px;font-size:13px;background:var(--bg3);border-radius:10px;padding:16px 18px;border:1px solid var(--border);text-align:left}
.pd-detail-label{color:var(--txt3);font-weight:600;font-size:11px;text-transform:uppercase;padding-top:2px;text-align:left}
.pd-detail-value{color:var(--txt);word-break:break-word;white-space:pre-wrap;line-height:1.6;text-align:left}

/* 이미지 미리보기 */
.pd-img-preview{max-width:200px;max-height:200px;border-radius:8px;object-fit:contain;border:1px solid var(--border);margin-top:4px}

/* 모달 */
.pd-modal-bg{position:fixed;inset:0;background:rgba(45,51,40,0.4);z-index:9000;display:flex;align-items:center;justify-content:center}
.pd-modal{background:var(--bg3);border-radius:var(--radius-lg);padding:28px;width:680px;max-width:92vw;max-height:85vh;overflow-y:auto;box-shadow:0 16px 50px rgba(45,51,40,0.2)}
.pd-modal h3{font-size:18px;font-weight:700;margin-bottom:18px;color:var(--txt)}
.pd-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.pd-form-full{grid-column:1/-1}
.pd-ff{display:flex;flex-direction:column;gap:3px}
.pd-ff label{font-size:11px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:0.04em}
.pd-ff input,.pd-ff select,.pd-ff textarea{font-size:13px;padding:9px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--txt);outline:none;font-family:inherit;width:100%;box-sizing:border-box}
.pd-ff input:focus,.pd-ff select:focus,.pd-ff textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(91,107,82,0.06)}
.pd-ff textarea{resize:vertical;line-height:1.6}
.pd-ff-img-wrap{display:flex;align-items:center;gap:12px;margin-top:4px}
.pd-ff-img-preview{width:60px;height:60px;border-radius:8px;object-fit:cover;border:1px solid var(--border);background:var(--bg2)}
.pd-ff-img-btn{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:7px 14px;font-size:12px;color:var(--txt2);cursor:pointer;font-family:inherit}
.pd-ff-img-btn:hover{background:var(--bg);border-color:var(--green)}
.pd-ff-img-remove{background:none;border:none;font-size:12px;color:#E24B4A;cursor:pointer;padding:4px}

/* 가격 필드 */
.pd-price-input{position:relative}
.pd-price-input input{padding-right:24px}
.pd-price-unit{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--txt3);pointer-events:none}

/* 모달 버튼 */
.pd-modal-btns{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
.pd-modal-btn{padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:1px solid var(--border);background:var(--bg);color:var(--txt)}
.pd-modal-btn:hover{background:var(--bg2)}
.pd-modal-btn-save{background:var(--green)!important;color:#fff!important;border-color:var(--green)!important}
.pd-modal-btn-save:hover{opacity:0.9}

/* 이미지 확대 오버레이 */
.pd-img-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:9500;display:flex;align-items:center;justify-content:center;cursor:pointer}
.pd-img-overlay img{max-width:70vw;max-height:70vh;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,0.4);cursor:default}
.pd-img-close{position:fixed;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.15);border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:9501;transition:background .15s;backdrop-filter:blur(4px)}
.pd-img-close:hover{background:rgba(255,255,255,0.3)}

/* 모바일 */
@media (max-width: 768px) {
  .pd-main-tabs{padding:0 16px}
  .pd-main-tab{padding:10px 14px;font-size:12px}
  .pd-toolbar{padding:8px 16px;gap:6px}
  .pd-cats{gap:2px}
  .pd-cat{padding:4px 8px;font-size:10px}
  .pd-search-wrap{min-width:0;max-width:none;flex:1}
  .pd-detail-grid{grid-template-columns:80px 1fr}
  .pd-form-grid{grid-template-columns:1fr}
  .pd-modal{width:95vw;padding:20px}
  .pd-table th,.pd-table td{padding:8px 8px;font-size:12px}

  .pd-hdr-popover{width:200px!important;min-width:200px!important}
}

/* ===== 열 리사이저 ===== */
.pd-col-resizer{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:3;transition:background .12s}
.pd-col-resizer:hover,.pd-col-resizer-active{background:var(--green);opacity:0.5}
.pd-col-resizer-active{opacity:0.8}

/* ===== 열 드래그 ===== */
.pd-th-dragging{opacity:0.35!important}
.pd-th-drag-left{box-shadow:inset 3px 0 0 var(--green)!important}
.pd-th-drag-right{box-shadow:inset -3px 0 0 var(--green)!important}
.pd-th-col[draggable="true"]{cursor:grab}
.pd-th-col[draggable="true"]:active{cursor:grabbing}

/* ===== + 컬럼 추가 헤더 ===== */
.pd-th-add-col{width:36px!important;min-width:36px!important;text-align:center!important;cursor:pointer;color:var(--green);font-size:16px;font-weight:700;padding:8px 4px!important;transition:background .12s;border-left:1px dashed var(--border)}
.pd-th-add-col:hover{background:rgba(91,107,82,0.08)}

/* ===== 노션 스타일 헤더 팝오버 ===== */
.pd-hdr-popover{position:fixed;z-index:9100;background:var(--bg3);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px rgba(45,51,40,0.18),0 2px 8px rgba(0,0,0,0.06);min-width:220px;width:220px;padding:6px 0;animation:pdPopIn .12s ease-out}
@keyframes pdPopIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* 이름 편집 영역 */
.pd-hdr-pop-name{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:2px 6px;border-radius:6px;background:var(--bg2)}
.pd-hdr-pop-icon{font-size:12px;font-weight:700;color:var(--txt3);flex-shrink:0;width:22px;text-align:center}
.pd-hdr-pop-input{flex:1;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--txt);outline:none;font-family:inherit;padding:2px 0;min-width:0}
.pd-hdr-pop-input::placeholder{color:var(--txt3)}
.pd-hdr-pop-input:focus{border-bottom:1.5px solid var(--green)}

/* 구분선 */
.pd-hdr-pop-sep{height:1px;background:var(--border);margin:4px 10px}

/* 메뉴 항목 */
.pd-hdr-pop-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--txt);cursor:pointer;transition:background .1s;white-space:nowrap}
.pd-hdr-pop-item:hover{background:rgba(91,107,82,0.06)}
.pd-hdr-pop-item-icon{width:20px;text-align:center;font-size:13px;flex-shrink:0;opacity:0.8}
.pd-hdr-pop-danger{color:#E24B4A!important}
.pd-hdr-pop-danger:hover{background:rgba(226,75,74,0.06)!important}

/* ===== 액션 컬럼 (＋ 복사 — 노션 스타일) ===== */
.pd-th-act,.pd-td-act{width:40px!important;min-width:40px!important;padding:0!important;text-align:center}
.pd-th-act-label{font-size:8px;line-height:1.2;color:var(--txt3);font-weight:600;letter-spacing:0}
.pd-row-act-wrap{display:flex;align-items:center;justify-content:center;gap:0;opacity:0;transition:opacity .1s}
.pd-row:hover .pd-row-act-wrap{opacity:1}
.pd-act-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:2px 4px;border-radius:3px;color:var(--txt);font-weight:700;transition:all .1s;line-height:1}
.pd-act-add:hover{color:var(--green);background:rgba(91,107,82,0.08)}
.pd-act-copy:hover{color:#1967D2;background:rgba(25,103,210,0.08)}

/* ===== 열기 + 추가 버튼 래퍼 ===== */
.pd-row-btn-wrap{display:none;position:absolute;right:4px;top:50%;transform:translateY(-50%);z-index:6;gap:3px;align-items:center}
.pd-row:hover .pd-row-btn-wrap{display:flex}
.pd-row-open-btn{background:var(--bg3)!important;border:1px solid var(--border);border-radius:6px;padding:3px 10px;font-size:10px;font-weight:700;color:var(--green);cursor:pointer;white-space:nowrap;box-shadow:0 2px 6px rgba(45,51,40,0.1);font-family:inherit;transition:background .1s}
.pd-row-open-btn:hover{background:var(--bg2)!important;border-color:var(--green)}
.pd-row-add-btn{background:var(--bg3)!important;border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:13px;font-weight:800;color:var(--txt);cursor:pointer;white-space:nowrap;box-shadow:0 2px 6px rgba(45,51,40,0.1);font-family:inherit;transition:all .1s;line-height:1}
.pd-row-add-btn:hover{background:var(--green)!important;color:#fff;border-color:var(--green)}

/* ===== 인라인 편집 ===== */
.pd-td-cell{cursor:pointer;transition:background .08s}
.pd-td-cell:hover{background:rgba(91,107,82,0.04)}
.pd-td-cell[data-editable="1"]:hover{background:rgba(91,107,82,0.07);outline:1px solid rgba(91,107,82,0.15);outline-offset:-1px;border-radius:2px}
.pd-inline-input{width:100%;font-size:12px;padding:4px 6px;border:1.5px solid var(--green);border-radius:4px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box}
.pd-inline-input:focus{box-shadow:0 0 0 3px rgba(91,107,82,0.1)}

/* ===== 인라인 드롭다운 ===== */
.pd-inline-dropdown{position:fixed;z-index:9200;background:var(--bg3);border:1px solid var(--border);border-radius:8px;box-shadow:0 6px 24px rgba(45,51,40,0.16);padding:4px 0;max-height:240px;overflow-y:auto;animation:pdPopIn .1s ease-out}
.pd-inline-drop-opt{padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:background .08s;white-space:nowrap}
.pd-inline-drop-opt:hover{background:rgba(91,107,82,0.06)}
.pd-inline-drop-active{background:rgba(91,107,82,0.1)!important;font-weight:700}

/* ===== 팝오버 서브 표시 ===== */
.pd-hdr-pop-sub{margin-left:auto;font-size:10px;color:var(--txt3);font-weight:500;padding-left:10px}
.pd-hdr-pop-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--txt);cursor:pointer;transition:background .1s;white-space:nowrap}

/* ===== 유형 변경 서브메뉴 ===== */
.pd-type-popover{min-width:200px;width:200px}
.pd-hdr-pop-title{padding:8px 14px;font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:0.04em}
.pd-hdr-pop-item-active{background:rgba(91,107,82,0.08)!important;font-weight:700;color:var(--green)!important}
.pd-hdr-pop-check{margin-left:auto;font-size:13px;color:var(--green);font-weight:700}

/* ===== 패널 헤더 아래 제조원가 바 ===== */
.pd-panel-cost-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 24px;background:rgba(91,107,82,0.06);border-bottom:1px solid var(--border);flex-shrink:0}
.pd-panel-cost-label{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:0.04em}
.pd-panel-cost-val{font-size:15px;font-weight:800;color:var(--green)}

/* ===== 제품 상세 모달 ===== */
.pd-modal-overlay{position:fixed;inset:0;background:rgba(45,51,40,0.4);z-index:8000;display:flex;align-items:center;justify-content:center}
.pd-detail-modal{position:relative;width:75vw;max-width:1100px;min-width:500px;max-height:90vh;background:var(--bg3);border-radius:var(--radius-lg,14px);box-shadow:0 20px 60px rgba(45,51,40,0.25);display:flex;flex-direction:column;overflow:hidden;animation:pdModalIn .2s ease-out}
@keyframes pdModalIn{from{opacity:0;transform:scale(0.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* 리사이저 (좌우) */
.pd-dm-resizer{position:absolute;top:0;bottom:0;width:6px;cursor:col-resize;z-index:10;transition:background .12s}
.pd-dm-resizer:hover,.pd-dm-resizer:active{background:var(--green);opacity:0.3}
.pd-dm-resizer-l{left:0}
.pd-dm-resizer-r{right:0}

/* 헤더 */
.pd-dm-head{display:flex;align-items:center;gap:10px;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.pd-dm-title{flex:1;font-size:18px;font-weight:800;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pd-dm-title-text{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .1s}
.pd-dm-title-text:hover{background:rgba(91,107,82,0.08)}
.pd-dm-title-input{width:100%;font-size:18px;font-weight:800;border:1.5px solid var(--green);border-radius:6px;padding:6px 10px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box}

/* 제조원가 바 (헤더 내) */
.pd-dm-cost-bar{display:flex;align-items:center;gap:8px;flex-shrink:0}
.pd-dm-cost-label{font-size:11px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em}
.pd-dm-cost-val{font-size:16px;font-weight:800;color:var(--green)}

.pd-dm-close{background:none;border:none;font-size:18px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .12s;flex-shrink:0}
.pd-dm-close:hover{color:var(--txt);background:var(--bg2)}

/* 스크롤 영역 */
.pd-dm-scroll{flex:1;overflow-y:auto;padding:24px;-webkit-overflow-scrolling:touch}

/* 하단 버튼 */
.pd-dm-foot{display:flex;gap:8px;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end}

/* 모바일 */
@media (max-width: 768px) {
  .pd-detail-modal{width:98vw!important;min-width:0!important;max-width:none!important;max-height:95vh;border-radius:12px}
}

/* ===== footer 부자재 추가 버튼 ===== */
.pd-foot-add-bom{color:var(--green)!important;border-color:var(--green)!important;font-weight:700!important}
.pd-foot-add-bom:hover{background:rgba(91,107,82,0.08)!important}
.pd-foot-save{background:var(--green)!important;color:#fff!important;border-color:var(--green)!important;font-weight:700!important}
.pd-foot-save:hover{opacity:0.9}

/* ===== 우측 상세 패널 (업무요청과 동일 패턴) ===== */
.pd-panel{width:0;overflow:hidden;border-left:1px solid var(--border);background:var(--bg3);display:flex;flex-direction:column;transition:width .25s ease;flex-shrink:0;position:relative}
.pd-panel.open{width:44vw;min-width:420px}

.pd-panel-resizer{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:3;transition:background .12s}
.pd-panel-resizer:hover,.pd-panel-resizer.active{background:var(--green);opacity:0.4}

.pd-panel-head{display:flex;align-items:center;gap:10px;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.pd-panel-title{flex:1;font-size:17px;font-weight:800;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pd-panel-close{background:none;border:none;font-size:18px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .12s}
.pd-panel-close:hover{color:var(--txt);background:var(--bg2)}

.pd-panel-scroll{flex:1;overflow-y:auto;padding:24px;-webkit-overflow-scrolling:touch}

.pd-panel-img{margin-bottom:20px;text-align:center}
.pd-panel-img img{max-width:100%;max-height:220px;border-radius:10px;object-fit:contain;border:1px solid var(--border);background:var(--bg2)}

.pd-panel-fields{display:flex;flex-direction:column;gap:0;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.pd-panel-field{display:flex;align-items:center;min-height:44px;padding:0;border-bottom:1px solid var(--border);transition:background .08s}
.pd-panel-field:last-child{border-bottom:none}
.pd-panel-field:hover{background:rgba(91,107,82,0.03)}
.pd-panel-field-label{width:100px;flex-shrink:0;font-size:12px;font-weight:700;color:var(--txt2);padding:10px 14px;background:rgba(91,107,82,0.04);border-right:1px solid var(--border);align-self:stretch;display:flex;align-items:center}
.pd-panel-field-value{flex:1;font-size:14px;font-weight:500;color:var(--txt);word-break:break-word;line-height:1.7;min-height:24px;padding:10px 16px;border-radius:0;transition:background .1s;cursor:pointer}
.pd-panel-field-value:hover{background:rgba(91,107,82,0.06)}

.pd-panel-foot{display:flex;gap:8px;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end}

/* 행 활성 (패널 열림) */
.pd-row-active td{background:rgba(91,107,82,0.08)!important}
.pd-row-active td:first-child{box-shadow:inset 3px 0 0 var(--green)}

/* 모바일 패널 */
@media (max-width: 768px) {
  .pd-panel.open{width:100vw!important;min-width:0!important;position:fixed;inset:0;z-index:100}
}

/* ===== 패널 타이틀 편집 ===== */
.pd-panel-title-text{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .1s}
.pd-panel-title-text:hover{background:rgba(91,107,82,0.08)}
.pd-panel-title-input{width:100%;font-size:17px;font-weight:800;border:1.5px solid var(--green);border-radius:6px;padding:6px 10px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box}
.pd-panel-title-input:focus{box-shadow:0 0 0 3px rgba(91,107,82,0.12)}

/* ===== 패널 이미지 갤러리 (컴팩트 — 요약 탭 안) ===== */
.pd-gallery-compact{margin-bottom:14px}
.pd-gallery-compact .pd-panel-gallery-grid{grid-template-columns:repeat(5,1fr);gap:4px}
.pd-gallery-compact .pd-panel-gallery-item{aspect-ratio:1/1;border-radius:6px}
.pd-gallery-compact .pd-panel-gallery-add{aspect-ratio:1/1;border-radius:6px;font-size:16px}
.pd-gallery-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.55);color:#fff;font-size:9px;font-weight:600;text-align:center;padding:2px 0;border-radius:0 0 5px 5px;pointer-events:none}

/* ===== 사양 탭 이미지 ===== */
.pd-spec-img-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}
.pd-spec-img-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px}
.pd-spec-img-label{font-size:9px;color:var(--txt3);text-align:center;white-space:nowrap}
.pd-spec-img-name{font-size:9px;color:var(--txt2);text-align:center;white-space:nowrap;cursor:pointer;padding:0 2px;border-radius:2px;transition:background .1s;max-width:44px;overflow:hidden;text-overflow:ellipsis}
.pd-spec-img-name:hover{background:rgba(91,107,82,0.08);color:var(--green)}
.pd-spec-img-name-input{width:50px;font-size:9px;padding:1px 3px;border:1px solid var(--green);border-radius:2px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;text-align:center}
.pd-spec-img-del{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:rgba(0,0,0,0.5);color:#fff;font-size:8px;display:none;align-items:center;justify-content:center;cursor:pointer;line-height:1}
.pd-spec-img-item:hover .pd-spec-img-del{display:flex}
.pd-spec-img-add{width:32px;height:32px;border:1.5px dashed var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--txt3);transition:all .12s;align-self:flex-start}
.pd-spec-img-add:hover{border-color:var(--green);color:var(--green)}

/* ===== 사양 탭 작은 썸네일 ===== */
.pd-spec-thumbs{display:flex;gap:4px;flex-wrap:wrap}
.pd-spec-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover;border:1px solid var(--border);cursor:pointer;transition:transform .12s,box-shadow .12s}
.pd-spec-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px rgba(45,51,40,0.15);z-index:1}

/* ===== 패널 이미지 갤러리 (3열) ===== */
.pd-panel-gallery{margin-bottom:14px}
.pd-panel-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.pd-panel-gallery-item{position:relative;aspect-ratio:3/4;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--bg2)}
.pd-panel-gallery-item img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}
.pd-panel-gallery-del{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,0.5);color:#fff;border:none;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1}
.pd-panel-gallery-item:hover .pd-panel-gallery-del{display:flex}
.pd-panel-gallery-add{aspect-ratio:3/4;border:2px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s;font-size:20px;color:var(--txt3)}
.pd-panel-gallery-add:hover{border-color:var(--green);color:var(--green);background:rgba(91,107,82,0.03)}

/* ===== 패널 탭 ===== */
.pd-panel-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px;flex-shrink:0}
.pd-panel-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:13px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;transition:all .12s}
.pd-panel-tab:hover{color:var(--txt);background:rgba(91,107,82,0.03)}
.pd-panel-tab-active{color:var(--green)!important;border-bottom-color:var(--green)!important}

/* ===== 원가 계산기 ===== */
.pd-cost-calc{padding:0}
.pd-cost-header{display:flex;gap:4px;padding:6px 0;border-bottom:1px solid var(--border);font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em}
.pd-cost-h-name{flex:2;padding-left:4px}
.pd-cost-h-price{width:80px;text-align:center}
.pd-cost-h-qty{width:52px;text-align:center}
.pd-cost-h-sub{width:80px;text-align:right}
.pd-cost-h-del{width:28px}

.pd-cost-row{display:flex;gap:4px;align-items:center;padding:4px 0;border-bottom:1px solid rgba(213,216,208,0.4)}
.pd-cost-input{font-size:12px;padding:5px 6px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box}
.pd-cost-input:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(91,107,82,0.08)}
.pd-cost-name{flex:2}
.pd-cost-price{width:80px;text-align:right}
.pd-cost-qty{width:52px;text-align:center}
.pd-cost-sub{width:80px;text-align:right;font-size:12px;font-weight:600;color:var(--txt)}
.pd-cost-del{width:24px;height:24px;background:none;border:none;color:var(--txt3);cursor:pointer;font-size:12px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pd-cost-del:hover{color:#E24B4A;background:rgba(226,75,74,0.06)}

.pd-cost-add-btn{width:100%;padding:8px;margin-top:6px;background:none;border:1px dashed var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--green);cursor:pointer;font-family:inherit;transition:all .12s}
.pd-cost-add-btn:hover{background:rgba(91,107,82,0.04);border-color:var(--green)}

.pd-cost-summary{margin-top:14px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px}
.pd-cost-total-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.pd-cost-total-label{font-size:12px;font-weight:600;color:var(--txt2)}
.pd-cost-total-val{font-size:14px;font-weight:700;color:var(--txt)}
.pd-cost-margin-row{border-top:1px solid var(--border);margin-top:6px;padding-top:8px}
.pd-cost-margin-row .pd-cost-total-label{font-size:13px;font-weight:700;color:var(--txt)}
.pd-cost-margin-row .pd-cost-total-val{font-size:16px}

/* ===== 사양서 미리보기 카드 ===== */
.pd-spec-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}
.pd-spec-card-head{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.pd-spec-card-badge{display:inline-flex;padding:2px 10px;border-radius:100px;font-size:10px;font-weight:700;white-space:nowrap}
.pd-spec-card-name{font-size:14px;font-weight:700;color:var(--txt)}
.pd-spec-card-fields{display:flex;flex-wrap:wrap;gap:4px 12px;padding:10px 14px}
.pd-spec-field-item{display:flex;align-items:center;gap:4px;font-size:12px}
.pd-spec-field-key{color:var(--txt3);font-weight:600;white-space:nowrap}
.pd-spec-field-key::after{content:':'}
.pd-spec-field-val{color:var(--txt);padding:1px 4px;border-radius:3px;outline:none;min-width:30px;transition:background .1s}
.pd-spec-field-val:hover{background:rgba(91,107,82,0.06)}
.pd-spec-field-val:focus{background:rgba(91,107,82,0.1);box-shadow:0 0 0 2px rgba(91,107,82,0.15)}

/* ═══════════════════════════════════════════════════
   탭 1: 제품 요약
   ═══════════════════════════════════════════════════ */

.pd-sum-section{margin-bottom:16px}
.pd-sum-section-title{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:0.06em;padding:0 2px 8px;display:flex;align-items:center;gap:6px}
.pd-sum-section-title::before{content:'■';font-size:8px;color:var(--green)}

.pd-sum-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.pd-sum-field{display:flex;align-items:center;min-height:40px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);transition:background .08s}
.pd-sum-field:nth-child(2n){border-right:none}
.pd-sum-card>.pd-sum-field:last-child{border-bottom:none}
.pd-sum-card>.pd-sum-field:nth-last-child(2):nth-child(odd){border-bottom:none}
.pd-sum-card.pd-sum-card-single{grid-template-columns:1fr}
.pd-sum-card.pd-sum-card-single .pd-sum-field{border-right:none}
.pd-sum-card.pd-sum-card-single .pd-sum-field:last-child{border-bottom:none}
@media(max-width:600px){.pd-sum-card{grid-template-columns:1fr}.pd-sum-field{border-right:none!important}}
.pd-sum-field:hover{background:rgba(91,107,82,0.03)}
.pd-sum-field-label{width:110px;flex-shrink:0;font-size:12px;font-weight:700;color:var(--txt2);padding:8px 14px;background:rgba(91,107,82,0.04);border-right:1px solid var(--border);align-self:stretch;display:flex;align-items:center}
.pd-sum-field-value{flex:1;font-size:13px;font-weight:500;color:var(--txt);padding:8px 14px;word-break:break-word;line-height:1.6;min-height:22px;transition:background .1s}
.pd-sum-editable .pd-sum-field-value{cursor:pointer;border-radius:0}
.pd-sum-editable .pd-sum-field-value:hover{background:rgba(91,107,82,0.06)}

/* 마진율 게이지 */
.pd-sum-gauge-wrap{display:flex;align-items:center;gap:10px;width:100%}
.pd-sum-gauge{flex:1;height:8px;background:var(--bg2);border-radius:100px;overflow:hidden}
.pd-sum-gauge-fill{height:100%;border-radius:100px;transition:width .3s ease}
.pd-sum-gauge-val{font-size:14px;font-weight:800;flex-shrink:0;min-width:50px;text-align:right}

/* ═══════════════════════════════════════════════════
   탭 3: 원가 (BOM) — ERP 테이블
   ═══════════════════════════════════════════════════ */

.pd-bom-erp-wrap{overflow-x:auto;margin-bottom:10px;border:1px solid var(--border);border-radius:8px}
.pd-bom-erp{width:100%;border-collapse:collapse;table-layout:fixed;min-width:520px}
.pd-bom-erp thead{background:var(--bg2);position:sticky;top:0;z-index:1}
.pd-bom-erp th{padding:8px 6px;text-align:left;font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em;border-bottom:1px solid var(--border);white-space:nowrap}
.pd-bom-th-chk{width:28px;text-align:center!important}
.pd-bom-th-handle{width:32px;text-align:center!important}
.pd-bom-th-name{width:auto}
.pd-bom-th-cat{width:60px;text-align:center}
.pd-bom-th-unit{width:50px;text-align:center}
.pd-bom-th-qty{width:64px;text-align:right}
.pd-bom-th-uprice{width:72px;text-align:right}
.pd-bom-th-amount{width:72px;text-align:right}
.pd-bom-th-total{width:80px;text-align:right}
.pd-bom-th-del{width:28px}

/* 선택 바 */
.pd-bom-sel-bar{display:flex;align-items:center;gap:10px;padding:6px 10px;background:rgba(91,107,82,0.08);border-radius:8px;margin-bottom:6px}
.pd-bom-sel-count{font-size:12px;font-weight:600;color:var(--green)}
.pd-bom-sel-del{background:none;border:1px solid rgba(226,75,74,0.3);border-radius:6px;padding:4px 12px;font-size:11px;font-weight:600;color:#E24B4A;cursor:pointer;font-family:inherit;transition:all .12s}
.pd-bom-sel-del:hover{background:rgba(226,75,74,0.06)}

/* 체크박스 */
.pd-bom-td-chk{text-align:center!important;width:28px}
.pd-bom-chk,.pd-bom-chk-all{width:14px;height:14px;accent-color:var(--green);cursor:pointer}

/* 드래그 핸들 */
.pd-bom-td-handle{text-align:center!important;width:32px;cursor:grab;user-select:none;position:relative}
.pd-bom-td-handle:active{cursor:grabbing}
.pd-bom-handle{font-size:12px;color:var(--txt3);opacity:0.5;transition:opacity .1s;position:absolute;left:4px;top:50%;transform:translateY(-50%)}
.pd-bom-td-handle:hover .pd-bom-handle{opacity:1;color:var(--green)}
.pd-bom-row-no{font-size:11px;font-weight:600;color:var(--txt3)}

/* 드래그 표시 */
.pd-bom-tr-dragging{opacity:0.4!important}
.pd-bom-drag-above{box-shadow:inset 0 2px 0 var(--green)!important}
.pd-bom-drag-below{box-shadow:inset 0 -2px 0 var(--green)!important}

.pd-bom-tr{transition:background .08s}
.pd-bom-tr:hover td{background:rgba(91,107,82,0.03)}
.pd-bom-erp td{padding:4px 6px;border-bottom:1px solid rgba(213,216,208,0.3);vertical-align:middle;font-size:12px}
.pd-bom-td-cat{text-align:center}
.pd-bom-td-amount{text-align:right}
.pd-bom-td-total{text-align:right}
.pd-bom-td-del{text-align:center;width:28px;padding:0 2px!important}
.pd-bom-total-cell{font-size:11px;font-weight:600;color:var(--green);white-space:nowrap}

.pd-bom-mix-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;margin:0 4px}

.pd-bom-name-wrap{display:flex;align-items:center;gap:4px}
.pd-bom-search-btn{background:none;border:none;font-size:12px;cursor:pointer;padding:2px;flex-shrink:0;border-radius:3px;transition:background .1s;line-height:1;opacity:0.6}
.pd-bom-search-btn:hover{opacity:1;background:rgba(91,107,82,0.08)}
.pd-bom-name-input{flex:1;font-size:12px;font-weight:600;padding:4px 6px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box;min-width:0;transition:all .12s}
.pd-bom-name-input:focus{border-color:var(--green);background:var(--bg);box-shadow:0 0 0 2px rgba(91,107,82,0.06)}
.pd-bom-name-input::placeholder{color:var(--txt3);font-weight:400}
.pd-bom-link-badge{font-size:10px;flex-shrink:0}

.pd-bom-cat-chip{font-size:10px;font-weight:700;color:var(--green);padding:2px 8px;border-radius:100px;background:rgba(91,107,82,0.08);cursor:pointer;transition:background .1s;user-select:none;white-space:nowrap}
.pd-bom-cat-chip:hover{background:rgba(91,107,82,0.16)}

.pd-bom-cell-input{width:100%;font-size:11px;padding:4px 5px;border:1px solid transparent;border-radius:3px;background:transparent;color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box;text-align:right;transition:all .1s}
.pd-bom-cell-input:focus{border-color:var(--green);background:var(--bg);box-shadow:0 0 0 2px rgba(91,107,82,0.06)}
.pd-bom-unit-input{text-align:center}
.pd-bom-amount-val{font-size:11px;font-weight:600;color:var(--txt);white-space:nowrap}
.pd-bom-conv-price{font-size:11px;font-weight:500;color:var(--txt2);white-space:nowrap}
.pd-bom-del-btn{width:20px;height:20px;background:none;border:none;color:var(--txt3);cursor:pointer;font-size:11px;border-radius:3px;display:flex;align-items:center;justify-content:center;transition:all .1s}
.pd-bom-del-btn:hover{color:#E24B4A;background:rgba(226,75,74,0.06)}

/* 셀 호버 클리어 버튼 */
.pd-bom-cell-clear{display:none;position:absolute;right:2px;top:50%;transform:translateY(-50%);font-size:9px;color:var(--txt3);cursor:pointer;padding:2px 3px;border-radius:3px;line-height:1;z-index:2;transition:color .1s}
.pd-bom-cell-clear:hover{color:#E24B4A;background:rgba(226,75,74,0.08)}
td:hover .pd-bom-cell-clear{display:inline}

/* 빈 행 (미입력) */
.pd-bom-tr-empty td{opacity:0.4}
.pd-bom-tr-empty:hover td{opacity:0.7}

/* ⬇ 행 추가 */
.pd-bom-add-row-wrap{display:flex;justify-content:center;padding:4px 0;border-top:1px solid var(--border)}
.pd-bom-add-row-btn{background:none;border:none;font-size:16px;color:var(--green);cursor:pointer;padding:4px 20px;border-radius:6px;transition:all .12s;font-family:inherit;line-height:1}
.pd-bom-add-row-btn:hover{background:rgba(91,107,82,0.08)}

/* 배합 모드 바 */
.pd-bom-mix-bar{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap}
.pd-bom-mix-label{font-size:12px;font-weight:700;color:var(--txt2);flex-shrink:0}
.pd-bom-mix-vol{width:64px;font-size:13px;font-weight:700;padding:5px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg3);color:var(--txt);outline:none;font-family:inherit;text-align:right}
.pd-bom-mix-vol:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(91,107,82,0.08)}
.pd-bom-mix-vunit{font-size:12px;padding:5px 4px;border:1px solid var(--border);border-radius:6px;background:var(--bg3);color:var(--txt2);outline:none;font-family:inherit}
.pd-bom-mix-toggle-wrap{display:flex;align-items:center;gap:6px;margin-left:auto}
.pd-bom-mix-toggle-label{font-size:11px;font-weight:600;color:var(--txt2)}

/* 토글 스위치 */
.pd-bom-toggle{position:relative;display:inline-block;width:34px;height:18px;flex-shrink:0}
.pd-bom-toggle input{opacity:0;width:0;height:0}
.pd-bom-toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:9px;transition:background .2s}
.pd-bom-toggle-slider::before{content:'';position:absolute;width:14px;height:14px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s}
.pd-bom-toggle input:checked+.pd-bom-toggle-slider{background:var(--green)}
.pd-bom-toggle input:checked+.pd-bom-toggle-slider::before{transform:translateX(16px)}

/* 비율 컬럼 */
.pd-bom-th-ratio{width:48px;text-align:center}
.pd-bom-td-ratio{text-align:center}
.pd-bom-ratio-input{text-align:center!important;font-weight:600!important;color:var(--green)!important}

/* 비율 합계 게이지 */
.pd-bom-ratio-bar{display:flex;align-items:center;gap:10px;padding:6px 10px;margin-top:6px;font-size:12px;color:var(--txt2);background:var(--bg);border:1px solid var(--border);border-radius:8px}
.pd-bom-ratio-gauge{flex:1;height:6px;background:var(--bg2);border-radius:100px;overflow:hidden}
.pd-bom-ratio-gauge-fill{height:100%;border-radius:100px;transition:width .2s,background .2s}
.pd-bom-ratio-val{font-size:13px;font-weight:700;flex-shrink:0;min-width:40px;text-align:right}

.pd-bom-total-section{padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-top:10px}
.pd-bom-total-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.pd-bom-total-label{font-size:12px;font-weight:600;color:var(--txt2)}
.pd-bom-total-val{font-size:14px;font-weight:700;color:var(--txt)}
.pd-bom-margin-row{border-top:1px solid var(--border);margin-top:6px;padding-top:8px}
.pd-bom-margin-row .pd-bom-total-label{font-size:13px;font-weight:700;color:var(--txt)}
.pd-bom-margin-row .pd-bom-total-val{font-size:16px}

/* ═══════════════════════════════════════════════════
   자재 검색 모달
   ═══════════════════════════════════════════════════ */

.pd-mat-modal{background:var(--bg3);border-radius:14px;width:480px;max-width:92vw;max-height:70vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 50px rgba(45,51,40,0.2)}
.pd-mat-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 12px;flex-shrink:0}
.pd-mat-modal-head h3{font-size:16px;font-weight:700;color:var(--txt);margin:0}
.pd-mat-modal-close{background:none;border:none;font-size:18px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .1s}
.pd-mat-modal-close:hover{color:var(--txt);background:var(--bg2)}

.pd-mat-modal-search{padding:0 22px 8px}
.pd-mat-modal-input{width:100%;font-size:13px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box;transition:border-color .12s}
.pd-mat-modal-input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(91,107,82,0.08)}

/* 필터 */
.pd-mat-modal-filters{padding:0 22px 10px;display:flex;flex-direction:column;gap:6px}
.pd-mat-filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pd-mat-filter-label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em;flex-shrink:0;width:32px}
.pd-mat-filter-chips{display:flex;gap:3px;flex-wrap:wrap}
.pd-mat-chip{background:var(--bg2);border:1px solid transparent;border-radius:100px;padding:3px 10px;font-size:10px;font-weight:600;color:var(--txt2);cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .12s}
.pd-mat-chip:hover{background:var(--bg);border-color:var(--border);color:var(--txt)}
.pd-mat-chip-active{background:rgba(91,107,82,0.12)!important;color:var(--green)!important;border-color:rgba(91,107,82,0.3)!important;font-weight:700}
.pd-mat-chip-count{font-size:9px;opacity:0.6;margin-left:2px}

.pd-mat-modal-list{flex:1;overflow-y:auto;padding:0 10px 14px}
.pd-mat-modal-opt{padding:10px 14px;border-radius:8px;cursor:pointer;transition:background .08s;margin-bottom:2px}
.pd-mat-modal-opt:hover{background:rgba(91,107,82,0.06)}
.pd-mat-modal-opt-main{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.pd-mat-modal-opt-name{font-size:13px;font-weight:700;color:var(--txt)}
.pd-mat-modal-opt-cat{font-size:10px;font-weight:600;padding:1px 8px;border-radius:100px;white-space:nowrap}
.pd-mat-modal-opt-sub{display:flex;gap:8px;font-size:11px;color:var(--txt3)}
.pd-mat-modal-opt-price{font-size:13px;font-weight:800;color:var(--green);margin-top:2px}
.pd-mat-modal-empty{padding:30px;text-align:center;font-size:13px;color:var(--txt3)}

/* (제조소요량 탭 — 원가 탭에 통합됨) */

/* ═══════════════════════════════════════════════════
   구분 필터 태그 검색기
   ═══════════════════════════════════════════════════ */
.pd-cat-filter-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}
.pd-cat-filter-label{font-size:11px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em;flex-shrink:0}
.pd-cat-filter-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--txt);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .12s;white-space:nowrap}
.pd-cat-filter-btn:hover{border-color:var(--green);background:rgba(91,107,82,0.04)}
.pd-cat-filter-clear{font-size:11px;color:var(--txt3);margin-left:2px;padding:0 2px;border-radius:3px;transition:color .1s}
.pd-cat-filter-clear:hover{color:#E24B4A}
.pd-cat-filter-count{margin-left:auto;font-size:10px;font-weight:400;color:var(--txt3);opacity:0.7;padding-left:8px}
.pd-cat-filter-picker{min-width:240px}
.pd-cat-filter-picker .tag-opt{display:flex;align-items:center;gap:6px}

/* ═══════════════════════════════════════════════════
   마우스 드래그 셀 선택
   ═══════════════════════════════════════════════════ */
.pd-cell-selected{background:rgba(91,107,82,0.12)!important;outline:1.5px solid rgba(91,107,82,0.35)!important;outline-offset:-1px}
.pd-cell-selected::after{content:'';position:absolute;inset:0;pointer-events:none;border:1px solid rgba(91,107,82,0.3)}
.pd-cell-focused{outline:2px solid var(--green)!important;outline-offset:-1px;background:rgba(91,107,82,0.06)!important;position:relative;z-index:1}

/* 마진율 뱃지 */
.pd-margin-badge{font-size:12px;font-weight:700;white-space:nowrap}
.pd-margin-basis{display:block;font-size:8px;color:var(--txt);font-weight:400;white-space:nowrap;margin-top:1px;opacity:0.7}

/* 날짜 셀 */
.pd-date-cell{font-size:11px;color:var(--txt2);white-space:nowrap}

/* 마스킹 (권한 제한) */
.pd-masked{font-size:12px;color:var(--txt3);opacity:0.5;cursor:default;user-select:none}

/* ═══════════════════════════════════════════════════
   CSV 내보내기 승인 요청 패널 (캘린더 연차 패턴)
   ═══════════════════════════════════════════════════ */
.pd-csv-req-panel{width:320px;min-width:320px;background:var(--bg3);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;animation:pdSlideIn .2s ease-out}
@keyframes pdSlideIn{from{transform:translateX(-20px);opacity:0}to{transform:translateX(0);opacity:1}}
.pd-csv-req-head{display:flex;align-items:center;gap:8px;padding:16px 18px 8px;font-size:15px;font-weight:700;color:var(--txt)}
.pd-csv-req-badge{background:#EF9F27;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:100px;min-width:18px;text-align:center}
.pd-csv-req-close{margin-left:auto;background:none;border:none;font-size:16px;color:var(--txt3);cursor:pointer;padding:4px}
.pd-csv-req-close:hover{color:var(--txt)}
.pd-csv-req-sub{font-size:12px;color:var(--txt3);padding:0 18px 12px}
.pd-csv-req-list{flex:1;overflow-y:auto;padding:0 12px 12px}
@media(max-width:768px){.pd-csv-req-panel{width:100%;min-width:0;position:fixed;inset:0;z-index:100}}

/* 정렬 화살표 */
.pd-sort-arrow{font-size:10px;color:var(--green);font-weight:700;margin-left:2px}

/* 구분 (매입품/매출품) 뱃지 */
.pd-trade-badge{display:inline-flex;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:700;white-space:nowrap}
.pd-tt-buy{background:#B5D4F4;color:#0C447C}
.pd-tt-sell{background:#C0DD97;color:#27500A}
/* productType 배지 (원료/부자재/완제품) */
.pd-type-badge{display:inline-flex;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:700;white-space:nowrap}
.pd-pt-raw{background:#E6F1FB;color:#1565C0}
.pd-pt-sub{background:#FEF3DA;color:#7A4A08}
.pd-pt-fin{background:#E1F5EE;color:#0F6E56}

/* 행 삭제 버튼 */
.pd-row-del-btn{background:none;border:none;font-size:13px;cursor:pointer;padding:2px 4px;border-radius:4px;opacity:0.3;transition:all .12s;line-height:1}
.pd-row:hover .pd-row-del-btn{opacity:0.7}
.pd-row-del-btn:hover{opacity:1!important;background:rgba(226,75,74,0.08)}

/* 삭제/끝 컬럼 */
.pd-td-cell[data-col-type="delete"]{text-align:center}

/* ═══════════════════════════════════════════════════
   노션 스타일 멀티 선택 태그 검색기
   ═══════════════════════════════════════════════════ */
.pd-tag-multi-picker{min-width:260px;max-width:320px}
.pd-tag-head{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);min-height:36px}
.pd-tag-selected{display:flex;flex-wrap:wrap;gap:3px;align-items:center}
.pd-tag-sel-badge{display:inline-flex;align-items:center;gap:2px;border-radius:4px;overflow:hidden}
.pd-tag-sel-badge .tag-opt-badge{border-radius:4px 0 0 4px;padding-right:2px}
.pd-tag-sel-x{font-size:10px;color:rgba(0,0,0,0.35);cursor:pointer;padding:2px 5px 2px 2px;border-radius:0 4px 4px 0;transition:all .1s;line-height:1;display:flex;align-items:center}
.pd-tag-sel-x:hover{color:#E24B4A;background:rgba(226,75,74,0.08)}
.pd-tag-input{flex:1!important;min-width:80px!important;border:none!important;padding:4px 2px!important;font-size:13px!important;background:transparent!important;outline:none!important;box-shadow:none!important}
.pd-tag-drag-handle{font-size:10px;color:var(--txt3);opacity:0.4;cursor:grab;flex-shrink:0;padding:0 2px;user-select:none;transition:opacity .1s;letter-spacing:-1px}
.pd-tag-drag-handle:hover{opacity:1;color:var(--green)}

/* 헤더 정렬 활성 표시 (팝오버) */
.pd-hdr-pop-item-active{background:rgba(91,107,82,0.08)!important;font-weight:700;color:var(--green)!important}

/* ── 플로팅 선택 바 (마지막 체크 행 아래) ── */
.pd-sel-float{display:flex;align-items:center;gap:8px;padding:7px 16px;background:#2D3328;border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,0.18);animation:pdSelFloatIn .15s ease-out;z-index:5;white-space:nowrap;width:fit-content}
@keyframes pdSelFloatIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.pd-sel-float-count{font-size:13px;font-weight:600;color:#C0DD97;white-space:nowrap}
.pd-sel-float-sep{width:1px;height:18px;background:rgba(255,255,255,0.15);flex-shrink:0}
.pd-sel-float-btn{background:rgba(255,255,255,0.1);border:none;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;color:#fff;cursor:pointer;font-family:inherit;transition:background .12s;white-space:nowrap}
.pd-sel-float-btn:hover{background:rgba(255,255,255,0.2)}
.pd-sel-float-del{background:#E24B4A}
.pd-sel-float-del:hover{background:#c93d3d}

/* 모달 품목 태그선택기 */
.pd-modal-tag-picker{position:fixed;z-index:9500;background:var(--bg3);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px rgba(45,51,40,0.15);width:240px;overflow:hidden}
.pd-mtp-search{padding:8px 10px;border-bottom:1px solid var(--border)}
.pd-mtp-input{width:100%;font-size:13px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--txt);outline:none;font-family:inherit;box-sizing:border-box}
.pd-mtp-input:focus{border-color:var(--green)}
.pd-mtp-list{max-height:220px;overflow-y:auto}
.pd-mtp-opt{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .08s;font-size:13px}
.pd-mtp-opt:hover{background:var(--bg2)}
.pd-mtp-active{background:rgba(91,107,82,0.08);font-weight:600}
.pd-mtp-check{width:18px;text-align:center;font-size:12px;color:var(--green);flex-shrink:0}
.pd-mtp-create:hover{background:var(--green-bg)}


/* BOM 테이블 헤더 컬럼 너비 (table-layout:fixed 기반) */
.pd-bom-erp .pd-bom-th-del{width:28px}
.pd-bom-erp .pd-bom-td-chk,.pd-bom-erp th:first-child{width:30px}
.pd-bom-erp .pd-bom-td-handle,.pd-bom-erp th:nth-child(2){width:34px}

/* BOM 테이블 — 품목명 넓게, 삭제 좁게 */
.pd-bom-erp th:last-child,
.pd-bom-erp td:last-child{width:28px!important;max-width:28px!important;padding:0 2px!important;box-sizing:border-box}
.pd-bom-erp th.pd-bom-th-name,
.pd-bom-erp .pd-bom-td-name{width:40%!important}
