/*
 * app.css — console overlay on top of tfi.css
 *
 * tfi.css provides the brand tokens, typography, tables, forms, boxes.
 * This stylesheet adds only what the console UI needs beyond that:
 * status colors for job states, page-level layout, log entry styling,
 * live-status indicator, and job-detail metadata list.
 */

:root {
  /* Darker accents for readable text against the cream body background.
   * The brand --tfi-green is a pill-fill colour (paired with white fg);
   * too low-contrast for text on cream. --tfi-off-black carries the
   * "warn" semantics inside table bodies — orange stays reserved for
   * header cells, and the uppercase state label already conveys the
   * meaning without needing a second warning hue. */
  --tfi-green-dark: #556b2f;
  --tfi-off-black: #2d2a38;
}

/* ── Layout ────────────────────────────────────────────────────── */

header nav {
  margin-top: 0.25rem;
  font-size: 0.85rem;
  color: var(--tfi-dark-grey);
}

main { margin-top: 1rem; }

p.hint {
  margin: 0.5rem 0 1rem;
  color: var(--tfi-dark-grey);
  font-size: 0.85rem;
}

p.status-line {
  margin-top: 1rem;
  font-size: 0.8rem;
  text-align: right;
}

/* ── Shared utilities already used by SSR templates ────────────── */

.subtle { color: var(--tfi-dark-grey); }
.empty  { color: var(--tfi-dark-grey); font-style: italic; }
.ok     { color: var(--tfi-green-dark); }
.bad    { color: var(--tfi-red); }
.warn   { color: var(--tfi-off-black); }

tr.warn-row td { background: rgba(238, 185, 34, 0.12); }

hr.sep {
  border: none;
  border-top: 1px dashed var(--tfi-light-grey);
  margin: 1rem 0;
}

h3 {
  margin: 1rem 0 0.3rem;
  font-size: 1rem;
  color: var(--tfi-black);
  font-weight: bold;
}

h1 img {
  height: 1em;
  width: auto;
  vertical-align: middle;
  margin-right: 0.3em;
}

/* ── Live status indicator ────────────────────────────────────── */

#live-status.connecting   { color: var(--tfi-orange); }
#live-status.reconnecting { color: var(--tfi-orange); }
#live-status.live         { color: var(--tfi-green-dark); }
#live-status.stale        { color: var(--tfi-orange); }
#live-status.error        { color: var(--tfi-red); }

/* ── Status pill on the job detail page ───────────────────────── */

.status-pill {
  display: inline-block;
  padding: 0.1em 0.6em;
  margin-left: 0.5rem;
  border-radius: 0.8em;
  font-size: 0.7em;
  font-weight: bold;
  vertical-align: middle;
  background: var(--tfi-light-grey);
  color: var(--tfi-black);
}

.status-pill.state-done     { background: var(--tfi-green-dark); color: var(--tfi-white); }
.status-pill.state-failed,
.status-pill.state-cancelled{ background: var(--tfi-red); color: var(--tfi-white); }
.status-pill.state-waiting  { background: var(--tfi-orange); color: var(--tfi-white); }
.status-pill.state-running  { background: var(--tfi-blue); color: var(--tfi-white); }

/* ── Job metadata list ───────────────────────────────────────── */

dl.job-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.2rem 1rem;
  font-size: 0.9rem;
}
dl.job-meta dt { font-weight: bold; color: var(--tfi-orange); }
dl.job-meta dd { color: var(--tfi-black); word-break: break-word; }

/* ── Log entries ───────────────────────────────────────────────── */

.log {
  font-size: 0.85rem;
  padding-top: 0.25rem;
}

.log .entry {
  padding: 0.3rem 0.5rem;
  border-left: 3px solid var(--tfi-light-grey);
  margin-bottom: 0.35rem;
  background: var(--tfi-white);
}

.log .entry-start  { border-left-color: var(--tfi-blue); }
.log .entry-result { border-left-color: var(--tfi-green-dark); }
.log .entry-result.bad { border-left-color: var(--tfi-red); }
.log .entry-state  { border-left-color: var(--tfi-orange); }
.log .entry-print  { border-left-color: var(--tfi-yellow); background: rgba(238, 185, 34, 0.08); }

.log .entry .idx {
  color: var(--tfi-dark-grey);
  margin-right: 0.5rem;
  font-variant-numeric: tabular-nums;
}
.log .entry .ts {
  color: var(--tfi-dark-grey);
  font-size: 0.85em;
  margin-left: 0.25rem;
}
.log .entry pre {
  margin-top: 0.3rem;
  max-height: 10em;
  overflow-y: auto;
}

/* ── Entrypoint group headings ────────────────────────────────── */

.ep-group {
  margin-bottom: 1.5rem;
}
.ep-group:last-child { margin-bottom: 0; }
.ep-group h3 { margin-bottom: 0.2rem; }
.ep-group .ep-section-label {
  font-size: 0.8rem;
  color: var(--tfi-dark-grey);
  margin: 0.5rem 0 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
