/* ===========================================================================
   JDT Tender & Pricing Console — "Clean Technical" enterprise design system
   Flat 2.0, 1px borders, tabular numerals, light + dark via CSS variables.
   ======================================================================== */
/* Brand: JD Refrigerated Transport — azure accent + navy, on cool neutrals. */
:root{
  --bg:#FFFFFF; --surface:#F5F9FC; --surface-2:#EAF1F7; --raised:#FFFFFF;
  --border:#DBE6EE; --border-strong:#C1D2DE;
  --text:#16273A; --text-2:#496279; --text-3:#8EA3B5;
  --primary:#0B7CAC; --primary-hover:#096A93; --primary-weak:#E6F4FB; --on-primary:#FFFFFF;
  --accent:#1BA3DD; --navy:#26395B;
  --go:#059669; --go-bg:#ECFDF5; --review:#B45309; --review-bg:#FFFBEB; --nogo:#DC2626; --nogo-bg:#FEF2F2;
  --input-bg:#FEFBEA; --input-border:#F1DE9A;
  --st-draft:#64748B; --st-submitted:#2F77C2; --st-shortlisted:#7C3AED; --st-won:#059669; --st-lost:#DC2626; --st-nobid:#94A3B8;
  --ring:rgba(27,163,221,.38);
  --sb-w:248px; --top-h:56px;
  --r-lg:8px; --r-md:6px; --r-sm:4px;
}
html[data-theme="dark"]{
  --bg:#0C1B2C; --surface:#0A1826; --surface-2:#13273A; --raised:#0F2234;
  --border:#203850; --border-strong:#34526E;
  --text:#E5EEF5; --text-2:#9DB1C2; --text-3:#637789;
  --primary:#179AD2; --primary-hover:#36AFE0; --primary-weak:#0B2E42; --on-primary:#FFFFFF;
  --accent:#3DB5E6; --navy:#1A2C46;
  --go:#34D399; --go-bg:#06281F; --review:#FBBF24; --review-bg:#2A2008; --nogo:#F87171; --nogo-bg:#2A1212;
  --input-bg:#15263A; --input-border:#33506C;
  --st-draft:#94A3B8; --st-submitted:#4FA0E6; --st-shortlisted:#A78BFA; --st-won:#34D399; --st-lost:#F87171; --st-nobid:#637789;
  --ring:rgba(61,181,230,.45);
}

*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;height:100%}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  font-size:13px; color:var(--text); background:var(--bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.ico{width:18px;height:18px;flex:none;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
kbd{font-family:inherit;font-size:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:1px 6px;color:var(--text-2)}

/* layout shell ----------------------------------------------------------- */
#app{display:grid;grid-template-columns:var(--sb-w) 1fr;height:100vh;overflow:hidden}
body.sb-collapsed{--sb-w:64px}

/* sidebar ---------------------------------------------------------------- */
#sidebar{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}
.sb-head{display:flex;align-items:center;justify-content:space-between;height:var(--top-h);padding:0 12px 0 16px;border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.logo{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--accent),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;letter-spacing:.5px;flex:none}
.brand-logo{width:34px;height:34px;object-fit:contain;flex:none}

/* launch splash ---------------------------------------------------------- */
.splash{position:fixed;inset:0;z-index:300;background:#fff;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease}
.splash.hide{opacity:0;pointer-events:none}
.splash-inner{display:flex;flex-direction:column;align-items:center;gap:16px;animation:splashIn .6s ease both}
.splash-logo{width:320px;max-width:64vw;height:auto}
.splash-tag{font-size:14px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#26395B}
@keyframes splashIn{from{opacity:0;filter:blur(12px);transform:scale(1.03)}to{opacity:1;filter:blur(0);transform:none}}
.brand-text{min-width:0}
.brand-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-sub{font-size:11px;color:var(--text-3);white-space:nowrap}
body.sb-collapsed .brand-text,body.sb-collapsed .sb-group,body.sb-collapsed .sb-item span,body.sb-collapsed .sb-foot{display:none}
body.sb-collapsed .sb-head{padding:0;justify-content:center}
body.sb-collapsed #sbCollapse{transform:rotate(180deg)}

.sb-nav{flex:1;overflow-y:auto;padding:8px}
.sb-group{font-size:10.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-3);padding:14px 10px 5px}
.sb-item{display:flex;align-items:center;gap:10px;width:100%;border:0;background:transparent;color:var(--text-2);
  padding:7px 10px;border-radius:var(--r-md);cursor:pointer;font-size:13px;font-weight:500;text-align:left;font-family:inherit}
.sb-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-item:hover{background:var(--surface-2);color:var(--text)}
.sb-item.active{background:var(--primary-weak);color:var(--primary);font-weight:600}
html[data-theme="dark"] .sb-item.active{color:var(--accent)}
.sb-item.active .ico{stroke:var(--primary)}
html[data-theme="dark"] .sb-item.active .ico{stroke:var(--accent)}
body.sb-collapsed .sb-item{justify-content:center;padding:9px 0}
.sb-foot{border-top:1px solid var(--border);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.save-state{font-size:11.5px;color:var(--text-3)}
.save-state.dirty{color:var(--review)}
.sb-reset{border:0;background:transparent;color:var(--text-3);cursor:pointer;font-size:11.5px;font-family:inherit}
.sb-reset:hover{color:var(--nogo)}

/* topbar ----------------------------------------------------------------- */
#content{display:grid;grid-template-rows:var(--top-h) 1fr;min-width:0;overflow:hidden}
#topbar{display:flex;align-items:center;gap:14px;padding:0 16px;border-bottom:1px solid var(--border);background:var(--bg)}
.search{display:flex;align-items:center;gap:9px;flex:0 1 420px;height:34px;padding:0 10px;border:1px solid var(--border);
  border-radius:var(--r-md);background:var(--surface);color:var(--text-3);cursor:text;font-size:13px;font-family:inherit}
.search:hover{border-color:var(--border-strong)}
.search span{flex:1;text-align:left}
.search kbd{margin-left:auto}
.top-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid transparent;
  background:transparent;color:var(--text-2);border-radius:var(--r-md);cursor:pointer}
.icon-btn:hover{background:var(--surface-2);color:var(--text)}
#sbCollapse{width:28px;height:28px}
.has-dot .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--nogo);border:1.5px solid var(--bg)}
.profile{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--primary-weak);color:var(--primary);
  font-weight:600;font-size:12px;cursor:pointer}
html[data-theme="dark"] .profile{color:var(--accent)}
.ico-moon{display:none}
html[data-theme="dark"] .ico-sun{display:none}
html[data-theme="dark"] .ico-moon{display:block}

/* buttons ---------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;border:1px solid var(--border);background:var(--bg);
  color:var(--text);border-radius:var(--r-sm);cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;white-space:nowrap}
.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}
.btn .ico{width:16px;height:16px}
.btn-primary{background:var(--primary);border-color:var(--primary);color:var(--on-primary)}
.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}
.btn-ghost{background:transparent}
.btn-sm{height:28px;padding:0 9px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* dropdown --------------------------------------------------------------- */
.dropdown{position:relative}
.dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--raised);border:1px solid var(--border);
  border-radius:var(--r-md);box-shadow:0 8px 24px rgba(15,23,42,.12);padding:5px;min-width:215px;display:none;z-index:40}
.dropdown.open .dropdown-menu{display:block}
.dropdown-menu button{display:block;width:100%;text-align:left;border:0;background:transparent;color:var(--text);
  padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;font-size:12.5px;font-family:inherit}
.dropdown-menu button:hover{background:var(--surface-2)}
.dropdown-sep{height:1px;background:var(--border);margin:5px 4px}

/* views ------------------------------------------------------------------ */
#views{overflow-y:auto;padding:22px 24px 40px}
.view{display:none;animation:fade .12s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0}to{opacity:1}}
.view-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:18px}
h1{font-size:19px;font-weight:600;letter-spacing:-.01em;margin:0 0 3px}
.sub{color:var(--text-2);margin:0;font-size:13px}
.view-tools{display:flex;gap:8px;align-items:center}
.field{height:34px;padding:0 11px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);
  font-size:13px;font-family:inherit;min-width:200px}
.field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}

/* segmented status filter ----------------------------------------------- */
.seg{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface)}
.seg button{border:0;background:transparent;color:var(--text-2);padding:7px 11px;font-size:12px;cursor:pointer;font-family:inherit;border-right:1px solid var(--border)}
.seg button:last-child{border-right:0}
.seg button:hover{background:var(--surface-2);color:var(--text)}
.seg button.on{background:var(--primary);color:#fff}

/* stat strip (KPI cards) ------------------------------------------------- */
.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:13px 15px}
.kpi .k{font-size:11.5px;color:var(--text-2);font-weight:500}
.kpi .v{font-size:22px;font-weight:600;letter-spacing:-.02em;margin-top:3px;font-variant-numeric:tabular-nums}
.kpi .s{font-size:11px;color:var(--text-3);margin-top:2px}
.kpi.good .v{color:var(--go)}
.kpi.warn{background:var(--review-bg);border-color:color-mix(in srgb,var(--review) 35%,transparent)}
.kpi.warn .v{color:var(--review)}
.kpi.bad{background:var(--nogo-bg);border-color:color-mix(in srgb,var(--nogo) 35%,transparent)}
.kpi.bad .v{color:var(--nogo)}

/* data grid (tenders) ---------------------------------------------------- */
.grid-wrap{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--raised);overflow:auto}
.grid-wrap.tall{max-height:calc(100vh - 230px)}
table.dgrid{border-collapse:collapse;width:100%;font-size:12.5px}
table.dgrid th,table.dgrid td{padding:0 12px;height:40px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
table.dgrid thead th{position:sticky;top:0;z-index:2;background:var(--surface);color:var(--text-2);font-weight:600;font-size:11.5px;
  text-transform:uppercase;letter-spacing:.3px;cursor:pointer;user-select:none}
table.dgrid thead th .sort{color:var(--text-3);margin-left:4px;font-size:10px}
table.dgrid td.num,table.dgrid th.num{text-align:right;font-variant-numeric:tabular-nums}
table.dgrid tbody tr{cursor:pointer}
table.dgrid tbody tr:hover{background:var(--surface)}
table.dgrid tbody tr.sel{background:var(--primary-weak)}
table.dgrid tbody tr.sel td:first-child{box-shadow:inset 2px 0 0 var(--primary)}
.exp{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--text-3)}
.exp:hover{background:var(--surface-2);color:var(--text)}
tr.expanded .exp{transform:rotate(90deg)}
.row-actions{display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .1s}
tr:hover .row-actions{opacity:1}
.row-actions button{border:1px solid var(--border);background:var(--bg);color:var(--text-2);border-radius:var(--r-sm);
  padding:3px 8px;font-size:11px;cursor:pointer;font-family:inherit}
.row-actions button:hover{background:var(--surface-2);color:var(--text)}
.row-actions .award:hover{color:var(--go);border-color:var(--go)}
.row-actions .reject:hover{color:var(--nogo);border-color:var(--nogo)}
.subrow td{background:var(--surface);padding:0;border-bottom:1px solid var(--border)}
.subrow .bids-inline{padding:10px 14px 12px 46px}
.bids-inline table{width:100%;border-collapse:collapse;font-size:12px}
.bids-inline th{text-align:left;color:var(--text-3);font-weight:600;font-size:11px;padding:3px 8px;text-transform:uppercase}
.bids-inline td{padding:4px 8px;border-top:1px solid var(--border)}

/* status + decision badges ---------------------------------------------- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600;line-height:1.5}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.bg-Draft{color:var(--st-draft);background:color-mix(in srgb,var(--st-draft) 14%,transparent)}
.bg-Submitted{color:var(--st-submitted);background:color-mix(in srgb,var(--st-submitted) 14%,transparent)}
.bg-Shortlisted{color:var(--st-shortlisted);background:color-mix(in srgb,var(--st-shortlisted) 14%,transparent)}
.bg-Won{color:var(--st-won);background:color-mix(in srgb,var(--st-won) 16%,transparent)}
.bg-Lost{color:var(--st-lost);background:color-mix(in srgb,var(--st-lost) 14%,transparent)}
.bg-Nobid{color:var(--st-nobid);background:color-mix(in srgb,var(--st-nobid) 14%,transparent)}
.bg-Compliant{color:var(--go);background:var(--go-bg)}
.bg-Due{color:var(--review);background:var(--review-bg)}
.bg-Overdue{color:var(--nogo);background:var(--nogo-bg)}
.bg-NA{color:var(--text-3);background:var(--surface-2)}
.bg-Pending{color:var(--st-submitted);background:color-mix(in srgb,var(--st-submitted) 14%,transparent)}
.bg-Awarded{color:var(--go);background:var(--go-bg)}
.bg-Rejected{color:var(--nogo);background:var(--nogo-bg)}
.due-soon{color:var(--review);font-weight:600}
.due-overdue{color:var(--nogo);font-weight:600}

/* analysis cards --------------------------------------------------------- */
.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.card{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}
.card-h{font-size:13px;font-weight:600;margin-bottom:14px}
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:96px 1fr 64px;align-items:center;gap:10px;font-size:12px}
.bar-row .lbl{color:var(--text-2)}
.bar-track{height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:var(--primary)}
.bar-row .val{text-align:right;font-variant-numeric:tabular-nums;color:var(--text)}
.kv{display:grid;grid-template-columns:1fr auto;gap:9px 14px;margin:0}
.kv dt{color:var(--text-2)}
.kv dd{margin:0;text-align:right;font-weight:600;font-variant-numeric:tabular-nums}

/* settings / pricing cards ---------------------------------------------- */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.settings-grid.compact{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));margin-bottom:16px}
.setbox{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}
.setbox h3{margin:0 0 13px;font-size:13px;font-weight:600}
.setbox h3 small{color:var(--text-3);font-weight:400}
.setbox label{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:9px;font-size:12.5px;color:var(--text-2)}
.setbox input,.setbox select{width:130px;height:32px;padding:0 9px;border:1px solid var(--input-border);background:var(--input-bg);
  color:var(--text);border-radius:var(--r-sm);text-align:right;font-size:12.5px;font-family:inherit;font-variant-numeric:tabular-nums}
.setbox select{text-align:left}
.setbox input:focus,.setbox select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}
.setbox label.calc output{font-weight:700;color:var(--primary);font-size:15px;font-variant-numeric:tabular-nums}
html[data-theme="dark"] .setbox label.calc output{color:var(--accent)}
.setbox.engine ul{margin:0;padding-left:16px;color:var(--text-2);line-height:1.7;font-size:12px}

/* spreadsheet grids (lanes/warehousing/leg/carrier/compliance) ----------- */
table.grid{border-collapse:collapse;width:max-content;min-width:100%;font-size:12.5px;white-space:nowrap;font-variant-numeric:tabular-nums}
table.grid th,table.grid td{padding:6px 10px;border-bottom:1px solid var(--border);text-align:right;height:36px}
table.grid thead th{position:sticky;top:0;background:var(--surface);color:var(--text-2);z-index:2;font-weight:600;font-size:11px;
  text-transform:uppercase;letter-spacing:.3px;text-align:right}
table.grid thead th.in{color:var(--text)}
table.grid thead th:nth-child(1),table.grid thead th:nth-child(2),table.grid thead th:nth-child(3){text-align:left}
table.grid td:first-child,table.grid td.txt{text-align:left}
table.grid tbody tr:hover{background:var(--surface)}
table.grid input,table.grid select{width:74px;height:30px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);
  border-radius:var(--r-sm);padding:0 7px;text-align:right;font-size:12.5px;font-family:inherit;font-variant-numeric:tabular-nums}
table.grid input:focus,table.grid select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--ring)}
table.grid input.txt{width:150px;text-align:left}
table.grid select{width:100px;text-align:left}
table.grid td.calc{color:var(--text);padding-left:14px}
table.grid tfoot th{background:var(--surface-2);position:sticky;bottom:0}
.cell-dec{font-weight:700}
.dec-GO{color:var(--go)}.dec-REVIEW{color:var(--review)}.dec-NO-GO{color:var(--nogo)}
tr.row-GO td.calc{background:var(--go-bg)}
tr.row-REVIEW td.calc{background:var(--review-bg)}
tr.row-NO-GO td.calc{background:var(--nogo-bg)}
.qflag{text-align:center!important;text-transform:uppercase}
.rowdel{border:0;background:transparent;color:var(--text-3);cursor:pointer;font-size:15px;padding:0 4px}
.rowdel:hover{color:var(--nogo)}
.empty{color:var(--text-3);font-style:italic;padding:10px}

/* pricing grids (lanes/warehousing/leg) — filled-cell inputs, aligned columns */
table.pgrid{border-collapse:collapse;width:100%;min-width:100%;table-layout:fixed;font-size:12.5px;font-variant-numeric:tabular-nums}
table.pgrid th{height:36px;padding:0 10px;background:var(--surface);color:var(--text-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px;text-align:right;position:sticky;top:0;z-index:2;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
table.pgrid th.l{text-align:left}
table.pgrid td{height:36px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:right;padding:0;overflow:hidden}
table.pgrid td:last-child{border-right:0}
table.pgrid td.calc{padding:0 10px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
table.pgrid td.txt{text-align:left}
table.pgrid input,table.pgrid select{width:100%;height:35px;border:0;background:var(--input-bg);color:var(--text);padding:0 9px;text-align:right;font-family:inherit;font-size:12.5px;font-variant-numeric:tabular-nums;border-radius:0}
table.pgrid td.txt input,table.pgrid select{text-align:left}
table.pgrid select{cursor:pointer}
table.pgrid input:focus,table.pgrid select:focus{outline:2px solid var(--primary);outline-offset:-2px;background:var(--bg)}
table.pgrid tbody tr:hover td.calc{background:var(--surface)}
table.pgrid .rowdel{width:100%;height:35px;padding:0}
table.pgrid .rowdel:hover{background:var(--nogo-bg)}
table.pgrid tfoot th{background:var(--surface-2);position:sticky;bottom:0;text-align:right;border-top:1px solid var(--border)}
table.pgrid tfoot th.l{text-align:left}
#lanesTable{min-width:1880px}
#whTable{min-width:1440px}
#legTable{min-width:100%}

/* leg builder ------------------------------------------------------------ */
.leg-row{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:16px;margin-bottom:16px;align-items:start}
@media(max-width:980px){.leg-row{grid-template-columns:1fr}}

/* summary ---------------------------------------------------------------- */
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.sumcard{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px}
.sumcard.combined{background:var(--navy);color:#fff;border-color:var(--navy)}
html[data-theme="dark"] .sumcard.combined{border-color:var(--border)}
.sumcard h3{margin:0 0 12px;font-size:13px;font-weight:600}
.sumcard dl{display:grid;grid-template-columns:1fr auto;gap:9px 12px;margin:0}
.sumcard dt{color:var(--text-2)}
.sumcard.combined dt{color:rgba(255,255,255,.8)}
.sumcard dd{margin:0;text-align:right;font-weight:600;font-variant-numeric:tabular-nums}

/* quote ------------------------------------------------------------------ */
.quote-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;background:var(--raised);
  border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;margin-bottom:16px}
.quote-meta label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--text-2);font-weight:500}
.quote-meta input{height:34px;padding:0 10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:var(--r-sm);font-size:13px;font-family:inherit}
.qsection{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:16px}
.qsection h3{margin:0 0 10px;font-size:13px;font-weight:600}
.qsection table{width:100%;border-collapse:collapse;font-size:12.5px;font-variant-numeric:tabular-nums}
.qsection th,.qsection td{padding:7px 8px;border-bottom:1px solid var(--border);text-align:right}
.qsection th{color:var(--text-2);font-weight:600}
.qsection th:first-child,.qsection td:first-child{text-align:left}
.qsection tfoot td{font-weight:700;border-top:2px solid var(--border-strong);border-bottom:0}
.qtotal{font-size:16px;background:var(--navy);color:#fff;border-radius:var(--r-lg);padding:16px 18px;display:flex;justify-content:space-between;align-items:center;font-variant-numeric:tabular-nums}
html[data-theme="dark"] .qtotal{border:1px solid var(--border)}
.qtotal b{font-size:20px}

/* empty state ------------------------------------------------------------ */
.empty-state{text-align:center;padding:60px 20px;border:1px dashed var(--border-strong);border-radius:var(--r-lg);background:var(--surface);margin-top:16px}
.empty-state .es-icon{font-size:34px;color:var(--text-3)}
.empty-state h3{margin:10px 0 4px;font-size:15px}
.empty-state p{color:var(--text-2);max-width:440px;margin:0 auto 16px}

/* reports ---------------------------------------------------------------- */
.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.report-card{background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;cursor:pointer;display:flex;flex-direction:column;gap:6px}
.report-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}
.report-card .rc-ico{width:34px;height:34px;border-radius:var(--r-md);background:var(--primary-weak);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:4px}
html[data-theme="dark"] .report-card .rc-ico{color:var(--accent)}
.report-card h3{margin:0;font-size:13.5px;font-weight:600}
.report-card p{margin:0;color:var(--text-2);font-size:12px}
.report-card .tag{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-3)}

/* contextual detail panel ------------------------------------------------ */
.scrim{position:fixed;inset:0;background:rgba(15,23,42,.32);z-index:45}
.ctx{position:fixed;top:0;right:0;height:100vh;width:420px;max-width:92vw;background:var(--bg);border-left:1px solid var(--border);
  transform:translateX(100%);transition:transform .18s ease;z-index:46;display:flex;flex-direction:column;overflow:hidden}
.ctx.open{transform:translateX(0);box-shadow:-12px 0 40px rgba(15,23,42,.14)}
.ctx-head{display:flex;align-items:flex-start;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}
.ctx-head .ref{font-size:11.5px;color:var(--text-3);font-weight:600}
.ctx-head h2{margin:2px 0 6px;font-size:16px;font-weight:600}
.ctx-body{flex:1;overflow-y:auto;padding:18px}
.ctx-sec{margin-bottom:20px}
.ctx-sec h4{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin:0 0 10px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fgrid label{display:flex;flex-direction:column;gap:4px;font-size:11.5px;color:var(--text-2);font-weight:500}
.fgrid label.full{grid-column:1/-1}
.fgrid input,.fgrid select,.fgrid textarea{height:32px;padding:0 9px;border:1px solid var(--input-border);background:var(--input-bg);
  color:var(--text);border-radius:var(--r-sm);font-size:12.5px;font-family:inherit}
.fgrid textarea{height:auto;padding:7px 9px;resize:vertical;min-height:52px}
.fgrid input:focus,.fgrid select:focus,.fgrid textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--ring)}
#ctxMap{height:180px;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface-2);position:relative}
#ctxMap .map-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-3);font-size:12px;text-align:center;padding:14px}
.route-chip{display:flex;align-items:center;gap:8px;font-size:12.5px;margin-bottom:10px}
.route-chip .dot2{width:8px;height:8px;border-radius:50%;background:var(--primary)}
.route-chip .line{flex:1;height:1px;background:var(--border-strong);position:relative}
.bidlist{display:flex;flex-direction:column;gap:7px}
.bidrow{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;align-items:center;border:1px solid var(--border);border-radius:var(--r-md);padding:8px 10px;font-size:12px}
.bidrow input,.bidrow select{height:28px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:var(--r-sm);font-size:12px;font-family:inherit;padding:0 7px}
.bidrow .bcar{width:100%}
.bidrow .bamt{width:88px;text-align:right;font-variant-numeric:tabular-nums}
.ctx-foot{border-top:1px solid var(--border);padding:12px 18px;display:flex;gap:8px;flex-wrap:wrap}

/* tender workspace ------------------------------------------------------- */
.tw-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.tw-title{flex:1;min-width:0}
.tw-title .ref{font-size:11px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.tw-title h1{margin:3px 0 0}
.tw-head-actions{display:flex;gap:8px;align-items:center}
.tw-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin:18px 0 20px;overflow-x:auto}
.tw-tabs button{border:0;background:transparent;color:var(--text-2);padding:10px 14px;font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;font-family:inherit;margin-bottom:-1px}
.tw-tabs button:hover{color:var(--text)}
.tw-tabs button.on{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
html[data-theme="dark"] .tw-tabs button.on{color:var(--accent);border-bottom-color:var(--accent)}

/* panes & cards */
.tw-pane{max-width:1180px}
.tw-pane-narrow{max-width:760px}

/* per-tonne (banded $/t) section */
.pt-toggle{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.pt-mbtn{flex:1 1 280px;display:flex;flex-direction:column;gap:3px;text-align:left;padding:11px 14px;
  border:1px solid var(--border);border-radius:var(--r-lg);background:var(--raised);color:var(--text-2);cursor:pointer;font-family:inherit}
.pt-mbtn:hover{border-color:var(--border-strong);background:var(--surface)}
.pt-mbtn b{font-size:13px;color:var(--text);font-weight:600}
.pt-mbtn span{font-size:11.5px;color:var(--text-3)}
.pt-mbtn.on{border-color:var(--primary);background:var(--primary-weak)}
.pt-mbtn.on b{color:var(--primary)}
.pt-strip{margin-bottom:18px}
.pt-floor{display:inline-flex;padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600;color:var(--review);background:var(--review-bg)}
.pt-bite{display:inline-flex;padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600;color:var(--go);background:var(--go-bg)}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.ai-out{margin-top:4px}
.ai-busy{color:var(--text-2);font-size:13px;padding:10px 2px}
.ai-busy::before{content:"";display:inline-block;width:12px;height:12px;margin-right:8px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;vertical-align:-2px;animation:ai-spin .7s linear infinite}
@keyframes ai-spin{to{transform:rotate(360deg)}}
.ai-err{color:var(--nogo);background:var(--nogo-bg);border:1px solid var(--nogo);border-radius:var(--r-md);padding:10px 12px;font-size:12.5px}
.ai-md{font-size:13px;color:var(--text);line-height:1.55}
.ai-md h4{font-size:13.5px;margin:14px 0 6px}
.ai-md h4:first-child{margin-top:2px}
.ai-md p{margin:6px 0}
.ai-md ul{margin:6px 0;padding-left:20px}
.ai-md li{margin:3px 0}
.ai-md code{background:var(--surface-2);border-radius:var(--r-sm);padding:1px 5px;font-size:12px}
.ai-foot{margin-top:12px;padding-top:10px;border-top:1px solid var(--border);font-size:11px;color:var(--text-3)}

/* AI Analysis view */
.aia-drop{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px;border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);background:var(--surface);color:var(--text-2);font-size:13px;text-align:center}
.aia-drop.over{border-color:var(--primary);background:var(--primary-weak);color:var(--primary)}
.aia-dropico{width:30px;height:30px;stroke:var(--text-3)}
.linkbtn{border:0;background:none;color:var(--primary);cursor:pointer;font:inherit;text-decoration:underline;padding:0}
.aia-file{display:flex;align-items:center;justify-content:space-between;gap:12px}
.aia-file b{font-size:13.5px}
.aia-file span{display:block;font-size:11.5px;color:var(--text-3);margin-top:2px}
.aia-sheets{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.aia-chip{font-size:11px;color:var(--text-2);background:var(--surface-2);border-radius:999px;padding:2px 9px}
.aia-prompt{width:100%;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);
  padding:10px 12px;font-family:inherit;font-size:13px;resize:vertical}
.aia-prompt:focus{outline:none;border-color:var(--primary)}
.aia-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.aia-ex{font-size:12px;color:var(--text-2);background:var(--surface);border:1px solid var(--border);border-radius:999px;
  padding:4px 11px;cursor:pointer;font-family:inherit}
.aia-ex:hover{border-color:var(--border-strong);color:var(--text)}
.aia-run-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}
.aia-target{font-size:12.5px;color:var(--text-2);display:flex;align-items:center;gap:8px}
.aia-target select{height:32px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);padding:0 8px;font-family:inherit}
.aia-applied{margin-top:14px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}
.aia-applied h4{margin:0 0 6px;font-size:12.5px;color:var(--text-2)}
.aia-applied ul{margin:0 0 10px;padding-left:18px;font-size:13px}
.aia-applied li{margin:3px 0}
.aia-fileacts{display:flex;gap:8px}

/* AI Analysis — chat */
.chat-log{max-height:46vh;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:2px}
.chat-row{display:flex}
.chat-row.user{justify-content:flex-end}
.chat-row .bubble{max-width:80%;padding:9px 13px;border-radius:12px;font-size:13px;line-height:1.5}
.chat-row.user .bubble{background:var(--primary-weak);color:var(--text);border-bottom-right-radius:4px}
.chat-row.ai .bubble{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}
.chat-tool{align-self:flex-start;font-size:11.5px;color:var(--text-3);background:var(--surface-2);border-radius:999px;padding:3px 11px}
.chat-preview{border:1px solid var(--border-strong);border-radius:var(--r-md);padding:12px 14px;background:var(--surface)}
.chat-preview.pending{border-color:var(--primary)}
.chat-preview.applied{border-color:var(--go)}
.chat-preview.muted{opacity:.7}
.prev-h{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.prev-list{margin:0 0 10px;padding-left:18px;font-size:13px}
.prev-list li{margin:3px 0}
.prev-actions{display:flex;gap:8px}
.prev-done{font-size:12.5px;color:var(--text-2);margin-bottom:8px}
.chat-preview.applied .prev-done{color:var(--go)}
.aia-composer{display:flex;flex-direction:column}
.card-sub{font-size:12px;color:var(--text-2);margin:-8px 0 14px}
.card .card-foot{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);display:flex;gap:18px;flex-wrap:wrap}
.card .card-foot .cf{font-size:12px;color:var(--text-2)}
.card .card-foot .cf b{display:block;font-size:15px;color:var(--text);font-weight:600;font-variant-numeric:tabular-nums;margin-top:2px}

/* form fields */
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}
.f-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.f-field.span2{grid-column:1/-1}
.f-label{font-size:11px;font-weight:600;letter-spacing:.3px;color:var(--text-2);text-transform:uppercase}
.f-field input,.f-field textarea,.f-field select{width:100%;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:var(--r-sm);font-family:inherit;font-size:13px}
.f-field input,.f-field select{height:36px;padding:0 11px}
.f-field textarea{padding:9px 11px;resize:vertical;min-height:54px;line-height:1.5}
.f-field input:focus,.f-field textarea:focus,.f-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}
.f-hint{font-size:11.5px;color:var(--text-3)}

/* overview: details + map */
.ov-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:16px;align-items:start}
.map-card{display:flex;flex-direction:column}
.tw-toolbar{display:flex;gap:8px;margin-bottom:14px;align-items:center}
.tw-toolbar .tw-count{margin-left:auto;font-size:12px;color:var(--text-3)}
.tw-map{flex:1;min-height:340px;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface-2);position:relative}
.tw-map .map-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12.5px;text-align:center;padding:16px}
.map-note{font-size:11.5px;color:var(--text-3);margin-top:10px}
#tenderLanes{min-width:2010px}

/* volume */
.vol-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:16px;align-items:start}
.vol-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:8px;align-items:end;height:190px;padding:6px 0 0}
.vol-col{display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.vol-bar{width:64%;background:var(--primary);border-radius:3px 3px 0 0;min-height:2px;transition:height .12s}
.vol-col:hover .vol-bar{background:var(--primary-hover)}
.vol-m{font-size:11px;color:var(--text-3)}
#volTable{min-width:100%}

/* bids */
.bid-head{display:grid;grid-template-columns:1fr 110px 130px 64px;gap:8px;padding:0 2px 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-3)}
.bid-head span:nth-child(2),.bid-head span:nth-child(3){text-align:left}
.bidrow{grid-template-columns:1fr 110px 130px 28px 28px!important}

@media(max-width:1080px){.ov-grid,.vol-layout{grid-template-columns:1fr}}

/* modal (Excel import) --------------------------------------------------- */
.modal{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:60;display:flex;justify-content:center;align-items:flex-start;padding-top:8vh}
.modal-box{width:660px;max-width:94vw;max-height:84vh;display:flex;flex-direction:column;background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 24px 60px rgba(15,23,42,.3);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.modal-head h3{margin:0;font-size:14px}
.modal-body{padding:18px;overflow-y:auto}
.modal-foot{display:flex;gap:8px;justify-content:flex-end;padding:14px 18px;border-top:1px solid var(--border)}
.import-status{margin-top:12px;font-size:12.5px;color:var(--text-2)}
.import-tpl{display:flex;align-items:center;gap:10px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border);font-size:12.5px;color:var(--text-3)}
.imp-h{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin:4px 0 10px}
#importDetails{padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--border)}
.choose-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.choose-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;cursor:pointer;font-family:inherit;color:var(--text)}
.choose-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}
.choose-card .cc-ico{width:36px;height:36px;border-radius:var(--r-md);background:var(--primary-weak);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:6px}
html[data-theme="dark"] .choose-card .cc-ico{color:var(--accent)}
.choose-card h4{margin:0;font-size:14px;font-weight:600}
.choose-card p{margin:0;font-size:12px;color:var(--text-2)}
.import-map{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;margin-top:8px}
.import-map label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-2);font-weight:500}
.imp-sheet{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12.5px;color:var(--text-2)}
.import-map select,.imp-sheet select{height:32px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:var(--r-sm);font-family:inherit;font-size:12.5px;padding:0 8px}
input[type=file]{font-family:inherit;font-size:13px;color:var(--text-2)}

/* command palette -------------------------------------------------------- */
.cmdk{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:60;display:flex;justify-content:center;align-items:flex-start;padding-top:12vh}
.cmdk-box{width:560px;max-width:92vw;background:var(--raised);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:0 24px 60px rgba(15,23,42,.3);overflow:hidden}
.cmdk-input{width:100%;height:50px;border:0;border-bottom:1px solid var(--border);background:transparent;color:var(--text);
  font-size:15px;padding:0 18px;font-family:inherit;outline:none}
.cmdk-list{max-height:50vh;overflow-y:auto;padding:6px}
.cmdk-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);cursor:pointer;font-size:13px}
.cmdk-item .meta{margin-left:auto;color:var(--text-3);font-size:11.5px}
.cmdk-item.active,.cmdk-item:hover{background:var(--primary-weak)}
.cmdk-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);padding:9px 12px 4px;font-weight:600}

/* toast ------------------------------------------------------------------ */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--text);color:var(--bg);
  padding:11px 18px;border-radius:var(--r-md);opacity:0;transition:.2s;z-index:70;font-size:13px;box-shadow:0 8px 30px rgba(0,0,0,.2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--nogo);color:#fff}
