/* ============================================================================
   OpenMAO — Component primitives
   Depends on colors_and_type.css. Reused by preview cards and UI kits.
   ============================================================================ */

/* ---- Buttons ------------------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 36px; padding: 0 14px;
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  border-radius: var(--r); border: 1px solid var(--line);
  background: var(--bg); color: var(--fg-1);
  cursor: pointer; white-space: nowrap;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease),
    background var(--dur) var(--ease);
}
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.btn:active { transform: none; }

.btn-primary { background: var(--accent); border-color: var(--accent); color: var(--fg-on-accent); }
.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); color: var(--fg-on-accent); }
.btn-primary:active { background: var(--accent-press); border-color: var(--accent-press); }

.btn-danger:hover { border-color: var(--danger); color: var(--danger); }
.btn-danger-solid { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-danger-solid:hover { background: var(--danger-hover); border-color: var(--danger-hover); color:#fff; }

.btn-ghost { background: transparent; border-color: transparent; color: var(--fg-2); }
.btn-ghost:hover { background: var(--surface-2); border-color: transparent; color: var(--fg-1); }

.btn-sm { min-height: 28px; padding: 0 10px; font-size: 12.5px; }
.btn-lg { min-height: 44px; padding: 0 22px; font-size: 15px; }

/* ---- Status badge ------------------------------------------------------- */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  height: 22px; padding: 0 9px;
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 500;
  border-radius: var(--r-pill); border: 1px solid;
  white-space: nowrap;
}
.badge .bdot { width: 6px; height: 6px; border-radius: 999px; background: currentColor; flex: none; }
.badge-neutral { color: var(--state-neutral-fg); background: var(--state-neutral-bg); border-color: var(--state-neutral-line); }
.badge-info    { color: var(--state-info-fg);    background: var(--state-info-bg);    border-color: var(--state-info-line); }
.badge-pending { color: var(--state-pending-fg); background: var(--state-pending-bg); border-color: var(--state-pending-line); }
.badge-success { color: var(--state-success-fg); background: var(--state-success-bg); border-color: var(--state-success-line); }
.badge-danger  { color: var(--state-danger-fg);  background: var(--state-danger-bg);  border-color: var(--state-danger-line); }

/* Square/technical badge variant (risk, autonomy) */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  height: 22px; padding: 0 8px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.02em; border-radius: var(--r-sm); border: 1px solid var(--line);
  color: var(--fg-2); background: var(--surface-1);
}

/* ---- Inputs ------------------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 6px; }
.field > label {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-3);
}
.input {
  min-height: 36px; width: 100%;
  padding: 0 11px; font-family: var(--font-sans); font-size: 14px;
  color: var(--fg-1); background: var(--bg);
  border: 1px solid var(--line); border-radius: var(--r);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.input::placeholder { color: var(--fg-3); }
.input:focus { outline: none; border-color: var(--accent); box-shadow: var(--focus-ring); }
textarea.input { padding: 9px 11px; min-height: 80px; resize: vertical; line-height: 1.5; }

/* ---- Card --------------------------------------------------------------- */
.card {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: var(--space-5);
}
.card-pad-sm { padding: var(--space-4); }

/* ---- Table -------------------------------------------------------------- */
.table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.table th {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-3);
  text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line);
}
.table td { padding: 11px 10px; border-bottom: 1px solid var(--line); color: var(--fg-1); vertical-align: middle; }
.table tr:last-child td { border-bottom: 0; }
.table tbody tr { transition: background var(--dur-fast) var(--ease); }
.table tbody tr:hover { background: var(--surface-1); }
.table .mono { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); }

/* ---- Terminal / log block ---------------------------------------------- */
.terminal {
  background: var(--terminal-bg); color: var(--terminal-fg);
  font-family: var(--font-mono); font-size: 13px; line-height: 1.6;
  border-radius: var(--r); padding: 16px 18px; overflow: auto;
}
.terminal .tprompt { color: var(--accent); }
.terminal .tmuted { color: var(--terminal-muted); }
.terminal .tok { color: #6fd0b3; }
.terminal .twarn { color: #dba94a; }

/* ---- Autonomy pill ------------------------------------------------------ */
.autonomy {
  display: inline-flex; align-items: center; gap: 7px;
  height: 24px; padding: 0 10px; border-radius: var(--r-pill);
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 500;
  color: #fff;
}
.autonomy[data-level="advisory"]  { background: var(--autonomy-advisory); }
.autonomy[data-level="supervised"]{ background: var(--autonomy-supervised); }
.autonomy[data-level="bounded"]   { background: var(--autonomy-bounded); }
.autonomy[data-level="board-governed"] { background: var(--autonomy-board); }
