:root{
  --bg:#f4f6f8; --card:#fff; --line:#e2e8f0; --ink:#1e293b; --muted:#64748b;
  --pri:#2563eb; --ok:#16a34a; --warn:#d97706; --danger:#dc2626;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Segoe UI","Malgun Gothic",system-ui,sans-serif;font-size:15px}
a{color:inherit;text-decoration:none}

/* 상단바 */
.topbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:#0f172a;color:#fff;padding:10px 16px;position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700;font-size:17px}
.topbar nav{display:flex;gap:6px;flex-wrap:wrap;flex:1}
.topbar nav a{padding:6px 12px;border-radius:8px;font-size:14px}
.topbar nav a:hover{background:#1e293b}
.whoami{font-size:13px;opacity:.85}

main{max-width:1100px;margin:0 auto;padding:16px}
h1{font-size:22px;margin:8px 0 14px}
h2{font-size:16px;margin:22px 0 10px;color:#334155}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.muted{color:var(--muted)}
.empty{color:var(--muted);padding:30px;text-align:center}
.note{background:#fffbeb;border-left:3px solid var(--warn);padding:8px 12px;border-radius:6px}
.meta{color:#475569;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* 버튼 */
.btn{display:inline-block;background:var(--pri);color:#fff;border:0;border-radius:8px;
  padding:9px 16px;font-size:14px;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn.sm{padding:6px 11px;font-size:13px}
.btn.ok{background:var(--ok)}
.btn.ghost{background:#e2e8f0;color:#334155}
.btn.sel{outline:3px solid #93c5fd}
.btn.danger{background:#dc2626}

/* 담당공정 다중선택 체크박스 */
.pcwrap{display:inline-flex;flex-wrap:wrap;gap:4px 10px;align-items:center;vertical-align:middle}
.pcck{display:inline-flex;align-items:center;gap:3px;font-size:13px;color:var(--ink);white-space:nowrap}
.pcck input{width:auto;margin:0}
.rolerow{flex-wrap:wrap;gap:6px}

/* 칩 */
.chip{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}
.chip.ok{background:#dcfce7;color:#166534}
.chip.warn{background:#fef3c7;color:#92400e}
.chip.danger{background:#fee2e2;color:#991b1b}
.chip.muted{background:#e2e8f0;color:#475569}

/* 요약 통계 */
.summary{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:12px 18px;flex:1;min-width:110px;text-align:center}
.stat b{display:block;font-size:26px}
.stat span{font-size:12px;color:var(--muted)}
.stat.ok b{color:var(--ok)} .stat.warn b{color:var(--warn)} .stat.danger b{color:var(--danger)}

/* 카드 그리드 */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;
  display:block;transition:.1s}
.card:hover{box-shadow:0 4px 14px rgba(0,0,0,.08)}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.card-top strong{font-size:16px}
.card-sub{color:var(--muted);font-size:13px;margin-bottom:8px}
.steps{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.bar{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}
.bar span{display:block;height:100%;background:var(--ok)}
.card-foot{font-size:12px;color:var(--muted);margin-top:6px}

/* 표 */
table{width:100%;border-collapse:collapse;background:var(--card);border-radius:12px;overflow:hidden}
.list,.proc{border:1px solid var(--line)}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
th{background:#f8fafc;color:#475569;font-size:12px}
.list tbody tr{cursor:pointer}
.list tbody tr:hover{background:#f1f5f9}
.proc td{vertical-align:middle}

/* 폼 */
.inline{display:inline-flex;gap:6px;align-items:center;margin:0}
.form-inline{margin-bottom:10px}
input,select{padding:8px 10px;border:1px solid #cbd5e1;border-radius:8px;font-size:14px;font-family:inherit}
.form-card{margin-bottom:18px}
.form-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.form-row input{flex:1;min-width:120px}
.qform{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.qc-list{list-style:none;padding:0;margin:0}
.qc-list li{padding:8px 0;border-bottom:1px solid var(--line)}
.qc-list small{color:var(--muted);margin-left:6px}

.picker{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.picker span{color:var(--muted);font-size:13px}

.card.info{background:#eff6ff;border-color:#bfdbfe}
.card.flash-ok{background:#dcfce7;border-color:#86efac;color:#166534;font-weight:600}

/* QR 페이지 */
.qrpage{text-align:center;padding:20px}
.qrpage #qr{display:inline-block;margin:14px auto}
.qrpage .url{font-family:monospace;color:var(--muted);word-break:break-all}

@media(max-width:600px){
  .topbar{padding:8px 10px}
  .topbar nav a{padding:5px 8px}
  main{padding:10px}
}
@media print{.topbar,.btn{display:none}}

/* 로그인 */
.logout{margin-left:10px;font-size:12px;opacity:.85;text-decoration:underline}
.login-wrap{max-width:360px;margin:8vh auto;text-align:center}
.login-wrap h1{font-size:22px}
.login-box{display:flex;flex-direction:column;gap:10px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;padding:22px}
.login-box input{font-size:16px;padding:11px}
.login-msg{color:var(--danger);background:#fee2e2;border-radius:8px;padding:8px}
.login-hint{margin-top:14px;font-size:13px}

/* 툴바(정렬/필터 아이콘) */
.toolbar{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin:10px 0 14px}
.toolbar span{color:var(--muted);font-size:13px}
.filterbadge{margin-left:auto;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;
  padding:4px 12px;font-size:13px;font-weight:600;color:#1e40af}
.filterbadge a{margin-left:6px;color:#1e40af;font-weight:700;text-decoration:none}
.hint-cust{font-size:12px;margin:0 0 12px}
.custlink{color:inherit;text-decoration:none;border-bottom:1px dotted #94a3b8}
.custlink:hover{color:var(--pri);border-bottom-color:var(--pri)}
/* 거래처 헤더 클릭 검색 팝업 */
.custhead{cursor:pointer;position:relative;user-select:none;white-space:nowrap}
.custhead:hover{color:var(--pri)}
.custpop{position:absolute;top:100%;left:0;z-index:30;width:220px;background:#fff;
  border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.15);
  padding:8px;text-align:left;font-weight:400}
.custpop input{width:100%;font-size:13px;padding:7px 8px;margin-bottom:6px}
.custpop-list{max-height:260px;overflow-y:auto}
.custpop-item{display:block;padding:6px 8px;border-radius:6px;color:var(--ink);
  text-decoration:none;font-size:13px}
.custpop-item:hover{background:#eff6ff;color:var(--pri)}
.custpop-item.all{color:var(--muted);border-bottom:1px solid var(--line);margin-bottom:4px}
.pager{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:7px 10px}
.pager .pginfo{color:var(--ink);font-weight:600;margin:0 6px}

/* 폼 라벨 */
.fld{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted);flex:1;min-width:120px}
.fld input,.fld select{font-size:14px}
h3.sub{font-size:14px;color:#334155;margin:14px 0 6px}
table.mini th,table.mini td{padding:6px 10px}
table.mini input{width:100%;min-width:120px}

/* 설정 행 버튼들 */
.rowbtns{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.rowbtns form{margin:0}
.rowbtns input{width:90px}
code{background:#f1f5f9;padding:1px 6px;border-radius:5px;font-size:13px}

/* 현황판 리스트형 */
table.board{font-size:14px}
table.board th,table.board td{padding:8px 10px;vertical-align:middle;white-space:nowrap}
table.board td.ono{font-variant-numeric:tabular-nums}
table.board td.num{text-align:center}
table.board td.dt{font-variant-numeric:tabular-nums;color:#475569}
table.board td.dt .chip{margin-left:4px}
table.board td.item{white-space:normal;max-width:160px}
table.board td.steps{white-space:normal;line-height:1.9}
table.board .steps .chip{margin:1px}
table.board .prog{min-width:92px;white-space:nowrap}
table.board .prog .bar{width:64px;display:inline-block;vertical-align:middle}
table.board .prog small{margin-left:6px;color:var(--muted);font-variant-numeric:tabular-nums}
.useck{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--ink)}
.useck input{width:auto}
@media(max-width:760px){
  main{overflow-x:auto}
  table.board{min-width:720px}
}

/* 주문 공정 선택 카드 */
.proclist{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px;margin-bottom:14px}
.procitem{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#f8fafc;opacity:.65;transition:.12s}
.procitem.on{opacity:1;background:#eff6ff;border-color:#bfdbfe}
.proctoggle{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer}
.proctoggle input{width:18px;height:18px}
.pdates{display:flex;gap:8px;margin-top:8px}
.pdates label{display:flex;flex-direction:column;font-size:11px;color:var(--muted);gap:2px;flex:1}
.pdates input{width:100%}
.pdate:disabled{background:#e9edf2;color:#9aa5b1;cursor:not-allowed}

/* 미등록(임시) 업체: 빨간 점선 테두리만 (배경색 없음) */
.temp-badge{color:#b91c1c;border:1px dashed #ef4444;border-radius:6px;padding:1px 7px;font-size:13px}

/* 현황판 강조: 납기지연 / 특이사항(불량) 발생 행만 선명하게 */
tr.rowdefect{background:#fef9c3}
tr.rowdefect:hover{background:#fef08a}
tr.rowdelay{background:#fee2e2}
tr.rowdelay:hover{background:#fecaca}
tr.rowdelay.rowdefect{background:#fee2e2;box-shadow:inset 5px 0 0 #f59e0b}

/* 접기/펼치기 박스 */
.foldbox{margin:6px 0 14px}
.foldbox>summary{cursor:pointer;font-weight:600;color:#334155;padding:8px 12px;background:#f1f5f9;border:1px solid var(--line);border-radius:8px;list-style:none}
.foldbox>summary::-webkit-details-marker{display:none}
.foldbox>summary::before{content:"▸ ";color:var(--muted)}
.foldbox[open]>summary::before{content:"▾ "}
.foldbox table{margin-top:8px}
.crowlist{display:flex;flex-direction:column;gap:8px;padding:8px}
.crow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:8px}
.editrow{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin:0;flex:1}
.editrow input{font-size:13px}
.editrow input[name=name]{font-weight:600;min-width:120px}
.cname{min-width:120px;font-size:14px}
.filterbar{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:8px 10px}
.filterbar select,.filterbar input{font-size:13px}

/* 작업자 카드: 목표일 경과(지연) 강조 */
.card.overdue{border:2px solid #ef4444;background:#fff5f5;box-shadow:0 0 0 3px #fecaca}

/* 내작업 카드(컴팩트) */
.wkcard{padding:10px 12px}
.wkcard .card-top{margin-bottom:2px}
.wkcard .card-top strong{font-size:17px}
.wksub{font-size:13px;color:#475569;margin:3px 0 6px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.wkdates{display:flex;gap:6px;margin-bottom:8px}
.wkdate{flex:1;border:1px solid var(--line);border-radius:8px;padding:4px 9px;background:#f8fafc;
  display:flex;align-items:center;justify-content:space-between;gap:6px}
.wkdate span{font-size:11px;color:var(--muted)}
.wkdate b{font-size:15px;font-variant-numeric:tabular-nums}
.wkdate.od{background:#fee2e2;border-color:#fca5a5}
.wkdate.od b{color:#b91c1c}
.wkform{display:flex;align-items:center;gap:8px;margin:0}
.wkbtn{font-size:15px;padding:8px 18px;flex:1}
.qtylbl{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.qtylbl input{width:64px;font-size:15px;padding:6px}
.wkmeta{font-size:13px;color:var(--muted)}
@media(max-width:600px){
  .wkcard{padding:9px 11px}
  .wkdate b{font-size:14px}
  .wkbtn{padding:7px 14px}
}
