/* ============================================================
   B2B CRM — Design System
   The single source of visual truth. Colors, type, spacing,
   and shared components. Every screen is built on these.
   ============================================================ */

:root {
  /* ---- Color: brand & accents ---- */
  --color-brand:        #2f5bea;
  --color-brand-dark:   #1e40c4;
  --color-brand-soft:   #eaf0ff;

  /* ---- Color: semantic ---- */
  --color-success:      #12805c;
  --color-success-soft: #e3f5ee;
  --color-danger:       #c0392b;
  --color-danger-soft:  #fdecea;
  --color-warning:      #b7791f;
  --color-warning-soft: #fdf3e2;

  /* ---- Color: neutrals ---- */
  --color-bg:           #f5f6f8;
  --color-surface:      #ffffff;
  --color-surface-2:    #fafbfc;
  --color-border:       #e2e5ea;
  --color-border-strong:#cbd0d9;
  --color-text:         #1a1d24;
  --color-text-soft:    #5b6370;
  --color-text-faint:   #8b93a1;

  /* ---- Typography ---- */
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-mono: "SF Mono", ui-monospace, "Cascadia Mono", Consolas, monospace;
  --fs-xs:   0.75rem;
  --fs-sm:   0.8125rem;
  --fs-base: 0.9375rem;
  --fs-md:   1.0625rem;
  --fs-lg:   1.25rem;
  --fs-xl:   1.5rem;
  --fs-2xl:  2rem;
  --fw-normal: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --lh-tight: 1.25;
  --lh-normal: 1.5;

  /* ---- Spacing (4px scale) ---- */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.5rem;
  --sp-6: 2rem;
  --sp-7: 3rem;

  /* ---- Radius / shadow ---- */
  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 2px rgba(20, 25, 40, 0.06);
  --shadow:    0 2px 8px rgba(20, 25, 40, 0.08);
  --shadow-lg: 0 12px 40px rgba(20, 25, 40, 0.18);

  --layout-max: 1180px;
}

/* ---- Reset-ish ---- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, p { margin: 0; }
button, input, select, textarea { font: inherit; color: inherit; }
a { color: var(--color-brand); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Typography helpers ---- */
.h1 { font-size: var(--fs-2xl); font-weight: var(--fw-bold); line-height: var(--lh-tight); }
.h2 { font-size: var(--fs-xl);  font-weight: var(--fw-semibold); line-height: var(--lh-tight); }
.h3 { font-size: var(--fs-lg);  font-weight: var(--fw-semibold); }
.muted { color: var(--color-text-soft); }
.faint { color: var(--color-text-faint); }
.mono  { font-family: var(--font-mono); }
.text-sm { font-size: var(--fs-sm); }
.text-xs { font-size: var(--fs-xs); }
.nowrap { white-space: nowrap; }
.right { text-align: right; }
.center { text-align: center; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-base); font-weight: var(--fw-medium);
  border: 1px solid transparent; border-radius: var(--radius-sm);
  background: var(--color-surface); color: var(--color-text);
  cursor: pointer; white-space: nowrap;
  transition: background .12s ease, border-color .12s ease, opacity .12s ease;
}
.btn:hover { text-decoration: none; }
.btn:focus-visible { outline: 2px solid var(--color-brand); outline-offset: 2px; }
.btn:disabled { opacity: .55; cursor: not-allowed; }
.btn--primary { background: var(--color-brand); color: #fff; border-color: var(--color-brand); }
.btn--primary:hover { background: var(--color-brand-dark); border-color: var(--color-brand-dark); }
.btn--secondary { background: var(--color-surface); border-color: var(--color-border-strong); color: var(--color-text); }
.btn--secondary:hover { background: var(--color-surface-2); }
.btn--ghost { background: transparent; border-color: transparent; color: var(--color-text-soft); }
.btn--ghost:hover { background: var(--color-brand-soft); color: var(--color-brand); }
.btn--danger { background: var(--color-danger); color: #fff; border-color: var(--color-danger); }
.btn--danger:hover { opacity: .9; }
.btn--success { background: var(--color-success); color: #fff; border-color: var(--color-success); }
.btn--success:hover { opacity: .9; }
.btn--sm { padding: var(--sp-1) var(--sp-3); font-size: var(--fs-sm); }
.btn--block { width: 100%; }

/* ---- Forms ---- */
.field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.field > label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text-soft); }
.input, .select, .textarea {
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-base);
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  transition: border-color .12s ease, box-shadow .12s ease;
}
.input:focus, .select:focus, .textarea:focus {
  outline: none; border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-soft);
}
.textarea { resize: vertical; min-height: 72px; }
.field-hint { font-size: var(--fs-xs); color: var(--color-text-faint); }
.checkbox-row { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-base); }
.checkbox-list { display: flex; flex-direction: column; gap: var(--sp-2); max-height: 220px; overflow-y: auto;
  border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--sp-3); }

/* ---- Card / panel ---- */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.card__header { padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.card__body { padding: var(--sp-5); }
.card__title { font-size: var(--fs-md); font-weight: var(--fw-semibold); }

/* ---- Table ---- */
.table-wrap { overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-base); }
.table th, .table td { padding: var(--sp-3) var(--sp-4); text-align: left; border-bottom: 1px solid var(--color-border); }
.table th { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .04em;
  color: var(--color-text-faint); font-weight: var(--fw-semibold); background: var(--color-surface-2); }
.table tbody tr { transition: background .1s ease; }
.table tbody tr.is-clickable { cursor: pointer; }
.table tbody tr.is-clickable:hover { background: var(--color-brand-soft); }
.table td.right, .table th.right { text-align: right; }

/* ---- Badges / pills ---- */
.badge {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: 2px var(--sp-2); border-radius: 999px;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold); line-height: 1.6;
  background: var(--color-border); color: var(--color-text-soft);
}
.badge--open    { background: var(--color-brand-soft); color: var(--color-brand-dark); }
.badge--won     { background: var(--color-success-soft); color: var(--color-success); }
.badge--lost    { background: var(--color-danger-soft); color: var(--color-danger); }
.badge--neutral { background: var(--color-border); color: var(--color-text-soft); }

/* ---- Modal ---- */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(20, 25, 40, .45);
  display: flex; align-items: flex-start; justify-content: center;
  padding: var(--sp-7) var(--sp-4); z-index: 100; overflow-y: auto;
}
.modal {
  background: var(--color-surface); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); width: 100%; max-width: 480px; margin-top: var(--sp-6);
}
.modal--wide { max-width: 640px; }
.modal__header { padding: var(--sp-5); border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between; }
.modal__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); }
.modal__body { padding: var(--sp-5); }
.modal__footer { padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--color-border);
  display: flex; justify-content: flex-end; gap: var(--sp-3); }
.modal__close { background: none; border: none; cursor: pointer; font-size: var(--fs-lg);
  color: var(--color-text-faint); line-height: 1; padding: var(--sp-1); }

/* ---- Empty state ---- */
.empty { text-align: center; padding: var(--sp-7) var(--sp-4); color: var(--color-text-soft); }
.empty__icon { font-size: 2rem; margin-bottom: var(--sp-2); }

/* ---- Toast ---- */
.toast-stack { position: fixed; bottom: var(--sp-5); right: var(--sp-5); display: flex;
  flex-direction: column; gap: var(--sp-2); z-index: 200; }
.toast {
  background: var(--color-text); color: #fff; padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-sm); box-shadow: var(--shadow-lg); font-size: var(--fs-sm);
  max-width: 340px; animation: toast-in .18s ease;
}
.toast--error { background: var(--color-danger); }
.toast--success { background: var(--color-success); }
@keyframes toast-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ---- Utility layout ---- */
.row { display: flex; gap: var(--sp-3); align-items: center; }
.row--between { justify-content: space-between; }
.row--wrap { flex-wrap: wrap; }
.stack { display: flex; flex-direction: column; }
.grid { display: grid; gap: var(--sp-4); }
.spacer { flex: 1; }
.mt-2 { margin-top: var(--sp-2); } .mt-4 { margin-top: var(--sp-4); } .mt-5 { margin-top: var(--sp-5); }
.mb-4 { margin-bottom: var(--sp-4); }
.hidden { display: none !important; }

/* ---- Spinner ---- */
.spinner { width: 20px; height: 20px; border: 2px solid var(--color-border-strong);
  border-top-color: var(--color-brand); border-radius: 50%; animation: spin .7s linear infinite; }
.spinner--center { margin: var(--sp-7) auto; }
@keyframes spin { to { transform: rotate(360deg); } }
