/* ============================================================
   App layout — built entirely on design-system.css tokens.
   ============================================================ */

/* ---- App shell ---- */
.app { min-height: 100vh; display: flex; flex-direction: column; }

.topbar {
  background: var(--color-surface); border-bottom: 1px solid var(--color-border);
  position: sticky; top: 0; z-index: 50;
}
.topbar__inner {
  max-width: var(--layout-max); margin: 0 auto; padding: 0 var(--sp-5);
  height: 60px; display: flex; align-items: center; gap: var(--sp-5);
}
.brand { display: flex; align-items: center; gap: var(--sp-2); font-weight: var(--fw-bold);
  font-size: var(--fs-md); color: var(--color-text); }
.brand__mark { width: 26px; height: 26px; border-radius: var(--radius-sm);
  background: var(--color-brand); color: #fff; display: grid; place-items: center;
  font-size: var(--fs-sm); font-weight: var(--fw-bold); }

.nav { display: flex; gap: var(--sp-1); }
.nav__link {
  padding: var(--sp-2) var(--sp-3); border-radius: var(--radius-sm);
  color: var(--color-text-soft); font-weight: var(--fw-medium); font-size: var(--fs-base);
  cursor: pointer;
}
.nav__link:hover { background: var(--color-surface-2); text-decoration: none; color: var(--color-text); }
.nav__link.is-active { background: var(--color-brand-soft); color: var(--color-brand-dark); }

.topbar__user { display: flex; align-items: center; gap: var(--sp-3); font-size: var(--fs-sm); }
.avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--color-brand-soft);
  color: var(--color-brand-dark); display: grid; place-items: center; font-weight: var(--fw-semibold);
  font-size: var(--fs-sm); }

.main { flex: 1; max-width: var(--layout-max); width: 100%; margin: 0 auto; padding: var(--sp-6) var(--sp-5); }
.page-head { display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--sp-3); margin-bottom: var(--sp-5); flex-wrap: wrap; }
.page-head__sub { color: var(--color-text-soft); font-size: var(--fs-base); margin-top: var(--sp-1); }

/* ---- Login ---- */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: var(--sp-5);
  background: linear-gradient(160deg, #eef2ff 0%, #f5f6f8 55%); }
.login-card { width: 100%; max-width: 380px; }
.login-card .brand { justify-content: center; margin-bottom: var(--sp-2); }

/* ---- Dashboard ---- */
.kpi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-6); }
.kpi {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius); padding: var(--sp-5); box-shadow: var(--shadow-sm);
}
.kpi__label { font-size: var(--fs-sm); color: var(--color-text-soft); font-weight: var(--fw-medium); }
.kpi__value { font-size: var(--fs-2xl); font-weight: var(--fw-bold); margin-top: var(--sp-2); }
.kpi__foot { font-size: var(--fs-xs); color: var(--color-text-faint); margin-top: var(--sp-1); }
.kpi--actual .kpi__value { color: var(--color-brand); }

/* progress bar (actual vs potential) */
.bar { height: 8px; background: var(--color-border); border-radius: 999px; overflow: hidden; min-width: 90px; }
.bar__fill { height: 100%; background: var(--color-brand); border-radius: 999px; }
.bar__fill--full { background: var(--color-success); }

.country-block { margin-bottom: var(--sp-5); }
.country-block__ops .table th:first-child { padding-left: var(--sp-6); }

/* ---- Lead detail ---- */
.detail-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--sp-5); align-items: start; }
.kv { display: grid; grid-template-columns: 140px 1fr; gap: var(--sp-3) var(--sp-4); align-items: center; }
.kv dt { color: var(--color-text-soft); font-size: var(--fs-sm); }
.kv dd { margin: 0; font-weight: var(--fw-medium); }
.followup { padding: var(--sp-4) 0; border-bottom: 1px solid var(--color-border); }
.followup:last-child { border-bottom: none; }
.followup__date { font-size: var(--fs-xs); color: var(--color-text-faint); font-weight: var(--fw-semibold); }
.followup__note { margin-top: var(--sp-1); white-space: pre-wrap; }

/* ---- Filters / toolbar ---- */
.toolbar { display: flex; gap: var(--sp-3); align-items: center; flex-wrap: wrap; margin-bottom: var(--sp-4); }
.toolbar .input, .toolbar .select { width: auto; min-width: 160px; }
.toolbar .search { min-width: 220px; }

/* ---- Responsive ---- */
@media (max-width: 860px) {
  .kpi-grid { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
  .topbar__inner { gap: var(--sp-3); padding: 0 var(--sp-4); }
  .main { padding: var(--sp-5) var(--sp-4); }
  .nav__link { padding: var(--sp-2); }
}
