/* JC Growers — base styles (Robinhood-inspired, flat & sharp) */
:root {
  /* Brand */
  --brand-green: #3DBA4E;
  --brand-green-dark: #1A5C2A;
  --brand-black: #111111;
  --brand-white: #FFFFFF;

  /* Aliased legacy tokens — point to brand colors so existing CSS keeps working */
  --green: #3DBA4E;
  --green-dark: #1A5C2A;
  --green-soft: #E8F6EA;

  --bg: #F5F5F5;
  --card: #FFFFFF;
  --border: #E2E2E2;
  --text: #111111;
  --text-secondary: #555555;
  --muted: #6A6A6A;

  --warn: #B35A00;
  --warn-bg: #FFF3E0;
  --crit: #A8281F;
  --crit-bg: #FDE7E5;
  --ok: #3DBA4E;
  --ok-bg: #E8F6EA;

  /* No shadows — flat and sharp */
  --shadow: none;

  --row-hover: #F0F0F0;
  --row-alt: #FFFFFF;
  --row-zebra: #FAFAFA;

  --input-bg: #FFFFFF;
  --input-text: #111111;
  --input-border: #D8D8D8;

  --topbar-bg: #111111;
  --topbar-text: #FFFFFF;

  --side-bg: #1A5C2A;
  --side-text: #FFFFFF;
  --side-hover-bg: #15481F;
  --side-active-bg: #3DBA4E;
  --side-active-text: #111111;

  --table-header-bg: #1A5C2A;
  --table-header-text: #FFFFFF;

  --btn-primary-bg: #1F7A3D;
  --btn-primary-text: #FFFFFF;
  --btn-secondary-bg: #111111;
  --btn-secondary-text: #FFFFFF;

  --kpi-accent: #1A5C2A;
  --link: #1A5C2A;
}

body.dark-mode {
  --brand-green: #3DBA4E;
  --brand-green-dark: #1A5C2A;

  --green: #3DBA4E;
  --green-dark: #3DBA4E;
  --green-soft: #1B2A1F;

  --bg: #121212;
  --card: #1E1E1E;
  --border: #2A2A2A;
  --text: #E0E0E0;
  --text-secondary: #B0B0B0;
  --muted: #9A9A9A;

  --warn: #F0A463;
  --warn-bg: #3A2A17;
  --crit: #F08E85;
  --crit-bg: #3A1F1C;
  --ok: #3DBA4E;
  --ok-bg: #1B2A1F;

  --shadow: none;

  --row-hover: #262626;
  --row-alt: #1E1E1E;
  --row-zebra: #232323;

  --input-bg: #1B1B1B;
  --input-text: #E0E0E0;
  --input-border: #333333;

  --topbar-bg: #000000;
  --topbar-text: #FFFFFF;

  --side-bg: #111111;
  --side-text: #E0E0E0;
  --side-hover-bg: #1C1C1C;
  --side-active-bg: #3DBA4E;
  --side-active-text: #111111;

  --table-header-bg: #1A5C2A;
  --table-header-text: #FFFFFF;

  --btn-primary-bg: #1F7A3D;
  --btn-primary-text: #FFFFFF;
  --btn-secondary-bg: #FFFFFF;
  --btn-secondary-text: #111111;

  --kpi-accent: #3DBA4E;
  --link: #3DBA4E;
}

/* Dark-mode targeted overrides */
body.dark-mode .logo-mark { background: #3DBA4E; color: #111111; }
body.dark-mode .btn.btn-ghost { background: #1B1B1B; color: #E0E0E0; border-color: #333; }
body.dark-mode .btn.btn-ghost:hover { background: #262626; color: #FFFFFF; }
body.dark-mode .badge.draft, body.dark-mode .badge.declined,
body.dark-mode .badge.void, body.dark-mode .badge.expired,
body.dark-mode .badge.tier-standard { background: #222; color: #C0C0C0; }
body.dark-mode .status-pill.status-overdue { background: #3A1F1C; color: #F08E85; border-color: #6C2E28; }
body.dark-mode .status-pill.status-due-soon { background: #3A2A17; color: #F0A463; border-color: #6F4A26; }
body.dark-mode .status-pill.status-due-later { background: #1C2538; color: #97B1EF; border-color: #36497A; }
body.dark-mode .status-pill.status-paid { background: #1B2A1F; color: #3DBA4E; border-color: #2A4D34; }
body.dark-mode .status-pill.status-sent { background: #1C2538; color: #97B1EF; border-color: #36497A; }
body.dark-mode .status-pill.status-draft { background: #232323; color: #C0C0C0; border-color: #353535; }
body.dark-mode .status-pill.status-deposit { background: #2A2538; color: #C8B8FF; border-color: #4C3D80; }
body.dark-mode tr.contacts-detail td { background: #181818; }
body.dark-mode .feed .tag { background: #1B2A1F; color: #3DBA4E; }
body.dark-mode .alert { color: var(--text); }
body.dark-mode a { color: #3DBA4E; }
body.dark-mode .page-h h1 { color: #3DBA4E; }
body.dark-mode .card h2 { color: #3DBA4E; }
body.dark-mode .tab.active { background: #1E1E1E; color: #3DBA4E; }
body.dark-mode .kpi .value { color: #3DBA4E; }
body.dark-mode .invoice-row.status-overdue td,
body.dark-mode .invoice-row.status-overdue .balance-cell { color: #F08E85; }
body.dark-mode .invoice-row.status-paid td,
body.dark-mode .invoice-row.status-paid .balance-cell { color: #3DBA4E; }
body.dark-mode .zone-cell { background: #1E1E1E; color: var(--text); }
body.dark-mode .zone-cell.has-stock { background: #1B2A1F; }
body.dark-mode .zone-cell.low-stock { background: #3A2A17; }
body.dark-mode .zone-cell.qc-issue { background: #3A1F1C; }
body.dark-mode .zone-cell.empty { background: #1E1E1E; opacity: 0.55; }
body.dark-mode .zone-cell .code { color: #3DBA4E; }
body.dark-mode .totals-box .row.total { color: #3DBA4E; border-top-color: #3DBA4E; }
body.dark-mode table.tbl tr:nth-child(even) td { background: var(--row-zebra); }
body.dark-mode table.tbl tr:hover td { background: var(--row-hover); }

/* Topbar */
.topbar { background: var(--topbar-bg); color: var(--topbar-text); }

/* Theme toggle button */
.theme-toggle {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.35);
  color: #fff;
  border-radius: 4px;
  padding: 0.25rem 0.55rem;
  font-size: 1rem;
  cursor: pointer;
  line-height: 1;
}
.theme-toggle:hover { background: rgba(255,255,255,0.1); }
.theme-icon-light { display: inline; }
.theme-icon-dark { display: none; }
body.dark-mode .theme-icon-light { display: none; }
body.dark-mode .theme-icon-dark { display: inline; }

* { box-sizing: border-box; }
html, body { background: var(--bg); }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--text);
  font-size: 14px;
  line-height: 1.45;
  position: relative;
  min-height: 100vh;
}

/* Watermark — fixed, behind all content, tinted green in dark mode */
body::before {
  content: "";
  position: fixed;
  top: 0; left: 220px; right: 0; bottom: 0;
  background-image: url("/static/img/logo.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: min(70vmin, 720px) auto;
  opacity: 0.04;
  pointer-events: none;
  z-index: 0;
}
body.dark-mode::before {
  opacity: 0.04;
  filter: brightness(0) saturate(100%) invert(60%) sepia(53%) saturate(640%) hue-rotate(80deg) brightness(95%) contrast(90%);
}
@media (max-width: 800px) { body::before { left: 0; } }
.topbar, .layout { position: relative; z-index: 1; }

a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex;
  align-items: center;
  padding: 0.6rem 1rem;
  gap: 0.75rem;
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--border);
}
.nav-toggle {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: 4px;
  font-size: 1.1rem;
  padding: 0.25rem 0.6rem;
  cursor: pointer;
  display: none;
}
.brand { display: flex; align-items: center; gap: 0.6rem; color: #fff; }
.brand:hover { text-decoration: none; }
.logo-mark {
  background: var(--brand-green);
  color: var(--brand-black);
  font-weight: 800;
  width: 32px; height: 32px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  letter-spacing: -1px;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name { font-weight: 700; }
.brand-sub { font-size: 0.7rem; opacity: 0.8; }

/* Weather strip in top bar */
.weather-strip {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #fff;
  font-size: 0.85rem;
  padding: 0.2rem 0.6rem;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 4px;
  white-space: nowrap;
}
.weather-strip:hover { background: rgba(255,255,255,0.08); text-decoration: none; color: #fff; }
.weather-strip .wx-icon { font-size: 1rem; line-height: 1; }
.weather-strip .wx-temp { font-weight: 700; color: #3DBA4E; }
.weather-strip .wx-cond { color: #DDD; }
.weather-strip .wx-wind { color: #BBB; font-size: 0.78rem; }
@media (max-width: 700px) { .weather-strip .wx-wind, .weather-strip .wx-cond { display: none; } }

.layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: calc(100vh - 56px);
}
.side {
  background: var(--side-bg);
  border-right: 1px solid var(--border);
  padding: 0.75rem 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.side a {
  padding: 0.55rem 0.75rem;
  border-radius: 4px;
  color: var(--side-text);
  font-weight: 500;
}
.side a:hover { background: var(--side-hover-bg); text-decoration: none; }
.side a.active {
  background: var(--side-active-bg);
  color: var(--side-active-text);
  font-weight: 700;
}

.content {
  padding: 1.25rem;
  max-width: 100%;
  overflow-x: hidden;
  position: relative;
  z-index: 1;
}

.page-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin: 0 0 1rem;
  flex-wrap: wrap;
}
.page-h h1 { margin: 0; font-size: 1.4rem; color: var(--brand-green-dark); font-weight: 700; }
.page-h .actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 1rem;
  box-shadow: var(--shadow);
  color: var(--text);
}
.card + .card { margin-top: 1rem; }
.card h2 { margin: 0 0 0.75rem; font-size: 1.05rem; color: var(--brand-green-dark); font-weight: 700; }
.card h3 { margin: 0 0 0.5rem; font-size: 0.9rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; }

.grid { display: grid; gap: 1rem; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 900px) { .grid-2, .grid-3, .grid-4, .grid-5 { grid-template-columns: 1fr; } }

/* Inventory + customer flag dots */
.inv-flag { font-size: 1rem; line-height: 1; margin-left: 4px; cursor: help; }
.inv-flag.flag-red    { color: #B00020; }
.inv-flag.flag-orange { color: #E68900; }
.inv-flag.flag-yellow { color: #C9A227; }
.inv-flag.flag-blue   { color: #234A99; }
.inv-flag.flag-green  { color: #2F6B3A; }

/* KPI card — Robinhood-style left accent */
.kpi { text-align: left; border-left: 4px solid var(--kpi-accent); }
.kpi .label { color: var(--muted); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; }
.kpi .value { font-size: 1.75rem; font-weight: 700; color: var(--brand-green-dark); margin-top: 0.2rem; }

.progress {
  height: 8px;
  background: var(--green-soft);
  border-radius: 4px;
  overflow: hidden;
  margin-top: 6px;
}
.progress > div {
  height: 100%;
  background: var(--brand-green);
}

.alert {
  padding: 0.6rem 0.75rem;
  border-radius: 4px;
  border-left: 4px solid var(--warn);
  background: var(--warn-bg);
  display: flex; gap: 0.6rem;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}
.alert.alert-critical { border-left-color: var(--crit); background: var(--crit-bg); }
.alert.alert-info { border-left-color: var(--brand-green); background: var(--ok-bg); }
.alert .title { font-weight: 600; }
.alert .body { color: var(--muted); font-size: 0.85rem; margin-top: 2px; }
.alert form { margin: 0; }

.banner {
  padding: 0.7rem 0.85rem;
  border-radius: 4px;
  border-left: 4px solid var(--warn);
  background: var(--warn-bg);
  color: var(--text);
  margin-bottom: 1rem;
  font-weight: 500;
}
.banner.banner-crit { border-left-color: var(--crit); background: var(--crit-bg); }
.banner.banner-ok { border-left-color: var(--brand-green); background: var(--ok-bg); }

.feed { list-style: none; padding: 0; margin: 0; }
.feed li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
}
.feed li:last-child { border-bottom: 0; }
.feed .when { color: var(--muted); font-size: 0.8rem; white-space: nowrap; }
.feed .tag {
  display: inline-block;
  background: var(--green-soft);
  color: var(--brand-green-dark);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 2px 6px;
  border-radius: 3px;
  margin-right: 4px;
}

table.tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--card);
}
table.tbl th, table.tbl td {
  padding: 0.55rem 0.6rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
  color: var(--text);
}
table.tbl th { background: var(--table-header-bg); color: var(--table-header-text); font-weight: 700; }
table.tbl tr:nth-child(even) td { background: var(--row-alt); }
table.tbl tr:hover td { background: var(--row-hover); }
table.tbl td.right, table.tbl th.right { text-align: right; }
table.tbl td.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Buttons — flat, sharp */
.btn {
  display: inline-block;
  border: 1px solid var(--btn-primary-bg);
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  padding: 0.45rem 0.85rem;
  border-radius: 4px;
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
}
.btn:hover { background: #26934A; border-color: #26934A; text-decoration: none; color: #fff; }
.btn.btn-ghost {
  background: var(--btn-secondary-bg);
  border-color: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
}
.btn.btn-ghost:hover { background: #2a2a2a; border-color: #2a2a2a; color: #fff; }
.btn.btn-danger { background: var(--crit); border-color: var(--crit); color: #fff; }
.btn.btn-danger:hover { background: #8A201A; border-color: #8A201A; color: #fff; }
.btn-sm { padding: 0.3rem 0.55rem; font-size: 0.78rem; }

.tabs { display: flex; gap: 0.25rem; border-bottom: 1px solid var(--border); margin-bottom: 1rem; flex-wrap: wrap; }
.tab {
  padding: 0.5rem 0.85rem;
  border-radius: 4px 4px 0 0;
  color: var(--muted);
  border: 1px solid transparent;
  border-bottom: 0;
  font-size: 0.85rem;
}
.tab.active { background: var(--card); color: var(--brand-green-dark); border-color: var(--border); font-weight: 700; }
.tab:hover { text-decoration: none; background: var(--green-soft); }

form .field { margin-bottom: 0.75rem; display: flex; flex-direction: column; }
form label { font-size: 0.8rem; color: var(--muted); margin-bottom: 0.2rem; text-transform: uppercase; letter-spacing: 0.04em; }
form input, form select, form textarea {
  padding: 0.5rem 0.6rem;
  border: 1px solid var(--input-border);
  border-radius: 4px;
  font: inherit;
  background: var(--input-bg);
  color: var(--input-text);
}
form textarea { min-height: 70px; resize: vertical; }
form input:focus, form select:focus, form textarea:focus {
  outline: 2px solid var(--green-soft);
  border-color: var(--brand-green);
}
form input::placeholder, form textarea::placeholder { color: var(--muted); opacity: 0.7; }

.flashes { margin-bottom: 0.75rem; }
.flash {
  padding: 0.55rem 0.75rem;
  border-radius: 4px;
  margin-bottom: 0.4rem;
  border-left: 4px solid var(--brand-green);
  background: var(--green-soft);
  color: var(--text);
}
.flash-err { border-left-color: var(--crit); background: var(--crit-bg); }
.flash-message, .flash-ok { border-left-color: var(--brand-green); background: var(--ok-bg); }

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.badge.draft { background: #EEE; color: #555; }
.badge.sent { background: #E0EAFF; color: #234A99; }
.badge.accepted, .badge.paid { background: var(--brand-green); color: var(--brand-black); }
.badge.declined, .badge.void, .badge.expired { background: #EFEFEF; color: #777; }
.badge.overdue, .badge.critical { background: var(--crit-bg); color: var(--crit); }
.badge.converted { background: #E9DEFE; color: #5B3992; }
.badge.tier-standard { background: #EEE; color: #555; }
.badge.tier-wholesale { background: #FFF3E0; color: var(--warn); }
.badge.tier-premium { background: #E9DEFE; color: #5B3992; }
.badge.tier-landscape { background: var(--brand-green); color: var(--brand-black); }

.muted { color: var(--muted); }
.right { text-align: right; }
.row { display: flex; gap: 0.6rem; flex-wrap: wrap; align-items: center; }
.row > * { flex: 1; min-width: 0; }
.row.tight { gap: 0.4rem; }
.spacer { flex: 1; }

.zone-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: 6px;
}
.zone-cell {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 0.45rem 0.3rem;
  text-align: center;
  font-size: 0.78rem;
  position: relative;
  color: var(--text);
  text-decoration: none;
}
.zone-cell:hover { background: var(--green-soft); text-decoration: none; }
.zone-cell .code { font-weight: 700; color: var(--brand-green-dark); font-size: 0.92rem; }
.zone-cell .count { font-size: 0.7rem; color: var(--muted); }
.zone-cell .sku { font-size: 0.68rem; color: var(--muted); }
.zone-cell.has-stock { background: var(--ok-bg); }
.zone-cell.low-stock { background: var(--warn-bg); }
.zone-cell.qc-issue { background: var(--crit-bg); }
.zone-cell.empty { opacity: 0.55; }

/* Mobile */
@media (max-width: 800px) {
  .layout { grid-template-columns: 1fr; }
  .side {
    position: fixed;
    top: 56px; left: -240px;
    bottom: 0;
    width: 220px;
    transition: left 0.2s;
    z-index: 50;
  }
  body.nav-open .side { left: 0; }
  .nav-toggle { display: inline-block; }
  .content { padding: 0.85rem; }
  table.tbl { font-size: 0.82rem; }
  table.tbl th, table.tbl td { padding: 0.4rem 0.35rem; }
}

@media print {
  .topbar, .side, .actions, .nav-toggle, .flashes { display: none !important; }
  body::before { display: none !important; }
  .layout { grid-template-columns: 1fr; }
  .card { box-shadow: none; border: 1px solid #ccc; }
}

.line-items { width: 100%; border-collapse: collapse; }
.line-items th, .line-items td { padding: 0.4rem; }
.line-items input, .line-items select { width: 100%; }
.line-items .col-desc { width: 38%; }
.line-items .col-size { width: 12%; }
.line-items .col-qty { width: 10%; }
.line-items .col-price { width: 15%; }
.line-items .col-total { width: 15%; text-align: right; }
.line-items .col-act { width: 5%; }

.totals-box { max-width: 320px; margin-left: auto; }
.totals-box .row { justify-content: space-between; padding: 0.25rem 0; }
.totals-box .row.total { border-top: 2px solid var(--brand-green); font-weight: 700; font-size: 1.05rem; color: var(--brand-green-dark); margin-top: 0.3rem; padding-top: 0.5rem; }

/* Invoice list status pills */
.status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 99px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.status-pill.status-overdue { background: #FDE7E5; color: #A8281F; border: 1px solid #F1B9B3; }
.status-pill.status-due-soon { background: #FFF3E0; color: #B35A00; border: 1px solid #F0C98A; }
.status-pill.status-due-later { background: #E0EAFF; color: #234A99; border: 1px solid #B6C7EF; }
.status-pill.status-paid { background: #3DBA4E; color: #111111; border: 1px solid #2A9C3C; }
.status-pill.status-sent { background: #E0EAFF; color: #234A99; border: 1px solid #B6C7EF; }
.status-pill.status-draft { background: #EEE; color: #555; border: 1px solid #D0D0D0; }
.status-pill.status-void { background: #EFEFEF; color: #888; border: 1px solid #D8D8D8; text-decoration: line-through; }
.status-pill.status-deposit { background: #EDE4FF; color: #5B3992; border: 1px solid #C2B3EC; }
.status-pill.status-default { background: #EEE; color: #555; border: 1px solid #D0D0D0; }

/* Fulfillment status pills */
.status-pill.fl-pending { background: #EEE; color: #555; border: 1px solid #D0D0D0; }
.status-pill.fl-being-pulled { background: #FFF3E0; color: #B35A00; border: 1px solid #F0C98A; }
.status-pill.fl-ready { background: #3DBA4E; color: #111; border: 1px solid #2A9C3C; }
.status-pill.fl-scheduled { background: #E0EAFF; color: #234A99; border: 1px solid #B6C7EF; }
.status-pill.fl-out-for-delivery { background: #EDE4FF; color: #5B3992; border: 1px solid #C2B3EC; }
.status-pill.fl-delivered { background: #1A5C2A; color: #FFF; border: 1px solid #1A5C2A; }
.status-pill.fl-picked-up { background: #1A5C2A; color: #FFF; border: 1px solid #1A5C2A; }
body.dark-mode .status-pill.fl-pending { background: #232323; color: #C0C0C0; border-color: #353535; }
body.dark-mode .status-pill.fl-being-pulled { background: #3A2A17; color: #F0A463; border-color: #6F4A26; }
body.dark-mode .status-pill.fl-scheduled { background: #1C2538; color: #97B1EF; border-color: #36497A; }
body.dark-mode .status-pill.fl-out-for-delivery { background: #2A2538; color: #C8B8FF; border-color: #4C3D80; }

.tbl-invoices td.nowrap { white-space: nowrap; }
.tbl-invoices tr.invoice-row td { transition: background-color 120ms; }

/* Zoho-style row tinting */
.invoice-row.status-overdue td:nth-child(4),
.invoice-row.status-overdue .balance-cell { color: #A8281F; font-weight: 600; }
.invoice-row.status-due-soon td:nth-child(4),
.invoice-row.status-due-soon .balance-cell { color: #B35A00; font-weight: 600; }
.invoice-row.status-due-later td:nth-child(4),
.invoice-row.status-due-later .balance-cell { color: #234A99; }
.invoice-row.status-paid td:nth-child(4),
.invoice-row.status-paid .balance-cell { color: #1A5C2A; }
.invoice-row.status-paid td:nth-child(2) { color: #1A5C2A; }

/* Sourcing supplier badges */
.supplier-badge {
  display: inline-block;
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 99px;
  background: var(--green-soft);
  color: var(--brand-green-dark);
}
.supplier-badge.low { background: #FFF3E0; color: var(--warn); }
.supplier-badge.unconfirmed { background: #EEF; color: #234A99; }

.kpi-positive .value { color: var(--brand-green-dark); }
.kpi-negative .value { color: var(--crit); }
.kpi-neutral .value { color: var(--text); }
body.dark-mode .kpi-positive .value { color: #3DBA4E; }
body.dark-mode .kpi-negative .value { color: #F08E85; }
body.dark-mode .kpi-neutral .value { color: var(--text); }

.chart-card svg { width: 100%; height: auto; display: block; max-height: 280px; }

/* ===== Dashboard KPI cards (compact, dense, informational) ===== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}
@media (max-width: 900px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .kpi-grid { grid-template-columns: 1fr; } }

.kpi-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 3px solid #3DBA4E;
  border-radius: 12px;
  padding: 14px 16px;
  max-height: 100px;
  overflow: hidden;
  /* staggered fade-in + slide-up; delay set inline per card */
  opacity: 0;
  animation: kpiIn 0.45s ease-out forwards;
}
.kpi-card .label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #888;
  font-weight: 600;
}
.kpi-card .value {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.15;
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.kpi-card .sub { font-size: 0.75rem; color: var(--muted); margin-top: 2px; }

.kpi-card.kpi-pos .value { color: var(--brand-green-dark); }
.kpi-card.kpi-neg .value { color: var(--crit); }
.kpi-card.kpi-neutral .value { color: var(--text); }
.kpi-card.kpi-overdue .value { color: #e05252; }
.kpi-card.kpi-ytd .value { color: #4caf50; }
body.dark-mode .kpi-card.kpi-pos .value { color: #3DBA4E; }

@keyframes kpiIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}
@keyframes overduePulse {
  0%   { box-shadow: 0 0 0 0 rgba(224,82,82,0.55); }
  70%  { box-shadow: 0 0 0 12px rgba(224,82,82,0); }
  100% { box-shadow: 0 0 0 0 rgba(224,82,82,0); }
}
/* Overdue card with a balance pulses red once after the fade-in lands. */
.kpi-card.pulse-overdue {
  animation: kpiIn 0.45s ease-out forwards, overduePulse 1s ease-out 0.5s 1;
}
@media (prefers-reduced-motion: reduce) {
  .kpi-card { opacity: 1; animation: none; }
}

/* Revenue bars grow upward from the baseline on load (easeOutQuart). */
.rev-chart .rev-bar {
  transform: scaleY(0);
  transform-box: fill-box;
  transform-origin: bottom;
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.rev-chart.grown .rev-bar { transform: scaleY(1); }
.rev-chart .rev-bar.current { filter: drop-shadow(0 0 5px rgba(46,204,113,0.85)); }
.rev-chart .rev-bar:hover { fill: #2ecc71; }
@media (prefers-reduced-motion: reduce) {
  .rev-chart .rev-bar { transform: scaleY(1); transition: none; }
}

/* Revenue progress bars animate from 0 to target width on load. */
.progress > div { transition: width 1s ease-out; }

/* Consistent 16px spacing between dashboard sections. */
.dash-widget + .dash-widget,
.dash-grid > .dash-widget { margin-top: 16px; }
.dash-grid > .dash-widget:first-child { margin-top: 0; }

.dash-grid { display: block; }
.dash-grid.editing .dash-widget {
  outline: 2px dashed var(--brand-green);
  outline-offset: -2px;
  cursor: grab;
}
.dash-grid.editing .dash-widget:active { cursor: grabbing; }
.dash-grid.editing .dash-widget::before {
  content: "↕ drag to reorder";
  display: block;
  font-size: 0.7rem;
  color: var(--brand-green-dark);
  background: var(--green-soft);
  padding: 2px 6px;
  margin-bottom: 0.4rem;
  border-radius: 3px;
  width: max-content;
}

.import-inline { display: inline-block; margin: 0; }

/* Customer expandable rows */
.expand-btn {
  background: transparent; border: 0; cursor: pointer;
  font-size: 0.9rem; color: var(--brand-green-dark);
  padding: 2px 4px; line-height: 1;
}
.expand-btn:hover { color: var(--brand-green); }
tr.contacts-detail td { background: var(--row-zebra); padding: 0.6rem 1rem; }
.tbl-nested th, .tbl-nested td { font-size: 0.82rem; padding: 0.3rem 0.5rem; }

/* Customer contacts row */
.contact-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1.2fr 0.6fr 0.4fr;
  gap: 0.4rem;
  align-items: end;
  margin-bottom: 0.4rem;
}
.contact-row label { font-size: 0.7rem; }
@media (max-width: 900px) {
  .contact-row { grid-template-columns: 1fr 1fr; }
}

/* Toggle switch */
.toggle { position: relative; display: inline-block; width: 38px; height: 20px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle .slider {
  position: absolute; cursor: pointer; inset: 0;
  background: #CCC; border-radius: 20px; transition: 0.2s;
}
.toggle .slider::before {
  position: absolute; content: ""; height: 14px; width: 14px;
  left: 3px; bottom: 3px; background: #FFF; border-radius: 50%; transition: 0.2s;
}
.toggle input:checked + .slider { background: var(--brand-green); }
.toggle input:checked + .slider::before { transform: translateX(18px); }
body.dark-mode .toggle .slider { background: #444; }
body.dark-mode .toggle input:checked + .slider { background: var(--brand-green); }

/* ===== Weather page ===== */
.weather-hero {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
}
.weather-hero .wx-now-icon { font-size: 3.5rem; line-height: 1; }
.weather-hero .wx-now-temp { font-size: 3rem; font-weight: 700; color: var(--brand-green-dark); line-height: 1; }
.weather-hero .wx-now-cond { color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.85rem; }
.weather-hero .wx-meta { display: grid; grid-template-columns: repeat(2, auto); gap: 0.3rem 1rem; font-size: 0.85rem; }
.weather-hero .wx-meta .lbl { color: var(--muted); }
body.dark-mode .weather-hero .wx-now-temp { color: var(--brand-green); }

.wx-hourly {
  display: flex;
  overflow-x: auto;
  gap: 0.4rem;
  padding-bottom: 0.4rem;
}
.wx-hour {
  flex: 0 0 auto;
  min-width: 78px;
  text-align: center;
  padding: 0.5rem 0.4rem;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--card);
}
.wx-hour .h { font-size: 0.78rem; color: var(--muted); }
.wx-hour .i { font-size: 1.4rem; line-height: 1.1; }
.wx-hour .t { font-weight: 700; }

.wx-daily {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.4rem;
}
.wx-day {
  display: grid;
  grid-template-columns: 110px 50px 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.6rem;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--card);
}
.wx-day .d { font-weight: 700; }
.wx-day .i { font-size: 1.4rem; line-height: 1; text-align: center; }
.wx-day .lo { color: var(--muted); }
.wx-day .hi { font-weight: 700; }
.wx-day .pop { color: #234A99; font-size: 0.82rem; }

/* ===== Fulfillment board ===== */
.fl-board {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 1000px) { .fl-board { grid-template-columns: 1fr; } }
.fl-col h2 { display: flex; justify-content: space-between; align-items: baseline; }
.fl-col h2 .count {
  background: var(--brand-green);
  color: var(--brand-black);
  padding: 0 8px;
  border-radius: 99px;
  font-size: 0.75rem;
  font-weight: 700;
}
.fl-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--brand-green-dark);
  border-radius: 4px;
  padding: 0.7rem 0.8rem;
  margin-bottom: 0.6rem;
}
.fl-card.is-delivery { border-left-color: #234A99; }
.fl-card.is-done { border-left-color: var(--brand-green); opacity: 0.85; }
.fl-card .row1 { display: flex; justify-content: space-between; align-items: center; gap: 0.5rem; }
.fl-card .row1 a { font-weight: 700; }
.fl-card .row1 .total { font-weight: 700; color: var(--brand-green-dark); }
.fl-card .row2 { color: var(--muted); font-size: 0.85rem; margin-top: 2px; }
.fl-card .row3 { margin-top: 6px; display: flex; gap: 0.4rem; flex-wrap: wrap; align-items: center; }
.fl-card details { margin-top: 0.5rem; }
.fl-card summary { cursor: pointer; color: var(--brand-green-dark); font-size: 0.85rem; }
.fl-card .items { margin: 0.4rem 0 0; padding-left: 1.1rem; }
.fl-card .items li { font-size: 0.83rem; }
.fl-card form { margin: 0; display: inline-flex; gap: 0.3rem; flex-wrap: wrap; }
body.dark-mode .fl-card { background: #1E1E1E; }

/* Compliance card */
.compliance-card { border-left: 4px solid var(--brand-green); }
.compliance-card.expired { border-left-color: var(--crit); }
.compliance-card.expiring { border-left-color: var(--warn); }
.compliance-card .lic-num { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 1.05rem; font-weight: 700; }
.compliance-card .lic-status { display: inline-block; padding: 2px 10px; border-radius: 99px; font-size: 0.72rem; font-weight: 700; }
.compliance-card .lic-status.active { background: var(--brand-green); color: var(--brand-black); }
.compliance-card .lic-status.expired { background: var(--crit); color: #FFF; }
.compliance-card .lic-status.expiring { background: var(--warn); color: #FFF; }
