:root{
  --ink:#0f0e0c;--paper:#f5f2ec;--cream:#ede9e0;
  --accent:#d4550a;--accent2:#2563a8;--gold:#c8960c;--green:#1a7a4a;
  --muted:#7a7670;--border:#d6d1c8;--card:#fff;--radius:10px;
  --sidebar:224px;--font-head:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font-body);background:#eeeae2;color:var(--ink);min-height:100vh;display:flex;flex-direction:column;}
 
/* TOP BAR */
.topbar{height:50px;background:var(--ink);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;z-index:300;}
.tl{font-family:var(--font-head);font-size:17px;font-weight:800;color:#fff;letter-spacing:-.4px;}
.tl span{color:var(--accent);}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
 
/* SHELL */
.shell{display:flex;flex:1;overflow:hidden;height:calc(100vh - 50px);}
 
/* SIDEBAR */
.sidebar{width:var(--sidebar);background:var(--card);border-right:1.5px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;}
.sb-sec{padding:14px 10px 4px 14px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;}
.ni{display:flex;align-items:center;gap:9px;padding:8px 12px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-radius:7px;margin:1px 6px;transition:all .15s;}
.ni:hover{background:var(--paper);color:var(--ink);}
.ni.active{background:#fff3ee;color:var(--accent);font-weight:600;}
.ni-icon{font-size:14px;width:18px;text-align:center;}
.nc{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:1px 7px;}
.sb-bot{margin-top:auto;padding:12px 10px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.sb-uname{font-size:12px;font-weight:500;color:var(--ink);}
.sb-urole{font-size:11px;color:var(--muted);}
 
/* MAIN */
.main{flex:1;overflow-y:auto;display:flex;flex-direction:column;}
.page{display:none;flex:1;flex-direction:column;}
.page.active{display:flex;}
.ph{padding:18px 26px 14px;border-bottom:1.5px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.pt{font-family:var(--font-head);font-size:21px;font-weight:800;letter-spacing:-.3px;}
.ps{font-size:12px;color:var(--muted);margin-top:2px;}
.pb{padding:22px 26px;flex:1;}
 
/* BUTTONS */
.btn{font-family:var(--font-body);font-weight:500;font-size:13px;padding:8px 16px;border-radius:8px;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s;}
.btn-p{background:var(--accent);color:#fff;}
.btn-p:hover{background:#b8450a;}
.btn-g{background:transparent;color:var(--ink);border:1.5px solid var(--border);}
.btn-g:hover{border-color:var(--ink);}
.btn-sm{padding:5px 12px;font-size:12px;}
 
/* DASHBOARD STATS */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;}
.dc{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;}
.dn{font-family:var(--font-head);font-size:28px;font-weight:800;}
.dl{font-size:11px;color:var(--muted);margin-top:3px;}
 
/* TABLE */
.tw{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.ttb{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border);}
.sb2{flex:1;display:flex;align-items:center;gap:7px;background:var(--paper);border:1.5px solid var(--border);border-radius:7px;padding:6px 11px;}
.sb2 input{border:none;background:transparent;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;flex:1;}
.tbl{width:100%;border-collapse:collapse;}
.tbl th{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:7px 10px;border-bottom:1.5px solid var(--border);text-align:left;white-space:nowrap;background:var(--paper);}
.tbl td{padding:7px 10px;border-bottom:1px solid var(--border);font-size:12px;vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr:hover td{background:#fafaf8;}
.oid{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--muted);}
.rush-tag{background:#fff3cd;color:#856404;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;border:1px solid #fde68a;margin-left:5px;}
 
/* Pills */
.pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;display:inline-block;}
.pd{background:#dbeafe;color:#1e40af;}
.ps2{background:#fce7f3;color:#9d174d;}
.psu{background:#ede9fe;color:#5b21b6;}
.pv{background:#fef3c7;color:#92400e;}
.pe{background:#d1fae5;color:#065f46;}
.pf{background:#fee2e2;color:#991b1b;}
.pt2{background:#f3f4f6;color:#374151;}
.pc{background:#fdf4ff;color:#7e22ce;}
.pu{background:#e0f2fe;color:#0369a1;}
 
/* Status */
.st{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;}
.st::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7;}
.sn{background:#f0fdf4;color:#16a34a;}
.si{background:#eff6ff;color:#1d4ed8;}
.sr{background:#fdf4ff;color:#7e22ce;}
.ss{background:#f0fdf4;color:#15803d;}
.so{background:#fef2f2;color:#dc2626;}
 
/* Dept mini status */
.dm{display:flex;flex-direction:column;gap:3px;}
.dmr{display:flex;align-items:center;gap:5px;font-size:11px;}
.dd{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.dd-n{background:#22c55e;}
.dd-p{background:#3b82f6;}
.dd-d{background:#9ca3af;}
.dms{font-size:10px;color:var(--muted);}
 
/* Actions */
.ab{display:flex;gap:5px;}
.ib{background:var(--paper);border:1.5px solid var(--border);border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .15s;}
.ib:hover{border-color:var(--accent);background:#fff3ee;}
 
/* PRODUCTION TRACKING */
.prod-stats{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;}
.pstat{background:var(--card);border:1.5px solid var(--border);border-radius:8px;padding:7px 13px;font-size:12px;display:flex;align-items:center;gap:7px;}
.pstat strong{font-family:var(--font-head);font-size:15px;font-weight:800;}
.dtabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.dtb{font-size:12px;font-weight:600;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border);cursor:pointer;background:var(--paper);color:var(--muted);transition:all .15s;display:flex;align-items:center;gap:6px;}
.dtb:hover{border-color:var(--accent2);color:var(--accent2);}
.dtb.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.dc2{background:rgba(255,255,255,.25);border-radius:10px;padding:1px 6px;font-size:10px;}
.dtb:not(.active) .dc2{background:var(--border);color:var(--muted);}
.prtabs{display:flex;gap:5px;flex-wrap:wrap;}
.ptab{font-size:11px;font-weight:600;padding:5px 11px;border-radius:6px;border:1.5px solid var(--border);cursor:pointer;background:var(--paper);color:var(--muted);display:flex;align-items:center;gap:5px;transition:all .15s;}
.ptab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.pdot{width:7px;height:7px;border-radius:50%;background:#22c55e;}
.stage-pill{font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;white-space:nowrap;}
.sf{background:#dbeafe;color:#1e40af;}
.ssp{background:#fde68a;color:#92400e;}
.spr{background:#d1fae5;color:#065f46;}
.sq{background:#ede9fe;color:#5b21b6;}
.sk{background:#fce7f3;color:#9d174d;}
.sh2{background:#d1fae5;color:#065f46;}
.mvb{display:flex;gap:4px;}
.mb{width:26px;height:26px;border-radius:5px;border:1.5px solid var(--border);background:var(--paper);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;font-weight:700;}
.mb:hover{border-color:var(--accent2);background:#edf3fb;}
.opsel{font-family:var(--font-body);font-size:12px;border:1.5px solid var(--border);border-radius:6px;padding:4px 8px;background:var(--paper);cursor:pointer;}
.overdue{color:#dc2626;font-weight:600;}
.dept-header{background:#f8f7ff;border-radius:8px;padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--accent2);border:1px solid #e0d9ff;}
 
/* MODAL */
.mbg{display:none;position:fixed;inset:0;background:rgba(15,14,12,.5);z-index:500;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;}
.mbg.open{display:flex;}
/* Primary app modals must sit above dept-alert (600) and orphan .mbg overlays from inline confirmations */
#modal-new.mbg.open,#modal-detail.mbg.open{z-index:720;}
.modal{background:var(--card);border-radius:14px;width:100%;max-width:650px;box-shadow:0 20px 60px rgba(0,0,0,.15);animation:mUp .22s ease;margin:auto;}
@keyframes mUp{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.mh{padding:20px 24px 16px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:2;border-radius:14px 14px 0 0;}
.mt{font-family:var(--font-head);font-size:17px;font-weight:800;}
.ms{font-size:12px;color:var(--muted);margin-top:2px;}
.mcb{background:var(--cream);border:none;width:28px;height:28px;border-radius:7px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;color:var(--muted);}
.mcb:hover{background:var(--border);}
.mb2{padding:18px 24px 24px;}
 
/* FORM */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;}
.fl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;}
.fl .req{color:var(--accent);}
.fi,.fsl,.fta{font-family:var(--font-body);font-size:13px;padding:8px 11px;border:1.5px solid var(--border);border-radius:8px;background:var(--paper);color:var(--ink);outline:none;transition:border-color .15s;width:100%;}
.fi:focus,.fsl:focus,.fta:focus{border-color:var(--accent2);}
.fta{resize:vertical;min-height:68px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.fauto{font-size:11px;color:var(--muted);margin-top:2px;}
 
/* PRODUCT TYPE TABS */
.pttabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px;}
.ptb{padding:9px 4px;border-radius:8px;border:1.5px solid var(--border);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;background:var(--paper);color:var(--muted);transition:all .15s;text-align:center;}
.ptb:hover{border-color:var(--accent);}
.ptb.active{background:var(--accent);color:#fff;border-color:var(--accent);}
 
/* SECTION HEADER */
.sec-div{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 0 6px;position:relative;margin:4px 0 10px;}
.sec-div::before{content:'';position:absolute;left:0;top:50%;height:1px;width:100%;background:var(--border);}
.sec-div span{background:var(--card);padding:0 10px;position:relative;}
 
/* QUALITY BLOCK */
.qblock{background:var(--paper);border:1.5px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;}
.qbtitle{font-size:11px;font-weight:700;color:var(--accent);margin-bottom:10px;text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;justify-content:space-between;}
.rmq{background:none;border:none;color:var(--muted);font-size:17px;cursor:pointer;line-height:1;}
.rmq:hover{color:#dc2626;}
.sqgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-top:8px;}
.sqcell{display:flex;flex-direction:column;align-items:center;gap:3px;}
.sqlab{font-size:10px;font-weight:700;color:var(--muted);}
.sqin{width:100%;text-align:center;font-family:var(--font-body);font-size:13px;font-weight:600;padding:6px 2px;border:1.5px solid var(--border);border-radius:6px;background:var(--card);color:var(--ink);outline:none;}
.sqin:focus{border-color:var(--accent2);}
.qtot{text-align:right;font-size:11px;color:var(--muted);margin-top:6px;}
.ac-wrap .ac-field{position:relative;}
.ac-dd{position:absolute;left:0;right:0;top:100%;z-index:60;margin-top:4px;max-height:220px;overflow-y:auto;background:var(--card);border:1.5px solid var(--border);border-radius:8px;box-shadow:0 10px 32px rgba(15,14,12,.14);}
.ac-item{display:block;width:100%;text-align:left;padding:8px 12px;border:none;border-bottom:1px solid var(--border);background:transparent;font-family:var(--font-body);font-size:13px;color:var(--ink);cursor:pointer;}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover{background:var(--paper);color:var(--accent);}
.modal-new-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:12px;flex-wrap:wrap;align-items:center;}
.order-review-pane{margin-top:4px;padding:14px 16px;background:var(--paper);border:1.5px solid var(--border);border-radius:10px;}
.order-review-hint{font-size:12px;color:var(--muted);margin-bottom:12px;line-height:1.45;}
.or-block{display:flex;flex-direction:column;gap:8px;font-size:13px;}
.or-row{display:flex;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:8px;}
.or-row:last-child{border-bottom:none;padding-bottom:0;}
.or-k{flex:0 0 120px;font-weight:700;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;}
.or-v{flex:1;min-width:0;color:var(--ink);word-break:break-word;}
.or-lines{margin:0;padding-left:18px;color:var(--ink);}
.aqbtn{width:100%;font-size:13px;font-weight:500;color:var(--accent);background:none;border:1.5px dashed var(--accent);border-radius:8px;padding:8px;cursor:pointer;margin-bottom:12px;}
.aqbtn:hover{background:#fff3ee;}
 
/* PRINT METHOD (per quality) */
.pm-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px;}
.pmb{padding:5px 11px;border-radius:6px;border:1.5px solid var(--border);font-family:var(--font-body);font-size:11px;font-weight:600;cursor:pointer;background:var(--card);color:var(--muted);transition:all .12s;}
.pmb:hover{border-color:var(--accent2);}
.pmb.on{background:var(--ink);color:#fff;border-color:var(--ink);}
 
/* MATERIAL INCHARGE CARD VIEW */
.mi-card{background:var(--card);border-radius:0;padding:16px 20px 0;border-left:4px solid var(--accent);}
.mi-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.mi-card-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.mi-card-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.mi-badge-confirmed{background:#d1fae5;color:#065f46;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;border:1.5px solid #6ee7b7;}
.mi-badge-shortage{background:#fff3cd;color:#92400e;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;border:1.5px solid #fbbf24;}
.mi-badge-pending{background:#f3f4f6;color:#6b7280;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;border:1.5px solid #d1d5db;}
.mi-info-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:12px;margin-bottom:14px;}
.mi-info-block{background:var(--paper);border:1.5px solid var(--border);border-radius:8px;padding:10px 13px;}
.mi-info-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;}
.mi-info-val{font-size:14px;font-weight:500;}
.mi-mat-section{background:var(--paper);border:1.5px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:10px;}
.mi-mat-title{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.mi-mat-body{display:flex;flex-direction:column;gap:8px;}
.mi-notes-section{background:#fffbf4;border:1.5px solid #fde68a;border-radius:8px;padding:10px 14px;margin-bottom:10px;}
.mi-note-item{font-size:12px;color:var(--muted);margin-bottom:4px;}
.mi-note-item:last-child{margin-bottom:0;}
.mi-confirm-panel{background:#f0f7ff;border:1.5px solid #c7d9f5;border-radius:10px;padding:14px 16px;margin-bottom:16px;}
.mi-confirm-panel.mi-locked{pointer-events:none;opacity:.55;user-select:none;position:relative;}
.mi-confirm-panel.mi-locked::after{content:'🔒 Locked';position:absolute;top:10px;right:12px;font-size:11px;font-weight:700;color:#065f46;background:#d1fae5;padding:2px 10px;border-radius:20px;}
.mi-confirm-title{font-size:12px;font-weight:700;color:var(--accent2);margin-bottom:11px;text-transform:uppercase;letter-spacing:.4px;}
.mi-confirm-row{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;}
.mi-confirm-col{display:flex;flex-direction:column;}
.mi-confirm-btns{display:flex;flex-direction:column;gap:7px;}
.mi-cbtn{padding:9px 16px;border-radius:8px;border:1.5px solid var(--border);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;background:var(--card);color:var(--muted);transition:all .15s;text-align:left;white-space:nowrap;}
.mi-cbtn:hover{border-color:var(--accent2);}
.mi-cbtn-ok.active{background:#d1fae5;border-color:#10b981;color:#065f46;}
.mi-cbtn-short.active{background:#fff3cd;border-color:#f59e0b;color:#92400e;}
/* MI quality / detail sub-components */
.mi-qrow{background:var(--card);border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:7px;}
.mi-qrow:last-child{margin-bottom:0;}
.mi-qhead{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:7px;}
.mi-qnum{background:var(--accent);color:#fff;font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;flex-shrink:0;}
.mi-qname{font-size:12px;font-weight:700;color:var(--ink);}
.mi-color-highlight{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:800;padding:3px 12px;border-radius:20px;background:linear-gradient(135deg,#fff3ee,#fde8db);color:var(--accent);border:1.5px solid #fbbfa0;letter-spacing:.2px;}
.mi-color-highlight::before{content:'🎨';font-size:11px;}
.mi-pm{background:var(--ink);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;}
.mi-sizes{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:5px;}
.mi-sz{background:#edf3fb;color:var(--accent2);font-size:12px;font-weight:700;padding:4px 10px;border-radius:6px;white-space:nowrap;}
.mi-sub{font-size:11px;color:var(--muted);}
.mi-dgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px;}
.mi-di{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:7px 10px;}
.mi-dl{display:block;font-size:9px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;}
.mi-dv{font-size:12px;font-weight:600;color:var(--ink);}
.pm-placement-sec{background:var(--paper);border:1.5px solid var(--border);border-radius:10px;padding:13px 14px;margin-bottom:10px;}
.pm-placement-title{font-size:12px;font-weight:700;color:var(--accent2);margin-bottom:10px;display:flex;align-items:center;gap:7px;}
.pm-placement-title span{background:var(--accent2);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;}
.pm-placement-title em{font-style:normal;font-size:11px;color:var(--muted);font-weight:400;}
.placement-cbgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.pcb-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;transition:all .13s;}
.pcb-row:hover{border-color:var(--accent2);background:#f0f5ff;}
.pcb-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent2);cursor:pointer;flex-shrink:0;}
.pcb-row label{font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;line-height:1.2;}
.pcb-row.checked{background:#edf3fb;border-color:var(--accent2);}
.pcb-row.checked label{color:var(--accent2);font-weight:600;}
 
/* DEPT ASSIGN */
.dalist{display:flex;flex-wrap:wrap;gap:6px;}
.dabtn{font-size:12px;font-weight:500;padding:5px 11px;border-radius:20px;border:1.5px solid var(--border);cursor:pointer;background:var(--paper);color:var(--muted);transition:all .13s;}
.dabtn:hover{border-color:var(--accent2);}
.dabtn.on{background:var(--accent2);color:#fff;border-color:var(--accent2);}
.dabtn.on[data-auto="1"]{background:var(--accent2);border-color:var(--accent2);position:relative;}
.dabtn.on[data-auto="1"]::after{content:'auto';position:absolute;top:-8px;right:-2px;font-size:8px;font-weight:800;background:var(--gold);color:#fff;padding:1px 4px;border-radius:4px;}
.dabtn.dabtn-pt-disabled{opacity:0.42;pointer-events:none;cursor:not-allowed;filter:grayscale(0.9);border-color:var(--border);}
.dabtn.dabtn-pt-disabled.on{background:var(--paper);color:var(--muted);border-color:var(--border);}
 
/* TOGGLE */
.tog-wrap{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;}
.tog{position:relative;width:34px;height:19px;flex-shrink:0;}
.tog input{opacity:0;width:0;height:0;}
.tsl{position:absolute;inset:0;background:var(--border);border-radius:20px;transition:.2s;}
.tog input:checked+.tsl{background:var(--accent);}
.tsl::before{content:'';position:absolute;width:13px;height:13px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;}
.tog input:checked+.tsl::before{transform:translateX(15px);}
 
/* INPUT WITH UNIT */
.fi-unit{display:flex;gap:0;}
.fi-unit .fi{border-radius:8px 0 0 8px;flex:1;}
.unit-tag{background:var(--cream);border:1.5px solid var(--border);border-left:none;border-radius:0 8px 8px 0;padding:8px 10px;font-size:12px;font-weight:600;color:var(--muted);display:flex;align-items:center;}
 
/* DETAIL MODAL */
.ds{margin-bottom:16px;}
.dst{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:5px;border-bottom:1px dashed var(--border);}
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.di .dl2{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px;}
.di .dv{font-size:14px;font-weight:500;}
.dsr{display:flex;align-items:center;justify-content:space-between;padding:8px 11px;border-radius:7px;background:var(--paper);margin-bottom:6px;gap:8px;}
.stsel{font-family:var(--font-body);font-size:12px;border:1.5px solid var(--border);border-radius:6px;padding:4px 8px;background:var(--paper);}
 
/* TOAST */
.toast{position:fixed;bottom:22px;right:22px;z-index:9999;background:var(--ink);color:#fff;font-size:13px;font-weight:500;padding:10px 17px;border-radius:9px;display:none;animation:fu .25s ease;}
.toast.show{display:block;}
@keyframes fu{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
 
/* ORDER FLOW PIPELINE */
/* PRODUCTION FLOW STEP TRACKER — order management */
.fstep-container{display:flex;flex-direction:column;gap:4px;padding:1px 0;}
.fstep-row{display:flex;align-items:center;gap:5px;flex-wrap:nowrap;}
.fstep-dept{display:flex;align-items:center;gap:2px;font-size:9px;font-weight:700;color:var(--muted);white-space:nowrap;min-width:46px;flex-shrink:0;}
.fstep-track{display:flex;align-items:center;gap:0;flex:1;flex-wrap:wrap;row-gap:2px;}
.fstep-wrap{display:flex;align-items:center;gap:0;}
.fstep-item{display:flex;flex-direction:column;align-items:center;gap:1px;padding:0 1px;}
.fstep-dot{width:10px;height:10px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:6px;font-weight:800;transition:all .2s;}
.fstep-done{color:#fff;}
.fstep-active{animation:pulse-dot 1.8s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.fstep-pending{background:var(--border);}
.fstep-label{font-size:7px;font-weight:600;color:var(--muted);text-align:center;white-space:nowrap;line-height:1.2;max-width:40px;overflow:hidden;text-overflow:ellipsis;}
.fstep-label.fstep-label--doneby-name{max-width:min(132px,26vw);white-space:normal;display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2px;line-height:1.15;overflow:visible;}
.fstep-doneby-inline{font-size:6px;font-weight:700;color:#065f46;max-width:min(88px,18vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fstep-current .fstep-label{color:var(--ink);font-weight:800;}
.fstep-past .fstep-label{color:#10b981;}
.fstep-line{width:10px;height:2px;background:var(--border);flex-shrink:0;margin-bottom:7px;}
.fstep-line-done{background:#10b981;}
.fstep-line-error{background:#dc2626;}
.fstep-denied-item .fstep-label{color:#dc2626;font-weight:800;}
.fstep-blocked-item{opacity:.4;}
.fstep-blocked-item .fstep-label{color:#9ca3af;}
.fstep-denied-badge{font-size:8px;font-weight:700;color:#dc2626;background:#fef2f2;border:1px solid #fca5a5;padding:1px 5px;border-radius:20px;white-space:nowrap;flex-shrink:0;margin-left:3px;}
.fnbar{width:100%;height:2px;background:var(--border);border-radius:3px;margin-top:1px;overflow:hidden;}
 
/* DEPT STAGE LIST — order management column (keep for detail modal) */
.dept-stage-list{display:flex;flex-direction:column;gap:6px;min-width:220px;}
.dsl-row{display:flex;align-items:flex-start;gap:7px;}
.dsl-icon{font-size:14px;margin-top:2px;flex-shrink:0;}
.dsl-body{flex:1;min-width:0;}
.dsl-top{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:3px;}
.dsl-name{font-size:11px;font-weight:700;color:var(--ink);white-space:nowrap;}
.dsl-stage{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;white-space:nowrap;}
.dsl-confirmed{background:#d1fae5;color:#065f46;font-size:9px;font-weight:800;padding:1px 6px;border-radius:20px;}
.dsl-shortage{background:#fff3cd;color:#92400e;font-size:9px;font-weight:800;padding:1px 6px;border-radius:20px;}
.dsl-bar-wrap{height:4px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:2px;}
.dsl-bar{height:4px;border-radius:4px;transition:width .4s ease;}
.dsl-step{font-size:9px;color:var(--muted);}
.color-pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;background:linear-gradient(135deg,#fff3ee,#fde8db);color:var(--accent);border:1.5px solid #fbbfa0;}
 
/* SUBLIMATION STAGE CARD */
.sub-card{background:var(--card);padding:16px 20px 18px;border-left:4px solid #7c3aed;}
.sub-stages-track{display:flex;gap:0;align-items:stretch;margin-bottom:14px;flex-wrap:wrap;gap:4px;}
/* Full-width Done by (Sublimation / DTF) — not squeezed into narrow sub-step column */
.sub-dtf-doneby-panel{box-sizing:border-box;width:100%;margin-top:4px;padding:14px 14px 16px;border-radius:10px;border:1.5px solid #6ee7b7;background:linear-gradient(180deg,#f0fdf4 0%,#ecfdf5 100%);border-left:4px solid #10b981;}
.sub-dtf-doneby-title{font-size:13px;font-weight:800;color:#065f46;margin:0 0 6px;}
.sub-dtf-doneby-title .req{color:#b91c1c;font-weight:800;}
.sub-dtf-doneby-desc{font-size:11px;color:var(--muted);margin:0 0 10px;line-height:1.45;}
.sub-dtf-doneby-label{font-size:11px;font-weight:700;margin-bottom:5px;display:block;}
.sub-dtf-doneby-panel .fi.sub-dtf-doneby-input{box-sizing:border-box;min-height:44px;font-size:14px;padding:10px 12px;border-color:#10b981;background:#fff;}
.sub-dtf-doneby-panel .fi.sub-dtf-doneby-input:focus{border-color:#059669;box-shadow:0 0 0 3px rgba(16,185,129,.18);}
.sub-dtf-doneby-saved{font-size:11px;color:#065f46;font-weight:600;margin-top:10px;}
.sub-doneby-inline-hint{display:flex;align-items:center;justify-content:center;min-height:36px;padding:0 4px;}
.sub-step{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border:1.5px solid var(--border);border-radius:8px;background:var(--paper);min-width:96px;flex:1;text-align:center;transition:all .2s;}
.sub-step-active{border-color:#7c3aed;background:#faf5ff;box-shadow:0 0 0 2px #ddd6fe;}
.sub-step-done{border-color:#10b981;background:#f0fdf4;}
.sub-step-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0;}
.sub-done{color:#fff;}
.sub-active{animation:pulse-dot 1.8s ease-in-out infinite;}
.sub-pending{background:var(--border);}
.sub-step-num{font-size:9px;font-weight:700;color:var(--muted);}
.sub-step-active .sub-step-num{color:#7c3aed;}
.sub-step-done .sub-step-num{color:#10b981;}
.sub-step-label{font-size:10px;font-weight:600;color:var(--muted);line-height:1.3;}
.sub-step-active .sub-step-label{color:var(--ink);font-weight:700;}
.sub-step-done .sub-step-label{color:#065f46;}
.sub-advance-btn{background:#7c3aed;color:#fff;border:none;border-radius:5px;padding:3px 8px;font-size:10px;font-weight:700;cursor:pointer;margin-top:2px;}
.sub-advance-btn:hover{background:#6d28d9;}
.sub-back-btn{background:var(--paper);color:var(--muted);border:1px solid var(--border);border-radius:5px;padding:3px 8px;font-size:10px;font-weight:600;cursor:pointer;margin-top:2px;}
.sub-back-btn:hover{border-color:var(--muted);}
.sub-approved-state{display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:5px;}
.sub-approved-badge{background:#d1fae5;color:#065f46;font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;border:1.5px solid #6ee7b7;}
.sub-locked-badge{font-size:9px;font-weight:700;color:#065f46;background:#d1fae5;border:1px solid #6ee7b7;padding:2px 7px;border-radius:6px;margin-top:4px;text-align:center;}
.sub-locked-future{font-size:9px;color:var(--muted);background:var(--paper);border:1px dashed var(--border);padding:2px 7px;border-radius:6px;margin-top:4px;text-align:center;pointer-events:none;}
.sub-approve-bar{display:flex;gap:5px;margin-top:6px;}
.sub-approve-btn{padding:4px 10px;border-radius:6px;border:1.5px solid #d1fae5;background:#f0fdf4;color:#065f46;font-size:10px;font-weight:700;cursor:pointer;transition:all .13s;}
.sub-approve-btn:hover,.sub-approve-btn.sub-ap-active{background:#10b981;border-color:#10b981;color:#fff;}
.sub-deny-btn{padding:4px 10px;border-radius:6px;border:1.5px solid #fecaca;background:#fef2f2;color:#dc2626;font-size:10px;font-weight:700;cursor:pointer;transition:all .13s;}
.sub-deny-btn:hover,.sub-deny-btn.sub-dn-active{background:#dc2626;border-color:#dc2626;color:#fff;}
.sub-deny-box{background:#fff5f5;border:1.5px solid #fecaca;border-radius:7px;padding:8px;margin-top:6px;}
.sub-dispatch-active{background:#f0fdf4;border:1.5px solid #10b981;}
.sub-dispatch-label{font-size:11px;font-weight:700;color:var(--accent2);text-transform:uppercase;letter-spacing:.4px;}
.dept-design-banner{display:flex;align-items:flex-start;gap:8px;background:#faf5ff;border:1.5px solid #ddd6fe;border-radius:7px;padding:8px 10px;margin-top:6px;}
.ddb-icon{font-size:16px;flex-shrink:0;margin-top:1px;}
.ddb-info{flex:1;min-width:0;}
.ddb-label{font-size:9px;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;}
.ddb-name{font-size:12px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ddb-note{font-size:10px;color:var(--muted);margin-top:2px;}
.ddb-status{font-size:10px;color:#7c3aed;font-style:italic;}
.ddb-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;}
.ddb-ready{background:#d1fae5;color:#065f46;}
.ddb-pending{background:#f3f4f6;color:#6b7280;}
.ddb-dl-btn{background:#7c3aed;color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;}
.ddb-dl-btn:hover{background:#6d28d9;}
 
.design-card-locked{border-left-color:#10b981;background:#fafffe;}
.design-attach-frozen{cursor:default;pointer-events:none;background:#f9fafb;border-color:var(--border);opacity:.7;}

/* DESIGN DEPT CARD — single column stack so dept chips can never overlap attach/actions (Chrome-safe) */
.design-card{background:var(--card);padding:16px 20px 18px;border-left:4px solid #7c3aed;}
.design-body{display:flex;flex-direction:column;gap:18px;margin-top:12px;}
.design-col-info,.design-col-action{display:flex;flex-direction:column;min-width:0;width:100%;}
.design-dept-assign{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.design-dept-chk{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--paper);cursor:pointer;font-size:12px;font-weight:500;color:var(--muted);transition:border-color .13s,background .13s;user-select:none;}
.design-dept-chk:hover{border-color:#7c3aed;color:#7c3aed;}
.design-dept-chk input[type=checkbox]{width:14px;height:14px;accent-color:#7c3aed;cursor:pointer;flex-shrink:0;}
.design-dept-chk.dch-on{background:#ede9fe;border-color:#7c3aed;color:#5b21b6;font-weight:700;}
.design-section-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px;}
.design-color-block{background:var(--paper);border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;}
.design-qual-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.design-file-info{background:var(--paper);border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;}
.design-file-pill{display:inline-flex;align-items:center;gap:5px;background:#ede9fe;color:#5b21b6;font-size:12px;font-weight:600;padding:4px 11px;border-radius:6px;}
.design-attach-area{position:relative;border:2px dashed var(--border);border-radius:8px;padding:16px 12px;cursor:pointer;transition:all .15s;background:var(--paper);min-height:80px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.design-attach-area:hover{border-color:#7c3aed;background:#faf5ff;}
.design-file-input-overlay{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:4;font-size:0;}
.design-attach-inner{position:relative;z-index:1;}
.design-attached{display:flex;align-items:center;gap:10px;font-size:12px;}
/* FINISH BUTTON & PICKUP */
.finish-btn{width:100%;padding:11px;border-radius:9px;border:2px solid #10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#065f46;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:all .15s;letter-spacing:.2px;}
.finish-btn:hover{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#059669;}
.finish-btn--compact{width:auto;max-width:280px;padding:7px 14px;font-size:11px;font-weight:600;border-width:1.5px;}
.finish-btn:disabled,.finish-btn.finish-btn--compact:disabled{opacity:0.45;cursor:not-allowed;filter:grayscale(0.3);pointer-events:none;}
.finish-done-badge{display:flex;align-items:center;gap:8px;background:#d1fae5;color:#065f46;border:1.5px solid #6ee7b7;border-radius:9px;padding:10px 14px;font-size:12px;font-weight:700;}
/* PICKUP CARD */
.pickup-card{background:var(--card);border-left:4px solid #d97706;padding:16px 20px 18px;}
.pickup-dept-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;background:#d1fae5;color:#065f46;border:1.5px solid #6ee7b7;margin:3px;}
.pickup-dept-tag.pending{background:#f3f4f6;color:#6b7280;border-color:var(--border);}
.pickup-finished-list{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0;}
.pickup-stage-sel{font-size:12px;padding:6px 10px;border:1.5px solid var(--border);border-radius:7px;background:var(--paper);font-family:var(--font-body);}
 
.split-job-card{background:var(--paper);border:1.5px solid #ddd6fe;border-radius:10px;padding:13px 15px;margin-bottom:10px;transition:all .2s;}
.split-job-card.split-sent{border-color:#10b981;background:#f0fdf4;}
.split-job-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.split-sent-badge{background:#d1fae5;color:#065f46;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;border:1.5px solid #6ee7b7;}
.dept-alert-bg{position:fixed;inset:0;background:rgba(15,14,12,.55);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px;animation:fu .2s ease;}
.dept-alert-box{background:var(--card);border-radius:16px;width:100%;max-width:480px;box-shadow:0 24px 64px rgba(0,0,0,.18);overflow:hidden;animation:mUp .25s ease;}
.dept-alert-header{background:var(--accent);padding:18px 22px 14px;color:#fff;}
.dept-alert-header .dah-id{font-size:12px;font-weight:600;opacity:.8;margin-bottom:3px;}
.dept-alert-header .dah-title{font-family:var(--font-head);font-size:18px;font-weight:800;}
.dept-alert-header .dah-sub{font-size:12px;opacity:.85;margin-top:3px;}
.dept-alert-body{padding:18px 22px;}
.dept-alert-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.dept-notif-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.dept-notif-card{display:flex;align-items:center;gap:12px;background:var(--paper);border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;animation:mUp .3s ease;}
.dept-notif-card.highlight{border-color:var(--accent);background:#fff7f3;}
.dnc-icon{font-size:22px;flex-shrink:0;}
.dnc-info{flex:1;}
.dnc-name{font-size:13px;font-weight:700;color:var(--ink);}
.dnc-msg{font-size:11px;color:var(--muted);margin-top:2px;}
.dnc-badge{background:#22c55e;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;}
.dept-alert-footer{display:flex;gap:8px;justify-content:flex-end;padding:0 22px 18px;}
.dept-alert-cur{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.dept-alert-cur-label{font-size:11px;font-weight:700;color:var(--accent2);text-transform:uppercase;letter-spacing:.5px;}
.dept-cur-pill{display:inline-flex;align-items:center;gap:6px;background:#edf3fb;color:var(--accent2);font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;border:1.5px solid #c7d9f5;}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}
 
/* LOGIN SCREEN */
.login-screen{position:fixed;inset:0;background:var(--ink);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;}
.login-box{background:var(--card);border-radius:18px;width:100%;max-width:420px;padding:40px 36px;box-shadow:0 30px 80px rgba(0,0,0,.4);}
.login-logo{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:6px;letter-spacing:-.5px;}
.login-logo span{color:var(--accent);}
.login-sub{text-align:center;font-size:13px;color:var(--muted);margin-bottom:28px;}
.login-field{margin-bottom:14px;}
.login-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;display:block;}
.login-input{width:100%;font-family:var(--font-body);font-size:14px;padding:11px 14px;border:1.5px solid var(--border);border-radius:9px;background:var(--paper);color:var(--ink);outline:none;transition:border-color .15s;}
.login-input:focus{border-color:var(--accent2);}
.login-btn{width:100%;font-family:var(--font-body);font-size:14px;font-weight:600;padding:12px;border-radius:9px;border:none;background:var(--accent);color:#fff;cursor:pointer;margin-top:6px;transition:background .15s;}
.login-btn:hover{background:#b8450a;}
.login-err{font-size:12px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:8px 12px;margin-top:10px;display:none;}
.login-err.show{display:block;}
.login-accounts{margin-top:22px;border-top:1px dashed var(--border);padding-top:16px;}
.login-accounts-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.login-account-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.la-chip{background:var(--paper);border:1.5px solid var(--border);border-radius:7px;padding:6px 10px;cursor:pointer;transition:all .13s;font:inherit;color:inherit;width:100%;text-align:left;display:block;}
button.la-chip{-webkit-appearance:none;appearance:none;margin:0;}
.la-chip:hover{border-color:var(--accent2);background:#edf3fb;}
.la-chip-role{font-size:10px;font-weight:700;color:var(--accent);display:block;}
.la-chip-user{font-size:11px;font-weight:600;color:var(--ink);}
.la-chip-pw{font-size:10px;color:var(--muted);}
 
/* USER BADGE in topbar */
.user-role-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:rgba(255,255,255,.15);color:#fff;}

@media (max-width:900px){
  .sidebar{display:none;}
  .dash-grid,.dgrid{grid-template-columns:1fr 1fr;}
  .pttabs{grid-template-columns:repeat(2,1fr);}
  .sqgrid{grid-template-columns:repeat(4,1fr);}
  .pagrid{grid-template-columns:repeat(3,1fr);}
}
