/* ═══════════════════════════════════════════════════════════════════════
   ZTCG mobile — clean phone-first UI, fully isolated from desktop.
   Dark theme by default, follows system preference.
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* Layout */
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --appbar-h: 56px;
  --bottomnav-h: 56px;
  --radius-card: 14px;
  --radius-pill: 999px;

  /* Type */
  --font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI",
               "Inter", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Cascadia Mono", "Roboto Mono",
               Menlo, Consolas, monospace;
  --text-xs:  12px;
  --text-sm:  13px;
  --text-md:  15px;
  --text-lg:  17px;
  --text-xl:  20px;

  /* Dark palette (default) */
  --bg:           #0b0c14;
  --bg-elev:      #14161f;
  --bg-elev-2:    #1c1f2c;
  --bg-input:     #1a1d28;
  --border:       #232636;
  --border-soft:  #1a1d28;
  --fg:           #e7e9f3;
  --fg-2:         #a8acc4;
  --fg-3:         #6f7491;
  --accent:       #5e8bff;
  --accent-pressed: #3f6dde;
  --danger:       #ff6b7a;
  --warn:         #f0b056;
  --ok:           #4ade80;
  --shadow:       0 1px 2px rgba(0,0,0,.35), 0 4px 18px rgba(0,0,0,.20);

  /* Status palette — match desktop semantics, lighter on dark */
  --st-paid-bg:    #0e2b1b; --st-paid-fg:    #6fe0a4; --st-paid-bd:    #134a2c;
  --st-ship-bg:    #0d2238; --st-ship-fg:    #6fbde0; --st-ship-bd:    #14467a;
  --st-deliv-bg:   #0e2e2a; --st-deliv-fg:   #6fe0d3; --st-deliv-bd:   #134a42;
  --st-refund-bg:  #2e1a10; --st-refund-fg:  #e0a36f; --st-refund-bd:  #4a2d14;
  --st-partial-bg: #2a1c0c; --st-partial-fg: #e0c46f; --st-partial-bd: #4a3a14;
  --st-cancel-bg:  #2e1016; --st-cancel-fg:  #e06f88; --st-cancel-bd:  #4a1423;
  --st-await-bg:   #1f2230; --st-await-fg:   #a8acc4; --st-await-bd:   #2c3046;
  --st-return-bg:  #2a1c2e; --st-return-fg:  #d68fe0; --st-return-bd:  #4a2d52;
}

@media (prefers-color-scheme: light) {
  :root {
    --bg:           #f6f7fb;
    --bg-elev:      #ffffff;
    --bg-elev-2:    #f0f2f8;
    --bg-input:     #f0f2f8;
    --border:       #e2e5ee;
    --border-soft:  #ecedf3;
    --fg:           #131520;
    --fg-2:         #4a4f66;
    --fg-3:         #7a8099;
    --accent:       #3f6dde;
    --accent-pressed: #2c52b0;
    --shadow:       0 1px 2px rgba(20,30,60,.06), 0 4px 18px rgba(20,30,60,.07);

    --st-paid-bg:    #e6f5ec; --st-paid-fg:    #1a7a45; --st-paid-bd:    #c4e6d3;
    --st-ship-bg:    #e3eefb; --st-ship-fg:    #1f5fa6; --st-ship-bd:    #c2d8f1;
    --st-deliv-bg:   #e3f4f1; --st-deliv-fg:   #197268; --st-deliv-bd:   #c2e3dd;
    --st-refund-bg:  #f8ebdf; --st-refund-fg:  #944a14; --st-refund-bd:  #ebd0b0;
    --st-partial-bg: #f7eed5; --st-partial-fg: #836514; --st-partial-bd: #ebd896;
    --st-cancel-bg:  #f8e0e5; --st-cancel-fg:  #963049; --st-cancel-bd:  #efbcc6;
    --st-await-bg:   #ecedf3; --st-await-fg:   #4a4f66; --st-await-bd:   #d6d9e3;
    --st-return-bg:  #f3e3f5; --st-return-fg:  #7a3486; --st-return-bd:  #e0c1e6;
  }
}

/* ── Reset ─────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.42;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  text-rendering: optimizeLegibility;
  /* Suppress iOS Safari's pull-to-reload + elastic bounce so our pull-to-
     refresh gesture controls the top of the scroll instead. `none` blocks
     both directions; we only care about top, but bottom-bounce isn't
     useful here either. */
  overscroll-behavior-y: none;
}
body {
  min-height: 100vh;
  padding-top: calc(var(--appbar-h) + var(--safe-top));
  padding-bottom: calc(var(--bottomnav-h) + var(--safe-bottom));
  font-feature-settings: "tnum" 1; /* tabular nums for $ + dates */
}
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
a { color: var(--accent); text-decoration: none; }

/* Prevent iOS zoom-on-focus by keeping inputs ≥16px */
input, select, textarea { font-size: 16px; }

/* ── App bar ──────────────────────────────────────────────────────────── */
.appbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: calc(var(--appbar-h) + var(--safe-top));
  padding-top: var(--safe-top);
  background: color-mix(in srgb, var(--bg-elev) 92%, transparent);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--border-soft);
  display: flex; align-items: center;
  padding-left: 12px; padding-right: 8px;
  z-index: 50;
}
.appbar__logo {
  width: 32px; height: 32px; border-radius: 8px; object-fit: cover;
  margin-right: 10px; box-shadow: var(--shadow);
}
.appbar__title { font-size: var(--text-lg); font-weight: 600; letter-spacing: .2px; }
.appbar__sub   { font-size: var(--text-xs); color: var(--fg-3); margin-top: -2px; }
.appbar__spacer { flex: 1; }
.appbar__btn {
  width: 40px; height: 40px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--fg-2); font-size: 20px;
}
.appbar__btn:active { background: var(--bg-elev-2); color: var(--fg); }
.appbar__btn .dot {
  position: absolute; top: 8px; right: 8px; width: 8px; height: 8px;
  border-radius: 50%; background: var(--accent);
}
.appbar__btn { position: relative; }
.appbar__send {
  /* Scanner-style: a primary "Send N →" action that lives in the appbar
     instead of competing for space at the bottom of the scan view.
     M-3.3: bumped to 40px (was 32) so iOS HIG 44pt tap target ≈ holds
     and the button responds reliably to fingertip taps. */
  display: inline-flex; align-items: center; gap: 4px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font: inherit; font-weight: 700; font-size: var(--text-sm);
  border: 0;
  min-height: 40px;
  margin-left: 8px;
  -webkit-tap-highlight-color: rgba(255,255,255,.2);
  cursor: pointer;
}
.appbar__send:active { background: var(--accent-pressed); }
.appbar__send:disabled,
.appbar__send[disabled] { opacity: .4; pointer-events: none; }
.appbar__send[hidden] { display: none; }

/* ── Offline banner ───────────────────────────────────────────────────── */
.offline-bar {
  position: fixed;
  top: calc(var(--appbar-h) + var(--safe-top));
  left: 0; right: 0;
  z-index: 49;
  background: var(--st-partial-bg);
  color: var(--st-partial-fg);
  border-bottom: 1px solid var(--st-partial-bd);
  font-size: var(--text-xs); font-weight: 600;
  padding: 8px 14px;
  display: flex; align-items: center; gap: 8px;
  animation: slideDown .25s cubic-bezier(.2,.8,.2,1);
}
.offline-bar[hidden] { display: none; }
.offline-bar__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--st-partial-fg);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
@keyframes pulse {
  0%, 100% { opacity: .55; }
  50%      { opacity: 1; }
}
body.is-offline { padding-top: calc(var(--appbar-h) + var(--safe-top) + 36px); }

/* ── Page content ─────────────────────────────────────────────────────── */
.page { padding: 12px 12px 80px; max-width: 720px; margin: 0 auto; }
.page__title { font-size: var(--text-xl); font-weight: 700; padding: 8px 4px 4px; }
.page__sub { font-size: var(--text-sm); color: var(--fg-3); padding: 0 4px 12px; }

/* ── Game segmented switcher (mobile inventory) ───────────────────────── */
.game-switch {
  display: inline-flex; gap: 2px; padding: 2px;
  background: var(--bg-strong); border: 1px solid var(--bg-strong);
  border-radius: 8px; margin: 0 4px 10px;
}
.game-switch__btn {
  appearance: none; border: 0; cursor: pointer;
  padding: 6px 14px; font-size: var(--text-sm); font-weight: 600;
  color: var(--fg-4); background: transparent; border-radius: 6px;
  min-width: 56px; transition: background .12s, color .12s;
}
.game-switch__btn:active { transform: translateY(1px); }
.game-switch__btn.is-active { background: var(--bg-panel); color: var(--fg); }

/* ── KPI strip ────────────────────────────────────────────────────────── */
.kpis {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin: 4px 0 12px;
}
.kpi {
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  padding: 12px 14px;
}
.kpi__lbl { font-size: var(--text-xs); color: var(--fg-3); text-transform: uppercase; letter-spacing: .6px; }
.kpi__num { font-size: var(--text-lg); font-weight: 700; margin-top: 2px; font-variant-numeric: tabular-nums; }
.kpi--wide { grid-column: 1 / -1; }

/* ── Filter chips row (date presets) ──────────────────────────────────── */
.chiprow {
  display: flex; gap: 6px; overflow-x: auto;
  padding: 6px 4px 8px; margin: 0 -4px;
  scrollbar-width: none;
}
.chiprow::-webkit-scrollbar { display: none; }
.chip {
  flex: 0 0 auto;
  padding: 8px 14px; border-radius: var(--radius-pill);
  background: var(--bg-elev); border: 1px solid var(--border);
  color: var(--fg-2); font-size: var(--text-sm); font-weight: 500;
  white-space: nowrap;
}
.chip[aria-pressed="true"], .chip.is-active {
  background: var(--accent); border-color: var(--accent);
  color: #fff;
}

/* ── Order list ──────────────────────────────────────────────────────── */
.orders { display: flex; flex-direction: column; gap: 10px; }
.order {
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.order__hdr {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  align-items: start;
  padding: 14px 14px;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(94,139,255,.08);
  transition: background .12s ease;
}
.order__hdr:active { background: var(--bg-elev-2); }
.order__top { display: flex; align-items: center; gap: 8px; min-width: 0; }
.order__no  {
  font-family: var(--font-mono); font-size: var(--text-sm);
  color: var(--fg-2);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.order__total {
  font-size: var(--text-lg); font-weight: 700; font-variant-numeric: tabular-nums;
  text-align: right;
}
.order__meta {
  grid-column: 1 / 2;
  font-size: var(--text-sm); color: var(--fg-3);
  display: flex; gap: 8px; flex-wrap: wrap;
}
.order__meta b { color: var(--fg-2); font-weight: 500; }
.order__chev {
  grid-column: 2; align-self: end;
  font-size: 18px; color: var(--fg-3);
  transition: transform .18s ease;
}
.order.is-open .order__chev { transform: rotate(90deg); color: var(--fg-2); }
.order__refund {
  font-size: var(--text-xs); color: var(--st-refund-fg); margin-top: 2px;
}

/* Syncing state — set by the server when an order row exists with no
   SALE rows yet (push fired faster than eBay's Finance API settled). */
.order__syncing {
  display: inline-block;
  font-size: var(--text-sm); font-weight: 500;
  color: var(--fg-3); font-style: italic;
}
.order.is-syncing { background: color-mix(in srgb, var(--bg-elev) 92%, var(--accent) 8%); }
.order__placeholder {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 4px; color: var(--fg-3); font-size: var(--text-sm);
}
.order__placeholder-spinner {
  width: 14px; height: 14px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: pullSpin 1s linear infinite;
  flex-shrink: 0;
}

/* Status badge */
.badge {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: var(--radius-pill);
  font-size: var(--text-xs); font-weight: 600;
  border: 1px solid transparent; line-height: 1.5;
  white-space: nowrap;
}
.badge--paid          { background: var(--st-paid-bg);    color: var(--st-paid-fg);    border-color: var(--st-paid-bd); }
.badge--shipped       { background: var(--st-ship-bg);    color: var(--st-ship-fg);    border-color: var(--st-ship-bd); }
.badge--delivered     { background: var(--st-deliv-bg);   color: var(--st-deliv-fg);   border-color: var(--st-deliv-bd); }
.badge--refunded      { background: var(--st-refund-bg);  color: var(--st-refund-fg);  border-color: var(--st-refund-bd); }
.badge--partial_refund{ background: var(--st-partial-bg); color: var(--st-partial-fg); border-color: var(--st-partial-bd); }
.badge--cancelled     { background: var(--st-cancel-bg);  color: var(--st-cancel-fg);  border-color: var(--st-cancel-bd); }
.badge--awaiting_payment { background: var(--st-await-bg); color: var(--st-await-fg);  border-color: var(--st-await-bd); }
.badge--returned      { background: var(--st-return-bg);  color: var(--st-return-fg);  border-color: var(--st-return-bd); }

/* ── Order body (expanded) ───────────────────────────────────────────── */
.order__body {
  border-top: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--bg) 50%, var(--bg-elev) 50%);
  padding: 8px 14px 14px;
  display: none;
}
.order.is-open .order__body { display: block; }

.line {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--border-soft);
}
.line:last-child { border-bottom: 0; }
.line__photo {
  width: 56px; height: 78px;
  background: var(--bg-elev-2);
  border-radius: 6px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3); font-size: 11px;
}
.line__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.line__title { font-size: var(--text-md); font-weight: 600; color: var(--fg); }
.line__title a { color: inherit; }
.line__title a:active { color: var(--accent); }
.line__sub   { font-size: var(--text-sm); color: var(--fg-3); margin-top: 2px; }
.line__sub b { color: var(--fg-2); font-weight: 500; }
.line__variant {
  display: inline-block; margin-left: 6px;
  background: var(--bg-elev-2); color: var(--fg-2);
  font-size: 11px; padding: 1px 6px; border-radius: 4px; font-weight: 500;
}
.line__promo { color: var(--ok); font-size: var(--text-xs); margin-top: 2px; }
.line__num   { text-align: right; font-variant-numeric: tabular-nums; }
.line__qty   { font-size: var(--text-sm); color: var(--fg-2); }
.line__price { font-size: var(--text-md); font-weight: 600; margin-top: 2px; }

.lots {
  margin-top: 6px; padding: 6px 8px;
  background: var(--bg-elev-2); border-radius: 8px;
  font-size: var(--text-xs); color: var(--fg-2);
}
.lots__hdr { color: var(--fg-3); text-transform: uppercase; letter-spacing: .5px; font-size: 10px; margin-bottom: 2px; }
.lot { display: flex; justify-content: space-between; padding: 2px 0; }
.lot__id { font-family: var(--font-mono); }

.order__foot {
  margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border-soft);
  font-size: var(--text-xs); color: var(--fg-3); display: grid; gap: 4px;
}
.order__foot b { color: var(--fg-2); font-weight: 500; }
.foot-refund {
  display: inline-block; margin-top: 4px;
  background: var(--st-refund-bg); color: var(--st-refund-fg);
  border: 1px solid var(--st-refund-bd);
  padding: 2px 8px; border-radius: var(--radius-pill);
  font-weight: 600;
}

/* ── Empty / error / load-more ────────────────────────────────────────── */
.empty, .error {
  text-align: center; padding: 48px 16px;
  color: var(--fg-3); font-size: var(--text-md);
}
.empty__icon { font-size: 36px; margin-bottom: 8px; opacity: .55; }
.error { color: var(--danger); }

.loadmore {
  display: block; width: 100%; margin: 14px 0 4px;
  padding: 14px; border-radius: var(--radius-card);
  background: var(--bg-elev); color: var(--fg-2);
  font-weight: 600; font-size: var(--text-sm);
  border: 1px solid var(--border-soft);
}
.loadmore:active { background: var(--bg-elev-2); }
.loadmore[disabled] { opacity: .55; }

.skeleton {
  background: linear-gradient(90deg, var(--bg-elev) 0%, var(--bg-elev-2) 50%, var(--bg-elev) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border-radius: var(--radius-card);
}
.skeleton--card { height: 88px; margin-bottom: 10px; }
@keyframes shimmer { from { background-position: 200% 0 } to { background-position: -200% 0 } }

/* ── Bottom sheet ─────────────────────────────────────────────────────── */
.sheet-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  opacity: 0; pointer-events: none; transition: opacity .2s ease;
  z-index: 90;
}
.sheet-backdrop.is-open { opacity: 1; pointer-events: auto; }

.sheet {
  position: fixed; left: 0; right: 0; bottom: 0;
  background: var(--bg-elev); color: var(--fg);
  border-radius: 18px 18px 0 0;
  transform: translateY(100%);
  transition: transform .24s cubic-bezier(.2,.8,.2,1);
  z-index: 91;
  max-height: 85vh; overflow-y: auto;
  padding-bottom: calc(16px + var(--safe-bottom));
  box-shadow: 0 -8px 30px rgba(0,0,0,.5);
}
.sheet.is-open { transform: translateY(0); }
.sheet__handle {
  width: 36px; height: 4px; background: var(--fg-3); opacity: .35;
  border-radius: 4px; margin: 8px auto 4px;
}
.sheet__hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 16px 4px;
}
.sheet__title { font-size: var(--text-lg); font-weight: 600; }
.sheet__close {
  width: 36px; height: 36px; border-radius: 10px; color: var(--fg-2);
  display: inline-flex; align-items: center; justify-content: center; font-size: 18px;
}
.sheet__close:active { background: var(--bg-elev-2); color: var(--fg); }
.sheet__body { padding: 8px 16px 16px; }
.sheet__section { margin-top: 14px; }
.sheet__lbl { font-size: var(--text-xs); color: var(--fg-3); text-transform: uppercase; letter-spacing: .6px; margin-bottom: 6px; }
.sheet__chips { display: flex; flex-wrap: wrap; gap: 6px; }
.sheet__inputs { display: flex; gap: 8px; }
.sheet__inputs input {
  flex: 1; padding: 12px 12px;
  background: var(--bg-input); border: 1px solid var(--border);
  color: var(--fg); border-radius: 10px;
  font-size: 16px;
}
.sheet__row { display: flex; gap: 8px; align-items: center; margin-top: 8px; }
.sheet__row input {
  flex: 1; padding: 12px 12px;
  background: var(--bg-input); border: 1px solid var(--border);
  color: var(--fg); border-radius: 10px; font-size: 16px;
}
.sheet__btns { display: flex; gap: 8px; margin-top: 16px; }
.btn {
  flex: 1; padding: 14px; border-radius: 12px; font-weight: 600;
  font-size: var(--text-md); text-align: center;
  background: var(--bg-elev-2); color: var(--fg);
  border: 1px solid var(--border);
}
.btn:active { background: var(--bg-input); }
.btn:disabled,
.btn[disabled] {
  opacity: .4;
  pointer-events: none;
  cursor: not-allowed;
}
.btn--primary {
  background: var(--accent); color: #fff; border-color: var(--accent);
}
.btn--primary:active { background: var(--accent-pressed); border-color: var(--accent-pressed); }

/* ── Pull-to-refresh indicator ────────────────────────────────────────── */
/* Sits flush under the app bar, height grows with the user's pull. JS sets
   the height inline; the CSS only describes the visual states. */
.pull-indicator {
  position: fixed;
  top: calc(var(--appbar-h) + var(--safe-top));
  left: 0; right: 0;
  height: 0; overflow: hidden;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--border-soft);
  color: var(--fg-3); font-size: var(--text-xs); font-weight: 600;
  z-index: 49;
  pointer-events: none;
  transition: height .18s cubic-bezier(.2,.8,.2,1);
}
.pull-indicator.is-firing { transition: none; }
.pull-indicator__spinner {
  width: 18px; height: 18px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  transition: transform .12s ease;
}
.pull-indicator.is-firing .pull-indicator__spinner {
  animation: pullSpin .9s linear infinite;
}
@keyframes pullSpin { to { transform: rotate(360deg); } }
.pull-indicator__label { white-space: nowrap; }

/* ── Toast ────────────────────────────────────────────────────────────── */
.toaster {
  position: fixed;
  left: 0; right: 0;
  bottom: calc(20px + var(--safe-bottom));
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; pointer-events: none;
  z-index: 95;
}
.toast {
  pointer-events: auto;
  max-width: calc(100% - 32px);
  background: var(--bg-elev);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: var(--text-sm); font-weight: 500;
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
  animation: toastIn .25s cubic-bezier(.2,.8,.2,1);
  display: flex; align-items: center; gap: 10px;
}
.toast--ok    { border-color: var(--st-paid-bd);   color: var(--st-paid-fg); }
.toast--err   { border-color: var(--st-cancel-bd); color: var(--st-cancel-fg); }
.toast--info  { border-color: var(--st-ship-bd);   color: var(--st-ship-fg); }
.toast.is-leaving { animation: toastOut .2s ease forwards; }
@keyframes toastIn  { from { transform: translateY(20px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }
@keyframes toastOut { from { transform: translateY(0);    opacity: 1 } to { transform: translateY(20px); opacity: 0 } }

/* ── Footer (view switcher) ──────────────────────────────────────────── */
.viewswitch {
  text-align: center; padding: 22px 16px 28px; margin-top: 12px;
  color: var(--fg-3); font-size: var(--text-sm);
}
.viewswitch a {
  color: var(--accent); font-weight: 600;
}

/* ── Login overlay ────────────────────────────────────────────────────── */
.login {
  position: fixed; inset: 0;
  background: var(--bg);
  display: none; align-items: center; justify-content: center;
  padding: 20px; z-index: 200;
}
.login.is-open { display: flex; }
.login__card {
  width: 100%; max-width: 380px;
  background: var(--bg-elev); border: 1px solid var(--border-soft);
  border-radius: 18px; padding: 28px 22px;
  box-shadow: var(--shadow);
}
.login__logo { display: block; width: 64px; height: 64px; border-radius: 14px; margin: 0 auto 14px; box-shadow: var(--shadow); }
.login__title { text-align: center; font-size: var(--text-xl); font-weight: 700; }
.login__sub   { text-align: center; color: var(--fg-3); font-size: var(--text-sm); margin: 4px 0 18px; }
.login input {
  width: 100%; padding: 14px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 12px; color: var(--fg);
  font-size: 16px; margin-bottom: 10px;
}
.login button.btn--primary { width: 100%; margin-top: 4px; }
.login__err { color: var(--danger); font-size: var(--text-sm); min-height: 1.4em; margin-top: 10px; text-align: center; }

/* ── Card detail overlay ─────────────────────────────────────────────── */
.line__photo { cursor: zoom-in; }
.line__photo img { transition: transform .15s ease; }
.line__photo:active img { transform: scale(.97); }

.carddet {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.85);
  display: flex; align-items: flex-start; justify-content: center;
  overflow-y: auto;
  padding: calc(var(--safe-top) + 12px) 12px calc(var(--safe-bottom) + 24px);
  z-index: 150;
  -webkit-overflow-scrolling: touch;
}
.carddet[hidden] { display: none; }
.carddet__inner {
  width: 100%; max-width: 460px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.carddet__close {
  position: fixed;
  top: calc(var(--safe-top) + 8px); right: 12px;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(20,22,31,.85);
  color: var(--fg);
  border: 1px solid var(--border);
  font-size: 18px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  z-index: 1;
  backdrop-filter: blur(6px);
}
.carddet__close:active { background: var(--bg-elev-2); }

.carddet__photo {
  background: #000;
  border-radius: 12px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 5 / 7;
  max-height: 70vh;
}
.carddet__photo img {
  width: 100%; height: 100%; object-fit: contain; display: block;
}

.carddet__set {
  display: flex; align-items: center; gap: 10px;
  margin-top: 14px;
}
.carddet__set-icon {
  width: 36px; height: 36px;
  background: var(--bg-elev-2);
  border-radius: 8px;
  padding: 5px;
  object-fit: contain;
  flex: 0 0 auto;
}
.carddet__set-icon[src=""] { visibility: hidden; }
.carddet__set-name {
  font-size: var(--text-md); font-weight: 600; color: var(--fg);
}

.carddet__title {
  font-size: var(--text-lg); font-weight: 700;
  margin: 10px 0 4px;
  color: var(--fg);
}

.carddet__meta {
  display: grid; grid-template-columns: max-content 1fr;
  gap: 6px 14px;
  margin: 12px 0 16px;
  font-size: var(--text-sm);
}
.carddet__meta dt { color: var(--fg-3); }
.carddet__meta dd { color: var(--fg); font-weight: 500; }

.carddet__lots-hdr {
  font-size: var(--text-xs);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: .4px;
  border-top: 1px solid var(--border-soft);
  padding-top: 12px;
  margin-bottom: 6px;
}
.carddet__lots { display: flex; flex-direction: column; gap: 6px; }
.cd-lot {
  display: flex; gap: 10px;
  font-size: var(--text-sm);
  padding: 6px 0;
}
.cd-lot__id { font-family: var(--font-mono); color: var(--fg-2); flex: 0 0 auto; }
.cd-lot__name { color: var(--fg); }
.cd-lot__qty { margin-left: auto; color: var(--fg-3); }

/* ── Misc ─────────────────────────────────────────────────────────────── */
.muted { color: var(--fg-3); }
.small { font-size: var(--text-xs); }
.mono  { font-family: var(--font-mono); }

/* hide focus rings except for keyboard users */
:focus { outline: none; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 8px; }


/* ═════════════════════════════════════════════════════════════════════════
   INVENTORY (PR2 of mobile inventory series)
   ═════════════════════════════════════════════════════════════════════════ */

/* ── App-bar back arrow + restructured head ────────────────────────────── */
.appbar__back {
  width: 36px; height: 36px; margin-right: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; line-height: 1; color: var(--fg-2);
  border-radius: 8px;
}
.appbar__back:active { background: var(--bg-elev-2); color: var(--fg); }
.appbar__head { display: flex; flex-direction: column; min-width: 0; }

/* ── Multi-view containers ─────────────────────────────────────────────── */
.view[hidden] { display: none; }

/* ── KPI strip — 3-up variant for inventory ────────────────────────────── */
.kpis--3 { grid-template-columns: repeat(3, 1fr); }

/* ── Set grid ──────────────────────────────────────────────────────────── */
.setgrid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  margin-top: 6px;
}
@media (min-width: 600px) { .setgrid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 900px) { .setgrid { grid-template-columns: repeat(6, 1fr); } }

.settile {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 14px 6px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  text-decoration: none; color: inherit;
  box-shadow: var(--shadow);
  transition: transform .12s ease;
}
.settile:active { transform: scale(.97); background: var(--bg-elev-2); }
.settile__icon {
  width: 48px; height: 48px; object-fit: contain;
  margin-bottom: 8px;
  /* Scryfall set SVGs are dark-on-transparent — invert for the dark theme */
  filter: invert(1) brightness(.95);
}
@media (prefers-color-scheme: light) { .settile__icon { filter: none; } }
.settile__icon--missing {
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev-2); border-radius: 8px;
  font-family: var(--font-mono); font-size: 13px; font-weight: 700;
  color: var(--fg-2); filter: none;
}
.settile__code {
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 700;
  letter-spacing: .4px; color: var(--fg);
}
.settile__count {
  font-size: 11px; color: var(--fg-3); margin-top: 2px;
  font-variant-numeric: tabular-nums;
}

/* ── Card list rows ────────────────────────────────────────────────────── */
.cardlist { display: flex; flex-direction: column; gap: 6px; }

.cardrow {
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.cardrow.is-open { border-color: var(--border); }

.cardrow__hdr {
  display: grid;
  grid-template-columns: 56px 1fr auto 16px;
  gap: 10px; align-items: center;
  width: 100%; padding: 8px 10px;
  text-align: left; background: transparent; color: inherit;
  border: 0; cursor: pointer;
}
.cardrow__hdr:active { background: var(--bg-elev-2); }
.cardrow__photo {
  width: 56px; height: 78px;
  background: var(--bg-elev-2);
  border-radius: 4px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3); font-size: 11px;
}
.cardrow__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cardrow__main { display: flex; flex-direction: column; min-width: 0; gap: 2px; }
.cardrow__name {
  font-size: var(--text-md); font-weight: 600; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cardrow__sub {
  font-size: var(--text-sm); color: var(--fg-3);
}
.cardrow__sub.small { font-size: var(--text-xs); }
.cardrow__qty {
  font-size: var(--text-lg); font-weight: 700;
  font-variant-numeric: tabular-nums; color: var(--fg);
}
.cardrow__chev {
  font-size: 18px; color: var(--fg-3);
  transition: transform .18s ease;
}
.cardrow.is-open .cardrow__chev { transform: rotate(90deg); color: var(--fg-2); }

.cardrow__variant {
  display: inline-block; margin-left: 4px;
  background: var(--bg-elev-2); color: var(--fg-2);
  font-size: 10px; padding: 1px 5px; border-radius: 4px; font-weight: 600;
  vertical-align: 1px;
}
.cardrow__finish {
  display: inline-block; margin-left: 4px;
  font-size: 10px; padding: 1px 5px; border-radius: 4px; font-weight: 700;
  vertical-align: 1px;
}
.cardrow__finish--foil   { background: #2a1f3d; color: #c9a9ff; }
.cardrow__finish--etched { background: #2e2614; color: #d9b25c; }
@media (prefers-color-scheme: light) {
  .cardrow__finish--foil   { background: #ede5fb; color: #6b3eb8; }
  .cardrow__finish--etched { background: #f5ecd0; color: #7a5d18; }
}

.cardrow__body {
  padding: 8px 14px 12px;
  border-top: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--bg) 50%, var(--bg-elev) 50%);
}
.cardrow__lots-hdr {
  font-size: 10px; text-transform: uppercase; letter-spacing: .6px;
  color: var(--fg-3); margin-bottom: 6px;
}
.cardrow__lot {
  display: grid; grid-template-columns: 50px 1fr auto auto;
  gap: 8px; padding: 4px 0;
  font-size: var(--text-xs); align-items: center;
}
.cardrow__lot-cond  { font-weight: 700; color: var(--fg-2); }
.cardrow__lot-id    { color: var(--fg-2); }
.cardrow__lot-status{ color: var(--fg-3); font-variant-caps: small-caps; }
.cardrow__lot-qty   { font-variant-numeric: tabular-nums; font-weight: 600; color: var(--fg); }
.cardrow__actions { display: flex; gap: 8px; margin-top: 10px; }

/* ── Skeletons (new variants) ──────────────────────────────────────────── */
.skeleton--row  { height: 78px; margin-bottom: 6px; }
.skeleton--tile { aspect-ratio: 1 / 1; }

/* ── Bottom navigation ─────────────────────────────────────────────────── */
.bottomnav {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  height: calc(var(--bottomnav-h) + var(--safe-bottom));
  padding-bottom: var(--safe-bottom);
  background: color-mix(in srgb, var(--bg-elev) 92%, transparent);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-top: 1px solid var(--border-soft);
  display: flex; align-items: stretch;
  z-index: 60;
}
.bottomnav__tab {
  flex: 1;
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; padding: 4px;
  color: var(--fg-3); background: transparent; border: 0;
  font-size: 11px; font-weight: 600;
}
.bottomnav__tab.is-active { color: var(--accent); }
.bottomnav__tab:active { background: var(--bg-elev-2); }
.bottomnav__icon { font-size: 22px; line-height: 1; }
.bottomnav__label { letter-spacing: .2px; }

/* ── Sort action sheet ─────────────────────────────────────────────────── */
.actionsheet {
  position: fixed; left: 0; right: 0; bottom: 0;
  background: var(--bg-elev); color: var(--fg);
  border-radius: 18px 18px 0 0;
  transform: translateY(100%);
  transition: transform .24s cubic-bezier(.2,.8,.2,1);
  z-index: 91;
  max-height: 80vh; overflow-y: auto;
  padding-bottom: calc(16px + var(--safe-bottom));
  box-shadow: 0 -8px 30px rgba(0,0,0,.5);
}
.actionsheet.is-open { transform: translateY(0); }
.actionsheet__body { padding: 4px 8px 8px; }
.actionsheet__opt {
  display: block; width: 100%;
  text-align: left; padding: 14px 16px;
  background: transparent; color: var(--fg);
  border: 0; border-radius: 10px;
  font-size: var(--text-md);
}
.actionsheet__opt:active     { background: var(--bg-elev-2); }
.actionsheet__opt.is-active  {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent); font-weight: 600;
}

/* ── Buyer cancel/refund flag + history sheet ─────────────────────────── */
.order__buyer-flag {
  display: inline-flex; align-items: center; gap: 4px;
  margin-left: 6px;
  font-size: var(--text-xs); font-weight: 700;
  color: #d45f7a;
  background: transparent; border: 0; padding: 2px 4px; border-radius: 6px;
}
.order__buyer-flag:active { background: color-mix(in srgb, #d45f7a 18%, transparent); }
.order__buyer-flag--repeat { color: #5fd49a; }
.order__buyer-flag--repeat:active { background: color-mix(in srgb, #5fd49a 18%, transparent); }
.bh-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px 12px;
  padding: 12px 4px;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.bh-row:last-child { border-bottom: 0; }
.bh-row__id {
  font-family: monospace; color: var(--accent); text-decoration: none;
  font-size: var(--text-sm); word-break: break-all;
}
.bh-row__total { font-weight: 600; font-size: var(--text-sm); }
.bh-row__meta {
  grid-column: 1 / -1;
  display: flex; gap: 8px; align-items: center;
  color: var(--fg-3); font-size: var(--text-xs);
}
.bh-row__items {
  grid-column: 1 / -1;
  color: var(--fg-3); font-size: var(--text-xs); line-height: 1.3;
}
.bh-empty { color: var(--fg-3); font-size: var(--text-sm); padding: 16px 4px; }
.alt-match {
  display: inline-block; padding: 1px 8px; border-radius: 8px;
  background: var(--bg-elev-2); color: var(--fg-2); font-size: var(--text-xs);
  border: 1px solid var(--border);
}

/* ── Search overlay ────────────────────────────────────────────────────── */
.search-overlay {
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 100;
  display: flex; flex-direction: column;
  padding-top: var(--safe-top);
}
.search-overlay[hidden] { display: none; }
.search-overlay__bar {
  display: flex; align-items: center; gap: 4px;
  padding: 8px 8px 6px;
  border-bottom: 1px solid var(--border-soft);
}
.search-overlay__back {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; color: var(--fg-2);
  background: transparent; border: 0; border-radius: 10px;
}
.search-overlay__back:active { background: var(--bg-elev-2); color: var(--fg); }
.search-overlay__input {
  flex: 1;
  padding: 10px 14px;
  background: var(--bg-input); border: 1px solid var(--border);
  color: var(--fg); border-radius: 10px;
  font-size: 16px;
}
.search-overlay__clear {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--fg-2);
  background: transparent; border: 0; border-radius: 8px;
}
.search-overlay__clear:active { background: var(--bg-elev-2); color: var(--fg); }
.search-overlay__chips {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0 12px 6px;
}
.search-overlay__chip {
  display: inline-block; padding: 3px 10px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  border-radius: var(--radius-pill);
  font-size: var(--text-xs); font-weight: 600;
}
.search-overlay__results {
  flex: 1; overflow-y: auto; padding: 4px 12px 16px;
}

.search-result {
  display: grid; grid-template-columns: 44px 1fr; gap: 10px;
  align-items: center;
  padding: 8px;
  border-radius: 10px;
  text-decoration: none; color: inherit;
}
.search-result:active { background: var(--bg-elev-2); }
.search-result__photo {
  width: 44px; height: 62px;
  border-radius: 4px; overflow: hidden;
  background: var(--bg-elev-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3); font-size: 11px;
}
.search-result__photo img { width: 100%; height: 100%; object-fit: cover; }
.search-result__main { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.search-result__name {
  font-weight: 600; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.search-result__sub { color: var(--fg-3); }

/* ── Small-button variant for in-row actions ───────────────────────────── */
.btn--small {
  padding: 8px 14px; font-size: var(--text-sm); border-radius: 8px;
}

/* ── Multi-image carousel (PR4) ────────────────────────────────────────── */
/* Lives in the expanded card/sealed body. Renders nothing when product
   has ≤1 image (invisible div). The track is a snap-scroll container —
   native momentum + scroll-snap give us a real carousel feel without a
   JS animation loop. Dot indicators below; tap to seek. */
.cardrow__carousel { margin: 0 0 10px; }
.cardrow__carousel:empty { display: none; }
.carousel { width: 100%; }
.carousel__track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  border-radius: 8px;
}
.carousel__track::-webkit-scrollbar { display: none; }
.carousel__slide {
  flex: 0 0 100%;
  scroll-snap-align: center;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev-2);
}
.carousel__slide img {
  width: 100%; height: auto; max-height: 320px;
  object-fit: contain;
  display: block;
}
.carousel__dots {
  display: flex; justify-content: center; gap: 6px;
  padding: 8px 0 0;
}
.carousel__dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--border);
  transition: background .15s ease, width .15s ease;
  cursor: pointer;
}
.carousel__dot.is-active {
  background: var(--accent);
  width: 18px;
  border-radius: 4px;
}
/* Single-slide variant: no scroll-snap, no swipe affordance — just a
   centered, full-width image so the expanded body always reserves the
   same vertical canvas regardless of face count. */
.carousel--single .carousel__track {
  overflow-x: hidden;
  scroll-snap-type: none;
}

/* ── Listings sub-screen (PR4) ─────────────────────────────────────────── */
.listings-sec {
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  margin: 8px 0;
  overflow: hidden;
}
.listings-sec__hdr {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px;
  font-size: var(--text-sm); font-weight: 700;
  color: var(--fg-2);
  background: var(--bg-elev-2);
}
.listings-sec__hdr--btn {
  width: 100%; background: var(--bg-elev-2); border: 0; cursor: pointer;
  text-align: left;
}
.listings-sec__hdr--btn:active { background: var(--bg-input); }
.listings-sec__chev { font-size: 14px; color: var(--fg-3); }
.listings-sec__body { display: flex; flex-direction: column; }

.listing-row {
  display: grid;
  grid-template-columns: 56px 1fr 16px;
  gap: 10px; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px dashed var(--border-soft);
  text-decoration: none; color: inherit;
}
.listing-row:last-child { border-bottom: 0; }
.listing-row:active { background: var(--bg-elev-2); }
.listing-row__photo {
  width: 56px; height: 56px;
  border-radius: 4px; overflow: hidden;
  background: var(--bg-elev-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3);
}
.listing-row__photo img { width: 100%; height: 100%; object-fit: cover; }
.listing-row__main { display: flex; flex-direction: column; min-width: 0; gap: 2px; }
.listing-row__title {
  font-weight: 600; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.listing-row__sub {
  font-size: var(--text-xs); color: var(--fg-3);
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.listing-row__chev { color: var(--fg-3); font-size: 18px; }

/* ── Cards | Sealed type switcher ──────────────────────────────────────── */
/* Pill-shaped 2-button toggle pinned just below the app bar on inventory
   views. Visually distinct from the bottom nav so users never confuse
   "section" (Orders / Inventory) with "type" (Cards / Sealed). */
.typeswitch {
  position: sticky;
  top: calc(var(--appbar-h) + var(--safe-top));
  z-index: 48;
  display: flex; gap: 4px;
  margin: 8px 12px 0;
  padding: 4px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-pill);
}
.typeswitch[hidden] { display: none; }
.typeswitch__btn {
  flex: 1;
  padding: 8px 14px;
  border: 0; border-radius: var(--radius-pill);
  background: transparent; color: var(--fg-2);
  font-size: var(--text-sm); font-weight: 600;
}
.typeswitch__btn.is-active {
  background: var(--accent); color: #fff;
}

/* ── Sealed sectioned list ─────────────────────────────────────────────── */
.sealed-list { display: flex; flex-direction: column; gap: 12px; }

.sealed-section {
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.sealed-section__hdr {
  display: grid;
  grid-template-columns: 36px 1fr 18px;
  gap: 10px; align-items: center;
  width: 100%; padding: 10px 14px;
  background: transparent; border: 0; color: inherit;
  text-align: left; cursor: pointer;
}
.sealed-section__hdr:active { background: var(--bg-elev-2); }
.sealed-section__icon {
  width: 32px; height: 32px; object-fit: contain;
  filter: invert(1) brightness(.95);
}
@media (prefers-color-scheme: light) { .sealed-section__icon { filter: none; } }
.sealed-section__icon--missing {
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev-2); border-radius: 6px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  color: var(--fg-2); filter: none;
}
.sealed-section__title {
  display: flex; flex-direction: column; min-width: 0; gap: 2px;
}
.sealed-section__name {
  font-weight: 700; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sealed-section__sub {
  font-size: var(--text-xs); color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.sealed-section__chev {
  font-size: 14px; color: var(--fg-3);
  text-align: right; line-height: 1;
}
.sealed-section.is-collapsed .sealed-section__body { display: none; }
.sealed-section__body {
  border-top: 1px solid var(--border-soft);
  padding: 4px 6px 6px;
  display: flex; flex-direction: column; gap: 4px;
}
/* Inside a section, cardrows shed their own border so the section card
   reads as the visual frame. */
.sealed-section__body .cardrow {
  border: 0; border-radius: 8px;
  background: transparent;
}
.sealed-section__body .cardrow:hover,
.sealed-section__body .cardrow.is-open {
  background: var(--bg-elev-2);
}

/* ── Intake (M-2 → M-2.3) ─────────────────────────────────────────────────
   /m/intake landing + /m/intake/scan scanner-style capture.

   Layout, top to bottom (natural document flow — no grid math, no
   position:fixed):
     • appbar (chrome) — gains a "Send N→" pill on the right while on
       this view + captures > 0
     • chip row (lot · cond · finish), tap to expand to the full form
     • two big CTAs: 📷 Take photo (native iOS Camera via
       <input capture="environment">) + 🖼 Choose from gallery
     • thumb strip showing accumulated captures
     • M-3.6 removed the live <video> preview; WebKit on iOS produces
       a stream that's documented to be dimmer than the native Camera
       app, and no web-side knob (CSS filter, canvas tone-map,
       exposureCompensation, ISO, torch) lifts it enough to be usable.
       Bottom nav is now visible — no more "camera dominates the
       screen" rationale since there is no camera in-app. */

.intake-home {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}
.intake-card {
  display: block;
  padding: 18px 16px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  text-decoration: none;
  color: var(--fg);
  box-shadow: var(--shadow);
}
.intake-card:active { background: var(--bg-elev-2); }
.intake-card__icon { font-size: 28px; margin-bottom: 6px; }
.intake-card__title { font-size: var(--text-xl); font-weight: 700; }
.intake-card__sub   { color: var(--fg-3); font-size: var(--text-sm); margin-top: 4px; }

.view--scan {
  padding: 0;
  margin: 0;
  background: #000;
}

/* Chip summary (collapsed default) */
.scan-meta-row {
  display: flex; align-items: center; gap: 6px;
  width: 100%;
  padding: 6px 12px;
  background: var(--bg-elev);
  border: 0; border-bottom: 1px solid var(--border-soft);
  text-align: left;
  color: var(--fg);
  font: inherit;
  cursor: pointer;
  min-height: 36px;
}
.scan-meta-row__edit {
  margin-left: auto;
  color: var(--accent);
  font-size: var(--text-sm); font-weight: 600;
}
.chip {
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  font-size: 12px; font-weight: 600;
  color: var(--fg);
  white-space: nowrap;
}
.chip--muted { color: var(--fg-3); background: transparent; }

/* Expanded form (shown via [data-meta-open=true]) */
.scan-meta {
  display: none;
  gap: 8px;
  padding: 10px 12px;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--border-soft);
}
.view--scan[data-meta-open="true"] .scan-meta { display: grid; }
.view--scan[data-meta-open="true"] .scan-meta-row { display: none; }

.scan-meta__lbl {
  font-size: 11px; font-weight: 600; color: var(--fg-3);
  text-transform: uppercase; letter-spacing: .4px;
}
.scan-meta__select,
.scan-meta__inline select {
  width: 100%; padding: 10px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 10px; color: var(--fg);
  font-size: 16px;
}
.scan-meta__row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.scan-meta__inline { display: grid; gap: 4px; }
.scan-meta__inline span {
  font-size: 11px; font-weight: 600; color: var(--fg-3);
  text-transform: uppercase; letter-spacing: .4px;
}
.scan-meta__cta { display: grid; gap: 8px; margin-top: 4px; }
.scan-meta__cta .btn { width: 100%; padding: 12px; font-size: 15px; }

/* M-3.6 pick CTAs — replaces the in-app camera viewport. Two big tap
   targets that route to the iOS system camera (capture=environment)
   or the photo library (multiple). */
.scan-pick {
  display: grid; gap: 10px;
  padding: 14px 12px 8px;
}
.scan-pick__btn {
  display: grid; gap: 2px; justify-items: center; align-items: center;
  padding: 16px 14px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  color: var(--fg);
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(255,255,255,.04);
  text-align: center;
  font: inherit; font-weight: 700; font-size: var(--text-base);
  min-height: 80px;
}
.scan-pick__btn:active { background: var(--bg-elev-2); }
.scan-pick__btn--primary {
  background: var(--accent); color: #fff; border-color: var(--accent);
}
.scan-pick__btn--primary:active { background: var(--accent-pressed); }
.scan-pick__icon { font-size: 22px; margin-bottom: 4px; }
.scan-pick__sub {
  font-weight: 500; font-size: var(--text-sm);
  opacity: .8;
}

/* Thumb strip (hidden when empty) — accumulates photos as the user
   takes / picks them. Tap-to-remove via × on each tile. */
.scan-thumbs {
  display: flex; gap: 8px;
  overflow-x: auto;
  padding: 10px 12px;
  -webkit-overflow-scrolling: touch;
}
.scan-thumbs:empty { display: none; }
.scan-thumb {
  position: relative;
  flex: 0 0 auto;
  width: 56px; aspect-ratio: 5 / 7;
  border-radius: 6px; overflow: hidden;
  background: #0f1120;
  border: 1px solid var(--border);
}
.scan-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.scan-thumb__rm {
  position: absolute; top: 2px; right: 2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(0,0,0,.7); color: #fff;
  border: 0; font-size: 12px; line-height: 16px; padding: 0;
}

.scan-err {
  margin: 6px 12px;
  padding: 8px 10px; border-radius: 10px;
  background: rgba(255,107,122,.16);
  border: 1px solid var(--danger, #ff8898);
  color: var(--danger, #ff8898);
  font-size: var(--text-sm);
}

/* ── Intake review (M-3) ───────────────────────────────────────────────────
   /m/intake/scan/review/<job_id>. List rows by default; tap a row to open
   the full-screen carousel detail (.review-detail) that lets the operator
   edit finish / condition / quantity per card before bulk-graduating. */

.view--review { padding: 0 12px 16px; }

.review-banner {
  margin: 10px 0 12px;
  padding: 12px 14px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
}
.review-banner__title {
  font-size: var(--text-base); font-weight: 700; color: var(--fg);
}
.review-banner__sub {
  font-size: var(--text-sm); color: var(--fg-3); margin-top: 2px;
}
.review-banner__bar {
  margin-top: 10px; height: 6px;
  background: var(--bg-input);
  border-radius: 999px; overflow: hidden;
}
.review-banner__fill {
  height: 100%; width: 0%;
  background: var(--accent);
  transition: width .25s ease-out;
}
.review-banner--done .review-banner__bar { display: none; }

.review-list {
  display: flex; flex-direction: column; gap: 6px;
}
.review-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.review-row:active { background: var(--bg-elev-2); }
.review-row__thumb {
  flex: 0 0 auto;
  width: 44px; aspect-ratio: 5 / 7;
  background: #0f1120;
  border-radius: 5px; overflow: hidden;
  border: 1px solid var(--border);
}
.review-row__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.review-row__body { flex: 1; min-width: 0; }
.review-row__name {
  font-size: var(--text-base); font-weight: 600; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.review-row__meta {
  font-size: var(--text-xs); color: var(--fg-3); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.review-row__pill {
  flex: 0 0 auto;
  padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 700;
  white-space: nowrap;
}
.review-row__pill--matched   { background: rgba(74,222,128,.15); color: #4ade80;   border: 1px solid rgba(74,222,128,.35); }
.review-row__pill--review    { background: rgba(244,184,96,.15); color: #f4b860;   border: 1px solid rgba(244,184,96,.35); }
.review-row__pill--verify    { background: rgba(94,139,255,.15); color: #5e8bff;   border: 1px solid rgba(94,139,255,.35); }
.review-row__pill--unresolved{ background: rgba(255,107,122,.18); color: #ff8898;  border: 1px solid rgba(255,107,122,.45); }

.review-err {
  margin-top: 12px;
  padding: 10px 12px; border-radius: 10px;
  background: rgba(255,107,122,.16);
  border: 1px solid var(--danger, #ff8898);
  color: var(--danger, #ff8898);
  font-size: var(--text-sm);
}

/* Full-screen carousel detail overlay */
.review-detail {
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 80;
  display: flex; flex-direction: column;
  padding-top: var(--safe-top);
  padding-bottom: var(--safe-bottom);
}
.review-detail[hidden] { display: none; }
.review-detail__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-soft);
}
.review-detail__close {
  width: 36px; height: 36px; border-radius: 10px;
  background: transparent; border: 0;
  color: var(--fg); font-size: 22px;
}
.review-detail__close:active { background: var(--bg-elev-2); }
.review-detail__title { font-weight: 600; color: var(--fg); }

.review-detail__photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 10px 12px;
}
.review-photo {
  position: relative;
  background: #0a0c14;
  border-radius: 10px; overflow: hidden;
  aspect-ratio: 5 / 7;
}
.review-photo__lbl {
  position: absolute; top: 4px; left: 6px;
  font-size: 10px; font-weight: 700;
  color: rgba(255,255,255,.9);
  background: rgba(0,0,0,.55);
  padding: 1px 6px; border-radius: 4px;
  z-index: 2;
}
.review-photo__img { width: 100%; height: 100%; object-fit: contain; background: #0a0c14; display: block; }
.review-photo__missing {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3); font-size: var(--text-sm); padding: 8px; text-align: center;
}

.review-detail__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 4px 12px 12px;
}
.review-detail__name {
  font-size: var(--text-lg); font-weight: 700; color: var(--fg);
}
.review-detail__meta {
  font-size: var(--text-sm); color: var(--fg-3); margin-bottom: 14px;
}
.review-detail__lbl {
  display: block;
  font-size: 11px; font-weight: 600; color: var(--fg-3);
  text-transform: uppercase; letter-spacing: .4px;
  margin: 12px 0 6px;
}

/* Segmented control */
.seg {
  display: flex; gap: 4px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
}
.seg__btn {
  flex: 1 1 0; min-width: 0;
  padding: 8px 6px;
  background: transparent; border: 0;
  font: inherit; font-weight: 600; font-size: 13px;
  color: var(--fg-3);
  border-radius: 8px;
  cursor: pointer;
}
.seg__btn[aria-pressed="true"],
.seg__btn.is-active {
  background: var(--bg-elev-2);
  color: var(--fg);
}

/* Override match search (M-3.1) — collapsible <details> inside the carousel */
.review-override {
  margin: 8px 0 6px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 10px;
}
.review-override__summary {
  list-style: none;
  cursor: pointer;
  padding: 10px 12px;
  font-size: var(--text-sm); font-weight: 600;
  color: var(--accent);
  -webkit-tap-highlight-color: transparent;
}
.review-override__summary::-webkit-details-marker { display: none; }
.review-override__summary::after {
  content: '▾'; float: right; color: var(--fg-3); font-weight: 700;
  transition: transform .12s;
}
.review-override[open] .review-override__summary::after { transform: rotate(180deg); }
.review-override__body {
  padding: 0 12px 10px;
}
.review-override__input {
  width: 100%;
  padding: 9px 10px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 8px; color: var(--fg);
  font-size: 16px;  /* prevents iOS zoom on focus */
}
.review-override__results {
  margin-top: 8px;
  display: flex; flex-direction: column;
  gap: 4px;
  max-height: 280px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.review-override__hint,
.review-override__empty {
  padding: 8px 4px;
  color: var(--fg-3); font-size: var(--text-sm);
  text-align: center;
}
.review-override__result {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  text-align: left;
  font: inherit; color: var(--fg);
  cursor: pointer;
}
.review-override__result:active { background: var(--bg-elev-2); border-color: var(--border-soft); }
.review-override__result-thumb {
  flex: 0 0 auto;
  width: 32px; aspect-ratio: 5 / 7;
  background: #0f1120;
  border-radius: 4px; overflow: hidden;
  border: 1px solid var(--border);
}
.review-override__result-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.review-override__result-body { flex: 1; min-width: 0; }
.review-override__result-name {
  font-size: var(--text-sm); font-weight: 600; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.review-override__result-meta {
  font-size: var(--text-xs); color: var(--fg-3); margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Stepper */
.stepper {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
}
.stepper__btn {
  width: 36px; height: 36px; border-radius: 8px;
  background: transparent; border: 0;
  color: var(--fg); font-size: 20px;
}
.stepper__btn:active { background: var(--bg-elev-2); }
.stepper__val {
  min-width: 36px; text-align: center;
  font-weight: 700; color: var(--fg);
}

.review-detail__nav {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  padding: 8px 12px calc(8px + var(--safe-bottom));
  border-top: 1px solid var(--border-soft);
}
.review-detail__nav .btn { width: 100%; padding: 12px; }
