/* ============================================================================
   BuildMyBot — Client Portal styles
   Builds on the brand tokens in /assets/colors_and_type.css (Inter, colors,
   radii, spacing). This file only adds portal-specific layout.
   ========================================================================== */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--bmb-font);
  color: var(--bmb-ink);
  background: var(--bmb-bg);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--bmb-blue); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Top bar -------------------------------------------------------------- */
.bmb-topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--bmb-space-4);
  padding: 14px var(--bmb-gutter);
  background: var(--bmb-surface);
  border-bottom: 1px solid var(--bmb-line);
}
.bmb-topbar .brand { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: -.3px; }
.bmb-topbar .brand img { height: 26px; width: auto; display: block; }
.bmb-topbar .who { display: flex; align-items: center; gap: 14px; font-size: var(--bmb-sm); color: var(--bmb-muted); }

/* ---- Layout --------------------------------------------------------------- */
.bmb-wrap { max-width: var(--bmb-maxw-app); margin: 0 auto; padding: var(--bmb-space-7) var(--bmb-gutter) var(--bmb-space-9); }
.bmb-wrap.wide { max-width: var(--bmb-maxw); }

.card {
  background: var(--bmb-surface);
  border: 1px solid var(--bmb-line);
  border-radius: var(--bmb-radius-card);
  padding: var(--bmb-space-6);
  margin-bottom: var(--bmb-space-5);
}
.card h2 { font-size: var(--bmb-h3); font-weight: 600; margin: 0 0 var(--bmb-space-4); }
.section-label { font-size: var(--bmb-overline); font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--bmb-muted-3); margin: 0 0 var(--bmb-space-3); }

/* ---- Buttons -------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font: 600 var(--bmb-sm)/1 var(--bmb-font);
  padding: 12px 18px; border-radius: var(--bmb-radius-sm);
  border: 1px solid transparent; cursor: pointer; transition: all var(--bmb-dur-fast) var(--bmb-ease);
}
.btn-primary { background: var(--bmb-ink-button); color: #fff; }
.btn-primary:hover { background: #000; }
.btn-ghost { background: transparent; color: var(--bmb-ink); border-color: var(--bmb-line); }
.btn-ghost:hover { border-color: var(--bmb-blue-300); background: var(--bmb-blue-tint); text-decoration: none; }
.btn:disabled { opacity: .55; cursor: not-allowed; }
.btn-sm { padding: 8px 12px; font-size: var(--bmb-xs); }
.btn-link { background: none; border: none; color: var(--bmb-muted); cursor: pointer; font: 600 var(--bmb-sm) var(--bmb-font); }
.btn-link:hover { color: var(--bmb-ink); }

/* ---- Forms ---------------------------------------------------------------- */
.field { margin-bottom: var(--bmb-space-4); }
.field label { display: block; font-size: var(--bmb-sm); font-weight: 600; margin-bottom: 6px; }
.field .hint { font-size: var(--bmb-xs); color: var(--bmb-muted-2); margin-top: 4px; }
input[type=text], input[type=email], input[type=password], input[type=tel], select, textarea {
  width: 100%; font: 400 var(--bmb-body) var(--bmb-font); color: var(--bmb-ink);
  background: var(--bmb-surface); border: 1px solid var(--bmb-line);
  border-radius: var(--bmb-radius-input); padding: 11px 13px; transition: all var(--bmb-dur-fast) var(--bmb-ease);
}
textarea { resize: vertical; min-height: 84px; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--bmb-blue); box-shadow: var(--bmb-focus-glow); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--bmb-space-4); }
@media (max-width: 560px) { .grid-2 { grid-template-columns: 1fr; } }

/* ---- Chips (multi-select for pain points / goals) ------------------------- */
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  font-size: var(--bmb-sm); padding: 8px 13px; border-radius: var(--bmb-radius-pill);
  border: 1px solid var(--bmb-line); background: var(--bmb-surface); cursor: pointer;
  user-select: none; transition: all var(--bmb-dur-fast) var(--bmb-ease);
}
.chip[aria-pressed=true] { background: var(--bmb-blue-tint); border-color: var(--bmb-blue); color: var(--bmb-blue-700); font-weight: 600; }

/* ---- Messages ------------------------------------------------------------- */
.msg { font-size: var(--bmb-sm); padding: 11px 13px; border-radius: var(--bmb-radius-input); margin-bottom: var(--bmb-space-4); }
.msg.error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.msg.ok    { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.msg.info  { background: var(--bmb-blue-tint); color: var(--bmb-blue-700); border: 1px solid var(--bmb-blue-ring); }
.hidden { display: none !important; }

/* ---- Progress ------------------------------------------------------------- */
.progress-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--bmb-space-3); }
.progress-head .pct { font-size: var(--bmb-h2); font-weight: 700; letter-spacing: -.5px; }
.stage-badge { display: inline-block; padding: 5px 11px; border-radius: var(--bmb-radius-pill);
  background: var(--bmb-blue-tint-2); color: var(--bmb-blue-700); font-size: var(--bmb-xs); font-weight: 600; }
.track { height: 10px; border-radius: var(--bmb-radius-pill); background: var(--bmb-line); overflow: hidden; }
.track > span { display: block; height: 100%; background: var(--bmb-blue); border-radius: inherit;
  transition: width var(--bmb-dur-slow) var(--bmb-ease); }

/* ---- Milestone timeline --------------------------------------------------- */
.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--bmb-line); }
.timeline li:last-child { border-bottom: 0; }
.dot { flex: none; width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--bmb-line);
  background: var(--bmb-surface); margin-top: 1px; display: grid; place-items: center; font-size: 12px; color: #fff; }
.dot.done { background: var(--bmb-success); border-color: var(--bmb-success); }
.dot.in_progress { border-color: var(--bmb-blue); background: var(--bmb-blue); }
.timeline .m-title { font-weight: 600; font-size: var(--bmb-body); }
.timeline .m-status { font-size: var(--bmb-xs); color: var(--bmb-muted-2); text-transform: capitalize; }

/* ---- Updates feed --------------------------------------------------------- */
.feed { list-style: none; margin: 0; padding: 0; }
.feed li { padding: 14px 0; border-bottom: 1px solid var(--bmb-line); }
.feed li:last-child { border-bottom: 0; }
.feed .meta { font-size: var(--bmb-xs); color: var(--bmb-muted-2); margin-top: 4px; }
.feed .body { font-size: var(--bmb-body); color: var(--bmb-ink); white-space: pre-wrap; line-height: var(--bmb-leading-body); }
.empty { color: var(--bmb-muted-2); font-size: var(--bmb-sm); padding: 8px 0; }

/* ---- Auth (login/signup) -------------------------------------------------- */
.auth-shell { min-height: 100dvh; display: grid; place-items: center; padding: var(--bmb-gutter); }
.auth-card { width: 100%; max-width: 420px; }
.auth-card .brand { display: flex; align-items: center; gap: 10px; justify-content: center; margin-bottom: var(--bmb-space-5); }
.auth-card .brand img { height: 30px; }
.auth-tabs { display: flex; gap: 4px; background: var(--bmb-bg); border: 1px solid var(--bmb-line);
  border-radius: var(--bmb-radius-sm); padding: 4px; margin-bottom: var(--bmb-space-5); }
.auth-tabs button { flex: 1; padding: 9px; border: 0; background: transparent; border-radius: 9px;
  font: 600 var(--bmb-sm) var(--bmb-font); color: var(--bmb-muted); cursor: pointer; }
.auth-tabs button.active { background: var(--bmb-surface); color: var(--bmb-ink); box-shadow: var(--bmb-shadow-sm); }
.auth-foot { text-align: center; font-size: var(--bmb-xs); color: var(--bmb-muted-2); margin-top: var(--bmb-space-4); }

/* ---- Admin client list ---------------------------------------------------- */
.client-row { display: flex; align-items: center; justify-content: space-between; gap: var(--bmb-space-4);
  padding: 14px 0; border-bottom: 1px solid var(--bmb-line); cursor: pointer; }
.client-row:last-child { border-bottom: 0; }
.client-row:hover .name { color: var(--bmb-blue); }
.client-row .name { font-weight: 600; }
.client-row .sub { font-size: var(--bmb-xs); color: var(--bmb-muted-2); margin-top: 2px; }
.mini-track { width: 120px; height: 8px; border-radius: var(--bmb-radius-pill); background: var(--bmb-line); overflow: hidden; }
.mini-track > span { display: block; height: 100%; background: var(--bmb-blue); }
.row-right { display: flex; align-items: center; gap: 14px; }

.loading { text-align: center; color: var(--bmb-muted-2); padding: var(--bmb-space-8) 0; font-size: var(--bmb-sm); }
