/* ===== Atlas Relief Tender Tracker — base styles ===== */

:root{
  --brand-blue:#1e4074;
  --brand-blue-deep:#15305a;
  --brand-blue-soft:#2a528c;
  --brand-amber:#f3ac2a;
  --brand-amber-deep:#d49419;
  --brand-amber-soft:#faecca;
  --paper:#ffffff;
  --paper-2:#f7f6f3;
  --paper-3:#efece6;
  --ink:#0c1d35;
  --ink-2:#3a4a64;
  --rule:#e3dfd5;
  --muted:#767063;
  --gold-light:#fbf5e6;
  --st-lead:#2a528c;
  --st-offer:#7e5dab;
  --st-submitted:#1e4074;
  --st-followup:#d49419;
  --st-won:#2d7a55;
  --st-lost:#b04a3d;
  --st-postponed:#8a8275;
  --st-cancel:#767063;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper-2);color:var(--ink);font-family:'Geist',system-ui,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none;background:none}
a{color:inherit;text-decoration:none}
.display{font-family:'Geist',system-ui,sans-serif;font-weight:700;letter-spacing:-0.005em}
.mono{font-family:'Geist Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.1em}

/* layout */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* sidebar */
.sidebar{background:var(--brand-blue);color:#fff;padding:0;position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column}
.sb-brand{padding:20px 22px;border-bottom:1px solid rgba(255,255,255,0.1)}
.sb-brand-row{display:flex;align-items:center;gap:11px;margin-bottom:4px}
.sb-mark{width:36px;height:36px;background:var(--brand-amber);border-radius:6px;display:grid;place-items:center;color:var(--brand-blue-deep);font-family:'Geist',sans-serif;font-weight:800;font-size:20px}
.sb-brand-name{font-family:'Geist',sans-serif;font-size:17px;font-weight:800;line-height:1;letter-spacing:0.02em;color:#fff}
.sb-brand-sub{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-top:6px;line-height:1.3}
.sb-flags{display:flex;gap:6px;margin-top:10px}
.flag{width:22px;height:15px;border-radius:2px;display:inline-block;flex-shrink:0;box-shadow:0 1px 2px rgba(0,0,0,0.2)}
.flag.ug{background:linear-gradient(to bottom,#000 0 33%,#fcdc04 33% 66%,#d90000 66%)}
.flag.ss{background:linear-gradient(to bottom,#000 0 33%,#fff 33% 39%,#d21034 39% 61%,#fff 61% 67%,#078930 67%)}
.sb-nav{padding:14px 10px;flex:1;display:flex;flex-direction:column;gap:4px}

/* Collapsible group (HTML <details>) */
.nav-group{border-radius:6px;overflow:hidden}
.nav-group[open]{background:rgba(255,255,255,0.03)}
.nav-group summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  font-family:'Geist',sans-serif;font-weight:700;font-size:13px;
  letter-spacing:0.02em;text-transform:uppercase;
  color:#fff;
  border-radius:6px;
  transition:background .15s;
  user-select:none;
}
.nav-group summary::-webkit-details-marker{display:none}
.nav-group summary:hover{background:rgba(255,255,255,0.08)}
.nav-group[open] summary{background:rgba(255,255,255,0.10)}
.nav-group-icon{
  width:24px;height:24px;border-radius:5px;
  display:grid;place-items:center;flex-shrink:0;
  font-size:13px;
  box-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.nav-group-name{flex:1;font-weight:700}
.nav-group-arrow{
  font-size:11px;color:rgba(255,255,255,0.6);
  transition:transform .2s;
}
.nav-group[open] > summary .nav-group-arrow{transform:rotate(180deg);color:var(--brand-amber)}
.nav-group-badge{
  font-family:'Geist Mono',monospace;font-size:10px;font-weight:700;
  background:var(--brand-amber);color:var(--ink);
  padding:2px 7px;border-radius:9px;letter-spacing:0;
}

/* Section inside a group */
.nav-section{padding:4px 6px 8px 6px}
.nav-section:not(:last-child){border-bottom:1px dashed rgba(255,255,255,0.08);margin-bottom:6px}
.nav-sublabel{
  font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.42);
  padding:6px 10px 4px;
}

/* Nav-title left for backward compat (some pages might still reference it) */
.nav-title{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);padding:0 10px;margin-bottom:8px;margin-top:18px}
.nav-title:first-child{margin-top:0}

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:5px;
  color:rgba(255,255,255,0.78);cursor:pointer;
  font-size:13px;font-weight:500;
  transition:all .15s;margin-bottom:1px;text-decoration:none;
}
.nav-item:hover{background:rgba(255,255,255,0.06);color:#fff}
.nav-item.active{background:rgba(255,255,255,0.14);color:#fff;font-weight:600}
.nav-item.active .nav-dot{background:var(--brand-amber)}
.nav-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.3);flex-shrink:0}
.nav-count{margin-left:auto;font-size:10.5px;color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.10);padding:2px 7px;border-radius:10px;font-family:'Geist Mono',monospace;font-weight:600}
.sb-foot{padding:16px 22px;border-top:1px solid rgba(255,255,255,0.1);font-size:11px;color:rgba(255,255,255,0.55)}
.sb-foot strong{color:#fff;display:block;font-weight:500;margin-bottom:2px}
.sb-foot a{display:inline-block;margin-top:6px;font-size:11px}

/* main */
.main{background:var(--paper-2);min-height:100vh}
.topbar{background:var(--paper);border-bottom:1px solid var(--rule);padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;position:sticky;top:0;z-index:50}
.page-title{font-family:'Geist',sans-serif;font-size:26px;font-weight:700;line-height:1.15;color:var(--ink);letter-spacing:-0.015em}
.page-sub{font-family:'Geist Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-top:5px}
.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search{background:var(--paper-2);border:1px solid var(--rule);border-radius:6px;padding:8px 12px;width:260px;display:flex;align-items:center;gap:8px;color:var(--muted)}
.search input{flex:1;color:var(--ink)}
.btn{padding:9px 16px;border-radius:5px;font-weight:500;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:7px;transition:all .15s;border:1px solid transparent;font-family:inherit;text-decoration:none}
.btn-primary{background:var(--brand-blue);color:#fff}
.btn-primary:hover{background:var(--brand-blue-deep);color:#fff}
.btn-amber{background:var(--brand-amber);color:var(--ink)}
.btn-amber:hover{background:var(--brand-amber-deep);color:#fff}
.btn-ghost{background:var(--paper);color:var(--ink);border:1px solid var(--rule)}
.btn-ghost:hover{background:var(--paper-2);border-color:var(--ink-2)}
.body-wrap{padding:24px 32px 60px}

/* flash */
.flash{padding:12px 18px;border-radius:6px;margin-bottom:14px;font-size:13.5px}
.flash-success{background:rgba(45,122,85,0.1);border:1px solid rgba(45,122,85,0.25);color:var(--st-won)}
.flash-error{background:rgba(176,74,61,0.08);border:1px solid rgba(176,74,61,0.2);color:var(--st-lost)}

/* stage ribbon */
.stage-ribbon{background:var(--paper);border:1px solid var(--rule);border-radius:8px;padding:14px 18px;margin-bottom:20px;display:flex;gap:6px;align-items:center;overflow-x:auto;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.stage-pill{display:flex;align-items:center;gap:9px;padding:6px 12px;border-radius:5px;font-size:12.5px;color:var(--ink-2);white-space:nowrap;flex-shrink:0;background:var(--paper-2);border:1px solid var(--rule)}
.st-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.stage-pill.lead .st-dot{background:var(--st-lead)}
.stage-pill.offer .st-dot{background:var(--st-offer)}
.stage-pill.submitted .st-dot{background:var(--st-submitted)}
.stage-pill.followup .st-dot{background:var(--st-followup)}
.stage-pill.outcome .st-dot{background:var(--st-won)}
.st-count{font-family:'Geist Mono',monospace;font-weight:600;color:var(--ink)}
.st-arrow{color:var(--rule);font-size:14px;flex-shrink:0}

/* alerts */
.alerts{background:var(--gold-light);border:1px solid var(--brand-amber-soft);border-left:4px solid var(--brand-amber);border-radius:6px;padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;gap:14px}
.alert-icon{width:34px;height:34px;background:var(--brand-amber);border-radius:6px;display:grid;place-items:center;color:var(--ink);flex-shrink:0;font-size:16px;font-weight:600}
.alert-text{flex:1}
.alert-title{font-weight:600;font-size:14px;color:var(--ink)}
.alert-detail{font-size:12px;color:var(--ink-2);margin-top:2px}

/* KPIs */
.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--paper);border:1px solid var(--rule);border-radius:8px;padding:18px 18px 16px;position:relative;overflow:hidden;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.kpi-label{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;font-weight:500}
.kpi-value{font-family:'Geist',sans-serif;font-size:30px;font-weight:700;line-height:1.05;margin-top:8px;color:var(--ink);letter-spacing:-0.02em}
.kpi-delta{font-size:11.5px;margin-top:6px;color:var(--ink-2)}
.kpi-delta strong{color:var(--brand-blue);font-weight:600}
.kpi-stripe{position:absolute;left:0;top:0;bottom:0;width:3px}
.kpi.lead .kpi-stripe{background:var(--st-lead)}
.kpi.offer .kpi-stripe{background:var(--st-offer)}
.kpi.submitted .kpi-stripe{background:var(--st-submitted)}
.kpi.followup .kpi-stripe{background:var(--st-followup)}
.kpi.outcome .kpi-stripe{background:var(--st-won)}

/* cards / split */
.split{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;margin-bottom:22px}
.card{background:var(--paper);border:1px solid var(--rule);border-radius:8px;overflow:hidden;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.card-head{padding:16px 20px;border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;background:var(--paper)}
.card-title{font-family:'Geist',sans-serif;font-size:17px;font-weight:700;color:var(--ink);line-height:1.1;letter-spacing:-0.01em}
.card-sub{font-family:'Geist Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-top:4px}

/* deadline row */
.deadline-row{display:flex;align-items:center;gap:12px;padding:13px 20px;border-bottom:1px solid var(--rule);cursor:pointer;transition:background .15s}
.deadline-row:hover{background:var(--paper-2)}
.deadline-row:last-child{border-bottom:none}
.dl-date{flex-shrink:0;width:48px;text-align:center;background:var(--paper-2);border-radius:5px;padding:6px 0;border:1px solid var(--rule)}
.dl-day{font-family:'Geist',sans-serif;font-size:18px;font-weight:700;line-height:1;color:var(--ink)}
.dl-month{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-top:2px}
.dl-info{flex:1;min-width:0}
.dl-title{font-weight:500;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dl-meta{font-size:11.5px;color:var(--muted);margin-top:2px}
.dl-tag{flex-shrink:0;font-family:'Geist Mono',monospace;font-size:10px;padding:3px 8px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em}
.dl-tag.urgent{background:rgba(176,74,61,0.1);color:var(--st-lost)}
.dl-tag.soon{background:rgba(212,148,25,0.12);color:var(--brand-amber-deep)}
.dl-tag.ok{background:rgba(45,122,85,0.1);color:var(--st-won)}

/* activity */
.activity-row{display:flex;gap:12px;padding:12px 20px;border-bottom:1px solid var(--rule)}
.activity-row:last-child{border-bottom:none}
.act-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-blue);margin-top:6px;flex-shrink:0}
.act-dot.green{background:var(--st-won)}
.act-dot.red{background:var(--st-lost)}
.act-dot.amber{background:var(--brand-amber-deep)}
.act-dot.purple{background:var(--st-offer)}
.act-body{flex:1;font-size:13px;color:var(--ink-2)}
.act-body strong{color:var(--ink);font-weight:600}
.act-time{color:var(--muted);font-size:10.5px;margin-top:3px;font-family:'Geist Mono',monospace;text-transform:uppercase;letter-spacing:0.08em}

/* toolbar / chips */
.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.chip{padding:7px 13px;background:var(--paper);border:1px solid var(--rule);border-radius:20px;font-size:12px;color:var(--ink-2);cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-weight:500;transition:all .15s;text-decoration:none}
.chip.active{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}
.chip.active .chip-count{color:var(--brand-amber)}
.chip:hover:not(.active){background:var(--paper-2);border-color:var(--ink-2)}
.chip-count{font-family:'Geist Mono',monospace;color:var(--brand-blue);font-size:11px;font-weight:600}
.view-switcher{margin-left:auto;display:flex;gap:0;background:var(--paper);border:1px solid var(--rule);border-radius:6px;overflow:hidden}
.vs-btn{padding:7px 14px;font-size:12px;cursor:pointer;color:var(--ink-2);font-weight:500;border-right:1px solid var(--rule);text-decoration:none;display:inline-block}
.vs-btn:last-child{border-right:none}
.vs-btn.active{background:var(--brand-blue);color:#fff}

/* table */
.tbl-wrap{background:var(--paper);border:1px solid var(--rule);border-radius:8px;overflow:hidden;overflow-x:auto;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
table{width:100%;border-collapse:collapse;min-width:920px}
thead th{text-align:left;padding:12px 14px;font-family:'Geist Mono',monospace;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;border-bottom:1px solid var(--rule);background:var(--paper-2);white-space:nowrap}
tbody td{padding:13px 14px;border-bottom:1px solid var(--rule);font-size:12.8px;vertical-align:middle;color:var(--ink-2)}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s;cursor:pointer}
tbody tr:hover{background:var(--paper-2)}
.t-code{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}
.t-name{font-weight:600;font-size:13px;color:var(--ink)}
.t-sub{font-size:11.5px;color:var(--muted);margin-top:2px}

/* stage badges */
.stage{padding:3px 9px;border-radius:4px;font-family:'Geist Mono',monospace;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;display:inline-block;border:1px solid transparent}
.stage.lead{background:rgba(42,82,140,0.08);color:var(--st-lead);border-color:rgba(42,82,140,0.2)}
.stage.offer{background:rgba(126,93,171,0.08);color:var(--st-offer);border-color:rgba(126,93,171,0.2)}
.stage.submitted{background:rgba(30,64,116,0.08);color:var(--st-submitted);border-color:rgba(30,64,116,0.2)}
.stage.followup{background:rgba(243,172,42,0.12);color:var(--brand-amber-deep);border-color:rgba(212,148,25,0.3)}
.stage.won{background:rgba(45,122,85,0.1);color:var(--st-won);border-color:rgba(45,122,85,0.25)}
.stage.lost{background:rgba(176,74,61,0.08);color:var(--st-lost);border-color:rgba(176,74,61,0.2)}
.stage.postponed{background:rgba(118,112,99,0.08);color:var(--muted);border-color:rgba(118,112,99,0.2)}
.stage.cancelled{background:rgba(118,112,99,0.08);color:var(--muted);border-color:rgba(118,112,99,0.2)}

.value-cell{font-family:'Geist Mono',monospace;font-size:12px;text-align:right;white-space:nowrap;color:var(--ink);font-weight:600}
.value-pending{color:var(--muted);font-style:italic;font-weight:400;font-family:'Geist',sans-serif;font-size:11.5px}
.dl-cell{display:flex;align-items:center;gap:7px;white-space:nowrap}
.pulse{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.pulse.red{background:var(--st-lost);box-shadow:0 0 0 4px rgba(176,74,61,0.12)}
.pulse.amber{background:var(--brand-amber);box-shadow:0 0 0 4px rgba(243,172,42,0.15)}
.pulse.green{background:var(--st-won)}
.pulse.grey{background:#c5beaf}
.owner-pill{display:inline-flex;align-items:center;gap:7px}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--brand-blue);display:grid;place-items:center;font-size:10.5px;font-weight:600;color:var(--brand-amber);font-family:'Geist Mono',monospace}

/* KANBAN */
.kanban{display:grid;grid-template-columns:repeat(5,minmax(260px,1fr));gap:14px;margin-top:6px;align-items:flex-start}
.kb-col{background:var(--paper);border:1px solid var(--rule);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;min-height:500px;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.kb-head{padding:12px 14px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:9px;background:var(--paper)}
.kb-color{width:4px;height:18px;border-radius:2px;flex-shrink:0}
.kb-col[data-stage="lead"] .kb-color{background:var(--st-lead)}
.kb-col[data-stage="offer"] .kb-color{background:var(--st-offer)}
.kb-col[data-stage="submitted"] .kb-color{background:var(--st-submitted)}
.kb-col[data-stage="followup"] .kb-color{background:var(--st-followup)}
.kb-col[data-stage="closed"] .kb-color{background:var(--st-won)}
.kb-title{font-family:'Geist',sans-serif;font-size:14px;font-weight:700;color:var(--ink);flex:1;line-height:1;letter-spacing:-0.005em}
.kb-num{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:2px;display:block}
.kb-count{font-family:'Geist Mono',monospace;font-size:11px;color:var(--ink-2);background:var(--paper-2);padding:3px 8px;border-radius:10px;font-weight:600}
.kb-add{width:22px;height:22px;border-radius:4px;background:var(--paper-2);border:1px solid var(--rule);display:grid;place-items:center;cursor:pointer;color:var(--muted);font-size:14px;line-height:1;text-decoration:none}
.kb-add:hover{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}
.kb-body{padding:10px;flex:1;display:flex;flex-direction:column;gap:8px;background:var(--paper-2);min-height:200px}
.kb-card{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:12px;cursor:grab;transition:all .15s;box-shadow:0 1px 1px rgba(12,29,53,0.04);position:relative;text-decoration:none;color:inherit;display:block}
.kb-card:hover{border-color:var(--brand-blue);box-shadow:0 4px 12px rgba(12,29,53,0.08);transform:translateY(-1px)}
.kb-card.dragging{opacity:0.4;cursor:grabbing}
.kb-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.kb-card-code{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em}
.kb-card-pulse{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:2px}
.kb-card-name{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:5px}
.kb-card-ngo{font-size:11.5px;color:var(--ink-2);margin-bottom:8px}
.kb-card-meta{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-top:8px;border-top:1px dashed var(--rule)}
.kb-card-lot{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--brand-blue);background:rgba(30,64,116,0.06);padding:2px 6px;border-radius:3px;letter-spacing:0.04em;font-weight:600}
.kb-card-deadline{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}
.kb-card-deadline.urgent{color:var(--st-lost);font-weight:600}
.kb-card-deadline.soon{color:var(--brand-amber-deep);font-weight:600}
.kb-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.kb-card-value{font-family:'Geist Mono',monospace;font-size:11px;font-weight:600;color:var(--ink)}
.kb-card-value.pending{font-style:italic;font-weight:400;color:var(--muted);font-family:'Geist',sans-serif}
.kb-avatar{width:22px;height:22px;border-radius:50%;background:var(--brand-blue);display:grid;place-items:center;font-size:9.5px;font-weight:600;color:var(--brand-amber);font-family:'Geist Mono',monospace}
.kb-empty{padding:30px 10px;text-align:center;font-size:11.5px;color:var(--muted);font-style:italic;border:1px dashed var(--rule);border-radius:6px;background:var(--paper)}
.kb-drop-zone{transition:background .15s}
.kb-drop-zone.drag-over{background:rgba(243,172,42,0.08);outline:2px dashed var(--brand-amber);outline-offset:-2px;border-radius:6px}

/* form */
.form-card{background:var(--paper);border:1px solid var(--rule);border-radius:8px;padding:28px;max-width:980px;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.form-head{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 22px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.field label{font-family:'Geist',sans-serif;font-size:12px;color:var(--ink);font-weight:700;text-transform:uppercase;letter-spacing:0.04em}
.field label .req{color:var(--brand-amber-deep)}
.field input,.field select,.field textarea{background:var(--paper);border:1px solid var(--rule);border-radius:5px;padding:10px 12px;color:var(--ink);font-size:13.5px;transition:border-color .15s;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px rgba(30,64,116,0.08)}
.field textarea{resize:vertical;min-height:84px}
.field-hint{font-family:'Geist',sans-serif;font-size:11.5px;color:var(--brand-amber-deep);margin-top:2px;font-style:italic}
.section-title{
  font-family:'Geist',sans-serif;font-weight:700;font-size:15px;
  letter-spacing:0.02em;text-transform:uppercase;color:var(--ink);
  display:flex;align-items:center;gap:14px;line-height:1;
  margin:32px 0 18px;padding:14px 18px;
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-left:5px solid var(--brand-blue);
  border-radius:6px;
}
.section-title:first-of-type{margin-top:0}
.section-num{
  font-family:'Geist',sans-serif;font-weight:800;font-size:14px;
  width:30px;height:30px;display:grid;place-items:center;
  background:var(--brand-blue);color:#fff;
  border-radius:5px;flex-shrink:0;
  box-shadow:0 1px 3px rgba(12,29,53,0.15);
}

/* ── Per-section colour cycling (8 brand colours, A through H) ── */
.section-num[data-section="A"]{background:#1e4074}    /* brand blue */
.section-num[data-section="B"]{background:#d49419}    /* amber deep */
.section-num[data-section="C"]{background:#7e5dab}    /* purple */
.section-num[data-section="D"]{background:#2d7a55}    /* green */
.section-num[data-section="E"]{background:#b04a3d}    /* red */
.section-num[data-section="F"]{background:#2a528c}    /* light blue */
.section-num[data-section="G"]{background:#0c1d35}    /* ink */
.section-num[data-section="H"]{background:#767063}    /* muted */

/* Border + tint of the title block matches the badge colour (uses :has()) */
.section-title:has(.section-num[data-section="A"]){border-left-color:#1e4074;background:rgba(30,64,116,0.05)}
.section-title:has(.section-num[data-section="B"]){border-left-color:#d49419;background:rgba(212,148,25,0.07)}
.section-title:has(.section-num[data-section="C"]){border-left-color:#7e5dab;background:rgba(126,93,171,0.06)}
.section-title:has(.section-num[data-section="D"]){border-left-color:#2d7a55;background:rgba(45,122,85,0.05)}
.section-title:has(.section-num[data-section="E"]){border-left-color:#b04a3d;background:rgba(176,74,61,0.05)}
.section-title:has(.section-num[data-section="F"]){border-left-color:#2a528c;background:rgba(42,82,140,0.05)}
.section-title:has(.section-num[data-section="G"]){border-left-color:#0c1d35;background:rgba(12,29,53,0.05)}
.section-title:has(.section-num[data-section="H"]){border-left-color:#767063;background:rgba(118,112,99,0.07)}

/* The form-grid immediately after each section-title gets a matching thin left border too */
.section-title + .form-grid{
  padding:6px 0 6px 22px;margin-bottom:8px;
  border-left:2px solid var(--rule);
  margin-left:14px;
}
.stage-banner{padding:14px 18px;border-radius:6px;margin-bottom:22px;display:flex;align-items:center;gap:14px;border:1px solid var(--rule);border-left:4px solid var(--brand-blue)}
.stage-banner.lead{background:rgba(42,82,140,0.04);border-left-color:var(--st-lead)}
.stage-banner.offer{background:rgba(126,93,171,0.04);border-left-color:var(--st-offer)}
.stage-icon{width:38px;height:38px;border-radius:6px;display:grid;place-items:center;font-size:18px;flex-shrink:0;background:var(--paper);border:1px solid var(--rule)}
.stage-banner-text strong{font-size:14px;display:block;margin-bottom:3px;color:var(--ink);font-weight:600}
.stage-banner-text span{font-size:12px;color:var(--ink-2)}
.progress-strip{display:flex;background:var(--paper-2);border-radius:6px;padding:5px;gap:4px;margin-bottom:22px;border:1px solid var(--rule)}
.ps-step{flex:1;padding:9px 10px;border-radius:4px;text-align:center;font-size:11.5px;color:var(--muted);font-weight:500}
.ps-step.done{color:var(--st-won);background:rgba(45,122,85,0.06)}
.ps-step.active{color:#fff;background:var(--brand-blue);font-weight:600}
.ps-step.future{opacity:0.6}
.ps-num{font-family:'Geist Mono',monospace;font-size:9.5px;display:block;margin-bottom:2px;letter-spacing:0.08em;opacity:0.7}
.form-foot{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:28px;padding-top:20px;border-top:1px solid var(--rule);flex-wrap:wrap}
.form-foot-left{font-size:12.5px;color:var(--ink-2)}
.form-foot-right{display:flex;gap:10px}

/* outcome buttons */
.outcome-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.outcome-btn{padding:16px 12px;border-radius:6px;background:var(--paper);border:1px solid var(--rule);cursor:pointer;text-align:center;transition:all .15s}
.outcome-btn:hover{border-color:var(--brand-blue);background:var(--paper-2)}
.outcome-btn.win:hover{border-color:var(--st-won);background:rgba(45,122,85,0.05)}
.outcome-btn.loss:hover{border-color:var(--st-lost);background:rgba(176,74,61,0.05)}
.outcome-btn.cancel:hover{border-color:var(--muted)}
.outcome-icon{font-size:22px;margin-bottom:5px;font-family:'Geist',sans-serif;font-weight:700}
.outcome-label{font-family:'Geist Mono',monospace;font-weight:600;font-size:12px;letter-spacing:0.08em;text-transform:uppercase}
.outcome-desc{font-size:11.5px;color:var(--muted);margin-top:3px}

/* login */
.login-wrap{display:grid;place-items:center;min-height:100vh;background:var(--paper-2)}
.login-card{background:var(--paper);border:1px solid var(--rule);border-radius:10px;padding:36px 40px;width:380px;box-shadow:0 4px 16px rgba(12,29,53,0.06)}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.login-brand .sb-mark{width:42px;height:42px;font-size:26px}
.login-title{font-family:'Geist',sans-serif;font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-0.015em}
.login-sub{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.login-error{background:rgba(176,74,61,0.08);border:1px solid rgba(176,74,61,0.2);color:var(--st-lost);padding:10px 12px;border-radius:5px;font-size:13px;margin-bottom:18px}

/* toast */
#toast{position:fixed;bottom:24px;right:24px;background:var(--brand-blue);color:#fff;padding:12px 18px;border-radius:6px;font-size:13px;box-shadow:0 8px 24px rgba(12,29,53,0.25);z-index:1000;border-left:4px solid var(--brand-amber);transition:opacity .3s, transform .3s;opacity:0;transform:translateY(10px);pointer-events:none;font-family:'Geist',sans-serif}
#toast.show{opacity:1;transform:translateY(0)}
#toast.error{border-left-color:var(--st-lost)}

/* ============= RESPONSIVE / MOBILE ============= */

/* Mobile hamburger toggle (hidden on desktop) */
.mobile-menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:1100;width:44px;height:44px;background:var(--brand-blue);border:none;border-radius:6px;cursor:pointer;padding:11px 9px;box-shadow:0 2px 6px rgba(12,29,53,0.25)}
.mobile-menu-toggle span{display:block;width:100%;height:2px;background:#fff;border-radius:1px;margin:4px 0;transition:all .2s}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(12,29,53,0.55);z-index:1000;opacity:0;transition:opacity .2s}
.sidebar-close{display:none;background:none;border:none;color:rgba(255,255,255,0.7);font-size:28px;line-height:1;cursor:pointer;padding:0 4px;margin-left:auto}

/* Big screens — first tighten kanban */
@media (max-width:1400px){.kanban{grid-template-columns:repeat(5,minmax(230px,1fr))}}
@media (max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.kanban{overflow-x:auto;grid-template-columns:repeat(5,260px)}}
@media (max-width:1000px){.split{grid-template-columns:1fr}.outcome-grid{grid-template-columns:repeat(2,1fr)}}

/* ── PHONE (≤ 900px) — hamburger sidebar, single-column everything ── */
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  .mobile-menu-toggle{display:block}
  .sidebar{
    display:flex;position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;
    z-index:1050;transform:translateX(-100%);transition:transform .25s ease;
    box-shadow:4px 0 16px rgba(0,0,0,0.3);
  }
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open .sidebar-backdrop{display:block;opacity:1}
  .sidebar-close{display:block}
  .sb-brand-row{flex-wrap:nowrap}

  /* Topbar — leave room for hamburger + simplify */
  .topbar{padding:14px 18px 14px 64px;flex-direction:column;align-items:flex-start;gap:10px;position:relative}
  .page-title{font-size:20px}
  .page-sub{font-size:10px}
  .top-actions{width:100%;flex-direction:column;align-items:stretch;gap:8px}
  .top-actions .search{width:100%}
  .top-actions .btn{width:100%;justify-content:center}

  /* Body padding tighter on phone */
  .body-wrap{padding:14px 14px 60px}

  /* KPIs stack 1-up */
  .kpi-grid{grid-template-columns:1fr !important;gap:10px;margin-bottom:14px}
  .kpi-value{font-size:24px}

  /* Forms always single column on phone */
  .form-grid{grid-template-columns:1fr !important;gap:14px 0}
  .form-card{padding:18px 14px}
  .form-head{flex-direction:column;align-items:flex-start;gap:14px}

  /* Tables — wrap in scroller, slightly smaller */
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:640px;font-size:12px}
  thead th{padding:10px 10px;font-size:9.5px}
  tbody td{padding:10px 10px;font-size:11.5px}

  /* Kanban: horizontal scroll, narrower */
  .kanban{grid-template-columns:repeat(5,260px);overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch}
  .ctn-board{grid-template-columns:repeat(6,220px);overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Toolbar chips wrap nicely */
  .toolbar{gap:6px}
  .chip{padding:6px 11px;font-size:11.5px}

  /* Section banners — tighter padding */
  .section-title{margin:22px 0 14px;padding:11px 14px;font-size:13px}
  .section-num{width:26px;height:26px;font-size:13px}
  .section-title + .form-grid{padding-left:14px;margin-left:8px;border-left-width:2px}

  /* Mail list — collapse the grid to vertical */
  .mail-row-link{grid-template-columns:1fr;gap:4px;padding-right:60px}
  .mail-meta{position:absolute;top:11px;right:12px}
  .mail-when{min-width:auto;font-size:10px}
  .mail-subj-snip{flex-wrap:wrap;white-space:normal}
  .mail-subj{max-width:100%;white-space:normal}
  .mail-snip{display:none}  /* preview snippet hidden on phone — saves vertical space */

  /* Mail detail — header rows stack */
  .mail-detail-row{grid-template-columns:1fr;gap:2px}
  .mail-detail-actions{gap:6px}
  .mail-detail-actions .btn{flex:1;min-width:0;font-size:12px;padding:8px 10px}

  /* Thread row — single column */
  .thread-row{grid-template-columns:1fr;gap:4px}

  /* CBM calculator — table scrolls */
  #cbm-rows-table{min-width:900px}
  .dim-unit-btn{min-width:0;padding:7px 12px;font-size:12px;flex:1}

  /* Login card — full width minus margin */
  .login-card{width:auto;margin:0 16px;padding:28px 22px}

  /* Bigger touch targets on form inputs + buttons */
  .field input,.field select,.field textarea{padding:11px 12px;font-size:14px;min-height:44px}
  .btn{padding:11px 16px;min-height:42px}
}

/* Very small phones */
@media (max-width:400px){
  .ctn-board{grid-template-columns:repeat(6,200px)}
  .kanban{grid-template-columns:repeat(5,230px)}
  .page-title{font-size:18px}
}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#bfb8a8}

/* ============= WEBMAIL ============= */

.mail-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.mail-folder-tabs{display:flex;gap:6px;flex-wrap:wrap}
.mail-folder-chip{display:inline-flex;align-items:center;gap:6px}
.mail-search{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:7px 10px;display:flex;align-items:center;gap:7px;color:var(--muted);min-width:260px}
.mail-search input{flex:1;color:var(--ink);font-size:13px}
.mail-search-clear{color:var(--muted);font-size:18px;line-height:1;padding:0 4px}

.mail-bulkbar{display:flex;align-items:center;gap:10px;background:var(--brand-blue);color:#fff;padding:10px 18px;border-radius:6px;margin-bottom:10px;box-shadow:0 2px 6px rgba(12,29,53,0.1)}
.mail-bulkbar-count{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--brand-amber);font-weight:600;margin-right:8px}
.mail-bulkbar .btn{padding:6px 12px;font-size:12px}

.mail-list-card{background:var(--paper);border:1px solid var(--rule);border-radius:8px;overflow:hidden;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.mail-row{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--rule);transition:background .12s;position:relative}
.mail-row:last-child{border-bottom:none}
.mail-row:hover{background:var(--paper-2)}
.mail-row.unread{background:rgba(243,172,42,0.03)}
.mail-row.unread .mail-from,.mail-row.unread .mail-subj{font-weight:700;color:var(--ink)}
.mail-row.unread::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand-amber)}
.mail-row-check{flex-shrink:0;width:14px;height:14px;accent-color:var(--brand-blue);cursor:pointer}
.mail-flag{flex-shrink:0;width:22px;height:22px;color:var(--rule);font-size:15px;cursor:pointer;line-height:1;border-radius:3px;background:none;border:none;padding:0}
.mail-flag:hover{color:var(--brand-amber-deep)}
.mail-flag.on{color:var(--brand-amber-deep)}
.mail-row-link{flex:1;display:grid;grid-template-columns:200px 1fr auto;gap:14px;align-items:center;min-width:0;color:inherit;text-decoration:none}
.mail-from{font-size:13px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.mail-subj-snip{min-width:0;display:flex;align-items:baseline;gap:6px;white-space:nowrap;overflow:hidden}
.mail-subj{font-size:13.5px;color:var(--ink);flex-shrink:0;max-width:50%;overflow:hidden;text-overflow:ellipsis}
.mail-snip{color:var(--muted);font-size:12.5px;overflow:hidden;text-overflow:ellipsis;font-weight:400}
.mail-meta{display:flex;gap:6px;align-items:center;flex-shrink:0}
.mail-when{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap;min-width:60px;text-align:right}
.mail-tag{display:inline-block;font-family:'Geist Mono',monospace;font-size:9.5px;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:0.05em;font-weight:600;margin-left:8px;background:var(--paper-2);color:var(--ink-2);border:1px solid var(--rule);vertical-align:middle}
.mail-tag.draft{background:rgba(243,172,42,0.12);color:var(--brand-amber-deep);border-color:rgba(212,148,25,0.3)}
.mail-tag.tender{background:rgba(30,64,116,0.08);color:var(--brand-blue);border-color:rgba(30,64,116,0.25)}

.mail-empty{padding:60px 20px;text-align:center;color:var(--muted);font-size:13px;font-style:italic;line-height:1.7}
.mail-pager{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:18px}

/* mail detail */
.mail-detail-actions{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.mail-detail-card{padding:0;overflow:hidden}
.mail-detail-head{padding:20px 24px;background:var(--paper-2);border-bottom:1px solid var(--rule)}
.mail-detail-row{display:grid;grid-template-columns:90px 1fr;gap:14px;padding:5px 0;align-items:baseline}
.mail-detail-label{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;font-weight:600}
.mail-detail-val{font-size:13.5px;color:var(--ink-2);overflow-wrap:anywhere}
.mail-detail-addr{color:var(--muted);font-family:'Geist Mono',monospace;font-size:12px}
.mono-addr{font-family:'Geist Mono',monospace;font-size:12px}

.mail-tender-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(30,64,116,0.06);border:1px solid rgba(30,64,116,0.18);border-radius:4px;padding:5px 10px;text-decoration:none;color:var(--ink);font-size:12.5px}
.mail-tender-pill strong{font-family:'Geist Mono',monospace;color:var(--brand-blue);font-size:12px;letter-spacing:0.04em}
.mail-tender-unlink{margin-left:6px;background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;line-height:1}
.mail-tender-unlink:hover{color:var(--st-lost)}
#mail-tender-picker{background:var(--paper);border:1px solid var(--rule);border-radius:5px;padding:6px 10px;font-size:13px;color:var(--ink);max-width:480px}

.mail-attachments{padding:14px 24px;background:var(--paper);border-bottom:1px solid var(--rule)}
.attach-chips{display:flex;flex-wrap:wrap;gap:8px}
.attach-chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--rule);border-radius:5px;padding:7px 11px;text-decoration:none;color:var(--ink);font-size:12px;transition:all .15s}
.attach-chip:hover{border-color:var(--brand-blue);background:var(--paper-2)}
.attach-icon{font-size:16px;line-height:1}
.attach-name{font-weight:500;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attach-size{font-family:'Geist Mono',monospace;font-size:10.5px;color:var(--muted)}

.mail-body{padding:0}
.mail-body-html{width:100%;border:none;min-height:300px;background:#fff;display:block}
.mail-body-text{padding:20px 24px;white-space:pre-wrap;font-family:'Geist',sans-serif;font-size:13.5px;color:var(--ink-2);line-height:1.6;background:#fff;margin:0}
.mail-body-empty{padding:40px;text-align:center;color:var(--muted);font-style:italic}

.thread-row{display:grid;grid-template-columns:200px 1fr auto;gap:14px;padding:11px 20px;border-bottom:1px solid var(--rule);text-decoration:none;color:inherit;align-items:center;transition:background .12s}
.thread-row:last-child{border-bottom:none}
.thread-row:hover{background:var(--paper-2)}
.thread-row-from{font-size:13px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.thread-row-subj{font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.thread-row-when{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);white-space:nowrap}

/* compose */
.mail-compose-form .field input[type="file"]{padding:8px;background:var(--paper-2);cursor:pointer}
.mail-compose-form textarea{font-family:'Geist Mono',monospace !important}

@media (max-width:900px){
  .mail-row-link{grid-template-columns:1fr;gap:4px}
  .mail-meta{position:absolute;top:10px;right:14px}
  .mail-detail-row{grid-template-columns:1fr;gap:2px}
  .thread-row{grid-template-columns:1fr;gap:4px}
}

/* ============= SALES ============= */

.sale-pill{display:inline-block;font-family:'Geist Mono',monospace;font-size:9.5px;padding:2px 8px;border-radius:3px;text-transform:uppercase;letter-spacing:0.05em;font-weight:600;border:1px solid transparent}
.sale-pending  {background:rgba(243,172,42,0.12);color:var(--brand-amber-deep);border-color:rgba(212,148,25,0.3)}
.sale-partial  {background:rgba(126,93,171,0.10);color:var(--st-offer);       border-color:rgba(126,93,171,0.3)}
.sale-delivered{background:rgba(45,122,85,0.10); color:var(--st-won);         border-color:rgba(45,122,85,0.3)}
.sale-received {background:rgba(45,122,85,0.10); color:var(--st-won);         border-color:rgba(45,122,85,0.3)}

.search-inline{background:var(--paper);border:1px solid var(--rule);border-radius:5px;padding:7px 12px;font-size:13px;color:var(--ink);min-width:240px}
.search-inline:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px rgba(30,64,116,0.08)}

.sales-mix-title{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:8px;font-weight:600}
.sales-mix-bar{display:flex;height:14px;background:var(--paper-2);border-radius:7px;overflow:hidden;border:1px solid var(--rule)}
.sales-mix-seg{transition:flex .3s}
.sales-mix-seg:hover{filter:brightness(0.92)}
.sales-mix-legend{display:flex;gap:14px;margin-top:8px;font-size:11.5px;color:var(--ink-2);flex-wrap:wrap}
.sales-mix-legend span{display:inline-flex;align-items:center;gap:5px}
.sw{display:inline-block;width:10px;height:10px;border-radius:2px;flex-shrink:0}
.sw.sale-pending  {background:var(--brand-amber)}
.sw.sale-partial  {background:var(--st-offer)}
.sw.sale-delivered{background:var(--st-won)}
.sw.sale-received {background:var(--st-won)}
.sales-mix-seg.sale-pending  {background:var(--brand-amber)}
.sales-mix-seg.sale-partial  {background:var(--st-offer)}
.sales-mix-seg.sale-delivered{background:var(--st-won)}
.sales-mix-seg.sale-received {background:var(--st-won)}

/* Revenue trend bars */
.sales-trend{display:flex;align-items:flex-end;gap:8px;height:180px;padding-bottom:36px;position:relative;border-bottom:1px solid var(--rule)}
.sales-trend-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative;height:100%;cursor:default}
.sales-trend-fill{width:100%;background:linear-gradient(to top,var(--brand-blue),var(--brand-blue-soft));border-radius:3px 3px 0 0;min-height:2px;transition:all .2s}
.sales-trend-bar:hover .sales-trend-fill{background:linear-gradient(to top,var(--brand-amber-deep),var(--brand-amber))}
.sales-trend-label{position:absolute;bottom:-22px;font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);letter-spacing:0.04em}
.sales-trend-value{position:absolute;bottom:-36px;font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--ink-2);font-weight:600}

/* CBM calculator — dimension unit toggle buttons */
.dim-unit-btn{font-weight:600;font-size:13px;padding:8px 18px;min-width:120px;justify-content:center}
.dim-unit-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.dim-unit-btn.active:hover{background:var(--brand-blue-deep);color:#fff}

/* ============= CONTAINERS ============= */

/* Stage pills */
.ctn-pill{display:inline-block;font-family:'Geist Mono',monospace;font-size:9.5px;padding:2px 8px;border-radius:3px;text-transform:uppercase;letter-spacing:0.05em;font-weight:600;border:1px solid transparent}
.ctn-created       {background:var(--paper-2);                   color:var(--muted);             border-color:var(--rule)}
.ctn-loading       {background:rgba(42,82,140,0.08);              color:var(--st-lead);            border-color:rgba(42,82,140,0.25)}
.ctn-awaiting_ship {background:rgba(126,93,171,0.10);             color:var(--st-offer);           border-color:rgba(126,93,171,0.3)}
.ctn-at_sea        {background:rgba(30,64,116,0.08);              color:var(--brand-blue);         border-color:rgba(30,64,116,0.25)}
.ctn-at_mombasa    {background:rgba(243,172,42,0.12);             color:var(--brand-amber-deep);   border-color:rgba(212,148,25,0.3)}
.ctn-land_transit  {background:rgba(212,148,25,0.16);             color:var(--brand-amber-deep);   border-color:rgba(212,148,25,0.4)}
.ctn-delivered     {background:rgba(45,122,85,0.10);              color:var(--st-won);             border-color:rgba(45,122,85,0.3)}

/* Board (Kanban-like) */
.ctn-board{display:grid;grid-template-columns:repeat(6,minmax(180px,1fr));gap:12px;margin-top:8px;align-items:flex-start}
.ctn-col{background:var(--paper);border:1px solid var(--rule);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;min-height:300px;box-shadow:0 1px 2px rgba(12,29,53,0.03)}
.ctn-col-head{padding:11px 13px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:9px;background:var(--paper)}
.ctn-col-color{width:4px;height:18px;border-radius:2px;flex-shrink:0}
.ctn-col-loading       .ctn-col-color{background:var(--st-lead)}
.ctn-col-awaiting_ship .ctn-col-color{background:var(--st-offer)}
.ctn-col-at_sea        .ctn-col-color{background:var(--brand-blue)}
.ctn-col-at_mombasa    .ctn-col-color{background:var(--brand-amber)}
.ctn-col-land_transit  .ctn-col-color{background:var(--brand-amber-deep)}
.ctn-col-delivered     .ctn-col-color{background:var(--st-won)}
.ctn-col-title{font-family:'Geist',sans-serif;font-size:13px;font-weight:700;color:var(--ink);line-height:1.1;text-transform:uppercase;letter-spacing:0.04em}
.ctn-col-count{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.06em;margin-top:2px}
.ctn-col-body{padding:9px;flex:1;display:flex;flex-direction:column;gap:7px;background:var(--paper-2)}
.ctn-card{background:var(--paper);border:1px solid var(--rule);border-radius:5px;padding:10px;text-decoration:none;color:inherit;display:block;transition:all .15s}
.ctn-card:hover{border-color:var(--brand-blue);box-shadow:0 3px 8px rgba(12,29,53,0.07);transform:translateY(-1px)}
.ctn-card-num{font-family:'Geist Mono',monospace;font-size:11px;font-weight:700;color:var(--ink);letter-spacing:0.02em;margin-bottom:3px}
.ctn-card-line{font-size:11px;color:var(--ink-2);margin-bottom:8px}
.ctn-card-stats{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;padding:5px 0;border-top:1px dashed var(--rule);border-bottom:1px dashed var(--rule)}
.ctn-card-val{font-family:'Geist Mono',monospace;font-size:12px;font-weight:700;color:var(--brand-blue)}
.ctn-card-val-empty{color:var(--muted);font-weight:400;font-style:italic;font-size:10.5px}
.ctn-card-days{font-family:'Geist Mono',monospace;font-size:10.5px;color:var(--ink-2);background:var(--paper-2);padding:1px 7px;border-radius:8px;font-weight:600}
.ctn-card-meta{display:flex;justify-content:space-between;align-items:center;gap:6px;padding-top:6px;font-size:10.5px;color:var(--muted)}
.ctn-card-meta>span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ctn-card-tax{font-family:'Geist Mono',monospace;font-size:9px;padding:1px 6px;border-radius:3px;font-weight:600;letter-spacing:0.05em;flex-shrink:0}
.ctn-card-tax.paid   {background:rgba(45,122,85,0.12);color:var(--st-won)}
.ctn-card-tax.pending{background:rgba(243,172,42,0.14);color:var(--brand-amber-deep)}
.ctn-empty{padding:24px 8px;text-align:center;font-size:11px;color:var(--muted);font-style:italic}
.ctn-more{display:block;text-align:center;padding:8px;font-size:11px;color:var(--brand-blue);text-decoration:none;font-weight:500}

/* Milestone timeline (on detail page) */
.ctn-timeline{display:flex;gap:0;align-items:flex-start;padding:18px 20px;background:var(--paper-2);border:1px solid var(--rule);border-radius:6px;margin-bottom:22px;overflow-x:auto}
.ctn-tl-step{flex:1;min-width:90px;display:flex;flex-direction:column;align-items:center;position:relative;padding:0 4px}
.ctn-tl-step::after{content:"";position:absolute;top:9px;left:50%;width:100%;height:2px;background:var(--rule);z-index:0}
.ctn-tl-step:last-child::after{display:none}
.ctn-tl-step.filled::after{background:var(--st-won)}
.ctn-tl-dot{width:18px;height:18px;border-radius:50%;background:var(--paper);border:2px solid var(--rule);position:relative;z-index:1;margin-bottom:8px;flex-shrink:0}
.ctn-tl-step.filled .ctn-tl-dot{background:var(--st-won);border-color:var(--st-won);box-shadow:0 0 0 4px rgba(45,122,85,0.12)}
.ctn-tl-label{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;text-align:center;line-height:1.3;margin-bottom:4px}
.ctn-tl-step.filled .ctn-tl-label{color:var(--ink)}
.ctn-tl-date{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);text-align:center}
.ctn-tl-step.filled .ctn-tl-date{color:var(--st-won);font-weight:600}

@media (max-width:1400px){.ctn-board{grid-template-columns:repeat(6,minmax(170px,1fr))}}
@media (max-width:1200px){.ctn-board{overflow-x:auto;grid-template-columns:repeat(6,200px)}}
@media (max-width:900px){.ctn-board{grid-template-columns:repeat(6,180px)}}
