:root{
  --g:#16a34a;--gl:#dcfce7;--gd:#14532d;--gm:#15803d;
  --b:#2563eb;--bl:#dbeafe;--bd:#1e3a8a;
  --p:#7c3aed;--pl:#ede9fe;--pd:#4c1d95;
  --o:#ea580c;--ol:#ffedd5;--od:#9a3412;
  --r:#dc2626;--rl:#fee2e2;--rd:#991b1b;
  --y:#ca8a04;--yl:#fef9c3;--yb:#fef08a;
  --gb:#f3f4f6;--gborder:#e5e7eb;--gborder2:#f1f3f6;
  --text:#111827;--text2:#6b7280;--text3:#9ca3af;
  --radius:5px;--shadow:0 1px 3px rgba(0,0,0,.08);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
/* Touch-friendly for mobile */
@media (max-width: 430px){
  *{-webkit-tap-highlight-color:transparent}
  button,select,input,a{touch-action:manipulation}
}
body{font-family:'Segoe UI',system-ui,sans-serif;font-size:13px;color:var(--text);background:#eef0f3;height:100vh;overflow:hidden;display:flex;flex-direction:column}

/* ═══════════════════════════════════════════════════════ */
/* MOBILE RESPONSIVE - iPhone 12+ (390px - 428px width)   */
/* ═══════════════════════════════════════════════════════ */

/* iPhone 12/12 Pro/13/13 Pro/14/14 Pro/15/15 Pro (390px - 430px) */
@media (max-width: 430px) {
  /* Body adjustments */
  body{font-size:12px;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}
  
  /* Header - compact layout */
  .hd{height:52px;padding:0 8px;gap:6px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .hd::-webkit-scrollbar{height:3px}
  .logo{min-width:fit-content}
  .logo img{width:36px;height:36px}
  .logo span{display:none}
  .logo-dot{width:8px;height:8px}
  .vsep{display:none}
  
  /* Branch switcher - icon only */
  .bsw{padding:2px;gap:2px;min-width:fit-content}
  .bsw-btn{padding:4px 6px;border-radius:5px;min-width:36px;justify-content:center}
  .bsw-txt{display:none}
  .bsw-dot{width:7px;height:7px}
  
  /* Header buttons - icon only */
  #fxWidget{padding:4px 6px;min-width:fit-content}
  #fxWidget span:nth-child(2){display:none}
  #fxWidget span:nth-child(3){font-size:10px}
  #kiemHangHistoryBtn{padding:4px 5px;min-width:fit-content}
  #kiemHangHistoryBtn .hd-btn-txt{display:none}
  #adminBtn{padding:4px 5px;min-width:fit-content}
  #adminBtn .hd-btn-txt{display:none}
  .hd-right{gap:4px}
  
  /* Language toggle - smaller */
  .hd div:last-child button{padding:3px 6px;font-size:10px;min-width:32px}
  
  /* Nav — không overflow (overflow-x cắt mất menu xổ); cho xuống dòng trên mobile */
  .nav{min-height:42px;height:auto;padding:4px 8px;gap:4px;flex-wrap:wrap;align-content:flex-end;overflow:visible}
  .nav-btn{height:36px;padding:0 8px;font-size:10px;min-width:fit-content}
  .nav-btn span:not(.nbadge){display:none}
  .nav-btn::after{content:attr(data-icon);font-size:13px}
  .nav-group-btn{height:36px;padding:0 8px;font-size:10px;gap:4px}
  .nav-group .nav-dropdown{left:auto;right:0;border-radius:10px 0 10px 10px;min-width:min(88vw,260px)}
  .nav-drop-item{padding:8px 12px;font-size:11px;gap:6px}
  
  /* Toolbar - wrap content */
  .tb{padding:6px 8px;gap:6px;flex-wrap:wrap}
  .tb input[type=text],.tb select{height:32px;font-size:11px;padding:4px 8px;min-width:120px}
  .btn{height:32px;padding:0 10px;font-size:11px;min-height:36px}
  .btn-lg{height:34px;font-size:12px;padding:0 12px}
  .btn-xs{height:26px;padding:0 6px;font-size:10px}
  
  /* Stats - horizontal scroll */
  .stats{padding:6px 8px;gap:6px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .stats::-webkit-scrollbar{height:3px}
  .stat{padding:5px 10px;min-width:fit-content}
  .stat-lbl{font-size:9px}
  .stat-val{font-size:16px}
  
  /* Flow - scrollable */
  .flow{padding:6px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .flow::-webkit-scrollbar{height:3px}
  .fb{padding:3px 8px;font-size:10px;min-height:28px}
  .fa{font-size:12px;margin:0 3px}
  
  /* Table - responsive */
  .tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{font-size:11px;min-width:600px}
  th{padding:5px 6px;font-size:10px;white-space:nowrap}
  td{padding:5px 6px;font-size:11px}
  
  /* Modal - full width on mobile */
  .modal{width:96vw!important;max-width:96vw;max-height:95vh;margin:2vh auto;border-radius:12px}
  .mhd{padding:12px 14px}
  .mhd h3{font-size:13px}
  .mbd{padding:12px 14px}
  .mft{padding:10px 14px}
  .frow{flex-direction:column;gap:8px}
  .fg{min-width:100%}
  .fg input,.fg select,.fg textarea{font-size:12px;padding:6px 8px;min-height:40px}
  
  /* Cart panel - full width */
  .cpanel{width:100vw;right:0;bottom:0;border-radius:16px 16px 0 0}
  .cphd{border-radius:16px 16px 0 0;padding:14px 16px}
  .cphd h3{font-size:12px}
  .cpbody{padding:8px;padding-bottom:80px}
  .ci{padding:7px;margin-bottom:6px}
  .cinm{font-size:10px}
  .crow{font-size:10px}
  .crow input{width:60px;font-size:11px;min-height:32px}
  .cpft{padding:8px;padding-bottom:calc(8px + env(safe-area-inset-bottom))}
  .cfab{bottom:calc(14px + env(safe-area-inset-bottom));right:14px;padding:10px 16px;font-size:11px;min-height:44px;border-radius:28px;box-shadow:0 4px 20px rgba(0,0,0,.25)}
  
  /* Split layout - stack on mobile */
  .sl{flex-direction:column}
  .sl-l{border-right:none;border-bottom:1px solid var(--gborder);max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .sl-r{width:100%;max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  
  /* App modal specific */
  .app-modal{width:96vw!important}
  .app-item-hd{padding:7px 10px}
  .app-item-ma,.app-item-ten,.app-item-yc{font-size:11px}
  .stock-box{min-width:60px;padding:4px 6px}
  .stock-box .sv{font-size:14px}
  .stock-box .sl{font-size:8px}
  .xuly-row{padding:7px 8px}
  .xuly-col input,.xuly-col select{height:32px;font-size:11px;min-height:36px}
  
  /* Toast - smaller */
  #toastContainer{bottom:calc(16px + env(safe-area-inset-bottom));right:16px;left:16px}
  .toast{max-width:100%;padding:10px 14px;font-size:12px}
  
  /* Login screen mobile - removed */
}

/* iPhone 12/13/14/15 Pro Max (428px - 440px) */
@media (min-width: 431px) and (max-width: 440px) {
  .hd{height:54px;padding:0 10px}
  .logo img{width:38px;height:38px}
  .bsw-btn{padding:5px 8px}
  .nav{min-height:44px;height:auto;padding:0 10px;overflow:visible;flex-wrap:wrap}
  .nav-btn{height:38px;padding:0 10px;font-size:10.5px}
  .modal{width:94vw!important}
  .cpanel{width:340px}
}

/* Tablet and small desktop */
@media (max-width: 1024px) {
  .hd{padding:0 10px;gap:8px}
  .bsw-btn{padding:5px 10px}
  .bsw-txt{display:none}
  .hd-btn-txt{display:none}
  .vsep{display:none}
  .hd{overflow-x:auto}
  .nav{padding:0 10px}
  .nav-btn{padding:0 11px;font-size:11px}
}

/* Mobile general (fallback) */
@media (max-width: 768px) {
  .hd{height:46px}
  .logo span{display:none}
  .bsw{border-radius:6px}
  .bsw-btn{padding:5px 8px}
  #fxWidget{padding:4px 8px}
  #fxWidget span:nth-child(2){display:none}
  #kiemHangHistoryBtn{padding:4px 6px}
  #adminBtn{padding:4px 6px}
  #adminBtn .hd-btn-txt{display:none}
  .nav-btn{padding:0 9px;font-size:10.5px}
  .nav-btn span:not(.nbadge){display:none}
  .nav-btn::after{content:attr(data-icon);font-size:14px}
}

/* HEADER */
.hd{background:#fff;border-bottom:0px solid var(--gborder);display:flex;align-items:center;padding:0 16px;height:50px;flex-shrink:0;gap:12px;box-shadow:var(--shadow)}
.logo{font-size:15px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:10px}
.logo img{transition:transform .2s}
.logo:hover img{transform:scale(1.05)}
.logo-dot{width:10px;height:10px;border-radius:50%;background:var(--g)}
.vsep{width:1px;background:var(--gborder);height:28px}
.hd-right{margin-left:auto;display:flex;align-items:center;gap:8px}

/* BRANCH SWITCHER — prominent */
.bsw{display:flex;background:var(--gb);border:1px solid var(--gborder);border-radius:8px;padding:3px;gap:3px}
.bsw-btn{background:none;border:none;border-radius:6px;padding:5px 16px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text2);transition:.15s;white-space:nowrap;display:flex;align-items:center;gap:6px}
.bsw-btn:hover{background:rgba(0,0,0,.06);color:var(--text)}
.bsw-btn.on-tong{background:#fff;color:var(--gd);box-shadow:var(--shadow)}
.bsw-btn.on-cs1{background:#fff;color:var(--bd);box-shadow:var(--shadow)}
.bsw-btn.on-cs2{background:#fff;color:var(--pd);box-shadow:var(--shadow)}
.bsw-dot{width:8px;height:8px;border-radius:50%}

/* BUTTONS */
.btn{border:none;border-radius:var(--radius);padding:0 13px;height:30px;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:.12s;white-space:nowrap}
.btn-lg{height:36px;font-size:13px;padding:0 16px}
.btn-g{background:var(--g);color:#fff}.btn-g:hover{background:var(--gm)}
.btn-b{background:var(--b);color:#fff}
.btn-r{background:var(--r);color:#fff}
.btn-o{background:var(--o);color:#fff}
.btn-p{background:var(--p);color:#fff}
.btn-gh{background:#fff;color:var(--text);border:1px solid var(--gborder)}.btn-gh:hover{background:var(--gb)}
.btn-xs{height:24px;padding:0 8px;font-size:11px;border-radius:4px}

/* NAV — overflow visible để .nav-dropdown (absolute) không bị cắt bởi scroll container */
.nav{background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:0.5px solid var(--g);display:flex;align-items:flex-end;flex-wrap:wrap;padding:0 12px 0 16px;flex-shrink:0;gap:4px 6px;box-shadow:0 2px 8px rgba(0,0,0,.08);position:relative;z-index:100;min-height:46px;overflow:visible}
.nav-btn{background:none;border:1px solid transparent;padding:0 14px;height:46px;font-size:11.5px;color:var(--text2);cursor:pointer;border-bottom:1px solid transparent;display:flex;align-items:center;gap:5px;font-weight:600;transition:.15s;white-space:nowrap;margin:0;border-radius:6px 6px 0 0}
.nav-btn:hover{color:var(--text);background:rgba(0,0,0,.04)}
.nav-btn.act{font-weight:700;border-bottom-color:currentColor;background:rgba(255,255,255,.8)}
.nav-btn.act.nc-b{color:var(--b);border-bottom-color:var(--b)}
.nav-btn.act.nc-g{color:var(--g);border-bottom-color:var(--g)}
.nav-btn.act.nc-p{color:var(--p);border-bottom-color:var(--p)}
.nbadge{background:var(--o);color:#fff;border-radius:10px;font-size:9.5px;padding:1px 5px;font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.2)}
/* NAV GROUP DROPDOWN */
.nav-group{position:relative;display:inline-flex;flex-shrink:0;align-items:stretch}
.nav-group-btn{background:none;border:1px solid transparent;padding:0 12px;height:44px;font-size:11.3px;color:var(--text2);cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-weight:600;transition:.15s;white-space:nowrap;margin:0;border-radius:6px 6px 0 0;border-bottom:2px solid transparent}
.nav-group-btn:hover{color:var(--text);background:rgba(0,0,0,.04)}
.nav-group-btn.act{font-weight:700;color:var(--g);border-bottom-color:var(--g);background:rgba(255,255,255,.85)}
.nav-group-btn.act.nc-b{color:var(--b);border-bottom-color:var(--b)}
.nav-group-btn.act.nc-g{color:var(--g);border-bottom-color:var(--g)}
.nav-group-btn.act.nc-p{color:var(--p);border-bottom-color:var(--p)}
.nav-group-btn .arr{font-size:8px;opacity:.5;margin-left:1px}
.nav-group .nav-dropdown{display:none;position:absolute;top:100%;left:0;margin-top:0;background:#fff;border:1px solid var(--gborder);border-radius:0 10px 10px 10px;box-shadow:0 10px 28px rgba(0,0,0,.12);z-index:5000;min-width:200px;max-width:min(92vw,320px);padding:4px 0}
.nav-group:hover .nav-dropdown,.nav-group:focus-within .nav-dropdown{display:block}
.nav-drop-item .nbadge{margin-left:auto;flex-shrink:0}
.nav-drop-item{display:flex;align-items:center;gap:8px;padding:9px 16px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;white-space:nowrap;border:none;background:none;width:100%;text-align:left;transition:.1s}
.nav-drop-item:hover{background:var(--gb);color:var(--text)}
.nav-drop-item.act{color:var(--g);background:var(--gl);font-weight:700}
.nav-drop-item.act.nc-b{color:var(--b);background:var(--bl)}
.nav-drop-item.act.nc-g{color:var(--g);background:var(--gl)}
.nav-drop-sep{height:1px;background:var(--gborder);margin:4px 0}

/* TOOLBAR */
.tb{background:#fff;border-bottom:1px solid var(--gborder);display:flex;align-items:center;padding:7px 16px;gap:8px;flex-shrink:0;flex-wrap:wrap}
.tb input[type=text],.tb select{border:1px solid var(--gborder);border-radius:var(--radius);padding:4px 9px;font-size:12px;height:28px;color:var(--text);background:#fff}
.tb input:focus,.tb select:focus{outline:none;border-color:var(--b);box-shadow:0 0 0 2px rgba(37,99,235,.1)}
.sp{flex:1}

/* STATS */
.stats{display:flex;gap:8px;padding:8px 16px;background:#fff;border-bottom:1px solid var(--gborder);flex-shrink:0;flex-wrap:wrap;align-items:center}
.stat{background:var(--gb);border-radius:var(--radius);padding:6px 14px;display:flex;align-items:center;gap:8px}
.stat-lbl{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.stat-val{font-size:18px;font-weight:800;line-height:1}
.st-g .stat-val{color:var(--g)} .st-r .stat-val{color:var(--r)} .st-o .stat-val{color:var(--o)} .st-b .stat-val{color:var(--b)} .st-p .stat-val{color:var(--p)}

/* PAGES */
.page{display:none;flex:1;flex-direction:column;overflow:hidden;min-height:0}
.page.act{display:flex}

/* TABLE */
.tw{flex:1;overflow:auto}
table{border-collapse:collapse;font-size:12px;white-space:nowrap;width:100%}
th{background:#f8fafc;color:var(--text2);font-weight:600;font-size:11px;padding:6px 10px;border-bottom:2px solid var(--gborder);border-right:1px solid var(--gborder2);text-align:left;position:sticky;top:0;z-index:5}
th.ct{text-align:center}
td{padding:6px 10px;border-bottom:1px solid var(--gborder2);border-right:1px solid var(--gborder2);vertical-align:middle}
td.ct{text-align:center}
tr:hover>td{background:#f9fbff}
tr.gr>td{background:#f1f5f9;font-size:10px;font-weight:800;color:var(--text2);padding:3px 10px;letter-spacing:.7px;text-transform:uppercase;border-bottom:1px solid var(--gborder)}

/* col tints */
th.hb,td.hb{background:#eff6ff} th.hg,td.hg{background:#f0fdf4}
th.ho,td.ho{background:#fff7ed} th.hy,td.hy{background:#fefce8}
th.hr,td.hr{background:#fef2f2} th.hp,td.hp{background:#f5f3ff}
th.hcs1{background:#dbeafe;color:var(--bd)!important} th.hcs2{background:#ede9fe;color:var(--pd)!important}
th.htong{background:#dcfce7;color:var(--gd)!important}
td.bcs2{border-left:2px solid var(--p)!important}

/* number */
.nr{color:var(--r);font-weight:700} .no{color:var(--o);font-weight:700}
.ng{color:var(--g);font-weight:700} .nb{color:var(--b);font-weight:700}
.np{color:var(--p);font-weight:700} .nw{color:var(--text2)}
.nbig{font-size:14px;font-weight:800}

/* date cell */
td.dc{padding:2px 3px;text-align:center;background:#fefce8;min-width:28px}
td.dc.dv{background:#fff3e0}
td.dc.dc-locked{background:#f9fafb!important;cursor:not-allowed!important;opacity:0.6}
td.dc .dot{display:inline-block;width:32px;height:20px;background:var(--o);color:#fff;border-radius:3px;font-size:11px;font-weight:800;line-height:20px;text-align:center;cursor:pointer}
td.dc .dot:hover{background:#c2410c}
td.dc input{width:36px;border:1px solid var(--o);border-radius:3px;padding:1px 0;text-align:center;font-size:12px;font-weight:700;color:var(--o);background:#fff}
td.dc input:focus{outline:none;width:40px}
th.hd-date{background:#fff3e0;color:#92400e;text-align:center;min-width:42px;padding:4px 3px;font-size:10px}
th.hd-date.today{background:var(--o);color:#fff;font-weight:800}

/* badges */
.bdg{display:inline-flex;align-items:center;gap:2px;border-radius:20px;padding:2px 9px;font-size:11px;font-weight:700;white-space:nowrap}
#toastContainer{position:fixed;bottom:24px;right:24px;z-index:9998;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.18);pointer-events:all;animation:toastIn .2s ease;max-width:360px}
.toast-ok{background:#f0fdf4;border:1px solid #86efac;color:#166534}
.toast-warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e}
.toast-err{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b}
.toast-info{background:#eff6ff;border:1px solid #93c5fd;color:#1e40af}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.bok{background:var(--gl);color:var(--gd)} .bhet{background:var(--rl);color:var(--rd)}
.bthieu{background:var(--yl);color:var(--y)} .bdu{background:var(--bl);color:var(--bd)} .berr{background:#fee2e2;color:#dc2626}
.bpend{background:var(--ol);color:var(--od)} .bdone{background:#e0e7ff;color:#3730a3}
.bordered{background:var(--bl);color:var(--bd)} .barrived{background:var(--pl);color:var(--pd)}
.brejected{background:var(--rl);color:var(--rd)}
/* source tag */
.src{display:inline-block;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700;white-space:nowrap}
.src-order{background:#dbeafe;color:var(--bd)}
.src-gift{background:#dcfce7;color:var(--gd)}
.src-extra{background:#fef9c3;color:var(--y)}
.src-transfer{background:#ede9fe;color:var(--pd)}

/* inline action */
.ia{background:none;border:1px solid var(--gborder);border-radius:3px;padding:1px 6px;font-size:11px;cursor:pointer;color:var(--text2);white-space:nowrap}
.ia:hover{background:var(--gb)}
.ia-g{color:var(--g);border-color:var(--g)}.ia-g:hover{background:var(--gl)}
.ia-r{color:var(--r);border-color:var(--r)}.ia-r:hover{background:var(--rl)}
.ia-b{color:var(--b);border-color:var(--b)}.ia-b:hover{background:var(--bl)}
.ia-o{color:var(--o);border-color:var(--o)}.ia-o:hover{background:var(--ol)}

/* FLOW */
.flow{display:flex;align-items:center;padding:8px 16px;background:#fff;border-bottom:1px solid var(--gborder);overflow-x:auto;gap:0;flex-shrink:0}
.fs{display:flex;align-items:center}
.fb{border:1px solid var(--gborder);border-radius:var(--radius);padding:4px 12px;font-size:11px;white-space:nowrap;background:var(--gb);color:var(--text2)}
.fb.done{background:var(--gl);border-color:#86efac;color:var(--gd)}
.fb.active{background:var(--ol);border-color:#fdba74;color:var(--od);font-weight:700}
.fb.next{background:#fff;border-color:var(--b);color:var(--b)}
.fa{color:var(--text3);margin:0 5px;font-size:14px}

/* MODAL */
.ov{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:200;align-items:center;justify-content:center}
.ov.open{display:flex}
.modal{background:#fff;border-radius:10px;width:520px;max-width:96vw;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.mhd{padding:14px 18px;border-bottom:1px solid var(--gborder);display:flex;justify-content:space-between;align-items:center}
.mhd h3{font-size:14px;font-weight:700}
.mx{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text2)}
.mbd{padding:16px 18px}
.mft{padding:12px 18px;border-top:1px solid var(--gborder);display:flex;justify-content:flex-end;gap:8px}
.frow{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.fg{flex:1;min-width:120px}
.fg label{display:block;font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}
.fg input,.fg select,.fg textarea{width:100%;border:1px solid var(--gborder);border-radius:var(--radius);padding:6px 9px;font-size:13px}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--b)}
.notif{padding:8px 12px;border-radius:var(--radius);font-size:12px;margin-bottom:10px}
.nok{background:var(--gl);color:var(--gd);border-left:3px solid var(--g)}
.nwarn{background:var(--yl);color:var(--y);border-left:3px solid var(--y)}
.ninfo{background:var(--bl);color:var(--bd);border-left:3px solid var(--b)}
.nerr{background:var(--rl);color:var(--rd);border-left:3px solid var(--r)}

/* CART */
.cpanel{position:fixed;right:0;top:0;bottom:0;width:320px;background:#fff;box-shadow:-4px 0 20px rgba(0,0,0,.1);z-index:100;transform:translateX(100%);transition:.2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.cpanel.open{transform:none}
.cphd{background:var(--g);color:#fff;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.cphd h3{font-size:13px;font-weight:700}
.cpx{background:none;border:none;color:rgba(255,255,255,.8);cursor:pointer;font-size:17px}
.cpbody{flex:1;overflow-y:auto;padding:10px}
.ci{border:1px solid var(--gborder);border-radius:var(--radius);padding:9px;margin-bottom:7px}
.cinm{font-weight:700;font-size:11px;margin-bottom:6px}
.crow{display:flex;align-items:center;gap:7px;font-size:11px;margin-bottom:4px}
.crow label{color:var(--text2);width:64px;flex-shrink:0}
.crow input{border:1px solid var(--gborder);border-radius:3px;padding:2px 6px;width:70px;font-size:12px}
.cidel{background:none;border:none;color:var(--r);cursor:pointer;margin-left:auto;font-size:14px}
.cpft{padding:10px;border-top:1px solid var(--gborder);flex-shrink:0}
.cpft select,.cpft textarea{width:100%;border:1px solid var(--gborder);border-radius:var(--radius);padding:6px;font-size:12px;margin-bottom:7px}
.cfab{display:none;position:fixed;bottom:18px;right:18px;z-index:99;background:var(--g);color:#fff;border:none;border-radius:24px;padding:10px 16px;font-size:12px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.2);align-items:center;gap:6px}
.cfab.show{display:flex}
.cfcnt{background:var(--r);color:#fff;border-radius:50%;width:17px;height:17px;font-size:10px;display:inline-flex;align-items:center;justify-content:center}

/* split layout */
.sl{display:flex;flex:1;overflow:hidden;min-height:0}
.sl-l{flex:1;overflow:auto;border-right:1px solid var(--gborder)}
.sl-r{width:300px;overflow-y:auto;display:flex;flex-direction:column;background:#fafafa}
.sl-r-hd{padding:10px 12px;border-bottom:1px solid var(--gborder);font-size:12px;font-weight:700;background:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.sl-r-body{flex:1;overflow-y:auto;padding:10px}
.sl-r-ft{padding:10px;border-top:1px solid var(--gborder);background:#fff;flex-shrink:0}

/* Role indicator strip */
.role-strip{height:3px;flex-shrink:0}
.rs-tong{background:linear-gradient(90deg,var(--g),var(--gm))}
.rs-cs1{background:linear-gradient(90deg,var(--b),#3b82f6)}
.rs-cs2{background:linear-gradient(90deg,var(--p),#a78bfa)}

/* section divider */
.sec-ttl{padding:8px 16px 4px;font-size:10px;font-weight:800;color:var(--text2);text-transform:uppercase;letter-spacing:.7px;background:var(--gb);border-bottom:1px solid var(--gborder);flex-shrink:0}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}
/* ── APPROVE MODAL EXTRAS ── */
.app-modal{width:820px!important;max-width:97vw}
.app-item-card{border:1px solid var(--gborder);border-radius:8px;margin-bottom:14px;overflow:hidden}
.app-item-hd{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--gb);border-bottom:1px solid var(--gborder)}
.app-item-ma{font-weight:800;font-size:13px;color:var(--text)}
.app-item-ten{font-size:13px;color:var(--text);flex:1}
.app-item-yc{font-size:13px;font-weight:800;color:var(--b)}
.app-item-body{padding:10px 12px;display:flex;flex-direction:column;gap:8px}
/* stock row */
.stock-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.stock-box{border-radius:5px;padding:5px 10px;text-align:center;min-width:80px}
.stock-box .sv{font-size:16px;font-weight:800;line-height:1}
.stock-box .sl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-top:1px}
.sb-cs1{background:var(--bl);color:var(--bd)}
.sb-cs2{background:var(--pl);color:var(--pd)}
.sb-tong{background:var(--gl);color:var(--gd)}
.sb-min{background:var(--yl);color:var(--y)}
.sb-max{background:#f0f9ff;color:#0369a1}
.stock-arrow{color:var(--text3);font-size:14px}
/* xuly row */
.xuly-row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;background:#fafafa;border:1px solid var(--gborder);border-radius:6px;padding:9px 10px}
.xuly-col{display:flex;flex-direction:column;gap:3px}
.xuly-col label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text2)}
.xuly-col input,.xuly-col select{border:1px solid var(--gborder);border-radius:4px;padding:4px 8px;font-size:12px;background:#fff;height:28px;color:var(--text)}
.xuly-col input:focus,.xuly-col select:focus{outline:none;border-color:var(--b)}
.xuly-col input[readonly]{background:var(--gb);color:var(--text2)}
.xuly-result{display:flex;flex-direction:column;gap:3px}
.xuly-result label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text2)}
.xuly-chot{font-size:16px;font-weight:800;color:var(--g);background:var(--gl);border:1px solid #86efac;border-radius:4px;padding:4px 10px;min-width:60px;text-align:center}
.xuly-chot.need{color:var(--r);background:var(--rl);border-color:#fca5a5}
.xuly-chot.zero{color:var(--text3);background:var(--gb);border-color:var(--gborder)}
.dc-tag{background:var(--ol);color:var(--od);border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700}
.btn-dc-inline{background:var(--o);color:#fff;border:none;border-radius:4px;padding:0 10px;height:28px;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap}
.btn-dc-inline:hover{background:#c2410c}
/* summary footer */
.app-summary{background:var(--gb);border-radius:6px;padding:10px 12px;margin-top:4px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.app-sum-item{display:flex;flex-direction:column;gap:1px}
.app-sum-item .asl{font-size:10px;color:var(--text2);font-weight:600}
.app-sum-item .asv{font-size:15px;font-weight:800}
