/* DFC Agent Dashboard — Maestro Pizza palette. */

:root {
  /* Maestro core */
  --ink: #0A4731;            /* forest green — text & dark surfaces */
  --ink-soft: #14633F;       /* softer forest green */
  --leaf: #1FA84A;           /* vibrant leaf green — primary accent */
  --leaf-dk: #147A35;        /* darker leaf — hover/pressed */
  --sun: #FFC72C;            /* sunny yellow — secondary accent */
  --sun-dk: #E5A800;

  /* Neutrals tinted warm */
  --cream: #FAF4DE;          /* page background */
  --cream-soft: #FFFBED;     /* card surface */
  --rule: #E8E1C5;           /* borders */
  --muted: #6B7367;          /* secondary text */
  --slate: #2F4A3C;          /* body text on cream */

  /* Aliases used by the rest of the file */
  --accent: var(--leaf);
  --accent-dk: var(--leaf-dk);
  --sand: #F5EDC9;
  --bg: var(--cream);
  --surface: var(--cream-soft);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--slate);
  background: var(--bg);
}

a { color: var(--ink); text-decoration: none; border-bottom: 1px solid transparent; }
a:hover { color: var(--leaf-dk); border-bottom-color: currentColor; }
code { font-family: "SF Mono", Menlo, Consolas, monospace; font-size: 0.92em; color: var(--ink); }

/* Top bar */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--ink); color: var(--cream);
  padding: 12px 24px;
  border-bottom: 3px solid var(--sun);
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: 0.2px; }
.logo-dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--leaf);
  box-shadow: 0 0 0 3px rgba(31, 168, 74, 0.25);
}
.env-tag {
  font-size: 11px; padding: 2px 8px; border-radius: 999px;
  background: var(--sun); color: var(--ink);
  text-transform: uppercase; letter-spacing: 0.5px; font-weight: 700;
}
.topbar nav a {
  color: var(--cream); margin-left: 20px; opacity: 0.9;
  border-bottom: none;
}
.topbar nav a:hover { opacity: 1; color: var(--sun); }

/* Page */
.page { max-width: 1100px; margin: 0 auto; padding: 32px 24px 80px; }

h1 { font-size: 28px; margin: 0 0 8px; color: var(--ink); }
h2 { font-size: 18px; margin: 24px 0 8px; color: var(--ink); }
p.muted, .muted { color: var(--muted); }
.back { color: var(--muted); font-size: 13px; }

/* Cards */
.grid { display: grid; gap: 16px; grid-template-columns: 1fr; margin-top: 16px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 18px 20px;
  transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
}
.card:hover {
  border-color: var(--leaf);
  box-shadow: 0 2px 12px rgba(10, 71, 49, 0.06);
}
.card h2 { margin-top: 0; }
.card-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.card .meta { margin-top: 10px; font-size: 12px; color: var(--muted); display: flex; flex-wrap: wrap; gap: 14px; }

/* Buttons */
button, .primary {
  background: var(--cream-soft); border: 1px solid var(--rule);
  padding: 8px 14px; border-radius: 999px; cursor: pointer;
  font: inherit; color: var(--ink); font-weight: 600;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
button:hover { border-color: var(--leaf); color: var(--leaf-dk); }

button.primary, .primary {
  background: var(--leaf); color: white; border-color: var(--leaf);
}
button.primary:hover, .primary:hover {
  background: var(--leaf-dk); border-color: var(--leaf-dk); color: white;
}

/* Tables */
table.runs { width: 100%; border-collapse: collapse; margin-top: 12px; }
table.runs th, table.runs td { padding: 10px 12px; border-bottom: 1px solid var(--rule); text-align: left; font-size: 14px; }
table.runs th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }

/* Badges */
.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; background: var(--sand); color: var(--ink); font-size: 11px; font-weight: 600; }
.badge-success, .badge-RunStatus\.SUCCESS { background: #D2EBD6; color: var(--leaf-dk); }
.badge-running, .badge-RunStatus\.RUNNING { background: #FFE9A3; color: #8A5A00; }
.badge-failed, .badge-RunStatus\.FAILED { background: #F8D7C1; color: #8C3A0A; }

/* Forms */
.form-grid { display: grid; gap: 10px; grid-template-columns: 1fr 1fr; margin-top: 10px; }
.form-grid label { display: flex; flex-direction: column; font-size: 13px; color: var(--muted); gap: 4px; }
.form-grid input,
.form-grid select {
  padding: 8px 12px; border: 1px solid var(--rule); border-radius: 8px; font: inherit;
  background: white; color: var(--slate);
}
.form-grid input:focus,
.form-grid select:focus {
  outline: none; border-color: var(--leaf);
  box-shadow: 0 0 0 3px rgba(31, 168, 74, 0.15);
}
.form-grid fieldset { border: 1px dashed var(--rule); border-radius: 8px; padding: 12px 14px; }
.form-grid legend { padding: 0 6px; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }

/* Chat */
.chat { display: flex; flex-direction: column; gap: 12px; margin: 20px 0; min-height: 200px; }
.msg { background: var(--surface); border: 1px solid var(--rule); border-radius: 12px; padding: 12px 14px; }
.msg-role { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px; }
.msg-body { line-height: 1.55; }
.msg-user { background: #FFF7D6; border-color: #F2E6A8; }
.msg-assistant { border-left: 3px solid var(--leaf); }
.tool-trace { margin-top: 8px; font-size: 12px; color: var(--muted); }
.tool-trace summary { cursor: pointer; }
.chat-form { display: flex; gap: 8px; }
.chat-form input { flex: 1; padding: 10px 14px; border: 1px solid var(--rule); border-radius: 999px; font: inherit; background: white; }
.chat-form input:focus { outline: none; border-color: var(--leaf); box-shadow: 0 0 0 3px rgba(31, 168, 74, 0.15); }

/* Footer */
.footer { color: var(--muted); font-size: 12px; text-align: center; padding: 24px; border-top: 1px solid var(--rule); }
