/* ================================================================
   pc-polish.css — 최종 마감 레이어 (95% 체감 완성도)
   원칙:
   - 새 컴포넌트 X, 기존 컴포넌트만 톤/간격/타이포/강조 다듬기
   - 패키지 제조 전용 프로그램 느낌 (네이비+골드 일관)
   - 얼마에요/더존/이카운트 사용자도 덜 낯설게
   - 핵심 연동 로직 무수정
   ================================================================ */

/* =========================================================
   1. 상단 모드 탭 — 현재 위치 강조 + 타이포 정리
   ========================================================= */
body.tm-enabled .tm-bar{
  min-height:56px;   /* 70 → 56, 더 가볍게 */
  padding:0 20px;
  background:linear-gradient(180deg,#0B1222 0%,#070B14 100%);
  border-bottom:1px solid rgba(232,145,58,.1);
  box-shadow:0 1px 0 rgba(255,255,255,.02), 0 2px 10px rgba(0,0,0,.15);
}
body.tm-enabled .tm-bar::before{
  font-size:16px;
  padding:0 18px 0 0;
  height:34px;
  letter-spacing:-.02em;
}
body.tm-enabled .tm-tab{
  height:56px;
  padding:0 18px;
  font-size:13px;
  font-weight:700;
  letter-spacing:0;
  border-bottom-width:2px;
  gap:7px;
  display:inline-flex;align-items:center;
}
body.tm-enabled .tm-tab:not(.on){opacity:.72}
body.tm-enabled .tm-tab:hover{opacity:1;color:#fff}
body.tm-enabled .tm-tab.on{
  opacity:1;
  background:linear-gradient(180deg,transparent 0,rgba(232,145,58,.06) 100%);
  border-bottom-color:#E8913A;
}
body.tm-enabled .tm-tab-ico{font-size:15px}

/* 우측 사용자/액션 톤 조정 */
body.tm-enabled .tm-right-btn{width:34px;height:34px;font-size:15px}
body.tm-enabled .tm-user{padding:6px 14px 6px 8px;font-size:13px;border-radius:999px;display:inline-flex;align-items:center;gap:var(--sp-2);color:#fff;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);cursor:pointer;font-weight:700}
body.tm-enabled .tm-user:hover{background:rgba(255,255,255,.09)}
body.tm-enabled .tm-user .tm-avatar{width:28px;height:28px;font-size:13px}
body.tm-enabled .tm-user-caret{font-size:10px;color:rgba(255,255,255,.6);margin-left:2px}

/* 사용자 드롭다운 메뉴 */
.tm-user-wrap{position:relative}
.tm-user-menu{
  position:absolute;right:0;top:calc(100% + 8px);z-index:120;
  min-width:220px;background:#fff;border:1px solid #E2E8F0;border-radius:var(--r-md);
  box-shadow:0 18px 40px rgba(15,23,42,.18),0 2px 6px rgba(15,23,42,.06);
  padding:6px;overflow:hidden;
}
.tm-user-menu.hidden{display:none}
.tm-user-menu-hd{padding:10px var(--sp-3);border-bottom:1px solid #F1F5F9;margin-bottom:var(--sp-1)}
.tm-user-menu-nm{font-size:13px;font-weight:800;color:#0F172A}
.tm-user-menu-role{font-size:11px;color:#64748B;margin-top:2px}
.tm-user-menu-item{
  display:block;width:100%;text-align:left;
  padding:9px 12px;border-radius:7px;border:none;background:transparent;
  font-size:13px;font-weight:600;color:#1F2937;cursor:pointer;
}
.tm-user-menu-item:hover{background:#F1F5F9}
.tm-user-menu-item.danger{color:#DC2626}
.tm-user-menu-item.danger:hover{background:#FEF2F2}
.tm-user-menu-sep{height:1px;background:#F1F5F9;margin:4px 2px}

/* =========================================================
   2. 좌측 사이드바 — 가독성 + 현재 위치 강조
   ========================================================= */
@media (min-width:768px){
  /* 홈 버튼: 큰 파란 배경 제거 → 일반 아이템 톤으로 축소 */
  .sidebar .sb-home{
    margin:10px 8px 4px !important;padding:var(--sp-2) 14px !important;
    background:transparent !important;color:#CBD5E1 !important;
    border-radius:8px !important;font-size:13px !important;font-weight:600 !important;
    border-left:3px solid transparent !important;
    width:calc(100% - 16px);text-align:left;
  }
  .sidebar .sb-home:hover{background:rgba(255,255,255,.06) !important;color:#fff !important}
  .sidebar .sb-home.active{
    background:linear-gradient(90deg,rgba(232,145,58,.22) 0%,rgba(232,145,58,.05) 100%) !important;
    color:#fff !important;border-left-color:#E8913A !important;
  }

  /* 섹션 헤더 */
  .sb-section{margin:4px 0 2px;padding-bottom:2px}
  .sb-section-hd{padding:8px 18px 4px;font-size:10px;color:#64748B;letter-spacing:.5px;text-transform:uppercase}
  .sb-section-act{width:20px;height:20px;font-size:12px}

  /* 메뉴 항목: 편안한 hit area + 현재 위치 선명 */
  .sidebar .sb-item{
    margin:1px 8px;padding:var(--sp-2) 14px;
    border-radius:8px;font-size:13px;font-weight:500;
    color:#CBD5E1;border-left:3px solid transparent;
    transition:all var(--dur-fast) var(--ease-ui);letter-spacing:-.01em;
    display:block;width:calc(100% - 16px);text-align:left;
    border:none;border-left:3px solid transparent;
    background:transparent;cursor:pointer;
  }
  .sidebar .sb-item:hover{background:rgba(255,255,255,.06);color:#fff}
  .sidebar .sb-item.active{
    background:linear-gradient(90deg,rgba(232,145,58,.22) 0%,rgba(232,145,58,.05) 100%);
    color:#fff;font-weight:700;
    border-left-color:#E8913A;
    box-shadow:inset 0 0 0 1px rgba(232,145,58,.15);
  }
  /* 서브 메뉴 (3단): 들여쓰기 + 한 톤 어둡게 */
  .sidebar .sb-item.sb-sub{
    padding-left:32px;
    font-size:12px;
    color:#94A3B8;
    position:relative;
  }
  .sidebar .sb-item.sb-sub::before{
    content:'·';
    position:absolute;left:20px;top:50%;transform:translateY(-50%);
    color:#64748B;font-size:14px;
  }
  .sidebar .sb-item.sb-sub:hover{color:#CBD5E1}
  .sidebar .sb-item.sb-sub.active{
    color:#fff;font-weight:600;
  }

  /* 그룹 헤더: 현재 업무영역 섹션은 상단 여백과 구분선으로 메인 축임을 표시 */
  .sidebar .sb-group{
    padding:16px 18px 6px;font-size:11px;font-weight:800;
    color:#94A3B8;letter-spacing:.4px;text-transform:uppercase;
    cursor:default;border-left:none;
    position:relative;
    margin-top:8px;
  }
  .sidebar .sb-group::before{
    content:'';position:absolute;left:18px;right:18px;top:6px;height:1px;
    background:rgba(255,255,255,.06);
  }
  .sidebar .sb-group:first-of-type::before{display:none}
  .sidebar .sb-group .sb-arrow{display:none}

  /* 기초정보 / 시스템 그룹: 추가 강도 낮춤 */
  .sidebar .sb-group[data-group-key="master"],
  .sidebar .sb-group[data-group-key="system"]{color:#64748B}

  /* 사이드바 배경 한 톤 깊게 */
  body.tm-enabled .sidebar{background:#0B1222;width:232px;min-width:232px}

  /* 빈 상태 */
  .sb-empty{padding:10px 18px;font-size:10px;color:#64748B;line-height:1.5;font-style:normal}
}

/* =========================================================
   3. 공통 우클릭 메뉴 — 여백/타이포 정리
   ========================================================= */
.ux-ctx-menu{
  min-width:210px;padding:5px;border-radius:var(--r-md);
  border:1px solid #E2E8F0;
  box-shadow:0 14px 36px rgba(15,23,42,.16),0 2px 6px rgba(15,23,42,.05);
  font-size:13px;
  animation:uxCtxIn .14s cubic-bezier(.2,.9,.25,1);
}
@keyframes uxCtxIn{from{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:none}}
.ux-ctx-item{
  padding:var(--sp-2) 14px;border-radius:7px;
  font-size:13px;font-weight:500;color:#1F2937;
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);
  transition:background var(--dur-fast);
}
.ux-ctx-item:hover{background:#F1F5F9}
.ux-ctx-item.danger{color:#DC2626;font-weight:600}
.ux-ctx-item.danger:hover{background:#FEF2F2;color:#B91C1C}
.ux-ctx-sep{height:1px;background:#F1F5F9;margin:4px 2px}

/* =========================================================
   4. 통합 검색 모달 — 여백·타이포·강조 정리
   ========================================================= */
.pack-search-modal{
  border-radius:16px;
  box-shadow:0 24px 60px rgba(15,23,42,.28),0 4px 10px rgba(15,23,42,.06);
}
.pack-search-head{padding:18px 22px 10px}
.pack-search-title{font-size:16px;font-weight:800;color:#0F172A;letter-spacing:-.01em}
.pack-search-sub{font-size:12px;color:#64748B;margin-top:2px}
.pack-search-input{
  padding:var(--sp-3) var(--sp-4);font-size:14px;
  border:1.5px solid #E2E8F0;border-radius:var(--r-sm);
}
.pack-search-input:focus{border-color:#1E3A5F;box-shadow:0 0 0 4px rgba(30,58,95,.1)}

.pack-search-modes{padding:4px 22px 8px}
.pack-search-mode{
  padding:5px 12px;font-size:11px;
  border-radius:999px;border:1px solid #E2E8F0;
  background:#fff;color:#64748B;font-weight:700;letter-spacing:0;
}
.pack-search-mode.on{background:#1E3A5F;border-color:#1E3A5F;color:#fff}
.pack-search-recent{padding:4px 22px 8px}
.pack-search-recent-label{font-size:10px;color:#94A3B8}
.pack-search-tag{
  padding:4px 10px;font-size:11px;
  background:#F8FAFC;border:1px solid #E2E8F0;border-radius:999px;
  color:#334155;transition:all var(--dur-fast);
}
.pack-search-tag:hover{background:#1E3A5F;color:#fff;border-color:#1E3A5F}

.pack-search-table-head{
  padding:var(--sp-2) 22px;font-size:10px;color:#94A3B8;
  letter-spacing:.5px;text-transform:uppercase;
  background:#F8FAFC;border-top:1px solid #F1F5F9;
}
.pack-search-row{padding:11px 22px;gap:var(--sp-3)}
.pack-search-row:hover,.pack-search-row.is-active{background:#EFF6FF}
.pack-search-row.is-active{box-shadow:inset 3px 0 0 #1E3A5F}
.pack-search-primary{font-size:14px;font-weight:700;color:#0F172A;letter-spacing:-.01em}
.pack-search-secondary{font-size:12px;color:#64748B;line-height:1.5}
.pack-search-meta{font-size:11px;color:#64748B;text-align:right}
.pack-search-empty{padding:36px 20px;color:#94A3B8;font-size:13px}

/* =========================================================
   5. 컨텍스트 바 (최근 거래처·품목) — 더 얇고 자연스럽게
   ========================================================= */
.ctx-bar{
  background:#F1F5F9;border:1px solid #E2E8F0;
  padding:3px 8px;border-radius:999px;
  margin-left:12px;gap:6px;
}
.ctx-item{
  background:transparent;border:none;padding:3px 10px;
  border-radius:999px;max-width:200px;
}
.ctx-item:hover{background:#fff;box-shadow:0 1px 3px rgba(15,23,42,.08);border:none}
.ctx-lbl{font-size:10px;color:#94A3B8;font-weight:600}
.ctx-val{font-size:12px;color:#0F172A;font-weight:700}
.ctx-sep{color:#CBD5E1}

/* =========================================================
   6. 데이터 테이블 — 행간·헤더·빈상태 정돈
   ========================================================= */
.dt thead th{
  padding:10px var(--sp-3);font-size:11px;font-weight:700;
  color:#475569;letter-spacing:.3px;text-transform:uppercase;
  background:#F8FAFC;border-bottom:1px solid #E2E8F0;white-space:nowrap;
}
.dt tbody td{padding:11px 12px;font-size:13px;border-bottom:1px solid #F1F5F9}
.dt tbody tr:hover td{background:#FAFBFC}
.dt tbody tr[onclick]{cursor:pointer}

.empty-cell{
  padding:36px 20px !important;
  text-align:center;color:#94A3B8;font-size:13px;
  font-weight:500;
}
.empty-cell::before{
  content:'';display:block;width:36px;height:36px;
  margin:0 auto 8px;border-radius:50%;
  background:#F1F5F9 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><line x1='12' y1='8' x2='12' y2='12'/><line x1='12' y1='16' x2='12.01' y2='16'/></svg>") center/20px no-repeat;
}

/* =========================================================
   7. 상태 배지 — 일관된 팔레트
   ========================================================= */
.bd{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:0}
.bd-p{background:#DBEAFE;color:#1E3A8A;border:none}  /* 처리중 */
.bd-s{background:#DCFCE7;color:#14532D;border:none}  /* 완료 */
.bd-o{background:#FEF3C7;color:#854D0E;border:none}  /* 주의 */
.bd-d{background:#FEE2E2;color:#991B1B;border:none}  /* 경고/위험 */
.bd-w{background:#F1F5F9;color:#475569;border:none}  /* 대기/휴면 */
.bd-e{background:#EDE9FE;color:#5B21B6;border:none}  /* 외주/협력 */

/* =========================================================
   8. 버튼 — 패키지 제조 톤 (네이비 + 골드)
   ========================================================= */
.btn{font-weight:700;letter-spacing:0;transition:all var(--dur-fast)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}
.btn:disabled,.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}
.btn:active:not(:disabled){transform:scale(.98)}
.btn-p{background:#1E3A5F;color:#fff;border:none}
.btn-p:hover{background:#152B47;transform:translateY(-1px);box-shadow:0 4px 10px rgba(30,58,95,.25)}
.btn-s{background:#059669;color:#fff;border:none}
.btn-s:hover{background:#047857}
.btn-o{background:#fff;color:#334155;border:1px solid #CBD5E1}
.btn-o:hover{background:#F1F5F9;border-color:#94A3B8}
.btn-d{background:#DC2626;color:#fff;border:none}
.btn-d:hover{background:#B91C1C}
.btn-gold{background:#E8913A;color:#fff;border:none}
.btn-gold:hover{background:#C2710C}

/* 2차 테두리 버튼 hover 색감 통일 */
.btn-blue{background:#DBEAFE;color:#1E3A5F;border:none}
.btn-blue:hover{background:#BFDBFE}

/* =========================================================
   9. 사이드 패널 (openCliLedgerPanel 등) 정돈
   ========================================================= */
.ux-sp-section{margin-top:18px;padding-top:14px;border-top:1px solid #F1F5F9}
.ux-sp-section:first-child{margin-top:0;padding-top:0;border-top:none}
.ux-sp-section-t{
  font-size:11px;font-weight:800;color:#64748B;
  letter-spacing:.4px;text-transform:uppercase;margin-bottom:10px;
}
.ux-sp-field{padding:8px 0;display:flex;justify-content:space-between;align-items:baseline;gap:var(--sp-3)}
.ux-sp-field-l{font-size:11px;color:#94A3B8;font-weight:600;min-width:80px}
.ux-sp-field-v{font-size:13px;color:#0F172A;font-weight:700;text-align:right;flex:1}

/* =========================================================
   10. 빠른입력 FAB — 위치·그림자 한 톤 고급스럽게
   ========================================================= */
.qe-fab{
  box-shadow:0 10px 28px rgba(30,58,95,.32),0 2px 6px rgba(15,23,42,.12);
}
.qe-fab:hover{
  box-shadow:0 14px 36px rgba(30,58,95,.4),0 4px 10px rgba(15,23,42,.15);
}

/* =========================================================
   11. 토스트 — 부드러운 그림자
   ========================================================= */
.toast{box-shadow:0 10px 30px rgba(15,23,42,.24),0 2px 6px rgba(15,23,42,.08);font-weight:600}

/* =========================================================
   12. 브레드크럼 / 메인 헤더 정돈
   ========================================================= */
.main-header{
  padding:var(--sp-2) 22px;background:#fff;
  border-bottom:1px solid #EEF2F6;min-height:48px;
  display:flex;align-items:center;gap:10px;
}
#mainTitle{font-size:15px !important;letter-spacing:-.01em;font-weight:700 !important;margin-right:0 !important}
#mainBreadcrumb{font-size:11px !important;color:#94A3B8 !important;font-weight:500}
.main-header .noti-bell{width:32px;height:32px}
/* 헤더 내 tab pill 톤 — 과한 외곽 제거 */
.main-header .hd-tab,.main-header .s-tab{font-size:12px;padding:4px 10px}

/* =========================================================
   13. 안내·빈상태 공통 문구 톤
   ========================================================= */
.pack-inline-note{
  border-style:solid;border-color:#E2E8F0;
  background:#FAFBFC;color:#334155;font-size:12px;line-height:1.55;
}
.pack-inline-note b{color:#0F172A}
.recv-empty{padding:20px;text-align:center;color:#94A3B8;font-size:13px}

/* =========================================================
   14. 출고 준비/이력 행 — 납기 지연 시 시각 강조
   ========================================================= */
.dt tbody tr.row-late{background:#FEF2F2}
.dt tbody tr.row-late:hover td{background:#FEE2E2}
.dt tbody tr.row-warn{background:#FFFBEB}
.dt tbody tr.row-warn:hover td{background:#FEF3C7}

/* 사이드바 빠른 생성 (작업지시 / 출고) */
/* ============================================
   생산현황 대시보드 — 다크 헤더 + 미니멀 본문 (한 화면 컴팩트)
   ============================================ */
.tc.on.dash2{padding:0;background:#F5F7FA;height:calc(100vh - 145px);display:flex;flex-direction:column;overflow:hidden}
.tc.on.dash2 > .dash-bd{flex:1;min-height:0;overflow:auto}
/* DARK HEADER (compact) */
.dash2 .dh{background:linear-gradient(135deg,#0F1F3A 0%,#1E3A5F 60%,#2A4A75 100%);color:#fff;padding:10px 22px 12px;position:relative;overflow:hidden}
.dash2 .dh-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-2);position:relative;z-index:1;flex-wrap:wrap;gap:var(--sp-3)}
.dash2 .dh-l h1{font-size:20px;font-weight:900;letter-spacing:-.4px;margin:0 0 2px;display:inline-flex;align-items:center;gap:10px}
.dash2 .dh-l-sub{font-size:11px;color:#B6C5DD;font-weight:500}
.dash2 .dh-r{display:flex;align-items:center;gap:var(--sp-3)}
.dash2 .dh-clock{font-size:22px;font-weight:800;font-feature-settings:'tnum';color:#FFD89F;letter-spacing:-.4px;line-height:1;text-align:right}
.dash2 .dh-clock-sub{text-align:right;font-size:10px;color:#B6C5DD;font-weight:600;margin-top:3px}
.dash2 .dh-live{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;background:rgba(34,197,94,.18);border:1px solid rgba(34,197,94,.4);color:#86EFAC;border-radius:999px;font-size:10px;font-weight:700;vertical-align:middle}
.dash2 .dh-live::before{content:'';width:5px;height:5px;border-radius:50%;background:#22C55E;box-shadow:0 0 8px #22C55E;animation:dh-pulse 2s infinite}
@keyframes dh-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.dash2 .dh-rfr{padding:5px 12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#E2E8F0;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;transition:background var(--dur-base)}
.dash2 .dh-rfr:hover{background:rgba(255,255,255,.14)}

/* KPI BAND in header (compact) */
.dash2 .dh-kpi{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-2);position:relative;z-index:1}
.dash2 .dh-kpi-c{padding:6px 12px 7px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.11);border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur-base)}
.dash2 .dh-kpi-c:hover{background:rgba(255,255,255,.13);transform:translateY(-1px)}
.dash2 .dh-kpi-c.gold{background:linear-gradient(135deg,rgba(232,145,58,.16),rgba(232,145,58,.06));border-color:rgba(232,145,58,.32)}
.dash2 .dh-kpi-c.danger{background:linear-gradient(135deg,rgba(239,68,68,.14),rgba(239,68,68,.05));border-color:rgba(239,68,68,.32)}
.dash2 .dh-kpi-l{font-size:10px;color:#B6C5DD;font-weight:600;letter-spacing:.3px;text-transform:uppercase;margin-bottom:2px}
.dash2 .dh-kpi-v{font-size:20px;font-weight:900;letter-spacing:-.6px;line-height:1.05}
.dash2 .dh-kpi-c.gold .dh-kpi-v{color:#FFD89F}
.dash2 .dh-kpi-c.danger .dh-kpi-v{color:#FCA5A5}
.dash2 .dh-kpi-d{font-size:9px;color:#86EFAC;font-weight:600;margin-top:2px}
.dash2 .dh-kpi-d.flat{color:#94A3B8}
.dash2 .dh-kpi-d.dn{color:#FCA5A5}

/* BENTO BODY (compact) */
.dash2 > .dash-bd{padding:var(--sp-2) 14px 12px;display:grid;grid-template-columns:1.2fr 1.4fr 1fr;grid-template-rows:auto minmax(0,1fr);gap:var(--sp-2);align-content:stretch;align-items:stretch;justify-items:stretch}
.dash2 > .dash-bd > .d-card{min-height:0;overflow:auto}
/* 하단 row 2 박스 3개만 컨텐츠 풀높이 보장 — span-pipe(공정 파이프라인)는 auto 유지 */
.dash2 > .dash-bd > .span-tb,
.dash2 > .dash-bd > .span-gauge,
.dash2 > .dash-bd > .span-feed{min-height:300px}
.dash2 > .dash-bd > .d-card.span2{overflow:visible}
.dash2 > .dash-bd > .span2{grid-column:1 / -1}
.dash2 > .dash-bd > .span-pipe{grid-column:1 / -1;grid-row:1}
.dash2 > .dash-bd > .span-tb{grid-column:1 / 2;grid-row:2}
.dash2 > .dash-bd > .span-gauge{grid-column:2 / 3;grid-row:2}
.dash2 > .dash-bd > .span-feed{grid-column:3 / 4;grid-row:2}
.dash2 .d-card{background:#fff;border:1px solid rgba(226,232,240,.7);border-radius:var(--r-md);padding:10px var(--sp-3);box-shadow:0 1px 2px rgba(15,23,42,.03)}
.dash2 .d-card h3{font-size:11.5px;font-weight:800;color:#0F172A;margin:0 0 6px;display:flex;align-items:center;gap:6px;letter-spacing:-.2px}
.dash2 .d-card h3::before{content:'';width:4px;height:4px;border-radius:50%;background:#E8913A}

/* PIPELINE — Hero (compact) */
.dash2 .d-card .nd-pipe-row{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:4px 0}
.dash2 .d-card .nd-pipe-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;min-width:0}
.dash2 .d-card .nd-pipe-circle{width:54px;height:54px;font-size:16px;font-weight:900}
.dash2 .d-card .nd-pipe-name{font-size:11px;font-weight:700}
.dash2 .d-card .nd-pipe-tags{font-size:10px;display:flex;gap:4px;flex-wrap:wrap;justify-content:center}
.dash2 .d-card .nd-pipe-arrow{font-size:13px}

/* TODAY BOARD (compact 2x2) */
.dash2 .d-card .tb-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4px}
/* 오늘 할 일 박스: 헤더 + 4 카드 grid가 박스 전체 높이를 채우도록 */
.dash2 > .dash-bd > .span-tb{display:flex;flex-direction:column}
.dash2 > .dash-bd > .span-tb > h3{flex:0 0 auto}
.dash2 > .dash-bd > .span-tb > h3 + div{flex:1;display:flex;flex-direction:column;min-height:0}
.dash2 > .dash-bd > .span-tb .tb-wrap{flex:1;grid-template-rows:1fr 1fr;min-height:0;margin-bottom:0}
.dash2 .d-card .tb-card{padding:5px 8px;border-radius:6px;background:#F8FAFC;border:1px solid #EEF2F7;cursor:pointer;transition:all var(--dur-base)}
.dash2 .d-card .tb-card:hover{transform:translateY(-1px);box-shadow:0 3px 8px rgba(15,23,42,.05)}
.dash2 .d-card .tb-card-title{font-size:9px;font-weight:700;color:#64748B;margin-bottom:1px;display:flex;align-items:center;justify-content:space-between}
.dash2 .d-card .tb-card-num{font-size:14px;font-weight:900;color:#0F172A;line-height:1}
.dash2 .d-card .tb-card-num.zero{color:#94A3B8}
.dash2 .d-card .tb-card-sub{font-size:8px;color:#94A3B8;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash2 .d-card .tb-tag{font-size:8px;padding:0 5px;border-radius:3px}

/* dashOps 컴팩트 */
.dash2 #dashOps{display:none}
.dash2 .d-card .dash-ops-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;margin-top:4px}
.dash2 .d-card .dash-op-card{padding:5px 8px;border-radius:6px}
.dash2 .d-card .dash-op-label{font-size:9px;font-weight:700}
.dash2 .d-card .dash-op-value{font-size:14px;font-weight:900}
.dash2 .d-card .dash-op-sub{font-size:8px;margin-top:1px}

/* GAUGE (위 가로 3개) + CHART (아래 전폭) */
.dash2 #ndGaugeRow{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-2);align-items:start}
.dash2 #ndGaugeRow .nd-gauge-v2{background:transparent;padding:0;box-shadow:none;border-radius:0;min-height:0;min-width:0;align-items:center}
.dash2 #ndGaugeRow .nd-gauge-v2 .nd-gauge-title{font-size:10px;font-weight:700;color:#64748B;margin-bottom:var(--sp-1);text-transform:none;letter-spacing:0}
.dash2 #ndGaugeRow .nd-gauge-v2 .nd-gauge-circle{width:64px;height:64px}
.dash2 #ndGaugeRow .nd-gauge-v2 .nd-gauge-inner{width:48px;height:48px;box-shadow:inset 0 1px 2px rgba(0,0,0,.04)}
.dash2 #ndGaugeRow .nd-gauge-v2 .nd-gauge-val{font-size:13px;font-weight:900;letter-spacing:-.3px}
.dash2 #ndGaugeRow .nd-gauge-v2 .nd-gauge-val span{font-size:9px!important}
.dash2 #ndGaugeRow .nd-area{grid-column:1 / -1;background:transparent;padding:4px 0 0;box-shadow:none;border-radius:0;min-width:0;width:100%;margin-top:4px}
.dash2 #ndGaugeRow .nd-area-svg{height:42px;width:100%}

/* FEED (compact) */
.dash2 .span-feed .d-card{max-height:none}
.dash2 .span-feed .nd-feed{padding:0}
.dash2 .span-feed .nd-feed-item{padding:4px 7px;font-size:10px;line-height:1.3;margin-bottom:2px;border-radius:5px}
.dash2 .span-feed .nd-feed-mark{font-size:9px;padding:0 5px}
.dash2 .span-feed .nd-feed-time{font-size:8px}

/* ERP 정리: dailyTxCard 스타일 제거 — MES 중심 버전 */

@media (max-width:1100px){
  .dash2 > .dash-bd{grid-template-columns:1fr}
  .dash2 > .dash-bd > .span-pipe,.dash2 > .dash-bd > .span-tb,.dash2 > .dash-bd > .span-gauge,.dash2 > .dash-bd > .span-feed{grid-column:1 / -1;grid-row:auto}
  .dash2 .dh-kpi{grid-template-columns:repeat(2,1fr)}
}

/* 기존 렌더 함수의 내부 타이틀 숨김 */
.dash2 .d-card .nd-pipe-title,
.dash2 .d-card .nd-area-header,
.dash2 .d-card .nd-feed-title,
.dash2 .d-card .tb-hd{display:none}
.dash2 .d-card .nd-pipe,
.dash2 .d-card .nd-area,
.dash2 .d-card .nd-feed{padding:0;margin:0;background:transparent;box-shadow:none;border:none}

.sb-section-quick{padding:6px 14px 10px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:var(--sp-1)}
.sb-section-quick .sb-section-hd{padding:4px 0 6px;font-size:10px;color:#94A3B8;letter-spacing:.5px;text-transform:uppercase;font-weight:700}
.sb-quick{display:flex;flex-direction:column;gap:5px}
.sb-quick-btn{display:block;width:100%;padding:8px 10px;text-align:left;font-size:12px;font-weight:600;color:#E2E8F0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:background var(--dur-base)}
.sb-quick-btn:hover{background:rgba(255,255,255,.12);color:#fff}

/* =========================================================
   Phase 2 — Component polish
   ========================================================= */

/* --- 1. Form field states (.fg, .fg-help, .fg-error, .is-invalid) --- */
.fg.is-invalid input,
.fg.is-invalid select,
.fg.is-invalid textarea {
  border-color: var(--dan);
  box-shadow: 0 0 0 3px rgba(220,38,38,.12);
}
.fg-help {
  font-size: var(--fs-xs);
  color: var(--txt2);
  margin-top: 4px;
  line-height: var(--lh-base);
}
.fg-error {
  font-size: var(--fs-xs);
  color: var(--dan);
  margin-top: 4px;
  font-weight: var(--fw-semi);
  line-height: var(--lh-base);
}

/* --- 2. Table row states --- */
/* Override the too-faint #FAFBFC hover in section 6 above */
.dt tbody tr:hover { background: #F1F5F9; }
.dt tbody tr:hover td { background: #F1F5F9; }
.dt tbody tr.is-selected { background: var(--pri-l); border-left: 3px solid var(--gold); }
.dt tbody tr.is-selected td:first-child { padding-left: calc(14px - 3px); }

/* Row action buttons reveal-on-hover — 리스트 가독성 향상 */
.dt tbody td:last-child .btn-sm { opacity: .35; transition: opacity var(--dur-fast) var(--ease-ui); }
.dt tbody tr:hover td:last-child .btn-sm,
.dt tbody td:last-child .btn-sm:focus-visible,
.dt tbody td:last-child .btn-p,
.dt tbody td:last-child .btn-d { opacity: 1; }  /* primary/danger 는 항상 표시 */

/* --- 3. Skeleton loading rows --- */
.sk-cell {
  display: block;
  height: 13px;
  border-radius: 4px;
  background: linear-gradient(90deg, #F1F5F9 25%, #E9ECF0 50%, #F1F5F9 75%);
  background-size: 200% 100%;
  animation: sk-sweep 1.2s infinite;
}
@keyframes sk-sweep {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.sk-row td { padding: 14px; }

/* --- 4. Empty state .es component --- */
.es {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  gap: var(--sp-3);
  color: var(--txt2);
}
.es-icon {
  font-size: 32px;
  opacity: .6;
  line-height: 1;
}
.es-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--txt);
}
.es-sub {
  font-size: var(--fs-sm);
  color: var(--txt2);
  max-width: 280px;
}
.es-action { margin-top: var(--sp-2); }

/* --- 6. Toast variants — undo/recovery --- */
.toast.toast-undo {
  background: var(--surface, #fff);
  border: 1px solid var(--border-strong, #D1D5DB);
  color: var(--txt);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.toast.toast-undo .toast-action {
  margin-left: var(--sp-2);
  padding: 4px 10px;
  background: var(--pri);
  color: #fff;
  border-radius: var(--r-sm);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  cursor: pointer;
  border: none;
}

/* --- 7. Modal padding consistency via tokens --- */
.mo .my, .mo .mo-b { padding: var(--sp-6); }
.mo .mh, .mo .mo-t { padding: var(--sp-4) var(--sp-6); }
.mo .mf, .mo .mo-f { padding: var(--sp-4) var(--sp-6); gap: var(--sp-3); }

/* --- 8. Sidebar item focus-visible --- */
.sb-item:focus-visible { outline: none; box-shadow: inset 0 0 0 2px var(--gold); }
