:root {
  --indigo: #4f46e5;
  --navy: #1e1b4b;
  --bg: #0f0e1d;
  --panel: #1a1830;
  --panel-2: #221f3d;
  --text: #e8e7f3;
  --muted: #9a97b8;
  --line: #322e54;
  --green: #34d399;
  --amber: #fbbf24;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: radial-gradient(1200px 600px at 70% -10%, #2a2553 0%, var(--bg) 55%);
  color: var(--text);
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 22px; border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: baseline; gap: 8px; }
.brand .logo { color: var(--indigo); font-size: 22px; transform: translateY(2px); }
.brand .name { font-weight: 700; font-size: 20px; letter-spacing: -0.01em; }
.brand .sub { font-weight: 600; font-size: 20px; color: var(--muted); }
.brand .tag {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em;
  background: var(--indigo); color: white; padding: 2px 7px; border-radius: 999px;
  transform: translateY(-2px);
}
.built-on { color: var(--muted); font-size: 13px; }
.built-on a { color: #b9b4ff; text-decoration: none; }
.link-btn { background: none; border: 0; color: #b9b4ff; cursor: pointer; font-size: 13px; padding: 0; text-decoration: underline; }

.settings {
  max-width: 1400px; margin: 14px auto 0; padding: 16px 18px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
}
.settings h2 { margin: 0 0 6px; font-size: 15px; }
.settings .row { display: flex; gap: 12px; }
.settings .row .field { flex: 1; }
.settings code { background: var(--panel-2); padding: 1px 5px; border-radius: 4px; font-size: 12px; }

.banner {
  background: rgba(79, 70, 229, 0.14); border-bottom: 1px solid var(--line);
  color: #cfcbff; text-align: center; padding: 8px; font-size: 13px;
}
.notes {
  background: rgba(251, 191, 36, 0.12); border-bottom: 1px solid var(--line);
  color: var(--amber); text-align: center; padding: 6px; font-size: 13px;
}

.modelbar {
  max-width: 1400px; margin: 14px auto 0; padding: 10px 14px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
}
.ml-title { color: var(--muted); font-size: 13px; font-weight: 600; }
.ml-select { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 8px; padding: 6px 8px; font-size: 13px; }
.ml-load { background: var(--indigo); color: #fff; border: 0; border-radius: 8px; padding: 7px 12px; font-size: 13px; cursor: pointer; }
.ml-load:disabled { opacity: 0.5; cursor: progress; }
.model-status { font-size: 12px; color: var(--muted); flex: 1 1 240px; }
.model-status.loading { color: var(--amber); }
.model-status.ready { color: var(--green); }
.model-status.error { color: #fda4af; }

.side-note { color: var(--muted); font-size: 12px; margin: -4px 0 12px; }
.prov { margin-top: 8px; }
.prov summary { cursor: pointer; color: #b9b4ff; font-size: 12px; }
.prov-note { color: var(--muted); font-size: 12px; margin: 6px 0; }
.steps { margin: 4px 0 0; padding-left: 18px; display: flex; flex-direction: column; gap: 3px; }
.steps li { font-family: ui-monospace, Menlo, monospace; font-size: 11.5px; color: var(--muted); word-break: break-all; }
.steps li b { color: #b9b4ff; }

.grid {
  display: grid; grid-template-columns: 320px 1fr 340px; gap: 16px;
  padding: 18px; max-width: 1400px; margin: 0 auto; align-items: start;
}
@media (max-width: 1000px) { .grid { grid-template-columns: 1fr; } }

.panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  padding: 16px;
}
.panel h2 { margin: 0 0 12px; font-size: 14px; color: var(--muted); font-weight: 600; }

.field { display: block; margin-bottom: 12px; }
.field span { display: block; font-size: 12px; color: var(--muted); margin-bottom: 5px; }
.field input {
  width: 100%; padding: 9px 11px; border-radius: 9px; border: 1px solid var(--line);
  background: var(--panel-2); color: var(--text); font-size: 14px;
}
.field input:focus { outline: 2px solid var(--indigo); border-color: var(--indigo); }

.presets { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.presets button {
  font-size: 12px; padding: 5px 9px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--muted); cursor: pointer;
}
.presets button:hover { color: var(--text); border-color: var(--indigo); }

.run {
  width: 100%; padding: 11px; border: 0; border-radius: 10px; cursor: pointer;
  background: var(--indigo); color: white; font-weight: 600; font-size: 15px;
}
.run:hover { filter: brightness(1.08); }
.run:disabled { opacity: 0.5; cursor: progress; }
.reset {
  width: 100%; margin-top: 8px; padding: 8px; border-radius: 10px; cursor: pointer;
  background: transparent; color: var(--muted); border: 1px solid var(--line); font-size: 13px;
}
.hint { color: var(--muted); font-size: 12px; margin: 12px 0 0; }

.log { display: flex; flex-direction: column; gap: 12px; max-height: 70vh; overflow-y: auto; }
.empty { color: var(--muted); }
.empty.small { font-size: 13px; }

.rec { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.rec-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 10px 12px; background: var(--panel-2);
}
.rec-task { font-weight: 600; }
.rec-repo { color: var(--muted); font-size: 12px; }
.pill { font-size: 11px; padding: 3px 9px; border-radius: 999px; font-weight: 600; white-space: nowrap; }
.pill.macro { background: rgba(52, 211, 153, 0.16); color: var(--green); }
.pill.claude { background: rgba(79, 70, 229, 0.22); color: #c4bfff; }
.pill.unavailable { background: rgba(251, 191, 36, 0.16); color: var(--amber); }
.rec-body { padding: 10px 12px; }
.rec-summary { margin: 0 0 8px; }
.steps { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.steps li { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; color: var(--muted); }
.steps li b { color: #b9b4ff; }
.cost { margin-top: 8px; font-size: 12px; color: var(--muted); }

.grad { text-align: center; margin-bottom: 18px; }
.grad-label { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.grad-pct { font-size: 54px; font-weight: 800; line-height: 1.05; color: var(--green); }
.grad-bar { height: 8px; background: var(--panel-2); border-radius: 999px; overflow: hidden; margin: 8px 0 6px; }
.grad-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--indigo), var(--green)); transition: width 0.6s ease; }
.grad-sub { color: var(--muted); font-size: 12px; }

.count { background: var(--panel-2); color: var(--muted); border-radius: 999px; padding: 1px 8px; font-size: 12px; }
.macros { display: flex; flex-direction: column; gap: 10px; }
.macro-card { border: 1px solid var(--line); border-radius: 11px; padding: 11px; background: var(--panel-2); animation: pop 0.4s ease; }
.macro-card .mc-top { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.macro-card .mc-name { font-family: ui-monospace, Menlo, monospace; font-weight: 700; color: #c4bfff; }
.macro-card .mc-intent { color: var(--muted); font-size: 12px; margin: 6px 0; }
.macro-card .mc-meta { display: flex; flex-wrap: wrap; gap: 5px; }
.chip { font-size: 11px; padding: 2px 7px; border-radius: 999px; background: var(--panel); color: var(--muted); border: 1px solid var(--line); }
.chip.auto { color: var(--green); border-color: rgba(52,211,153,.4); }
.chip.candidate { color: var(--amber); border-color: rgba(251,191,36,.4); }
@keyframes pop { from { transform: scale(0.96); opacity: 0; } to { transform: scale(1); opacity: 1; } }
