:root{
  --red:#C62828; --red-d:#B71C1C; --cream:#FFEBEE; --green:#27AE60;
  --blue:#3498DB; --amber:#F39C12; --danger:#E74C3C; --bg:#F8F9FA; --ink:#2C3E50;
  --card:#fff; --line:#ECE3D6; --line2:#EDF0F2; --muted:#7d8a97;
  --shadow:0 1px 2px rgba(44,62,80,.04),0 6px 24px rgba(44,62,80,.07);
  --shadow-l:0 12px 40px rgba(44,62,80,.14);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hanken Grotesk",-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
.fr{font-family:"Fraunces",serif}
.num{font-variant-numeric:tabular-nums}
.boot{display:grid;place-items:center;height:100vh;color:var(--muted)}
a{color:inherit;text-decoration:none;cursor:pointer}
::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:#d9d2c7;border-radius:8px;border:3px solid transparent;background-clip:content-box}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(900px 500px at 12% -10%,#FFEBEE 0,rgba(255,235,238,0) 60%),radial-gradient(820px 460px at 112% 120%,#FFEBEE 0,rgba(255,235,238,0) 55%),#fff}
.login-card{width:100%;max-width:920px;background:#fff;border:1px solid var(--line2);border-radius:22px;box-shadow:0 24px 70px rgba(40,20,30,.16);overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.login-hero{background:linear-gradient(160deg,var(--red),var(--red-d));color:#fff;padding:42px 38px;position:relative;overflow:hidden}
.login-hero:after{content:"";position:absolute;right:-70px;bottom:-70px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.2),transparent 70%)}
.badge{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.18);display:grid;place-items:center;color:#fff}
.login-hero h1{font-size:30px;margin:14px 0 0}.login-hero h1 .v{background:#fff;color:var(--red-d);font-size:13px;padding:2px 7px;border-radius:7px;margin-left:5px;vertical-align:middle;font-family:"Hanken Grotesk"}
.login-hero .tag{color:rgba(255,255,255,.72);letter-spacing:1px;font-size:11px;margin-top:4px}
.login-hero p{color:rgba(255,255,255,.86);font-size:14px;margin-top:18px;max-width:320px}
.login-hero .foot{position:absolute;bottom:26px;left:38px;right:38px;color:rgba(255,255,255,.78);font-size:11px;line-height:1.7}
.login-form{padding:42px 38px}
.login-form h2{font-size:21px;margin:0}.login-form .sub{color:var(--muted);font-size:13px;margin:6px 0 20px}
@media(max-width:720px){.login-card{grid-template-columns:1fr}.login-hero{display:none}}

.field{margin-top:14px}
.field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:6px}
.field input,.field select,.inp{width:100%;padding:12px 13px;border:1.5px solid var(--line);border-radius:11px;background:linear-gradient(#fff,#fdfcfa);font-size:14px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.inp:focus{border-color:var(--red);box-shadow:0 0 0 4px rgba(198,40,40,.13)}
select.inp,.field select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B71C1C' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:10px;font-weight:700;font-size:13.5px;border:none;cursor:pointer;transition:.15s;font-family:inherit}
.btn-block{width:100%;padding:13px}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 6px 18px rgba(198,40,40,.3)}.btn-primary:hover{background:var(--red-d)}
.btn-ghost{background:#fff;border:1.5px solid var(--line);color:var(--ink)}
.btn-soft{background:var(--cream);color:var(--red-d);font-weight:700}
.btn-green{background:var(--green);color:#fff}.btn-red{background:var(--danger);color:#fff}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:8px}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* ---------- shell ---------- */
.shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.side{background:linear-gradient(180deg,#FBF5F6 0%,#F4F1F5 100%);border-right:1px solid var(--line2);display:flex;flex-direction:column}
.side-role{margin:6px 16px 8px;padding:11px 12px;background:#fff;border:1px solid var(--line2);border-radius:11px}
.side-top{padding:18px 18px 12px}
.brand-lock{display:flex;align-items:center;gap:11px}
.brand-badge{width:42px;height:42px;border-radius:12px;background:linear-gradient(150deg,var(--red),var(--red-d));color:#fff;display:grid;place-items:center;box-shadow:0 8px 22px rgba(198,40,40,.4)}
.side-top h1{font-size:19px;margin:0}.side-top h1 .v{background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff;font-size:10px;padding:1px 6px;border-radius:7px;margin-left:4px;vertical-align:middle;font-family:"Hanken Grotesk"}
.side-top small{color:var(--muted);font-size:10.5px}
.side-role .rl{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.side-role .rn{font-weight:700;font-size:13.5px;margin:2px 0 8px}
.nav{padding:6px 12px;flex:1;overflow:auto}
.nav .grp{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:10px 8px 6px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--ink);font-size:13.5px;font-weight:600;margin-bottom:2px}
.nav a:hover{background:var(--bg)}
.nav a.on{background:linear-gradient(120deg,var(--red),var(--red-d));color:#fff;box-shadow:0 6px 16px rgba(198,40,40,.32)}
.nav a .bdg{margin-left:auto;background:var(--danger);color:#fff;border-radius:20px;font-size:10px;padding:1px 7px}
.nav a.on .bdg{background:rgba(255,255,255,.3)}
.side-foot{padding:12px 16px;border-top:1px solid var(--line2)}
.side-foot a{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:13px;font-weight:600}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;background:#fff;border-bottom:1px solid var(--line2);position:sticky;top:0;z-index:20}
.tb-title{font-weight:800;font-size:16px}.tb-sub{font-size:12px;color:var(--muted)}
.tb-spacer{flex:1}
.brandtog{display:flex;background:var(--bg);border-radius:10px;padding:3px;border:1px solid var(--line2)}
.brandtog button{padding:7px 13px;border-radius:8px;font-size:12.5px;font-weight:700;color:var(--muted);border:none;background:none;cursor:pointer}
.brandtog button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.clockpill{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:700}
.content{padding:22px;overflow:auto}

/* ---------- generic ---------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head h2{font-size:22px;margin:0;letter-spacing:-.4px}.page-head p{color:var(--muted);margin:3px 0 0;font-size:13px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}
.card{background:#fff;border:1px solid var(--line2);border-radius:14px;box-shadow:var(--shadow)}
.card-pad{padding:18px}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line2)}
.card-h h3{margin:0;font-size:15px}.card-h .hint{font-size:12px;color:var(--muted)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;align-items:start}
@media(max-width:900px){.shell{grid-template-columns:1fr}.side{position:fixed;left:-260px;top:0;bottom:0;width:250px;z-index:50;transition:.2s}.side.open{left:0}.grid2{grid-template-columns:1fr}}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:13px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--line2);border-radius:14px;padding:14px 15px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--red),var(--red-d));opacity:.85}
.kpi .ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;margin-bottom:9px}
.kpi .lbl{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.kpi .val{font-size:26px;font-weight:700;font-family:"Fraunces",serif;letter-spacing:-.8px;line-height:1.05}
.kpi .val small{font-size:12px;color:var(--muted);font-family:"Hanken Grotesk"}
.tint-o{background:#fdeaea;color:var(--red-d)}.tint-g{background:#e6f6ed;color:#1d8a4e}.tint-b{background:#e7f2fb;color:#2376b8}.tint-a{background:#fef4e1;color:#c87f0a}.tint-r{background:#fdeceb;color:#c0392b}.tint-i{background:#eef1f4;color:#43586b}

table.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:11px 14px;background:#fbfaf8;border-bottom:1px solid var(--line2)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line2)}
.tbl tr:last-child td{border-bottom:none}
.tbl td.c,.tbl th.c{text-align:center}.tbl td.r,.tbl th.r{text-align:right}
.tbl-wrap{overflow:auto}
.code{font-family:ui-monospace,Menlo,monospace;font-size:11.5px;background:#f3f1ee;padding:1px 6px;border-radius:5px;color:#6a584a}
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:20px}
.chip .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.c-green{background:#e9f8ef;color:#1d8a4e}.c-amber{background:#fef3e0;color:#b9770b}.c-red{background:#fdeceb;color:#c0392b}.c-grey{background:#eef0f2;color:#6b7884}.c-blue{background:#e7f2fb;color:#2376b8}
.empty{padding:34px;text-align:center;color:var(--muted)}
.alertbar{display:flex;gap:11px;align-items:flex-start;border-radius:12px;padding:13px 15px;margin-bottom:16px;font-size:13px}
.al-blue{background:#eaf4fc;color:#225e86}.al-amber{background:#fff6e6;color:#8a5a00}.al-green{background:#e9f8ef;color:#1d6f3f}.al-red{background:#fdeaea;color:#9b1c1c}
.alertbar .ai{flex:none;margin-top:1px}

/* order builder */
.cat-block{border:1px solid var(--line2);border-radius:12px;margin-bottom:12px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.cat-head{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;background:#fbfaf8;cursor:pointer}
.cat-head b{font-size:14px}
.itemrow{display:flex;align-items:center;gap:12px;padding:9px 15px;border-top:1px solid var(--line2)}
.itemrow .nm{flex:1}.itemrow .nm small{color:var(--muted);font-size:11px}
.qtybox{width:84px;text-align:center}
.barrow{margin-bottom:12px}.barrow .bl{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px}
.track{height:9px;background:#eef0f2;border-radius:6px;overflow:hidden}.track .fill{height:100%;border-radius:6px}

/* modal */
.modal-back{position:fixed;inset:0;background:rgba(20,12,16,.45);display:grid;place-items:center;z-index:100;padding:20px}
.modal{background:#fff;border-radius:16px;width:100%;max-width:560px;box-shadow:var(--shadow-l);overflow:hidden}
.modal-wide{max-width:960px}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line2)}
.modal-h h3{margin:0;font-size:17px}
.modal-b{padding:18px 20px}
.modal-f{display:flex;gap:10px;align-items:center;padding:14px 20px;border-top:1px solid var(--line2)}
.iconbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line2);background:#fff;display:grid;place-items:center;cursor:pointer}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formgrid .full{grid-column:1/3}
.info-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line2);font-size:13px}.info-row span{color:var(--muted)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--ink);color:#fff;padding:12px 18px;border-radius:11px;font-size:13.5px;font-weight:600;opacity:0;transition:.25s;z-index:200;box-shadow:var(--shadow-l)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.flbl{font-size:11px;font-weight:700;color:var(--muted)}
textarea.inp{font-family:inherit;resize:vertical;min-height:84px}
.nav{padding-bottom:14px}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;border-bottom:1px solid var(--line2);padding-bottom:0}
.tabs button{border:none;background:none;padding:9px 14px;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;font-family:inherit}
.tabs button.on{color:var(--red-d);border-bottom-color:var(--red)}
/*PATCH11:filterbar*/
.filterbar{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;background:#FFFCF5;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:16px}
.filterbar .fld{display:flex;flex-direction:column;gap:5px;min-width:150px}
.filterbar .fld>label{font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.filterbar .fld .inp{min-width:150px}
/*PATCH14:enhance*/
#repWrap .tabs{gap:4px;border-bottom:2px solid var(--line2);margin-bottom:18px}
#repWrap .tabs button{padding:10px 16px;font-size:13.5px;border-radius:8px 8px 0 0}
#repWrap .tabs button:hover{color:var(--ink);background:#faf7f2}
#repWrap .tabs button.on{background:linear-gradient(180deg,#fff5f5,#fff);border-bottom-color:var(--red)}
#repWrap .filterbar{gap:16px;background:linear-gradient(180deg,#fffdf8,#fff);border:1px solid var(--line);box-shadow:0 2px 12px rgba(40,20,10,.045);border-radius:16px;padding:16px 18px}
#repWrap .filterbar .fld>label{font-size:10px;letter-spacing:.7px;color:#9a8f80}
#repWrap .filterbar .inp,#repWrap .card-pad>.inp{border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13.5px;background:#fff;transition:border-color .15s,box-shadow .15s}
#repWrap .filterbar .inp:focus,#repWrap .card-pad>.inp:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(198,40,40,.13)}
#repWrap .btn{transition:transform .12s,box-shadow .15s,filter .15s}
#repWrap .btn:hover{transform:translateY(-1px)}
#repWrap .btn:active{transform:translateY(0)}
#repWrap .btn-red{background:linear-gradient(180deg,#e2453b,#c62828);box-shadow:0 3px 10px rgba(198,40,40,.28)}
#repWrap .btn-red:hover{box-shadow:0 6px 18px rgba(198,40,40,.36)}
#repWrap .btn-green{background:linear-gradient(180deg,#31be6f,#1f9d57);box-shadow:0 3px 10px rgba(31,157,87,.26)}
#repWrap .btn-green:hover{box-shadow:0 6px 18px rgba(31,157,87,.34)}
#repWrap .btn-ghost:hover,#repWrap .btn-soft:hover{box-shadow:0 3px 10px rgba(40,20,10,.08)}
#repWrap .card{box-shadow:0 6px 24px rgba(40,20,10,.06);border-radius:16px}
#repWrap .card-h{padding:16px 18px}
#repWrap .card-h h3{font-size:15px;letter-spacing:.2px}
#repWrap .card-h .hint{font-size:11px;color:var(--muted);background:#f6f3ee;padding:4px 10px;border-radius:20px;font-weight:700}
#repWrap .tbl thead th{background:#fbf7f2;font-size:10.5px}
#repWrap .tbl tbody tr{transition:background .12s}
#repWrap .tbl tbody tr:nth-child(even){background:#fcfbf9}
#repWrap .tbl tbody tr:hover{background:#fff4f4}
#repWrap .tbl td.num,#repWrap .tbl td.r.num{font-variant-numeric:tabular-nums;font-weight:700}
#repWrap .card-pad>h3{font-size:16px;letter-spacing:.2px}
#repWrap .alertbar.al-green{border-radius:12px}
.matrix{border-collapse:separate;border-spacing:0;font-size:12px}
.matrix th,.matrix td{padding:7px 8px;border-bottom:1px solid var(--line2);white-space:nowrap}
.matrix th.rot{height:108px;vertical-align:bottom;padding:0 2px}
.matrix th.rot span{writing-mode:vertical-rl;transform:rotate(195deg);font-size:10.5px;color:var(--muted);font-weight:700;display:inline-block}
.matrix td.sticky,.matrix th.sticky{position:sticky;left:0;background:#fff;text-align:left;font-weight:700;z-index:2;box-shadow:1px 0 0 var(--line2)}
.mdot{width:13px;height:13px;border-radius:50%;display:inline-block}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:0 0 12px}
.legend span{display:inline-flex;align-items:center;gap:6px}
/* order page */
.cat-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:14px}
.cat-tab{flex:none;min-width:130px;text-align:left;border:1.5px solid var(--line2);background:#fff;border-radius:11px;padding:9px 12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;font-family:inherit}
.cat-tab:hover{border-color:#e3b9b9}
.cat-tab.on{border-color:var(--red);background:var(--cream);box-shadow:0 0 0 3px rgba(198,40,40,.1)}
.cat-tab .cn{font-weight:700;font-size:13px;color:var(--ink);white-space:nowrap}
.cat-tab .ci{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.prod-row{display:flex;align-items:center;gap:14px;padding:11px 14px;border-bottom:1px solid var(--line2)}
.prod-row:hover{background:#fffafa}
.prod-row .pcode{width:118px;flex:none}
.prod-row .pname{flex:1;font-weight:600;font-size:13.5px;min-width:0}
.prod-row .ptag{font-size:11px;color:var(--muted);font-weight:500}
.refs{display:flex;gap:5px;flex:none;align-items:center}
.rf{font-size:10.5px;font-weight:700;color:var(--muted);background:#f4f1ec;border:1px solid var(--line2);border-radius:7px;padding:2px 6px;white-space:nowrap}
.rf b{color:var(--ink)}
.rf.sug{background:var(--cream);border-color:#f0c9c9;color:var(--red-d);cursor:pointer}
.rf.sug:hover{background:#fbd9d9}
.stepper{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;flex:none}
.stepper button{width:34px;height:36px;font-size:18px;font-weight:700;color:var(--red-d);background:#fff;border:none;cursor:pointer}
.stepper button:hover{background:var(--cream)}
.stepper input{width:54px;height:36px;border:none;border-left:1px solid var(--line2);border-right:1px solid var(--line2);text-align:center;font-size:14px;font-weight:700;outline:none;font-variant-numeric:tabular-nums}
.order-foot{display:flex;align-items:center;gap:22px;padding:14px 16px;border-top:1px solid var(--line2);flex-wrap:wrap;position:sticky;bottom:0;background:#fff}
.order-foot .sum{font-size:12px;color:var(--muted)}
.order-foot .sum b{font-size:22px;color:var(--ink);font-weight:700;display:block;font-family:"Fraunces",serif}
.searchbox{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:8px 12px;max-width:340px;color:var(--muted)}
.searchbox input{border:none;outline:none;flex:1;font-size:13.5px;color:var(--ink);background:transparent}
@media(max-width:920px){.refs{display:none}.prod-row .pcode{width:90px}}
/* category-wise compliance (chip rows) */
.cmrow{display:flex;gap:16px;padding:11px 0;border-bottom:1px solid var(--line2);align-items:flex-start}
.cmrow:last-child{border-bottom:none}
.cmstore{flex:0 0 210px;font-weight:700;font-size:13px;padding-top:2px}
.cmchips{flex:1;display:flex;flex-wrap:wrap;gap:7px}
.cmchip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:20px;line-height:1}
.cmchip small{opacity:.65;font-weight:600;font-size:10px}
.cmdot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:none}
@media(max-width:760px){.cmrow{flex-direction:column;gap:7px}.cmstore{flex:auto}}
/* rich KPI cards (with trend + sparkline) */
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.kpi-top .ic{margin-bottom:0}
.kpi .trend{font-size:12px;font-weight:800;font-variant-numeric:tabular-nums}
.kpi-spark{height:34px;margin:8px 0 2px;opacity:.9}
.kpi .cmp{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
/* top bar: search, ordering-window pill, bell */
.topsearch{display:flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--line2);border-radius:11px;padding:8px 13px;min-width:240px;max-width:420px;flex:1;transition:border-color .15s,box-shadow .15s}
.topsearch:focus-within{border-color:var(--red);box-shadow:0 0 0 3px rgba(198,40,40,.1)}
.topsearch .tsi{color:var(--muted);display:flex;flex:none}
.topsearch input{border:none;outline:none;flex:1;font-size:13.5px;color:var(--ink);background:transparent}
.topsearch input::placeholder{color:#9aa5b1}
.winpill{display:flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--line2);border-radius:11px;padding:6px 12px}
.winpill .wd{width:9px;height:9px;border-radius:50%;flex:none}
.winpill .wd.g{background:#27AE60;box-shadow:0 0 0 3px rgba(39,174,96,.18)}
.winpill .wd.r{background:#E74C3C;box-shadow:0 0 0 3px rgba(231,76,60,.18)}
.winpill .wt b{display:block;font-size:12.5px;font-weight:800;line-height:1.15;color:var(--ink)}
.winpill .wt small{font-size:10.5px;color:var(--muted);font-weight:600}
@media(max-width:1100px){.winpill{display:none}}
@media(max-width:860px){.topsearch{min-width:0;max-width:none}.tb-sub{display:none}}
/* PATCH2:styles — order tiles, cut-off popup, history chart */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:14px;margin-bottom:18px}
.cat-card{display:flex;flex-direction:column;gap:9px;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 16px;cursor:pointer;box-shadow:var(--shadow);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}
.cat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-l);border-color:#d9c9b3}
.cat-card.has{border-color:var(--red);box-shadow:inset 0 0 0 1px var(--red),var(--shadow)}
.cat-card .cc-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.cat-card .cc-name{font-weight:800;font-size:14.5px;color:var(--ink)}
.cat-card .cc-mid{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.cat-card .cc-cut{font-size:11.5px;color:var(--muted);font-weight:600}
.cat-card .cc-cnt{font-size:21px;font-weight:800;color:var(--red-d);line-height:1}
.cat-card .cc-sub{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px;color:var(--muted);font-weight:600;min-height:15px}
.cat-card .cc-late{color:var(--amber);font-weight:800}
.prod-row .lf-late{margin-left:8px;font-size:10px;font-weight:800;color:var(--amber);background:rgba(243,156,18,.12);border-radius:999px;padding:2px 8px;white-space:nowrap}
.daterange{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.daterange .dr-in{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:700}
.daterange input[type=date]{border:1px solid var(--line);border-radius:9px;padding:7px 10px;font:inherit;color:var(--ink);background:var(--card)}
.hist-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.hist-stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow)}
.hist-stat .hs-lab{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800}
.hist-stat .hs-val{font-size:26px;font-weight:800;color:var(--ink);line-height:1.1;margin:4px 0 9px}
.hist-stat .hs-track{height:7px;border-radius:999px;background:var(--line2);overflow:hidden}
.hist-stat .hs-fill{height:100%;border-radius:999px;transition:width .3s ease}
.hist-stat.s-total .hs-fill{background:var(--blue)} .hist-stat.s-total .hs-val{color:var(--blue)}
.hist-stat.s-late .hs-fill{background:var(--amber)} .hist-stat.s-late .hs-val{color:var(--amber)}
.hist-stat.s-ok .hs-fill{background:var(--green)} .hist-stat.s-ok .hs-val{color:var(--green)}
.hist-stat.s-rej .hs-fill{background:var(--danger)} .hist-stat.s-rej .hs-val{color:var(--danger)}
@media(max-width:780px){.hist-stats{grid-template-columns:repeat(2,1fr)}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}
/* PATCH3:styles — refined order modal rows */
.mp-row{padding:11px 2px;border-bottom:1px solid var(--line2)}
.mp-row:last-child{border-bottom:0}
.mp-row:hover{background:#fcfaf6}
.mp-main{display:flex;align-items:center;gap:12px}
.mp-name{flex:1;min-width:0;font-weight:700;font-size:13.5px;color:var(--ink);line-height:1.35;overflow-wrap:anywhere}
.mp-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px 9px;margin-top:7px}
.mp-uom{font-size:11px;color:var(--muted);font-weight:600}
.mp-refs{display:flex;gap:5px;margin-left:auto}
.mp-row .stepper{flex:none}
.mp-meta .lf-late{font-size:10px;font-weight:800;color:var(--amber);background:rgba(243,156,18,.12);border-radius:999px;padding:2px 8px;white-space:nowrap}
/* PATCH4:styles — submitted category tiles */
.cat-card.done{border-color:var(--green);background:#f3fbf6}
.cat-card.done .cc-cnt{color:var(--green)}
.cat-card.done .cc-sub{color:var(--green);font-weight:700}
/* PATCH9:styles */
.mp-qty{min-width:64px;text-align:center;font-weight:800;font-size:16px;color:var(--ink)}
.mp-qty.z{color:var(--muted);font-weight:600}
.pend-badge{display:inline-flex;align-items:center;background:#FFF3DC;color:#B26A00;border:1px solid #F0C674;padding:1px 8px;border-radius:999px;font-weight:800;font-size:11px;line-height:1.7}

/*PATCH27:ui — produced stepper + collapsible consolidated*/
.qstep{display:inline-flex;align-items:stretch;border:1px solid var(--line);border-radius:10px;overflow:hidden;height:34px;background:#fff;box-shadow:0 1px 2px rgba(20,12,16,.06)}
.qstep .qbtn{border:0;background:var(--cream);color:var(--red-d);font-size:18px;font-weight:800;width:34px;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s ease,color .12s ease;user-select:none}
.qstep .qbtn:hover{background:#ffe3e6}
.qstep .qbtn:active{background:var(--red);color:#fff}
.qstep input{width:54px;text-align:center;border:0;border-left:1px solid var(--line);border-right:1px solid var(--line);height:32px;padding:0;font-size:14px;font-weight:800;color:var(--ink);background:#fff;-moz-appearance:textfield;appearance:textfield}
.qstep input:focus{outline:none;background:#fffaf0}
.qstep input::-webkit-outer-spin-button,.qstep input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.consol-h{cursor:pointer;user-select:none}
.consol-h .chev{display:inline-block;color:var(--muted);font-size:12px;margin-left:6px}

/*PATCH29:consol-stores — missed-store indicator*/
.nod{display:inline-block;color:var(--danger);font-size:9px;line-height:1;vertical-align:middle}
th.nod-h{color:var(--muted);font-weight:600}

/*P35:disp — enhanced Dispatch Records list*/
.disp-list .disp-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--line2)}
.disp-list .disp-title{font-family:"Fraunces",serif;font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px}
.disp-list .disp-title .chip{margin-left:2px}
.disp-list .disp-search{max-width:300px;flex:0 1 300px}
.disp-list .tbl tbody tr{transition:background .12s}
.disp-list .tbl tbody tr:hover{background:#FBF6EF}
.disp-list .sdot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:middle;box-shadow:0 0 0 2px rgba(0,0,0,.05)}
.disp-list .disp-dash{color:var(--muted)}

/*P36:store-email — Store Master email column*/
.st-mail{color:var(--red-d);text-decoration:none;font-weight:600}
.st-mail:hover{text-decoration:underline}
.st-dash{color:var(--muted)}

/*P37:alloc — Allocate & dispatch console*/
.alloc-back{position:fixed;inset:0;background:rgba(22,16,10,.44);z-index:1000;overflow:auto;padding:22px}
.alloc-shell{max-width:1480px;margin:0 auto}
.alloc-bar{display:flex;align-items:flex-end;gap:16px;background:linear-gradient(180deg,#FDF6E6,#FBEFD6);border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:16px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.alloc-bar .af{display:flex;flex-direction:column;gap:5px;min-width:160px}
.alloc-bar .af label{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.alloc-bar .af-done{font-size:13px;color:var(--ink);align-self:center;white-space:nowrap}
.alloc-x{background:#fff;border:1px solid var(--line);border-radius:10px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;align-self:center;color:var(--muted);flex:0 0 auto}
.alloc-x:hover{color:var(--red-d);border-color:var(--red-d)}
.alloc-cols{display:grid;grid-template-columns:1fr 430px;gap:16px;align-items:start}
.alloc-main,.alloc-side{padding:16px}
.alloc-h{font-family:"Fraunces",serif;font-weight:700;font-size:15px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.alloc-sub{font-size:11px;font-weight:500;color:var(--muted);font-family:inherit}
.alloc-main .alloc-q{width:66px;text-align:center;font-weight:700;padding:6px 6px}
.alloc-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.alloc-form .afld{display:flex;flex-direction:column;gap:5px}
.alloc-form .afld.afull{grid-column:1 / -1}
.alloc-form label{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.alloc-act{display:flex;justify-content:flex-end;margin-top:16px}
.tbl td.av0{color:var(--red);font-weight:800}
.alloc-gtbl .gst{color:var(--red-d);font-weight:700}
.alloc-gtbl tbody tr{cursor:pointer;transition:background .12s}
.alloc-gtbl tbody tr:hover{background:#FBF6EF}
.alloc-gtbl tbody tr.gsel{background:#FDF1E3}
.alloc-gtbl .gvar{color:#C8771A;font-weight:700}
@media(max-width:1000px){.alloc-cols{grid-template-columns:1fr}.alloc-bar{flex-wrap:wrap}.alloc-bar .af{min-width:140px}.alloc-form{grid-template-columns:1fr}}

/*P38:dap — Dispatch & allocate page*/
.dap-bar{background:linear-gradient(180deg,#FFF7F8,#FFEDEF);border:1px solid var(--line);border-radius:14px;padding:13px 16px;margin-bottom:16px;display:flex;align-items:flex-end;gap:16px;box-shadow:0 4px 16px rgba(150,15,40,.06)}
.dap-bar .fld{display:flex;flex-direction:column;gap:5px}
.dap-bar .fld label{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:5px}
.dap-bar .fld select{min-width:160px}
.dap-done{font-size:13px;color:var(--ink);align-self:center;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-weight:600;white-space:nowrap}
.dap-done b{color:var(--red-d)}
.dap-cols{display:grid;grid-template-columns:1fr 430px;gap:16px;align-items:start}
.dap-h{font-family:"Fraunces",serif;font-weight:700;font-size:15px;margin-bottom:12px}
.dap-main .qstep input{width:58px}
.tbl td.av0{color:var(--red);font-weight:800}
.tbl td.avok{color:var(--green);font-weight:700}
.dap-form{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-top:16px}
.dap-form .dapfld{display:flex;flex-direction:column;gap:5px}
.dap-form .dapfld.dapfull{grid-column:1 / -1}
.dap-form label{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.dap-act{display:flex;justify-content:flex-end;margin-top:16px}
.dap-gtbl .dap-st{color:var(--red-d);font-weight:700}
.dap-gtbl .dap-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:middle;box-shadow:0 0 0 2px rgba(0,0,0,.05)}
.dap-gtbl tbody tr{cursor:pointer;transition:background .12s}
.dap-gtbl tbody tr:hover{background:#FBF6EF}
.dap-gtbl tbody tr.sel{background:#FFF1F3}
.dap-gtbl .dap-var{color:#C8771A;font-weight:700}
@media(max-width:1000px){.dap-cols{grid-template-columns:1fr}.dap-bar{flex-wrap:wrap}.dap-form{grid-template-columns:1fr}}

/* ===== PATCH59 hygiene review + dispatch popup ===== */
.hy-back{position:fixed;inset:0;background:rgba(22,16,10,.46);z-index:1000;overflow:auto;padding:22px;display:flex;align-items:flex-start;justify-content:center}
.hy-panel{width:100%;max-width:880px;background:#fff;border-radius:16px;box-shadow:0 24px 70px rgba(40,20,30,.30);overflow:hidden;margin:0 auto}
.hy-bar{display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,#FBF5F6,#F4F1F5);border-bottom:1px solid var(--line2);padding:16px 20px}
.hy-title .hy-st{font-family:"Fraunces",serif;font-weight:700;font-size:18px;color:var(--ink)}
.hy-title .hy-sub{font-size:12px;color:var(--muted);margin-top:2px}
.hy-body{padding:6px 20px 2px}
.hy-qty{display:inline-block;min-width:50px;text-align:center;font-weight:800;color:var(--ink);background:#F4F1F5;border:1px solid var(--line2);border-radius:8px;padding:4px 10px}
.hy-act{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:14px 20px;border-top:1px solid var(--line2)}
.hy-relinfo{font-size:12px;color:var(--muted)}
.hy-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hy-form .hyfld{display:flex;flex-direction:column;gap:5px}
.hy-form .hyfld.hyfull{grid-column:1 / -1}
.hy-form label{font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
@media(max-width:620px){.hy-form{grid-template-columns:1fr}}

/* ===== patch106 — dispatch screen polish ===== */
.dap-main,.dap-side{border:1px solid var(--line);box-shadow:0 6px 22px rgba(150,15,40,.07)}
.dap-side .card-h{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.dap-side .card-h .hint{margin-left:auto;font-size:11px;color:var(--muted)}
.dap-main .tbl thead th{position:sticky;top:0;background:#fff;z-index:1}
.dap-main .tbl tbody tr:hover{background:#FBF6EF}
.dap-main .tbl td.dpi-av,.dap-main .tbl td.avok,.dap-main .tbl td.av0{font-weight:800;font-variant-numeric:tabular-nums}
.dap-gtbl .bi-i{cursor:pointer;transition:background .12s ease}
.dap-gtbl .bi-i td{padding-top:11px;padding-bottom:11px;border-bottom:1px solid var(--line)}
.dap-gtbl .bi-i td b{color:var(--ink);font-weight:700}
.dap-gtbl .bi-i:hover{background:#FBF6EF}
.dap-gtbl .bi-i.sel{background:#FFF1F3;box-shadow:inset 3px 0 0 var(--brand,#CB1142)}
.dap-gtbl .bi-i.sel td b{color:var(--red-d)}
.dap-gtbl .bi-tot{display:inline-block;min-width:30px;text-align:center;background:var(--cream);color:var(--red-d);border-radius:999px;padding:2px 9px;font-weight:800;font-size:12px}