:root {
  --bg: #0e0f0d;
  --panel: #161814;
  --panel-2: #1c1f1a;
  --moss: #3d6b3a;
  --moss-deep: #1f3a1d;
  --moss-bright: #6aa05f;
  --ember: #ff7a2e;
  --gold: #f5c352;
  --bone: #f4f1ea;
  --muted: #8b8f86;
  --line: #2a2d27;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background:
    radial-gradient(ellipse at 50% 0%, #1c2a1a 0%, #0e0f0d 60%) fixed,
    var(--bg);
  color: var(--bone);
  min-height: 100vh;
  font-size: 14px;
  line-height: 1.55;
}
a { color: var(--bone); text-decoration: none; }
a:hover { color: var(--gold); }
.muted { color: var(--muted); }

/* ---- SITE BAR (matches /pet/) ---- */
.site-bar {
  position: sticky; top: 0; z-index: 30;
  height: 56px;
  display: grid;
  grid-template-columns: minmax(230px, 1fr) auto minmax(230px, 1fr);
  align-items: center;
  padding: 0 28px;
  background: rgba(14,15,13,0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 8px 24px rgba(0,0,0,0.22);
}
.site-bar-brand { display: inline-flex; align-items: center; gap: 10px; }
.site-bar-mark  { display: inline-flex; }
.site-bar-mark img { display: block; border-radius: 5px; object-fit: contain; }
.site-bar-name  { font-family: 'EB Garamond', serif; font-size: 18px; letter-spacing: 0.01em; }
.site-bar-nav   {
  grid-column: 2;
  display: flex; align-items: center; justify-content: center; gap: 4px;
  background: rgba(22,24,20,0.78);
  border: 1px solid rgba(42,45,39,0.9);
  border-radius: 999px;
  padding: 4px;
  overflow-x: auto;
  white-space: nowrap;
  scrollbar-width: none;
  max-width: min(860px, calc(100vw - 360px));
}
.site-bar-nav::-webkit-scrollbar { display: none; }
.site-bar-link  {
  font-size: 13px; color: var(--muted);
  letter-spacing: 0.01em; transition: color 0.15s ease, background 0.15s ease;
  display: inline-flex; align-items: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
}
.site-bar-link:hover {
  color: var(--bone);
  background: rgba(244,241,234,0.05);
}
.site-bar-link.active {
  color: var(--gold);
  font-weight: 600;
  background: rgba(245,195,82,0.1);
}
@media (max-width: 720px) {
  .site-bar {
    display: flex;
    justify-content: center;
    padding: 0 14px;
  }
  .site-bar-name {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .site-bar-nav { display: none; }
}

/* ---- BANNER STACK ---- */
.banner-stack {
  position: fixed;
  top: 60px; left: 50%; transform: translateX(-50%);
  width: min(960px, calc(100vw - 32px));
  z-index: 20;
  display: flex; flex-direction: column; gap: 8px;
  pointer-events: none;
}
.banner {
  pointer-events: auto;
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  font-size: 13px; line-height: 1.4;
}
.banner code { background: rgba(0,0,0,0.4); border: 1px solid var(--line); border-radius: 4px; padding: 1px 6px; color: var(--gold); font-size: 12px; }
.banner.warn   { border-color: #5a4a26; background: rgba(245,195,82,0.07); color: #f4ddae; }
.banner.error  { border-color: #6a1414; background: rgba(255,80,40,0.07);  color: #ffd0c4; }
.banner.demo   { border-color: var(--ember); background: rgba(255,122,46,0.08); color: #ffe2cf; }
.banner.info   { border-color: var(--moss-deep); background: rgba(106,160,95,0.06); color: #d2e2cd; }
.banner-icon   { font-size: 18px; flex: 0 0 auto; }
.banner-body   { flex: 1; }
.banner-close  { background: transparent; border: none; color: inherit; opacity: 0.6; cursor: pointer; font-size: 16px; }
.banner-close:hover { opacity: 1; }

/* ---- PAGE LAYOUT ---- */
.page {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 24px 48px;
}

.card-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.card-head h1 { font-family: 'EB Garamond', serif; font-size: 28px; margin: 0; line-height: 1; }
.card-head h2 { font-family: 'EB Garamond', serif; font-size: 22px; margin: 0; line-height: 1; }

/* ---- OVERVIEW CARD ---- */
.overview-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px 18px;
  margin-bottom: 24px;
}
.overview-lede {
  margin: 0 0 14px;
  font-size: 13.5px;
  color: #cdd1c7;
  line-height: 1.55;
  max-width: 720px;
}
.overview-lede b { color: var(--gold); }
.roster-help {
  margin: -4px 0 10px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
}
.modal-lede {
  margin: 0 0 14px;
  font-size: 13px;
  color: #cdd1c7;
  line-height: 1.5;
}
.modal-lede b { color: var(--gold); }
.pill.state-disabled { color: var(--muted); border-color: var(--line); }
.overview-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
.ov-tile {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 14px;
}
.ov-num { font-family: 'EB Garamond', serif; font-size: 28px; color: var(--gold); line-height: 1; }
.ov-num.mode-swarms { color: var(--gold); }
.ov-num.mode-local  { color: var(--moss-bright); }
.ov-num.mode-demo   { color: var(--ember); }
.ov-num.swarms-on   { color: var(--gold); }
.ov-num.swarms-off  { color: var(--muted); }
.ov-num.swarms-bad  { color: #ff5a5a; }
.ov-lbl { font-size: 10.5px; color: var(--muted); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }
@media (max-width: 900px) { .overview-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---- BUTTONS ---- */
.btn-primary, .btn-ghost {
  border: 1px solid transparent;
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  font-weight: 600;
  font-size: 13px;
  padding: 8px 16px;
}
.btn-primary { background: var(--gold); color: #1a1408; }
.btn-primary:hover { background: #ffd56b; }
.btn-ghost { background: transparent; color: var(--ember); border-color: #5e3a18; }
.btn-ghost:hover { background: rgba(255,122,46,0.1); }
.btn-ghost.gold { color: var(--gold); border-color: #5a4a26; }
.btn-ghost.gold:hover { background: rgba(245,195,82,0.1); }
.btn-ghost:disabled { opacity: 0.45; cursor: not-allowed; }

/* ---- SPLIT ---- */
.split {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 22px;
  align-items: start;
}
@media (max-width: 1100px) {
  .split { grid-template-columns: 1fr; }
  .inspector { order: -1; }
}

/* ---- ROSTER ---- */
.roster-section {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 18px;
}
.roster-section h2 {
  font-family: 'EB Garamond', serif;
  font-size: 19px;
  margin: 0 0 12px;
  color: var(--bone);
}
.agent-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 10px;
}
.empty-cell {
  padding: 14px 10px;
  font-size: 13px;
  color: var(--muted);
  font-style: italic;
}
.empty-cell a { color: var(--gold); text-decoration: underline dotted; }

.agent-card {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 14px;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.12s ease;
  display: flex; gap: 12px;
  align-items: flex-start;
}
.agent-card:hover { border-color: var(--gold); transform: translateY(-1px); }
.agent-card.selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold);
}
.agent-card.disabled-row { opacity: 0.55; }
.agent-card .ac-avatar {
  flex: 0 0 auto;
  width: 72px; height: 72px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, #f4f1ea 0%, #e9dec7 100%);
  border-radius: 8px;
  overflow: hidden;
  line-height: 0;
}
.agent-card .ac-body   { flex: 1; min-width: 0; }
.agent-card .ac-row1   {
  display: flex; align-items: center; gap: 8px;
  font-weight: 600; color: var(--bone); font-size: 14px;
  margin-bottom: 2px;
}
.agent-card .ac-row1 .kind {
  font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--moss-bright);
}
.agent-card .ac-row1 .kind.custom { color: var(--gold); }
.agent-card .ac-desc {
  color: #cdd1c7;
  font-size: 12.5px;
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.agent-card .ac-meta {
  display: flex; gap: 8px; flex-wrap: wrap;
  font-size: 10.5px;
  color: var(--muted);
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.agent-card .ac-meta .pill {
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 1px 7px;
  text-transform: uppercase;
  font-size: 9.5px;
  letter-spacing: 0.08em;
}
.agent-card .ac-meta .pill.mode-swarms { color: var(--gold);        border-color: #5a4a26; }
.agent-card .ac-meta .pill.mode-local  { color: var(--moss-bright); border-color: var(--moss-deep); }
.agent-card .ac-meta .pill.mode-demo   { color: var(--ember);       border-color: var(--ember); }

/* ---- RUNS LIST ---- */
.runs-list { display: flex; flex-direction: column; gap: 6px; }
.run-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--line);
  border-radius: 8px;
  cursor: pointer;
  font-size: 12.5px;
}
.run-row:hover { border-color: var(--gold); }
.run-row .run-name { font-weight: 600; color: var(--bone); }
.run-row .run-meta { color: var(--muted); font-size: 11.5px; }
.run-row .run-mode {
  font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 999px;
  border: 1px solid var(--line);
}
.run-row .run-mode.mode-swarms { color: var(--gold); border-color: #5a4a26; }
.run-row .run-mode.mode-local  { color: var(--moss-bright); border-color: var(--moss-deep); }
.run-row .run-mode.mode-demo   { color: var(--ember); border-color: var(--ember); }

/* ---- INSPECTOR (right column) ---- */
.inspector {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
  position: sticky; top: 64px;
  max-height: calc(100vh - 88px);
  overflow-y: auto;
}
.inspector-meta {
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--muted);
}
.inspector-body { font-size: 13px; }
.empty-actions {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 14px;
}

/* hero block when an agent is selected */
.insp-hero {
  display: flex; align-items: center; gap: 14px;
  padding: 6px 0 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 14px;
}
.insp-hero-name { font-family: 'EB Garamond', serif; font-size: 22px; color: var(--bone); line-height: 1; }
.insp-hero-pills { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase;
  border: 1px solid var(--line);
}
.pill.kind-builtin { color: var(--moss-bright); border-color: var(--moss-deep); }
.pill.kind-custom  { color: var(--gold); border-color: #5a4a26; }
.pill.mode-swarms  { color: var(--gold); border-color: var(--gold); }
.pill.mode-local   { color: var(--moss-bright); border-color: var(--moss-deep); }
.pill.mode-demo    { color: var(--ember); border-color: var(--ember); }

.insp-section { margin-bottom: 14px; }
.insp-section h5 {
  margin: 0 0 6px;
  font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--moss-bright);
  font-weight: 600;
}
.insp-section.custom-h5 h5 { color: var(--gold); }
.insp-row {
  display: flex; gap: 8px; align-items: baseline;
  margin: 3px 0; font-size: 12.5px; color: #cdd1c7;
}
.insp-row .label {
  font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--muted); min-width: 90px;
}
.insp-section ul { margin: 4px 0; padding-left: 18px; }
.insp-section li { font-size: 12.5px; margin: 2px 0; }
.insp-preview {
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11.5px;
  color: var(--bone);
  white-space: pre-wrap; word-break: break-word;
  max-height: 220px;
  overflow-y: auto;
}
.insp-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.insp-actions .btn-ghost { padding: 5px 12px; font-size: 12px; }

.test-result {
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 12px;
  color: #cdd1c7;
  margin-top: 8px;
}
.test-result code { background: rgba(0,0,0,0.4); border: 1px solid var(--line); border-radius: 4px; padding: 1px 5px; color: var(--gold); font-size: 11.5px; }

/* ---- AGENT AVATAR (shared rendering) ---- */
.agent-avatar { display: inline-block; vertical-align: middle; filter: drop-shadow(0 1px 1px rgba(0,0,0,0.4)); --accent: #f5c352; }
.agent-avatar-state-idle      { animation: ava-idle 3.6s ease-in-out infinite; }
.agent-avatar-state-running   { animation: ava-bob  0.9s ease-in-out infinite; }
.agent-avatar-state-confessing{ animation: ava-bow  1.4s ease-in-out infinite; filter: drop-shadow(0 2px 4px rgba(255,122,46,0.6)); }
.agent-avatar-state-done      { animation: ava-pop  0.6s ease-out 1; filter: drop-shadow(0 2px 4px rgba(106,160,95,0.6)); }
.agent-avatar-state-failed    { animation: ava-shake 0.4s ease-in-out 3; filter: grayscale(0.5); }
@keyframes ava-idle  { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-1px); } }
@keyframes ava-bob   { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@keyframes ava-bow   { 0%,100% { transform: translateY(0)   rotate(0); } 50% { transform: translateY(2px) rotate(-3deg); } }
@keyframes ava-pop   { 0% { transform: scale(1); } 40% { transform: scale(1.15); } 100% { transform: scale(1); } }
@keyframes ava-shake { 0%,100% { transform: translateX(0); } 25% { transform: translateX(-2px); } 75% { transform: translateX(2px); } }

/* ---- MODAL ---- */
.modal {
  position: fixed; inset: 0; z-index: 50;
  display: flex; align-items: flex-start; justify-content: center;
}
/* The browser's implicit [hidden] { display: none } loses to the
   .modal { display: flex } rule above, so we explicitly hide it
   when the `hidden` attribute is set. Without this, closing the
   modal sets hidden=true but the user still sees the dialog. */
.modal[hidden] { display: none; }
body.modal-open { overflow: hidden; }
.modal-shade {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(2px);
  cursor: pointer;
}
.modal-body {
  position: relative;
  width: min(720px, calc(100vw - 32px));
  margin-top: 7vh;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 26px 18px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
  max-height: 86vh;
  overflow-y: auto;
}

/* ---- FORM ---- */
.agent-form { font-size: 13px; }
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.form-grid.four-up { grid-template-columns: repeat(4, 1fr); }
.form-grid.two-up  { grid-template-columns: 2fr 1fr; }
@media (max-width: 720px) {
  .form-grid, .form-grid.four-up, .form-grid.two-up { grid-template-columns: 1fr; }
}
.form-row { margin-bottom: 12px; }
.form-row label {
  display: block;
  font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; margin-bottom: 4px;
}
.form-row .req { color: var(--ember); margin-left: 2px; }
.form-row small { color: var(--muted); font-size: 11px; }
.form-row input:not([type=color]):not([type=checkbox]),
.form-row textarea,
.form-row select {
  width: 100%;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--bone);
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
  outline: none; border-color: var(--gold);
}
.form-row textarea { resize: vertical; min-height: 90px; }
.form-row input[type=color] {
  width: 100%; height: 40px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 8px; cursor: pointer;
}
.checks { display: flex; flex-direction: column; gap: 4px; font-size: 12.5px; }
.checks label, .switch {
  text-transform: none; letter-spacing: 0; font-weight: 400;
  color: var(--bone); font-size: 12.5px;
  display: inline-flex; align-items: center; gap: 6px;
}
.form-actions { display: flex; gap: 8px; margin-top: 12px; }
.form-error   { margin-top: 8px; min-height: 14px; font-size: 12px; color: #ffb09a; }

.avatar-picker { display: flex; gap: 8px; flex-wrap: wrap; }
.avatar-pick {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 4px;
  cursor: pointer;
  display: inline-flex; line-height: 0;
}
.avatar-pick:hover    { border-color: var(--gold); }
.avatar-pick.selected { border-color: var(--gold); box-shadow: 0 0 0 2px rgba(245,195,82,0.25); }

/* Pet-skin picker (Create/Edit Pet Agent modal) ------------------------ */
.skin-picker {
  display: flex; gap: 8px;
  overflow-x: auto;
  padding: 6px 2px;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}
.skin-picker::-webkit-scrollbar { height: 6px; }
.skin-picker::-webkit-scrollbar-thumb { background: var(--line); border-radius: 999px; }
.skin-pick {
  flex: 0 0 auto;
  width: 96px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px;
  cursor: pointer;
  text-align: center;
  scroll-snap-align: start;
  transition: border-color 0.12s ease;
}
.skin-pick:hover { border-color: var(--gold); }
.skin-pick.selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(245,195,82,0.25);
}
.skin-pick .skin-thumb {
  height: 78px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, #f4f1ea 0%, #e9dec7 100%);
  border-radius: 6px;
  margin-bottom: 4px;
  overflow: hidden;
}
.skin-pick.skin-pick-none .skin-thumb {
  background: rgba(0,0,0,0.25);
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.skin-pick .skin-name {
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--bone);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.skin-picker-empty {
  font-size: 12px; color: var(--muted);
  font-style: italic;
  padding: 14px 6px;
}

/* Unified avatar + skin picker (Create/Edit Pet Agent modal) ----------
   Two clearly-labelled sections inside one scrollable container:
     1. Badges (default SVG avatars)
     2. Installed skins (starters, Petdex, procedural, user imports)
   Each section is a CSS grid; the wrapper just controls scrolling. */
.avatar-skin-picker {
  display: block;
  margin-top: 6px;
  max-height: 320px;
  overflow-y: auto;
  padding: 8px 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,0.18);
}
.avatar-skin-picker .picker-section-label {
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
  padding: 4px 2px;
  margin-top: 4px;
}
.avatar-skin-picker .picker-section-label:first-child { margin-top: 0; }
.avatar-skin-picker .picker-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(56px, 1fr));
  gap: 6px;
  margin-bottom: 8px;
}
.avatar-skin-picker.loading { opacity: 0.7; }
.avatar-pick-tile {
  width: auto;
  padding: 3px;
}
.avatar-pick-tile .skin-thumb {
  height: 44px;
  margin-bottom: 2px;
  border-radius: 4px;
}
.avatar-pick-tile .skin-name {
  font-size: 9.5px;
  line-height: 1.1;
  letter-spacing: 0;
}
.avatar-pick-tile .skin-tag { display: none; }

#avatarPickerSearch {
  margin-bottom: 4px;
}
.pet-pager {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  margin-top: 10px;
}
.pet-pager .btn-ghost { padding: 4px 10px; font-size: 12px; }
.pet-pager:empty { display: none; }
