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

/* 사용법 팁 */
.pt-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}
.pt-tip-text{flex:1;font-size:12px;color:var(--txt2);line-height:1.6}
.pt-tip-close{background:none;border:none;font-size:14px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:4px;flex-shrink:0}
.pt-tip-close:hover{color:var(--txt);background:var(--bg2)}

/* 메인 탭 (제품 / 패키지·부자재) */
.pt-main-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0}
.pt-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}
.pt-main-tab:hover{color:var(--txt);background:rgba(91,107,82,0.04)}
.pt-main-tab-active{color:var(--green)!important;border-bottom-color:var(--green)!important}
.pt-main-tab-count{font-size:10px;font-weight:400;opacity:0.7;margin-left:4px;background:var(--bg2);padding:1px 6px;border-radius:100px}
.pt-main-tab-active .pt-main-tab-count{background:rgba(91,107,82,0.12)}

/* 툴바 */
.pt-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}
.pt-cats{display:flex;gap:4px;flex:1;flex-wrap:wrap;min-width:0}
.pt-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}
.pt-cat:hover{background:var(--bg2);color:var(--txt)}
.pt-cat-active{background:var(--green-bg)!important;border-color:var(--green)!important;color:var(--green)!important}
.pt-cat-count{font-size:10px;font-weight:400;opacity:0.7;margin-left:2px}

.pt-search-wrap{position:relative;min-width:180px;max-width:260px}
.pt-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none}
.pt-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}
.pt-search:focus{border-color:var(--green)}
.pt-search::placeholder{color:var(--txt3)}
.pt-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--txt3);cursor:pointer;padding:2px}
.pt-search-clear:hover{color:#E24B4A}
.pt-toolbar-actions{display:flex;gap:6px;margin-left:auto}
.pt-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}
.pt-tool-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}

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

/* 선택 툴바 */

.pt-sel-count{font-size:12px;font-weight:600;color:var(--green)}
.pt-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}
.pt-sel-btn:hover{background:var(--bg2);color:var(--txt)}
.pt-sel-btn-del{color:#E24B4A;border-color:rgba(226,75,74,0.3)}
.pt-sel-btn-del:hover{background:rgba(226,75,74,0.06)}

/* 테이블 */
.pt-table-wrap{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;background:var(--bg3);padding-bottom:60px}
.pt-table{width:max-content;min-width:100%;border-collapse:collapse;table-layout:fixed}
.pt-table thead{background:var(--bg2);position:sticky;top:0;z-index:4}
.pt-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}
.pt-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}
.pt-table tr{background:var(--bg3)}
.pt-table thead tr{background:var(--bg2)}

/* 틀고정 (sticky) 컬럼 */
.pt-sticky-col{position:sticky!important;background:var(--bg3)!important;z-index:2!important}
.pt-table thead .pt-sticky-col{background:var(--bg2)!important;z-index:5!important}
.pt-row:hover .pt-sticky-col{background:var(--bg2)!important}
.pt-row-selected .pt-sticky-col{background:rgba(91,107,82,0.06)!important}
.pt-row-active .pt-sticky-col{background:rgba(91,107,82,0.08)!important}

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

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

/* 이미지 썸네일 */
.pt-thumb{width:32px;height:32px;border-radius:5px;object-fit:cover;background:var(--bg2);border:1px solid var(--border);cursor:pointer}
.pt-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)}

/* 펼침 행 */
.pt-expand-row td{padding:0!important;background:var(--bg)!important;border-bottom:2px solid var(--green)}
.pt-expand{padding:18px 22px}
.pt-expand-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.pt-expand-title{font-size:16px;font-weight:700;color:var(--txt)}
.pt-expand-btns{display:flex;gap:6px}
.pt-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}
.pt-detail-label{color:var(--txt3);font-weight:600;font-size:11px;text-transform:uppercase;padding-top:2px;text-align:left}
.pt-detail-value{color:var(--txt);word-break:break-word;white-space:pre-wrap;line-height:1.6;text-align:left}

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

/* 모달 */
.pt-modal-bg{position:fixed;inset:0;background:rgba(45,51,40,0.4);z-index:9000;display:flex;align-items:center;justify-content:center}
.pt-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)}
.pt-modal h3{font-size:18px;font-weight:700;margin-bottom:18px;color:var(--txt)}
.pt-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.pt-form-full{grid-column:1/-1}
.pt-ff{display:flex;flex-direction:column;gap:3px}
.pt-ff label{font-size:11px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:0.04em}
.pt-ff input,.pt-ff select,.pt-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}
.pt-ff input:focus,.pt-ff select:focus,.pt-ff textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(91,107,82,0.06)}
.pt-ff textarea{resize:vertical;line-height:1.6}
.pt-ff-img-wrap{display:flex;align-items:center;gap:12px;margin-top:4px}
.pt-ff-img-preview{width:60px;height:60px;border-radius:8px;object-fit:cover;border:1px solid var(--border);background:var(--bg2)}
.pt-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}
.pt-ff-img-btn:hover{background:var(--bg);border-color:var(--green)}
.pt-ff-img-remove{background:none;border:none;font-size:12px;color:#E24B4A;cursor:pointer;padding:4px}

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

/* 모달 버튼 */
.pt-modal-btns{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
.pt-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)}
.pt-modal-btn:hover{background:var(--bg2)}
.pt-modal-btn-save{background:var(--green)!important;color:#fff!important;border-color:var(--green)!important}
.pt-modal-btn-save:hover{opacity:0.9}

/* 이미지 확대 오버레이 */
.pt-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}
.pt-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}
.pt-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)}
.pt-img-close:hover{background:rgba(255,255,255,0.3)}

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

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

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

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

/* ===== + 컬럼 추가 헤더 ===== */
.pt-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)}
.pt-th-add-col:hover{background:rgba(91,107,82,0.08)}

/* ===== 노션 스타일 헤더 팝오버 ===== */
.pt-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)}}

/* 이름 편집 영역 */
.pt-hdr-pop-name{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:2px 6px;border-radius:6px;background:var(--bg2)}
.pt-hdr-pop-icon{font-size:12px;font-weight:700;color:var(--txt3);flex-shrink:0;width:22px;text-align:center}
.pt-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}
.pt-hdr-pop-input::placeholder{color:var(--txt3)}
.pt-hdr-pop-input:focus{border-bottom:1.5px solid var(--green)}

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

/* 메뉴 항목 */
.pt-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}
.pt-hdr-pop-item:hover{background:rgba(91,107,82,0.06)}
.pt-hdr-pop-item-icon{width:20px;text-align:center;font-size:13px;flex-shrink:0;opacity:0.8}
.pt-hdr-pop-danger{color:#E24B4A!important}
.pt-hdr-pop-danger:hover{background:rgba(226,75,74,0.06)!important}

/* ===== 액션 컬럼 (＋ 복사 — 노션 스타일) ===== */
.pt-th-act,.pt-td-act{width:40px!important;min-width:40px!important;padding:0!important;text-align:center}
.pt-th-act-label{font-size:8px;line-height:1.2;color:var(--txt3);font-weight:600;letter-spacing:0}
.pt-row-act-wrap{display:flex;align-items:center;justify-content:center;gap:0;opacity:0;transition:opacity .1s}
.pt-row:hover .pt-row-act-wrap{opacity:1}
.pt-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}
.pt-act-add:hover{color:var(--green);background:rgba(91,107,82,0.08)}
.pt-act-copy:hover{color:#1967D2;background:rgba(25,103,210,0.08)}

/* ===== 열기 + 추가 버튼 래퍼 ===== */
.pt-row-btn-wrap{display:none;position:absolute;right:4px;top:50%;transform:translateY(-50%);z-index:6;gap:3px;align-items:center}
.pt-row:hover .pt-row-btn-wrap{display:flex}
.pt-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}
.pt-row-open-btn:hover{background:var(--bg2)!important;border-color:var(--green)}
.pt-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}
.pt-row-add-btn:hover{background:var(--green)!important;color:#fff;border-color:var(--green)}

/* ===== 인라인 편집 ===== */
.pt-td-cell{cursor:pointer;transition:background .08s}
.pt-td-cell:hover{background:rgba(91,107,82,0.04)}
.pt-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}
.pt-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}
.pt-inline-input:focus{box-shadow:0 0 0 3px rgba(91,107,82,0.1)}

/* ===== 인라인 드롭다운 ===== */
.pt-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}
.pt-inline-drop-opt{padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:background .08s;white-space:nowrap}
.pt-inline-drop-opt:hover{background:rgba(91,107,82,0.06)}
.pt-inline-drop-active{background:rgba(91,107,82,0.1)!important;font-weight:700}

/* ===== 팝오버 서브 표시 ===== */
.pt-hdr-pop-sub{margin-left:auto;font-size:10px;color:var(--txt3);font-weight:500;padding-left:10px}
.pt-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}

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

/* ===== 패널 헤더 아래 제조원가 바 ===== */
.pt-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}
.pt-panel-cost-label{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:0.04em}
.pt-panel-cost-val{font-size:15px;font-weight:800;color:var(--green)}

/* ===== 제품 상세 모달 ===== */
.pt-modal-overlay{position:fixed;inset:0;background:rgba(45,51,40,0.4);z-index:8000;display:flex;align-items:center;justify-content:center}
.pt-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)}}

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

/* 헤더 */
.pt-dm-head{display:flex;align-items:center;gap:10px;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.pt-dm-title{flex:1;font-size:18px;font-weight:800;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pt-dm-title-text{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .1s}
.pt-dm-title-text:hover{background:rgba(91,107,82,0.08)}
.pt-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}

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

.pt-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}
.pt-dm-close:hover{color:var(--txt);background:var(--bg2)}

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

/* 하단 버튼 */
.pt-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) {
  .pt-detail-modal{width:98vw!important;min-width:0!important;max-width:none!important;max-height:95vh;border-radius:12px}
}

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

/* ===== 우측 상세 패널 (업무요청과 동일 패턴) ===== */
.pt-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}
.pt-panel.open{width:44vw;min-width:420px}

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

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

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

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

.pt-panel-fields{display:flex;flex-direction:column;gap:0;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.pt-panel-field{display:flex;align-items:center;min-height:44px;padding:0;border-bottom:1px solid var(--border);transition:background .08s}
.pt-panel-field:last-child{border-bottom:none}
.pt-panel-field:hover{background:rgba(91,107,82,0.03)}
.pt-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}
.pt-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}
.pt-panel-field-value:hover{background:rgba(91,107,82,0.06)}

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

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

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

/* ===== 패널 타이틀 편집 ===== */
.pt-panel-title-text{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .1s}
.pt-panel-title-text:hover{background:rgba(91,107,82,0.08)}
.pt-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}
.pt-panel-title-input:focus{box-shadow:0 0 0 3px rgba(91,107,82,0.12)}

/* ===== 패널 이미지 갤러리 (컴팩트 — 요약 탭 안) ===== */
.pt-gallery-compact{margin-bottom:14px}
.pt-gallery-compact .pt-panel-gallery-grid{grid-template-columns:repeat(5,1fr);gap:4px}
.pt-gallery-compact .pt-panel-gallery-item{aspect-ratio:1/1;border-radius:6px}
.pt-gallery-compact .pt-panel-gallery-add{aspect-ratio:1/1;border-radius:6px;font-size:16px}
.pt-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}

/* ===== 사양 탭 이미지 ===== */
.pt-spec-img-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}
.pt-spec-img-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px}
.pt-spec-img-label{font-size:9px;color:var(--txt3);text-align:center;white-space:nowrap}
.pt-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}
.pt-spec-img-name:hover{background:rgba(91,107,82,0.08);color:var(--green)}
.pt-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}
.pt-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}
.pt-spec-img-item:hover .pt-spec-img-del{display:flex}
.pt-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}
.pt-spec-img-add:hover{border-color:var(--green);color:var(--green)}

/* ===== 사양 탭 작은 썸네일 ===== */
.pt-spec-thumbs{display:flex;gap:4px;flex-wrap:wrap}
.pt-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}
.pt-spec-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px rgba(45,51,40,0.15);z-index:1}

/* ===== 패널 이미지 갤러리 (3열) ===== */
.pt-panel-gallery{margin-bottom:14px}
.pt-panel-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.pt-panel-gallery-item{position:relative;aspect-ratio:3/4;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--bg2)}
.pt-panel-gallery-item img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}
.pt-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}
.pt-panel-gallery-item:hover .pt-panel-gallery-del{display:flex}
.pt-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)}
.pt-panel-gallery-add:hover{border-color:var(--green);color:var(--green);background:rgba(91,107,82,0.03)}

/* ===== 패널 탭 ===== */
.pt-panel-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px;flex-shrink:0}
.pt-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}
.pt-panel-tab:hover{color:var(--txt);background:rgba(91,107,82,0.03)}
.pt-panel-tab-active{color:var(--green)!important;border-bottom-color:var(--green)!important}

/* ===== 원가 계산기 ===== */
.pt-cost-calc{padding:0}
.pt-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}
.pt-cost-h-name{flex:2;padding-left:4px}
.pt-cost-h-price{width:80px;text-align:center}
.pt-cost-h-qty{width:52px;text-align:center}
.pt-cost-h-sub{width:80px;text-align:right}
.pt-cost-h-del{width:28px}

.pt-cost-row{display:flex;gap:4px;align-items:center;padding:4px 0;border-bottom:1px solid rgba(213,216,208,0.4)}
.pt-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}
.pt-cost-input:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(91,107,82,0.08)}
.pt-cost-name{flex:2}
.pt-cost-price{width:80px;text-align:right}
.pt-cost-qty{width:52px;text-align:center}
.pt-cost-sub{width:80px;text-align:right;font-size:12px;font-weight:600;color:var(--txt)}
.pt-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}
.pt-cost-del:hover{color:#E24B4A;background:rgba(226,75,74,0.06)}

.pt-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}
.pt-cost-add-btn:hover{background:rgba(91,107,82,0.04);border-color:var(--green)}

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

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

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

.pt-sum-section{margin-bottom:16px}
.pt-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}
.pt-sum-section-title::before{content:'■';font-size:8px;color:var(--green)}

.pt-sum-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.pt-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}
.pt-sum-field:nth-child(2n){border-right:none}
.pt-sum-card>.pt-sum-field:last-child{border-bottom:none}
.pt-sum-card>.pt-sum-field:nth-last-child(2):nth-child(odd){border-bottom:none}
.pt-sum-card.pt-sum-card-single{grid-template-columns:1fr}
.pt-sum-card.pt-sum-card-single .pt-sum-field{border-right:none}
.pt-sum-card.pt-sum-card-single .pt-sum-field:last-child{border-bottom:none}
@media(max-width:600px){.pt-sum-card{grid-template-columns:1fr}.pt-sum-field{border-right:none!important}}
.pt-sum-field:hover{background:rgba(91,107,82,0.03)}
.pt-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}
.pt-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}
.pt-sum-editable .pt-sum-field-value{cursor:pointer;border-radius:0}
.pt-sum-editable .pt-sum-field-value:hover{background:rgba(91,107,82,0.06)}

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

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

.pt-bom-erp-wrap{overflow-x:auto;margin-bottom:10px;border:1px solid var(--border);border-radius:8px}
.pt-bom-erp{width:100%;border-collapse:collapse;table-layout:fixed;min-width:520px}
.pt-bom-erp thead{background:var(--bg2);position:sticky;top:0;z-index:1}
.pt-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}
.pt-bom-th-chk{width:28px;text-align:center!important}
.pt-bom-th-handle{width:32px;text-align:center!important}
.pt-bom-th-name{width:auto}
.pt-bom-th-cat{width:60px;text-align:center}
.pt-bom-th-unit{width:50px;text-align:center}
.pt-bom-th-qty{width:64px;text-align:right}
.pt-bom-th-uprice{width:72px;text-align:right}
.pt-bom-th-amount{width:72px;text-align:right}
.pt-bom-th-total{width:80px;text-align:right}
.pt-bom-th-del{width:28px}

/* 선택 바 */
.pt-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}
.pt-bom-sel-count{font-size:12px;font-weight:600;color:var(--green)}
.pt-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}
.pt-bom-sel-del:hover{background:rgba(226,75,74,0.06)}

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

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

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

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

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

.pt-bom-name-wrap{display:flex;align-items:center;gap:4px}
.pt-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}
.pt-bom-search-btn:hover{opacity:1;background:rgba(91,107,82,0.08)}
.pt-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}
.pt-bom-name-input:focus{border-color:var(--green);background:var(--bg);box-shadow:0 0 0 2px rgba(91,107,82,0.06)}
.pt-bom-name-input::placeholder{color:var(--txt3);font-weight:400}
.pt-bom-link-badge{font-size:10px;flex-shrink:0}

.pt-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}
.pt-bom-cat-chip:hover{background:rgba(91,107,82,0.16)}

.pt-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}
.pt-bom-cell-input:focus{border-color:var(--green);background:var(--bg);box-shadow:0 0 0 2px rgba(91,107,82,0.06)}
.pt-bom-unit-input{text-align:center}
.pt-bom-amount-val{font-size:11px;font-weight:600;color:var(--txt);white-space:nowrap}
.pt-bom-conv-price{font-size:11px;font-weight:500;color:var(--txt2);white-space:nowrap}
.pt-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}
.pt-bom-del-btn:hover{color:#E24B4A;background:rgba(226,75,74,0.06)}

/* 셀 호버 클리어 버튼 */
.pt-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}
.pt-bom-cell-clear:hover{color:#E24B4A;background:rgba(226,75,74,0.08)}
td:hover .pt-bom-cell-clear{display:inline}

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

/* ⬇ 행 추가 */
.pt-bom-add-row-wrap{display:flex;justify-content:center;padding:4px 0;border-top:1px solid var(--border)}
.pt-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}
.pt-bom-add-row-btn:hover{background:rgba(91,107,82,0.08)}

/* 배합 모드 바 */
.pt-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}
.pt-bom-mix-label{font-size:12px;font-weight:700;color:var(--txt2);flex-shrink:0}
.pt-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}
.pt-bom-mix-vol:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(91,107,82,0.08)}
.pt-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}
.pt-bom-mix-toggle-wrap{display:flex;align-items:center;gap:6px;margin-left:auto}
.pt-bom-mix-toggle-label{font-size:11px;font-weight:600;color:var(--txt2)}

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

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

/* 비율 합계 게이지 */
.pt-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}
.pt-bom-ratio-gauge{flex:1;height:6px;background:var(--bg2);border-radius:100px;overflow:hidden}
.pt-bom-ratio-gauge-fill{height:100%;border-radius:100px;transition:width .2s,background .2s}
.pt-bom-ratio-val{font-size:13px;font-weight:700;flex-shrink:0;min-width:40px;text-align:right}

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

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

.pt-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)}
.pt-mat-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 12px;flex-shrink:0}
.pt-mat-modal-head h3{font-size:16px;font-weight:700;color:var(--txt);margin:0}
.pt-mat-modal-close{background:none;border:none;font-size:18px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .1s}
.pt-mat-modal-close:hover{color:var(--txt);background:var(--bg2)}

.pt-mat-modal-search{padding:0 22px 8px}
.pt-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}
.pt-mat-modal-input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(91,107,82,0.08)}

/* 필터 */
.pt-mat-modal-filters{padding:0 22px 10px;display:flex;flex-direction:column;gap:6px}
.pt-mat-filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pt-mat-filter-label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em;flex-shrink:0;width:32px}
.pt-mat-filter-chips{display:flex;gap:3px;flex-wrap:wrap}
.pt-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}
.pt-mat-chip:hover{background:var(--bg);border-color:var(--border);color:var(--txt)}
.pt-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}
.pt-mat-chip-count{font-size:9px;opacity:0.6;margin-left:2px}

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

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

/* ═══════════════════════════════════════════════════
   구분 필터 태그 검색기
   ═══════════════════════════════════════════════════ */
.pt-cat-filter-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}
.pt-cat-filter-label{font-size:11px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.04em;flex-shrink:0}
.pt-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}
.pt-cat-filter-btn:hover{border-color:var(--green);background:rgba(91,107,82,0.04)}
.pt-cat-filter-clear{font-size:11px;color:var(--txt3);margin-left:2px;padding:0 2px;border-radius:3px;transition:color .1s}
.pt-cat-filter-clear:hover{color:#E24B4A}
.pt-cat-filter-count{margin-left:auto;font-size:10px;font-weight:400;color:var(--txt3);opacity:0.7;padding-left:8px}
.pt-cat-filter-picker{min-width:240px}
.pt-cat-filter-picker .tag-opt{display:flex;align-items:center;gap:6px}

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

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

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

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

/* ═══════════════════════════════════════════════════
   CSV 내보내기 승인 요청 패널 (캘린더 연차 패턴)
   ═══════════════════════════════════════════════════ */
.pt-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}}
.pt-csv-req-head{display:flex;align-items:center;gap:8px;padding:16px 18px 8px;font-size:15px;font-weight:700;color:var(--txt)}
.pt-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}
.pt-csv-req-close{margin-left:auto;background:none;border:none;font-size:16px;color:var(--txt3);cursor:pointer;padding:4px}
.pt-csv-req-close:hover{color:var(--txt)}
.pt-csv-req-sub{font-size:12px;color:var(--txt3);padding:0 18px 12px}
.pt-csv-req-list{flex:1;overflow-y:auto;padding:0 12px 12px}
@media(max-width:768px){.pt-csv-req-panel{width:100%;min-width:0;position:fixed;inset:0;z-index:100}}

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

/* 구분 (매입품/매출품) 뱃지 */
.pt-trade-badge{display:inline-flex;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:700;white-space:nowrap}
.pt-tt-buy{background:#B5D4F4;color:#0C447C}
.pt-tt-sell{background:#C0DD97;color:#27500A}

/* 행 삭제 버튼 */
.pt-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}
.pt-row:hover .pt-row-del-btn{opacity:0.7}
.pt-row-del-btn:hover{opacity:1!important;background:rgba(226,75,74,0.08)}

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

/* ═══════════════════════════════════════════════════
   노션 스타일 멀티 선택 태그 검색기
   ═══════════════════════════════════════════════════ */
.pt-tag-multi-picker{min-width:260px;max-width:320px}
.pt-tag-head{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);min-height:36px}
.pt-tag-selected{display:flex;flex-wrap:wrap;gap:3px;align-items:center}
.pt-tag-sel-badge{display:inline-flex;align-items:center;gap:2px;border-radius:4px;overflow:hidden}
.pt-tag-sel-badge .tag-opt-badge{border-radius:4px 0 0 4px;padding-right:2px}
.pt-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}
.pt-tag-sel-x:hover{color:#E24B4A;background:rgba(226,75,74,0.08)}
.pt-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}
.pt-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}
.pt-tag-drag-handle:hover{opacity:1;color:var(--green)}

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

/* ── 플로팅 선택 바 (마지막 체크 행 아래) ── */
.pt-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)}}
.pt-sel-float-count{font-size:13px;font-weight:600;color:#C0DD97;white-space:nowrap}
.pt-sel-float-sep{width:1px;height:18px;background:rgba(255,255,255,0.15);flex-shrink:0}
.pt-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}
.pt-sel-float-btn:hover{background:rgba(255,255,255,0.2)}
.pt-sel-float-del{background:#E24B4A}
.pt-sel-float-del:hover{background:#c93d3d}

/* 모달 품목 태그선택기 */
.pt-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}
.pt-mtp-search{padding:8px 10px;border-bottom:1px solid var(--border)}
.pt-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}
.pt-mtp-input:focus{border-color:var(--green)}
.pt-mtp-list{max-height:220px;overflow-y:auto}
.pt-mtp-opt{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .08s;font-size:13px}
.pt-mtp-opt:hover{background:var(--bg2)}
.pt-mtp-active{background:rgba(91,107,82,0.08);font-weight:600}
.pt-mtp-check{width:18px;text-align:center;font-size:12px;color:var(--green);flex-shrink:0}
.pt-mtp-create:hover{background:var(--green-bg)}


/* ─── 취급품목 Live Join 탭 (BOM 탭 대체) ─── */
.pt-live-join-info{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(91,107,82,0.06);border:1px solid rgba(91,107,82,0.15);border-radius:6px;margin-bottom:10px;font-size:12px}
.pt-live-join-badge{background:var(--green,#5B6B52);color:#fff;font-weight:700;padding:3px 8px;border-radius:4px;font-size:11px;white-space:nowrap}
.pt-live-join-text{color:var(--txt2)}
.pt-live-join-text b{color:var(--txt)}
.pt-bom-empty-hint{padding:24px;text-align:center;color:var(--txt3);font-size:13px;background:var(--bg2);border-radius:6px;margin-top:10px}

/* 취급품목 인라인 추가 폼 */
.pt-lj-add-form{display:flex;gap:6px;align-items:stretch;padding:8px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;margin-bottom:10px}
.pt-lj-add-input{padding:6px 8px;font-size:12px;border:1px solid var(--border);border-radius:4px;background:#fff;color:var(--txt);min-width:0}
.pt-lj-add-input:focus{outline:none;border-color:var(--green,#5B6B52);box-shadow:0 0 0 2px rgba(91,107,82,0.12)}
.pt-lj-add-btn{padding:6px 14px;font-size:12px;font-weight:700;background:var(--green,#5B6B52);color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .1s}
.pt-lj-add-btn:hover{background:var(--dark,#2D3328)}

/* 취급품목 Live Join 테이블 */
.pt-live-join-table-wrap{border:1px solid var(--border);border-radius:6px;overflow:auto;max-height:400px}
.pt-live-join-table{width:100%;border-collapse:collapse;font-size:12px}
.pt-live-join-table thead{position:sticky;top:0;background:var(--bg2);z-index:1}
.pt-live-join-table th{padding:8px 10px;text-align:left;font-weight:600;color:var(--txt2);border-bottom:1px solid var(--border);white-space:nowrap}
.pt-live-join-table td{padding:8px 10px;border-bottom:1px solid var(--border)}
.pt-live-join-table tr:last-child td{border-bottom:none}
.pt-live-join-table tr:hover td{background:var(--bg2)}
.pt-lj-thumb{width:32px;height:32px;object-fit:cover;border-radius:4px;cursor:pointer}
.pt-lj-thumb-empty{display:inline-block;width:32px;height:32px;line-height:32px;text-align:center;background:var(--bg2);border-radius:4px;font-size:14px}
.pt-lj-td-img{width:44px}
.pt-lj-td-date{color:var(--txt3);font-size:11px;white-space:nowrap}
.pt-lj-td-go{text-align:center;width:44px}
.pt-lj-goto-btn{padding:4px 8px;font-size:13px;background:var(--bg2);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:background .1s}
.pt-lj-goto-btn:hover{background:var(--green,#5B6B52);color:#fff;border-color:var(--green,#5B6B52)}

/* ═══════════════════════════════════════════════
   플로팅 바 드래그 핸들 + 벌크 편집 (거래처 · 제품 공통)
   ═══════════════════════════════════════════════ */
.pt-sel-float-handle,
.pd-sel-float-handle {
  display: inline-block;
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  cursor: grab;
  padding: 4px 6px;
  margin-right: 2px;
  user-select: none;
  border-radius: 4px;
  line-height: 1;
  letter-spacing: -2px;
}
.pt-sel-float-handle:hover,
.pd-sel-float-handle:hover {
  color: #FFF;
  background: rgba(255,255,255,0.1);
}
.pt-sel-float-dragging,
.pd-sel-float-dragging {
  cursor: grabbing !important;
  opacity: 0.85;
  box-shadow: 0 10px 28px rgba(0,0,0,0.35) !important;
}
.pt-sel-float-dragging .pt-sel-float-handle,
.pd-sel-float-dragging .pd-sel-float-handle {
  cursor: grabbing !important;
}

/* 벌크 편집 모달 (거래처·제품 공통 디자인) */
.pt-bulk-overlay,
.pd-bulk-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 20000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: pdSelFloatIn 0.15s ease-out;
}
.pt-bulk-modal,
.pd-bulk-modal {
  background: var(--bg2);
  border-radius: 10px;
  width: 460px;
  max-width: 100%;
  box-shadow: 0 16px 48px rgba(0,0,0,0.3);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.pt-bulk-head,
.pd-bulk-head {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  font-weight: 700;
  font-size: 14px;
  color: var(--txt);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg3);
}
.pt-bulk-close,
.pd-bulk-close {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--txt2);
  cursor: pointer;
  padding: 0 6px;
  line-height: 1;
}
.pt-bulk-close:hover,
.pd-bulk-close:hover {
  color: var(--txt);
}
.pt-bulk-body,
.pd-bulk-body {
  padding: 16px 18px;
  background: var(--bg2);
}
.pt-bulk-warn,
.pd-bulk-warn {
  background: #FFF4DE;
  border: 1px solid #F0D690;
  color: #7A5610;
  padding: 9px 12px;
  border-radius: 6px;
  font-size: 11px;
  margin-bottom: 14px;
  line-height: 1.5;
}
.pt-bulk-warn b,
.pd-bulk-warn b {
  color: #5A3E08;
}
.pt-bulk-label,
.pd-bulk-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--txt2);
  margin-bottom: 6px;
}
.pt-bulk-select,
.pd-bulk-select,
.pt-bulk-input,
.pd-bulk-input {
  width: 100%;
  padding: 9px 11px;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg3);
  color: var(--txt);
  font-family: inherit;
  box-sizing: border-box;
}
.pt-bulk-select:focus,
.pd-bulk-select:focus,
.pt-bulk-input:focus,
.pd-bulk-input:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg2);
}
.pt-bulk-hint,
.pd-bulk-hint {
  font-size: 10px;
  color: var(--txt3);
  margin-top: 5px;
  line-height: 1.5;
}
.pt-bulk-radio-group,
.pd-bulk-radio-group {
  display: flex;
  gap: 14px;
  padding: 8px 0;
}
.pt-bulk-radio,
.pd-bulk-radio {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--txt);
  cursor: pointer;
}
.pt-bulk-radio input[type="radio"],
.pd-bulk-radio input[type="radio"] {
  accent-color: var(--accent);
}
.pt-bulk-foot,
.pd-bulk-foot {
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  background: var(--bg3);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.pt-bulk-btn,
.pd-bulk-btn {
  padding: 8px 16px;
  font-size: 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg2);
  color: var(--txt);
  cursor: pointer;
  font-family: inherit;
  font-weight: 500;
}
.pt-bulk-btn:hover,
.pd-bulk-btn:hover {
  background: var(--border);
}
.pt-bulk-btn-primary,
.pd-bulk-btn-primary {
  background: #2D5128;
  color: #FFF;
  border-color: #2D5128;
}
.pt-bulk-btn-primary:hover,
.pd-bulk-btn-primary:hover {
  background: #1F3A1C;
  border-color: #1F3A1C;
}

/* 체크박스 셀 드래그 선택 커서 힌트 */
.pt-td-chk, .pd-td-chk { cursor: cell; }
.pt-td-chk input, .pd-td-chk input { cursor: pointer; }

/* ═══ 연결된 견적서/거래명세서 이력 테이블 ═══ */
.pt-linked-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  table-layout: fixed;
}
.pt-linked-table thead th {
  background: var(--bg2, #F5F5F5);
  color: var(--txt3, #6B6B6B);
  font-weight: 600;
  font-size: 11px;
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border, #EAEAEA);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-linked-table tbody td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--border, #EAEAEA);
  color: var(--txt, #1A1A1A);
  vertical-align: middle;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-linked-table tbody tr:last-child td {
  border-bottom: none;
}
.pt-linked-row {
  transition: background .1s;
  cursor: pointer;
}
.pt-linked-row:hover td {
  background: #FFFBF0;
}
.pt-linked-badge {
  display: inline-block;
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 500;
  white-space: nowrap;
}
/* 빈 상태 행 */
.pt-linked-table .pt-linked-empty td {
  text-align: center;
  padding: 24px 12px;
  color: var(--txt3, #9A9A9A);
  font-size: 12px;
}
/* 번호 셀 (모노스페이스) */
.pt-linked-mono {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 11px;
  color: var(--txt2, #3A3A3A);
}
/* 날짜 셀 */
.pt-linked-date {
  font-size: 11px;
  color: var(--txt3, #6B6B6B);
}
/* 프로젝트 셀 (말줄임) */
.pt-linked-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 다크모드 */
body.dark .pt-linked-table thead th {
  background: var(--bg2, #2d2b28);
  color: var(--txt3, #9A9690);
  border-bottom-color: var(--border, #3a3733);
}
body.dark .pt-linked-table tbody td {
  color: var(--txt, #EDEAE4);
  border-bottom-color: var(--border, #3a3733);
}
body.dark .pt-linked-row:hover td {
  background: #2e2a1e;
}

/* 새 견적서/거래명세서 버튼 */
.pt-linked-new-btn {
  background: #FFFFFF;
  border: 1px solid #D97706;
  color: #D97706;
  font-size: 11px;
  font-weight: 500;
  padding: 4px 12px;
  border-radius: 5px;
  cursor: pointer;
  font-family: inherit;
  transition: all .1s;
}
.pt-linked-new-btn:hover {
  background: #D97706;
  color: #FFFFFF;
}
body.dark .pt-linked-new-btn {
  background: #242220;
  border-color: #D97706;
  color: #D97706;
}
body.dark .pt-linked-new-btn:hover {
  background: #D97706;
  color: #FFFFFF;
}
