:root {
  /* OmniPost palette — sampled from the product login page. */
  --bg: #f3f1ee;
  --bg-soft: #ebe8e3;
  --card: #ffffff;
  --ink: #1f2937;
  --ink-soft: #374151;
  --muted: #6b7280;
  --muted-soft: #9ca3af;
  --border: #e3dfd8;
  --border-soft: #efece6;

  --accent: #c4421f;
  --accent-hi: #b13818;
  --accent-soft: #fde6dd;

  --link: #0f3bc9;
  --link-hi: #1f4dd6;

  --ok: #16a34a;
  --warn: #d97706;
  --bad: #dc2626;

  --shadow-sm: 0 1px 2px rgba(17, 24, 39, .04), 0 1px 3px rgba(17, 24, 39, .03);
  --shadow-md: 0 6px 18px rgba(17, 24, 39, .08), 0 2px 6px rgba(17, 24, 39, .04);
  --shadow-fab: 0 8px 24px rgba(196, 66, 31, .35), 0 2px 4px rgba(196, 66, 31, .2);

  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 18px;
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}
body {
  min-height: 100dvh;
  padding-bottom: calc(env(safe-area-inset-bottom) + 96px); /* room for FAB */
}

/* ---------- Header ---------- */
.app-header {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px 12px;
  background: linear-gradient(180deg, #ffffff 0%, rgba(255, 255, 255, .92) 100%);
  border-bottom: 1px solid var(--border);
  backdrop-filter: saturate(180%) blur(8px);
  -webkit-backdrop-filter: saturate(180%) blur(8px);
}
.brand { display: flex; align-items: center; gap: 12px; min-width: 0; }
.brand-logo {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--accent);
  color: #ffffff;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: -.5px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(196, 66, 31, .25);
  flex-shrink: 0;
}
.brand-text { line-height: 1.15; min-width: 0; }
.brand-text h1 {
  margin: 0;
  font-size: 17px;
  font-weight: 400;
  color: #6b7077;
  letter-spacing: .15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brand-text h1 strong { color: var(--ink); font-weight: 600; }
.brand-text .tag {
  margin: 2px 0 0;
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.2px;
}
.counter {
  text-align: right;
  line-height: 1;
  flex-shrink: 0;
}
.counter-num {
  display: block;
  font-size: 22px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -.5px;
  font-variant-numeric: tabular-nums;
}
.counter-label {
  display: block;
  font-size: 10px;
  margin-top: 2px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.1px;
}

/* ---------- Main ---------- */
main {
  max-width: 720px;
  margin: 0 auto;
  padding: 16px 14px 24px;
}

/* ---------- Empty state ---------- */
.empty-state {
  text-align: center;
  padding: 56px 24px 40px;
  color: var(--muted);
}
.empty-illo {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 96px; height: 96px;
  border-radius: 50%;
  background: var(--bg-soft);
  color: var(--accent);
  margin-bottom: 18px;
  box-shadow: inset 0 0 0 1px var(--border);
}
.empty-state h2 {
  margin: 0 0 6px;
  font-size: 19px;
  font-weight: 600;
  color: var(--ink);
}
.empty-state p {
  margin: 0;
  font-size: 14px;
  color: var(--muted);
}
.empty-state b { color: var(--ink); font-weight: 600; }

/* ---------- Parcel groups ---------- */
.parcel-groups {
  display: grid;
  gap: 16px;
}
.parcel-group {
  background: transparent;
}
.parcel-group-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 0 4px 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}
.parcel-group-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: .1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.parcel-group-name.empty { color: var(--muted-soft); font-style: italic; font-weight: 500; }
.parcel-group-meta {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-shrink: 0;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.1px;
}
.parcel-group-postcode {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-weight: 600;
  color: var(--ink-soft);
  text-transform: none;
  letter-spacing: .2px;
}
.parcel-group-count {
  font-weight: 600;
}

/* ---------- Parcel list ---------- */
.parcel-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.parcel-item {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: 12px;
  align-items: center;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px 10px 10px;
  box-shadow: var(--shadow-sm);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  animation: slideIn .26s cubic-bezier(.2, .8, .2, 1);
}
@keyframes slideIn {
  from { transform: translateY(-6px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.parcel-item:hover {
  border-color: var(--muted-soft);
  box-shadow: var(--shadow-md);
}
.parcel-thumb {
  width: 64px; height: 64px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: #1a1a1a;
  flex-shrink: 0;
}
.parcel-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.parcel-body { min-width: 0; }
.parcel-barcode {
  margin-top: 3px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12.5px;
  color: var(--ink-soft);
  word-break: break-all;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.parcel-barcode.empty { color: var(--muted-soft); font-style: italic; font-family: inherit; }
.parcel-barcode .tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--accent);
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .4px;
  font-family: inherit;
  flex-shrink: 0;
}
.parcel-address {
  margin-top: 4px;
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}
.parcel-address.empty { font-style: italic; color: var(--muted-soft); }
.parcel-meta {
  margin-top: 4px;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: .2px;
}
.parcel-item {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.parcel-item:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(196, 66, 31, .18), var(--shadow-md);
}
.parcel-item:active { transform: translateY(1px); }
.parcel-remove {
  flex-shrink: 0;
  color: var(--muted-soft);
}
.parcel-remove:hover { color: var(--bad); }

/* ---------- Floating Action Button ---------- */
.fab {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom) + 18px);
  right: 18px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 22px;
  background: var(--accent);
  color: #ffffff;
  border: none;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .2px;
  cursor: pointer;
  box-shadow: var(--shadow-fab);
  -webkit-tap-highlight-color: transparent;
  transition: transform .12s ease, background-color .12s ease;
}
.fab:hover { background: var(--accent-hi); }
.fab:active { transform: translateY(1px) scale(.98); }
.fab svg { stroke: currentColor; }

.fab.fab-secondary {
  right: auto;
  left: 18px;
  background: #ffffff;
  color: var(--ink);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  padding: 12px 18px;
  font-size: 14px;
}
.fab.fab-secondary:hover { background: var(--bg-soft); border-color: var(--muted-soft); }
.fab.fab-secondary svg { color: var(--ok); }
.fab .done-count {
  display: inline-flex;
  align-items: center; justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  margin-left: 4px;
  background: var(--accent);
  color: #ffffff;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* ---------- Buttons ---------- */
.btn {
  appearance: none;
  border: 1px solid var(--border);
  background: #ffffff;
  color: var(--ink);
  font-size: 15px; font-weight: 600;
  padding: 11px 14px;
  border-radius: var(--radius-sm);
  cursor: pointer; min-height: 46px;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 6px;
  letter-spacing: .2px;
  -webkit-tap-highlight-color: transparent;
  transition: background-color .12s ease, border-color .12s ease, color .12s ease, transform .08s ease;
}
.btn:active { transform: translateY(1px); }
.btn.ghost { background: #ffffff; color: var(--ink-soft); }
.btn.ghost:hover { background: var(--bg-soft); border-color: var(--muted-soft); }
.btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
  box-shadow: 0 1px 2px rgba(196, 66, 31, .18);
}
.btn.primary:hover { background: var(--accent-hi); border-color: var(--accent-hi); }
.btn[disabled] { opacity: .55; cursor: not-allowed; }

.btn.capture {
  flex: 1;
  position: relative;
  padding-left: 44px;
}
.btn.capture .capture-ring {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .15);
  box-shadow: inset 0 0 0 2px #ffffff;
}

.icon-btn {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--ink);
  width: 38px; height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  cursor: pointer;
  transition: background-color .12s ease, color .12s ease;
}
.icon-btn:hover { background: var(--bg-soft); }

/* ---------- Dialog ---------- */
.scan-dialog {
  border: none;
  padding: 0;
  background: var(--card);
  color: var(--ink);
  width: min(560px, 100vw);
  max-width: 100vw;
  max-height: 100dvh;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  margin: auto;
}
.scan-dialog::backdrop {
  background: rgba(17, 24, 39, .55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.scan-dialog[open] {
  animation: dialogIn .22s cubic-bezier(.2, .8, .2, 1);
}
@keyframes dialogIn {
  from { transform: translateY(20px) scale(.98); opacity: 0; }
  to   { transform: translateY(0)    scale(1);   opacity: 1; }
}
@media (max-width: 560px) {
  .scan-dialog {
    width: 100vw;
    height: 100dvh;
    max-height: 100dvh;
    border-radius: 0;
  }
}

.dialog-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 100dvh;
}
.dialog-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 12px 12px 18px;
  border-bottom: 1px solid var(--border-soft);
  flex-shrink: 0;
}
.dialog-head h2 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.stage {
  display: none;
  flex: 1;
  flex-direction: column;
  padding: 14px;
  gap: 12px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.stage.active {
  display: flex;
  animation: stageIn .18s ease-out;
}
@keyframes stageIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Camera stage ---------- */
.video-wrap {
  position: relative;
  aspect-ratio: 3 / 4;
  background: #1a1a1a;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
}
@media (min-width: 560px) {
  .video-wrap { aspect-ratio: 4 / 3; }
}
video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.reticle {
  position: absolute;
  inset: 8%;
  border: 2px dashed rgba(255, 255, 255, .55);
  border-radius: var(--radius);
  pointer-events: none;
}
.cam-status {
  position: absolute;
  inset: auto 0 0 0;
  margin: 0;
  padding: 10px 12px;
  text-align: center;
  background: rgba(0, 0, 0, .55);
  color: #ffffff;
  font-size: 13px;
}
.cam-status:empty { display: none; }
.hint {
  margin: 0;
  text-align: center;
  font-size: 13px;
  color: var(--muted);
}
.controls {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

/* ---------- Photo wrap (shared: result + processing) ---------- */
.photo-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  background: #1a1a1a;
  border: 1px solid var(--border);
  aspect-ratio: 4 / 3;
}
.photo-wrap img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  background: #1a1a1a;
}

/* ---------- Processing / "Reading label" stage ---------- */
.scan-frame {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(circle at 30% 20%, #2b2b30, #0d0d10 70%);
  border: 1px solid #232327;
  box-shadow:
    0 0 0 1px rgba(196, 66, 31, .35),
    0 12px 40px rgba(0, 0, 0, .45),
    inset 0 0 60px rgba(196, 66, 31, .12);
}
.scan-frame img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  filter: brightness(.78) contrast(1.05) saturate(.9);
  animation: scanPulse 2.6s ease-in-out infinite;
}
@keyframes scanPulse {
  0%, 100% { filter: brightness(.74) contrast(1.05) saturate(.9); }
  50%      { filter: brightness(.92) contrast(1.05) saturate(1); }
}
/* Subtle technical grid that hints at "AI vision" */
.scan-grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(196, 66, 31, .12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(196, 66, 31, .12) 1px, transparent 1px);
  background-size: 28px 28px;
  mix-blend-mode: screen;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 85%);
  opacity: .55;
}
/* The horizontal scan beam sweeping the frame */
.scan-beam {
  position: absolute;
  left: -10%;
  right: -10%;
  height: 14%;
  top: 0;
  background:
    linear-gradient(180deg,
      transparent 0%,
      rgba(255, 220, 200, .15) 25%,
      rgba(255, 130, 70, .85) 50%,
      rgba(255, 220, 200, .15) 75%,
      transparent 100%);
  filter: blur(1px);
  box-shadow:
    0 0 24px 6px rgba(255, 110, 50, .55),
    0 0 64px 18px rgba(196, 66, 31, .35);
  animation: scanBeamSweep 2.2s cubic-bezier(.65, .05, .35, 1) infinite;
  pointer-events: none;
}
@keyframes scanBeamSweep {
  0%   { top: -14%; opacity: 0; }
  10%  { opacity: 1; }
  50%  { top: 100%; opacity: 1; }
  60%  { opacity: 0; }
  100% { top: 100%; opacity: 0; }
}
/* Reticle corners that read as "the AI is locked on" */
.scan-corners {
  position: absolute;
  inset: 7%;
  pointer-events: none;
}
.scan-corners span {
  position: absolute;
  width: 22px; height: 22px;
  border: 2px solid rgba(255, 255, 255, .9);
  filter: drop-shadow(0 0 6px rgba(196, 66, 31, .8));
}
.scan-corners span:nth-child(1) { top: 0;    left: 0;    border-right: none; border-bottom: none; border-top-left-radius: 4px; }
.scan-corners span:nth-child(2) { top: 0;    right: 0;   border-left: none;  border-bottom: none; border-top-right-radius: 4px; }
.scan-corners span:nth-child(3) { bottom: 0; left: 0;    border-right: none; border-top: none;    border-bottom-left-radius: 4px; }
.scan-corners span:nth-child(4) { bottom: 0; right: 0;   border-left: none;  border-top: none;    border-bottom-right-radius: 4px; }
.scan-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 50%, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* Status card under the scan frame */
.scan-status {
  margin-top: 4px;
  padding: 14px 16px;
  background: linear-gradient(180deg, var(--card), #fbfaf7);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.scan-status-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.scan-status-head h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: .1px;
}
.scan-status-msg {
  margin: 6px 0 0;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.4;
}
.scan-pulse {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.scan-pulse span {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  opacity: .25;
  animation: scanPulseDot 1.1s ease-in-out infinite;
}
.scan-pulse span:nth-child(2) { animation-delay: .18s; }
.scan-pulse span:nth-child(3) { animation-delay: .36s; }
@keyframes scanPulseDot {
  0%, 80%, 100% { transform: scale(.8); opacity: .25; }
  40%           { transform: scale(1.25); opacity: 1; }
}

.scan-steps {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.scan-steps li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--ink-soft);
  letter-spacing: .1px;
  opacity: .7;
}
.scan-steps li .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--muted-soft);
  position: relative;
  flex-shrink: 0;
}
.scan-steps li:nth-child(1) .dot { animation: stepDot 3s ease-in-out infinite; }
.scan-steps li:nth-child(2) .dot { animation: stepDot 3s ease-in-out infinite 1s; }
.scan-steps li:nth-child(3) .dot { animation: stepDot 3s ease-in-out infinite 2s; }
@keyframes stepDot {
  0%, 30%, 100% { background: var(--muted-soft); box-shadow: none; }
  10%, 20%      { background: var(--accent);
                  box-shadow: 0 0 0 4px rgba(196, 66, 31, .18); }
}

/* The submit-button spinner is shared from here */
.spinner {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 3px solid rgba(255, 255, 255, .25);
  border-top-color: #ffffff;
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---------- Result stage ---------- */
.result-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  background: rgba(255, 255, 255, .92);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.result-badge.ok   { background: var(--ok);   color: #ffffff; }
.result-badge.warn { background: var(--warn); color: #ffffff; }
.result-badge.bad  { background: var(--bad);  color: #ffffff; }

.result-data {
  margin: 0;
  display: grid;
  gap: 1px;
  background: var(--border-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.result-row {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 10px;
  padding: 10px 12px;
  background: var(--card);
  align-items: baseline;
}
.result-row dt {
  margin: 0;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.1px;
  font-weight: 600;
}
.result-row dd {
  margin: 0;
  font-size: 14.5px;
  color: var(--ink);
  word-break: break-word;
}
.result-row dd.primary {
  font-size: 16.5px;
  font-weight: 600;
}
.result-row dd.mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 13.5px;
}
.result-row dd.empty { color: var(--muted-soft); font-style: italic; font-weight: 400; }

.result-error {
  margin: 0;
  padding: 10px 12px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: var(--radius-sm);
  color: var(--bad);
  font-size: 13px;
}

.result-hint {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
  padding: 10px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--ink-soft);
  font-size: 13px;
  line-height: 1.4;
  animation: stageIn .2s ease-out;
}
.result-hint svg {
  flex-shrink: 0;
  color: var(--muted);
  margin-top: 1px;
}
.result-hint b { color: var(--ink); font-weight: 600; }

.result-duplicate {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
  padding: 12px 14px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: var(--radius-sm);
  color: #9a3412;
  font-size: 13px;
  animation: stageIn .2s ease-out;
}
.result-duplicate svg {
  flex-shrink: 0;
  color: var(--warn);
  margin-top: 1px;
}
.result-duplicate-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.35;
}
.result-duplicate-text strong {
  color: #7c2d12;
  font-weight: 700;
  letter-spacing: .1px;
}
.result-duplicate-text span { color: #9a3412; }

/* ---------- Result row tag (shared with parcel list) ---------- */
.result-row dd .tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--accent);
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .4px;
  margin-right: 6px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  vertical-align: 1px;
}

/* ---------- Review dialog ---------- */
.review-summary {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 4px 4px 8px;
  border-bottom: 1px solid var(--border-soft);
}
.review-summary-num {
  font-size: 32px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.review-summary-text {
  font-size: 13px;
  color: var(--muted);
}
.review-summary-text span {
  color: var(--ink);
  font-weight: 600;
}
.review-list {
  display: grid;
  gap: 14px;
  flex: 1;
  min-height: 0;
}
.review-group {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
}
.review-group-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.review-group-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.review-group-name.empty { color: var(--muted-soft); font-style: italic; font-weight: 500; }
.review-group-count {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .8px;
  background: var(--accent);
  color: #ffffff;
  padding: 2px 8px;
  border-radius: 999px;
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.review-group-address {
  margin-top: 4px;
  font-size: 13px;
  color: var(--muted);
  word-break: break-word;
}
.review-group-address.empty { font-style: italic; color: var(--muted-soft); }
.review-group-parcels {
  list-style: none;
  margin: 10px 0 0;
  padding: 8px 0 0;
  border-top: 1px dashed var(--border-soft);
  display: grid;
  gap: 6px;
}
.review-parcel {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-soft);
  word-break: break-all;
}
.review-parcel .tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--accent);
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .4px;
  flex-shrink: 0;
}
.review-parcel .mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12.5px;
}
.review-parcel.empty {
  color: var(--muted-soft);
  font-style: italic;
}
.review-controls { margin-top: 4px; }
.submit-spinner {
  width: 16px; height: 16px;
  border-width: 2px;
}

/* ---------- Success page ---------- */
.stage[data-stage="success"] {
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(ellipse at top, rgba(22, 163, 74, .10), transparent 60%),
    var(--card);
}
.success-card {
  width: 100%;
  max-width: 420px;
  margin: auto;
  text-align: center;
  padding: 8px 4px 16px;
  position: relative;
}
.success-burst {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex;
  justify-content: center;
}
.success-burst span {
  position: absolute;
  top: 70px;
  left: 50%;
  width: 3px;
  height: 28px;
  border-radius: 2px;
  background: linear-gradient(180deg, transparent, var(--ok));
  transform-origin: 50% 0;
  opacity: 0;
  animation: burstRay .9s ease-out .25s forwards;
}
.success-burst span:nth-child(1) { transform: translate(-50%, 0) rotate(0deg)   translateY(-46px); }
.success-burst span:nth-child(2) { transform: translate(-50%, 0) rotate(45deg)  translateY(-46px); }
.success-burst span:nth-child(3) { transform: translate(-50%, 0) rotate(90deg)  translateY(-46px); }
.success-burst span:nth-child(4) { transform: translate(-50%, 0) rotate(135deg) translateY(-46px); }
.success-burst span:nth-child(5) { transform: translate(-50%, 0) rotate(180deg) translateY(-46px); }
.success-burst span:nth-child(6) { transform: translate(-50%, 0) rotate(225deg) translateY(-46px); }
.success-burst span:nth-child(7) { transform: translate(-50%, 0) rotate(270deg) translateY(-46px); }
.success-burst span:nth-child(8) { transform: translate(-50%, 0) rotate(315deg) translateY(-46px); }
@keyframes burstRay {
  0%   { opacity: 0; }
  20%  { opacity: 1; }
  100% { opacity: 0; }
}
.success-burst span:nth-child(1) { animation-name: burstRay1; }
.success-burst span:nth-child(2) { animation-name: burstRay2; }
.success-burst span:nth-child(3) { animation-name: burstRay3; }
.success-burst span:nth-child(4) { animation-name: burstRay4; }
.success-burst span:nth-child(5) { animation-name: burstRay5; }
.success-burst span:nth-child(6) { animation-name: burstRay6; }
.success-burst span:nth-child(7) { animation-name: burstRay7; }
.success-burst span:nth-child(8) { animation-name: burstRay8; }
@keyframes burstRay1 { 0%{opacity:0; transform:translate(-50%,0) rotate(0deg)   translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(0deg)   translateY(-72px);} }
@keyframes burstRay2 { 0%{opacity:0; transform:translate(-50%,0) rotate(45deg)  translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(45deg)  translateY(-72px);} }
@keyframes burstRay3 { 0%{opacity:0; transform:translate(-50%,0) rotate(90deg)  translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(90deg)  translateY(-72px);} }
@keyframes burstRay4 { 0%{opacity:0; transform:translate(-50%,0) rotate(135deg) translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(135deg) translateY(-72px);} }
@keyframes burstRay5 { 0%{opacity:0; transform:translate(-50%,0) rotate(180deg) translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(180deg) translateY(-72px);} }
@keyframes burstRay6 { 0%{opacity:0; transform:translate(-50%,0) rotate(225deg) translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(225deg) translateY(-72px);} }
@keyframes burstRay7 { 0%{opacity:0; transform:translate(-50%,0) rotate(270deg) translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(270deg) translateY(-72px);} }
@keyframes burstRay8 { 0%{opacity:0; transform:translate(-50%,0) rotate(315deg) translateY(-30px);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,0) rotate(315deg) translateY(-72px);} }

.success-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 96px;
  height: 96px;
  margin: 12px auto 16px;
  border-radius: 50%;
  background: rgba(22, 163, 74, .12);
  color: var(--ok);
  position: relative;
  animation: successPop .55s cubic-bezier(.34, 1.56, .64, 1) both;
  box-shadow:
    0 0 0 0 rgba(22, 163, 74, .35),
    0 12px 32px rgba(22, 163, 74, .25);
}
.success-check::after {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  border: 2px solid rgba(22, 163, 74, .35);
  animation: successHalo 1.4s ease-out .15s both;
}
@keyframes successPop {
  0%   { transform: scale(.4); opacity: 0; }
  60%  { transform: scale(1.08); opacity: 1; }
  100% { transform: scale(1);    opacity: 1; }
}
@keyframes successHalo {
  0%   { transform: scale(.6); opacity: .9; }
  100% { transform: scale(1.4); opacity: 0; }
}
.success-check-ring {
  stroke-dasharray: 176;
  stroke-dashoffset: 176;
  animation: drawRing .55s ease-out .2s forwards;
  opacity: .6;
}
.success-check-tick {
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: drawTick .35s ease-out .55s forwards;
}
@keyframes drawRing { to { stroke-dashoffset: 0; } }
@keyframes drawTick { to { stroke-dashoffset: 0; } }

.success-title {
  margin: 0 0 4px;
  font-size: 24px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.3px;
}
.success-sub {
  margin: 0 0 22px;
  font-size: 14px;
  color: var(--muted);
  line-height: 1.4;
}
.success-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin: 0 0 18px;
  background: var(--border-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.success-stats > div {
  background: var(--card);
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.success-stats dt {
  margin: 0;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.1px;
  color: var(--muted);
  font-weight: 600;
}
.success-stats dd {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.4px;
  font-variant-numeric: tabular-nums;
}
.success-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 auto 22px;
  padding: 7px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 12px;
}
.success-meta-label {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.1px;
  font-weight: 600;
  font-size: 10px;
}
.success-meta .mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  color: var(--ink-soft);
  font-size: 12.5px;
  letter-spacing: .3px;
}
.success-cta {
  width: 100%;
  font-size: 15px;
  padding: 14px 18px;
}

/* ---------- Parcel detail dialog ---------- */
.detail-photo {
  position: relative;
  background: #1a1a1a;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.detail-photo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #1a1a1a;
}
.detail-data {
  margin: 0;
  display: grid;
  gap: 1px;
  background: var(--border-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.detail-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 10px;
  padding: 10px 12px;
  background: var(--card);
  align-items: baseline;
}
.detail-row dt {
  margin: 0;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.1px;
  font-weight: 600;
}
.detail-row dd {
  margin: 0;
  font-size: 14.5px;
  color: var(--ink);
  word-break: break-word;
}
.detail-row dd.primary {
  font-size: 17px;
  font-weight: 600;
}
.detail-row dd.mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 13.5px;
  letter-spacing: .2px;
}
.detail-row dd.multi { line-height: 1.4; }
.detail-row dd.multi > div + div { margin-top: 2px; }
.detail-row dd.empty { color: var(--muted-soft); font-style: italic; font-weight: 400; }
.detail-row dd .tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--accent);
  color: #ffffff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .4px;
  margin-right: 6px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  vertical-align: 1px;
}
.detail-controls .btn { flex: 1; }
.btn.ghost.danger { color: var(--bad); border-color: #fecaca; }
.btn.ghost.danger:hover { background: #fef2f2; border-color: #fca5a5; color: var(--bad); }

.hidden { display: none !important; }
