/* ─────────────────────────  Boutique Automation — styles  ───────────────────────── */

/* === Reset / base === */
*, *::before, *::after { box-sizing: border-box; }
.bx-root { font-family: var(--ff-body); color: var(--ink); background: var(--bg);
  width: 100%; height: 100%; overflow: hidden; font-size: 13px; line-height: 1.45;
  -webkit-font-smoothing: antialiased; }
.bx-root button { font-family: inherit; cursor: pointer; }
.bx-root input, .bx-root select, .bx-root textarea {
  font-family: inherit; font-size: 13px; color: var(--ink);
  border: 1px solid var(--line); background: var(--surface);
  border-radius: var(--radius); padding: 8px 10px; outline: none;
}
.bx-root input:focus, .bx-root select:focus, .bx-root textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}
.bx-mono { font-family: var(--ff-mono); font-size: 12px; letter-spacing: -0.01em; }
.bx-muted { color: var(--ink-3); }

/* === Shell layout === */
.bx-shell { display: grid; grid-template-columns: 224px 1fr; height: 100%; }
.bx-main  { display: flex; flex-direction: column; min-width: 0; background: var(--bg); }
.bx-page  { flex: 1; overflow: auto; padding: 20px 24px 32px; min-height: 0;
  display: flex; flex-direction: column; gap: 16px; }

/* === Sidebar === */
.bx-side { background: var(--side-bg); color: var(--side-ink);
  display: flex; flex-direction: column; padding: 18px 14px 14px;
  border-right: 1px solid var(--side-line);
}
.bx-side-head { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; padding: 0 4px; }
.bx-logo { display: inline-flex; align-items: center; justify-content: center;
  color: var(--side-ink); flex-shrink: 0; }
.bx-side-brand { font-family: var(--ff-display); font-size: 18px; line-height: 1; letter-spacing: 0.5px; }
.bx-side-brand-sub { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  color: var(--side-mute); letter-spacing: 0.18em; margin-top: 2px; }

.bx-side-section-label { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  color: var(--side-mute); letter-spacing: 0.18em; padding: 0 8px; margin: 12px 0 6px; }

.bx-side-store-pick { display: flex; flex-direction: column; gap: 2px; padding-bottom: 8px;
  border-bottom: 1px solid var(--side-line); }
.bx-side-store-btn { all: unset; cursor: pointer; display: flex; align-items: center; gap: 8px;
  padding: 7px 8px; border-radius: var(--radius); font-size: 12px; color: var(--side-mute); }
.bx-side-store-btn:hover { background: color-mix(in oklab, var(--side-ink) 8%, transparent); }
.bx-side-store-btn.is-active { background: color-mix(in oklab, var(--side-ink) 14%, transparent);
  color: var(--side-ink); }
.bx-side-store-btn.is-add { color: var(--side-mute); font-style: italic; }

.bx-side-nav { flex: 1; display: flex; flex-direction: column; gap: 2px; margin-top: 8px; min-height: 0; overflow: auto; }
.bx-side-link { all: unset; cursor: pointer; display: grid;
  grid-template-columns: 22px 1fr auto; align-items: center; gap: 8px;
  padding: 8px 8px; border-radius: var(--radius); font-size: 13px; color: var(--side-ink); }
.bx-side-link:hover { background: color-mix(in oklab, var(--side-ink) 8%, transparent); }
.bx-side-link.is-active { background: color-mix(in oklab, var(--accent) 90%, transparent);
  color: var(--accent-ink); }
.bx-side-link.is-active .bx-side-link-hindi { color: color-mix(in oklab, var(--accent-ink) 70%, transparent); }
.bx-side-link-icon { display: inline-flex; }
.bx-side-link-hindi { font-family: var(--ff-hindi); font-size: 11px; color: var(--side-mute); }

.bx-side-foot { padding-top: 12px; border-top: 1px solid var(--side-line); }
.bx-side-logout { all: unset; cursor: pointer; display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--side-mute); padding: 6px 8px; }
.bx-side-logout:hover { color: var(--side-ink); }

/* === Top bar === */
.bx-top { display: grid; grid-template-columns: minmax(220px, 280px) 1fr auto;
  align-items: center; gap: 14px; padding: 14px 24px;
  border-bottom: 1px solid var(--line); background: var(--bg-elev); flex-shrink: 0; }
.bx-top-title-main { font-family: var(--ff-display); font-size: 22px; line-height: 1.1; letter-spacing: -0.01em; color: var(--ink); font-weight: 500; }
.bx-top-title-sub  { font-family: var(--ff-hindi); font-size: 11px; color: var(--ink-3); margin-top: 3px; }

.bx-top-search { display: flex; align-items: center; gap: 8px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 0 10px; min-width: 0; height: 34px; color: var(--ink-3); }
.bx-top-search input { border: none; background: transparent; padding: 0; flex: 1; min-width: 0; }
.bx-top-search input:focus { box-shadow: none; }
.bx-top-search-kbd { font-family: var(--ff-mono); font-size: 10px; padding: 2px 6px;
  background: var(--chip-bg); border-radius: 3px; color: var(--ink-3); }

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

.bx-icon-btn { all: unset; cursor: pointer; width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--surface); color: var(--ink-2); position: relative; }
.bx-icon-btn:hover { color: var(--ink); }
.bx-icon-dot { position: absolute; top: 7px; right: 8px; width: 6px; height: 6px;
  border-radius: 50%; background: var(--bad); }

.bx-role { display: flex; align-items: center; gap: 8px; padding: 4px 10px 4px 4px;
  border: 1px solid var(--line); border-radius: var(--radius); cursor: pointer;
  background: var(--surface); position: relative; }
.bx-role-meta { display: flex; flex-direction: column; line-height: 1.1; }
.bx-role-name { font-size: 12px; font-weight: 600; }
.bx-role-sub  { font-size: 10px; color: var(--ink-3); }
.bx-role-menu { position: absolute; top: calc(100% + 6px); right: 0; z-index: 50;
  width: 260px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 6px; box-shadow: var(--shadow); }
.bx-role-menu-label { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  color: var(--ink-3); padding: 6px 8px; letter-spacing: 0.18em; }
.bx-role-menu-item { all: unset; cursor: pointer; display: flex; gap: 8px; align-items: center;
  padding: 6px 8px; border-radius: var(--radius); font-size: 12px; }
.bx-role-menu-item:hover { background: var(--chip-bg); }
.bx-role-menu-item.is-active { background: color-mix(in oklab, var(--accent) 12%, transparent); }
.bx-role-menu-item span { display: flex; flex-direction: column; }
.bx-role-menu-item b { font-size: 12px; }
.bx-role-menu-item em { font-size: 10px; color: var(--ink-3); font-style: normal; }

/* === Avatars === */
.bx-avatar { width: 26px; height: 26px; border-radius: 50%;
  background: var(--accent); color: var(--accent-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600; letter-spacing: 0.04em; flex-shrink: 0; }
.bx-avatar-sm { width: 22px; height: 22px; font-size: 9px; }

/* === Buttons === */
.bx-btn { all: unset; cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
  border-radius: var(--radius); font-size: 12px; font-weight: 500; white-space: nowrap;
  border: 1px solid transparent; padding: 7px 12px; transition: background .12s; }
.bx-btn-md { padding: 7px 12px; }
.bx-btn-lg { padding: 11px 16px; font-size: 13px; }
.bx-btn-sm { padding: 5px 9px; font-size: 11px; }
.bx-btn-primary { background: var(--accent); color: var(--accent-ink); }
.bx-btn-primary:hover { background: color-mix(in oklab, var(--accent) 88%, black); }
.bx-btn-soft { background: var(--chip-bg); color: var(--ink); }
.bx-btn-soft:hover { background: color-mix(in oklab, var(--chip-bg) 80%, var(--ink) 4%); }
.bx-btn-ghost { background: transparent; color: var(--ink-2); border-color: var(--line); }
.bx-btn-ghost:hover { background: var(--chip-bg); color: var(--ink); }
.bx-btn-default { background: var(--surface); border-color: var(--line); color: var(--ink); }

/* === Pills === */
.bx-pill { display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 999px;
  text-transform: uppercase; letter-spacing: 0.06em; }
.bx-pill-default { background: var(--chip-bg); color: var(--ink-2); }
.bx-pill-good  { background: var(--good); color: white; }
.bx-pill-warn  { background: var(--warn); color: white; }
.bx-pill-bad   { background: var(--bad);  color: white; }
.bx-pill-soft.bx-pill-good { background: color-mix(in oklab, var(--good) 14%, transparent); color: var(--good); }
.bx-pill-soft.bx-pill-warn { background: color-mix(in oklab, var(--warn) 16%, transparent); color: var(--warn); }
.bx-pill-soft.bx-pill-bad  { background: color-mix(in oklab, var(--bad)  16%, transparent); color: var(--bad); }
.bx-pill-soft.bx-pill-default { background: var(--chip-bg); color: var(--ink-2); }

/* === Stage chip === */
.bx-stage { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--ink-2); }
.bx-stage-dot { width: 7px; height: 7px; border-radius: 2px; background: var(--stage-color, var(--ink-3)); }
.bx-stage-text { font-weight: 500; }

/* === Progress === */
.bx-progress { width: 100%; height: 3px; background: var(--track); border-radius: 99px; overflow: hidden; }
.bx-progress-fill { height: 100%; background: var(--accent); }
.bx-progress-at-risk .bx-progress-fill { background: var(--warn); }
.bx-progress-off-track .bx-progress-fill { background: var(--bad); }

/* === Cards === */
.bx-card { background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
.bx-card.is-padded > * + * { /* spacing inside padded card */ }
.bx-card-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 10px;
  padding: 14px 16px; border-bottom: 1px solid var(--line-2); }
.bx-card-title { font-family: var(--ff-display); font-size: 15px; font-weight: 600; color: var(--ink); }
.bx-card-hindi { font-family: var(--ff-hindi); font-size: 10px; color: var(--ink-3); margin-top: 2px; }
.bx-card.is-padded > *:not(.bx-card-head) { padding-left: 16px; padding-right: 16px; }
.bx-card.is-padded > *:last-child:not(.bx-card-head) { padding-bottom: 16px; }
.bx-card.is-padded > .bx-card-head + * { padding-top: 14px; }

/* === Table === */
.bx-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.bx-table th { text-align: left; font-weight: 500; font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--ink-3); padding: 10px 12px;
  border-bottom: 1px solid var(--line-2); background: var(--bg-elev); }
.bx-table td { padding: 10px 12px; border-bottom: 1px solid var(--line-2); color: var(--ink); vertical-align: middle; }
.bx-table tbody tr { cursor: pointer; }
.bx-table tbody tr:hover { background: var(--chip-bg); }
.bx-table tbody tr:last-child td { border-bottom: none; }

/* === Dashboard === */
.bx-dash { display: flex; flex-direction: column; gap: 16px; }
.bx-dash-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.bx-stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 14px 16px; box-shadow: var(--shadow); }
.bx-stat-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.bx-stat-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); font-weight: 500; }
.bx-stat-hindi { font-family: var(--ff-hindi); font-size: 10px; color: var(--ink-3); }
.bx-stat-value { font-family: var(--ff-display); font-size: 26px; font-weight: 600; line-height: 1.1; letter-spacing: -0.02em; }
.bx-stat-foot { display: flex; gap: 6px; align-items: center; margin-top: 8px; }
.bx-stat-sub  { font-size: 10px; color: var(--ink-3); }

.bx-dash-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 12px; }
.bx-dash-grid:has(.bx-card:nth-child(2):last-child) { /* keep */ }

/* Pipeline mini bar chart */
.bx-pipe-mini { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px;
  align-items: end; min-height: 220px; padding-top: 8px; }
.bx-pipe-mini-col { display: flex; flex-direction: column; align-items: center; gap: 5px; text-align: center; }
.bx-pipe-mini-bar { width: 100%; background: var(--c, var(--accent)); border-radius: 3px 3px 0 0; min-height: 14px; }
.bx-pipe-mini-count { font-family: var(--ff-mono); font-size: 14px; font-weight: 600; color: var(--ink); }
.bx-pipe-mini-label { font-size: 10px; color: var(--ink-2); line-height: 1.15; }
.bx-pipe-mini-hindi { font-family: var(--ff-hindi); font-size: 9px; color: var(--ink-3); }

/* Today's focus */
.bx-focus { list-style: none; margin: 0; padding: 0; }
.bx-focus li { display: grid; grid-template-columns: 8px 1fr auto; gap: 10px; align-items: center;
  padding: 12px 16px; border-bottom: 1px solid var(--line-2); }
.bx-focus li:last-child { border-bottom: none; }
.bx-focus-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ink-3); }
.bx-focus-dot-warn { background: var(--warn); }
.bx-focus-dot-bad { background: var(--bad); }
.bx-focus-dot-good { background: var(--good); }
.bx-focus li b { display: block; font-size: 12px; }
.bx-focus li em { display: block; font-size: 11px; color: var(--ink-3); font-style: normal; margin-top: 2px; }

.bx-activity { list-style: none; margin: 0; padding: 0; }
.bx-activity li { display: grid; grid-template-columns: 8px 1fr; gap: 10px; padding: 10px 0;
  border-bottom: 1px dashed var(--line-2); }
.bx-activity li:last-child { border-bottom: none; }
.bx-activity-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-3); margin-top: 6px; }
.bx-activity li div b { font-size: 11px; }
.bx-activity li div em { display: block; font-size: 10px; color: var(--ink-3); font-style: normal; margin-top: 2px; }

/* === Pipeline / Kanban === */
.bx-pipe { display: flex; flex-direction: column; gap: 12px; min-height: 0; flex: 1; }
.bx-pipe-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.bx-pipe-filters { display: flex; gap: 6px; align-items: center; }
.bx-pipe-count { font-size: 11px; color: var(--ink-3); margin-left: 8px; }

.bx-seg { display: inline-flex; background: var(--chip-bg); padding: 3px; border-radius: var(--radius); }
.bx-seg-btn { all: unset; cursor: pointer; padding: 5px 12px; font-size: 11px; font-weight: 500;
  color: var(--ink-2); border-radius: calc(var(--radius) - 2px); }
.bx-seg-btn.is-active { background: var(--surface); color: var(--ink); box-shadow: var(--shadow); }

.bx-kanban { display: grid; grid-template-columns: repeat(8, minmax(150px, 1fr)); gap: 8px;
  flex: 1; min-height: 0; }
.bx-kcol { background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-lg); display: flex; flex-direction: column; min-height: 320px; overflow: hidden; }
.bx-kcol-head { display: flex; align-items: center; gap: 6px; padding: 10px 10px;
  border-bottom: 1px solid var(--line-2); border-top: 2px solid var(--c); background: var(--surface); }
.bx-kcol-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--c); flex-shrink: 0; }
.bx-kcol-titles { flex: 1; min-width: 0; }
.bx-kcol-titles b { font-size: 11px; display: block; }
.bx-kcol-titles em { font-family: var(--ff-hindi); font-size: 9px; color: var(--ink-3); font-style: normal; }
.bx-kcol-count { font-family: var(--ff-mono); font-size: 11px; background: var(--chip-bg);
  padding: 1px 7px; border-radius: 99px; color: var(--ink-2); }
.bx-kcol-body { padding: 8px; display: flex; flex-direction: column; gap: 6px; flex: 1; overflow: auto; }
.bx-kcol-empty { font-size: 11px; color: var(--ink-3); text-align: center; padding: 12px; }

.bx-kcard { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 9px; cursor: pointer; transition: border-color .12s, transform .12s; }
.bx-kcard:hover { border-color: var(--accent); transform: translateY(-1px); }
.bx-kcard-head { display: flex; justify-content: space-between; align-items: center; gap: 4px; margin-bottom: 5px; }
.bx-kcard-title { font-size: 12px; font-weight: 600; }
.bx-kcard-sub { font-size: 10px; color: var(--ink-3); margin: 2px 0 8px; }
.bx-kcard-foot { display: flex; justify-content: space-between; align-items: center; gap: 6px;
  font-size: 10px; color: var(--ink-3); margin-bottom: 6px; }
.bx-kcard-foot span { display: inline-flex; align-items: center; gap: 3px; }

/* Timeline */
.bx-timeline { background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 0; overflow: hidden; flex: 1;
  display: flex; flex-direction: column; min-height: 0; }
.bx-timeline-grid { display: grid; grid-template-columns: 180px repeat(10, 1fr);
  padding-left: 180px; border-bottom: 1px solid var(--line-2); background: var(--bg-elev); }
.bx-timeline-col-head { padding: 8px 0; font-family: var(--ff-mono); font-size: 10px;
  color: var(--ink-3); text-align: center; border-left: 1px solid var(--line-2); }
.bx-timeline-rows { display: flex; flex-direction: column; overflow: auto; flex: 1; }
.bx-timeline-row { display: grid; grid-template-columns: 180px 1fr; align-items: center;
  border-bottom: 1px solid var(--line-2); cursor: pointer; }
.bx-timeline-row:hover { background: var(--chip-bg); }
.bx-timeline-label { padding: 10px 14px; display: flex; flex-direction: column; gap: 2px; }
.bx-timeline-label span:first-child { font-family: var(--ff-mono); font-size: 11px; }
.bx-timeline-label span:last-child { font-size: 11px; color: var(--ink-2); }
.bx-timeline-track { position: relative; height: 36px; background-image:
  linear-gradient(to right, var(--line-2) 1px, transparent 1px);
  background-size: 10% 100%; }
.bx-timeline-bar { position: absolute; top: 8px; height: 20px; background: var(--c, var(--accent));
  border-radius: 3px; color: white; padding: 0 8px; display: flex; align-items: center;
  font-size: 10px; font-weight: 500; overflow: hidden; position: relative; }
.bx-timeline-bar span { z-index: 1; }
.bx-timeline-bar-prog { position: absolute; left: 0; top: 0; bottom: 0;
  background: color-mix(in oklab, white 25%, transparent); }

/* === Order Detail === */
.bx-order { display: flex; flex-direction: column; gap: 14px; }
.bx-order-head { display: flex; gap: 14px; align-items: flex-start; }
.bx-back { all: unset; cursor: pointer; display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; color: var(--ink-3); padding: 6px 8px; border-radius: var(--radius); margin-top: 4px; }
.bx-back:hover { background: var(--chip-bg); color: var(--ink); }
.bx-order-head-main { flex: 1; }
.bx-order-head-meta { display: flex; gap: 8px; align-items: center; }
.bx-order-head-main h2 { font-family: var(--ff-display); font-size: 24px; margin: 6px 0 4px; font-weight: 500; }
.bx-order-head-main h2 em { font-style: normal; color: var(--ink-2); }
.bx-order-head-sub { font-size: 11px; color: var(--ink-3); }
.bx-order-head-actions { display: flex; gap: 6px; align-items: center; }

.bx-order-tracker { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 14px; }
.bx-order-step { display: flex; gap: 8px; align-items: center; opacity: .5; }
.bx-order-step.is-done { opacity: 1; }
.bx-order-step.is-active { opacity: 1; }
.bx-order-step-dot { width: 22px; height: 22px; border-radius: 50%; background: var(--chip-bg);
  display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600;
  color: var(--ink-2); flex-shrink: 0; }
.bx-order-step.is-done .bx-order-step-dot { background: var(--good); color: white; }
.bx-order-step.is-active .bx-order-step-dot { background: var(--accent); color: var(--accent-ink); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent); }
.bx-order-step-label b { display: block; font-size: 10px; }
.bx-order-step-label em { display: block; font-family: var(--ff-hindi); font-size: 9px;
  color: var(--ink-3); font-style: normal; }

.bx-order-body { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.bx-order-col { display: flex; flex-direction: column; gap: 12px; }
.bx-order-divider { height: 1px; background: var(--line-2); margin: 6px 0; }

.bx-dl { display: grid; grid-template-columns: 100px 1fr; gap: 6px 12px; font-size: 12px; margin: 0; }
.bx-dl dt { color: var(--ink-3); font-size: 11px; }
.bx-dl dd { margin: 0; color: var(--ink); }
.bx-dl dd em { display: block; font-size: 10px; color: var(--ink-3); font-style: normal; }

.bx-meas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.bx-meas-cell { background: var(--bg-elev); border: 1px solid var(--line-2);
  border-radius: var(--radius); padding: 8px; }
.bx-meas-cell em { display: block; font-size: 9px; color: var(--ink-3); text-transform: uppercase;
  letter-spacing: 0.08em; font-style: normal; }
.bx-meas-cell b { display: block; font-family: var(--ff-mono); font-size: 13px; margin-top: 3px; }

.bx-assign { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.bx-assign li { background: var(--bg-elev); border-radius: var(--radius);
  padding: 8px 10px; border: 1px solid var(--line-2); }
.bx-assign em { display: block; font-size: 9px; color: var(--ink-3); text-transform: uppercase;
  letter-spacing: 0.08em; font-style: normal; }
.bx-assign b { font-size: 12px; }

.bx-tasks { list-style: none; margin: 0; padding: 0; }
.bx-tasks li { display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 11px;
  color: var(--ink-2); }
.bx-tasks li.is-done { color: var(--ink-3); text-decoration: line-through; }
.bx-tasks li.is-done svg { color: var(--good); }
.bx-tasks li.is-active { color: var(--ink); font-weight: 500; }
.bx-tasks li.is-active svg { color: var(--accent); }

.bx-refs { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line-2); }
.bx-ref-tile { background: var(--bg-elev); aspect-ratio: 4/5; position: relative;
  display: flex; align-items: center; justify-content: center; color: var(--ink-3); }
.bx-ref-svg { width: 100%; height: 100%; color: var(--ink-3); }
.bx-ref-label { position: absolute; bottom: 6px; left: 8px; font-family: var(--ff-mono);
  font-size: 9px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.1em; }

.bx-notes { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.bx-notes li { display: grid; grid-template-columns: 22px 1fr; gap: 8px; }
.bx-notes b { font-size: 11px; }
.bx-notes em { font-size: 10px; color: var(--ink-3); font-style: normal; margin-left: 6px; }
.bx-notes p { margin: 3px 0 0; font-size: 11px; color: var(--ink-2); }
.bx-textarea { width: 100%; min-height: 50px; resize: vertical; margin-top: 10px; }

/* === Login === */
.bx-login { display: grid; grid-template-columns: 1fr 1fr; height: 100%; }
.bx-login-left { padding: 40px 48px; background: var(--side-bg); color: var(--side-ink);
  display: flex; flex-direction: column; position: relative; overflow: hidden; }
.bx-login-left::before { content: ''; position: absolute; right: -100px; top: -100px;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklab, var(--accent) 30%, transparent), transparent 70%); }
.bx-login-brand { display: flex; align-items: center; gap: 10px; font-family: var(--ff-display);
  font-size: 22px; }
.bx-login-brand em { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  color: var(--side-mute); letter-spacing: 0.18em; font-style: normal; }
.bx-login-hero { flex: 1; display: flex; flex-direction: column; justify-content: center; position: relative; }
.bx-login-eyebrow { font-family: var(--ff-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.18em; color: var(--side-mute); margin-bottom: 18px; }
.bx-login-hero h1 { font-family: var(--ff-display); font-size: 52px; line-height: 1.05;
  font-weight: 400; letter-spacing: -0.02em; margin: 0 0 18px; }
.bx-login-hero h1 span { color: color-mix(in oklab, var(--side-ink) 60%, transparent); font-style: italic; }
.bx-login-hero p { font-size: 14px; max-width: 420px; color: color-mix(in oklab, var(--side-ink) 75%, transparent); }
.bx-login-stats { display: flex; gap: 24px; margin-top: 28px; }
.bx-login-stats b { display: block; font-family: var(--ff-display); font-size: 20px; font-weight: 500; }
.bx-login-stats em { display: block; font-size: 10px; color: var(--side-mute); font-style: normal; }

.bx-login-right { padding: 40px 48px; display: flex; align-items: center; justify-content: center; overflow: auto; }
.bx-login-card { width: 100%; max-width: 420px; padding: 28px; }
.bx-login-card-title { font-family: var(--ff-display); font-size: 22px; font-weight: 500; }
.bx-login-card-sub { font-size: 11px; color: var(--ink-3); font-family: var(--ff-hindi); margin-top: 2px; }
.bx-login-card-head { margin-bottom: 18px; }
.bx-login-role-label { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--ink-3); margin: 14px 0 8px; }
.bx-login-roles { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; margin-bottom: 16px; max-height: 200px; overflow: auto; }
.bx-login-role { all: unset; cursor: pointer; display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; border-radius: var(--radius); border: 1px solid var(--line-2); }
.bx-login-role:hover { border-color: var(--accent); }
.bx-login-role.is-active { background: color-mix(in oklab, var(--accent) 10%, transparent); border-color: var(--accent); }
.bx-login-role-meta b { font-size: 11px; display: block; }
.bx-login-role-meta em { font-family: var(--ff-hindi); font-size: 9px; color: var(--ink-3); font-style: normal; display: block; }
.bx-login-foot { font-size: 11px; color: var(--ink-3); text-align: center; margin-top: 14px; }
.bx-login-foot a { color: var(--accent); cursor: pointer; }

.bx-field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 10px; }
.bx-field > span { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--ink-3); }

/* === Modal === */
.bx-modal-bg { position: absolute; inset: 0; background: rgba(20,15,12,0.45);
  z-index: 100; display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(2px); }
.bx-modal { background: var(--surface); border-radius: var(--radius-lg); width: min(880px, 100%);
  max-height: 100%; display: flex; flex-direction: column; box-shadow: 0 20px 60px rgba(0,0,0,0.25); overflow: hidden; }
.bx-modal-sm { width: min(520px, 100%); }
.bx-modal-head { display: flex; justify-content: space-between; align-items: center;
  padding: 18px 22px; border-bottom: 1px solid var(--line-2); }
.bx-modal-title { font-family: var(--ff-display); font-size: 18px; font-weight: 600; }
.bx-modal-sub { font-size: 11px; color: var(--ink-3); margin-top: 2px; font-family: var(--ff-hindi); }
.bx-modal-close { all: unset; cursor: pointer; width: 30px; height: 30px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center; color: var(--ink-3); font-size: 14px; }
.bx-modal-close:hover { background: var(--chip-bg); }
.bx-modal-stepper { display: flex; gap: 12px; padding: 12px 22px; border-bottom: 1px solid var(--line-2); background: var(--bg-elev); }
.bx-modal-step { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--ink-3); }
.bx-modal-step span { width: 18px; height: 18px; border-radius: 50%; background: var(--chip-bg);
  display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600; }
.bx-modal-step.is-active { color: var(--ink); font-weight: 500; }
.bx-modal-step.is-active span { background: var(--accent); color: var(--accent-ink); }
.bx-modal-step.is-done span { background: var(--good); color: white; }
.bx-modal-body { padding: 22px; overflow: auto; flex: 1; }
.bx-modal-foot { display: flex; justify-content: space-between; align-items: center;
  padding: 14px 22px; border-top: 1px solid var(--line-2); background: var(--bg-elev); }
.bx-modal-foot-actions { display: flex; gap: 8px; }

.bx-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; }
.bx-field-wide { grid-column: span 2; }
.bx-meas-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.bx-field-small { font-size: 11px; }
.bx-pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  background: var(--bg-elev); padding: 12px; border-radius: var(--radius); margin-top: 6px; }
.bx-pricing-grid > div { display: flex; flex-direction: column; }
.bx-pricing-grid em { font-size: 10px; color: var(--ink-3); font-style: normal; }
.bx-pricing-grid b { font-family: var(--ff-mono); font-size: 12px; }
.bx-pricing-grid .is-total { grid-column: span 3; border-top: 1px solid var(--line);
  padding-top: 8px; margin-top: 4px; flex-direction: row; justify-content: space-between; }
.bx-pricing-grid .is-total b { font-size: 16px; }

/* === Vendors screen === */
.bx-vend { display: grid; grid-template-columns: 280px 1fr; gap: 12px; flex: 1; min-height: 0; }
.bx-vend-list { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  display: flex; flex-direction: column; overflow: hidden; box-shadow: var(--shadow); }
.bx-vend-list-head { display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px; border-bottom: 1px solid var(--line-2); }
.bx-vend-list-head b { font-family: var(--ff-display); font-size: 14px; font-weight: 600; }
.bx-vend-list-item { all: unset; cursor: pointer; padding: 12px 14px;
  border-bottom: 1px solid var(--line-2); display: flex; flex-direction: column; gap: 8px; }
.bx-vend-list-item:hover { background: var(--chip-bg); }
.bx-vend-list-item.is-active { background: color-mix(in oklab, var(--accent) 8%, transparent);
  border-left: 3px solid var(--accent); padding-left: 11px; }
.bx-vend-list-name b { font-size: 12px; display: block; }
.bx-vend-list-name em { font-size: 10px; color: var(--ink-3); font-style: normal; }
.bx-vend-list-meta { display: flex; justify-content: space-between; align-items: center; }
.bx-vend-rate { font-family: var(--ff-mono); font-size: 11px; font-weight: 600; }
.bx-vend-rate.is-good { color: var(--good); }
.bx-vend-rate.is-warn { color: var(--warn); }
.bx-vend-rate.is-bad { color: var(--bad); }
.bx-vend-active { font-size: 10px; color: var(--ink-3); }

.bx-vend-detail { display: flex; flex-direction: column; gap: 12px; overflow: auto; min-height: 0; padding-right: 2px; }
.bx-vend-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 16px 18px; box-shadow: var(--shadow); }
.bx-vend-head-type { font-family: var(--ff-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--ink-3); }
.bx-vend-head h2 { font-family: var(--ff-display); font-size: 22px; font-weight: 500; margin: 4px 0; }
.bx-vend-head-sub { display: flex; gap: 16px; font-size: 11px; color: var(--ink-3); flex-wrap: wrap; }
.bx-vend-head-sub span { display: inline-flex; align-items: center; gap: 4px; }
.bx-vend-head-actions { display: flex; gap: 8px; flex-shrink: 0; }

.bx-vend-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }

/* Reminder composer */
.bx-reminder-preview { background: #e6dfd4; border-radius: var(--radius-lg); padding: 14px;
  display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.bx-reminder-preview-head { display: flex; align-items: center; gap: 6px; color: #075e54;
  font-family: var(--ff-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; }
.bx-reminder-bubble { background: #dcf8c6; padding: 10px 12px; border-radius: 8px;
  font-size: 12px; color: #1c2533; max-width: 80%; align-self: flex-end; line-height: 1.4; }
.bx-reminder-foot { font-size: 10px; color: var(--ink-3); margin-top: 2px; }

/* === Fabric === */
.bx-fab-cols { display: grid; grid-template-columns: 360px 1fr; gap: 12px; }
.bx-fab-summary { display: flex; flex-direction: column; gap: 12px; }
.bx-fab-flow { display: grid; grid-template-columns: 1fr 14px 1fr 14px 1fr 14px 1fr; gap: 6px;
  align-items: center; }
.bx-fab-flow-step { display: flex; flex-direction: column; align-items: center; text-align: center;
  background: var(--bg-elev); border: 1px solid var(--line-2); border-radius: var(--radius);
  padding: 10px 6px; }
.bx-fab-flow-step.is-warn { border-color: var(--warn); background: color-mix(in oklab, var(--warn) 8%, var(--surface)); }
.bx-fab-flow-step.is-good { border-color: var(--good); background: color-mix(in oklab, var(--good) 8%, var(--surface)); }
.bx-fab-flow-icon { width: 30px; height: 30px; border-radius: 50%; background: var(--chip-bg);
  display: inline-flex; align-items: center; justify-content: center; color: var(--ink-2); margin-bottom: 4px; }
.bx-fab-flow-step b { font-size: 11px; }
.bx-fab-flow-step em { font-size: 10px; color: var(--ink-3); font-style: normal; }
.bx-fab-flow-arrow { font-family: var(--ff-mono); color: var(--ink-3); font-size: 14px; text-align: center; }

.bx-swatch { width: 16px; height: 16px; border-radius: 3px; display: inline-block;
  vertical-align: middle; margin-right: 8px; border: 1px solid var(--line); }
.bx-swatch-sm { width: 12px; height: 12px; margin-right: 6px; }

.bx-lots { list-style: none; margin: 0; padding: 0; }
.bx-lots li { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--line-2); }
.bx-lots li:last-child { border-bottom: none; }
.bx-lots b { font-size: 12px; display: block; }
.bx-lots em { font-size: 10px; color: var(--ink-3); font-style: normal; }
.bx-lots .bx-swatch { width: 24px; height: 24px; border-radius: var(--radius); margin: 0; }

/* === Stitching === */
.bx-stitch { display: flex; flex-direction: column; gap: 12px; flex: 1; min-height: 0; }
.bx-stitch-people { display: grid; }
.bx-cap { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bx-cap-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.bx-cap-head b { font-size: 12px; }
.bx-cap-head em { font-size: 10px; color: var(--ink-3); font-style: normal; }
.bx-cap-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 6px;
  font-size: 10px; color: var(--ink-3); }

.bx-stitch-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2);
  flex: 1; min-height: 0; }
.bx-stitch-col { background: var(--surface); display: flex; flex-direction: column; }
.bx-stitch-col-head { padding: 10px 12px; border-bottom: 1px solid var(--line-2);
  display: flex; justify-content: space-between; align-items: center; }
.bx-stitch-col-head b { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.bx-stitch-col-head span { font-family: var(--ff-mono); font-size: 11px;
  background: var(--chip-bg); padding: 1px 7px; border-radius: 99px; color: var(--ink-2); }
.bx-stitch-col-body { padding: 8px; display: flex; flex-direction: column; gap: 6px; overflow: auto; }
.bx-stitch-card { background: var(--bg-elev); border: 1px solid var(--line-2);
  border-radius: var(--radius); padding: 9px; }
.bx-stitch-card-head { display: flex; justify-content: space-between; margin-bottom: 4px; }
.bx-stitch-card b { font-size: 12px; display: block; }
.bx-stitch-card em { font-size: 10px; color: var(--ink-3); font-style: normal; display: block; margin-bottom: 6px; }
.bx-stitch-card-foot { font-size: 10px; color: var(--ink-3); margin-top: 4px; }

/* === Stock === */
.bx-stock { display: flex; flex-direction: column; gap: 12px; }
.bx-stock-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.bx-table-stock td:nth-child(4),
.bx-table-stock td:nth-child(5),
.bx-table-stock td:nth-child(6),
.bx-table-stock td:nth-child(7) { font-family: var(--ff-mono); }

/* === Delivery === */
.bx-deliv { display: flex; flex-direction: column; gap: 12px; }
.bx-deliv-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }

/* === Customer screen === */
.bx-cust-flex { display: grid; grid-template-columns: auto 1fr; gap: 32px; align-items: start; padding: 8px; }
.bx-cust-phone-frame { width: 320px; height: 640px; border-radius: 36px;
  background: var(--side-bg); padding: 12px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.18), inset 0 0 0 2px color-mix(in oklab, var(--side-bg) 80%, white 10%); }
.bx-cust-side h3 { font-family: var(--ff-display); font-size: 20px; margin: 0 0 8px; }
.bx-cust-side p { color: var(--ink-2); font-size: 13px; max-width: 380px; }
.bx-cust-side-list { list-style: none; margin: 16px 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.bx-cust-side-list li { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink); }
.bx-cust-side-list svg { color: var(--good); }
.bx-cust-link { display: inline-flex; align-items: center; gap: 8px; background: var(--chip-bg);
  padding: 8px 12px; border-radius: var(--radius); font-size: 12px; color: var(--ink-2); }

/* === Customer mobile inside frame === */
.cm-root { width: 100%; height: 100%; background: var(--bg); border-radius: 26px; overflow: hidden;
  font-family: var(--ff-body); color: var(--ink); display: flex; flex-direction: column; }
.cm-status-bar { display: flex; justify-content: space-between; padding: 8px 18px; font-size: 11px; font-weight: 600; }
.cm-app { flex: 1; overflow: auto; padding: 0 16px 14px; }
.cm-head { display: flex; justify-content: space-between; align-items: center; padding: 4px 0 14px; font-size: 13px; color: var(--ink-2); }
.cm-back, .cm-more { font-size: 18px; color: var(--ink-3); }

.cm-hero { background: var(--surface); padding: 18px; border-radius: var(--radius-lg);
  border: 1px solid var(--line); margin-bottom: 14px; }
.cm-hero-id { font-family: var(--ff-mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.12em; }
.cm-hero h1 { font-family: var(--ff-display); font-size: 22px; line-height: 1.1; margin: 4px 0; font-weight: 500; }
.cm-hero-sub { font-size: 11px; color: var(--ink-3); }
.cm-hero-due { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px;
  padding-top: 14px; border-top: 1px solid var(--line-2); }
.cm-hero-due em { display: block; font-size: 10px; color: var(--ink-3); text-transform: uppercase;
  letter-spacing: 0.08em; font-style: normal; }
.cm-hero-due b { font-family: var(--ff-display); font-size: 16px; }

.cm-track { display: flex; flex-direction: column; gap: 12px; margin-bottom: 14px; }
.cm-step { display: grid; grid-template-columns: 24px 1fr; gap: 10px; align-items: center; }
.cm-step-dot { width: 22px; height: 22px; border-radius: 50%; background: var(--chip-bg);
  display: inline-flex; align-items: center; justify-content: center; font-size: 10px; color: var(--ink-3); }
.cm-step.is-done .cm-step-dot { background: var(--good); color: white; }
.cm-step.is-active .cm-step-dot { background: var(--accent); color: var(--accent-ink); }
.cm-step b { font-size: 11px; }
.cm-step em { display: block; font-size: 10px; color: var(--ink-3); font-style: normal; }

.cm-actions { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.cm-actions button { all: unset; cursor: pointer; padding: 12px; text-align: center;
  border: 1px solid var(--line); border-radius: var(--radius); font-size: 12px; font-weight: 500; }
.cm-actions button:first-child { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* === Phone frame & mobile artboards === */
.phone-frame { width: 100%; height: 100%; background: #0a0a0c; padding: 10px;
  border-radius: 44px; position: relative; box-shadow: inset 0 0 0 2px #2a2a30, 0 20px 60px rgba(0,0,0,0.2); }
.phone-notch { position: absolute; top: 18px; left: 50%; transform: translateX(-50%);
  width: 100px; height: 22px; background: #0a0a0c; border-radius: 99px; z-index: 5; }
.phone-inner { width: 100%; height: 100%; background: var(--bg); border-radius: 34px; overflow: hidden; }

/* Customer mobile full-frame */
.cmf-root { width: 100%; height: 100%; background: var(--bg); display: flex; flex-direction: column;
  font-family: var(--ff-body); color: var(--ink); overflow: auto; }
.cmf-bar { display: flex; justify-content: space-between; padding: 12px 28px 8px; font-size: 11px; font-weight: 600; }
.cmf-head { display: flex; justify-content: space-between; align-items: center; padding: 8px 20px 14px; }
.cmf-brand { display: flex; align-items: center; gap: 8px; font-family: var(--ff-display); font-size: 16px; font-weight: 500; }
.cmf-logo { width: 26px; height: 26px; border-radius: 50%; background: var(--accent); color: var(--accent-ink);
  display: inline-flex; align-items: center; justify-content: center; font-size: 14px; }
.cmf-bell { font-size: 16px; }

.cmf-hero { margin: 0 16px 14px; padding: 22px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); }
.cmf-hero-eyebrow { font-family: var(--ff-mono); font-size: 9px; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--ink-3); }
.cmf-hero-id { font-family: var(--ff-mono); font-size: 11px; color: var(--ink-3); margin-top: 6px; }
.cmf-hero h1 { font-family: var(--ff-display); font-size: 28px; line-height: 1.05; margin: 6px 0 8px; font-weight: 500; letter-spacing: -0.02em; }
.cmf-hero-sub { font-size: 12px; color: var(--ink-2); }
.cmf-hero-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 18px;
  padding-top: 16px; border-top: 1px solid var(--line-2); }
.cmf-hero-grid em { display: block; font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--ink-3); font-style: normal; }
.cmf-hero-grid b { font-family: var(--ff-display); font-size: 14px; font-weight: 500; }

.cmf-section { margin: 0 16px 14px; }
.cmf-section-title { font-family: var(--ff-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.14em; color: var(--ink-3); margin-bottom: 10px; padding: 0 4px; }
.cmf-track { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 16px; }
.cmf-step { display: grid; grid-template-columns: 28px 1fr; gap: 10px; position: relative; padding-bottom: 14px; }
.cmf-step:last-child { padding-bottom: 0; }
.cmf-step-line { position: absolute; left: 13px; top: 28px; bottom: 0; width: 2px; background: var(--line-2); }
.cmf-step:last-child .cmf-step-line { display: none; }
.cmf-step.is-done .cmf-step-line { background: var(--good); }
.cmf-step-dot { width: 26px; height: 26px; border-radius: 50%; background: var(--chip-bg);
  display: inline-flex; align-items: center; justify-content: center; font-size: 11px; color: var(--ink-3); z-index: 1; }
.cmf-step.is-done .cmf-step-dot { background: var(--good); color: white; }
.cmf-step.is-active .cmf-step-dot { background: var(--accent); color: var(--accent-ink);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 18%, transparent); }
.cmf-step-body b { font-size: 13px; display: block; }
.cmf-step-body em { font-size: 11px; color: var(--ink-3); font-style: normal; }

.cmf-note { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 14px; display: grid; grid-template-columns: 26px 1fr; gap: 10px; }
.cmf-note b { font-size: 12px; }
.cmf-note p { margin: 4px 0 0; font-size: 12px; color: var(--ink-2); line-height: 1.5; }

.cmf-cta { padding: 0 16px 24px; display: flex; flex-direction: column; gap: 8px; }
.cmf-btn-primary { all: unset; cursor: pointer; padding: 14px; text-align: center;
  background: var(--accent); color: var(--accent-ink); border-radius: var(--radius); font-size: 13px; font-weight: 500; }
.cmf-btn-ghost { all: unset; cursor: pointer; padding: 14px; text-align: center;
  border: 1px solid var(--line); border-radius: var(--radius); font-size: 13px; }

/* === Vendor mobile (WhatsApp-style) === */
.vmf-root { width: 100%; height: 100%; display: flex; flex-direction: column;
  background: #e6dfd4; font-family: var(--ff-body); color: #1c2533; }
.vmf-head { display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  background: #075e54; color: white; }
.vmf-back { font-size: 18px; }
.vmf-title b { font-size: 14px; display: block; }
.vmf-title em { font-size: 10px; font-style: normal; opacity: .85; }
.vmf-icons { margin-left: auto; font-size: 14px; letter-spacing: 4px; }
.vmf-chat { flex: 1; overflow: auto; padding: 14px 12px; display: flex; flex-direction: column; gap: 10px;
  background-image: radial-gradient(circle at 25px 25px, rgba(0,0,0,0.03) 1px, transparent 1px);
  background-size: 50px 50px; }
.vmf-day { align-self: center; font-size: 10px; background: #fff5c2; color: #4a3f33;
  padding: 4px 10px; border-radius: 8px; }
.vmf-msg { display: flex; flex-direction: column; max-width: 80%; }
.vmf-in { align-self: flex-start; }
.vmf-out { align-self: flex-end; align-items: flex-end; }
.vmf-bubble { background: white; padding: 8px 10px; border-radius: 8px; font-size: 12px;
  line-height: 1.4; box-shadow: 0 1px 0 rgba(0,0,0,0.06); }
.vmf-out .vmf-bubble { background: #dcf8c6; }
.vmf-bubble-card { background: #f0f7e8; border-left: 3px solid #075e54; padding: 10px; }
.vmf-card-head { display: flex; justify-content: space-between; font-size: 10px;
  margin-bottom: 4px; color: #075e54; font-weight: 600; }
.vmf-card-head em { font-style: normal; opacity: .7; }
.vmf-bubble-card p { margin: 4px 0 0; }
.vmf-bubble-action { background: white; }
.vmf-action-row { display: flex; gap: 6px; margin-top: 8px; }
.vmf-action-row button { all: unset; cursor: pointer; flex: 1; text-align: center;
  background: #075e54; color: white; padding: 8px; border-radius: 6px; font-size: 11px; }
.vmf-action-row .vmf-action-ghost { background: transparent; color: #075e54; border: 1px solid #075e54; }
.vmf-time { font-size: 9px; color: rgba(0,0,0,0.5); margin-top: 2px; padding: 0 2px; }
.vmf-image { width: 200px; height: 140px; background: white; padding: 2px; border-radius: 8px; margin-top: 4px; overflow: hidden; }
.vmf-msg.vmf-auto .vmf-bubble { background: #fff8e1; }
.vmf-input { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: #f0f0f0; }
.vmf-input input { flex: 1; border: none; background: white; padding: 8px 12px; border-radius: 99px; font-size: 12px; }
.vmf-input input:focus { box-shadow: none; }
.vmf-send { background: #075e54; color: white; width: 32px; height: 32px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center; font-size: 14px; }

/* === Misc === */
.bx-spark { width: 60px; height: 24px; color: var(--accent); display: inline-block; }
