/* Warehouse Condition Monitor — shared design system + app shell (sidebar + topbar).
   Light "operations console" look modelled on the reference layout. */
:root{
  --bg:#eef2f8; --surface:#fff; --surface-2:#f6f8fc; --line:#e6ebf3;
  --ink:#0f172a; --ink-2:#475569; --muted:#94a3b8;
  --brand:#4f46e5; --brand-2:#6366f1; --brand-soft:#eef0ff;
  --high:#e11d48; --high-soft:#fff1f3; --med:#d97706; --med-soft:#fff7ed;
  --ok:#059669; --ok-soft:#ecfdf5; --info:#0ea5e9; --info-soft:#e0f2fe;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 8px 24px rgba(16,24,40,.05);
  --radius:16px; --sidebar:248px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
.muted{color:var(--muted);}
[data-lucide]{width:1em;height:1em;stroke-width:2;vertical-align:-2px;}

/* ── App layout ─────────────────────────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh;}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar);background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;z-index:30;}
.sidebar .logo{display:flex;align-items:center;gap:11px;padding:6px 10px 18px;}
.sidebar .logo .mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));
  display:grid;place-items:center;color:#fff;box-shadow:0 6px 16px rgba(79,70,229,.35);}
.sidebar .logo .mark [data-lucide]{width:19px;height:19px;}
.sidebar .logo b{font-size:16px;font-weight:700;letter-spacing:-.2px;}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px;}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink-2);font-size:14px;font-weight:500;transition:background .12s,color .12s;}
.nav a [data-lucide]{width:18px;height:18px;color:var(--muted);}
.nav a:hover{background:var(--surface-2);color:var(--ink);}
.nav a.active{background:var(--brand-soft);color:var(--brand);font-weight:600;}
.nav a.active [data-lucide]{color:var(--brand);}
.sidebar .foot{margin-top:auto;}

.main{grid-column:2;display:flex;flex-direction:column;min-width:0;}
.topbar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:16px 30px;display:flex;align-items:center;gap:18px;}
.topbar h1{font-size:21px;font-weight:700;letter-spacing:-.3px;}
.topbar .sub{font-size:12.5px;color:var(--muted);margin-top:1px;}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.upd{font-size:13px;color:var(--ink-2);} .upd b{font-weight:700;}
.iconbtn{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);background:var(--surface);display:grid;place-items:center;
  color:var(--ink-2);cursor:pointer;position:relative;}
.iconbtn:hover{background:var(--surface-2);}
.iconbtn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--high);border:2px solid #fff;}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#c7d2fe,#a5b4fc);display:grid;place-items:center;
  color:var(--brand);font-weight:700;font-size:14px;border:1px solid var(--line);}
.content{padding:26px 30px 64px;max-width:1500px;width:100%;}

/* ── Buttons ────────────────────────────────────────────────── */
.btn{border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;border-radius:10px;padding:9px 15px;
  background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(79,70,229,.25);transition:transform .08s,filter .15s;display:inline-flex;align-items:center;gap:7px;}
.btn:hover{filter:brightness(1.07);} .btn:active{transform:translateY(1px);}
.btn.soft{background:var(--surface);color:var(--brand);border:1px solid var(--line);box-shadow:none;}
.btn.ghost{background:var(--surface);color:var(--ink-2);border:1px solid var(--line);box-shadow:none;}

/* ── Section titles ─────────────────────────────────────────── */
.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:34px;
  font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-2);margin:26px 2px 14px;}
.section-title:first-child{margin-top:6px;}
.section-title .controls{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-weight:500;}

/* ── Status / KPI cards (top row) ───────────────────────────── */
.statcards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
@media(max-width:1100px){.statcards{grid-template-columns:repeat(2,1fr);}}
.statcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:15px;}
.statcard .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:none;}
.statcard .ic [data-lucide]{width:22px;height:22px;}
.ic.brand{background:var(--brand-soft);color:var(--brand);} .ic.high{background:var(--high-soft);color:var(--high);}
.ic.ok{background:var(--ok-soft);color:var(--ok);} .ic.info{background:var(--info-soft);color:var(--info);} .ic.med{background:var(--med-soft);color:var(--med);}
.statcard .label{font-size:12.5px;color:var(--muted);font-weight:500;}
.statcard .value{font-size:26px;font-weight:800;letter-spacing:-1px;margin-top:2px;}
.statcard .value small{font-size:14px;font-weight:600;color:var(--muted);}

/* ── Generic card ───────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}
.card .hd{padding:17px 20px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.card .hd h3{font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:8px;}
.card .hd h3 [data-lucide]{width:16px;height:16px;color:var(--brand);}
.card .hd .sub{font-size:12px;color:var(--muted);margin-top:3px;font-weight:400;}
.card .bd{padding:16px 20px 20px;}

/* ── Rules strip ────────────────────────────────────────────── */
.rules-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);}
.rules-strip .lbl{font-size:12px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.5px;}
.rchip{font-size:12px;font-weight:600;padding:5px 11px;border-radius:8px;border:1px solid transparent;}
.rchip.high{background:var(--high-soft);color:var(--high);border-color:#fecdd3;}
.rchip.medium{background:var(--med-soft);color:var(--med);border-color:#fed7aa;}

/* ── Charts ─────────────────────────────────────────────────── */
.charts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:1100px){.charts{grid-template-columns:1fr;}}
.chart-box{height:200px;margin-top:8px;}
.metric-now{font-size:13px;font-weight:700;}

/* ── Services (alerts + digest) ─────────────────────────────── */
.services{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:1000px){.services{grid-template-columns:1fr;}}
.count-badge{font-size:12px;font-weight:800;padding:3px 10px;border-radius:20px;}
.count-badge.alarm{background:var(--high-soft);color:var(--high);} .count-badge.calm{background:var(--ok-soft);color:var(--ok);}
.alert-list{display:flex;flex-direction:column;gap:10px;max-height:520px;overflow:auto;padding-right:4px;}
.alert-row{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);}
.alert-row.high{background:var(--high-soft);border-color:#fecdd3;}
.alert-row .bar{width:4px;align-self:stretch;border-radius:4px;background:var(--muted);}
.alert-row.high .bar{background:var(--high);} .alert-row.medium .bar{background:var(--med);}
.alert-row .body{flex:1;min-width:0;} .alert-row .dev{font-weight:700;font-size:14px;}
.alert-row .rule{font-size:12.5px;color:var(--ink-2);margin-top:1px;} .alert-row .val{font-size:12px;color:var(--muted);margin-top:3px;}
.sev{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;padding:3px 8px;border-radius:6px;white-space:nowrap;}
.sev.high{background:var(--high);color:#fff;} .sev.medium{background:var(--med);color:#fff;}
.notif{display:none;align-items:center;gap:10px;background:var(--med-soft);border:1px solid #fed7aa;color:#b45309;border-radius:11px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:14px;}
.notif.show{display:flex;}
.dctl{display:flex;align-items:center;gap:9px;margin-bottom:12px;}

/* ── Forms ──────────────────────────────────────────────────── */
select,input{font-family:inherit;background:var(--surface);color:var(--ink);border:1px solid var(--line);
  padding:9px 12px;font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s;}
select:focus,input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft);}
input::placeholder{color:var(--muted);}
.search-wrap{position:relative;display:inline-flex;align-items:center;}
.search-wrap [data-lucide]{position:absolute;left:12px;width:16px;height:16px;color:var(--muted);pointer-events:none;}
.search-wrap input{padding-left:34px;min-width:240px;}

/* ── Tables ─────────────────────────────────────────────────── */
table{width:100%;border-collapse:collapse;}
th{text-align:left;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px;border-bottom:1px solid var(--line);}
td{font-size:13px;padding:10px 8px;border-bottom:1px solid var(--surface-2);}
.tag-open{color:var(--high);font-weight:700;} .tag-clear{color:var(--ok);font-weight:600;}
.empty{text-align:center;color:var(--muted);font-size:13px;padding:34px 0;}

/* ── Device list ────────────────────────────────────────────── */
.filters{display:flex;gap:11px;flex-wrap:wrap;align-items:center;margin-bottom:14px;}
.viewtog{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden;}
.vt{border:none;background:var(--surface);color:var(--ink-2);font:inherit;font-size:12.5px;font-weight:600;padding:7px 13px;cursor:pointer;}
.vt.on{background:var(--brand);color:#fff;}
.dlist{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;}
.dlist-head,.drow{display:grid;grid-template-columns:1.7fr 1.5fr .7fr .7fr .7fr 1.1fr 24px;gap:12px;align-items:center;padding:12px 18px;}
.dlist-head{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;background:var(--surface-2);border-bottom:1px solid var(--line);}
.drow{border-bottom:1px solid var(--surface-2);color:inherit;transition:background .1s;}
.drow:last-child{border-bottom:none;} .drow:hover{background:var(--surface-2);}
.drow.alert{box-shadow:inset 3px 0 0 var(--high);}
.drow .nm{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:9px;min-width:0;}
.drow .nm span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.drow .loc{font-size:12.5px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.drow .cv{font-size:14px;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;} .drow .cv.hot{color:var(--high);} .drow .cv.cold{color:var(--info);}
.drow .upd{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;}
.drow .chev{color:var(--brand);font-size:18px;font-weight:700;justify-self:end;}
.alert-tag{font-size:10px;font-weight:700;color:var(--high);background:var(--high-soft);border:1px solid #fecdd3;border-radius:6px;padding:2px 6px;}
.sdot{width:8px;height:8px;border-radius:50%;flex:none;}
.sdot.alert{background:var(--high);box-shadow:0 0 0 3px var(--high-soft);} .sdot.ok{background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft);}
@media(max-width:820px){.hide-sm{display:none !important;}.dlist-head,.drow{grid-template-columns:1.6fr .7fr .7fr .7fr 24px;}}

/* device cards (alt view) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px;}
.dcard{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);transition:transform .1s,box-shadow .15s;cursor:pointer;}
.dcard:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(16,24,40,.1);} .dcard.alert{border-color:#fecdd3;}
.dcard .dtop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:13px;}
.dcard .dname{font-weight:700;font-size:14px;display:flex;align-items:center;gap:7px;} .dcard .dloc{font-size:11.5px;color:var(--muted);margin-top:2px;padding-left:15px;}
.sensors{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;} .s{background:var(--surface-2);border-radius:10px;padding:9px 6px;text-align:center;}
.s label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:block;} .s .v{font-size:19px;font-weight:800;letter-spacing:-.5px;margin-top:3px;}
.s .v.hot{color:var(--high);} .s .v.cold{color:var(--info);}
.dpills{margin-top:11px;display:flex;flex-wrap:wrap;gap:5px;} .dpill{font-size:10px;font-weight:600;background:var(--high-soft);color:var(--high);border:1px solid #fecdd3;border-radius:6px;padding:3px 7px;}
.dupd{font-size:11px;color:var(--muted);margin-top:11px;}

/* ── Modal ──────────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(3px);z-index:60;align-items:center;justify-content:center;}
.overlay.show{display:flex;}
.modal{background:var(--surface);border-radius:18px;box-shadow:0 24px 60px rgba(16,24,40,.3);width:min(720px,94vw);max-height:88vh;overflow:auto;}
.modal-hd{padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);}
.modal-hd .row{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.modal-hd h3{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;}
.x-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:22px;line-height:1;}
.modal-bd{padding:10px 24px 22px;}

/* ── Shipments: route groups + roster ───────────────────────── */
.route{display:flex;align-items:center;flex-wrap:wrap;gap:7px;}
.node{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-weight:600;font-size:12.5px;}
.arrow{color:var(--muted);}
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap;}
.badge.ok{background:var(--ok-soft);color:var(--ok);} .badge.transit{background:var(--brand-soft);color:var(--brand);}
.badge.alert{background:var(--high-soft);color:var(--high);}
.rgroup{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden;}
.rg-head{display:flex;align-items:center;gap:12px;padding:15px 18px;cursor:pointer;user-select:none;}
.rg-head:hover{background:var(--surface-2);}
.rg-head .chev{transition:transform .15s;color:var(--muted);font-size:18px;}
.rgroup.open .rg-head .chev{transform:rotate(90deg);}
.rg-route{flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:7px;}
.rg-meta{font-size:12px;color:var(--muted);font-weight:600;white-space:nowrap;}
.rg-body{border-top:1px solid var(--line);} .rg-body[hidden]{display:none;}
.srow,.srow-head{display:grid;grid-template-columns:1.2fr .9fr .8fr 1.3fr 24px;gap:12px;align-items:center;padding:12px 18px;}
.srow{border-bottom:1px solid var(--surface-2);cursor:pointer;}
.srow:last-child{border-bottom:none;} .srow:hover{background:var(--surface-2);}
.srow .sid{font-family:ui-monospace,Menlo,monospace;font-weight:700;font-size:13px;}
.srow .when{font-size:12px;color:var(--muted);}
.srow .chev{color:var(--brand);font-size:18px;font-weight:700;justify-self:end;}
.srow-head{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;background:var(--surface-2);}
.devchip{display:inline-flex;align-items:center;gap:6px;background:var(--brand-soft);color:var(--brand);font-weight:700;font-size:12px;padding:5px 10px;border-radius:8px;}
.drow-modal{display:flex;align-items:center;gap:12px;padding:13px 4px;border-bottom:1px solid var(--surface-2);color:inherit;}
.drow-modal:hover{background:var(--surface-2);border-radius:10px;}
.drow-modal .nm{font-weight:700;font-size:13.5px;} .drow-modal .id{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;}
.drow-modal .m{font-size:12.5px;color:var(--ink-2);min-width:64px;text-align:right;} .drow-modal .go{color:var(--brand);font-weight:600;font-size:12px;}

::-webkit-scrollbar{width:9px;height:9px;}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9px;}
@media(max-width:760px){.app{grid-template-columns:1fr;}.sidebar{display:none;}.main{grid-column:1;}}

/* ── Warehouse setup ────────────────────────────────────────── */
.crumbs{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:16px;}
.crumbs a{color:var(--brand);font-weight:600;cursor:pointer;} .crumbs .sep{color:var(--muted);}
.crumbs .cur{color:var(--ink);font-weight:700;}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.tile{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);padding:18px;cursor:pointer;transition:transform .1s,box-shadow .15s,border-color .15s;position:relative;}
.tile:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(16,24,40,.1);border-color:#c7cdfb;}
.tile .tic{width:42px;height:42px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand);margin-bottom:12px;}
.tile .tname{font-weight:700;font-size:15px;} .tile .tmeta{font-size:12.5px;color:var(--muted);margin-top:4px;}
.tile .del{position:absolute;top:12px;right:12px;border:none;background:none;color:var(--muted);cursor:pointer;opacity:0;transition:opacity .1s;}
.tile:hover .del{opacity:1;} .tile .del:hover{color:var(--high);}
.tile.add{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border-style:dashed;color:var(--brand);background:var(--surface-2);min-height:120px;}
.addform{display:flex;flex-direction:column;gap:10px;width:100%;}
.addform input{width:100%;}
.row-inline{display:flex;gap:8px;} .row-inline input{flex:1;min-width:0;}
.weather{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.weather .big{font-size:40px;font-weight:800;letter-spacing:-1.5px;}
.weather .cond{font-size:14px;color:var(--ink-2);font-weight:600;}
.wx-grid{display:flex;gap:22px;flex-wrap:wrap;} .wx-grid .m label{font-size:10px;color:var(--muted);text-transform:uppercase;display:block;} .wx-grid .m .v{font-size:17px;font-weight:700;}
.fcast{display:flex;gap:10px;margin-top:6px;} .fcast .d{background:var(--surface-2);border:1px solid var(--line);padding:8px 12px;text-align:center;font-size:12px;min-width:74px;}
.fcast .d b{display:block;font-size:13px;}
.loc-row{display:grid;grid-template-columns:1.5fr 1.3fr 1.2fr .7fr .7fr .9fr 28px;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--surface-2);}
.loc-row:last-child{border-bottom:none;} .loc-head{background:var(--surface-2);font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;}
.loc-row .lname{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:9px;}
.loc-row .dev{font-size:12.5px;color:var(--ink-2);} .loc-row .cv{font-weight:700;} .loc-row .cv.hot{color:var(--high);} .loc-row .cv.cold{color:var(--info);}
.loc-row .del{border:none;background:none;color:var(--muted);cursor:pointer;justify-self:end;} .loc-row .del:hover{color:var(--high);}
.loc-add{display:flex;gap:10px;align-items:center;padding:14px 16px;background:var(--surface-2);border-top:1px solid var(--line);flex-wrap:wrap;}
.loc-add input,.loc-add select{flex:1;min-width:140px;} .loc-add .btn{flex:none;}

/* ── Masters: risk chips, threshold band preview, form grid, priority picker ── */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;text-transform:capitalize;}
.chip.low{background:var(--ok-soft);color:var(--ok);} .chip.medium{background:var(--med-soft);color:var(--med);}
.chip.high{background:#fff1e8;color:#c2410c;} .chip.critical{background:var(--high-soft);color:var(--high);}
.chip.p1{background:var(--high-soft);color:var(--high);} .chip.p2{background:#fff1e8;color:#c2410c;}
.chip.p3{background:var(--med-soft);color:var(--med);} .chip.p4{background:var(--surface-2);color:var(--ink-2);}
.chip.cat{background:var(--brand-soft);color:var(--brand);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid .full{grid-column:1/-1;}
.fld{display:flex;flex-direction:column;gap:5px;} .fld label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;}
.fld input,.fld select,.fld textarea{width:100%;}
.band-bar{display:flex;height:30px;border:1px solid var(--line);overflow:hidden;font-size:10px;font-weight:700;color:#fff;}
.band-bar .seg{display:flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;}
.band-bar .crit{background:var(--high);} .band-bar .warn{background:var(--med);} .band-bar .opt{background:var(--ok);}
.seg-pick{display:inline-flex;border:1px solid var(--line);overflow:hidden;}
.seg-pick button{border:none;background:var(--surface);padding:7px 14px;font-weight:700;font-size:12px;cursor:pointer;color:var(--ink-2);border-right:1px solid var(--line);}
.seg-pick button:last-child{border-right:none;} .seg-pick button.on{background:var(--brand);color:#fff;}
.tbl{width:100%;border-collapse:collapse;} .tbl th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);text-align:left;padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--line);}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--surface-2);font-size:13.5px;} .tbl tr:last-child td{border-bottom:none;}
.tbl tr.click{cursor:pointer;} .tbl tr.click:hover td{background:var(--surface-2);}
.drawer-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px;padding:16px 0 2px;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--surface);}
/* refined commodity drawer */
.modal-hd .m-sub{font-size:12.5px;color:var(--muted);margin-top:4px;}
.drawer-section{background:var(--surface-2);border:1px solid var(--line);padding:16px 16px 4px;margin-bottom:14px;}
.drawer-section .ds-head{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-2);margin-bottom:14px;}
.drawer-section .ds-head [data-lucide]{width:15px;height:15px;color:var(--brand);}
.drawer-section .ds-hint{margin-left:auto;font-size:11px;font-weight:700;color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:2px 8px;}
.form-grid.four{grid-template-columns:repeat(4,1fr);}
.fld input,.fld select,.fld textarea{padding:9px 11px;background:var(--surface);}
.chk{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--ink);text-transform:none;letter-spacing:0;background:var(--surface);border:1px solid var(--line);padding:10px 12px;cursor:pointer;}
.chk input{width:auto;margin:0;}
.band-bar{height:34px;}
.band-cap{display:flex;justify-content:space-between;font-size:10.5px;color:var(--muted);font-weight:600;margin:5px 2px 0;}
@media(max-width:620px){.form-grid,.form-grid.four{grid-template-columns:1fr 1fr;}}
/* polished add tiles */
.tile.add .addform input{width:100%;}
.tile.add .btn{width:100%;justify-content:center;}

/* ── Squared theme: remove all rounded corners everywhere ───── */
*,*::before,*::after{border-radius:0 !important;}
