/* ============================================================================
   Food Chain Lens: component primitives (warm, light)
   Builds on design_tokens.css. Reusable across the app.
   ============================================================================ */

/* ---- Surfaces ----------------------------------------------------------- */
.bk-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-card);
}
.bk-card-2 { background: var(--card-2); border: 1px solid var(--line); border-radius: var(--r-md); }
.bk-well {
  background: var(--sunken);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-md);
}

/* ---- Eyebrow ------------------------------------------------------------ */
.bk-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  font-weight: 500;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}

/* ---- Buttons ------------------------------------------------------------ */
.bk-btn {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 600;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 10px 16px;
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .04s ease;
  white-space: nowrap;
  user-select: none;
}
.bk-btn:active { transform: translateY(0.5px); }
.bk-btn-primary { background: var(--accent); color: #fff; }
.bk-btn-primary:hover { background: var(--accent-600); }
.bk-btn-ghost { background: var(--card); color: var(--ink-2); border-color: var(--line-strong); }
.bk-btn-ghost:hover { background: var(--paper-2); color: var(--ink-1); border-color: var(--ink-4); }
.bk-btn-soft { background: var(--accent-wash); color: var(--accent-600); }
.bk-btn-soft:hover { background: #D2E0EE; }
.bk-btn-sm { padding: 7px 12px; font-size: var(--t-cap); }

/* ---- Form controls ------------------------------------------------------ */
.bk-field-label {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-3);
  display: block;
  margin-bottom: var(--s-2);
}
.bk-select, .bk-input {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  color: var(--ink-1);
  background: var(--card);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  padding: 10px 13px;
  width: 100%;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.bk-select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-3) 50%), linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position: calc(100% - 17px) center, calc(100% - 12px) center;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 34px;
  cursor: pointer;
}
.bk-select:focus, .bk-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-wash); }
.bk-input::placeholder { color: var(--ink-4); }

/* Segmented control */
.bk-segmented {
  display: inline-flex;
  background: var(--sunken);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 3px;
  gap: 2px;
}
.bk-segmented button {
  font-family: var(--font-sans);
  font-size: var(--t-cap);
  font-weight: 500;
  color: var(--ink-3);
  background: transparent;
  border: none;
  border-radius: 6px;
  padding: 7px 13px;
  cursor: pointer;
  transition: background .14s, color .14s, box-shadow .14s;
}
.bk-segmented button:hover { color: var(--ink-1); }
.bk-segmented button.is-active { background: var(--card); color: var(--accent-600); box-shadow: var(--shadow-sm); }

/* ---- Pills / badges ----------------------------------------------------- */
.bk-pill {
  font-family: var(--font-sans);
  font-size: var(--t-cap);
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.bk-pill-soft   { background: var(--sunken); color: var(--ink-2); }
.bk-pill-accent { background: var(--accent-wash); color: var(--accent-600); }
.bk-pill-wheat  { background: var(--wheat-wash); color: #936219; }
.bk-pill-teal   { background: var(--teal-wash); color: #1F6E69; }
.bk-pill-leaf   { background: var(--leaf-wash); color: #34663E; }
.bk-pill-risk   { background: var(--risk-wash); color: #97352C; }

/* Archetype / category chip (mono, uppercase) */
.bk-tag {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-xs);
  background: var(--sunken);
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}

/* Signal badge */
.bk-signal { font-family: var(--font-mono); font-size: var(--t-cap); font-weight: 600; padding: 3px 9px; border-radius: var(--r-pill); display: inline-flex; align-items: center; gap: 4px; }
.bk-signal-up   { background: var(--sig-up-wash);   color: #97352C; }
.bk-signal-down { background: var(--sig-down-wash); color: #34663E; }
.bk-signal-flat { background: var(--sunken);        color: var(--ink-3); }

/* Status dot */
.bk-dot { width: 8px; height: 8px; border-radius: var(--r-pill); display: inline-block; flex-shrink: 0; }
.bk-dot-live  { background: var(--status-live); }
.bk-dot-warn  { background: var(--status-warn); }
.bk-dot-alert { background: var(--status-alert); }
.bk-dot-idle  { background: var(--status-idle); }

/* ---- Trust labels (data honesty, a first-class element) ----------------- */
.bk-trust {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  letter-spacing: 0.03em;
  padding: 3px 8px 3px 7px;
  border-radius: var(--r-xs);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  border: 1px solid transparent;
}
.bk-trust::before { content: ""; width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.bk-trust-live     { background: var(--leaf-wash);  color: #34663E; }
.bk-trust-live::before { background: var(--leaf); }
.bk-trust-origin   { background: var(--teal-wash);  color: #1F6E69; }
.bk-trust-origin::before { background: var(--teal); }
.bk-trust-static   { background: var(--card); color: var(--ink-3); border-color: var(--line-strong); border-style: dashed; }
.bk-trust-static::before { background: var(--ink-4); }
.bk-trust-planned  { background: var(--accent-wash); color: var(--accent-600); }
.bk-trust-planned::before { background: var(--accent-300); }
.bk-trust-blocked  { background: var(--risk-wash); color: #97352C; }
.bk-trust-blocked::before { background: var(--risk); }

/* ---- Pressure meter ----------------------------------------------------- */
.bk-meter { height: 8px; background: var(--sunken); border-radius: var(--r-pill); overflow: hidden; }
.bk-meter-fill { height: 100%; border-radius: var(--r-pill); transition: width .6s cubic-bezier(.2,.8,.2,1); }

/* ---- Icon tile (food symbol holder) ------------------------------------- */
.bk-itile {
  display: inline-grid;
  place-items: center;
  border-radius: var(--r-sm);
  flex-shrink: 0;
}

/* ---- KPI ---------------------------------------------------------------- */
.bk-kpi-label { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: var(--track-eyebrow); text-transform: uppercase; color: var(--ink-3); }
.bk-kpi-value { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 32px; font-weight: 500; color: var(--ink-1); letter-spacing: -0.01em; line-height: 1; }

/* ---- Scrollbars --------------------------------------------------------- */
.bk-scroll::-webkit-scrollbar { width: 11px; height: 11px; }
.bk-scroll::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: var(--r-pill); border: 3px solid transparent; background-clip: padding-box; }
.bk-scroll::-webkit-scrollbar-thumb:hover { background: var(--ink-4); background-clip: padding-box; }
.bk-scroll::-webkit-scrollbar-track { background: transparent; }
