/* ═══ SOURCING-OPS STYLES (scoped .so-scope) ════════════════════════
 * 원본 sourcing-ops index.html 내 <style> 블록 이식.
 * 모든 규칙을 .so-scope 하위로 스코핑 → 옥토퍼스원 기존 CSS와 격리.
 * 모달 규칙은 .so-modal-* 접두사 (so-core.js의 soShowModal 구조에 맞춤).
 * 원본의 body/sidebar/topbar/nav-* 규칙은 옥토퍼스원이 자체 레이아웃을
 * 제공하므로 제외.
 * ════════════════════════════════════════════════════════════════════ */

/* ── 페이지 컨테이너 폭 해제 ─────────────────────────────
 * 옥토퍼스원 기본 .page는 max-width:980px로 중앙정렬.
 * sourcing 페이지는 와이드 테이블이 많아 980px이면 셀이 눌려
 * 세로로 wrap됨 → 전체 폭 사용하도록 해제.
 * app-main의 overflow-x:hidden도 있어 페이지 밖으로 튀지 않음. */
.page.so-scope { max-width: none; padding: 16px 20px; }

/* ── 소싱 CSS 변수 (로컬 스코핑) ───────────────────────── */
.so-scope {
  --primary: #0E7490;       /* deep teal — THEME B 통일 */
  --primary-dark: #155E75;
  --primary-light: #CFFAFE;
  --surface: #FFFFFF;
  --surface-2: #F8FAFC;
  --border: #E2E8F0;
  --text: #1E293B;
  --text-muted: #64748B;
  --success: #10B981;
  --warning: #F59E0B;
  --danger: #EF4444;
  --info: #3B82F6;
  --radius: 10px;
  --shadow: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.10);
}

/* ── Buttons ────────────────────────────────────────────── */
/* width:auto 명시: auth.css의 전역 .btn-primary{width:100%} 오버라이드 */
.so-scope .btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 8px; font-size: 13.5px; font-weight: 500; cursor: pointer; border: none; transition: all 0.15s; text-decoration: none; font-family: inherit; width: auto; }
.so-scope .btn-primary { background: var(--primary); color: #fff; width: auto; padding: 8px 16px; }
.so-scope .btn-primary:hover { background: var(--primary-dark); }
.so-scope .btn-outline { background: transparent; color: var(--text); border: 1px solid var(--border); }
.so-scope .btn-outline:hover { background: var(--surface-2); }
.so-scope .btn-success { background: var(--success); color: #fff; }
.so-scope .btn-danger { background: var(--danger); color: #fff; }
.so-scope .btn-warning { background: var(--warning); color: #fff; }
.so-scope .btn-sm { padding: 5px 11px; font-size: 12.5px; border-radius: 6px; }
.so-scope .btn-xs { padding: 3px 8px; font-size: 11.5px; border-radius: 5px; }
.so-scope .btn-icon { padding: 8px; border-radius: 8px; }
.so-scope .btn-ghost { background: transparent; color: var(--text-muted); border: none; }
.so-scope .btn-ghost:hover { background: var(--surface-2); color: var(--text); }

/* ── Cards ──────────────────────────────────────────────── */
.so-scope .card { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 20px; box-shadow: var(--shadow); }
.so-scope .card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.so-scope .card-title { font-size: 14px; font-weight: 600; color: var(--text); }

/* ── Stats ──────────────────────────────────────────────── */
.so-scope .stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.so-scope .stat-card { background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 18px 20px; box-shadow: var(--shadow); }
.so-scope .stat-label { font-size: 12px; color: var(--text-muted); font-weight: 500; margin-bottom: 8px; }
.so-scope .stat-value { font-size: 26px; font-weight: 700; color: var(--text); }
.so-scope .stat-sub { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.so-scope .stat-icon { width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; margin-bottom: 10px; }

/* ── Table ──────────────────────────────────────────────── */
.so-scope .table-wrap { overflow-x: auto; }
.so-scope table { width: 100%; border-collapse: collapse; }
.so-scope th { background: var(--surface-2); font-size: 12px; font-weight: 600; color: var(--text-muted); padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--border); white-space: nowrap; }
/* td nowrap: 'Shanghai Kada zhiqu...' 같은 긴 컨텐츠가 세로로 쌓이지 않게.
 * 너무 길면 .table-wrap의 overflow-x:auto로 가로 스크롤. */
.so-scope td { padding: 11px 14px; border-bottom: 1px solid var(--border); font-size: 13.5px; color: var(--text); vertical-align: middle; white-space: nowrap; }
/* 긴 텍스트 셀은 JS에서 max-width와 text-overflow:ellipsis로 처리 중 */
.so-scope tr:last-child td { border-bottom: none; }
.so-scope tr:hover td { background: #F8FAFC; will-change: background; }
.so-scope .td-link { color: var(--primary); font-weight: 500; cursor: pointer; }
.so-scope .td-link:hover { text-decoration: underline; }
.so-scope .search-result-item { padding: 10px 14px; cursor: pointer; border-bottom: 1px solid var(--border); }
.so-scope .search-result-item:hover { background: var(--surface-2); }

/* ── Badges ─────────────────────────────────────────────── */
.so-scope .badge { display: inline-flex; align-items: center; padding: 3px 8px; border-radius: 5px; font-size: 11.5px; font-weight: 600; }
.so-scope .badge-blue { background: #DBEAFE; color: #1D4ED8; }
.so-scope .badge-green { background: #D1FAE5; color: #065F46; }
.so-scope .badge-yellow { background: #FEF3C7; color: #92400E; }
.so-scope .badge-red { background: #FEE2E2; color: #991B1B; }
.so-scope .badge-gray { background: #F1F5F9; color: #475569; }
.so-scope .badge-purple { background: #EDE9FE; color: #5B21B6; }
.so-scope .badge-cyan { background: #E0F7FF; color: #0369A1; }

/* ── Forms ──────────────────────────────────────────────── */
.so-scope .form-grid { display: grid; gap: 18px; }
.so-scope .form-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.so-scope .form-row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.so-scope .form-row-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.so-scope .form-group { display: flex; flex-direction: column; gap: 6px; }
.so-scope .form-label { font-size: 12.5px; font-weight: 600; color: var(--text-muted); }
.so-scope .form-label .required { color: var(--danger); margin-left: 2px; }
/* width:100% 명시: form-group(flex-column) 안에서 꽉 차게. 오버라이드는 부모 flex로 조정 */
.so-scope .form-input,
.so-scope .form-select,
.so-scope .form-textarea { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 13.5px; color: var(--text); background: var(--surface); outline: none; transition: border 0.15s; font-family: inherit; width: 100%; }
.so-scope .form-input:focus,
.so-scope .form-select:focus,
.so-scope .form-textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(14,165,201,0.1); }
.so-scope .form-input::placeholder { color: #CBD5E1; }
.so-scope .form-textarea { resize: vertical; min-height: 80px; }
.so-scope .form-hint { font-size: 11.5px; color: var(--text-muted); }
.so-scope .form-section { background: var(--surface-2); border-radius: 10px; padding: 16px 18px; border: 1px solid var(--border); }
.so-scope .form-section-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }

/* ── Search bar ─────────────────────────────────────────── */
/* width:auto로 features.css의 전역 .search-input{width:100%} 오버라이드
 * (sourcing은 JS에서 style="width:200px" 등으로 개별 지정) */
.so-scope .search-bar { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); padding: 16px 18px; margin-bottom: 16px; box-shadow: var(--shadow); }
.so-scope .search-field { display: flex; flex-direction: column; gap: 5px; }
.so-scope .search-label { font-size: 11.5px; font-weight: 600; color: var(--text-muted); }
.so-scope .search-input { padding: 7px 11px; border: 1.5px solid var(--border); border-radius: 7px; font-size: 13px; color: var(--text); outline: none; background: var(--surface); font-family: inherit; width: auto; box-shadow: none; }
.so-scope .search-input:focus { border-color: var(--primary); }

/* ── PI Preview (발주 PI 문서 — 프린트 대비) ───────────── */
.so-scope .so-pi-doc { background: #fff; border: 1px solid #ddd; border-radius: 8px; padding: 36px 40px; max-width: 900px; margin: 0 auto; font-family: 'Times New Roman', serif; color: #111; }
.so-scope .so-pi-header { text-align: center; margin-bottom: 20px; }
.so-scope .so-pi-company-name { font-size: 18px; font-weight: 700; }
.so-scope .so-pi-title { font-size: 22px; font-weight: 700; letter-spacing: 2px; margin: 6px 0; }
.so-scope .so-pi-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 16px 0; font-size: 12px; }
.so-scope .so-pi-party { border: 1px solid #ccc; padding: 10px 12px; border-radius: 4px; }
.so-scope .so-pi-party-label { font-weight: 700; margin-bottom: 4px; font-size: 11px; color: #555; }
.so-scope .so-pi-items { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 12px; }
.so-scope .so-pi-items th { background: #f0f0f0; border: 1px solid #ccc; padding: 7px 10px; text-align: center; font-weight: 700; }
.so-scope .so-pi-items td { border: 1px solid #ccc; padding: 7px 10px; vertical-align: top; }
.so-scope .so-pi-total { text-align: right; font-weight: 700; font-size: 13px; margin: 8px 0; }
.so-scope .so-pi-terms { font-size: 11.5px; margin: 12px 0; }
.so-scope .so-pi-terms-row { display: flex; gap: 8px; margin: 3px 0; }
.so-scope .so-pi-terms-key { font-weight: 700; min-width: 140px; }
.so-scope .so-pi-bank { margin-top: 12px; font-size: 11.5px; border: 1px solid #ccc; padding: 10px 12px; border-radius: 4px; }
.so-scope .so-pi-bank-title { font-weight: 700; margin-bottom: 6px; }
.so-scope .so-pi-bank-body { display: flex; gap: 14px; align-items: flex-start; }
.so-scope .so-pi-bank-text { flex: 1; min-width: 0; }
.so-scope .so-pi-bank-row { display: flex; gap: 8px; margin: 2px 0; }
.so-scope .so-pi-bank-key { min-width: 180px; font-weight: 600; }
.so-scope .so-pi-bank-stamp { flex: 0 0 140px; display: flex; align-items: center; justify-content: center; }
.so-scope .so-pi-bank-stamp img { max-width: 130px; max-height: 130px; object-fit: contain; }
.so-scope .so-pi-sign { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.so-scope .so-pi-sign-box { border-top: 1px solid #333; padding-top: 8px; text-align: center; font-size: 12px; }

/* ── Tabs ───────────────────────────────────────────────── */
.so-scope .tabs { display: flex; gap: 0; border-bottom: 2px solid var(--border); margin-bottom: 20px; }
.so-scope .tab { padding: 10px 20px; font-size: 13.5px; font-weight: 500; color: var(--text-muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.so-scope .tab.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }
.so-scope .tab:hover:not(.active) { color: var(--text); }

/* ── Status steps ───────────────────────────────────────── */
.so-scope .status-steps { display: flex; gap: 0; margin: 16px 0; }
.so-scope .step { flex: 1; text-align: center; position: relative; }
.so-scope .step::before { content: ''; position: absolute; top: 14px; left: 50%; right: -50%; height: 2px; background: var(--border); z-index: 0; }
.so-scope .step:last-child::before { display: none; }
.so-scope .step-dot { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--border); background: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; margin: 0 auto 6px; position: relative; z-index: 1; }
.so-scope .step.done .step-dot { background: var(--success); border-color: var(--success); color: #fff; }
.so-scope .step.active .step-dot { background: var(--primary); border-color: var(--primary); color: #fff; }
.so-scope .step.done::before { background: var(--success); }
.so-scope .step-label { font-size: 11px; color: var(--text-muted); }
.so-scope .step.active .step-label { color: var(--primary); font-weight: 600; }
.so-scope .step.done .step-label { color: var(--success); }

/* ── Empty state ────────────────────────────────────────── */
.so-scope .empty { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.so-scope .empty-icon { font-size: 48px; margin-bottom: 12px; }
.so-scope .empty-text { font-size: 15px; font-weight: 500; color: var(--text); }
.so-scope .empty-sub { font-size: 13px; margin-top: 6px; }

/* ── Alerts ─────────────────────────────────────────────── */
.so-scope .alert { padding: 12px 16px; border-radius: 8px; font-size: 13.5px; margin-bottom: 16px; display: flex; align-items: flex-start; gap: 10px; }
.so-scope .alert-info { background: #EFF6FF; border: 1px solid #BFDBFE; color: #1E40AF; }
.so-scope .alert-success { background: #F0FDF4; border: 1px solid #BBF7D0; color: #065F46; }
.so-scope .alert-warning { background: #FFFBEB; border: 1px solid #FDE68A; color: #92400E; }

/* ── Divider & utility ─────────────────────────────────── */
.so-scope .divider { border: none; border-top: 1px solid var(--border); margin: 20px 0; }
.so-scope .overflow-hidden { overflow: hidden; }
.so-scope .text-right { text-align: right; }
.so-scope .text-center { text-align: center; }
.so-scope .font-bold { font-weight: 700; }
.so-scope .font-medium { font-weight: 500; }
.so-scope .text-muted { color: var(--text-muted); }
.so-scope .text-sm { font-size: 12.5px; }
.so-scope .text-xs { font-size: 11.5px; }
.so-scope .mt-2 { margin-top: 8px; }
.so-scope .mt-4 { margin-top: 16px; }
.so-scope .mb-4 { margin-bottom: 16px; }
.so-scope .gap-2 { gap: 8px; }
.so-scope .flex { display: flex; }
.so-scope .flex-col { flex-direction: column; }
.so-scope .items-center { align-items: center; }
.so-scope .justify-between { justify-content: space-between; }
.so-scope .flex-wrap { flex-wrap: wrap; }
.so-scope .grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.so-scope .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

/* ── Page frame (so-orders 등에서 사용) ──────────────────── */
.so-scope .so-page-body { margin-top: 0; }
.so-scope .so-page-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* ═══ 모달 (soShowModal 전용) ═══════════════════════════════
 * so-core.js의 soShowModal은 html 전체를 옥토퍼스원의
 * #modal-overlay/#modal-box에 주입. 최상위 div에 so-scope
 * 포함해서 변수/클래스가 동작하게 함.
 * ═══════════════════════════════════════════════════════════ */
/* 소싱 모달이 들어있으면 #modal-box는 단순 컨테이너 역할만 (패딩/스크롤 제거) */
#modal-box:has(> .so-scope) { padding: 0; max-height: none; overflow: visible; background: transparent; box-shadow: none; width: auto; max-width: min(96vw, 1200px); }
.so-scope .so-modal { background: var(--surface); border-radius: 14px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.2); }
.so-scope .so-modal-sm { max-width: 500px; }
.so-scope .so-modal-md { max-width: 720px; }
.so-scope .so-modal-lg { max-width: 1000px; }
.so-scope .so-modal-xl { max-width: 1200px; }
.so-scope .so-modal-header { padding: 20px 24px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; background: var(--surface); z-index: 10; }
.so-scope .so-modal-title { font-size: 16px; font-weight: 700; }
.so-scope .so-modal-body { padding: 24px; }
.so-scope .so-modal-footer { padding: 16px 24px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 10px; }
.so-scope .btn-close { background: none; border: none; font-size: 20px; cursor: pointer; color: var(--text-muted); padding: 4px 8px; border-radius: 6px; font-family: inherit; }
.so-scope .btn-close:hover { background: var(--surface-2); }

/* ── 프린트 (PI 문서용) ───────────────────────────────────── */
@page { size: A4; margin: 10mm; }
@media print {
  body > *:not(#modal-overlay) { display: none !important; }
  #modal-overlay { position: static !important; background: none !important; }
  #modal-overlay, #modal-box, .so-scope, .so-modal { overflow: visible !important; max-height: none !important; height: auto !important; }
  .so-modal-header, .so-modal-footer { display: none !important; }
  .so-modal-body { padding: 0 !important; }
  .so-scope .so-pi-doc { border: none; padding: 0; box-shadow: none; max-width: 100%; font-size: 10px; line-height: 1.3; }
  .so-scope .so-pi-doc .so-pi-title { font-size: 16px; margin: 4px 0; }
  .so-scope .so-pi-doc .so-pi-items { font-size: 9.5px; }
  .so-scope .so-pi-doc .so-pi-items th, .so-scope .so-pi-doc .so-pi-items td { padding: 4px 6px; }
  .so-scope .so-pi-doc .so-pi-terms, .so-scope .so-pi-doc .so-pi-bank { font-size: 9.5px; }
  .so-scope .so-pi-doc .so-pi-bank-stamp { flex: 0 0 110px; }
  .so-scope .so-pi-doc .so-pi-bank-stamp img { max-width: 100px; max-height: 100px; }
  .so-scope .so-pi-doc .so-pi-sign { margin-top: 12px; }
}
