/* Madrasa Boarding SaaS — design tokens + app styles */

:root {
  /* Forest / mint / ink palette */
  --mb-forest: #0f5132;
  --mb-forest-2: #134c30;
  --mb-mint: #10b981;
  --mb-mint-soft: #d1fae5;
  --mb-ink: #0a1f17;
  --mb-ink-2: #1f2a25;
  --mb-muted: #6b7568;
  --mb-muted-2: #9aa39a;
  --mb-canvas: #f4f6f3;
  --mb-paper: #ffffff;
  --mb-paper-2: #fbfcfb;
  --mb-border: #e6ebe5;
  --mb-border-strong: #d4dcd3;
  --mb-amber: #c08a3a;
  --mb-rose: #b04a3a;
  --mb-blue: #2f6f8a;

  --mb-radius-card: 16px;
  --mb-radius-btn: 10px;
  --mb-radius-input: 8px;

  --mb-shadow-1: 0 1px 0 rgba(15, 40, 30, .04), 0 1px 2px rgba(15, 40, 30, .04);
  --mb-shadow-2: 0 1px 0 rgba(15, 40, 30, .04), 0 6px 18px rgba(15, 40, 30, .06);

  --mb-font-ui: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mb-font-mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --mb-font-serif: "Amiri", "Iowan Old Style", "Hoefler Text", serif;
}

[data-mb-theme="dark"] {
  --mb-forest: #10b981;
  --mb-forest-2: #34d399;
  --mb-mint: #34d399;
  --mb-mint-soft: rgba(52, 211, 153, .14);
  --mb-ink: #e6efea;
  --mb-ink-2: #c7d3cc;
  --mb-muted: #8e9b91;
  --mb-muted-2: #6a766f;
  --mb-canvas: #0a1410;
  --mb-paper: #0f1c17;
  --mb-paper-2: #112019;
  --mb-border: #1c2c25;
  --mb-border-strong: #243a31;

  --mb-shadow-1: 0 1px 0 rgba(0,0,0,.35), 0 1px 2px rgba(0,0,0,.4);
  --mb-shadow-2: 0 1px 0 rgba(0,0,0,.35), 0 8px 24px rgba(0,0,0,.45);
}

* { box-sizing: border-box; }

html, body, #root { height: 100%; }
body {
  margin: 0;
  font-family: var(--mb-font-ui);
  font-size: 14px;
  line-height: 1.45;
  color: var(--mb-ink);
  background: var(--mb-canvas);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Subtle dotted canvas */
body::before {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(rgba(15, 40, 30, 0.045) 1px, transparent 1px);
  background-size: 22px 22px;
  background-position: 0 0;
  opacity: .8;
}
[data-mb-theme="dark"] body::before {
  background-image: radial-gradient(rgba(180, 220, 200, 0.05) 1px, transparent 1px);
}

button { font-family: inherit; }
.mb-mono { font-family: var(--mb-font-mono); font-feature-settings: "tnum" 1; }
.mb-serif { font-family: var(--mb-font-serif); }
.mb-tnum { font-variant-numeric: tabular-nums; }

/* ─────────────────────────── App shell ─────────────────────────── */

.mb-app {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: var(--mb-sidebar-w, 244px) 1fr;
  min-height: 100vh;
}
.mb-app[data-sidebar="rail"]   { --mb-sidebar-w: 68px; }
.mb-app[data-sidebar="pill"]   { --mb-sidebar-w: 240px; }
.mb-app[data-sidebar="labeled"]{ --mb-sidebar-w: 248px; }

/* ─────────────────────────── Sidebar ─────────────────────────── */

.mb-side {
  position: sticky; top: 0; height: 100vh;
  display: flex; flex-direction: column;
  background: var(--mb-paper);
  border-right: 1px solid var(--mb-border);
  padding: 18px 14px 14px;
  gap: 6px;
}
.mb-side-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 8px 14px;
  border-bottom: 1px solid var(--mb-border);
  margin-bottom: 8px;
}
.mb-side-logo {
  width: 36px; height: 36px;
  border-radius: 9px;
  background: var(--mb-forest);
  display: grid; place-items: center;
  color: #f7f9f6;
  position: relative;
  flex: 0 0 36px;
}
[data-mb-theme="dark"] .mb-side-logo { background: #0c2018; color: var(--mb-mint); }
.mb-side-brand-name {
  font-weight: 700; font-size: 13.5px; letter-spacing: -.005em;
  line-height: 1.1; color: var(--mb-ink);
}
.mb-side-brand-bism {
  font-family: var(--mb-font-serif);
  font-size: 12px; color: var(--mb-muted);
  margin-top: 2px;
  font-style: italic;
}
.mb-side-brand-text { min-width: 0; }

.mb-side-scroll {
  flex: 1; min-height: 0; overflow-y: auto;
  margin: 4px -4px 0;
  padding: 0 4px;
  scrollbar-width: thin;
}
.mb-side-scroll::-webkit-scrollbar { width: 6px; }
.mb-side-scroll::-webkit-scrollbar-thumb { background: var(--mb-border-strong); border-radius: 3px; }

.mb-side-group { padding: 6px 0 4px; }
.mb-side-group-hd {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 10px 10px 6px;
  color: var(--mb-muted-2);
  font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.mb-side-group-hd .mb-bn {
  font-family: var(--mb-font-serif);
  font-size: 11px; letter-spacing: 0;
  text-transform: none;
  color: var(--mb-muted-2);
  font-weight: 400;
  font-style: italic;
}

.mb-side-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 9px;
  color: var(--mb-ink-2);
  background: transparent;
  border: 0;
  cursor: default;
  font-size: 13.5px;
  text-align: left;
  position: relative;
}
.mb-side-item:hover { background: rgba(15,40,30,.04); }
[data-mb-theme="dark"] .mb-side-item:hover { background: rgba(180, 220, 200, .05); }
.mb-side-item.is-active {
  background: var(--mb-mint-soft);
  color: var(--mb-forest);
  font-weight: 600;
}
[data-mb-theme="dark"] .mb-side-item.is-active { color: var(--mb-mint); }
.mb-side-item .mb-side-icon {
  flex: 0 0 18px;
  width: 18px; height: 18px;
  display: grid; place-items: center;
  color: currentColor;
  opacity: .8;
}
.mb-side-item .mb-side-label { flex: 1; min-width: 0; white-space: nowrap; }
.mb-side-item .mb-side-badge {
  font-size: 10.5px; font-weight: 600;
  background: rgba(15,40,30,.06);
  color: var(--mb-muted);
  padding: 1px 6px; border-radius: 999px;
  font-family: var(--mb-font-mono);
}
[data-mb-theme="dark"] .mb-side-item .mb-side-badge { background: rgba(180, 220, 200, .08); }
.mb-side-item.is-active .mb-side-badge { background: rgba(15, 81, 50, .12); color: var(--mb-forest); }
[data-mb-theme="dark"] .mb-side-item.is-active .mb-side-badge { background: rgba(52, 211, 153, .14); color: var(--mb-mint); }

/* Sidebar — variant: rail (icon-only) */
.mb-app[data-sidebar="rail"] .mb-side { padding: 14px 8px; align-items: center; }
.mb-app[data-sidebar="rail"] .mb-side-brand { border: 0; padding: 0 0 10px; margin: 0 0 6px; justify-content: center; }
.mb-app[data-sidebar="rail"] .mb-side-brand-text { display: none; }
.mb-app[data-sidebar="rail"] .mb-side-group-hd {
  padding: 8px 0 4px; justify-content: center; opacity: 0;
  height: 8px; overflow: hidden;
}
.mb-app[data-sidebar="rail"] .mb-side-group-hd::before {
  content: ""; width: 18px; height: 1px; background: var(--mb-border-strong); opacity: 1;
}
.mb-app[data-sidebar="rail"] .mb-side-item {
  width: 44px; height: 44px; padding: 0; justify-content: center; border-radius: 10px;
}
.mb-app[data-sidebar="rail"] .mb-side-item .mb-side-label,
.mb-app[data-sidebar="rail"] .mb-side-item .mb-side-badge { display: none; }
.mb-app[data-sidebar="rail"] .mb-side-item .mb-side-icon { width: 20px; height: 20px; opacity: .9; }
.mb-app[data-sidebar="rail"] .mb-side-foot { display: none; }

/* Sidebar — variant: pill */
.mb-app[data-sidebar="pill"] .mb-side { background: var(--mb-canvas); border-right: 0; padding: 18px 12px; }
.mb-app[data-sidebar="pill"] .mb-side-brand { background: var(--mb-paper); border: 1px solid var(--mb-border); border-radius: 12px; padding: 10px; margin-bottom: 12px; }
.mb-app[data-sidebar="pill"] .mb-side-item {
  background: var(--mb-paper); border: 1px solid var(--mb-border);
  margin-bottom: 6px; border-radius: 11px;
}
.mb-app[data-sidebar="pill"] .mb-side-item:hover { background: var(--mb-paper-2); }
.mb-app[data-sidebar="pill"] .mb-side-item.is-active {
  background: var(--mb-forest); color: #f7f9f6; border-color: var(--mb-forest);
}
.mb-app[data-sidebar="pill"] .mb-side-item.is-active .mb-side-badge { background: rgba(255,255,255,.16); color: #f7f9f6; }
[data-mb-theme="dark"] .mb-app[data-sidebar="pill"] .mb-side-item.is-active { background: var(--mb-mint); color: #0a1410; border-color: var(--mb-mint); }

.mb-side-foot {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--mb-border);
  display: flex; align-items: center; gap: 10px;
}
.mb-side-foot-avatar {
  width: 32px; height: 32px; border-radius: 8px;
  background: linear-gradient(135deg, var(--mb-forest), var(--mb-mint));
  color: #fff; display: grid; place-items: center;
  font-weight: 700; font-size: 12px;
}
.mb-side-foot-text { min-width: 0; flex: 1; line-height: 1.2; }
.mb-side-foot-name { font-weight: 600; font-size: 12.5px; color: var(--mb-ink); }
.mb-side-foot-role { font-size: 11px; color: var(--mb-muted); }

/* ─────────────────────────── Main column ─────────────────────────── */

.mb-main {
  display: flex; flex-direction: column;
  min-width: 0;
}

.mb-topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; gap: 12px;
  padding: 12px 28px;
  background: rgba(247, 249, 246, .8);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border-bottom: 1px solid var(--mb-border);
}
[data-mb-theme="dark"] .mb-topbar { background: rgba(10, 20, 16, .8); }

.mb-branch {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px 6px 8px;
  background: var(--mb-paper); border: 1px solid var(--mb-border);
  border-radius: 10px;
  font-size: 12.5px; font-weight: 500;
  color: var(--mb-ink);
}
.mb-branch-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--mb-mint); box-shadow: 0 0 0 3px rgba(16,185,129,.12); }
.mb-branch-meta { color: var(--mb-muted); font-size: 11px; font-weight: 400; margin-left: 4px; }

.mb-topbar-search {
  flex: 1; max-width: 480px;
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: var(--mb-paper); border: 1px solid var(--mb-border);
  border-radius: 10px;
  color: var(--mb-muted);
}
.mb-topbar-search input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font: inherit; color: var(--mb-ink);
  font-size: 13px;
}
.mb-topbar-search kbd {
  font-family: var(--mb-font-mono); font-size: 10.5px;
  padding: 1px 5px; border-radius: 4px;
  background: rgba(15,40,30,.06); color: var(--mb-muted);
  border: 1px solid var(--mb-border);
}
[data-mb-theme="dark"] .mb-topbar-search kbd { background: rgba(180,220,200,.08); }

.mb-topbar-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.mb-icon-btn {
  width: 34px; height: 34px;
  display: grid; place-items: center;
  background: var(--mb-paper); border: 1px solid var(--mb-border);
  border-radius: 9px; color: var(--mb-ink); position: relative;
}
.mb-icon-btn .mb-dot {
  position: absolute; top: 7px; right: 8px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--mb-rose);
  border: 1.5px solid var(--mb-paper);
}
.mb-date {
  display: flex; flex-direction: column; line-height: 1.1; margin-right: 4px;
  text-align: right;
}
.mb-date b { font-weight: 600; font-size: 12.5px; color: var(--mb-ink); }
.mb-date span { font-size: 10.5px; color: var(--mb-muted); font-family: var(--mb-font-serif); }

/* ─────────────────────────── Content ─────────────────────────── */

.mb-content {
  padding: 24px 28px 64px;
  display: flex; flex-direction: column;
  gap: 20px;
}

.mb-page-hd {
  display: flex; align-items: flex-end; gap: 16px;
  padding: 2px 2px 6px;
}
.mb-page-hd h1 {
  margin: 0;
  font-size: 26px; font-weight: 700;
  letter-spacing: -0.018em;
  color: var(--mb-ink);
}
.mb-page-hd .mb-greet-sub {
  color: var(--mb-muted); font-size: 13.5px; margin-top: 4px;
}
.mb-bismillah {
  margin-left: auto;
  font-family: var(--mb-font-serif);
  font-size: 18px; color: var(--mb-forest);
  line-height: 1;
  padding: 8px 16px;
  background: var(--mb-paper); border: 1px solid var(--mb-border);
  border-radius: 999px;
  display: flex; align-items: center; gap: 10px;
}
[data-mb-theme="dark"] .mb-bismillah { color: var(--mb-mint); }
.mb-bismillah .mb-star { width: 12px; height: 12px; flex: 0 0 12px; }

/* Card */
.mb-card {
  background: var(--mb-paper);
  border: 1px solid var(--mb-border);
  border-radius: var(--mb-radius-card);
  box-shadow: var(--mb-shadow-1);
  position: relative;
}
.mb-card-hd {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px 10px;
}
.mb-card-hd h3 {
  margin: 0;
  font-size: 13.5px; font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--mb-ink);
}
.mb-card-hd .mb-sub { color: var(--mb-muted); font-size: 11.5px; }
.mb-card-hd .mb-spacer { flex: 1; }
.mb-tabs { display: flex; gap: 2px; padding: 2px; background: var(--mb-canvas); border-radius: 8px; }
.mb-tab { padding: 4px 9px; border-radius: 6px; font-size: 11.5px; color: var(--mb-muted); font-weight: 500; }
.mb-tab.is-on { background: var(--mb-paper); color: var(--mb-ink); box-shadow: var(--mb-shadow-1); }

.mb-card-body { padding: 0 18px 18px; }
.mb-card-foot {
  padding: 12px 18px;
  border-top: 1px solid var(--mb-border);
  display: flex; align-items: center;
  font-size: 12px; color: var(--mb-muted);
  gap: 10px;
}

/* KPI strip */
.mb-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.mb-kpi {
  background: var(--mb-paper);
  border: 1px solid var(--mb-border);
  border-radius: var(--mb-radius-card);
  padding: 16px 18px 14px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative; overflow: hidden;
  box-shadow: var(--mb-shadow-1);
}
.mb-kpi-lbl {
  font-size: 11.5px; color: var(--mb-muted);
  text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600;
  display: flex; align-items: center; gap: 8px;
}
.mb-kpi-lbl .mb-ic {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  background: var(--mb-mint-soft); color: var(--mb-forest);
  border-radius: 6px;
}
[data-mb-theme="dark"] .mb-kpi-lbl .mb-ic { color: var(--mb-mint); }
.mb-kpi-val {
  font-family: var(--mb-font-mono);
  font-size: 28px; font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--mb-ink);
  line-height: 1.05;
  font-variant-numeric: tabular-nums;
}
.mb-kpi-val .mb-cur { color: var(--mb-muted); font-weight: 400; font-size: 18px; padding-right: 2px; }
.mb-kpi-foot { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--mb-muted); }
.mb-delta {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: var(--mb-font-mono); font-size: 11.5px; font-weight: 600;
  padding: 1px 6px; border-radius: 999px;
}
.mb-delta.is-up   { background: rgba(16,185,129,.12); color: #0f7a55; }
.mb-delta.is-down { background: rgba(176,74,58,.12);  color: var(--mb-rose); }
.mb-delta.is-flat { background: rgba(15,40,30,.06);   color: var(--mb-muted); }
[data-mb-theme="dark"] .mb-delta.is-up { color: var(--mb-mint); }

.mb-kpi-spark {
  position: absolute;
  right: 12px; top: 14px;
  width: 80px; height: 28px;
  opacity: .85;
}

/* Grid layouts */
.mb-grid { display: grid; gap: 14px; }
.mb-grid-8-4 { grid-template-columns: 8fr 4fr; }
.mb-grid-7-5 { grid-template-columns: 7fr 5fr; }
.mb-grid-2 { grid-template-columns: 1fr 1fr; }

/* Live attendance donut */
.mb-att {
  display: grid; grid-template-columns: 152px 1fr; gap: 16px; align-items: center;
}
.mb-att-list { display: flex; flex-direction: column; gap: 8px; }
.mb-att-row {
  display: grid; grid-template-columns: 8px 1fr auto; gap: 10px; align-items: center;
  font-size: 13px;
}
.mb-att-swatch { width: 8px; height: 8px; border-radius: 2px; }
.mb-att-name { color: var(--mb-ink-2); }
.mb-att-val { font-family: var(--mb-font-mono); font-weight: 600; }

/* Activity feed */
.mb-feed { display: flex; flex-direction: column; }
.mb-feed-row {
  display: grid; grid-template-columns: 26px 1fr auto; gap: 10px;
  padding: 10px 0;
  border-top: 1px dashed var(--mb-border);
}
.mb-feed-row:first-child { border-top: 0; }
.mb-feed-ic {
  width: 26px; height: 26px;
  display: grid; place-items: center;
  border-radius: 7px;
  background: var(--mb-canvas); color: var(--mb-ink-2);
}
.mb-feed-ic.is-mint { background: var(--mb-mint-soft); color: var(--mb-forest); }
.mb-feed-ic.is-amber { background: rgba(192,138,58,.12); color: var(--mb-amber); }
.mb-feed-ic.is-blue { background: rgba(47,111,138,.12); color: var(--mb-blue); }
.mb-feed-ic.is-rose { background: rgba(176,74,58,.12); color: var(--mb-rose); }
[data-mb-theme="dark"] .mb-feed-ic { background: rgba(180,220,200,.06); }
[data-mb-theme="dark"] .mb-feed-ic.is-mint { color: var(--mb-mint); }
.mb-feed-text { font-size: 12.8px; line-height: 1.35; color: var(--mb-ink-2); }
.mb-feed-text b { color: var(--mb-ink); font-weight: 600; }
.mb-feed-time { font-size: 11px; color: var(--mb-muted-2); font-family: var(--mb-font-mono); }

/* Charts */
.mb-chart-wrap { padding: 4px 4px 0; }
.mb-chart-legend { display: flex; gap: 14px; flex-wrap: wrap; font-size: 11.5px; color: var(--mb-muted); margin-top: 4px; padding: 0 14px 0; }
.mb-chart-legend .sw { display: inline-block; width: 9px; height: 9px; border-radius: 2px; margin-right: 6px; vertical-align: -1px; }

/* Bar chart */
.mb-bar { fill: var(--mb-forest); }
.mb-bar-2 { fill: var(--mb-mint); }
.mb-bar-3 { fill: #a7d7c0; }
.mb-bar-4 { fill: #6cc59b; }
[data-mb-theme="dark"] .mb-bar { fill: #0e7a52; }
[data-mb-theme="dark"] .mb-bar-2 { fill: var(--mb-mint); }
[data-mb-theme="dark"] .mb-bar-3 { fill: #1e4d3a; }
[data-mb-theme="dark"] .mb-bar-4 { fill: #2d8763; }

.mb-grid-line { stroke: var(--mb-border); stroke-width: 1; stroke-dasharray: 2 4; }
.mb-axis-tx { fill: var(--mb-muted-2); font-size: 10.5px; font-family: var(--mb-font-mono); }

/* Table */
.mb-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.mb-table th {
  text-align: left; padding: 8px 14px;
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--mb-muted);
  border-bottom: 1px solid var(--mb-border);
}
.mb-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--mb-border);
  color: var(--mb-ink-2);
}
.mb-table tr:last-child td { border-bottom: 0; }
.mb-stu {
  display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: center;
}
.mb-stu-avatar {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  font-weight: 700; font-size: 11px; color: #fff;
}
.mb-stu-name { font-weight: 600; color: var(--mb-ink); font-size: 13px; line-height: 1.15; }
.mb-stu-meta { font-size: 11px; color: var(--mb-muted); line-height: 1.15; }
.mb-amt { font-family: var(--mb-font-mono); font-weight: 600; color: var(--mb-ink); }
.mb-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px;
  font-size: 11px; font-weight: 600;
  border-radius: 999px;
  background: var(--mb-canvas); color: var(--mb-muted);
  border: 1px solid var(--mb-border);
}
.mb-pill.is-warn  { color: var(--mb-amber); background: rgba(192,138,58,.10); border-color: rgba(192,138,58,.18); }
.mb-pill.is-rose  { color: var(--mb-rose);  background: rgba(176,74,58,.10);  border-color: rgba(176,74,58,.18); }
.mb-pill.is-mint  { color: #0f7a55;         background: rgba(16,185,129,.10); border-color: rgba(16,185,129,.18); }
[data-mb-theme="dark"] .mb-pill.is-mint { color: var(--mb-mint); }
.mb-pill .mb-dot-s { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }

.mb-btn {
  padding: 6px 11px; border-radius: 8px;
  font-size: 12px; font-weight: 600;
  background: var(--mb-canvas); border: 1px solid var(--mb-border);
  color: var(--mb-ink-2);
  display: inline-flex; align-items: center; gap: 6px;
}
.mb-btn.is-primary { background: var(--mb-forest); color: #f7f9f6; border-color: var(--mb-forest); }
[data-mb-theme="dark"] .mb-btn.is-primary { background: var(--mb-mint); color: #0a1410; border-color: var(--mb-mint); }
.mb-btn.is-ghost { background: transparent; }

/* Meal package mini list */
.mb-pkg-list { display: flex; flex-direction: column; }
.mb-pkg {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 10px 0;
  border-top: 1px dashed var(--mb-border);
  gap: 6px;
}
.mb-pkg:first-child { border-top: 0; }
.mb-pkg-name { font-size: 13px; font-weight: 600; color: var(--mb-ink); }
.mb-pkg-meta { font-size: 11.5px; color: var(--mb-muted); }
.mb-pkg-count { font-family: var(--mb-font-mono); font-size: 13px; font-weight: 600; color: var(--mb-ink); }
.mb-pkg-bar { grid-column: 1 / -1; height: 4px; border-radius: 999px; background: var(--mb-canvas); overflow: hidden; }
.mb-pkg-bar > i { display: block; height: 100%; background: var(--mb-forest); border-radius: 999px; }
.mb-pkg-bar > i.c2 { background: var(--mb-mint); }
.mb-pkg-bar > i.c3 { background: #6cc59b; }
.mb-pkg-bar > i.c4 { background: var(--mb-amber); }
.mb-pkg-bar > i.c5 { background: var(--mb-blue); }
.mb-pkg-bar > i.c6 { background: #a7d7c0; }

/* Bazar list */
.mb-bazar-row {
  display: grid; grid-template-columns: 32px 1fr auto auto; gap: 10px;
  align-items: center;
  padding: 9px 0;
  border-top: 1px dashed var(--mb-border);
}
.mb-bazar-row:first-child { border-top: 0; }
.mb-bazar-ic {
  width: 32px; height: 32px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--mb-canvas); color: var(--mb-ink-2);
  font-family: var(--mb-font-serif); font-style: italic; font-size: 14px;
}
.mb-bazar-name { font-size: 13px; font-weight: 600; color: var(--mb-ink); line-height: 1.15; }
.mb-bazar-meta { font-size: 11.5px; color: var(--mb-muted); }
.mb-bazar-qty { font-family: var(--mb-font-mono); font-size: 12.5px; color: var(--mb-ink-2); }
.mb-bazar-amt { font-family: var(--mb-font-mono); font-size: 13px; font-weight: 600; color: var(--mb-ink); }

/* Occupancy mini bar */
.mb-occ {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px;
  padding: 6px 18px 18px;
}
.mb-occ-card { padding: 12px 14px; border: 1px solid var(--mb-border); border-radius: 12px; }
.mb-occ-card .mb-lbl { font-size: 11.5px; color: var(--mb-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.mb-occ-card .mb-val { font-family: var(--mb-font-mono); font-size: 22px; color: var(--mb-ink); margin-top: 4px; }
.mb-occ-card .mb-occ-bar { height: 4px; margin-top: 8px; background: var(--mb-canvas); border-radius: 999px; overflow: hidden; }
.mb-occ-card .mb-occ-bar > i { display: block; height: 100%; background: var(--mb-forest); }
[data-mb-theme="dark"] .mb-occ-card .mb-occ-bar > i { background: var(--mb-mint); }

/* Empty state for other screens */
.mb-stub {
  background: var(--mb-paper);
  border: 1px dashed var(--mb-border-strong);
  border-radius: var(--mb-radius-card);
  padding: 56px 36px;
  text-align: center;
  color: var(--mb-muted);
}
.mb-stub h2 { color: var(--mb-ink); margin: 0 0 6px; font-size: 18px; }

/* Scrollbar */
.mb-content { scroll-behavior: smooth; }

/* Responsive — under 1100, sidebar collapses to rail */
@media (max-width: 1100px) {
  .mb-app:not([data-sidebar="rail"]) { grid-template-columns: 68px 1fr; }
  .mb-app .mb-side-brand-text,
  .mb-app .mb-side-item .mb-side-label,
  .mb-app .mb-side-item .mb-side-badge,
  .mb-app .mb-side-group-hd { display: none; }
  .mb-app .mb-side-item { width: 44px; height: 44px; padding: 0; justify-content: center; }
}
