:root {
  color-scheme: light;
  --bg: #f5f6f8;
  --panel: #ffffff;
  --panel-2: #f9fafb;
  --text: #1d2430;
  --muted: #697386;
  --line: #dfe4ea;
  --line-strong: #c9d1da;
  --accent: #1f6feb;
  --accent-soft: #eaf2ff;
  --success: #1d7f4f;
  --warning: #a15c00;
  --shadow: 0 18px 45px rgba(20, 35, 55, 0.08);
  --radius: 8px;
  --sidebar: #111827;
  --sidebar-muted: #9ca3af;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Noto Sans TC", "PingFang TC", "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
}

body.auth-screen-open {
  overflow: hidden;
}

body.theme-dark {
  color-scheme: dark;
  --bg: #0b1220;
  --panel: #0f1724;
  --panel-2: #111c2e;
  --text: #eef5ff;
  --muted: #9fb0c8;
  --line: #26344a;
  --line-strong: #475569;
  --accent: #3b82f6;
  --accent-soft: #13264a;
  --success: #34d399;
  --warning: #f59e0b;
  --shadow: none;
  --sidebar: #0a101c;
  --sidebar-muted: #94a3b8;
}

body.theme-light {
  color-scheme: light;
}

button,
input {
  font: inherit;
}

textarea,
select {
  font: inherit;
}

.auth-screen {
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: grid;
  place-items: center;
  padding: 22px;
  background:
    radial-gradient(circle at 78% 28%, rgba(69, 55, 120, .28), transparent 30%),
    radial-gradient(circle at 24% 68%, rgba(13, 67, 99, .42), transparent 34%),
    linear-gradient(135deg, #081425 0%, #101a33 100%);
}

.auth-login-card {
  width: min(420px, 100%);
  border: 1px solid rgba(148, 163, 184, .26);
  border-radius: 18px;
  background: rgba(13, 23, 38, .78);
  box-shadow: 0 24px 70px rgba(2, 8, 23, .34);
  padding: 18px;
  color: #e8eef7;
  backdrop-filter: blur(18px);
}

.auth-login-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.auth-login-title {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.auth-login-title img {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: #fff;
  object-fit: cover;
}

.auth-login-title strong {
  color: #f8fafc;
  font-size: 20px;
  font-weight: 950;
  letter-spacing: 0;
}

.auth-screen-theme {
  min-height: 36px;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 999px;
  background: rgba(15, 23, 42, .45);
  color: #eef2f8;
  padding: 7px 12px;
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
  cursor: pointer;
}

.auth-screen-theme:hover {
  border-color: rgba(203, 213, 225, .46);
}

.auth-login-body {
  display: grid;
  gap: 10px;
}

.auth-login-google-frame {
  min-height: 44px;
  display: grid;
  place-items: center;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.auth-screen-google-slot {
  min-height: 44px;
  display: grid;
  place-items: center;
  width: 100%;
}

.auth-login-button,
.auth-login-secondary {
  min-height: 46px;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 8px;
  background: rgba(30, 41, 59, .72);
  color: #eef2f8;
  padding: 11px 14px;
  font: inherit;
  font-size: 16px;
  font-weight: 950;
}

.auth-login-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.auth-login-button.is-disabled {
  color: #cbd5e1;
}

.auth-login-secondary {
  min-height: 38px;
  background: rgba(15, 23, 42, .38);
  color: #dbe7f0;
  font-size: 13px;
  cursor: pointer;
}

.auth-login-secondary:hover {
  border-color: rgba(203, 213, 225, .46);
}

.google-g {
  width: 18px;
  height: 18px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #fff;
  color: #4285f4;
  font-size: 13px;
  font-weight: 950;
}

.auth-login-setup {
  display: grid;
  gap: 4px;
  border: 1px solid rgba(216, 171, 116, .32);
  border-radius: 8px;
  background: rgba(120, 53, 15, .22);
  padding: 10px 12px;
}

.auth-login-setup strong {
  color: #fde68a;
  font-size: 13px;
}

.auth-login-setup span,
.auth-login-status,
.auth-login-note {
  color: #aebbd0;
  font-size: 12px;
  line-height: 1.45;
}

.auth-login-status {
  min-height: 28px;
  border-radius: 8px;
  background: rgba(15, 23, 42, .28);
  padding: 7px 10px;
}

.auth-login-status.is-error {
  color: #fecaca;
  background: rgba(127, 29, 29, .22);
}

.auth-login-note {
  margin: 14px 0 0;
  font-weight: 700;
}

body.auth-login-light .auth-screen {
  background:
    radial-gradient(circle at 78% 24%, rgba(161, 185, 168, .28), transparent 30%),
    radial-gradient(circle at 18% 70%, rgba(200, 223, 232, .42), transparent 34%),
    linear-gradient(135deg, #f8fbfa 0%, #eef4f7 100%);
}

body.auth-login-light .auth-login-card {
  border-color: rgba(180, 191, 203, .7);
  background: rgba(255, 255, 255, .9);
  color: #223044;
  box-shadow: 0 24px 70px rgba(56, 74, 95, .16);
}

body.auth-login-light .auth-login-title strong {
  color: #203147;
}

body.auth-login-light .auth-screen-theme,
body.auth-login-light .auth-login-button,
body.auth-login-light .auth-login-secondary {
  border-color: #d6e0ea;
  background: #f8fafc;
  color: #223044;
}

body.auth-login-light .auth-login-secondary:hover,
body.auth-login-light .auth-screen-theme:hover {
  border-color: #b7c6d6;
}

body.auth-login-light .auth-login-setup {
  border-color: #e4cfaa;
  background: #fff8ed;
}

body.auth-login-light .auth-login-setup strong {
  color: #7c4a03;
}

body.auth-login-light .auth-login-setup span,
body.auth-login-light .auth-login-status,
body.auth-login-light .auth-login-note {
  color: #607086;
}

.shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
}

.sidebar {
  background: var(--sidebar);
  color: #fff;
  padding: 18px 14px;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: auto;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 8px 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.mark {
  width: 38px;
  height: 38px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: #fff;
  color: #111827;
  font-weight: 900;
}

.brand-title {
  font-size: 15px;
  font-weight: 900;
}

.brand-sub {
  color: var(--sidebar-muted);
  font-size: 12px;
  margin-top: 2px;
}

.brand-copy {
  min-width: 0;
  flex: 1;
}

.theme-toggle {
  min-height: 36px;
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, .94);
  color: #314155;
  padding: 7px 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(51, 72, 95, .08);
}

.theme-toggle:hover {
  border-color: var(--line-strong);
  transform: translateY(-1px);
}

.theme-icon {
  font-size: 14px;
  line-height: 1;
}

.theme-label {
  line-height: 1;
}

.nav {
  display: grid;
  gap: 6px;
  margin-top: 16px;
}

.nav button {
  width: 100%;
  border: 0;
  border-radius: 8px;
  color: #d1d5db;
  background: transparent;
  padding: 10px 11px;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.nav button:hover,
.nav button.active {
  background: rgba(255,255,255,.1);
  color: #fff;
}

.count {
  color: var(--sidebar-muted);
  font-size: 12px;
}

.main {
  padding: 22px;
  min-width: 0;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 26px;
  letter-spacing: 0;
}

h2 {
  font-size: 17px;
  letter-spacing: 0;
}

#pageSubtitle,
#sectionHint,
#detailDesc {
  color: var(--muted);
  margin-top: 6px;
  line-height: 1.5;
}

.top-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.auth-widget {
  min-width: 0;
}

.auth-placeholder,
.auth-logout {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--text);
  padding: 7px 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.auth-placeholder {
  color: var(--muted);
}

.auth-placeholder.needs-config {
  background: #fffaf0;
  color: #7c5420;
}

.auth-user {
  min-height: 40px;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  padding: 4px 5px 4px 6px;
  box-shadow: var(--shadow-soft);
}

.auth-avatar {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 12px;
  font-weight: 950;
  flex: 0 0 auto;
}

.auth-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.auth-copy {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.auth-copy strong,
.auth-copy small {
  overflow: hidden;
  max-width: 150px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth-copy strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.1;
}

.auth-copy small,
.auth-google-wrap small {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.2;
}

.auth-logout {
  min-height: 30px;
  border-color: transparent;
  background: var(--panel-2);
  cursor: pointer;
}

.auth-logout:hover {
  border-color: var(--line-strong);
}

.auth-google-wrap {
  display: grid;
  align-items: center;
  gap: 2px;
}

.google-signin-slot {
  min-height: 32px;
}

.auth-error {
  color: #b42318 !important;
}

.search {
  height: 40px;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 8px;
  padding: 0 10px;
  min-width: 300px;
}

.search span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.search input {
  border: 0;
  outline: 0;
  min-width: 0;
  flex: 1;
  background: transparent;
}

.icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}

.theme-btn {
  display: grid;
  place-items: center;
}

.operations-mode {
  background: #0b1220;
  --bg: #0b1220;
  --panel: #0f1724;
  --panel-2: #111c2e;
  --text: #eef5ff;
  --muted: #9fb0c8;
  --line: #26344a;
  --line-strong: #475569;
  --shadow: none;
}

.operations-mode .main {
  background: #0b1220;
}

.operations-mode .topbar {
  margin-bottom: 14px;
}

.operations-mode .summary-grid {
  display: none;
}

.operations-mode .top-actions {
  display: flex;
}

.operations-mode .search,
.operations-mode #compactBtn {
  display: none;
}

.operations-mode .workspace {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.operations-mode .section-head {
  display: none;
}

.operations-mode #pageSubtitle,
.operations-mode #sectionHint {
  color: #a9b8cd;
}

.operations-mode .nav .count {
  display: none;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.metric,
.workspace,
.detail {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.metric {
  padding: 14px;
}

.metric .label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.metric .value {
  margin-top: 6px;
  font-size: 24px;
  font-weight: 950;
}

.metric .note {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.workspace,
.detail {
  padding: 16px;
}

.section-head,
.detail-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
}

.view-tabs {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: var(--panel-2);
}

.tab {
  border: 0;
  background: transparent;
  padding: 8px 12px;
  cursor: pointer;
  color: var(--muted);
  font-weight: 800;
}

.tab.active {
  background: var(--panel);
  color: var(--text);
}

.cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.native-panel {
  display: grid;
  gap: 14px;
  margin-bottom: 14px;
}

.native-panel[hidden] {
  display: none;
}

.native-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
}

.native-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 14px;
}

.native-card h3 {
  margin: 0 0 8px;
  font-size: 15px;
  letter-spacing: 0;
}

.home-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.home-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 14px;
  display: grid;
  gap: 12px;
  min-height: 184px;
}

.home-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.home-card h3 {
  margin: 0;
  font-size: 17px;
}

.home-card p {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  margin-top: 6px;
}

.home-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.home-go {
  align-self: end;
  width: 100%;
}

.home-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.home-strip div {
  border: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: 8px;
  padding: 10px;
}

.home-strip strong {
  display: block;
  font-size: 22px;
}

.home-strip span {
  color: var(--muted);
  font-size: 12px;
}

.status-details summary {
  cursor: pointer;
  font-weight: 900;
}

.status-details summary + .native-muted {
  margin-top: 8px;
}

.native-muted {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.secretary-toolbar,
.command-row,
.control-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.secretary-toolbar {
  justify-content: space-between;
}

.pill-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
}

.pill-tab {
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--muted);
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
}

.pill-tab.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.kanban-mini {
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.kanban-col {
  min-width: 220px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 10px;
}

.kanban-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 13px;
  font-weight: 950;
}

.task-mini {
  background: var(--panel);
  border: 1px solid var(--line);
  border-left: 4px solid var(--line-strong);
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 8px;
}

.task-mini.in_progress {
  border-left-color: #f59e0b;
}

.task-mini.done {
  border-left-color: #1d7f4f;
}

.task-mini.todo {
  border-left-color: var(--accent);
}

.task-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.35;
}

.task-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.mini-select,
.mini-input,
.mini-textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  color: var(--text);
  padding: 8px 9px;
  font-size: 13px;
}

.mini-textarea {
  min-height: 82px;
  resize: vertical;
}

.command-row .mini-input {
  flex: 1;
  min-width: 220px;
}

.task-form-grid,
.control-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.task-form-grid .wide,
.control-grid .wide {
  grid-column: 1 / -1;
}

.progress-track {
  height: 9px;
  border-radius: 999px;
  background: #e6ebf1;
  overflow: hidden;
  margin-top: 8px;
}

.progress-fill {
  height: 100%;
  background: var(--accent);
}

.ai-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.ops-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.ops-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.ops-kpi {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  padding: 12px;
}

.ops-kpi span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.ops-kpi strong {
  display: block;
  margin-top: 6px;
  font-size: 22px;
  line-height: 1.1;
}

.delta {
  display: inline-flex;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 950;
}

.delta.up {
  color: var(--success);
}

.delta.down {
  color: #b42318;
}

.ops-split {
  display: grid;
  gap: 9px;
  margin-top: 8px;
}

.didi-ops-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
}

.ops-panel {
  background: #0f1724;
  border: 1px solid #324259;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .16);
}

.ops-panel-title {
  font-size: 16px;
  font-weight: 950;
  margin-bottom: 10px;
  color: #f8fafc;
}

.ops-control-row,
.ops-table-head {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.ops-table-head {
  justify-content: space-between;
}

.didi-ops-page .mini-select,
.didi-ops-page .mini-input {
  width: auto;
  min-width: 96px;
  background: #0b1220;
  color: #e2e8f0;
  border-color: #475569;
}

.didi-ops-page .btn {
  background: #182235;
  border-color: #475569;
  color: #e2e8f0;
}

.ops-control-row label {
  color: #f8fafc;
  font-weight: 800;
}

.ops-control-row span,
.ops-muted-line {
  color: #cbd5e1;
  font-size: 12px;
}

.decision-risk-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 6px 0 12px;
  font-size: 14px;
  font-weight: 850;
}

.risk-dot,
.consistency-list span {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  display: inline-block;
  flex: 0 0 auto;
}

.risk-dot.high,
.consistency-list .bad {
  background: #ef4444;
}

.risk-dot.warn {
  background: #f59e0b;
}

.risk-dot.ok,
.consistency-list .ok {
  background: #22c55e;
}

.decision-grid,
.action-score-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.decision-metric-card,
.action-score-card,
.quality-card,
.ops-advice-item,
.ops-nested-box {
  border: 1px solid #334155;
  border-radius: 8px;
  background: rgba(15, 23, 42, .62);
}

.decision-metric-card,
.action-score-card,
.quality-card {
  padding: 10px;
}

.decision-metric-card.status-high {
  border-color: rgba(248, 113, 113, .75);
}

.decision-metric-card.status-warn {
  border-color: rgba(251, 191, 36, .75);
}

.decision-metric-card.status-ok {
  border-color: rgba(52, 211, 153, .55);
}

.metric-card-head,
.metric-card-foot,
.action-score-card > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.metric-card-head span,
.action-score-card span,
.quality-card span,
.ops-mix-item span {
  color: #aebbd0;
  font-size: 12px;
}

.metric-card-head b {
  color: #86efac;
  font-size: 10px;
  white-space: nowrap;
}

.status-high .metric-card-head b {
  color: #fca5a5;
}

.status-warn .metric-card-head b {
  color: #fde68a;
}

.decision-metric-card strong,
.action-score-card strong,
.quality-card strong,
.ops-mix-item strong {
  display: block;
  margin-top: 5px;
  color: #f8fafc;
  font-size: 18px;
  line-height: 1.2;
}

.metric-card-foot {
  margin-top: 6px;
  color: #94a3b8;
  font-size: 10px;
  flex-wrap: wrap;
}

.up,
.text-ok {
  color: #34d399 !important;
}

.down,
.text-danger {
  color: #f87171 !important;
}

.text-warn {
  color: #fbbf24 !important;
}

.ops-nested-box {
  margin-top: 10px;
  padding: 10px;
}

.ops-nested-box.muted {
  color: #cbd5e1;
}

.ops-box-title {
  color: #cbd5e1;
  font-size: 12px;
  margin-bottom: 8px;
}

.ops-mix-grid,
.quality-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}

.ops-mix-item small,
.quality-card small,
.action-score-card small {
  display: block;
  color: #94a3b8;
  font-size: 11px;
  margin-top: 3px;
}

.ops-progress {
  height: 6px;
  border-radius: 999px;
  background: #1e293b;
  overflow: hidden;
  margin-top: 8px;
}

.ops-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
}

.ops-progress .ok {
  background: #22c55e;
}

.ops-progress .warn {
  background: #f59e0b;
}

.ops-progress .danger {
  background: #ef4444;
}

.ops-advice-list,
.consistency-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.ops-advice-item {
  padding: 10px 12px;
}

.ops-advice-item > div {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.ops-advice-item span {
  color: #34d399;
  font-size: 12px;
  font-weight: 900;
}

.ops-advice-item.priority-p1 span {
  color: #f87171;
}

.ops-advice-item.priority-p2 span {
  color: #fbbf24;
}

.ops-advice-item strong {
  color: #f8fafc;
}

.ops-advice-item p {
  color: #cbd5e1;
  font-size: 13px;
  line-height: 1.5;
  margin-top: 3px;
}

.consistency-list div {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #e2e8f0;
  font-size: 13px;
}

.consistency-list small {
  color: #94a3b8;
}

.didi-ops-page .table-wrap {
  border-radius: 8px;
}

.didi-ops-page table {
  color: #e2e8f0;
  min-width: 760px;
}

.didi-ops-page th {
  background: #111c2e;
  color: #dbeafe;
  position: sticky;
  top: 0;
}

.didi-ops-page td,
.didi-ops-page th {
  border-bottom-color: #253349;
}

.didi-ops-page code {
  color: #bfdbfe;
}

.didi-member-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
}

.member-mgmt-panel {
  min-height: 56vh;
}

.member-block-title {
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 800;
  margin: 18px 0 8px;
}

.member-upload-area {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.member-help {
  display: inline-grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border: 1px solid #64748b;
  border-radius: 999px;
  color: #cbd5e1;
  font-size: 11px;
  cursor: help;
}

.member-upload-name,
.member-upload-message {
  min-height: 18px;
  margin-top: 6px;
  color: #cbd5e1;
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.member-upload-message {
  color: #fbbf24;
}

.member-mgmt-search-grid {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 190px 88px 88px;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

.member-mgmt-input,
.member-mgmt-select {
  width: 100%;
  height: 36px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #0b1220;
  color: #e2e8f0;
  padding: 0 10px;
}

.member-mgmt-input {
  padding: 8px 10px;
}

.member-mgmt-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
}

.member-mgmt-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  color: #e2e8f0;
  font-size: 13px;
}

.member-mgmt-table th {
  background: #111c2e;
  color: #dbeafe;
  font-weight: 900;
}

.member-mgmt-table td,
.member-mgmt-table th {
  border-bottom: 1px solid #253349;
  padding: 10px;
  text-align: left;
  vertical-align: middle;
}

.member-mgmt-row.even {
  background: rgba(30, 41, 59, .35);
}

.member-mgmt-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
  color: #cbd5e1;
  font-size: 12px;
}

.member-mgmt-pagination > div:last-child {
  display: flex;
  gap: 6px;
}

.list-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  color: var(--muted);
  font-size: 12px;
}

.list-pagination-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.list-pagination-meta strong {
  color: var(--ink);
  font-weight: 850;
}

.list-pagination-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}

.list-pagination-size {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  color: var(--ink);
  padding: 0 10px;
  font: inherit;
}

.list-pagination .btn[disabled] {
  cursor: not-allowed;
  opacity: .45;
}

.didi-member-page .btn[disabled],
.didi-ops-page .btn[disabled],
.didi-finance-page .btn[disabled] {
  cursor: not-allowed;
  opacity: .45;
}

.didi-finance-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
}

.cfo-panel {
  background: #0f1724;
  border: 1px solid #324259;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .16);
}

.cfo-toolbar,
.cfo-section-head,
.cfo-upload-toolbar,
.cfo-detail-actions,
.cfo-year-filter {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.cfo-toolbar,
.cfo-section-head {
  justify-content: space-between;
}

.cfo-sync-status {
  color: #86efac;
  font-size: 12px;
  font-weight: 800;
}

.cfo-section-title,
.cfo-upload-title {
  color: #f8fafc;
  font-size: 16px;
  font-weight: 950;
}

.cfo-upload-title {
  margin-bottom: 8px;
}

.cfo-kpi-grid {
  display: grid;
  gap: 8px;
}

.cfo-kpi-grid-top,
.cfo-kpi-grid-mid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cfo-kpi-card {
  min-width: 0;
  border: 1px solid #334155;
  border-radius: 8px;
  background: rgba(15, 23, 42, .44);
  padding: 10px 12px;
}

.cfo-kpi-card.sales,
.cfo-kpi-card.sales-soft {
  border-color: #2563eb;
  background: rgba(30, 64, 175, .22);
}

.cfo-kpi-card.purchase,
.cfo-kpi-card.purchase-soft {
  border-color: #059669;
  background: rgba(6, 95, 70, .22);
}

.cfo-kpi-card.neutral {
  background: rgba(15, 23, 42, .36);
}

.cfo-kpi-card span,
.cfo-detail-summary span,
.cfo-period-chip span,
.cfo-upload-help,
.cfo-upload-name,
.cfo-completion-line {
  color: #cbd5e1;
  font-size: 12px;
}

.cfo-kpi-card strong {
  display: block;
  margin-top: 4px;
  color: #f8fafc;
  font-size: 18px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.cfo-upload-name {
  min-width: 120px;
  max-width: 260px;
  border: 1px solid #334155;
  border-radius: 999px;
  padding: 5px 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cfo-upload-help {
  min-height: 18px;
  margin-top: 8px;
  color: #fbbf24;
}

.cfo-period-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.cfo-period-chip {
  min-height: 46px;
  border: 1px solid rgba(74, 222, 128, .38);
  border-radius: 8px;
  background: rgba(22, 163, 74, .12);
  color: inherit;
  text-align: left;
  padding: 7px 8px;
  cursor: pointer;
}

.cfo-period-chip.active {
  border-color: rgba(96, 165, 250, .82);
  background: rgba(37, 99, 235, .26);
}

.cfo-period-chip strong {
  display: block;
  color: #f8fafc;
  font-size: 14px;
}

.cfo-detail-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 10px 0 8px;
}

.cfo-detail-summary article {
  border: 1px solid #334155;
  border-radius: 8px;
  background: rgba(15, 23, 42, .36);
  padding: 10px 12px;
}

.cfo-detail-summary strong {
  display: block;
  margin-top: 4px;
  color: #f8fafc;
  font-size: 18px;
}

.cfo-field-table {
  overflow: hidden;
  border: 1px solid #334155;
  border-radius: 8px;
  margin-top: 8px;
}

.cfo-field-section {
  padding: 9px 12px;
  background: rgba(59, 130, 246, .16);
  border-bottom: 1px solid #253349;
  color: #dbeafe;
  font-weight: 950;
}

.cfo-field-row {
  display: grid;
  grid-template-columns: minmax(190px, 30%) minmax(0, 1fr);
  border-bottom: 1px solid #253349;
}

.cfo-field-row:last-child {
  border-bottom: 0;
}

.cfo-field-key,
.cfo-field-value {
  padding: 8px 10px;
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 13px;
}

.cfo-field-key {
  background: rgba(30, 41, 59, .55);
  color: #dbeafe;
  font-weight: 700;
}

.cfo-field-row.focus .cfo-field-key {
  color: #bfdbfe;
  font-weight: 950;
}

.cfo-field-value {
  color: #eef2ff;
  font-weight: 700;
  line-height: 1.45;
}

.cfo-field-input {
  width: 100%;
  min-height: 34px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #0b1220;
  color: #e2e8f0;
  padding: 7px 9px;
}

.cfo-field-input.is-textarea {
  min-height: 76px;
  resize: vertical;
}

.didi-finance-page .btn.danger {
  border-color: rgba(248, 113, 113, .42);
  color: #fecaca;
}

.theme-light.operations-mode {
  background: #eef2f7;
  --bg: #eef2f7;
  --panel: #ffffff;
  --panel-2: #f8fafc;
  --text: #162033;
  --muted: #64748b;
  --line: #d8e0eb;
  --line-strong: #b8c4d4;
  --sidebar: #f8fafc;
  --sidebar-muted: #64748b;
}

.theme-light.operations-mode .main {
  background: #eef2f7;
}

.theme-light.operations-mode .sidebar {
  background: #f8fafc;
  color: #172033;
  border-right: 1px solid #d8e0eb;
}

.theme-light.operations-mode .brand {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .mark {
  background: #172033;
  color: #fff;
}

.theme-light.operations-mode .nav button {
  color: #475569;
}

.theme-light.operations-mode .nav button:hover,
.theme-light.operations-mode .nav button.active {
  background: #e7edf6;
  color: #172033;
}

.theme-light.operations-mode .didi-ops-page {
  color: #172033;
}

.theme-light.operations-mode .ops-panel {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .ops-panel-title,
.theme-light.operations-mode .ops-control-row label,
.theme-light.operations-mode .ops-advice-item strong {
  color: #172033;
}

.theme-light.operations-mode .ops-control-row span,
.theme-light.operations-mode .ops-muted-line,
.theme-light.operations-mode #pageSubtitle,
.theme-light.operations-mode #sectionHint {
  color: #64748b;
}

.theme-light.operations-mode .didi-ops-page .mini-select,
.theme-light.operations-mode .didi-ops-page .mini-input {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .didi-ops-page .btn {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #172033;
}

.theme-light.operations-mode .decision-metric-card,
.theme-light.operations-mode .action-score-card,
.theme-light.operations-mode .quality-card,
.theme-light.operations-mode .ops-advice-item,
.theme-light.operations-mode .ops-nested-box {
  background: #f8fafc;
  border-color: #d5deea;
}

.theme-light.operations-mode .decision-metric-card.status-high {
  border-color: #ef4444;
}

.theme-light.operations-mode .decision-metric-card.status-warn {
  border-color: #eab308;
}

.theme-light.operations-mode .decision-metric-card.status-ok {
  border-color: #10b981;
}

.theme-light.operations-mode .metric-card-head span,
.theme-light.operations-mode .action-score-card span,
.theme-light.operations-mode .quality-card span,
.theme-light.operations-mode .ops-mix-item span,
.theme-light.operations-mode .metric-card-foot,
.theme-light.operations-mode .ops-box-title,
.theme-light.operations-mode .ops-mix-item small,
.theme-light.operations-mode .quality-card small,
.theme-light.operations-mode .action-score-card small,
.theme-light.operations-mode .consistency-list small {
  color: #64748b;
}

.theme-light.operations-mode .decision-metric-card strong,
.theme-light.operations-mode .action-score-card strong,
.theme-light.operations-mode .quality-card strong,
.theme-light.operations-mode .ops-mix-item strong,
.theme-light.operations-mode .consistency-list div {
  color: #172033;
}

.theme-light.operations-mode .ops-advice-item p {
  color: #334155;
}

.theme-light.operations-mode .ops-progress {
  background: #dbe4ef;
}

.theme-light.operations-mode .didi-ops-page table {
  color: #172033;
}

.theme-light.operations-mode .didi-ops-page th {
  background: #eef3f9;
  color: #334155;
}

.theme-light.operations-mode .didi-ops-page td,
.theme-light.operations-mode .didi-ops-page th {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .didi-ops-page code {
  color: #1d4ed8;
}

.theme-light.operations-mode .didi-member-page {
  color: #172033;
}

.theme-light.operations-mode .member-block-title,
.theme-light.operations-mode .member-upload-name,
.theme-light.operations-mode .member-mgmt-pagination {
  color: #64748b;
}

.theme-light.operations-mode .member-help {
  border-color: #94a3b8;
  color: #64748b;
}

.theme-light.operations-mode .member-upload-message {
  color: #b45309;
}

.theme-light.operations-mode .member-mgmt-input,
.theme-light.operations-mode .member-mgmt-select {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .member-mgmt-table {
  color: #172033;
}

.theme-light.operations-mode .member-mgmt-table th {
  background: #eef3f9;
  color: #334155;
}

.theme-light.operations-mode .member-mgmt-table td,
.theme-light.operations-mode .member-mgmt-table th {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .member-mgmt-row.even {
  background: #f1f5f9;
}

.theme-light.operations-mode .didi-finance-page {
  color: #172033;
}

.theme-light.operations-mode .cfo-panel {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .cfo-section-title,
.theme-light.operations-mode .cfo-upload-title,
.theme-light.operations-mode .cfo-period-chip strong,
.theme-light.operations-mode .cfo-kpi-card strong,
.theme-light.operations-mode .cfo-detail-summary strong {
  color: #172033;
}

.theme-light.operations-mode .cfo-sync-status {
  color: #047857;
}

.theme-light.operations-mode .cfo-kpi-card,
.theme-light.operations-mode .cfo-detail-summary article {
  background: #f8fafc;
  border-color: #d5deea;
}

.theme-light.operations-mode .cfo-kpi-card.sales,
.theme-light.operations-mode .cfo-kpi-card.sales-soft {
  border-color: #3b82f6;
  background: #eff6ff;
}

.theme-light.operations-mode .cfo-kpi-card.purchase,
.theme-light.operations-mode .cfo-kpi-card.purchase-soft {
  border-color: #10b981;
  background: #ecfdf5;
}

.theme-light.operations-mode .cfo-kpi-card span,
.theme-light.operations-mode .cfo-detail-summary span,
.theme-light.operations-mode .cfo-period-chip span,
.theme-light.operations-mode .cfo-upload-name,
.theme-light.operations-mode .cfo-completion-line {
  color: #64748b;
}

.theme-light.operations-mode .cfo-upload-help {
  color: #b45309;
}

.theme-light.operations-mode .cfo-upload-name,
.theme-light.operations-mode .cfo-field-table,
.theme-light.operations-mode .cfo-detail-summary article {
  border-color: #d8e0eb;
}

.theme-light.operations-mode .cfo-period-chip {
  background: #ecfdf5;
  border-color: #86efac;
}

.theme-light.operations-mode .cfo-period-chip.active {
  background: #dbeafe;
  border-color: #60a5fa;
}

.theme-light.operations-mode .cfo-field-section {
  background: #eaf2ff;
  border-bottom-color: #d8e0eb;
  color: #1d4ed8;
}

.theme-light.operations-mode .cfo-field-row {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .cfo-field-key {
  background: #f1f5f9;
  color: #334155;
}

.theme-light.operations-mode .cfo-field-row.focus .cfo-field-key {
  color: #1d4ed8;
}

.theme-light.operations-mode .cfo-field-value {
  color: #172033;
}

.theme-light.operations-mode .cfo-field-input {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .didi-finance-page .btn.danger {
  color: #b91c1c;
  border-color: #fecaca;
}

.didi-supplier-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
}

.supplier-page {
  min-height: 56vh;
}

.supplier-section-card {
  border: 1px solid #324259;
  border-radius: 8px;
  background: #0f1724;
  padding: 12px;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .16);
}

.supplier-section-title {
  color: #f8fafc;
  font-size: 16px;
  font-weight: 950;
  margin-bottom: 14px;
}

.supplier-form-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.supplier-input {
  width: 100%;
  min-height: 36px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #0b1220;
  color: #e2e8f0;
  padding: 8px 10px;
  font-size: 13px;
  outline: 0;
}

.supplier-input::placeholder {
  color: #94a3b8;
}

.supplier-message {
  min-height: 18px;
  margin-top: 8px;
  color: #fbbf24;
  font-size: 12px;
}

.supplier-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.supplier-search {
  flex: 1;
  min-width: 280px;
}

.supplier-toolbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.supplier-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #cbd5e1;
  font-size: 12px;
  white-space: nowrap;
}

.supplier-count {
  color: #cbd5e1;
  font-size: 12px;
  white-space: nowrap;
}

.supplier-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
}

.supplier-table {
  width: 100%;
  min-width: 1500px;
  border-collapse: collapse;
  color: #e2e8f0;
  font-size: 13px;
}

.supplier-table th {
  color: #dbeafe;
  font-weight: 950;
  text-align: left;
  padding: 10px 8px;
  background: #111c2e;
  border-bottom: 1px solid #253349;
}

.supplier-table td {
  padding: 30px 8px;
  border-bottom: 1px solid #253349;
  vertical-align: middle;
  line-height: 1.45;
}

.supplier-table tr.is-local td {
  background: rgba(37, 99, 235, .08);
}

.supplier-local-note {
  margin-top: 4px;
  color: #fbbf24;
  font-size: 11px;
}

.supplier-mobile-list {
  display: none;
}

.supplier-mobile-card {
  border: 1px solid #324259;
  border-radius: 8px;
  padding: 10px;
  display: grid;
  gap: 6px;
  background: #0f1724;
}

.supplier-mobile-card.is-local {
  border-color: #60a5fa;
}

.supplier-mobile-head {
  color: #f8fafc;
  font-weight: 900;
  font-size: 14px;
}

.supplier-mobile-sub,
.supplier-mobile-row {
  color: #cbd5e1;
  font-size: 12px;
}

.supplier-mobile-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.supplier-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(59, 130, 246, .12);
  color: #bfdbfe;
  font-size: 11px;
  border: 1px solid rgba(59, 130, 246, .18);
}

.supplier-mobile-row {
  display: flex;
  gap: 6px;
}

.supplier-mobile-row b {
  min-width: 72px;
  color: #dbeafe;
}

.theme-light.operations-mode .didi-supplier-page {
  color: #172033;
}

.theme-light.operations-mode .supplier-section-card,
.theme-light.operations-mode .supplier-mobile-card {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .supplier-section-title,
.theme-light.operations-mode .supplier-mobile-head {
  color: #172033;
}

.theme-light.operations-mode .supplier-input {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .supplier-input::placeholder,
.theme-light.operations-mode .supplier-check,
.theme-light.operations-mode .supplier-count,
.theme-light.operations-mode .supplier-mobile-sub,
.theme-light.operations-mode .supplier-mobile-row {
  color: #64748b;
}

.theme-light.operations-mode .supplier-message,
.theme-light.operations-mode .supplier-local-note {
  color: #b45309;
}

.theme-light.operations-mode .supplier-table {
  color: #172033;
}

.theme-light.operations-mode .supplier-table th {
  background: #eef3f9;
  color: #334155;
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .supplier-table td {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .supplier-table tr.is-local td {
  background: #eff6ff;
}

.theme-light.operations-mode .supplier-mobile-row b {
  color: #334155;
}

.theme-light.operations-mode .supplier-chip {
  background: #eff6ff;
  color: #1d4ed8;
  border-color: #bfdbfe;
}

.didi-purchase-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
}

.purchase-create-card,
.purchase-backup-card,
.purchase-table-card,
.purchase-stat-card {
  border: 1px solid #324259;
  border-radius: 8px;
  background: #0f1724;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .16);
}

.purchase-create-card,
.purchase-backup-card,
.purchase-table-card {
  padding: 14px;
}

.purchase-title {
  color: #f8fafc;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.35;
}

.purchase-desc,
.purchase-muted,
.purchase-ledger-title-row p,
.purchase-stat-card small {
  color: #cbd5e1;
  font-size: 12px;
  line-height: 1.45;
}

.purchase-form-grid {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.purchase-form-grid.top {
  grid-template-columns: 142px 128px repeat(4, minmax(0, 1fr));
}

.purchase-form-grid.bottom {
  grid-template-columns: 310px minmax(260px, 1fr) 250px;
}

.purchase-input,
.purchase-mini-select {
  width: 100%;
  min-height: 40px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #0b1220;
  color: #e2e8f0;
  padding: 8px 10px;
  font-size: 13px;
  outline: 0;
}

.purchase-mini-select {
  min-height: 32px;
  max-width: 170px;
  padding: 5px 9px;
}

.purchase-input::placeholder {
  color: #94a3b8;
}

.purchase-create-btn {
  width: 310px;
  max-width: 100%;
  margin-top: 8px;
}

.didi-purchase-page .btn.upload {
  background: #1f2937;
}

.purchase-message,
.purchase-local-note {
  min-height: 18px;
  color: #fbbf24;
  font-size: 12px;
}

.purchase-message {
  margin-top: 8px;
}

.purchase-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.purchase-stat-card {
  min-height: 92px;
  padding: 14px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.purchase-stat-card span,
.purchase-backup-label {
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 850;
}

.purchase-stat-card strong {
  color: #f8fafc;
  font-size: 26px;
  font-weight: 950;
  line-height: 1.1;
}

.purchase-stat-card strong.green {
  color: #86efac;
}

.purchase-stat-card strong.danger {
  color: #fda4af;
}

.purchase-stat-card strong.blue {
  color: #93c5fd;
}

.purchase-stat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.purchase-backup-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.purchase-backup-state {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0;
  color: #f8fafc;
  font-size: 16px;
  font-weight: 950;
}

.ok-dot,
.bad-dot {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  display: inline-block;
}

.ok-dot {
  background: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, .14);
}

.bad-dot {
  background: #ef4444;
  box-shadow: 0 0 0 4px rgba(239, 68, 68, .14);
}

.purchase-backup-actions,
.purchase-row-actions,
.purchase-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.purchase-backup-actions {
  justify-content: flex-end;
}

.purchase-ledger-head,
.purchase-ledger-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.purchase-tabs button {
  min-height: 38px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #1f2937;
  color: #e2e8f0;
  padding: 8px 13px;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.purchase-tabs button.active {
  background: #2563eb;
  border-color: #60a5fa;
  color: #fff;
}

.purchase-search {
  max-width: 420px;
}

.purchase-ledger-title-row {
  margin: 14px 0 8px;
}

.purchase-ledger-title-row h3 {
  margin: 0;
  color: #f8fafc;
  font-size: 18px;
}

.purchase-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
}

.purchase-ledger-table {
  min-width: 1120px;
  color: #e2e8f0;
  border-collapse: collapse;
  font-size: 13px;
}

.purchase-ledger-table th {
  background: #111c2e;
  color: #dbeafe;
  font-weight: 950;
  border-bottom: 1px solid #253349;
}

.purchase-ledger-table td,
.purchase-ledger-table th {
  padding: 11px 10px;
  border-bottom: 1px solid #253349;
  vertical-align: middle;
}

.purchase-row-local td {
  background: rgba(37, 99, 235, .08);
}

.purchase-pill {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  border-radius: 999px;
  padding: 4px 10px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: rgba(148, 163, 184, .13);
  color: #dbeafe;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.purchase-pill.pending {
  color: #facc15;
  background: rgba(250, 204, 21, .13);
  border-color: rgba(250, 204, 21, .3);
}

.purchase-pill.settled,
.purchase-pill.settle {
  color: #86efac;
  background: rgba(34, 197, 94, .13);
  border-color: rgba(34, 197, 94, .3);
}

.purchase-pill.delete {
  color: #fca5a5;
  background: rgba(239, 68, 68, .12);
  border-color: rgba(239, 68, 68, .3);
}

.btn.small {
  min-height: 30px;
  padding: 5px 9px;
  font-size: 12px;
}

.btn.ok {
  background: #15803d;
  border-color: #166534;
  color: #fff;
}

.theme-light.operations-mode .didi-purchase-page {
  color: #172033;
}

.theme-light.operations-mode .purchase-create-card,
.theme-light.operations-mode .purchase-backup-card,
.theme-light.operations-mode .purchase-table-card,
.theme-light.operations-mode .purchase-stat-card {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .purchase-title,
.theme-light.operations-mode .purchase-backup-state,
.theme-light.operations-mode .purchase-ledger-title-row h3,
.theme-light.operations-mode .purchase-stat-card strong {
  color: #172033;
}

.theme-light.operations-mode .purchase-desc,
.theme-light.operations-mode .purchase-muted,
.theme-light.operations-mode .purchase-ledger-title-row p,
.theme-light.operations-mode .purchase-stat-card span,
.theme-light.operations-mode .purchase-stat-card small,
.theme-light.operations-mode .purchase-backup-label {
  color: #64748b;
}

.theme-light.operations-mode .purchase-input,
.theme-light.operations-mode .purchase-mini-select {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .purchase-input::placeholder {
  color: #94a3b8;
}

.theme-light.operations-mode .didi-purchase-page .btn.upload,
.theme-light.operations-mode .purchase-tabs button {
  background: #f8fafc;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .purchase-tabs button.active {
  background: #2563eb;
  border-color: #60a5fa;
  color: #fff;
}

.theme-light.operations-mode .purchase-message,
.theme-light.operations-mode .purchase-local-note {
  color: #b45309;
}

.theme-light.operations-mode .purchase-stat-card strong.green {
  color: #047857;
}

.theme-light.operations-mode .purchase-stat-card strong.danger {
  color: #be123c;
}

.theme-light.operations-mode .purchase-stat-card strong.blue {
  color: #1d4ed8;
}

.theme-light.operations-mode .purchase-ledger-table {
  color: #172033;
}

.theme-light.operations-mode .purchase-ledger-table th {
  background: #eef3f9;
  color: #334155;
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .purchase-ledger-table td,
.theme-light.operations-mode .purchase-ledger-table th {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .purchase-row-local td {
  background: #eff6ff;
}

.store-pickup-page {
  --pickup-bg: #f6f8fc;
  --pickup-card: #ffffff;
  --pickup-line: #d8e1ed;
  --pickup-text: #263446;
  --pickup-muted: #64748b;
  --pickup-soft: #edf2f7;
  --pickup-primary: #2c4158;
  --pickup-blue: #2d92d8;
  --pickup-purple: #8d3fb3;
  --pickup-danger: #ef4444;
  display: grid;
  gap: 14px;
  min-width: 0;
  border-radius: 8px;
  background: var(--pickup-bg);
  color: var(--pickup-text);
  padding: 20px;
}

.store-pickup-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid var(--pickup-line);
  padding-bottom: 18px;
}

.store-pickup-header h3 {
  margin: 0;
  color: var(--pickup-text);
  font-size: 30px;
  font-weight: 950;
  letter-spacing: 0;
}

.store-pickup-header p {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 7px 0 0;
  color: var(--pickup-muted);
  font-size: 13px;
  font-weight: 850;
}

.store-pickup-ok-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #22c55e;
  display: inline-block;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, .12);
}

.store-pickup-tabs {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 8px;
  background: var(--pickup-soft);
  padding: 4px;
}

.store-pickup-tabs button {
  min-height: 42px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--pickup-muted);
  padding: 8px 18px;
  font-size: 14px;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.store-pickup-tabs button.active {
  background: var(--pickup-card);
  color: var(--pickup-text);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
}

.store-pickup-tabs span {
  margin-left: 4px;
}

.store-pickup-create-card,
.store-pickup-search-row,
.store-pickup-table-card,
.store-pickup-source-note,
.store-pickup-empty {
  border: 1px solid var(--pickup-line);
  border-radius: 8px;
  background: var(--pickup-card);
}

.store-pickup-create-card {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
  padding: 24px;
}

.store-pickup-create-card label {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.store-pickup-create-card label.wide {
  grid-column: span 7;
}

.store-pickup-create-card label span {
  color: var(--pickup-text);
  font-size: 12px;
  font-weight: 950;
}

.store-pickup-create-card small {
  color: #0ea5e9;
  font-size: 12px;
  font-weight: 900;
}

.store-pickup-input {
  width: 100%;
  min-height: 45px;
  border: 1px solid #cbd8e6;
  border-radius: 8px;
  background: var(--pickup-card);
  color: var(--pickup-text);
  padding: 9px 12px;
  font-size: 14px;
  outline: 0;
}

.store-pickup-input::placeholder {
  color: #94a3b8;
}

.store-pickup-primary-btn,
.store-pickup-action-btn,
.store-pickup-ghost-btn {
  min-height: 44px;
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.store-pickup-primary-btn {
  border: 1px solid var(--pickup-primary);
  background: var(--pickup-primary);
  color: #fff;
}

.store-pickup-action-btn {
  border: 1px solid var(--pickup-blue);
  background: var(--pickup-blue);
  color: #fff;
}

.store-pickup-ghost-btn {
  border: 1px solid #cbd8e6;
  background: var(--pickup-card);
  color: #334155;
}

.store-pickup-ghost-btn.edit {
  border-color: var(--pickup-purple);
  color: var(--pickup-purple);
}

.store-pickup-ghost-btn.danger {
  border-color: var(--pickup-danger);
  color: var(--pickup-danger);
}

.store-pickup-search-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 120px;
  gap: 12px;
  padding: 12px 0;
  border: 0;
  background: transparent;
}

.store-pickup-search-row .store-pickup-input {
  max-width: 350px;
}

.store-pickup-message,
.store-pickup-local-note {
  color: #b45309;
  font-size: 12px;
  font-weight: 850;
}

.store-pickup-table-card {
  padding: 0;
  overflow: hidden;
}

.store-pickup-table-wrap {
  overflow-x: auto;
}

.store-pickup-table {
  min-width: 980px;
  width: 100%;
  border-collapse: collapse;
  color: var(--pickup-text);
  font-size: 13px;
}

.store-pickup-table th {
  color: #1f2937;
  font-size: 13px;
  font-weight: 950;
  text-align: left;
  border-bottom: 1px solid var(--pickup-line);
  padding: 13px 10px;
}

.store-pickup-table td {
  border-bottom: 1px solid var(--pickup-line);
  padding: 13px 10px;
  vertical-align: middle;
}

.store-pickup-table td:first-child,
.store-pickup-table th:first-child {
  width: 36px;
}

.store-pickup-table strong {
  color: #111827;
  font-weight: 950;
}

.store-pickup-muted {
  margin-top: 4px;
  color: var(--pickup-muted);
  font-size: 12px;
  line-height: 1.4;
}

.store-pickup-location {
  color: #db2777;
  font-size: 13px;
  font-weight: 850;
}

.store-pickup-pill,
.store-pickup-payment {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 13px;
  font-weight: 950;
}

.store-pickup-pill.arrived {
  background: #eef5f1;
  color: #315846;
  border: 1px solid #bfd4c7;
}

.store-pickup-pill.vendor {
  background: #f4f0e8;
  color: #6f5e45;
  border: 1px solid #d8cdbb;
}

.store-pickup-pill.done {
  background: #edf6ef;
  color: #2c6842;
  border: 1px solid #b7d3bf;
}

.store-pickup-pill.waiting {
  background: #fff7e8;
  color: #7a5416;
  border: 1px solid #e7c987;
}

.store-pickup-payment.paid {
  background: #eef7f1;
  color: #2f6845;
  border: 1px solid #b8d8c2;
}

.store-pickup-payment.unpaid {
  background: #fff0ee;
  color: #9a372f;
  border: 1px solid #efb0aa;
}

.store-pickup-row-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.store-pickup-row-actions .store-pickup-action-btn,
.store-pickup-row-actions .store-pickup-ghost-btn {
  min-width: 54px;
  min-height: 44px;
  padding: 6px 10px;
  font-size: 13px;
}

.store-pickup-source-note,
.store-pickup-empty {
  padding: 12px 14px;
  color: var(--pickup-muted);
  font-size: 12px;
}

.store-pickup-table tr.is-local td {
  background: #eff6ff;
}

.theme-dark.operations-mode .store-pickup-page {
  --pickup-bg: #0b1220;
  --pickup-card: #101827;
  --pickup-line: #26344a;
  --pickup-text: #e8f0fb;
  --pickup-muted: #9fb0c8;
  --pickup-soft: #17233a;
  --pickup-primary: #748ffc;
  --pickup-blue: #2d92d8;
  --pickup-purple: #a855f7;
  --pickup-danger: #fb7185;
}

.theme-dark.operations-mode .store-pickup-table strong,
.theme-dark.operations-mode .store-pickup-table th {
  color: #e8f0fb;
}

.theme-dark.operations-mode .store-pickup-input,
.theme-dark.operations-mode .store-pickup-ghost-btn {
  background: #0b1220;
  border-color: #2f415b;
  color: #e8f0fb;
}

.theme-dark.operations-mode .store-pickup-table tr.is-local td {
  background: rgba(37, 99, 235, .08);
}

.cat-litter-page {
  --cat-bg: #0b1220;
  --cat-card: #101827;
  --cat-line: #2b3b52;
  --cat-text: #e8f0fb;
  --cat-muted: #9fb0c8;
  --cat-soft: #162238;
  --cat-primary: #253184;
  --cat-pickup: #15998b;
  --cat-renew: #8736ac;
  display: grid;
  gap: 14px;
  min-width: 0;
  border-radius: 8px;
  background: var(--cat-bg);
  color: var(--cat-text);
  padding: 18px;
}

.cat-litter-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.cat-litter-header h3 {
  margin: 0;
  color: var(--cat-text);
  font-size: 30px;
  font-weight: 950;
  letter-spacing: 0;
}

.cat-litter-header p {
  margin: 12px 0 0;
  color: #10a488;
  font-size: 12px;
  font-weight: 950;
}

.cat-litter-top-tabs {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  max-width: min(100%, 480px);
  border: 4px solid var(--cat-line);
  border-radius: 8px;
  background: var(--cat-soft);
  padding: 3px;
}

.cat-litter-top-tabs button {
  min-height: 42px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--cat-muted);
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.cat-litter-top-tabs button.active {
  background: var(--cat-card);
  color: var(--cat-primary);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
}

.cat-litter-top-tabs span {
  margin-left: 4px;
  color: inherit;
}

.cat-litter-brand-card,
.cat-litter-create-card,
.cat-litter-search-row,
.cat-litter-table-card,
.cat-litter-source-note,
.cat-litter-empty {
  border: 1px solid var(--cat-line);
  border-radius: 8px;
  background: var(--cat-card);
}

.cat-litter-brand-card,
.cat-litter-create-card,
.cat-litter-search-row,
.cat-litter-table-card {
  padding: 20px;
}

.cat-litter-brand-card {
  border-style: dashed;
}

.cat-litter-brand-add {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 140px;
  gap: 12px;
}

.cat-litter-brand-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.cat-litter-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  border: 1px solid var(--cat-line);
  border-radius: 999px;
  background: var(--cat-soft);
  color: var(--cat-text);
  padding: 5px 12px;
  font-size: 13px;
  cursor: pointer;
}

.cat-litter-chip small {
  color: #ef4444;
  font-size: 14px;
  font-weight: 950;
}

.cat-litter-create-card {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  align-items: end;
}

.cat-litter-create-card label {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.cat-litter-create-card label span {
  color: var(--cat-primary);
  font-size: 12px;
  font-weight: 950;
}

.cat-litter-input {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--cat-line);
  border-radius: 8px;
  background: var(--cat-card);
  color: var(--cat-text);
  padding: 8px 10px;
  font-size: 13px;
  outline: 0;
}

.cat-litter-input::placeholder {
  color: var(--cat-muted);
}

.cat-litter-primary-btn,
.cat-litter-action-btn,
.cat-litter-ghost-btn {
  min-height: 40px;
  border-radius: 8px;
  border: 1px solid transparent;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.cat-litter-primary-btn {
  background: var(--cat-primary);
  color: #fff;
}

.cat-litter-action-btn.pickup {
  background: var(--cat-pickup);
  color: #fff;
}

.cat-litter-action-btn.renew {
  background: var(--cat-renew);
  color: #fff;
}

.cat-litter-ghost-btn {
  background: var(--cat-card);
  color: #51637c;
  border-color: var(--cat-line);
}

.cat-litter-search-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 110px;
  gap: 12px;
  padding: 12px 20px;
}

.cat-litter-message,
.cat-litter-local-note {
  color: #b45309;
  font-size: 12px;
  font-weight: 850;
}

.cat-litter-table-card {
  padding-top: 8px;
}

.cat-litter-table-wrap {
  overflow-x: auto;
  max-width: 100%;
}

.cat-litter-table {
  min-width: 1080px;
  width: 100%;
  border-collapse: collapse;
  color: var(--cat-text);
  font-size: 14px;
}

.cat-litter-table th {
  color: #51637c;
  font-size: 12px;
  font-weight: 950;
  text-align: left;
  border-bottom: 1px solid var(--cat-line);
  padding: 12px 14px;
}

.cat-litter-table td {
  border-bottom: 1px solid var(--cat-line);
  padding: 16px 14px;
  vertical-align: middle;
}

.cat-litter-table td:first-child,
.cat-litter-table th:first-child {
  width: 36px;
}

.cat-litter-table strong {
  color: var(--cat-text);
  font-weight: 950;
}

.cat-litter-table tr.is-local td {
  background: rgba(37, 49, 132, .06);
}

.cat-litter-table tr.is-low td {
  background-image: linear-gradient(90deg, rgba(251, 191, 36, .06), transparent 28%);
}

.cat-litter-table tr.is-selected td {
  background-color: rgba(37, 49, 132, .08);
}

.cat-litter-muted,
.cat-litter-tags {
  display: block;
  margin-top: 3px;
  color: var(--cat-muted);
  font-size: 12px;
  line-height: 1.35;
}

.cat-litter-phone {
  color: #172d78;
  font-weight: 950;
}

.cat-litter-stock {
  font-size: 18px;
  font-weight: 950;
}

.cat-litter-stock.ok {
  color: #0f9f8e;
}

.cat-litter-stock.warning {
  color: #f59e0b;
}

.cat-litter-stock.danger {
  color: #ef4444;
}

.cat-litter-row-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.cat-litter-row-actions .cat-litter-action-btn,
.cat-litter-row-actions .cat-litter-ghost-btn {
  min-height: 44px;
  padding: 8px 13px;
}

.cat-litter-source-note,
.cat-litter-empty,
.cat-litter-record-card {
  padding: 12px 14px;
}

.cat-litter-source-note,
.cat-litter-empty {
  color: var(--cat-muted);
  font-size: 12px;
}

.cat-litter-record-card {
  border: 1px solid var(--cat-line);
  border-radius: 8px;
  background: var(--cat-card);
}

.cat-litter-record-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--cat-line);
  padding-bottom: 10px;
}

.cat-litter-record-head h4 {
  margin: 0;
  color: var(--cat-text);
  font-size: 16px;
  font-weight: 950;
}

.cat-litter-record-head p {
  margin: 5px 0 0;
  color: var(--cat-muted);
  font-size: 12px;
  line-height: 1.45;
}

.cat-litter-record-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.cat-litter-record-list article {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 10px;
  border: 1px solid var(--cat-line);
  border-radius: 8px;
  background: var(--cat-soft);
  padding: 9px 10px;
}

.cat-litter-record-list strong {
  color: var(--cat-primary);
  font-size: 12px;
  font-weight: 950;
}

.cat-litter-record-list span {
  color: var(--cat-text);
  font-size: 13px;
  line-height: 1.45;
}

.cat-litter-popup-card {
  border: 0;
  background: transparent;
  padding: 0;
}

.cat-litter-popup-card .cat-litter-record-list article {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.cat-litter-record-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cat-litter-record-link {
  border: 0;
  background: transparent;
  color: #2563eb;
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  padding: 4px 2px;
}

.cat-litter-record-link.danger {
  color: #ef4444;
}

.cat-litter-popup-close-btn {
  justify-self: center;
  min-width: 112px;
  margin-top: 4px;
}

.cat-litter-popup-form label.wide,
.cat-litter-popup-actions,
.cat-litter-popup-notice {
  grid-column: 1 / -1;
}

.cat-litter-popup-notice {
  border: 1px solid rgba(56, 189, 248, .28);
  border-radius: 8px;
  background: rgba(56, 189, 248, .09);
  color: var(--cat-primary);
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.55;
}

.cat-litter-popup-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding-top: 4px;
}

.cat-litter-popup-actions .cat-litter-primary-btn,
.cat-litter-popup-actions .cat-litter-ghost-btn {
  width: auto;
  min-width: 108px;
}

.theme-light.operations-mode .cat-litter-page {
  --cat-bg: #f6f8fc;
  --cat-card: #ffffff;
  --cat-line: #dce5f0;
  --cat-text: #263446;
  --cat-muted: #718198;
  --cat-soft: #edf2f8;
  --cat-primary: #202a71;
  --cat-pickup: #199d90;
  --cat-renew: #8b3caf;
}

.theme-light.operations-mode .cat-litter-ghost-btn {
  background: #ffffff;
}

.theme-light.operations-mode .cat-litter-table th {
  color: #50627b;
}

.theme-light.operations-mode .cat-litter-phone {
  color: #172d78;
}

.theme-dark.operations-mode .cat-litter-page {
  --cat-bg: #0b1220;
  --cat-card: #101827;
  --cat-line: #26344a;
  --cat-text: #e8f0fb;
  --cat-muted: #9fb0c8;
  --cat-soft: #17233a;
  --cat-primary: #8aa5ff;
  --cat-pickup: #15998b;
  --cat-renew: #8b3caf;
}

.theme-dark.operations-mode .cat-litter-phone {
  color: #a9c4ff;
}

.theme-dark.operations-mode .cat-litter-ghost-btn {
  color: #d7e2f1;
}

.didi-expiry-page {
  display: grid;
  gap: 12px;
  color: #e5edf7;
  min-width: 0;
}

.expiry-create-card,
.expiry-backup-card,
.expiry-table-card,
.expiry-stat-card {
  min-width: 0;
  border: 1px solid #324259;
  border-radius: 8px;
  background: #0f1724;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .16);
}

.expiry-create-card,
.expiry-backup-card,
.expiry-table-card {
  padding: 14px;
}

.expiry-title {
  color: #f8fafc;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.35;
}

.expiry-desc,
.expiry-muted,
.expiry-count {
  color: #cbd5e1;
  font-size: 12px;
  line-height: 1.45;
}

.expiry-form-grid {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.expiry-form-grid.top {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.expiry-form-grid.bottom {
  grid-template-columns: minmax(260px, 1fr) 260px 260px;
}

.expiry-input,
.expiry-mini-select {
  width: 100%;
  min-height: 40px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #0b1220;
  color: #e2e8f0;
  padding: 8px 10px;
  font-size: 13px;
  outline: 0;
}

.expiry-mini-select {
  min-height: 34px;
  max-width: 190px;
  padding: 5px 9px;
}

.expiry-input::placeholder {
  color: #94a3b8;
}

.expiry-risk-preview {
  margin-top: 10px;
  border: 1px solid #324259;
  border-radius: 8px;
  background: #111c2e;
  padding: 10px;
}

.expiry-risk-preview span {
  display: block;
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 850;
}

.expiry-risk-preview strong {
  display: block;
  margin-top: 3px;
  color: #f8fafc;
  font-size: 22px;
  font-weight: 950;
}

.didi-expiry-page .btn.upload {
  background: #1f2937;
}

.expiry-message,
.expiry-local-note {
  min-height: 18px;
  color: #fbbf24;
  font-size: 12px;
}

.expiry-message {
  margin-top: 8px;
}

.expiry-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.expiry-stat-card {
  min-height: 82px;
  padding: 14px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.expiry-stat-card span,
.expiry-backup-label {
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 850;
}

.expiry-stat-card strong {
  color: #f8fafc;
  font-size: 26px;
  font-weight: 950;
  line-height: 1.1;
}

.expiry-stat-card strong.green {
  color: #86efac;
}

.expiry-stat-card strong.danger {
  color: #fda4af;
}

.expiry-backup-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.expiry-export-card {
  justify-content: flex-end;
}

.expiry-backup-state {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0;
  color: #f8fafc;
  font-size: 16px;
  font-weight: 950;
}

.expiry-backup-actions,
.expiry-row-actions,
.expiry-tabs,
.expiry-filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.expiry-backup-actions {
  justify-content: flex-end;
}

.expiry-ledger-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.expiry-list-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 8px;
}

.expiry-tabs button {
  min-height: 38px;
  border: 1px solid #475569;
  border-radius: 8px;
  background: #1f2937;
  color: #e2e8f0;
  padding: 8px 13px;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.expiry-tabs button.active {
  background: #2563eb;
  border-color: #60a5fa;
  color: #fff;
}

.expiry-search {
  max-width: 420px;
}

.expiry-filter-row {
  margin: 14px 0 8px;
}

.expiry-filter-row h3 {
  margin: 0;
  color: #f8fafc;
  font-size: 18px;
}

.expiry-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
  max-width: 100%;
}

.expiry-ledger-table {
  min-width: 1020px;
  color: #e2e8f0;
  border-collapse: collapse;
  font-size: 13px;
}

.expiry-ledger-table th {
  background: #111c2e;
  color: #dbeafe;
  font-weight: 950;
  border-bottom: 1px solid #253349;
}

.expiry-ledger-table td,
.expiry-ledger-table th {
  padding: 11px 10px;
  border-bottom: 1px solid #253349;
  vertical-align: middle;
}

.expiry-row-local td {
  background: rgba(37, 99, 235, .08);
}

.expiry-pill {
  display: inline-grid;
  align-items: center;
  justify-items: center;
  gap: 2px;
  min-width: 92px;
  min-height: 36px;
  border-radius: 10px;
  padding: 6px 10px;
  border: 1px solid #cbd5e1;
  background: #f8fafc;
  color: #334155;
  white-space: nowrap;
  line-height: 1.15;
  text-align: center;
}

.expiry-status-cell {
  min-width: 130px;
  text-align: center;
}

.expiry-pill strong {
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0;
}

.expiry-pill small {
  font-size: 11px;
  font-weight: 850;
  color: currentColor;
  opacity: .88;
}

.expiry-pill.pending {
  color: #8a4b00;
  background: #fff4cf;
  border-color: #f1c55d;
}

.expiry-pill.settled {
  color: #ffffff;
  background: #16824b;
  border-color: #11693d;
}

.expiry-pill.danger {
  color: #ffffff;
  background: #c24135;
  border-color: #a7372d;
}

.expiry-return-yes,
.expiry-return-no {
  font-weight: 950;
  white-space: nowrap;
}

.expiry-return-yes {
  color: #86efac;
}

.expiry-return-no {
  color: #fca5a5;
}

.theme-light.operations-mode .didi-expiry-page {
  color: #172033;
}

.theme-light.operations-mode .expiry-create-card,
.theme-light.operations-mode .expiry-backup-card,
.theme-light.operations-mode .expiry-table-card,
.theme-light.operations-mode .expiry-stat-card {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .expiry-title,
.theme-light.operations-mode .expiry-backup-state,
.theme-light.operations-mode .expiry-filter-row h3,
.theme-light.operations-mode .expiry-stat-card strong,
.theme-light.operations-mode .expiry-risk-preview strong {
  color: #172033;
}

.theme-light.operations-mode .expiry-desc,
.theme-light.operations-mode .expiry-muted,
.theme-light.operations-mode .expiry-count,
.theme-light.operations-mode .expiry-stat-card span,
.theme-light.operations-mode .expiry-backup-label,
.theme-light.operations-mode .expiry-risk-preview span {
  color: #64748b;
}

.theme-light.operations-mode .expiry-input,
.theme-light.operations-mode .expiry-mini-select {
  background: #ffffff;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .expiry-input::placeholder {
  color: #94a3b8;
}

.theme-light.operations-mode .expiry-risk-preview {
  background: #f8fafc;
  border-color: #d5deea;
}

.theme-light.operations-mode .didi-expiry-page .btn.upload,
.theme-light.operations-mode .expiry-tabs button {
  background: #f8fafc;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .expiry-tabs button.active {
  background: #2563eb;
  border-color: #60a5fa;
  color: #fff;
}

.theme-light.operations-mode .expiry-message,
.theme-light.operations-mode .expiry-local-note {
  color: #b45309;
}

.theme-light.operations-mode .expiry-stat-card strong.green,
.theme-light.operations-mode .expiry-return-yes {
  color: #047857;
}

.theme-light.operations-mode .expiry-stat-card strong.danger,
.theme-light.operations-mode .expiry-return-no {
  color: #be123c;
}

.theme-light.operations-mode .expiry-ledger-table {
  color: #172033;
}

.theme-light.operations-mode .expiry-ledger-table th {
  background: #eef3f9;
  color: #334155;
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .expiry-ledger-table td,
.theme-light.operations-mode .expiry-ledger-table th {
  border-bottom-color: #d8e0eb;
}

.theme-light.operations-mode .expiry-row-local td {
  background: #eff6ff;
}

.didi-office-page {
  display: grid;
  gap: 14px;
  color: #dbe7ff;
  min-width: 0;
}

.office-topline,
.office-card,
.office-detail-card {
  min-width: 0;
  border: 1px solid #253b5f;
  border-radius: 8px;
  background: #0e1728;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .18);
}

.office-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 14px;
}

.office-hero-main {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.office-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.office-title {
  color: #f8fafc;
  font-size: 19px;
  font-weight: 950;
  line-height: 1.2;
}

.office-title-row > img {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
  image-rendering: pixelated;
}

.office-build-tag {
  align-self: flex-start;
  border: 1px solid rgba(143, 180, 255, .28);
  border-radius: 999px;
  background: rgba(96, 165, 250, .12);
  color: #8fb4ff;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px;
  font-weight: 850;
  padding: 3px 8px;
  white-space: nowrap;
}

.office-meta {
  margin-top: 3px;
  color: #a7bad8;
  font-size: 12px;
  line-height: 1.45;
}

.office-status-row {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}

.office-pill {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 999px;
  background: rgba(15, 23, 42, .36);
  color: #c7d8ef;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.office-pill i {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #34d399;
  box-shadow: 0 0 0 3px rgba(52, 211, 153, .14);
}

.office-pill.degraded i {
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, .14);
}

.office-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.office-link {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  border: 1px solid #40618f;
  border-radius: 999px;
  background: #13223a;
  color: #dbeafe;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.office-soft-btn {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #40618f;
  border-radius: 999px;
  background: #13223a;
  color: #dbeafe;
  padding: 7px 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
  cursor: pointer;
}

.office-message {
  border: 1px solid rgba(251, 191, 36, .32);
  border-radius: 8px;
  background: rgba(251, 191, 36, .1);
  color: #fde68a;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 850;
}

.office-layout {
  display: grid;
  grid-template-columns: minmax(640px, 1fr) minmax(320px, 380px);
  gap: 14px;
  align-items: start;
}

.office-map-shell {
  min-width: 0;
  max-width: 100%;
  display: grid;
  gap: 10px;
  overflow: hidden;
  border: 1px solid #253b5f;
  border-radius: 8px;
  background: #0b1424;
  box-shadow: 0 16px 36px rgba(5, 12, 24, .18);
  padding: 10px;
}

.office-map-toolbar {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid #263b5e;
  border-radius: 8px;
  background: #0f1b2e;
  padding: 10px 12px;
}

.office-map-toolbar > div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.office-map-toolbar span,
.office-map-toolbar small {
  color: #9fb3cf;
  font-size: 12px;
  font-weight: 850;
}

.office-map-toolbar strong {
  min-width: 0;
  overflow: hidden;
  color: #f8fafc;
  font-size: 17px;
  line-height: 1.2;
  font-weight: 950;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.office-map-viewport {
  max-width: 100%;
  overflow: auto;
  border: 3px solid #273151;
  border-radius: 8px;
  background: #07101f;
  -webkit-overflow-scrolling: touch;
}

.office-stage {
  position: relative;
  width: 1220px;
  height: 735px;
  overflow: hidden;
  background-color: #c8b78e;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.12) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.12) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(80, 64, 40, .08) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(80, 64, 40, .08) 75%);
  background-position: 0 0, 0 32px, 32px -32px, -32px 0;
  background-size: 64px 64px;
}

.office-wall {
  position: absolute;
  inset: 0 0 auto;
  height: 64px;
  display: grid;
  place-items: center;
  background: linear-gradient(#7e8ead, #687999);
  color: #dce8ff;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 16px;
  font-weight: 950;
  text-transform: uppercase;
}

.office-zone {
  position: absolute;
  z-index: 1;
  border-radius: 12px;
  background: rgba(226, 232, 240, .38);
}

.office-zone-label {
  position: absolute;
  z-index: 4;
  min-width: 70px;
  border-radius: 7px;
  background: #43536e;
  color: #f8fafc;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 950;
  text-align: center;
  box-shadow: 0 6px 16px rgba(15, 23, 42, .25);
}

.office-deco,
.office-sticker {
  position: absolute;
  z-index: 5;
  image-rendering: pixelated;
  pointer-events: none;
}

.office-deco.plant {
  width: 30px;
  top: 88px;
}

.office-deco.plant.left {
  left: 30px;
}

.office-deco.plant.right {
  right: 30px;
}

.office-deco.printer {
  width: 58px;
  left: 1005px;
  bottom: 112px;
}

.office-deco.cabinet {
  width: 38px;
  left: 1105px;
  bottom: 118px;
}

.office-sticker {
  width: 58px;
  left: 150px;
  bottom: 78px;
}

.office-agent {
  position: absolute;
  z-index: 8;
  width: 104px;
  height: 94px;
  transform: translate(-26px, -28px);
  border: 0;
  background: transparent;
  color: #f8fafc;
  cursor: pointer;
}

.office-agent img {
  width: 68px;
  height: 68px;
  object-fit: contain;
  image-rendering: pixelated;
  filter: drop-shadow(0 7px 8px rgba(15, 23, 42, .38));
}

.office-agent.selected img,
.office-agent:hover img {
  filter: drop-shadow(0 0 0 #93c5fd) drop-shadow(0 9px 12px rgba(37, 99, 235, .45));
}

.office-agent-name {
  position: absolute;
  left: 50%;
  bottom: 1px;
  max-width: 100px;
  transform: translateX(-50%);
  border-radius: 4px;
  background: rgba(17, 24, 39, .78);
  color: #fff;
  padding: 3px 6px;
  font-size: 10px;
  font-weight: 950;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.office-agent .office-agent-dot {
  position: absolute;
  right: 18px;
  top: 20px;
}

.office-agent-dot {
  width: 11px;
  height: 11px;
  flex: 0 0 11px;
  border-radius: 999px;
  border: 2px solid rgba(15, 23, 42, .45);
  background: #60a5fa;
  box-shadow: 0 0 0 3px rgba(96, 165, 250, .15);
}

.office-agent-dot.busy {
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, .18);
}

.office-agent-dot.online,
.office-agent-dot.idle {
  background: #60a5fa;
}

.office-agent-dot.offline {
  background: #94a3b8;
  box-shadow: none;
}

.office-agent-bubble {
  position: absolute;
  left: 50%;
  top: -18px;
  display: none;
  width: max-content;
  max-width: 220px;
  transform: translateX(-50%);
  border: 1px solid rgba(219, 234, 254, .45);
  border-radius: 8px;
  background: rgba(15, 23, 42, .92);
  color: #f8fafc;
  padding: 6px 8px;
  font-size: 11px;
  font-weight: 850;
  white-space: normal;
}

.office-agent:hover .office-agent-bubble,
.office-agent.selected .office-agent-bubble {
  display: block;
}

.office-side {
  display: grid;
  gap: 12px;
  min-width: 0;
  position: sticky;
  top: 14px;
}

.office-card,
.office-detail-card {
  padding: 14px;
}

.office-agent-card {
  display: grid;
  gap: 10px;
}

.office-card-title,
.office-detail-title,
.office-agent-summary-title {
  color: #f8fafc;
  font-size: 15px;
  font-weight: 950;
}

.office-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #a7bad8;
  font-size: 12px;
  font-weight: 850;
}

.office-filter-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(130px, .75fr);
  gap: 8px;
  margin-top: 10px;
}

.office-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.office-stat-grid div {
  border: 1px solid #29436d;
  border-radius: 8px;
  background: #101f36;
  padding: 10px;
}

.office-stat-grid span {
  display: block;
  color: #93a9c8;
  font-size: 12px;
  font-weight: 850;
}

.office-stat-grid strong {
  display: block;
  margin-top: 5px;
  color: #f8fafc;
  font-size: 26px;
  line-height: 1;
  font-weight: 950;
}

.office-focus-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.office-focus-list div {
  border: 1px solid #29436d;
  border-radius: 8px;
  background: #0b1628;
  color: #dbeafe;
  padding: 9px 10px;
  font-size: 12px;
  line-height: 1.45;
}

.office-input {
  width: 100%;
  min-height: 36px;
  border: 1px solid #334b70;
  border-radius: 8px;
  background: #0b1424;
  color: #e2e8f0;
  padding: 8px 10px;
  font-size: 13px;
  outline: 0;
}

.office-input::placeholder {
  color: #8294b2;
}

.office-agent-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  max-height: 388px;
  overflow: auto;
  padding-right: 2px;
}

.office-agent-row {
  width: 100%;
  display: grid;
  grid-template-columns: 12px 44px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid #29436d;
  border-radius: 8px;
  background: #10203a;
  color: #e2e8f0;
  padding: 9px;
  text-align: left;
  cursor: pointer;
}

.office-agent-row.selected,
.office-agent-row:hover {
  border-color: #60a5fa;
  background: #152b4f;
}

.office-agent-row img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  image-rendering: pixelated;
}

.office-agent-row span {
  min-width: 0;
}

.office-agent-row strong,
.office-agent-row small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.office-agent-row strong {
  color: #f8fafc;
  font-size: 13px;
  font-weight: 950;
}

.office-agent-row small {
  margin-top: 2px;
  color: #a7bad8;
  font-size: 11px;
}

.office-agent-row em {
  border-radius: 999px;
  background: rgba(96, 165, 250, .12);
  color: #bfdbfe;
  padding: 4px 7px;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.office-empty {
  border: 1px dashed #334b70;
  border-radius: 8px;
  color: #a7bad8;
  padding: 12px;
  text-align: center;
}

.office-detail-card,
.office-agent-summary {
  display: grid;
  gap: 8px;
  background:
    linear-gradient(135deg, rgba(96, 165, 250, .12), transparent 34%),
    #0e1728;
}

.office-agent-summary {
  border: 1px solid #29436d;
  border-radius: 8px;
  padding: 11px;
}

.office-agent-summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.office-agent-summary-head p,
.office-agent-summary p {
  margin: 4px 0 0;
  color: #cbd5e1;
  font-size: 12px;
  line-height: 1.45;
}

.office-agent-summary-grid {
  display: grid;
  gap: 6px;
}

.office-agent-summary-grid span {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 8px;
  color: #93a9c8;
  font-size: 12px;
  line-height: 1.4;
}

.office-agent-summary-grid strong {
  min-width: 0;
  overflow: hidden;
  color: #dbeafe;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.office-detail-card p,
.office-detail-line {
  color: #cbd5e1;
  font-size: 13px;
  line-height: 1.45;
}

.office-detail-sub {
  margin-top: 4px;
  color: #93c5fd;
  font-size: 12px;
  font-weight: 950;
}

.office-duty-list {
  display: grid;
  gap: 6px;
}

.office-duty-list div {
  border: 1px solid #29436d;
  border-radius: 8px;
  background: #0b1628;
  color: #dbeafe;
  padding: 8px 9px;
  font-size: 12px;
}

.office-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(96, 165, 250, .3);
  background: rgba(96, 165, 250, .12);
  color: #bfdbfe;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 950;
  white-space: nowrap;
}

.office-status-pill.online,
.office-status-pill.idle {
  border-color: rgba(52, 211, 153, .32);
  background: rgba(52, 211, 153, .12);
  color: #bbf7d0;
}

.office-status-pill.busy {
  border-color: rgba(245, 158, 11, .38);
  background: rgba(245, 158, 11, .13);
  color: #fde68a;
}

.office-status-pill.offline {
  border-color: rgba(148, 163, 184, .28);
  background: rgba(148, 163, 184, .12);
  color: #cbd5e1;
}

@media (max-width: 1320px) {
  .office-layout {
    grid-template-columns: 1fr;
  }

  .office-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    position: static;
  }

  .office-agent-card {
    grid-column: 1 / -1;
  }
}

.theme-light.operations-mode .didi-office-page {
  color: #172033;
}

.theme-light.operations-mode .office-topline,
.theme-light.operations-mode .office-card,
.theme-light.operations-mode .office-detail-card,
.theme-light.operations-mode .office-map-shell {
  background: #ffffff;
  border-color: #d5deea;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .07);
}

.theme-light.operations-mode .office-map-toolbar {
  background: #f8fafc;
  border-color: #d5deea;
}

.theme-light.operations-mode .office-map-viewport {
  border-color: #dbe4ef;
  background: #eef3f9;
}

.theme-light.operations-mode .office-detail-card,
.theme-light.operations-mode .office-agent-summary {
  background:
    linear-gradient(135deg, rgba(235, 244, 255, .92), transparent 38%),
    #ffffff;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .office-title,
.theme-light.operations-mode .office-map-toolbar strong,
.theme-light.operations-mode .office-card-title,
.theme-light.operations-mode .office-detail-title,
.theme-light.operations-mode .office-agent-summary-title,
.theme-light.operations-mode .office-agent-summary-grid strong,
.theme-light.operations-mode .office-stat-grid strong,
.theme-light.operations-mode .office-agent-row strong {
  color: #172033;
}

.theme-light.operations-mode .office-meta,
.theme-light.operations-mode .office-map-toolbar span,
.theme-light.operations-mode .office-map-toolbar small,
.theme-light.operations-mode .office-card-head,
.theme-light.operations-mode .office-stat-grid span,
.theme-light.operations-mode .office-agent-row small,
.theme-light.operations-mode .office-detail-card p,
.theme-light.operations-mode .office-agent-summary p,
.theme-light.operations-mode .office-agent-summary-grid span,
.theme-light.operations-mode .office-detail-line {
  color: #64748b;
}

.theme-light.operations-mode .office-link,
.theme-light.operations-mode .office-soft-btn,
.theme-light.operations-mode .office-pill,
.theme-light.operations-mode .office-input,
.theme-light.operations-mode .office-stat-grid div,
.theme-light.operations-mode .office-focus-list div,
.theme-light.operations-mode .office-agent-row,
.theme-light.operations-mode .office-duty-list div {
  background: #f8fafc;
  color: #172033;
  border-color: #cbd5e1;
}

.theme-light.operations-mode .office-agent-row.selected,
.theme-light.operations-mode .office-agent-row:hover {
  background: #eff6ff;
  border-color: #60a5fa;
}

.theme-light.operations-mode .office-focus-list div,
.theme-light.operations-mode .office-duty-list div {
  color: #334155;
}

.theme-light.operations-mode .office-message {
  background: #fffbeb;
  border-color: #fcd34d;
  color: #92400e;
}

.internal-toolbox-page {
  --toolbox-bg: #0b1220;
  --toolbox-card: #101827;
  --toolbox-card-2: #0f1724;
  --toolbox-text: #eef5ff;
  --toolbox-muted: #9fb0c8;
  --toolbox-line: #26344a;
  --toolbox-soft: #17233a;
  display: grid;
  gap: 14px;
  min-width: 0;
  border-radius: 12px;
  background: var(--toolbox-bg);
  color: var(--toolbox-text);
}

.internal-toolbox-hero {
  display: grid;
  gap: 14px;
  border: 1px solid var(--toolbox-line);
  border-radius: 18px;
  background: var(--toolbox-card);
  padding: 18px;
}

.internal-toolbox-hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.internal-toolbox-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.internal-toolbox-brand img {
  width: 48px;
  height: 48px;
  border: 1px solid var(--toolbox-line);
  border-radius: 12px;
  background: #fff;
  object-fit: contain;
}

.internal-toolbox-brand h3 {
  margin: 0;
  color: var(--toolbox-text);
  font-size: 24px;
  font-weight: 950;
  letter-spacing: 0;
}

.internal-toolbox-brand p {
  margin-top: 4px;
  color: var(--toolbox-muted);
  font-size: 13px;
  font-weight: 750;
}

.internal-toolbox-actions,
.internal-toolbox-socials,
.internal-toolbox-tabs,
.internal-toolbox-search-row,
.internal-toolbox-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.internal-toolbox-actions {
  justify-content: flex-end;
}

.internal-toolbox-soft-btn,
.internal-toolbox-socials a {
  min-height: 34px;
  border: 1px solid var(--toolbox-line);
  border-radius: 999px;
  background: var(--toolbox-card-2);
  color: var(--toolbox-text);
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.internal-toolbox-socials a {
  width: 36px;
  padding: 0;
  display: grid;
  place-items: center;
  border-radius: 10px;
}

.internal-toolbox-social-svg {
  width: 18px;
  height: 18px;
  display: block;
}

.internal-toolbox-tabs {
  position: relative;
}

.internal-toolbox-tab,
.internal-toolbox-add {
  min-height: 32px;
  border: 0;
  border-radius: 999px;
  color: #fff;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.internal-toolbox-tab.all,
.internal-toolbox-tab.active {
  background: #2563eb;
}

.internal-toolbox-tab.fav {
  background: #d99aa9;
}

.internal-toolbox-tab.cs {
  background: #91cfc8;
}

.internal-toolbox-tab.ops {
  background: #d8b496;
}

.internal-toolbox-tab.ai {
  background: #ce8fae;
}

.internal-toolbox-tab.dev {
  background: #a58ad4;
}

.internal-toolbox-tab.design {
  background: #dfa98e;
}

.internal-toolbox-tab.marketing {
  background: #d8c89d;
}

.internal-toolbox-tab.bizdev {
  background: #8fbfa1;
}

.internal-toolbox-tab.procurement {
  background: #8dbfca;
}

.internal-toolbox-tab.adminfin {
  background: #8f9aa6;
}

.internal-toolbox-tab:not(.active) {
  opacity: .86;
}

.internal-toolbox-tab.active {
  background: #2563eb;
  opacity: 1;
}

.internal-toolbox-add {
  margin-left: auto;
  background: #2563eb;
}

.internal-toolbox-search-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 8px;
}

.internal-toolbox-search {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--toolbox-line);
  border-radius: 10px;
  background: var(--toolbox-card-2);
  color: var(--toolbox-text);
  padding: 10px 12px;
  outline: 0;
}

.internal-toolbox-search::placeholder {
  color: var(--toolbox-muted);
}

.internal-toolbox-switch {
  width: 46px;
  height: 26px;
  position: relative;
  display: inline-flex;
  align-items: center;
}

.internal-toolbox-switch input {
  position: absolute;
  opacity: 0;
}

.internal-toolbox-switch span {
  width: 46px;
  height: 26px;
  border-radius: 999px;
  background: #94a3b8;
  cursor: pointer;
  transition: background .16s ease;
}

.internal-toolbox-switch span::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #fff;
  transition: transform .16s ease;
}

.internal-toolbox-switch input:checked + span {
  background: #2563eb;
}

.internal-toolbox-switch input:checked + span::after {
  transform: translateX(20px);
}

.internal-toolbox-switch-text {
  color: var(--toolbox-muted);
  font-size: 12px;
  font-weight: 850;
}

.internal-toolbox-message {
  border: 1px solid rgba(251, 191, 36, .32);
  border-radius: 10px;
  background: rgba(251, 191, 36, .1);
  color: #fde68a;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 850;
}

.internal-toolbox-summary {
  color: var(--toolbox-muted);
  font-size: 12px;
  font-weight: 850;
}

.internal-toolbox-summary span {
  border: 1px solid var(--toolbox-line);
  border-radius: 999px;
  background: var(--toolbox-soft);
  padding: 6px 10px;
}

.internal-toolbox-section {
  display: grid;
  gap: 10px;
}

.internal-toolbox-section-title {
  margin: 0;
  color: var(--toolbox-text);
  font-size: 18px;
  font-weight: 950;
}

.internal-toolbox-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.internal-toolbox-card {
  position: relative;
  min-width: 0;
  min-height: 94px;
  border: 1px solid var(--toolbox-line);
  border-radius: 12px;
  background: var(--toolbox-card);
}

.internal-toolbox-card-main {
  width: 100%;
  min-height: 92px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 0;
  background: transparent;
  color: var(--toolbox-text);
  padding: 14px 52px 14px 16px;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.internal-toolbox-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--toolbox-line);
  border-radius: 10px;
  background: var(--toolbox-card-2);
  font-size: 22px;
  font-weight: 950;
}

.internal-toolbox-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.internal-toolbox-icon img.contain {
  object-fit: contain;
  padding: 4px;
}

.internal-toolbox-card-copy {
  min-width: 0;
}

.internal-toolbox-card-copy strong,
.internal-toolbox-card-copy small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.internal-toolbox-card-copy small {
  white-space: nowrap;
}

.internal-toolbox-card-copy strong {
  color: var(--toolbox-text);
  font-size: 14px;
  font-weight: 950;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
}

.internal-toolbox-card-copy small {
  margin-top: 5px;
  color: var(--toolbox-muted);
  font-size: 12px;
}

.internal-toolbox-pill {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  margin-top: 6px;
  border-radius: 999px;
  background: #fde68a;
  color: #a16207;
  padding: 2px 7px;
  font-size: 11px;
  font-weight: 950;
}

.internal-toolbox-pill.cs {
  background: #ccfbf1;
  color: #0f766e;
}

.internal-toolbox-pill.procurement {
  background: #dbeafe;
  color: #2563eb;
}

.internal-toolbox-pill.ai,
.internal-toolbox-pill.dev,
.internal-toolbox-pill.design {
  background: #ede9fe;
  color: #6d28d9;
}

.internal-toolbox-pill.adminfin {
  background: #e2e8f0;
  color: #475569;
}

.internal-toolbox-heart {
  position: absolute;
  right: 14px;
  top: 26px;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid var(--toolbox-line);
  border-radius: 999px;
  background: var(--toolbox-card-2);
  color: #8aa0bd;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.internal-toolbox-heart.active {
  color: #ff3b4f;
}

.internal-toolbox-card-actions {
  position: absolute;
  right: 10px;
  bottom: 8px;
  display: flex;
  gap: 5px;
}

.internal-toolbox-card-actions button {
  min-height: 24px;
  border: 1px solid var(--toolbox-line);
  border-radius: 999px;
  background: var(--toolbox-card-2);
  color: var(--toolbox-muted);
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
}

.internal-toolbox-card-actions button.danger {
  border-color: rgba(239, 68, 68, .28);
  color: #dc2626;
}

.toolbox-crud-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.toolbox-crud-form label {
  display: grid;
  gap: 6px;
}

.toolbox-crud-form label > span {
  color: var(--toolbox-muted);
  font-size: 12px;
  font-weight: 900;
}

.toolbox-crud-form .wide,
.toolbox-crud-actions {
  grid-column: 1 / -1;
}

.toolbox-crud-check {
  display: flex !important;
  grid-template-columns: none;
  align-items: center;
  gap: 8px;
  color: var(--toolbox-text);
  font-size: 13px;
  font-weight: 850;
}

.toolbox-crud-actions {
  display: flex;
  justify-content: flex-end;
}

.toolbox-crud-form textarea.internal-toolbox-search {
  min-height: 86px;
  resize: vertical;
  line-height: 1.5;
  padding-top: 10px;
}

.toolbox-file-input {
  padding: 8px 10px;
}

.toolbox-icon-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--toolbox-line);
  border-radius: 12px;
  background: var(--toolbox-card-2);
  padding: 10px;
}

.toolbox-icon-preview .internal-toolbox-icon {
  position: static;
  flex: 0 0 48px;
  width: 48px;
  height: 48px;
}

.toolbox-icon-preview strong,
.toolbox-icon-preview small {
  display: block;
}

.toolbox-icon-preview small {
  margin-top: 3px;
  color: var(--toolbox-muted);
  font-size: 12px;
  word-break: break-all;
}

.internal-toolbox-empty {
  border: 1px dashed var(--toolbox-line);
  border-radius: 10px;
  background: var(--toolbox-card);
  color: var(--toolbox-muted);
  padding: 16px;
  text-align: center;
}

.theme-light.operations-mode .internal-toolbox-page {
  --toolbox-bg: #f3f6fb;
  --toolbox-card: #ffffff;
  --toolbox-card-2: #f8fafc;
  --toolbox-text: #111827;
  --toolbox-muted: #52627a;
  --toolbox-line: #d8e1ee;
  --toolbox-soft: #eef3f9;
  padding: 0;
}

.theme-light.operations-mode .internal-toolbox-message {
  background: #fffbeb;
  border-color: #fcd34d;
  color: #92400e;
}

.member-searchbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 160px auto;
  gap: 8px;
  align-items: center;
}

.operation-member-searchbar {
  grid-template-columns: 160px minmax(220px, 1fr) auto;
}

.member-results {
  display: grid;
  gap: 8px;
}

.member-card {
  display: grid;
  grid-template-columns: 1.1fr .9fr .8fr .7fr;
  gap: 10px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 11px;
}

.member-name {
  font-weight: 950;
}

.member-field {
  min-width: 0;
}

.member-field span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 4px;
}

.member-field strong,
.member-field code {
  overflow-wrap: anywhere;
}

.finance-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(150px, 1fr));
  gap: 10px;
}

.finance-period {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 11px;
}

.finance-period .period {
  font-size: 17px;
  font-weight: 950;
}

.finance-period .meta {
  color: var(--muted);
  font-size: 12px;
  margin-top: 5px;
  line-height: 1.45;
}

.supplier-grid,
.purchase-grid,
.social-grid,
.toolbox-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.supplier-card,
.purchase-card,
.social-card,
.toolbox-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 12px;
}

.supplier-title,
.purchase-title,
.social-title,
.toolbox-title {
  font-weight: 950;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.supplier-meta,
.purchase-meta,
.social-meta,
.toolbox-meta {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
  margin-top: 8px;
}

.split-row {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 8px;
  align-items: center;
  font-size: 13px;
}

.split-track {
  height: 9px;
  border-radius: 999px;
  background: #e6ebf1;
  overflow: hidden;
}

.split-fill {
  height: 100%;
  background: var(--accent);
}

.ai-metric {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  padding: 10px;
}

.ai-metric span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.ai-metric strong {
  display: block;
  margin-top: 5px;
  font-size: 16px;
  overflow-wrap: anywhere;
}

.toast {
  border: 1px solid var(--line);
  background: var(--accent-soft);
  color: #174ea6;
  border-radius: 8px;
  padding: 9px 10px;
  font-size: 13px;
  font-weight: 750;
}

.global-toast-stack {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 520;
  display: grid;
  gap: 10px;
  width: min(360px, calc(100vw - 32px));
  pointer-events: none;
}

.global-toast {
  pointer-events: auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 10px;
  border: 1px solid #d6e4d6;
  border-radius: 12px;
  background: rgba(255, 255, 255, .96);
  color: #24364a;
  padding: 12px 12px;
  box-shadow: 0 18px 48px rgba(55, 67, 88, .16);
  animation: toastIn .18s ease-out;
  backdrop-filter: blur(12px);
}

.global-toast.info {
  border-color: #d8e1ee;
}

.global-toast.error {
  border-color: #f0c7bf;
}

.global-toast-dot {
  width: 10px;
  height: 10px;
  margin-top: 5px;
  border-radius: 999px;
  background: #6fa583;
  box-shadow: 0 0 0 4px rgba(111, 165, 131, .14);
}

.global-toast.info .global-toast-dot {
  background: #7d94ad;
  box-shadow: 0 0 0 4px rgba(125, 148, 173, .14);
}

.global-toast.error .global-toast-dot {
  background: #b95d4f;
  box-shadow: 0 0 0 4px rgba(185, 93, 79, .14);
}

.global-toast-copy {
  font-size: 13px;
  font-weight: 850;
  line-height: 1.45;
  word-break: break-word;
}

.global-toast button {
  width: 24px;
  height: 24px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: #7b8794;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.global-toast button:hover {
  border-color: #d8e1ee;
  background: #f6f8fb;
  color: #24364a;
}

@keyframes toastIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.theme-dark .global-toast {
  border-color: rgba(148, 163, 184, .28);
  background: rgba(16, 24, 39, .96);
  color: #e5edf7;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .3);
}

.theme-dark .global-toast button {
  color: #a8b3c2;
}

.theme-dark .global-toast button:hover {
  border-color: rgba(148, 163, 184, .32);
  background: rgba(255, 255, 255, .06);
  color: #fff;
}

.card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 13px;
  min-height: 174px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.card.compact {
  min-height: 128px;
  gap: 8px;
}

.card-top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.card-title {
  font-weight: 950;
  line-height: 1.35;
}

.card-desc {
  color: var(--muted);
  line-height: 1.5;
  font-size: 13px;
  flex: 1;
}

.badge {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
}

.badge.live {
  background: #e9f7ef;
  color: var(--success);
  border-color: #bfe8cf;
}

.badge.archive {
  background: #fff6e5;
  color: var(--warning);
  border-color: #f3d49b;
}

.actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.btn {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  text-decoration: none;
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
}

.btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.btn:hover {
  border-color: var(--line-strong);
}

.table-wrap {
  overflow: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 10px;
  vertical-align: top;
  text-align: left;
}

th {
  color: var(--muted);
  font-size: 12px;
  background: var(--panel-2);
}

code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  overflow-wrap: anywhere;
}

.detail {
  margin-top: 18px;
}

.eyebrow {
  color: var(--accent);
  font-size: 12px;
  font-weight: 950;
  margin-bottom: 4px;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.detail-box {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
}

.detail-box.wide {
  grid-column: 1 / -1;
}

.label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 6px;
}

.detail-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}

body.compact .card {
  min-height: 126px;
}

body.compact .card-desc {
  display: none;
}

@media (max-width: 1040px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    height: auto;
    position: static;
  }

  .nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .summary-grid,
  .cards,
  .home-grid,
  .home-strip,
  .native-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .native-grid {
    grid-template-columns: 1fr;
  }

  .office-layout {
    grid-template-columns: 1fr;
  }

  .office-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    position: static;
  }

  .office-detail-card {
    grid-column: 1 / -1;
  }

  .internal-toolbox-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .main {
    padding: 14px;
  }

  .topbar,
  .section-head,
  .detail-head {
    display: grid;
  }

  .top-actions,
  .search {
    width: 100%;
    min-width: 0;
  }

  .summary-grid,
  .cards,
  .home-grid,
  .home-strip,
  .detail-grid,
  .nav,
  .task-form-grid,
  .control-grid,
  .ai-metrics,
  .ops-hero,
  .ops-kpi-grid,
  .decision-grid,
  .action-score-grid,
  .member-mgmt-search-grid,
  .member-searchbar,
  .member-card,
  .supplier-form-grid,
  .purchase-form-grid.top,
  .purchase-form-grid.bottom,
	  .purchase-stat-grid,
	  .purchase-ledger-head,
	  .purchase-ledger-title-row,
	  .store-pickup-create-card,
	  .store-pickup-search-row,
	  .cat-litter-create-card,
  .cat-litter-brand-add,
  .cat-litter-search-row,
  .expiry-form-grid.top,
  .expiry-form-grid.bottom,
  .expiry-stat-grid,
  .expiry-ledger-head,
  .cfo-kpi-grid-top,
  .cfo-kpi-grid-mid,
  .cfo-detail-summary,
  .cfo-field-row,
  .finance-grid,
  .supplier-grid,
  .purchase-grid,
  .social-grid,
  .toolbox-grid {
    grid-template-columns: 1fr;
  }

  .member-mgmt-pagination {
    align-items: stretch;
    flex-direction: column;
  }

  .member-mgmt-pagination > div:last-child {
    justify-content: stretch;
  }

  .member-mgmt-pagination .btn {
    flex: 1;
  }

  .list-pagination {
    align-items: stretch;
    flex-direction: column;
  }

  .list-pagination-controls {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }

  .list-pagination-controls .btn,
  .list-pagination-size {
    width: 100%;
  }

  .list-pagination-size {
    grid-column: 1 / -1;
  }

  .supplier-toolbar {
    align-items: stretch;
  }

  .supplier-search,
  .supplier-toolbar-right,
  .supplier-toolbar-right .btn {
    width: 100%;
  }

  .supplier-toolbar-right {
    justify-content: stretch;
  }

  .supplier-table-wrap {
    display: none;
  }

  .supplier-mobile-list {
    display: grid;
    gap: 8px;
  }

  .purchase-backup-card {
    align-items: stretch;
    flex-direction: column;
  }

  .purchase-backup-actions {
    justify-content: stretch;
  }

  .purchase-backup-actions .btn,
  .purchase-search,
	  .purchase-create-btn {
	    width: 100%;
	    max-width: none;
	  }

	  .store-pickup-page {
	    padding: 14px;
	  }

	  .store-pickup-header,
	  .store-pickup-tabs {
	    align-items: stretch;
	    flex-direction: column;
	  }

	  .store-pickup-header h3 {
	    font-size: 24px;
	  }

	  .store-pickup-create-card label.wide {
	    grid-column: auto;
	  }

	  .store-pickup-search-row .store-pickup-input,
	  .store-pickup-primary-btn,
	  .store-pickup-ghost-btn {
	    width: 100%;
	    max-width: none;
	  }

	  .cat-litter-page {
	    padding: 14px;
	  }

  .cat-litter-header,
  .cat-litter-top-tabs {
    align-items: stretch;
    flex-direction: column;
  }

  .cat-litter-header h3 {
    font-size: 24px;
  }

  .cat-litter-top-tabs,
  .cat-litter-primary-btn,
  .cat-litter-ghost-btn {
    width: 100%;
  }

  .cat-litter-record-head {
    flex-direction: column;
  }

  .cat-litter-record-list article {
    grid-template-columns: 1fr;
  }

  .expiry-backup-card {
    align-items: stretch;
    flex-direction: column;
  }

  .expiry-backup-actions {
    justify-content: stretch;
  }

  .expiry-backup-actions .btn,
  .expiry-search,
  .expiry-mini-select {
    width: 100%;
    max-width: none;
  }

  .office-topline,
  .office-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .office-actions .btn,
  .office-actions .office-soft-btn,
  .office-link {
    justify-content: center;
    width: 100%;
  }

  .office-map-viewport {
    max-height: 62vh;
  }

  .office-side {
    grid-template-columns: 1fr;
  }

  .office-filter-grid {
    grid-template-columns: 1fr;
  }

  .office-agent-list {
    max-height: 360px;
  }

  .internal-toolbox-hero-top,
  .internal-toolbox-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .internal-toolbox-actions .internal-toolbox-soft-btn {
    width: 100%;
    text-align: center;
  }

	  .internal-toolbox-search-row,
	  .internal-toolbox-grid,
	  .toolbox-crud-form {
	    grid-template-columns: 1fr;
	  }

  .internal-toolbox-add {
    width: 100%;
    margin-left: 0;
  }
}

/* PonPonPet-inspired refresh: soft pet-service UI for the unified console. */
:root {
  --bg: #f4f8fb;
  --panel: #ffffff;
  --panel-2: #f8fbff;
  --text: #203143;
  --muted: #66788d;
  --line: #dbe7f0;
  --line-strong: #b8cad8;
  --accent: #2f6df6;
  --accent-2: #14a89c;
  --accent-3: #ff8b68;
  --accent-soft: #eef5ff;
  --success: #129b65;
  --warning: #c27803;
  --shadow: 0 14px 34px rgba(34, 54, 77, .08);
  --shadow-soft: 0 8px 22px rgba(34, 54, 77, .06);
  --radius: 8px;
  --sidebar: #ffffff;
  --sidebar-muted: #7990a5;
}

body,
body.theme-light,
body.theme-light.operations-mode {
  color-scheme: light;
  --bg: #f4f8fb;
  --panel: #ffffff;
  --panel-2: #f8fbff;
  --text: #203143;
  --muted: #66788d;
  --line: #dbe7f0;
  --line-strong: #b8cad8;
  --accent: #2f6df6;
  --accent-soft: #eef5ff;
  --sidebar: #ffffff;
  --sidebar-muted: #7990a5;
  background: #f4f8fb;
  color: var(--text);
}

body.theme-dark,
body.theme-dark.operations-mode {
  color-scheme: dark;
  --bg: #101927;
  --panel: #162234;
  --panel-2: #1b2a40;
  --text: #edf5ff;
  --muted: #a9b9cc;
  --line: #2d4059;
  --line-strong: #48627e;
  --accent: #7aa5ff;
  --accent-soft: #203a62;
  --sidebar: #101927;
  --sidebar-muted: #9caec4;
  --shadow: none;
  --shadow-soft: none;
  background: #101927;
}

.shell {
  grid-template-columns: 280px minmax(0, 1fr);
}

.sidebar,
.theme-light.operations-mode .sidebar {
  background: var(--sidebar);
  color: var(--text);
  border-right: 1px solid var(--line);
  box-shadow: 14px 0 32px rgba(47, 69, 91, .06);
  padding: 22px 14px;
}

.theme-dark.operations-mode .sidebar {
  background: var(--sidebar);
  color: var(--text);
  border-right-color: var(--line);
}

.theme-dark .theme-toggle {
  background: var(--panel-2);
  color: var(--text);
  border-color: var(--line);
  box-shadow: none;
}

.brand {
  min-height: 72px;
  border-bottom: 1px solid var(--line);
  padding: 6px 8px 18px;
}

.mark,
.theme-light.operations-mode .mark {
  width: 46px;
  height: 46px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff url("./assets/internal-toolbox/matsumoto-logo.png") center / cover no-repeat;
  color: transparent;
  font-size: 0;
  box-shadow: var(--shadow-soft);
}

.brand-title {
  color: var(--text);
  font-size: 16px;
  line-height: 1.2;
}

.brand-sub {
  color: var(--muted);
  font-weight: 750;
}

.nav {
  gap: 8px;
}

.nav button,
.theme-light.operations-mode .nav button {
  min-height: 46px;
  border: 1px solid transparent;
  border-radius: 8px;
  color: #536579;
  background: transparent;
  font-weight: 900;
  padding: 10px 12px;
}

.theme-dark.operations-mode .nav button {
  color: #b5c5d7;
}

.nav button span:first-child {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.nav button span:first-child::before {
  content: "";
  width: 10px;
  height: 10px;
  flex: 0 0 10px;
  border-radius: 999px;
  background: #b9c8d6;
  box-shadow: 0 0 0 4px rgba(185, 200, 214, .18);
}

.nav button:nth-child(3n + 1) span:first-child::before {
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(47, 109, 246, .14);
}

.nav button:nth-child(3n + 2) span:first-child::before {
  background: var(--accent-2);
  box-shadow: 0 0 0 4px rgba(20, 168, 156, .14);
}

.nav button:nth-child(3n) span:first-child::before {
  background: var(--accent-3);
  box-shadow: 0 0 0 4px rgba(255, 139, 104, .16);
}

.nav button:hover,
.nav button.active,
.theme-light.operations-mode .nav button:hover,
.theme-light.operations-mode .nav button.active {
  background: #eef5ff;
  border-color: #d6e6ff;
  color: #16345f;
}

.theme-dark.operations-mode .nav button:hover,
.theme-dark.operations-mode .nav button.active {
  background: #1b2a40;
  border-color: #334b68;
  color: #ffffff;
}

.count,
.theme-light.operations-mode .nav .count {
  color: var(--muted);
  font-weight: 900;
}

.main,
.operations-mode .main,
.theme-light.operations-mode .main {
  background: var(--bg);
  padding: 28px 32px;
}

.topbar {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: var(--shadow-soft);
  padding: 18px 20px;
  margin-bottom: 18px;
}

.operations-mode .topbar {
  margin-bottom: 18px;
}

h1 {
  color: var(--text);
  font-size: 28px;
  line-height: 1.2;
}

#pageSubtitle,
#sectionHint,
#detailDesc,
.native-muted {
  color: var(--muted);
}

.search,
.icon-btn,
.btn,
.mini-input,
.mini-select,
.mini-textarea,
input,
select,
textarea {
  border-color: var(--line);
  border-radius: 8px;
}

.search,
.icon-btn {
  background: var(--panel-2);
}

.icon-btn,
.btn {
  color: var(--text);
  font-weight: 950;
}

.btn.primary,
.pill-tab.active,
.tab.active,
.internal-toolbox-add {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.btn:hover,
.icon-btn:hover,
.nav button:hover {
  transform: translateY(-1px);
}

.workspace,
.detail,
.metric,
.native-card,
.home-card,
.card {
  border-color: var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: var(--shadow-soft);
}

.operations-mode .workspace {
  background: transparent;
  box-shadow: none;
}

.metric {
  border-top: 4px solid var(--accent);
}

.metric:nth-child(2) {
  border-top-color: var(--accent-2);
}

.metric:nth-child(3) {
  border-top-color: var(--accent-3);
}

.view-tabs,
.pill-tab,
.badge,
.home-strip div,
.detail-box,
.ai-metric,
.toast {
  border-color: var(--line);
  background: var(--panel-2);
}

table {
  color: var(--text);
}

th {
  background: #f1f7fb;
  color: #58708a;
}

td,
th {
  border-bottom-color: var(--line);
}

.theme-dark th {
  background: #1b2a40;
  color: #bad0e8;
}

.didi-ops-page,
.didi-member-page,
.didi-finance-page,
.didi-supplier-page,
.didi-purchase-page,
.store-pickup-page,
.cat-litter-page,
.didi-expiry-page,
.didi-office-page,
.internal-toolbox-page {
  background: transparent;
  color: var(--text);
  gap: 16px;
}

.didi-ops-page,
.ops-panel,
.didi-member-page,
.didi-finance-page,
.didi-supplier-page,
.didi-purchase-page,
.store-pickup-page,
.cat-litter-page,
.didi-expiry-page,
.didi-office-page,
.internal-toolbox-page,
.native-panel {
  min-width: 0;
  max-width: 100%;
}

.theme-light.operations-mode .ops-panel,
.theme-light.operations-mode .cfo-panel,
.theme-light.operations-mode .supplier-section-card,
.theme-light.operations-mode .supplier-mobile-card,
.theme-light.operations-mode .purchase-create-card,
.theme-light.operations-mode .purchase-backup-card,
.theme-light.operations-mode .purchase-table-card,
.theme-light.operations-mode .purchase-stat-card,
.theme-light.operations-mode .expiry-create-card,
.theme-light.operations-mode .expiry-backup-card,
.theme-light.operations-mode .expiry-table-card,
.theme-light.operations-mode .expiry-stat-card,
.store-pickup-create-card,
.store-pickup-table-card,
.store-pickup-source-note,
.store-pickup-empty,
.cat-litter-brand-card,
.cat-litter-create-card,
.cat-litter-table-card,
.cat-litter-record-card,
.cat-litter-source-note,
.cat-litter-empty,
.internal-toolbox-hero,
.internal-toolbox-card,
.office-topline,
.office-card,
.office-detail-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: var(--shadow-soft);
}

.office-detail-card,
.office-agent-summary {
  background:
    linear-gradient(135deg, rgba(47, 109, 246, .08), transparent 38%),
    var(--panel);
}

.theme-light.operations-mode .decision-metric-card,
.theme-light.operations-mode .action-score-card,
.theme-light.operations-mode .quality-card,
.theme-light.operations-mode .ops-advice-item,
.theme-light.operations-mode .ops-nested-box,
.theme-light.operations-mode .cfo-kpi-card,
.theme-light.operations-mode .cfo-detail-summary article,
.purchase-stat-card,
.expiry-stat-card {
  border-radius: 8px;
  background: var(--panel-2);
}

.store-pickup-page {
  --pickup-bg: transparent;
  --pickup-card: var(--panel);
  --pickup-line: var(--line);
  --pickup-text: var(--text);
  --pickup-muted: var(--muted);
  --pickup-soft: var(--panel-2);
  --pickup-primary: var(--accent);
  --pickup-blue: #2d92d8;
  --pickup-purple: #8d55c7;
  padding: 0;
}

.cat-litter-page {
  --cat-bg: transparent;
  --cat-card: var(--panel);
  --cat-line: var(--line);
  --cat-text: var(--text);
  --cat-muted: var(--muted);
  --cat-soft: var(--panel-2);
  --cat-primary: var(--accent);
  --cat-pickup: #14a89c;
  --cat-renew: #8d55c7;
  padding: 0;
}

.internal-toolbox-page {
  --toolbox-bg: transparent;
  --toolbox-card: var(--panel);
  --toolbox-card-2: var(--panel-2);
  --toolbox-text: var(--text);
  --toolbox-muted: var(--muted);
  --toolbox-line: var(--line);
  --toolbox-soft: var(--panel-2);
}

.store-pickup-header,
.cat-litter-header,
.internal-toolbox-hero-top {
  border-bottom-color: var(--line);
}

.store-pickup-tabs,
.cat-litter-top-tabs,
.internal-toolbox-actions,
.view-tabs {
  background: var(--panel-2);
  border-radius: 8px;
}

.store-pickup-tabs button.active,
.cat-litter-top-tabs button.active,
.internal-toolbox-tab.active,
.internal-toolbox-tab.all {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 8px 16px rgba(47, 109, 246, .18);
}

.store-pickup-primary-btn,
.cat-litter-primary-btn,
.purchase-create-btn {
  background: var(--accent);
  border-color: var(--accent);
}

.purchase-input,
.purchase-mini-select,
.expiry-input,
.expiry-mini-select,
.supplier-input,
.member-mgmt-input,
.member-mgmt-select,
.store-pickup-input,
.cat-litter-input,
.internal-toolbox-search,
.office-input,
.cfo-field-input,
.didi-ops-page .mini-select,
.didi-ops-page .mini-input {
  border-color: var(--line);
  background: var(--panel);
  color: var(--text);
}

.member-mgmt-input,
.member-mgmt-select,
.internal-toolbox-search {
  min-height: 45px;
  height: auto;
  padding: 9px 12px;
  font-size: 14px;
  line-height: 1.35;
}

.member-mgmt-input::placeholder,
.internal-toolbox-search::placeholder {
  color: #94a3b8;
  font-size: 14px;
  opacity: 1;
}

.member-mgmt-search-grid .btn {
  min-height: 45px;
  font-size: 14px;
}

.purchase-input:focus,
.expiry-input:focus,
.supplier-input:focus,
.member-mgmt-input:focus,
.store-pickup-input:focus,
.cat-litter-input:focus,
.internal-toolbox-search:focus,
.office-input:focus,
.mini-input:focus,
.mini-select:focus,
.mini-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(47, 109, 246, .12);
  outline: 0;
}

.store-pickup-table th,
.cat-litter-table th,
.purchase-ledger-table th,
.expiry-ledger-table th,
.member-mgmt-table th,
.supplier-table th,
.cfo-field-section,
.didi-ops-page th {
  background: #f1f7fb;
  color: #526a83;
}

.store-pickup-table tr:hover td,
.cat-litter-table tr:hover td,
.purchase-ledger-table tr:hover td,
.expiry-ledger-table tr:hover td,
.member-mgmt-table tr:hover td,
.supplier-table tr:hover td {
  background: #fbfdff;
}

.decision-metric-card.status-ok,
.theme-light.operations-mode .decision-metric-card.status-ok,
.quality-card,
.purchase-stat-card strong.green,
.expiry-stat-card strong.green {
  border-color: rgba(20, 168, 156, .36);
}

.decision-metric-card.status-warn,
.theme-light.operations-mode .decision-metric-card.status-warn {
  border-color: rgba(255, 139, 104, .45);
}

.decision-metric-card.status-high,
.theme-light.operations-mode .decision-metric-card.status-high {
  border-color: rgba(239, 68, 68, .45);
}

.theme-dark .workspace,
.theme-dark .detail,
.theme-dark .metric,
.theme-dark .native-card,
.theme-dark .home-card,
.theme-dark .card,
.theme-dark.operations-mode .ops-panel,
.theme-dark.operations-mode .cfo-panel,
.theme-dark.operations-mode .supplier-section-card,
.theme-dark.operations-mode .purchase-create-card,
.theme-dark.operations-mode .purchase-backup-card,
.theme-dark.operations-mode .purchase-table-card,
.theme-dark.operations-mode .purchase-stat-card,
.theme-dark.operations-mode .expiry-create-card,
.theme-dark.operations-mode .expiry-backup-card,
.theme-dark.operations-mode .expiry-table-card,
.theme-dark.operations-mode .expiry-stat-card,
.theme-dark .store-pickup-create-card,
.theme-dark .store-pickup-table-card,
.theme-dark .cat-litter-brand-card,
.theme-dark .cat-litter-create-card,
.theme-dark .cat-litter-table-card,
.theme-dark .internal-toolbox-hero,
.theme-dark .internal-toolbox-card,
.theme-dark .office-topline,
.theme-dark .office-card,
.theme-dark .office-detail-card,
.theme-dark .office-agent-summary {
  background: var(--panel);
  border-color: var(--line);
  box-shadow: none;
}

.theme-dark .office-detail-card,
.theme-dark .office-agent-summary {
  background:
    linear-gradient(135deg, rgba(96, 165, 250, .12), transparent 34%),
    var(--panel);
}

.theme-dark .store-pickup-page {
  --pickup-bg: transparent;
  --pickup-card: var(--panel);
  --pickup-line: var(--line);
  --pickup-text: var(--text);
  --pickup-muted: var(--muted);
  --pickup-soft: var(--panel-2);
  --pickup-primary: var(--accent);
}

.theme-dark .cat-litter-page {
  --cat-bg: transparent;
  --cat-card: var(--panel);
  --cat-line: var(--line);
  --cat-text: var(--text);
  --cat-muted: var(--muted);
  --cat-soft: var(--panel-2);
  --cat-primary: var(--accent);
}

.theme-dark .internal-toolbox-page {
  --toolbox-bg: transparent;
  --toolbox-card: var(--panel);
  --toolbox-card-2: var(--panel-2);
  --toolbox-text: var(--text);
  --toolbox-muted: var(--muted);
  --toolbox-line: var(--line);
  --toolbox-soft: var(--panel-2);
}

.theme-dark .store-pickup-table th,
.theme-dark .cat-litter-table th,
.theme-dark .purchase-ledger-table th,
.theme-dark .expiry-ledger-table th,
.theme-dark .member-mgmt-table th,
.theme-dark .supplier-table th,
.theme-dark .cfo-field-section,
.theme-dark .didi-ops-page th {
  background: var(--panel-2);
  color: #bad0e8;
}

.theme-dark .store-pickup-table tr:hover td,
.theme-dark .cat-litter-table tr:hover td,
.theme-dark .purchase-ledger-table tr:hover td,
.theme-dark .expiry-ledger-table tr:hover td,
.theme-dark .member-mgmt-table tr:hover td,
.theme-dark .supplier-table tr:hover td {
  background: #18253a;
}

.theme-dark .store-pickup-table strong,
.theme-dark .cat-litter-table strong,
.theme-dark .supplier-table strong,
.theme-dark .member-mgmt-table strong {
  color: var(--text);
}

@media (max-width: 1040px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
    height: auto;
  }

  .nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .main,
  .operations-mode .main,
  .theme-light.operations-mode .main {
    padding: 14px;
  }

  .topbar {
    display: grid;
    padding: 16px;
  }

  .shell {
    grid-template-columns: 1fr;
  }

  .nav {
    grid-template-columns: 1fr;
  }
}

.nav button,
.theme-light.operations-mode .nav button,
.theme-dark.operations-mode .nav button {
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 8px 11px;
}

.nav button .nav-icon {
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 8px;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.nav button .nav-icon::before {
  content: none !important;
  display: none !important;
}

.nav button .nav-icon img,
.nav button .nav-icon svg {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

.nav button .nav-label {
  min-width: 0;
  overflow-wrap: anywhere;
  line-height: 1.25;
}

.nav button span:first-child::before,
.nav button:nth-child(3n + 1) span:first-child::before,
.nav button:nth-child(3n + 2) span:first-child::before,
.nav button:nth-child(3n) span:first-child::before {
  content: none;
  display: none;
}

.nav button.active .nav-icon,
.nav button:hover .nav-icon {
  transform: translateY(-1px);
}

.theme-dark .nav button .nav-icon {
  background: transparent;
}

@media (max-width: 1040px) {
  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 60px minmax(0, 1fr) auto;
  }
}

/* UX pass: tighter navigation, clearer page context, calmer data surfaces. */
.shell {
  grid-template-columns: 292px minmax(0, 1fr);
}

.sidebar,
.theme-light.operations-mode .sidebar,
.theme-dark.operations-mode .sidebar {
  padding: 18px 12px;
}

.brand {
  margin-bottom: 10px;
  padding-bottom: 14px;
}

.nav {
  gap: 5px;
}

.nav button,
.theme-light.operations-mode .nav button,
.theme-dark.operations-mode .nav button {
  grid-template-columns: 52px minmax(0, 1fr) auto;
  min-height: 61px;
  gap: 10px;
  padding: 6px 10px;
}

.nav button .nav-icon {
  width: 52px;
  height: 52px;
  transition: transform .16s ease;
}

.nav button .nav-label {
  font-size: 14px;
  letter-spacing: 0;
}

.count,
.theme-light.operations-mode .nav .count {
  min-width: 24px;
  height: 24px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--muted);
  font-size: 11px;
}

.nav button.active .count {
  background: #ffffff;
  color: var(--accent);
  border-color: #cfe0ff;
}

.theme-dark .nav button.active .count {
  background: var(--panel-2);
}

.main,
.operations-mode .main,
.theme-light.operations-mode .main {
  padding: 24px 30px 40px;
}

.topbar {
  position: sticky;
  top: 16px;
  z-index: 20;
  display: flex;
  align-items: center;
  min-height: 112px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(14px);
}

.theme-dark .topbar {
  background: rgba(22, 34, 52, .9);
}

.topbar-main {
  min-width: 0;
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
}

.page-hero-icon {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff8ec;
  box-shadow: 0 12px 26px rgba(109, 87, 65, .09);
  overflow: hidden;
}

.page-hero-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.page-copy {
  min-width: 0;
}

.page-kicker {
  width: fit-content;
  max-width: 100%;
  margin-bottom: 4px;
  border: 1px solid #dbe7f0;
  border-radius: 999px;
  background: #f8fbff;
  color: #66788d;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 900;
}

.theme-dark .page-kicker {
  border-color: var(--line);
  background: var(--panel-2);
  color: var(--muted);
}

#pageTitle {
  overflow-wrap: anywhere;
}

#pageSubtitle {
  max-width: 780px;
}

.workspace,
.detail,
.ops-panel,
.cfo-panel,
.supplier-section-card,
.purchase-create-card,
.purchase-backup-card,
.purchase-table-card,
.purchase-stat-card,
.store-pickup-create-card,
.store-pickup-table-card,
.cat-litter-create-card,
.cat-litter-table-card,
.expiry-create-card,
.expiry-backup-card,
.expiry-table-card,
.expiry-stat-card,
.internal-toolbox-hero,
.internal-toolbox-card {
  scroll-margin-top: 150px;
}

.btn,
.icon-btn,
.tab,
.pill-tab,
.store-pickup-tabs button,
.cat-litter-top-tabs button,
.internal-toolbox-tab,
.store-pickup-primary-btn,
.store-pickup-action-btn,
.store-pickup-ghost-btn,
.cat-litter-primary-btn,
.cat-litter-action-btn,
.cat-litter-ghost-btn {
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.btn.primary,
.store-pickup-primary-btn,
.cat-litter-primary-btn,
.purchase-create-btn {
  box-shadow: 0 10px 18px rgba(47, 109, 246, .18);
}

.btn.primary:hover,
.store-pickup-primary-btn:hover,
.cat-litter-primary-btn:hover,
.purchase-create-btn:hover {
  box-shadow: 0 12px 22px rgba(47, 109, 246, .22);
}

.table-wrap,
.member-mgmt-table-wrap,
.supplier-table-wrap,
.purchase-table-wrap,
.store-pickup-table-wrap,
.cat-litter-table-wrap,
.expiry-table-wrap {
  border-radius: 8px;
}

.table-wrap table,
.member-mgmt-table,
.supplier-table,
.purchase-ledger-table,
.store-pickup-table,
.cat-litter-table,
.expiry-ledger-table {
  border-spacing: 0;
}

.table-wrap th,
.member-mgmt-table th,
.supplier-table th,
.purchase-ledger-table th,
.store-pickup-table th,
.cat-litter-table th,
.expiry-ledger-table th {
  position: sticky;
  top: 0;
  z-index: 1;
}

input,
select,
textarea,
.mini-input,
.mini-select,
.mini-textarea,
.purchase-input,
.expiry-input,
.supplier-input,
.member-mgmt-input,
.store-pickup-input,
.cat-litter-input,
.internal-toolbox-search {
  line-height: 1.35;
}

@media (max-width: 1040px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    position: static;
    height: auto;
  }

  .nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .main,
  .operations-mode .main,
  .theme-light.operations-mode .main {
    padding: 12px;
  }

  .topbar {
    position: static;
    min-height: 0;
  }

  .topbar-main {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 12px;
  }

  .page-hero-icon {
    width: 58px;
    height: 58px;
  }

  .nav {
    grid-template-columns: 1fr;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 48px minmax(0, 1fr) auto;
    min-height: 56px;
  }

  .nav button .nav-icon {
    width: 48px;
    height: 48px;
  }
}

/* Responsive targets: iPhone 17 / 17 Pro / Pro Max, iPad mini, iPad, iPad Pro. */
@media (min-width: 1041px) and (max-width: 1180px) {
  .shell {
    grid-template-columns: 244px minmax(0, 1fr);
  }

  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    padding: 14px 10px;
  }

  .brand {
    gap: 9px;
  }

  .mark {
    width: 40px;
    height: 40px;
  }

  .brand-title {
    font-size: 14px;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 44px minmax(0, 1fr) auto;
    min-height: 54px;
    gap: 8px;
    padding: 5px 8px;
  }

  .nav button .nav-icon {
    width: 44px;
    height: 44px;
  }

  .nav button .nav-label {
    font-size: 13px;
  }

  .main,
  .operations-mode .main,
  .theme-light.operations-mode .main {
    padding: 20px;
  }

  .topbar {
    min-height: 96px;
  }

  .topbar-main {
    grid-template-columns: 62px minmax(0, 1fr);
  }

  .page-hero-icon {
    width: 62px;
    height: 62px;
  }
}

@media (min-width: 721px) and (max-width: 1040px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    position: sticky;
    top: 0;
    z-index: 40;
    height: auto;
    max-height: none;
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    box-shadow: 0 10px 28px rgba(34, 54, 77, .08);
  }

  .brand {
    margin: 0;
    padding: 0;
    border-bottom: 0;
  }

  .nav {
    display: grid;
    grid-template-columns: repeat(5, minmax(112px, 1fr));
    gap: 7px;
    margin-top: 0;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 34px minmax(0, 1fr);
    min-height: 48px;
    gap: 6px;
    padding: 5px 7px;
  }

  .nav button .nav-icon {
    width: 34px;
    height: 34px;
  }

  .nav button .nav-label {
    font-size: 12px;
    line-height: 1.2;
  }

  .nav .count {
    display: none;
  }

  .main,
  .operations-mode .main,
  .theme-light.operations-mode .main {
    padding: 18px;
  }

  .topbar {
    top: 10px;
    min-height: 96px;
    padding: 14px;
  }

  .topbar-main {
    grid-template-columns: 62px minmax(0, 1fr);
    gap: 12px;
  }

  .page-hero-icon {
    width: 62px;
    height: 62px;
  }

  h1 {
    font-size: 24px;
  }

  .top-actions {
    gap: 8px;
  }

  .search {
    min-width: 220px;
  }

  .summary-grid,
  .cards,
  .home-grid,
  .home-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .decision-grid,
  .action-score-grid,
  .purchase-stat-grid,
  .expiry-stat-grid,
  .cfo-kpi-grid-top,
  .cfo-kpi-grid-mid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .store-pickup-create-card {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .store-pickup-create-card label.wide {
    grid-column: 1 / -1;
  }

  .cat-litter-create-card,
  .expiry-form-grid.top,
  .expiry-form-grid.bottom,
  .purchase-form-grid.top,
  .purchase-form-grid.bottom,
  .supplier-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .store-pickup-table,
  .cat-litter-table,
  .purchase-ledger-table,
  .expiry-ledger-table {
    min-width: 920px;
  }
}

@media (min-width: 721px) and (max-width: 820px) {
  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 9px;
  }

  .brand {
    width: fit-content;
  }

  .nav {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 30px minmax(0, 1fr);
    min-height: 48px;
    gap: 5px;
    padding: 5px;
  }

  .nav button .nav-icon {
    width: 30px;
    height: 30px;
  }

  .nav button .nav-label {
    font-size: 11px;
  }
}

@media (max-width: 720px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    position: sticky;
    top: 0;
    z-index: 50;
    height: auto;
    max-height: none;
    padding: 8px 10px 10px;
    overflow-x: hidden;
    box-shadow: 0 10px 28px rgba(34, 54, 77, .1);
  }

  .brand {
    min-height: 48px;
    margin: 0;
    padding: 0 2px 8px;
    border-bottom: 0;
  }

  .mark {
    width: 38px;
    height: 38px;
  }

  .brand-title {
    font-size: 14px;
  }

  .brand-sub {
    font-size: 11px;
  }

  .nav {
    display: flex;
    gap: 8px;
    margin: 0;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    padding: 2px 2px 6px;
  }

  .nav::-webkit-scrollbar {
    height: 0;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    flex: 0 0 118px;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-content: center;
    min-height: 92px;
    gap: 3px;
    padding: 6px;
    text-align: center;
    scroll-snap-align: start;
  }

  .nav button .nav-icon {
    width: 48px;
    height: 48px;
  }

  .nav button .nav-label {
    font-size: 12px;
    line-height: 1.2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }

  .nav .count {
    display: none;
  }

  .main,
  .operations-mode .main,
  .theme-light.operations-mode .main {
    padding: 12px;
  }

  .topbar {
    position: static;
    display: grid;
    gap: 12px;
    min-height: 0;
    padding: 12px;
    margin-bottom: 12px;
  }

  .topbar-main {
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 10px;
  }

  .page-hero-icon {
    width: 54px;
    height: 54px;
  }

  .page-kicker {
    max-width: 100%;
    font-size: 11px;
    padding: 3px 8px;
  }

  h1 {
    font-size: 22px;
  }

  #pageSubtitle {
    font-size: 13px;
    line-height: 1.45;
  }

  .top-actions {
    display: grid;
    grid-template-columns: 1fr 42px;
    gap: 8px;
    width: 100%;
  }

  .search {
    min-width: 0;
    width: 100%;
  }

  .search span {
    display: none;
  }

  .icon-btn {
    width: 42px;
    height: 42px;
  }

  .summary-grid,
  .cards,
  .home-grid,
  .home-strip,
  .detail-grid,
  .native-grid,
  .decision-grid,
  .quality-grid,
  .action-score-grid,
  .purchase-stat-grid,
  .expiry-stat-grid,
  .cfo-kpi-grid-top,
  .cfo-kpi-grid-mid,
  .cfo-detail-summary,
  .supplier-grid,
  .purchase-grid,
  .social-grid,
  .toolbox-grid,
  .internal-toolbox-grid {
    grid-template-columns: 1fr;
  }

  .ops-panel,
  .cfo-panel,
  .supplier-section-card,
  .purchase-create-card,
  .purchase-backup-card,
  .purchase-table-card,
  .purchase-stat-card,
  .store-pickup-create-card,
  .store-pickup-table-card,
  .cat-litter-create-card,
  .cat-litter-table-card,
  .expiry-create-card,
  .expiry-backup-card,
  .expiry-table-card,
  .expiry-stat-card,
  .internal-toolbox-hero {
    padding: 12px;
  }

  .ops-control-row,
  .cfo-toolbar,
  .cfo-section-head,
  .cfo-upload-toolbar,
  .supplier-toolbar,
  .purchase-ledger-head,
  .purchase-ledger-title-row,
  .store-pickup-header,
  .cat-litter-header,
  .expiry-ledger-head,
  .expiry-filter-row,
  .internal-toolbox-hero-top,
  .internal-toolbox-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .store-pickup-create-card,
  .cat-litter-create-card,
  .cat-litter-brand-add,
  .cat-litter-search-row,
  .expiry-form-grid.top,
  .expiry-form-grid.bottom,
  .purchase-form-grid.top,
  .purchase-form-grid.bottom,
  .supplier-form-grid,
  .member-mgmt-search-grid,
  .member-searchbar {
    grid-template-columns: 1fr;
  }

  .store-pickup-create-card label.wide {
    grid-column: auto;
  }

  .btn,
  .store-pickup-primary-btn,
  .store-pickup-ghost-btn,
  .cat-litter-primary-btn,
  .cat-litter-ghost-btn,
  .expiry-mini-select,
  .purchase-create-btn,
  .purchase-search,
  .supplier-search,
  .supplier-toolbar-right,
  .supplier-toolbar-right .btn,
  .internal-toolbox-add,
  .internal-toolbox-actions .internal-toolbox-soft-btn {
    width: 100%;
    max-width: none;
  }

  .store-pickup-tabs,
  .cat-litter-top-tabs,
  .purchase-tabs,
  .expiry-tabs,
  .pill-tabs,
  .internal-toolbox-tabs {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }

  .store-pickup-tabs button,
  .cat-litter-top-tabs button,
  .purchase-tabs button,
  .expiry-tabs button,
  .pill-tab,
  .internal-toolbox-tab {
    flex: 0 0 auto;
  }

  .store-pickup-table,
  .cat-litter-table,
  .purchase-ledger-table,
  .expiry-ledger-table,
  .member-mgmt-table,
  .supplier-table {
    min-width: 760px;
  }

  .table-wrap,
  .didi-ops-page .table-wrap,
  .member-mgmt-table-wrap,
  .supplier-table-wrap,
  .purchase-table-wrap,
  .store-pickup-table-wrap,
  .cat-litter-table-wrap,
  .expiry-table-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .office-layout {
    grid-template-columns: 1fr;
  }

  .office-map-viewport {
    max-height: 58vh;
  }
}

@media (max-width: 430px) {
  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    flex-basis: 108px;
    min-height: 88px;
  }

  .nav button .nav-icon {
    width: 44px;
    height: 44px;
  }

  .top-actions {
    grid-template-columns: 1fr 40px;
  }

  h1 {
    font-size: 21px;
  }

  .store-pickup-table,
  .cat-litter-table,
  .purchase-ledger-table,
  .expiry-ledger-table,
  .member-mgmt-table,
  .supplier-table {
    min-width: 720px;
  }
}

@media (max-width: 380px) {
  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    flex-basis: 100px;
  }

  .topbar-main {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .page-hero-icon {
    width: 48px;
    height: 48px;
  }
}

/* Mobile and tablet navigation: hamburger menu instead of persistent nav. */
.nav-toggle {
  display: none;
}

.nav-toggle-lines {
  width: 18px;
  display: grid;
  gap: 4px;
}

.nav-toggle-lines i {
  display: block;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

@media (max-width: 1040px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    position: sticky;
    top: 0;
    z-index: 80;
    display: block;
    height: auto;
    max-height: none;
    padding: 8px 12px;
    overflow: visible;
    box-shadow: 0 10px 28px rgba(34, 54, 77, .1);
  }

  .brand {
    width: auto;
    min-height: 52px;
    margin: 0;
    padding: 0;
    border-bottom: 0;
  }

  .brand-copy {
    flex: 0 1 auto;
  }

  .theme-toggle {
    min-height: 40px;
    margin-left: auto;
    padding: 8px 11px;
  }

  .nav-toggle {
    min-height: 40px;
    margin-left: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-2);
    color: var(--text);
    padding: 8px 10px;
    font: inherit;
    font-size: 13px;
    font-weight: 950;
    cursor: pointer;
  }

  .nav-toggle:hover {
    border-color: var(--line-strong);
  }

  body.nav-open .nav-toggle {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
  }

  body.nav-open .nav-toggle-lines i:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
  }

  body.nav-open .nav-toggle-lines i:nth-child(2) {
    opacity: 0;
  }

  body.nav-open .nav-toggle-lines i:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
  }

  .nav-toggle-lines i {
    transition: transform .16s ease, opacity .16s ease;
  }

  .nav,
  .theme-light.operations-mode .nav,
  .theme-dark.operations-mode .nav {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
    max-width: 100%;
    height: 0;
    max-height: 0;
    margin: 0;
    padding: 0 8px;
    border: 0;
    border-radius: 8px;
    background: var(--panel);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    visibility: hidden;
    transition: max-height .22s ease, opacity .18s ease, transform .18s ease, padding .18s ease, margin .18s ease;
  }

  body.nav-open .nav,
  body.nav-open.theme-light.operations-mode .nav,
  body.nav-open.theme-dark.operations-mode .nav {
    height: auto;
    max-height: min(72vh, 640px);
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    visibility: visible;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    width: 100%;
    min-height: 58px;
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    align-items: center;
    justify-items: stretch;
    gap: 8px;
    padding: 6px 8px;
    text-align: left;
  }

  .nav button .nav-icon {
    width: 44px;
    height: 44px;
  }

  .nav button .nav-label {
    display: block;
    font-size: 13px;
    line-height: 1.25;
    overflow: visible;
    -webkit-line-clamp: unset;
  }

  .nav .count {
    display: inline-grid;
  }
}

@media (max-width: 720px) {
  .sidebar,
  .theme-light.operations-mode .sidebar,
  .theme-dark.operations-mode .sidebar {
    padding: 8px 10px;
  }

  .theme-toggle {
    width: 42px;
    min-width: 42px;
    padding: 0;
  }

  .theme-label {
    display: none;
  }

  body.nav-open .nav,
  body.nav-open.theme-light.operations-mode .nav,
  body.nav-open.theme-dark.operations-mode .nav {
    max-height: calc(100vh - 74px);
  }

  .nav,
  .theme-light.operations-mode .nav,
  .theme-dark.operations-mode .nav {
    grid-template-columns: 1fr;
  }

  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    flex: none;
    min-height: 58px;
    grid-template-columns: 44px minmax(0, 1fr) auto;
  }

  .nav button .nav-icon {
    width: 44px;
    height: 44px;
  }

  .nav-toggle span:last-child {
    display: none;
  }
}

/* Requested cleanup: no entry-count chips in the header or sidebar. */
.page-kicker,
.count {
  display: none !important;
}

.nav button,
.theme-light.operations-mode .nav button,
.theme-dark.operations-mode .nav button {
  grid-template-columns: 36px minmax(0, 1fr) !important;
  min-height: 54px !important;
}

.nav button .nav-icon {
  width: 35px !important;
  height: 35px !important;
}

@media (min-width: 1041px) and (max-width: 1180px),
       (max-width: 1040px) {
  .nav button,
  .theme-light.operations-mode .nav button,
  .theme-dark.operations-mode .nav button {
    grid-template-columns: 30px minmax(0, 1fr) !important;
    min-height: 52px !important;
  }

  .nav button .nav-icon {
    width: 29px !important;
    height: 29px !important;
  }
}

/* Compact page header: keep the current workspace clear without taking vertical space. */
.topbar,
.operations-mode .topbar,
.theme-light.operations-mode .topbar,
.theme-dark.operations-mode .topbar {
  position: static !important;
  min-height: 0 !important;
  padding: 9px 14px !important;
  margin-bottom: 14px !important;
}

.topbar-main {
  grid-template-columns: 48px minmax(0, 1fr) !important;
  gap: 10px !important;
}

.page-hero-icon {
  width: 48px !important;
  height: 48px !important;
  box-shadow: none !important;
}

#pageTitle {
  font-size: 24px !important;
  line-height: 1.12 !important;
}

#pageSubtitle {
  display: none !important;
}

@media (max-width: 1040px) {
  .topbar,
  .operations-mode .topbar,
  .theme-light.operations-mode .topbar,
  .theme-dark.operations-mode .topbar {
    padding: 8px 10px !important;
    margin-bottom: 12px !important;
  }

  .topbar-main {
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 9px !important;
  }

  .page-hero-icon {
    width: 44px !important;
    height: 44px !important;
  }

  #pageTitle {
    font-size: 21px !important;
  }
}

@media (max-width: 430px) {
  .topbar-main {
    grid-template-columns: 40px minmax(0, 1fr) !important;
  }

  .page-hero-icon {
    width: 40px !important;
    height: 40px !important;
  }

  #pageTitle {
    font-size: 20px !important;
  }
}

/* Shared create popup: keep pages list-first and move add forms into a focused layer. */
.module-action-row {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 12px 14px;
  box-shadow: var(--shadow-soft);
}

.module-action-row strong {
  color: var(--text);
  display: block;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.25;
}

.module-action-row p {
  color: var(--muted);
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.45;
}

.module-action-row .btn {
  min-width: 132px;
  min-height: 38px;
  white-space: nowrap;
}

.module-message {
  border: 1px solid #fde68a;
  border-radius: 8px;
  background: #fffbeb;
  color: #92400e;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 850;
}

.theme-dark .module-message {
  background: rgba(251, 191, 36, .1);
  color: #fbbf24;
  border-color: rgba(251, 191, 36, .28);
}

.console-popup {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 24px;
}

.console-popup-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(15, 23, 42, .44);
  backdrop-filter: blur(8px);
  cursor: pointer;
}

.console-popup-panel {
  position: relative;
  z-index: 1;
  width: min(920px, calc(100vw - 32px));
  max-height: min(86vh, 820px);
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  box-shadow: 0 30px 90px rgba(15, 23, 42, .28);
}

.console-popup-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
  padding: 16px 18px 12px;
}

.console-popup-head h3 {
  color: var(--text);
  font-size: 20px;
  font-weight: 950;
  line-height: 1.25;
  margin: 0;
}

.console-popup-head p {
  color: var(--muted);
  margin-top: 4px;
  font-size: 13px;
  line-height: 1.45;
}

.console-popup-close {
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--text);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.console-popup-body {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.console-popup-message {
  border: 1px solid #fde68a;
  border-radius: 8px;
  background: #fffbeb;
  color: #92400e;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 850;
}

.theme-dark .console-popup-message {
  background: rgba(251, 191, 36, .1);
  color: #fbbf24;
  border-color: rgba(251, 191, 36, .28);
}

.confirm-action-card {
  display: grid;
  gap: 16px;
}

.confirm-action-summary {
  display: grid;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  padding: 14px;
}

.confirm-action-summary strong {
  color: var(--text);
  font-size: 16px;
  font-weight: 950;
  line-height: 1.35;
}

.confirm-action-summary span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.confirm-action-card.danger .confirm-action-summary {
  border-color: rgba(239, 68, 68, .28);
  background: rgba(239, 68, 68, .07);
}

.confirm-action-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.console-popup .btn.danger {
  border-color: #ef4444;
  background: #ef4444;
  color: #ffffff;
}

.expiry-attachment-row {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  padding: 10px 12px;
}

.expiry-attachment-row > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.expiry-attachment-row label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.console-popup-panel .supplier-form-grid,
.console-popup-panel .purchase-form-grid.top,
.console-popup-panel .expiry-form-grid.top {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.console-popup-panel .purchase-form-grid.bottom,
.console-popup-panel .expiry-form-grid.bottom {
  grid-template-columns: 1fr;
}

.console-popup-panel .purchase-create-btn {
  width: 100%;
}

.console-popup-panel .store-pickup-create-card,
.console-popup-panel .cat-litter-create-card {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.console-popup-panel .store-pickup-create-card {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.console-popup-panel .store-pickup-create-card label.wide {
  grid-column: 1 / -1;
}

.console-popup-panel .cat-litter-create-card {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.console-popup-panel .store-pickup-primary-btn,
.console-popup-panel .cat-litter-primary-btn {
  width: 100%;
}

.console-popup-panel .cat-litter-popup-actions .cat-litter-primary-btn,
.console-popup-panel .cat-litter-popup-actions .cat-litter-ghost-btn {
  width: auto;
  min-width: 108px;
}

@media (max-width: 720px) {
  .module-action-row {
    align-items: stretch;
    flex-direction: column;
  }

  .module-action-row .btn {
    width: 100%;
  }

  .console-popup {
    align-items: end;
    padding: 0;
  }

  .console-popup-panel {
    width: 100%;
    max-height: 88vh;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 16px 16px 0 0;
  }

  .console-popup-head {
    padding: 14px;
  }

  .console-popup-body {
    padding: 14px;
  }

  .console-popup-panel .supplier-form-grid,
  .console-popup-panel .purchase-form-grid.top,
  .console-popup-panel .purchase-form-grid.bottom,
  .console-popup-panel .store-pickup-create-card,
  .console-popup-panel .cat-litter-create-card,
  .console-popup-panel .expiry-form-grid.top,
  .console-popup-panel .expiry-form-grid.bottom {
    grid-template-columns: 1fr;
  }
}

/* Align cat litter and store pickup ledgers with the expiry risk-list rhythm. */
.store-pickup-search-row,
.cat-litter-search-row {
  display: grid;
  grid-template-columns: minmax(260px, 420px) auto !important;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid var(--line) !important;
  border-radius: 8px;
  background: var(--panel) !important;
  padding: 12px 14px !important;
  box-shadow: var(--shadow-soft);
}

.store-pickup-search-row .store-pickup-input,
.cat-litter-search-row .cat-litter-input {
  max-width: none;
  min-height: 40px;
}

.store-pickup-search-row .store-pickup-ghost-btn,
.cat-litter-search-row .cat-litter-ghost-btn {
  min-height: 40px;
  padding: 7px 12px;
}

.store-pickup-table-card,
.cat-litter-table-card {
  padding: 14px !important;
  overflow: visible;
}

.aligned-ledger-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0 0 8px;
}

.aligned-ledger-title-row h3 {
  margin: 0;
  color: var(--text);
  font-size: 18px;
  font-weight: 950;
  line-height: 1.25;
}

.aligned-ledger-title-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.store-pickup-table-wrap,
.cat-litter-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.store-pickup-table,
.cat-litter-table {
  min-width: 1020px;
  width: 100%;
  color: var(--text);
  border-collapse: collapse;
  font-size: 13px;
}

.cat-litter-table {
  min-width: 1040px;
}

.store-pickup-table th,
.cat-litter-table th {
  background: var(--panel-2);
  color: var(--muted);
  border-bottom: 1px solid var(--line);
  padding: 11px 10px;
  font-size: 13px;
  font-weight: 950;
}

.store-pickup-table th:last-child,
.store-pickup-table td:last-child {
  width: 210px;
  min-width: 210px;
}

.cat-litter-table th:last-child,
.cat-litter-table td:last-child {
  width: 270px;
  min-width: 270px;
}

.store-pickup-table td,
.cat-litter-table td {
  border-bottom: 1px solid var(--line);
  padding: 11px 10px;
  vertical-align: middle;
}

.store-pickup-table tbody tr:last-child td,
.cat-litter-table tbody tr:last-child td {
  border-bottom: 0;
}

.store-pickup-table strong,
.cat-litter-table strong {
  color: var(--text);
}

.store-pickup-muted,
.cat-litter-muted,
.cat-litter-tags {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.store-pickup-location {
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
}

.store-pickup-pill,
.store-pickup-payment {
  min-height: 26px;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
}

.store-pickup-status-cell {
  min-width: 126px;
  text-align: center;
}

.store-pickup-pill,
.store-pickup-payment {
  display: inline-grid;
  align-items: center;
  justify-items: center;
  gap: 2px;
  min-width: 92px;
  min-height: 38px;
  border-radius: 10px;
  padding: 6px 10px;
  border: 1px solid #cbd5e1;
  line-height: 1.15;
  text-align: center;
  white-space: nowrap;
}

.store-pickup-pill strong,
.store-pickup-payment strong {
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0;
}

.store-pickup-pill small,
.store-pickup-payment small {
  font-size: 11px;
  font-weight: 850;
  color: currentColor;
  opacity: .9;
}

.store-pickup-pill.arrived {
  color: #315846;
  background: #eef5f1;
  border-color: #bfd4c7;
}

.store-pickup-pill.vendor {
  color: #6f5e45;
  background: #f4f0e8;
  border-color: #d8cdbb;
}

.store-pickup-pill.done,
.store-pickup-payment.paid {
  color: #2f6845;
  background: #eef7f1;
  border-color: #b8d8c2;
}

.store-pickup-pill.waiting,
.store-pickup-payment.unpaid {
  color: #9a372f;
  background: #fff0ee;
  border-color: #efb0aa;
}

.cat-litter-phone {
  color: var(--accent);
  font-size: 13px;
}

.cat-litter-stock {
  display: inline-flex;
  justify-content: flex-end;
  min-width: 28px;
  font-size: 16px;
  line-height: 1;
}

.cat-litter-table tr.is-low td {
  background-image: none;
}

.store-pickup-row-actions,
.cat-litter-row-actions {
  justify-content: flex-start;
  gap: 6px;
  flex-wrap: nowrap;
}

.store-pickup-row-actions .store-pickup-action-btn,
.store-pickup-row-actions .store-pickup-ghost-btn,
.cat-litter-row-actions .cat-litter-action-btn,
.cat-litter-row-actions .cat-litter-ghost-btn {
  min-width: 0;
  min-height: 32px;
  border-radius: 8px;
  padding: 5px 9px;
  font-size: 12px;
  box-shadow: none;
}

@media (max-width: 720px) {
  .store-pickup-search-row,
  .cat-litter-search-row {
    grid-template-columns: 1fr !important;
  }

  .store-pickup-table-card,
  .cat-litter-table-card {
    padding: 12px !important;
  }

  .aligned-ledger-title-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .store-pickup-table,
  .cat-litter-table {
    min-width: 760px;
  }
}

/* Remove duplicated module titles when the top page header already names the tool. */
.store-pickup-header h3,
.cat-litter-header h3 {
  display: none !important;
}

.store-pickup-header,
.cat-litter-header {
  align-items: center !important;
  padding-bottom: 12px;
}

.store-pickup-header p,
.cat-litter-header p {
  margin: 0 !important;
  font-size: 12px;
  line-height: 1.35;
}

.cat-litter-header p {
  color: var(--muted);
}

/* Soften the old bright-blue actions into the PonPonPet green palette. */
:root,
body.theme-light,
body.theme-light.operations-mode {
  --accent: #4f806a;
  --accent-2: #73a68d;
  --accent-3: #d8ab74;
  --accent-soft: #eef7f1;
}

body.theme-dark,
body.theme-dark.operations-mode {
  --accent: #93bea3;
  --accent-2: #6fb7a4;
  --accent-3: #dfb77d;
  --accent-soft: #20362d;
}

.nav button:nth-child(3n + 1) span:first-child::before {
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(79, 128, 106, .16);
}

.nav button:hover,
.nav button.active,
.theme-light.operations-mode .nav button:hover,
.theme-light.operations-mode .nav button.active {
  background: #eef7f1;
  border-color: #cfe4d7;
  color: #315846;
}

.btn.primary,
.pill-tab.active,
.tab.active,
.internal-toolbox-add,
.store-pickup-primary-btn,
.store-pickup-action-btn,
.cat-litter-primary-btn,
.purchase-create-btn,
.purchase-tabs button.active,
.store-pickup-tabs button.active,
.cat-litter-top-tabs button.active,
.expiry-tabs button.active,
.internal-toolbox-tab.active,
.internal-toolbox-tab.all {
  border-color: #4f806a !important;
  background: linear-gradient(180deg, #6f9f85 0%, #4f806a 100%) !important;
  color: #fff !important;
  box-shadow: 0 10px 20px rgba(79, 128, 106, .2) !important;
}

.btn.primary:hover,
.internal-toolbox-add:hover,
.store-pickup-primary-btn:hover,
.store-pickup-action-btn:hover,
.cat-litter-primary-btn:hover,
.purchase-create-btn:hover {
  border-color: #426f5b !important;
  background: linear-gradient(180deg, #628f78 0%, #426f5b 100%) !important;
  box-shadow: 0 12px 22px rgba(79, 128, 106, .24) !important;
}

.cat-litter-action-btn.pickup {
  border-color: #328b7d !important;
  background: linear-gradient(180deg, #41a392 0%, #328b7d 100%) !important;
  color: #fff !important;
}

input:focus,
select:focus,
textarea:focus,
.mini-input:focus,
.mini-select:focus,
.mini-textarea:focus,
.purchase-input:focus,
.expiry-input:focus,
.supplier-input:focus,
.member-mgmt-input:focus,
.store-pickup-input:focus,
.cat-litter-input:focus,
.internal-toolbox-search:focus,
.office-input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 4px rgba(79, 128, 106, .14) !important;
}

.store-pickup-location,
.cat-litter-phone,
.purchase-stat-card strong.blue,
.theme-light.operations-mode .purchase-stat-card strong.blue {
  color: var(--accent) !important;
}

/* Finance room: quiet ledger style, no colored KPI blocks. */
.theme-light.operations-mode .cfo-panel,
.theme-light.operations-mode .cfo-kpi-card,
.theme-light.operations-mode .cfo-detail-summary article {
  border-color: var(--line);
  background: var(--panel);
  box-shadow: var(--shadow-soft);
}

.theme-light.operations-mode .cfo-kpi-card,
.theme-light.operations-mode .cfo-kpi-card.sales,
.theme-light.operations-mode .cfo-kpi-card.sales-soft,
.theme-light.operations-mode .cfo-kpi-card.purchase,
.theme-light.operations-mode .cfo-kpi-card.purchase-soft,
.theme-light.operations-mode .cfo-kpi-card.neutral,
.theme-light.operations-mode .cfo-detail-summary article {
  border-color: var(--line);
  background: #fbfdfb;
}

.theme-light.operations-mode .cfo-kpi-card strong,
.theme-light.operations-mode .cfo-kpi-card.sales strong,
.theme-light.operations-mode .cfo-kpi-card.sales-soft strong,
.theme-light.operations-mode .cfo-kpi-card.purchase strong,
.theme-light.operations-mode .cfo-kpi-card.purchase-soft strong,
.theme-light.operations-mode .cfo-detail-summary strong {
  color: var(--text);
}

.theme-light.operations-mode .cfo-sync-status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border: 1px solid #cfe5d8;
  border-radius: 999px;
  background: #f4faf6;
  color: #315846;
  padding: 5px 10px;
}

.theme-light.operations-mode .cfo-period-chip {
  border-color: #d6e5db;
  background: #f8fbf7;
  box-shadow: none;
}

.theme-light.operations-mode .cfo-period-chip.has-data {
  background: #f3faf5;
  border-color: #cce3d5;
}

.theme-light.operations-mode .cfo-period-chip.active {
  border-color: #4f806a;
  background: #4f806a;
  box-shadow: 0 8px 16px rgba(79, 128, 106, .16);
}

.theme-light.operations-mode .cfo-period-chip.active strong,
.theme-light.operations-mode .cfo-period-chip.active span {
  color: #fff;
}

.theme-light.operations-mode .cfo-field-section {
  background: #f4f8f6;
  border-bottom-color: var(--line);
  color: #315846;
}

.theme-light.operations-mode .cfo-field-key {
  background: #f8faf9;
  color: #4a5d50;
}

.theme-light.operations-mode .cfo-field-row.focus .cfo-field-key {
  color: #315846;
}

/* Monthly decision panel: compact hierarchy without the heavy color blocks. */
.ops-decision-panel {
  display: grid;
  gap: 12px;
}

.ops-decision-panel .ops-panel-title {
  margin-bottom: 0;
}

.ops-decision-panel .ops-control-row {
  margin-bottom: 0;
  padding: 10px 12px;
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 8px;
  background: rgba(15, 23, 42, .34);
}

.ops-decision-panel .decision-risk-banner {
  min-height: 40px;
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgba(148, 163, 184, .26);
  border-radius: 8px;
  background: rgba(15, 23, 42, .28);
}

.ops-decision-panel .decision-risk-banner.risk-high {
  border-color: rgba(248, 113, 113, .42);
  background: rgba(127, 29, 29, .2);
  color: #fecaca;
}

.ops-decision-panel .decision-risk-banner.risk-warn {
  border-color: rgba(245, 158, 11, .42);
  background: rgba(120, 53, 15, .22);
  color: #fde68a;
}

.ops-decision-panel .decision-risk-banner.risk-ok {
  border-color: rgba(52, 211, 153, .34);
  background: rgba(20, 83, 45, .2);
  color: #bbf7d0;
}

.ops-decision-panel .risk-dot {
  width: 10px;
  height: 10px;
}

.ops-decision-panel .decision-grid {
  gap: 10px;
}

.ops-decision-panel .decision-ledger {
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 8px;
  background: rgba(15, 23, 42, .2);
}

.ops-decision-panel .decision-ledger-head,
.ops-decision-panel .decision-ledger-row {
  display: grid;
  grid-template-columns: minmax(140px, 1.2fr) minmax(120px, .9fr) minmax(140px, 1fr) minmax(80px, .7fr);
  align-items: center;
  gap: 12px;
}

.ops-decision-panel .decision-ledger-head {
  padding: 9px 12px;
  background: rgba(15, 23, 42, .38);
  color: #aebbd0;
  font-size: 12px;
  font-weight: 900;
}

.ops-decision-panel .decision-ledger-row {
  min-height: 54px;
  padding: 10px 12px;
  border-top: 1px solid rgba(148, 163, 184, .18);
  border-left: 4px solid transparent;
}

.ops-decision-panel .decision-ledger-row.status-ok {
  border-left-color: #73a68d;
}

.ops-decision-panel .decision-ledger-row.status-warn {
  border-left-color: #d8ab74;
}

.ops-decision-panel .decision-ledger-row.status-high {
  border-left-color: #ef7777;
}

.ops-decision-panel .decision-ledger-name {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.ops-decision-panel .decision-ledger-name span {
  color: #aebbd0;
  font-size: 12px;
  font-weight: 850;
}

.ops-decision-panel .decision-ledger-name b {
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(52, 211, 153, .12);
  color: #86efac;
  font-size: 10px;
  white-space: nowrap;
}

.ops-decision-panel .decision-ledger-row.status-warn .decision-ledger-name b {
  background: rgba(245, 158, 11, .14);
  color: #fde68a;
}

.ops-decision-panel .decision-ledger-row.status-high .decision-ledger-name b {
  background: rgba(248, 113, 113, .14);
  color: #fca5a5;
}

.ops-decision-panel .decision-ledger-row strong {
  color: #f8fafc;
  font-size: 18px;
  line-height: 1.2;
}

.ops-decision-panel .decision-ledger-row > span,
.ops-decision-panel .decision-ledger-row small {
  color: #94a3b8;
  font-size: 12px;
}

.ops-decision-panel .decision-metric-card {
  min-height: 106px;
  border-left-width: 4px;
  border-left-style: solid;
  box-shadow: none;
}

.ops-decision-panel .decision-metric-card.status-ok {
  border-left-color: #73a68d;
}

.ops-decision-panel .decision-metric-card.status-warn {
  border-left-color: #d8ab74;
}

.ops-decision-panel .decision-metric-card.status-high {
  border-left-color: #ef7777;
}

.ops-decision-panel .metric-card-head b {
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(52, 211, 153, .12);
  font-size: 10px;
  letter-spacing: 0;
}

.ops-decision-panel .status-warn .metric-card-head b {
  background: rgba(245, 158, 11, .14);
}

.ops-decision-panel .status-high .metric-card-head b {
  background: rgba(248, 113, 113, .14);
}

.ops-decision-panel .decision-metric-card strong {
  margin-top: 9px;
  font-size: 22px;
}

.ops-decision-panel .metric-card-foot {
  margin-top: 9px;
}

.ops-decision-panel .ops-muted-line,
.ops-decision-panel .ops-nested-box {
  margin: 0;
  border-radius: 8px;
}

.ops-decision-panel .ops-muted-line {
  margin-top: 4px;
  padding: 9px 12px;
  border: 1px solid rgba(148, 163, 184, .24);
  background: rgba(15, 23, 42, .2);
}

.theme-light.operations-mode .ops-decision-panel {
  background: var(--panel);
  border-color: var(--line);
  box-shadow: var(--shadow-soft);
}

.theme-light.operations-mode .ops-decision-panel .ops-panel-title {
  color: var(--text);
  font-size: 18px;
}

.theme-light.operations-mode .ops-decision-panel .ops-control-row {
  background: #fbfdfb;
  border-color: var(--line);
}

.theme-light.operations-mode .ops-decision-panel .decision-risk-banner {
  border-color: var(--line);
  background: #fbfdfb;
  color: var(--text);
}

.theme-light.operations-mode .ops-decision-panel .decision-risk-banner.risk-high {
  border-color: #f2c8c4;
  background: #fff7f5;
  color: #8f332f;
}

.theme-light.operations-mode .ops-decision-panel .decision-risk-banner.risk-warn {
  border-color: #ead6ad;
  background: #fffaf0;
  color: #7c5420;
}

.theme-light.operations-mode .ops-decision-panel .decision-risk-banner.risk-ok {
  border-color: #cfe5d8;
  background: #f4faf6;
  color: #315846;
}

.theme-light.operations-mode .ops-decision-panel .decision-metric-card,
.theme-light.operations-mode .ops-decision-panel .ops-muted-line,
.theme-light.operations-mode .ops-decision-panel .ops-nested-box {
  background: #fbfdfb;
  border-color: var(--line);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger {
  background: #fbfdfb;
  border-color: var(--line);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-head {
  background: #f4f8f6;
  color: var(--muted);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-row {
  border-top-color: var(--line);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-name span,
.theme-light.operations-mode .ops-decision-panel .decision-ledger-row > span,
.theme-light.operations-mode .ops-decision-panel .decision-ledger-row small {
  color: var(--muted);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-row strong {
  color: var(--text);
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-name b {
  background: #eef7f1;
  color: #315846;
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-row.status-warn .decision-ledger-name b {
  background: #fff3df;
  color: #7c5420;
}

.theme-light.operations-mode .ops-decision-panel .decision-ledger-row.status-high .decision-ledger-name b {
  background: #fff0ee;
  color: #8f332f;
}

.theme-light.operations-mode .ops-decision-panel .decision-metric-card.status-ok {
  border-left-color: #73a68d;
}

.theme-light.operations-mode .ops-decision-panel .decision-metric-card.status-warn {
  border-left-color: #d8ab74;
}

.theme-light.operations-mode .ops-decision-panel .decision-metric-card.status-high {
  border-left-color: #ef7777;
}

.theme-light.operations-mode .ops-decision-panel .metric-card-head span,
.theme-light.operations-mode .ops-decision-panel .metric-card-foot,
.theme-light.operations-mode .ops-decision-panel .ops-muted-line,
.theme-light.operations-mode .ops-decision-panel .ops-box-title,
.theme-light.operations-mode .ops-decision-panel .ops-mix-item small {
  color: var(--muted);
}

.theme-light.operations-mode .ops-decision-panel .metric-card-head b {
  background: #eef7f1;
  color: #315846;
}

.theme-light.operations-mode .ops-decision-panel .status-warn .metric-card-head b {
  background: #fff3df;
  color: #7c5420;
}

.theme-light.operations-mode .ops-decision-panel .status-high .metric-card-head b {
  background: #fff0ee;
  color: #8f332f;
}

.theme-light.operations-mode .ops-decision-panel .decision-metric-card strong,
.theme-light.operations-mode .ops-decision-panel .ops-mix-item strong {
  color: var(--text);
}

@media (max-width: 720px) {
  .ops-decision-panel {
    gap: 10px;
  }

  .ops-decision-panel .ops-control-row {
    align-items: stretch;
  }

  .ops-decision-panel .ops-control-row label,
  .ops-decision-panel .ops-control-row span,
  .ops-decision-panel .ops-control-row .mini-select,
  .ops-decision-panel .ops-control-row .btn {
    width: 100%;
  }

  .ops-decision-panel .decision-metric-card {
    min-height: 96px;
  }

  .ops-decision-panel .decision-ledger-head {
    display: none;
  }

  .ops-decision-panel .decision-ledger-row {
    grid-template-columns: 1fr;
    gap: 6px;
    align-items: start;
  }

  .ops-decision-panel .decision-ledger-row > span::before {
    content: "門檻：";
    color: inherit;
    font-weight: 850;
  }

  .ops-decision-panel .decision-ledger-row small::before {
    content: "差距：";
    color: inherit;
    font-weight: 850;
  }
}

/* Sidebar navigation groups. */
.nav-section-title {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 12px 8px 4px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  line-height: 1;
}

.nav-section-title:first-child {
  margin-top: 2px;
}

.nav-section-title::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--line);
  opacity: .8;
}

.theme-dark .nav-section-title {
  color: var(--sidebar-muted);
}

.theme-dark .nav-section-title::after {
  background: rgba(148, 163, 184, .22);
}

@media (max-width: 1040px) {
  .nav-section-title {
    grid-column: 1 / -1;
    margin: 8px 4px 2px;
  }
}

.search input,
.member-mgmt-input[type="search"],
.supplier-search,
.purchase-search,
.store-pickup-search-row .store-pickup-input,
.cat-litter-search-row .cat-litter-input,
.expiry-search,
.office-input[type="search"],
.internal-toolbox-search-row .internal-toolbox-search,
#socialQuery {
  min-height: 42px;
  border-radius: 10px;
  border-color: var(--line);
  background: var(--panel);
  box-shadow: none;
  transition: border-color .14s ease, box-shadow .14s ease, background-color .14s ease;
}

.purchase-row-actions,
.expiry-row-actions,
.store-pickup-row-actions,
.cat-litter-row-actions {
  gap: 6px;
  align-items: center;
}

.purchase-row-actions .btn.small,
.expiry-row-actions .btn.small,
.store-pickup-row-actions .store-pickup-action-btn,
.store-pickup-row-actions .store-pickup-ghost-btn,
.cat-litter-row-actions .cat-litter-action-btn,
.cat-litter-row-actions .cat-litter-ghost-btn {
  min-width: 34px;
  min-height: 32px;
  border-radius: 8px;
  padding: 5px 9px;
  box-shadow: none !important;
}

.btn.danger,
.store-pickup-ghost-btn.danger,
.cat-litter-ghost-btn.danger,
.cat-litter-record-link.danger,
.internal-toolbox-card-actions button.danger {
  border-color: #d9b8b2 !important;
  background: #fff8f6 !important;
  color: #a6463a !important;
  box-shadow: none !important;
}

.btn.danger:hover,
.store-pickup-ghost-btn.danger:hover,
.cat-litter-ghost-btn.danger:hover,
.internal-toolbox-card-actions button.danger:hover {
  border-color: #bf7f76 !important;
  background: #fff1ee !important;
  color: #8c342b !important;
}

.theme-dark.operations-mode .btn.danger,
.theme-dark.operations-mode .store-pickup-ghost-btn.danger,
.theme-dark.operations-mode .cat-litter-ghost-btn.danger,
.theme-dark.operations-mode .cat-litter-record-link.danger,
.theme-dark.operations-mode .internal-toolbox-card-actions button.danger {
  border-color: rgba(248, 113, 113, .42) !important;
  background: rgba(248, 113, 113, .1) !important;
  color: #fecaca !important;
}

button:disabled,
.btn[disabled],
.store-pickup-action-btn[disabled],
.store-pickup-ghost-btn[disabled],
.cat-litter-action-btn[disabled],
.cat-litter-ghost-btn[disabled] {
  opacity: .58;
  cursor: wait;
  transform: none !important;
  box-shadow: none !important;
}
