/* ============================================================
   Mabel Inbox — Onboarding (new-account setup flow)
   Self-contained styles for the js/onboarding.js module. Built
   entirely on the Mabel token sheet (css/colors_and_type.css) so
   light/dark both track automatically — never hardcode hex here.
   All classes are `ob-` prefixed to avoid colliding with styles.css.
   ============================================================ */

.ob-wrap { max-width: 640px; margin: 0 auto; padding: var(--space-6) var(--space-4); }

.ob-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-3); }
.ob-brand { display: flex; align-items: center; gap: var(--space-2); }
.ob-brand-name { font-size: var(--text-base); font-weight: 500; }
.ob-step { font-size: var(--text-xs); color: var(--color-text-tertiary); }
.ob-feedback {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  font-size: var(--text-xs); font-weight: var(--text-base-medium-w);
  cursor: pointer; transition: background 120ms, border-color 120ms, color 120ms;
}
.ob-feedback:hover { border-color: var(--color-border-strong); color: var(--color-text-primary); }
.ob-feedback svg { width: 14px; height: 14px; }

.ob-mark {
  width: 26px; height: 26px; border-radius: var(--radius-sm);
  background: var(--color-accent); color: var(--color-accent-ink);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px; flex-shrink: 0;
}
.ob-mark-lg {
  width: 46px; height: 46px; border-radius: var(--radius-md);
  font-size: 22px; margin: 0 auto var(--space-4); position: relative;
}
.ob-mark-lg .ob-dot {
  position: absolute; top: -3px; right: -3px; width: 11px; height: 11px;
  border-radius: var(--radius-full); background: var(--color-coral, #D85A30);
  border: 2px solid var(--color-bg);
}

.ob-scrn {
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-6);
}
.ob-scrn.ob-center { text-align: center; padding: var(--space-12) var(--space-8); }

.ob-h1 { font-size: var(--text-xl); font-weight: 600; margin: 0 0 var(--space-1); }
.ob-h1-lg { font-size: var(--text-2xl); font-weight: 700; }
.ob-sub { font-size: var(--text-sm); color: var(--color-text-secondary); margin: 0 0 var(--space-5); }

.ob-card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-4);
}
.ob-rw { display: flex; align-items: center; gap: var(--space-3); }

.ob-ico {
  width: 34px; height: 34px; border-radius: var(--radius-md);
  background: var(--color-accent-subtle); color: var(--color-accent-strong);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ob-ico svg { width: 18px; height: 18px; }

.ob-btn {
  font-size: var(--text-sm); border-radius: var(--radius-md);
  padding: 9px 18px; cursor: pointer; font-family: var(--font-sans);
  border: 1px solid var(--color-border-strong); background: var(--color-surface);
  color: var(--color-text-secondary);
}
.ob-btn-pr {
  background: var(--color-accent); color: var(--color-accent-ink);
  border-color: var(--color-accent-hover); font-weight: 500;
}
.ob-btn svg { width: 15px; height: 15px; vertical-align: -2px; }

.ob-muted { font-size: var(--text-sm); color: var(--color-text-tertiary); cursor: pointer; user-select: none; }
.ob-lnk { color: var(--color-accent-strong); cursor: pointer; text-decoration: underline; font-size: var(--text-xs); }

.ob-kbd {
  display: inline-block; min-width: 15px; padding: 0 5px;
  border: 1px solid var(--color-border-strong); border-bottom-width: 2px;
  border-radius: var(--radius-sm); background: var(--color-surface);
  font-size: var(--text-xs); color: var(--color-text-secondary); line-height: 1.5; text-align: center;
}

.ob-cnt {
  background: var(--color-accent-subtle); color: var(--color-accent-strong);
  border-radius: var(--radius-full); padding: 1px 8px; font-size: var(--text-xs); font-weight: 500;
}
.ob-pill {
  display: inline-flex; align-items: center; gap: 6px; border-radius: var(--radius-full);
  padding: 6px 12px; font-size: var(--text-xs); border: 1px solid var(--color-border);
  background: var(--color-surface-sunken); color: var(--color-text-secondary); white-space: nowrap;
}

.ob-scard {
  cursor: pointer; border-radius: var(--radius-md); padding: var(--space-5);
  background: var(--color-surface); border: 1px solid var(--color-border); position: relative;
}
.ob-scard.sel { border: 2px solid var(--color-accent); padding: calc(var(--space-5) - 1px); }
.ob-scard svg { width: 24px; height: 24px; color: var(--color-accent-strong); }
.ob-scard-title { font-size: var(--text-lg); font-weight: 600; margin: var(--space-2) 0 var(--space-1); }
.ob-scard-desc { font-size: var(--text-sm); color: var(--color-text-secondary); margin-bottom: var(--space-3); }
.ob-scard-meta { font-size: var(--text-xs); color: var(--color-text-tertiary); margin-bottom: var(--space-1); }

.ob-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }

.ob-bignum { font-size: 44px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; margin-bottom: var(--space-2); }

.ob-info {
  display: flex; align-items: flex-start; gap: 8px; text-align: left;
  background: var(--color-surface-sunken); border-radius: var(--radius-md);
  padding: 11px 14px; font-size: var(--text-xs); color: var(--color-text-secondary);
  line-height: 1.55;
}
.ob-info svg { width: 15px; height: 15px; color: var(--color-accent-strong); flex-shrink: 0; margin-top: 1px; }

.ob-warn {
  display: flex; align-items: center; gap: 9px; background: var(--color-warning-subtle);
  border: 1px solid var(--color-warning-subtle); border-radius: var(--radius-md);
  padding: 11px 14px; font-size: var(--text-xs); color: var(--color-warning);
}
.ob-warn svg { width: 16px; height: 16px; flex-shrink: 0; }

.ob-yearbar { display: flex; gap: 6px; margin-bottom: var(--space-5); }
.ob-seg {
  cursor: pointer; flex: 1; background: var(--color-surface-sunken); color: var(--color-text-tertiary);
  border-radius: var(--radius-sm); padding: 14px 8px; text-align: center;
}
.ob-seg.sel { flex: 1.4; background: var(--color-accent); color: var(--color-accent-ink); }
.ob-seg-name { font-size: var(--text-sm); }
.ob-seg.sel .ob-seg-name { font-weight: 600; }
.ob-seg-sub { font-size: var(--text-xs); }

.ob-foot { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-5); }
.ob-hint { text-align: center; margin-top: 11px; font-size: var(--text-xs); color: var(--color-text-tertiary); }

.ob-spin {
  display: inline-block; width: 16px; height: 16px; border-radius: var(--radius-full);
  border: 2px solid var(--color-border); border-top-color: var(--color-accent-strong);
  animation: ob-spin 0.7s linear infinite; vertical-align: -3px;
}
@keyframes ob-spin { to { transform: rotate(360deg); } }

/* ── Detailed scan + pile setup (Phase 2) ─────────────────────────────────── */
.ob-progress { height: 8px; border-radius: var(--radius-full); background: var(--color-surface-sunken); overflow: hidden; margin: 0 auto 6px; max-width: 360px; }
.ob-progress > div { height: 100%; width: 0; background: var(--color-accent); transition: width .35s; }
.ob-dslist { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 460px; margin: 0 auto var(--space-5); }

.ob-legend { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: var(--space-4); font-size: var(--text-xs); color: var(--color-text-secondary); }
.ob-pilelist { display: flex; flex-direction: column; gap: 8px; }
.ob-pile { align-items: flex-start; gap: 13px; padding: 12px 14px; }
.ob-pile.foc { border-color: var(--color-accent-strong); box-shadow: 0 0 0 3px var(--color-accent-subtle); }
.ob-pile-mid { flex: 1; min-width: 0; }
.ob-pile-name { font-size: var(--text-base); font-weight: 500; }
.ob-dest { font-size: var(--text-xs); color: var(--color-accent-strong); margin-top: 3px; }
.ob-dest.new { color: var(--color-text-tertiary); }
.ob-dest.del { color: var(--color-danger); }
.ob-dest.del svg { width: 12px; height: 12px; vertical-align: -2px; margin-right: 3px; }
/* Finale stat tiles */
.ob-tiles { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin: 18px 0 4px; }
.ob-tile { min-width: 120px; padding: 14px 18px; border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); }
.ob-tile-n { font-size: 26px; font-weight: 600; letter-spacing: -0.02em; color: var(--color-accent-strong); }
.ob-tile-l { font-size: var(--text-xs); color: var(--color-text-secondary); margin-top: 2px; }
.ob-tile.del { border-color: var(--color-danger); background: var(--color-danger-subtle); }
.ob-tile.del .ob-tile-n { color: var(--color-danger); }
.ob-pile-right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex-shrink: 0; }

.ob-apill {
  display: inline-flex; align-items: center; gap: 6px; border-radius: var(--radius-full);
  padding: 5px 11px; font-size: var(--text-xs); cursor: pointer; white-space: nowrap; user-select: none;
  border: 1px solid var(--color-border); background: var(--color-surface-sunken); color: var(--color-text-secondary);
}
.ob-apill.del { color: var(--color-danger); border-color: var(--color-danger); background: var(--color-danger-subtle); }
.ob-tg { width: 34px; height: 20px; border-radius: var(--radius-full); background: var(--color-border-strong); position: relative; flex-shrink: 0; cursor: pointer; }
.ob-tg .k { width: 16px; height: 16px; border-radius: 50%; background: #fff; position: absolute; top: 2px; left: 2px; }
.ob-tg.on { background: var(--color-accent); }
.ob-tg.on .k { left: auto; right: 2px; }

/* Label picker (type-ahead) */
.ob-pick { margin-top: 6px; }
.ob-pick-in { width: 100%; padding: 8px 10px; border: 1px solid var(--color-accent); border-radius: var(--radius-md); font-family: var(--font-sans); font-size: var(--text-sm); outline: none; }
.ob-pick-list { margin-top: 4px; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; background: var(--color-surface); }
.ob-pick-item { padding: 7px 10px; font-size: var(--text-sm); color: var(--color-text-secondary); cursor: pointer; display: flex; align-items: center; gap: 7px; }
.ob-pick-item svg { width: 15px; height: 15px; }
.ob-pick-item.hl { background: var(--color-accent-subtle); color: var(--color-accent-ink); }
.ob-pick-item.new { color: var(--color-accent-strong); border-top: 1px solid var(--color-border); }
/* Shown in place of the list once a label is chosen: confirms the pick, no auto-advance. */
.ob-pick-sel { margin-top: 4px; padding: 8px 10px; border: 1px solid var(--color-success, var(--color-accent)); border-radius: var(--radius-md); background: var(--color-accent-subtle); color: var(--color-text-secondary); font-size: var(--text-sm); display: flex; align-items: center; gap: 7px; }
.ob-pick-sel svg { width: 15px; height: 15px; color: var(--color-success, var(--color-accent-strong)); }
.ob-pick-sel b { color: var(--color-text-primary); }

/* "Organize: One pile | A pile per year" segmented control + year preview */
.ob-organize { margin-top: 8px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ob-organize-lbl, .ob-organize-hint { font-size: var(--text-xs); color: var(--color-text-tertiary); }
.ob-seg2 { display: inline-flex; border: 1px solid var(--color-border-strong); border-radius: var(--radius-full); overflow: hidden; }
.ob-seg2-opt { font-size: var(--text-xs); padding: 4px 12px; cursor: pointer; color: var(--color-text-secondary); background: var(--color-surface); user-select: none; }
.ob-seg2-opt.on { background: var(--color-accent); color: var(--color-accent-ink); font-weight: 500; }
.ob-seg2-opt + .ob-seg2-opt { border-left: 1px solid var(--color-border-strong); }
/* Domains / people (Phase 3) */
.ob-chiprow { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 16px; }
.ob-chip { cursor: pointer; border-radius: var(--radius-full); padding: 7px 15px; font-size: var(--text-sm); border: 1px solid var(--color-border-strong); background: var(--color-surface); color: var(--color-text-secondary); user-select: none; display: inline-flex; align-items: center; gap: 5px; }
.ob-chip svg { width: 13px; height: 13px; flex-shrink: 0; }
/* Existing-label chips (your own Gmail labels) lead the row, tinted to read as
   "reuse this" vs. the plain "create a category" chips. */
.ob-chip-ex { border-color: var(--color-accent-hover); color: var(--color-accent-strong); background: var(--color-accent-subtle); }
.ob-chip.sel { background: var(--color-accent); color: var(--color-accent-ink); border-color: var(--color-accent-hover); font-weight: 500; }
.ob-chip-ex.sel { color: var(--color-accent-ink); }
.ob-tin { width: 100%; padding: 9px 11px; border: 1px solid var(--color-accent); border-radius: var(--radius-md); font-family: var(--font-sans); font-size: var(--text-sm); outline: none; }
.ob-prop { display: flex; align-items: center; justify-content: space-between; background: var(--color-accent-subtle); border-radius: var(--radius-md); padding: 11px 14px; }
.ob-prop-txt { font-size: var(--text-sm); color: var(--color-accent-ink); }
.ob-prop-danger { color: var(--color-danger); font-weight: 500; display: inline-flex; align-items: center; gap: 6px; }
.ob-prop-danger svg { width: 14px; height: 14px; flex-shrink: 0; }
/* Action-mode pills (Label / Delete / Leave alone) above the proposal bar. */
.ob-actsel { display: flex; gap: 8px; margin: 0 0 14px; }
.ob-actpill { cursor: pointer; border-radius: var(--radius-full); padding: 5px 13px; font-size: var(--text-xs); border: 1px solid var(--color-border-strong); background: var(--color-surface); color: var(--color-text-secondary); user-select: none; }
.ob-actpill.sel { background: var(--color-accent); color: var(--color-accent-ink); border-color: var(--color-accent-hover); font-weight: 500; }
.ob-actpill.danger.sel { background: var(--color-danger); color: #fff; border-color: var(--color-danger-hover); }
.ob-btn-danger { background: var(--color-danger); color: #fff; border-color: var(--color-danger-hover); font-weight: 500; }
.ob-err { color: var(--color-danger); font-size: var(--text-xs); margin: 0 0 12px; display: flex; align-items: center; gap: 5px; }
.ob-avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--color-coral-subtle, #FAECE7); color: #993C1D; display: flex; align-items: center; justify-content: center; font-weight: 500; flex-shrink: 0; }

.ob-yprev { margin-top: 8px; }
.ob-yprev-cap { font-size: var(--text-xs); color: var(--color-text-tertiary); margin-bottom: 5px; }
.ob-ychips { display: flex; flex-wrap: wrap; gap: 6px; }
.ob-ychip { background: var(--color-surface-sunken); color: var(--color-text-secondary); border-radius: var(--radius-full); padding: 3px 9px; font-size: var(--text-xs); font-weight: 500; }
